Building the Form’s UI
In Web Flows Builder you’ll find the Web Flow you have added from Journey Builder. This will be the Form that users will be directed to upon starting their Journey. Now let's build out the UI that will be contained in that Web Flow.
Working with Web Flow level Variables
- Rename the Web Flow to “Form” by double clicking on the Web Flow in the Tree.
data:image/s3,"s3://crabby-images/b225e/b225e16e50cfac34af4e085661ee4cb6439bd5de" alt="2022-07-19_09-36-36.png 675"
- Click on Variables at the bottom of the screen and in Activity Group Variables, click on the ‘+’ icon. Select the Variable of Type Object that you have created before.
data:image/s3,"s3://crabby-images/99a1d/99a1de908f0526288622879305c7b68a925680c4" alt="Variable Tree (1).png 963"
- Change its name to “user_input”.
data:image/s3,"s3://crabby-images/a53a9/a53a92a5fc65d42464a9961a04c304f1a6e48c5f" alt="Variable Tree (2).png 777"
This way, the user
Variable of Type Object will be now available at a Web Flow level. This means that it can be called from any of this Web Flow’s Web Pages.
Building the Web Pages
This Form Web Flow will include three Web Pages: a Personal Info Web Page, an Additional Info Web Page, and a Review Web Page.
Personal Info Web Page
- Rename the nested Web Page to "Personal Info" by double clicking on it.
- Add a Container and rename it to “Title”.
data:image/s3,"s3://crabby-images/3a19f/3a19fc2854015b4cbdcce8710dee9cbdbe2462b7" alt="WP100.png 875"
Containers help with the organization of the Form by grouping controls and can be styled to distribute them or make them sit side by side.
- Nest a Label by clicking on the ‘+’ icon next to the Container.
data:image/s3,"s3://crabby-images/777c6/777c62319a539ccde6bef53e3392c2afe73e7a10" alt="WP100a.png 874"
- With the Label selected, go to the General tab of the Inspector, and in Control Properties > Text, enter your Form’s title.
data:image/s3,"s3://crabby-images/4f640/4f64006f8c67fa7c0880cf2f285bcbd67076726b" alt="WP100b.png 1099"
- Add another Container and rename it to “Name”. Add a Label and a Text Input Control nested underneath.
data:image/s3,"s3://crabby-images/fc531/fc53108e53daf37df20ecd19503ff38b1ee3b423" alt="WP101.png 882"
- With the Text Input Control selected, go to the Inspector section and, in Data Binding, change the auto generated Variable. In order to tie it to the
user
Variable of Type Object we have created before, enter:
activityGroup.user_input.first_name
data:image/s3,"s3://crabby-images/4d8d9/4d8d9d46fe30409a8cb3c5c493e51e34c130d862" alt="WP102.png 775"
This way, the value the user enters in this field, will be bound to the App Object in AirData later on.
Why use the activityGroup namespace?
Using the corresponding Variable Namespace is a best practice to make sure Variable work in the scope we need. For example, the namespace corresponding to the Web Flow scope, is called by using activityGroup
before the Variable name.
Each scope includes the ones below, that is to say, if working with a Variable at a Web Flow level, it will also be available in all Web Pages, but it won’t be available globally to use on a different Web Flow.
Check the table below:
Variable scope | Namespace |
---|---|
Global | session.value |
Web Flow | activityGroup.value |
Web Page | activity.value |
- Duplicate the previous container and rename it to “Last Name”. Change the Label to “Last name” as well.
data:image/s3,"s3://crabby-images/91dc4/91dc481ea289fe6ba6fdb924717af723250a7c4a" alt="WP103.png 443"
- With the Text Input Control selected, in Data Binding enter the following:
activityGroup.user_input.last_name
data:image/s3,"s3://crabby-images/fa264/fa2644fbc15632b476cbc4a4037aa9b95cbfbc81" alt="WP1036.png 750"
- Duplicate the previous Container and rename it to “Phone number”. Rename the Label to “Phone”.
- Delete the Text Input and add a Phone Input Control.
data:image/s3,"s3://crabby-images/1f372/1f372d8ec679a2ce4b99469cb6931e0ed3ca490a" alt="WP1037.png 932"
- In Data Binding enter the following:
activityGroup.user_input.phone
data:image/s3,"s3://crabby-images/1bb4d/1bb4d0b27590c3b20d9c10e7b186c3f8427a3d5a" alt="WP1038.png 741"
This is how the Web Page should look like so far:
data:image/s3,"s3://crabby-images/b6e82/b6e82a7a9deba26a5bf91222caa0cedcb95e4884" alt="WP1035.png 861"
Add Validation to your Web Page
- Add a Label Control to type the following error message: “Phone number cannot be empty”. In the General tab of the Inspector section, change the Variant for the an error-like one.
data:image/s3,"s3://crabby-images/ab9d5/ab9d56b1a042d60e31a93576ad95e88dd93e0ad0" alt="WP104.png 898"
- Go to the Advanced tab and in, Is Visible, set up the ISEMPTY Expression so that this error message displays only when the Phone field is incomplete:
ISEMPTY(activityGroup.user_input.phone)
data:image/s3,"s3://crabby-images/02ca1/02ca10aa046153bc0ff9203de9e2279f0b3ea9c9" alt="WP105.png 391"
Why use the ISEMPTY function?
In this case, the ISEMPTY function allows you to confirm whether the user completed a required field, hence stopping them from advancing until the information is entered. On the other hand, this function works in tandem with the Phone Input Web Control ensuring that the numbers entered are actually a valid phone number.
- Add a Container and nest a Button Control underneath. Rename it to “Next”.
data:image/s3,"s3://crabby-images/1126b/1126b914ef9754421bb7669249e0f6b8697b8781" alt="WP107.png 871"
- Go to the Actions tab in the Inspector section and add a Navigate to Web Page Action. Select Add Web Page.
data:image/s3,"s3://crabby-images/57185/57185478dc2e79241d5c2be898e5cc44a14e1e18" alt="WP106.png 952"
- Save the app
Additional Info Web Page
- Rename the new Web Page to "Additional Info" by double clicking on it.
- Add a Container and rename it to “Birthday”. Add a Label and a Date Input Control nested underneath.
data:image/s3,"s3://crabby-images/d4e5c/d4e5c865cb28cb64fb3705acade52ed893a495d6" alt="WP201.png 871"
- With the Date Input Control selected, go to the Inspector section and, in Data Binding, change the auto generated Variable to:
activityGroup.user_input.birthday
data:image/s3,"s3://crabby-images/990bb/990bb75178cbc507bec715cd467f549b52e0a675" alt="WP1039.png 752"
Date Input Controls contain a Date Picker Control for further configuration. Select it and, in the Inspector section, change the Date Picker Layout to “1 month” for a clearer calendar view. Also, set Date Range to “past” so that the user can pick their date of birth.
data:image/s3,"s3://crabby-images/05d2c/05d2c50c00fbc65f8725a79b328d66333a4572ef" alt="WP202.png 339"
- Add another Container and rename it to “Email”. Add a Label, rename it to “Email” as well.
- Add a Text Input Control nested underneath. With the Text Input Control selected, go to the Inspector and, in Data Binding, enter the following:
activityGroup.user_input.email
data:image/s3,"s3://crabby-images/b5582/b55824615f8d6a3c2c458431a1b1ad6ebd8a67bc" alt="WP305.png 1103"
- Duplicate the previous Container and rename it to “Company”. Rename the Label to “Company”. With the Text Input Control selected, in Data Binding enter the following:
activityGroup.user_input.company
data:image/s3,"s3://crabby-images/0b824/0b82410dd755cb36e53d7bfbb345b495fd532dfc" alt="WP306.png 1122"
-
Add a Container and rename it to "Buttons".
-
Nest two Button Controls of different styles underneath.
data:image/s3,"s3://crabby-images/a71ab/a71ab705782df2f1e1def230d84ab1df7ebfbe93" alt="WP307.png 954"
- Rename the first one to “Back”. Go to the Actions tab in the Inspector section and add a Navigate to Web Page Action. Select the “Personal Info” Web Page.
data:image/s3,"s3://crabby-images/4f595/4f595863e4ccfb6064bba37cb0a517d66384153d" alt="WP205.png 1179"
This way, if the user wants to edit a field from the previous page, can go back to it.
- Rename the second one to “Next”. Go to the Actions tab in the Inspector section and add a Navigate to Web Page Action. Select the Add Web Page option for the user to move forward.
data:image/s3,"s3://crabby-images/43d29/43d295a3d1c8f5c30a5b93824d9053ef0853e790" alt="WP206.png 1177"
- So that the Button Controls sit side by side, select the Buttons Container and go to the General tab of the Inspector section. In Distribute Children click on Stack Horizontal. You can also change the spacing to your liking, in this case, the space between the buttons is set in 8px:
data:image/s3,"s3://crabby-images/8eb58/8eb583a6857436d6591a7a70c86334f90e035137" alt="WP204.png 925"
- Save the app.
Review Web Page
-
Rename the new Web Page to "Review" by double clicking on it.
-
Add a Container, rename it to "Title" and nest a Label underneath.
-
With the Label selected, go to Control properties > Text in the General tab of the Inspector and add a title.
data:image/s3,"s3://crabby-images/25e26/25e26a82290971edc945ab7171db45cba99d1a28" alt="WP304.png 1143"
-
Add another Container and rename it to “Inputs”. Nest six Labels, one for each of the Input Controls you added in the previous Web Pages.
-
Select the Labels one by one and in Control Properties > Text add the following Variables to bind the Values of the Input fields:
For the fields of type Text:
activityGroup.user_input.first_name
activityGroup.user_input.last_name
activityGroup.user_input.email
activityGroup.user_input.company
For the field of Type Phone add the following Expression:
FORMAT_PHONE(
activityGroup.user_input.phone,
"INTERNATIONAL"
)
For the of Type Date add the following Expression:
FORMAT_DATE(
activityGroup.user_input.birthday,
"MM/DD/YYYY"
)
Why use the FORMAT function?
The FORMAT function allows you to convert an input into a specific output format.
In this case, we are using FORMAT_PHONE to take the inputted phone number and return a string containing the same phone number but in an international format.
Also, we are using FORMAT_DATE to convert the inputted date into the desired format, in this case: MM/DD/YYYY.
You’ll notice that the Web Page looks blank, but you’ll be able to see the entered information once checking the app in the App Preview or by assigning dummy data to this Variables in the Variables Tree.
data:image/s3,"s3://crabby-images/0cc51/0cc5132b43fa865b5a71a31cb8f26ca2d11c3b85" alt="WP301.png 1323"
- Then add six more Labels and drag them over each of the Labels containing the Variables with the inputted data. In Text enter the name of the field so that data is displayed in a more orderly fashion once captured:
data:image/s3,"s3://crabby-images/5b44a/5b44af0ac5f53d3974c95764950f1f21a5416c68" alt="WP302.png 1183"
-
Add a Container and nest a Button Control underneath. Rename it to “Submit”.
-
With the button selected, go to the Actions tab in the Inspector and add a Run Data Flow Action.
data:image/s3,"s3://crabby-images/5ad8b/5ad8bd2b9b983f3ff5c14eb28a71b148d0c1e326" alt="WP303.png 927"
After building the Data Flow, we’ll come back here to tie it.
Updated about 2 years ago