Items
The items are organized into the following categories:
# Display
Items for displaying information.
Item | Description |
---|---|
title |
Creates a title item. |
subtitle |
Creates a subtitle item. |
question |
Creates a question item. |
p |
Creates one or more paragraph items. |
code |
Creates a code item. |
image |
Creates an image item. |
link |
Action link. |
line |
Creates a separator line item. |
space |
Creates a space separator item. |
section |
Creates an section item. |
embed |
Creates an embedded item. |
# title
Creates a title item.
Attributes
type
title
value
Title text.
Accepts text formatting and variables.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Examples
{ "type": "title", "value": "This is a title" }
# subtitle
Creates a subtitle item.
Attributes
type
subtitle
value
Subtitle text.
Accepts text formatting and variables.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{ "type": "subtitle", "value": "This is a subtitle" }
# question
Creates a question item.
Attributes
type
question
value
Subtitle text.
Accepts text formatting and variables.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Examples
{ "type": "question", "value": "Is that a question?" }
# p
Creates one or more paragraph items.
Attributes
type
p
value
Paragraph text or list of text.
Accepts text formatting and variables.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Examples
{ "type": "p", "value": "This is a paragraph" }
Example with list of texts:
{ "type": "p", "value": [
"This is a paragraph",
"This is another paragraph"
]}
Example with text formatting and variables:
{ "type": "p", "value": "Your name is {{name}}" }
# code
Creates a code item.
Attributes
type
code
value
Code text.
Accepts text formatting and variables.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{ "type": "code", "value": "var x = 42;" }
# image
Creates an image item.
Attributes
type
image
src
The URL of the image or a command returning a URL.
Images can be of the type JPEG, GIF, PNG, SVG, ICO, and BMP.
width
optional
Width of the image.
height
optional
Height of the image.
alt
optional
Text description of the image.
title
optional
Title of the image presented as a tooltip.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{
"type": "image",
"src": "https://devgutt.github.io/evaluatly/static/img/luna-avatar.png",
"width": 200,
"title": "Luna picture"
}
# link
Action link.
Attributes
type
link
label
Link label.
url
optional
Link to a website (http:\\
or https:\\
), phone (tel:
) or email (mailto:
). The link will open in another tab or window.
If informed, the attribute program
is ignored.
program
optional
One or more commands to be executed.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Examples
{ "type": "link", "label": "Go to evaluatly", "url": "https://devgutt.github.io/evaluatly" }
{ "type": "link", "label": "Send an email", "url": "mailto:email@domain.com" }
Example with program:
{ "type": "link", "label": "Next", "program": {"next_page": true} }
# line
Creates a separator line item.
Attributes
type
line
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{ "type": "line" }
# space
Creates a space separator item.
Attributes
type
space
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{ "type": "space" }
# section
Creates a section item.
Attributes
type
section
items
List of items to be displayed.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{ "type": "section",
"items": [
{ "type": "title", "value": "The Story" },
{ "type": "p", "value": "Now this is the story all about how..." }
],
"style": {
"border": "1px solid red",
"background-color": "yellow"
}
}
# embed
Creates an embedded item.
Attributes
type
embed
src
The URL of the page to embed.
width
optional
Width of the item. Default: 560 pixels.
height
optional
Height of the item. Default: 315 pixels.
title
optional
Describe the embedded content.
allow
optional
Specifies a feature policy for the item.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
Example of embedded youtube video:
{
"type": "embed",
"src": "https://www.youtube.com/embed/ScMzIvxBSi4"
}
# Forms
Items for creating forms.
Item | Description |
---|---|
Inputs | Data input form. |
radio |
Single choice input form. |
check |
Multiple choice input form. |
button |
Action button. |
# Inputs
Data input form.
Attributes
type
type | Description |
---|---|
text | Text input |
name | Name input |
Email address input | |
phone | Phone number input |
number | Number input |
url | URL input |
password | Password input |
textlong | Multiline text input |
label
optional
The label of the input.
save_key
Key to save the information in the data table.
required
Indicates whether the field is required.
Values: true or false (default).
placeholder
optional
Text displayed when the input is empty.
autoFocus
Automatically focus the form control when the page is loaded.
Values: true or false (default).
min
optional
For inputs of the type number this attribute indicates the minimum number allowed. Otherwise, it indicates the minimum number of characters.
max
optional
For inputs of the type number this attribute indicates the maximum number allowed. Otherwise, it indicates the maximum number of characters.
step
optional
Increment number value. Defaults to 1.
This attribute is only available for number.
pattern
optional
Pattern the value must match to be valid.
This attribute is not available for textlong.
auto
Hint for form autofill feature.
Values: off (default), on, current-password, new-password
This attribute is only available for password.
multiple
Whether to allow multiple emails.
Values: true or false (default).
This attribute is only available for email.
style_label
optional
Style to be applied to the label as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
style_input
optional
Style to be applied to the input as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Examples
{ "type": "name", "save_key": "name", "required": true }
Simple contact form:
{ "items": [
{ "type": "name", "label": "Your name", "save_key": "name", "required": true },
{ "type": "email", "label": "Your email", "save_key": "email", "required": true },
{ "type": "textlong", "label": "Message", "save_key": "msg", "required": true }
]}
# radio
Single choice input form.
Attributes
type
radio
save_key
Key to save the information in the data table.
label
optional
The label of the input.
show_marker
optional
Shows the check marker. This attribute only works with input_submit
.
Values: true (default) or false.
show_ripple
optional
Shows the ripple effect when selected.
Values: true or false (default).
required
optional
Indicates whether the field is required.
Values: true or false (default).
style_label
optional
Style to be applied to the label as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
options
List of options. Option attributes:
id
optional
Option id. This value is saved in the data table with the property id
or the index if not informed.
value
optional
Option value. This value is saved in the data table with the property value
.
label
Option label. This value is saved in the data table with the property label
.
Accepts text formatting and variables.
description
optional
Option description.
style_container
optional
Style to be applied to the option container as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
style
optional
Style to be applied to the option as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{ "type": "radio",
"save_key": "color",
"label": "Choose a color:",
"required": true,
"options": [
{ "id": "R", "label": "Red", "value": 20 },
{ "id": "B", "label": "Blue", "value": 40 },
{ "id": "Y", "label": "Yellow", "value": 60 }
]
}
# check
Multiple choice input form.
Attributes
type
check
label
optional
The label of the input.
show_marker
optional
Shows the check marker. This attribute only works with input_submit
.
Values: true (default) or false.
show_ripple
optional
Shows the ripple effect when selected.
Values: true or false (default).
min
optional
The minimum number of check boxes must be checked to submit the form. Defaults to 0.
max
optional
The maximum number of checkboxes must be checked to submit the form. Defaults to unlimited.
error_range_msg
optional
The message shown to the user if the min
and max
limits are not respected. Defaults to "Out of range".
style_label
optional
Style to be applied to the label as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
options
List of options. Option attributes:
save_key
Key to save the information in the data table.
id
optional
Option id. This value is saved in the data table with the property id
or the index if not informed.
value
optional
Option value. This value is saved in the data table with the property value
.
label
Option label. This value is saved in the data table with the property label
.
Accepts text formatting and variables.
description
optional
Option description.
required
optional
Indicates whether the checkbox is required.
Values: true or false (default).
style_container
optional
Style to be applied to the option container as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
style
optional
Style to be applied to the option as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{ "type": "check",
"label": "Choose the colors you like:",
"min": 1, "max": 2,
"error_range_msg": "One or two colors",
"options": [
{ "save_key": "color-red", "id": "R", "label": "Red", "value": 20 },
{ "save_key": "color-blue", "id": "B", "label": "Blue", "value": 40 },
{ "save_key": "color-yellow", "id": "Y", "label": "Yellow", "value": 60 }
]
}
# button
Action button.
Attributes
type
button
label
Button label.
program
One or more commands to be executed.
style
optional
Style to be applied to the item as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Examples
{ "type": "button", "label": "Next", "program": {"next_page": true} }
Example with multiple commands:
{ "type": "button", "label": "Info", "program": [
{"save": ["info_read", true]},
{"alert": {"is": "info", "msg": "Go to the next page!"}},
{"next_page": true}
]
}
# Logic
Programming items.
Item | Description |
---|---|
exec |
Run one or more commands. |
render-If |
Conditional item display. |
fetch |
Calls an endpoint to fetch items to be displayed. |
fetch-js |
Calls a Javascript function to fetch items to be displayed. |
alert |
Shows or hides an alert popup. |
# exec
Run one or more commands.
Attributes
type
exec
delay
optional
Delay executing commands in milliseconds (1000 milliseconds = 1 second).
It will execute immediately if not informed (defaults to 0).
program
One or more commands to be executed.
Example
{"type": "exec", "delay": 500,
"program": [
{"console": "Executing commands"},
{"save": ["status", "ATIVE"]},
{"next_page": true}
]
}
# render-If
Conditional item display.
Attributes
type
render-If
value
List of sequential conditions to be tested.
Condition Attributes
cond
Function with conditional.
render
List of items to be displayed if the condition is met.
Example
{ "type": "render-If",
"value": [
{
"cond": {"==": [{"v": "color"}, "RED"]},
"render": [
{ "type" : "p", "value": "The color is red"}
]
},
{
"cond": {"==": [{"v": "color"}, "BLUE"]},
"render": [
{ "type" : "p", "value": "The color is blue"}
]
},
{
"render": [
{ "type" : "p", "value": "Color not informed"}
]
}
]
}
# fetch
Calls an endpoint to fetch items to be displayed.
Attributes
type
fetch
endpoint
The URL to be called to fetch the items. The URL can be an absolute or relative path.
data
optional
List of parameters to be sent to the endpoint. It could be a variable key or a key-value parameter.
For key-value parameters, the value can be a literal or a command.
If not informed, all variables that do not start with "_" (underscore) will be sent.
By default, the value
property of the variable is used. If the value
is empty, the id
or label
is used instead.
Examples
{ "type": "fetch", "endpoint": "https://example.com/endpoint/fetch_1" }
Example with variables and relative URL:
{ "type": "fetch",
"endpoint": "/api/fetch_1",
"data": [
"name",
"email",
{"name_label": {"l": "name"}},
{"status": "OPEN"}
]
}
Server processing
The instructions below show how to respond to requests initiated by the fetch
item.
Request
A POST
request will be called on the URL endpoint, using the endpoint
attribute.
The following parameters will be sent in the BODY
of the request:
Parameter | Description |
---|---|
hash |
the root attribute hash . |
origin |
The protocol, hostname, and port number of the caller's URL. |
data |
JSON with the parameters specified in the data attribute. |
Response
The server must respond with a JSON message containing the following parameters:
Parameter | Description |
---|---|
ok |
true |
res |
List of items to be displayed. |
if an error occurs:
Parameter | Description |
---|---|
ok |
false |
error_msg |
The error message to be shown to the user. |
error_code |
The error code. |
Example of response:
{
"ok": true,
"res": [
{"type": "title", "value": "Hello there!"},
{"type": "button", "label": "next", "program": [ {"next_page": true} ]}
]
}
An error response:
{
"ok": false,
"error_msg": "Invalid request",
"error_code": "ERROR_INVALID_REQUEST"
}
# fetch-js
UNDER CONSTRUCTION
Calls a Javascript function to fetch items to be displayed.
Attributes
type
fetch-js
fn
Name of the Javascript function registered in the fetch
option on the config.
Examples
{ "type": "fetch-js", "fn": "MY_FUNCTION" }
# alert
Shows or hides an alert popup.
Attributes
type
alert
is
The alert type.
Values | Description |
---|---|
error |
Shows an error alert popup (default) |
warning |
Shows a warning alert popup |
info |
Shows an information alert popup |
success |
Shows a success alert popup |
msg
Message to be displayed.
Accepts text formatting and variables.
interval
optional
The period in milliseconds that the alert will be displayed. (1000 milliseconds = 1 second). The default is 3000 milliseconds.
Use -1
to not hide the alert automatically.
style
optional
Style to be applied to the alert as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{"type": "alert", "is": "info", "interval": 5000, "msg": "Hello there!"}
# Payment
Payment items.
Item | Description |
---|---|
card |
Collect card information for payment. |
# card
Collect card information for payment.
To use this item you need to setup the payment on the page.
Attributes
type
card
label
optional
The label of the input.
disabled
optional
Disable the input. Defaults do false
.
Example
{ "type": "card", "label": "Inform your credit card" }