Approving Users
Oftentimes you'd like to manually approve and verify users, e.g. if you're a ridesharing company and you're approving drivers.
In this tutorial, we'll show you how to display users from a Rest Api in a table, and have a button that allows you to verify them, one by one.
data:image/s3,"s3://crabby-images/e17d6/e17d6960c44d618be497be41b9d7f2de939a2b70" alt="Messages Image(185735127).png 3260"
Begin by clicking Add Data Query, and choosing the Rest API Selector.
DataSiv provides integrations and read/write capabilities across multiple sources
Although we use Rest API in this tutorial, you can swap these out with other supported integrations, such as a Rest Api Endpoint, GraphQL, Salesforce, Stripe, etc.
data:image/s3,"s3://crabby-images/bc456/bc4563405bdbf4f9185e1f5d7c42bc1abbf7b871" alt="1.png 2500"
We will load users from a dummy Rest API to demo the functionality of this workflow. Make the url https://jsonplaceholder.typicode.com/users
.
data:image/s3,"s3://crabby-images/7750c/7750c48623270af0c082ce1806ecbf44d2da7763" alt="3.png 2396"
Name the query rest0, and set automatic execution to On Document Load. This will ensure that the query runs when the document loads.
data:image/s3,"s3://crabby-images/6f6d6/6f6d60a69ac78ac10b49a3ebe8c5915c240c3a99" alt="Messages Image(3908296001).png 2688"
Congratulations! We will now connect the data query to the frontend.
Add a Table frontend component into the grid, and click Edit data on the right side. Select queries.rest0.data
is your data source.
data:image/s3,"s3://crabby-images/e24d4/e24d4a6adb090507b5f30ad9835a901ce2414ed9" alt="5.png 1982"
Now that your table is setup, we'll setup a Approve button on the right side that you can click to approve users.
Start by adding a new Rest API endpoint. use jsonplaceholder.typicode.com
for the url and users/{{data.table0.activeRow.id}}
as the endpoint. The activeRow
property of a Table automatically changes to the hovered row when a user hovers over a table.
What are {{}} good for?
All component properties are stored in a global key value store that other components in the app are able to access. You are able to reference other components using javascript dictionary terminology.
Based on Django's templated {{}} syntax, the special
{{}}
expression allows you to substitute in values from one set of objects in your application to another. For example, in the Google Sheet query a few lines below,{{data.transform0.result.0.Artist Id}}
gets replaced by the Artist Id property of first entry in the transform result.
data:image/s3,"s3://crabby-images/f420a/f420ab9a67c39040ddbebd60e0ccdd527ec026e2" alt="6.png 2588"
This is a dummy endpoint, but you can set the Request Type to POST
and the request body to {"approve": true}
data:image/s3,"s3://crabby-images/85264/85264be392620ed110e4a0de2760c7a1883f4315" alt="Messages Image(4240637757).png 2700"
Set Automatic Execution to Never
and save the data query, we'll trigger this action on a button click.
data:image/s3,"s3://crabby-images/c697e/c697e972d842049df65db2874c5769f322b1baef" alt="14.png 2496"
Go back to the main menu, and select the table. From the right hand sidebar menu, click Edit Actions.
data:image/s3,"s3://crabby-images/9ec63/9ec63cdc4f6daf4033d9cc2df625b5f99a524577" alt="9.png 378"
Triggering data queries
The table's actions property allows you to specify and trigger data queries per row.
Add a new action called Approve, and set the code to Datasiv.ExecuteQuery("queries.rest1", {})
. Whenever the approve action is clicked, the code will execute.
data:image/s3,"s3://crabby-images/40429/40429f7071e4f94e64889b0009f8601ad0acf194" alt="Messages Image(3506106439).png 1982"
Congratulations! Your approval workflow is now done. You've loaded users from a Rest API, and can trigger an action on each user, based off of their data, such as approving them, on a button click.
data:image/s3,"s3://crabby-images/8deac/8deacdf3177c1698b0699323ac7fc950b1b23245" alt="Messages Image(185735127).png 3260"
Updated almost 2 years ago