Variables

Taking a look at what you can do with the various variables within the action builder.

After reading this article you'll know:

  • What a variable is

  • The various types of variables

  • The scope in which variables are & can be used

What are variables

You can think of variables as storage for values, which you can reference by name. A variable can be assigned a different value at any time, making it usable in dynamic situations. For example, a coder can create a formula like a + b = c, using the 3 variables a , b and c . By assigning different values to the variables, this formula can be reused over and over and produce different outcomes.

A variable consists of a name and a type. The variable type indicates which kind of value this variable contains. For example a piece of text or a number.

Variable types

In the action builder, the following 4 variable types are available while building an action:

  • Action variables

  • Input variables

  • Step variables

  • Output variables

We'll go over each variable below.

Action variables

An action variable can be created and initialized with a value by clicking on the start step in the action flow.

By clicking on + Add you can add new variables to your action.

 

In the modal screen which is displayed to the user, the builder can select the variable kind, specify the name of the variable and initialize it with a value.

Editing the variable can be done by clicking on the variable in the list

Input variables

Input variables can be created by clicking on the start step. They cannot be initialized with a value in the action itself. Input variables are created in order to receive their value from the user of the action, which can for example be the page builder which sends values from input forms to the action as input variables.

To add new input variables to your action go the start step and click on the + Add button.

In the pop-up which is displayed to you, you can select the variable kind and specify the name of the variable.

Editing the variable can be done by clicking on the variable in the list.

Step variables

Step variables can be created in the configuration of a step itself.

You can add a new step variable by clicking on the + Add button when you have a step selected.

In the pop-up which is displayed to you, you can select the variable kind and specify the name of the variable.

Editing the variable can be done by clicking on the variable in the list.

Output variable

In the Finish step of the action, you can choose a variable (which was created within the action) that will be returned to the end-user as a result of the action.

The scope of variables

Variables are only available for use inside the region of the action they are created in. This is called the scope.

Variables like the action variable and the input variable are available within the scope of the whole action. Everywhere in the action, these variables can be read or changed.

Step variables are created in the scope of the step. Only in the step self, these variables can be used. A step variable, created in the ‘Create record’ step, can only be used in the Create record step, not in any subsequent steps, and not in any preceding steps. There are two step types that have a slightly different scope rule.

Steps with their own variables

Steps of this type can be identified by having a circle-shaped icon.

An example is the loop step. Variables defined in the loop step, are available to all steps configured in the context of the loop. They are not available anymore when the loop is finished.

For example; the variable “loop_iterator” created in the loop step above is available in the create record and log message step within the loop. But outside of the loop flow; this variable can not be used anymore.

Read more about the loop step here.

Variable types

The following variable types are available to any user while creating their action.

Text

 

description

stores a piece of text with a maximum of 4GiB of characters

example

“John Smith”

availability

action, input, step, output

Number

 

description

stores integers without decimals

example

123 or -123

availability

action, input, step, output

Checkbox

 

description

stores a value indicating a binary state: true or false

example

true

availability

action, input, step, output

JSON (only input)

 

description

stores a piece of text structure as a JSON object. see JSON

example

{company:"Betty Blocks",

house_number:7,

city:"Alkmaar"};

availability

action, input, step, output

Object (only input)

 

description

stores an object

example

-

availability

action, input, step, output

Array (only input)

 

description

stores one or multiple text or number variables

example

[1,2,3] or [“up”, “down”, “left”, “right”]

availability

action, input, step, output

Record (action var, step)

 

description

stores a database entry retrieved from a model

example

-

availability

action, input, step, output

Collection (action var, step)

 

description

stores one or multiple record variables

example

-

availability

action, input, step, output

All variable types can be used as output variables in the finish step.

Retrieving relational data via your variables, has a depth limit of 4 levels. After which Betty Blocks will display an error.
This limit is set to assist in optimally loading data in your application.