The asynchronous function allows you to choose when you want to execute code. For example, you may want to delay the query execution or fetch the data on demand.
In the Appsmith environment, a function is termed as async if you are performing one of the below actions:
-
You have a keyword (async) that marks the asynchronous execution of the function.
export default{ functionName: async() => { //use async-await or promises } }
-
You have any in-built Appsmith functions like
showModal(), showAlert()
, etc., added in the function block. -
You want to execute a query or call an API on run time. For example, you have an API
GetUsersList,
and you want to call this API on runtime, that is, whenever the JS Object functioncallAPI()
is executed. Your function may look as below:export default { callAPI: () => { GetUsersList.run(); } }
The line of code GetUsersList.run()
marks the function callAPI()
for asynchronous execution and hence callAPI
function is considered as async.
A JavaScript Editor in Appsmith provides some additional settings for asynchronous functions that will help you add more configurations.
You can specify the settings in the Settings tab on the Appsmith JS Editor.
You’ll see the Settings tab next to Code whenever you have added an asynchronous function to the JS Object. Head to the Settings tab and click on it to reveal additional configurations.
Let’s quickly dive into these configurations to understand how they help you make your application behavior better.
Navigate to JS Object —> You’ll see Settings next to Code
Click on Settings to reveal configurations.
You get two settings to configure for asynchronous functions:
- RUN ON PAGE LOAD
- CONFIRM BEFORE CALLING
The settings are available at the function level. For every asynchronous function defined, you’ll have a corresponding configuration available for a run on page load and confirm before calling. Refer to the screenshot below, where you can see that the functions - myFun2 and showData have configurations available that you can define for them individually.
As the name suggests, you can use the configuration to mark that your function will be executed whenever a page is loaded. For example, you have a page User Listing
and have added a JS object with the function GetUserRole
which fetches the user’s role. You want that the query should be executed at the time of page load so that the logged-in user will be able to see the user listing. To get this working, you have to set the RUN ON PAGE LOAD configuration as YES for the GetUserRole
function. Once the configuration is in place, the function GetUserRole
will be executed whenever the app is loaded and the response generated by it will be displayed on the page.
{% embed url="https://youtu.be/yo2-XEt_EuU" %}
{% hint style="info" %}
By default, RUN ON PAGE LOAD is turned ON (Yes selected) for functions that display data on a widget. That is, the widget binds to the response generated by JSObjectName.asynFunctionName.data
. In this case, the on-page load is automatically set as true. You can explicitly change this setting to suit your logic in the Settings tab.
{% endhint %}
If you wish to delay the call of function on demand, then select No. It marks that the function will not be called on page load, and the execution will be deferred until called on demand by calling the function.
On Appsmith, you can bind execution of JS Objects on page load in either of two ways:
Bind Response to Widget
Whenever you bind a query or API response to a widget, Appsmith automatically sets the execution of the corresponding API or Query on page load. For example, you have a widget that refers to the data property of the JavaScript async function by adding {{JSObject.myFun.data}}
, at that time Appsmith marks the execution of that query/API on page load. You can modify the same by navigating to JSObject → Settings → RUN ON PAGE LOAD → Select No.
{% embed url="https://youtu.be/urnRIZ2xMJk" %} RUN ON PAGE LOAD Set to Yes when you bind function data to a widget {% endembed %}
Here’s a quick snapshot of how Appsmith triggers a query or API execution on page load:
- Add a table widget (Table1), and add a function in
JSObject5
that calls an APIgetUsers
. ThegetUsers
API call is embedded in theshowData
function and generates a user listing.
- Bind the response generated by
showData
to table widgetTable1
by adding the below code in theTable Data
property available on the property pane of the Table widget.
{{JSObject5.showData.data}} // behind the scenes Appsmith
// marks execution of showData on page load
// to get the response and bind it to the table data
Asynchronous Function Setting
Especially for asynchronous functions, you can explicitly mark the execution of an async function on page load for the corresponding JS Object.
Navigate to JS Object —> Click on Settings —> Select Yes for RUN ON PAGE LOAD next to the JS function. You are all set. Appsmith will take care of executing the async function on page load for you.
As shown in the screenshot below, you can see that the showData
function is called on page load, and Table1
displays the data.
With this setting, you can generate a confirmation pop-up and take the user’s input for executing the function. For example, the JS object has the function deletePermission
which calls an API that deletes the database’s permission. You would want to ensure that the user wants to delete permission, in which case, you would like to show a confirmation dialogue. The confirmation dialog ensures that the user wants to perform a delete action. A user can choose Yes to delete or can decline the same by choosing No. Thus Confirm Before Calling
comes in handy to protect against users accidentally running destructive operations.
Confirmation is like a nudge given to the user before executing a function. It ensures that the user is aware of the action that would be performed, and the same is not triggered by chance. A confirmation setting can only be defined explicitly from the Settings tab.
Navigate to JS Object —> Click on Settings —> Select Yes for CONFIRM BEFORE CALLING next to the JS function. You are all set. Appsmith will take care of executing and showing the confirmation dialogue to the user whenever the action is triggered.
Asynchronous function settings enable users to create complex workflows by executing functions before the application loads, allowing the data manipulation logic to run and make the desired outcome — secure function execution with a confirmation before you want application users to execute any critical operations.
Let’s understand the settings deeper with examples.
For example, you would want to apply restrictions in your application based on the user’s domain. That is, anonymous users (users who are not a part of your domain) cannot access certain application pages. You can quickly implement this by creating a function that uses the asynchronous function setting- Run on page load.
{% embed url="https://youtu.be/6wCD_fgd8TQ" %} Appsmith users Vs Non-Appsmith users {% endembed %}
Here’s a quick snapshot of steps that you can take to create this logic:
- Create an application and add two pages to it
- First Page (UserListingForAppsmithUsers)- Add a table, and rename it to
UserListing
which displays the data generated by theshowUserListing
function of theDataLoader
JS object. The function generates a list of users. - Second Page (AnonymousUser) - Displays a message to the user.
- First Page (UserListingForAppsmithUsers)- Add a table, and rename it to
- Create a JS object
DataLoader
and add a functionshowUserListing
that checks whether the user is logged in or not._ The function will verify the below logic:- If the user is logged in, then the
GetUserList
API will be called, and the response will be generated - If the user is not logged in or is not an appsmith user, redirect the user to the
AnonymousUser
page.
- If the user is logged in, then the
- Mark function
showUserListing
of JS Object - DataLoader to run on page load by selecting Yes.
UserListingForAppsmithUsers - DataLoader JS object Code. You can see that a function showUserListing
is marked for asynchronous execution by defining the async
keyword.
export default {
showUserListing: async () => {
//use async-await or promises
if(appsmith.user.isAnonymous) {
navigateTo("AnonymousUser");
}
//verify if the logged-in user is from appsmith
if(appsmith.user.email.match("appsmith")){
return GetUserList.run();
}else{
navigateTo("AnonymousUser");
}
}
}
For logged-in appsmith users, a user listing is shown as theGetUserList
API is executed:
Anonymous users - Whenever the application renders, the showUserListing
function is executed. The function determines whether the user is anonymous. You can use the property of a user object isAnonymous
to check the user's logged-in status.
appsmith.user.isAnonymous
Suppose the user is not logged in, then appsmith.user.isAnonymous
returns true
and redirects the user to the AnonymousUser
page and displays the message.
{% hint style="info" %} You are not authorized to view user data. {% endhint %}
If the user is logged in appsmith.user.isAnonymous
returns false
and the logic is executed to verify if the logged-in user is an Appsmith user. If the user is an Appsmith user, GetUserList
API is called to fetch the user listing. The execution is completed, and the response is generated, displayed in the UserListing
table.
You can use authentication and authorization using the Async function settings. To get started; view and fork the authentication application, view and fork the authorization application.
You can do authentication and authorization using the Async function settings. To get started, you can use one of the below applications:
With the out-of-the-box settings provided for async functions, you can manage the execution of your asynchronous functions and create a better user experience.