Step-by-Step Guide on How to Build a Web Application with Velo

Written by velo | Published 2021/04/02
Tech Story Tags: tutorial | beginners | javascript | wix | velo | front-end-development | website-development | coding-with-velo

TLDR Velo by Wix is a full-stack development platform that empowers you to rapidly build, manage and deploy professional web apps. We created our own version of a "Hello, World!" example: a simple currency converter site that uses the wix-fetch API to connect to a third-party service. Site visitors choose source and target currencies from dropdowns and enter an amount to convert. The code for this example is added to a single page on the site using the Velo-based API.via the TL;DR App

Velo by Wix is an innovative product that lets you build robust web applications with zero setup. Work in Wix's visual builder, add custom functionality and interactions using Velo APIs, and enjoy serverless coding in both the front-end and backend. With Velo, your web app can be up and running in a fraction of the time it would normally take you.To introduce you to Velo, we created our own version of a "Hello, World!" example: a simple currency converter site that uses the wix-fetch API to connect to a third-party service. Site visitors choose source and target currencies from dropdowns and enter an amount to convert. The results are displayed in a text box.
Follow the steps below to get familiar with the basic structure and syntax of Velo.

Step 1: Create a New Wix Site

  1. Sign into your Wix account or sign up for a Wix account if you don’t already have one.
  2. Open a blank template in the Editor.

Step 2: Enable Velo

Enable Velo in the Wix Editor to let you work with code in your site.

Step 3: Add Elements to the Page

Add page elements in the Wix Editor: 
  1. On the left side of the Editor, click Add.
  2. Add the page elements illustrated below to your site.
    • When you add each element, set its ID in the Properties & Events panel that appears on the right side of the Code Panel. Use the name shown below for each element, minus the hashtag. See the table below for a full list of the elements and where to find them in the Add menu.
Element: Dropdown
Location in Add Menu:
User Input
Description: For selecting the source currency
ID: sourceCurrency
Element: Dropdown
Location in Add Menu: User Input
Description: For electing the target currency
ID: targetCurrency
Element: Input
Location in Add Menu: User Input
Description: For entering the amount to convert
ID: sourceAmount
Element: Textbox
Location in Add Menu: User Input
Description: To display the converted amount
ID: targetCurrency
Element: Button
Location in Add Menu: Button
Description: To trigger the currency conversion when clicked
ID: calculateButton

Step 4: Add Code

NOTES:
All the code for this example is added to a single page on the site. In this section we divided the code into short blocks followed by explanations. To see the complete code for this example without comments, scroll down to the end of the tutorial. 

See our API Reference to learn more about the Velo-based code in this example.
To add the code:
  1. Double-click Home Page Code at the bottom of the Editor to open the Code Panel.
  2. Add the following code to the top of the code in the tab before the onReady function:
    // The getJSON function in wix-fetch lets you retrieve a
    // JSON resource from the network using HTTPS.
    import {getJSON} from 'wix-fetch';
    
    // Set the URL of the 3rd-party service.
    const url = "https://api.exchangeratesapi.io/latest";
    
    // Define the currency option values and text for the dropdowns.
    let currencyOptions = [
      { "value": "USD",  "label": "US Dollars"},
      { "value": "EUR",  "label": "Euros"},
      { "value": "JPY",  "label": "Japanese Yen"},
    ];
    3. Add the code below to the onReady function. Code inside the onReady function runs when the page loads.
    $w.onReady(function () {
      // Set the currency options for the dropdowns.
      populateDropdowns();
    
      // Set the onClick event handler for calculateButton to calculate the target amount.
      $w('#calculateButton').onClick((event) => {
        calculateCurrency();
      })
    });
    The $w function can select elements on a page by ID or by type, allowing us to run functions and define the properties of the elements. Use this syntax to select an element by ID, $w("#myElementId"), and this syntax to select by type, $w("ElementType").
    Here we select the button and define an onClick event handler to calculate the target amount.
    4. Add code to define the functions:
    populateDropdowns( )
    // Populate the dropdowns.
    function populateDropdowns(){
      //Set the dropdown options.
      $w("Dropdown").options = currencyOptions;
      // Set the first dropdown option as the initial option.
      $w("Dropdown").selectedIndex = 0;
    }
    Here we select all the dropdowns by type. By calling $w with the element type "Dropdown", we select all dropdowns on the page.
    calculateCurrency( )
    // Calculate the target amount.
    function calculateCurrency() {
      // Initial amount 
      let initialAmount = $w("#sourceAmount").value;
      // Original currency
      let sourceSymbol = $w("#sourceCurrency").value;
      // Target currency
      let targetSymbol = $w("#targetCurrency").value;
      // Define the full url.
      let fullUrl = `${url}?base=${sourceSymbol}&symbols=${targetSymbol}`;
        
      // Call the wix-fetch API function to retrieve the JSON resource.
      getJSON(fullUrl)
      .then(json => {
        // Set the target amount as the initial amount multiplied by
        // the conversion rate.
        $w("#targetAmount").value = initialAmount * json.rates[targetSymbol];
      }
    )}
    We use template literals to define the full URL, which includes the source and target currencies.
    The wix-fetch API getJSON function retrieves the JSON resource using the full URL. getJSON returns a promise, which resolves to a JSON object.
    We multiply the retrieved rate by the initial amount and assign it to the targetAmount text box.

    Step 5: See It in Action

    Now it's time to test your site:
  1. Click Preview at the top right of the Editor.
  2. Enter an amount in the source currency input.
  3. Click the calculate button and see the converted currency result in the target amount text box.
  4. Publish your site to make it live and production ready.
That's it! In just a few minutes, you created a web application in Velo! No setup, no managing server infrastructure, just integrating Velo APIs with the Wix visual builder.

Next Steps

Now that you've had a taste of Velo, check out what else you can do:
  • Easily call backend code from the frontend using web modules
  • Work with Wix's visual builder.
  • Add features and customize your site using Velo APIs. Here are some examples of what you can do:

Example Code

Here is the complete code for this example, without comments:
import {getJSON} from 'wix-fetch';

const url = "https://api.exchangeratesapi.io/latest";

let currencyOptions = [
  { "value": "USD",  "label": "US Dollars"},
  { "value": "EUR",  "label": "Euros"},
  { "value": "JPY",  "label": "Japanese Yen"},
];

$w.onReady(function () {
  populateDropdowns();
 
  $w('#calculateButton').onClick((event) => {
    calculateCurrency();
  })
});

function populateDropdowns(){
  $w('Dropdown').options = currencyOptions;
  $w('Dropdown').selectedIndex = 0;
}

function calculateCurrency() {
  let initialAmount = $w("#sourceAmount").value;
  let sourceSymbol = $w("#sourceCurrency").value;
  let targetSymbol = $w("#targetCurrency").value;
  let fullUrl = `${url}?base=${sourceSymbol}&symbols=${targetSymbol}`;

  getJSON(fullUrl)
  .then(json => {
    $w("#targetAmount").value = initialAmount * json.rates[targetSymbol];
  }
)}

Written by velo | Velo is a full-stack development platform that empowers you to rapidly build, manage and deploy professional web apps.
Published by HackerNoon on 2021/04/02