Page
Index
A story page that contains the items to be displayed.
Attributes
page_id
optional
The unique identifier of the page.
style
optional
Style to be applied to the whole page as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
style_content
optional
Style to be applied to the page content as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
items
List of the items of the page.
submit
optional
Options for submitting forms. See more in Submitting forms bellow.
history
optional
Indicates whether to add the page to the backlist.
Values: true
(default) or false
env
Environment attributes:
show_back
optional
Indicates whether or not to show the back button on the page.
Values: true
(default) or false
show_logo
optional
Indicates whether or not to show the logo image, if it exists.
Values: true
(default) or false
progress
optional
Progress bar attributes:
show
Indicates whether or not to show the progress bar on the page. Defaults to the story.progress.show
.
value
optional
Percentage number of progress, from 0 to 100. Defaults to the progress of the page.
style
optional
Style to be applied to the progress bar as CSS key-value pairs.
The values can be a literal value or a single command call returning a literal value.
Example
{
"page_id": "page_start",
"style": {
"background_color": "#DAFFEF",
"align": "center"
},
"progress": {
"show": true,
"value": 33
},
"items": [
{ "type": "title", "value": "The Story" },
{ "type": "p", "value": "This is the story of a boy..." },
{ "type": "button", "label": "Next", "program": {"next_page": true} }
]
}
# Submitting forms
Process and save form information to variables.
Tip: To send information to the server, use the
call
command.
Attributes
program
One or more commands to execute, after processing and saving the variables.
label
Submission button label.
input_submit
optional
Transfers the form submission to the input elements. Defaults to false
.
For single-input forms, set this option to
true
to highlight the input and transfer the submission to the element. ✨
payment
optional
Information to create a checkout page to receive payments. Check the Payments section below for more details.
Examples
Page with multiple input elements:
{
"items": [
{ "type": "title", "value": "Contact Us" },
{ "type": "name", "label": "Name", "save_key": "name", "required": true },
{ "type": "email", "label": "Email", "save_key": "email", "required": true },
{ "type": "textlong", "save_key": "msg", "label": "Message", "required": true }
],
"submit" : {
"label": "Send Message",
"program": [
{"next_page": true}
]
}
}
Page with a single input element using input_submit
:
{
"items": [
{ "type": "question", "value": "What's your name?" },
{ "type": "name", "save_key": "name", "required": true}
],
"submit" : {
"label": "Next",
"input_submit": true,
"program": [ {"next_page": true} ]
}
}
# Payments
This section explains how to create a checkout page to receive payments with credit and debit cards.
The payment is processed using Stripe.
Attributes
pk
The publishable key provided by Stripe to receive payments.
If you don't have a Stripe account yet, create one on their website.
endpoint
The URL to be called to fetch the payment information. The URL can be an absolute or relative path.
save_key
optional
Key to save the payment information in the data table. Defaults to "payment_ok
".
required
optional
Indicates whether the payment is required. The default is true
.
data
Keys of the variables containing the buyer's information to be submitted with the payment:
Parameter | Description |
---|---|
name |
Key of the variable containing the name of the buyer. |
email |
Key of the variable containing the email of the buyer. |
receipt_email |
Key of the variable containing the email that will be used by Stripe to send the receipt for the buyer. See more about email receipts at Stripe. |
Example
{
"items": [
{ "type": "title", "value": "Payment" },
{ "type": "name", "label": "Name", "save_key": "name_buyer", "autoFocus": true, "required": true},
{ "type": "email", "label": "Email", "save_key": "email_buyer", "required": true},
{ "type": "p", "value": "Your credit card will be charged **$45**" },
{ "type": "card" }
],
"submit": {
"label": "Buy",
"program": {"next_page" : true},
"payment": {
"pk": "< YOUR PUBLISHABLE KEY >",
"endpoint": "/api/endpoint/payment",
"data": {
"name": "name_buyer",
"email": "email_buyer",
"receipt_email": "email_buyer"
}
}
}
}
Check the payment demo.
Server processing
To complete the payment you need to create a secret
token on the server-side to secure and validate the transaction.
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 |
---|---|
origin |
The protocol, hostname, and port number of the caller's URL. |
Response
The server must respond with a JSON message containing the following parameters:
Parameter | Description |
---|---|
ok |
true |
res.secret |
Token used to complete the payment. |
res.title |
Title of the item. |
The
secret
is created using the secret key associated with the publishable key provided by Stripe. For more information on how to create the secret, consult the Stripe documentation.
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": {"secret": "** secret generated **", "title": "Item 1"}
}
An error response:
{
"ok": false,
"error_msg": "Invalid request",
"error_code": "ERROR_INVALID_REQUEST"
}
Payment successfull
After the payment is accepted, a variable with the key informed on save_key
attribute is created on the data table.
The following properties are saved on the variable:
Property | Description |
---|---|
id |
The payment id provided by Stripe. |
amount |
The amount of the payment. |
currency |
The currency of the payment. |
title |
The title of the item. |
These variables can be retrieved using Data commands.
Example:
{ "type": "p", "value": "The item {{payment_ok.title}} was purchased. Payment ID: {{payment_ok.id}}" }