Frontend Variables
Frontend Variables were previously known as State Variables. While the naming and Superblocks UI has changed slightly since the recording of the video below, the core concepts remain the same.
Frontend Variables allow users to create temporary (for the user session, resets on refresh) and local storage (stored in the browser across sessions) variables for their Superblocks Applications. The local storage variant makes use of the browser's Storage interface to write data to and read data from the client. With frontend variables, application builders can implement caching and re-use of intermediate state across different APIs / components.
Create a frontend variable
To create a frontend variable, open the Navigation panel then click the + sign next to Frontend Variables. Choose whether to create a Temporary variable or a Local storage variable from the dropdown menu.
data:image/s3,"s3://crabby-images/dd3bf/dd3bf920d30aa23761ddecaa897bf119428bacd1" alt="Create a new frontend variable from the Navigation panel Create a new frontend variable from the Navigation panel"
Click into the variable to open its properties panel where you can set the Default Value (initially an empty string, ""
) as well as edit the Persistence after creation.
data:image/s3,"s3://crabby-images/ebbc4/ebbc4d4d81f1059350272c44b3642e75f144d26d" alt="Set a default value for a frontend variable in the properties panel Set a default value for a frontend variable in the properties panel"
Alternatively, frontend variables can be created from a component's event handler menu when using the Set Frontend Variable action type. Under Variable, open the dropdown menu to create a new temporary variable or new local storage variable.
data:image/s3,"s3://crabby-images/0d137/0d137055f571903f031110f51d3a19bdf0f41db4" alt="Create a new frontend variables from a component's event handler menu Create a new frontend variables from a component's event handler menu"
Delete a frontend variable
To delete a frontend variable, click the more options menu (...
) next to the variable in the Navigation panel, then click Delete.
data:image/s3,"s3://crabby-images/5827b/5827bc42db588f7af946a46ed9c64c790cf93bf9" alt="Delete a frontend variable Delete a frontend variable"
Set a frontend variable
Frontend variables are stored on the client. Therefore, they live in the frontend scope of an application and cannot be set from a backend API.
Set frontend variables in response to events using the form-based Set Frontend Variable action type in an event handler.
In addition, you can set frontend variables from code using the predefined variable.set()
and variable.setProperty()
functions in frontend Run JS actions. Note these important considerations to avoid retrieving stale values when setting frontend variables in code.
Inspect a frontend variable
To see the current value for a frontend variable, go to the State Inspector panel and expand the variable dropdown.
data:image/s3,"s3://crabby-images/3c5c3/3c5c35f6370784a11e7167d2bd2392b16e8b8383" alt="See a variable's value in the State Inspector panel See a variable's value in the State Inspector panel"
In the same State Inspector panel, you can also click the more options menu (...
) next to the variable, then click Expand State to open an isolated view of only the selected variable's state. Click ← Show full state inspector
to go back to viewing the state of all resources.
data:image/s3,"s3://crabby-images/7d966/7d966e8aefb42fbdc3f6f6fc48fef71da8282cc4" alt="Expand state for a frontend variable Expand state for a frontend variable"
data:image/s3,"s3://crabby-images/09484/094849383548be6d291746b0891af0bce7f89bdb" alt="Isolated state for a variable Isolated state for a variable"
Note, you can open the same isolated view of a frontend variable's state from the Navigation panel with View state.
data:image/s3,"s3://crabby-images/823d7/823d78f4544054cea13e60b469b5381c110bd840" alt=""
Reset a frontend variable
Reset from state inspector
To reset a frontend variable to its default value, click the more options menu (...
) next to the variable in the State Inspector panel, then click Reset to default.
data:image/s3,"s3://crabby-images/e9456/e9456fab83b67454368ff0fdd661337e3823620f" alt="Reset a frontend variable to its default value from the State Inspector Reset a frontend variable to its default value from the State Inspector"
Reset with event handler
Reset frontend variables in response to events using the form-based Reset Frontend Variable to Default action type in an event handler.
In addition, you can reset frontend variables from code using the predefined variable.resetToDefault()
function in frontend Run JS actions.
Reference a frontend variable
You can reference frontend variables in components, frontend code, and backend APIs using <VAR_NAME>.value
.
When referencing variables in non-language steps (i.e. not JavaScript and not Python) as well as non JS form fields, be sure to surround variables in {{}}
bindings.
Some examples include:
Frontend component
data:image/s3,"s3://crabby-images/bc699/bc6992aadb015a5c6fcf5bbadc553a482521fe4d" alt="Reference frontend variable in a Text component Reference frontend variable in a Text component"
Backend SQL step
data:image/s3,"s3://crabby-images/d2163/d21639d9498a98ab993fcbcd237ad3486deed032" alt="Reference frontend variable in a SQL step Reference frontend variable in a SQL step"
Backend condition block
data:image/s3,"s3://crabby-images/95327/95327e29fb3cdf47fcfb9f2cdb90da75f689e0be" alt="Reference frontend variable in a Condition block Reference frontend variable in a Condition block"
Backend Python step
data:image/s3,"s3://crabby-images/d0171/d017128e1d30782f2b40948ae7d1c8745525f911" alt="Reference frontend variable in a Python step Reference frontend variable in a Python step"