Split by Flow Result
Use this Split Action to evaluate a sequence of values separated by a space ( ), period (.) or plus sign (+).
As an example, you might record the birth of a child by soliciting messages in the following format: "birth [gender]+[name]+[mother's birth year]," which could yield the result "birth f+Noel+1985".
In the case above, the term "birth" acts as a keyword trigger, initiating the flow.
In the following example, we create a flow that collects and evaluates a sequence of values, Gender, Name, and Mother's Birth Year.
After sending an initial message, create a Wait for Response action with an open-ended response rule has any of the words to collect messages directed to this flow via the "birth" keyword trigger. Save the result as "Message."
Note: This response rule must remain open-ended, as it will collect all messages that contain the keyword we've designated, "Birth". Once we've stripped the initial message of its keyword, we can go about evaluating each field using a series of Split by Flow Result actions.
data:image/s3,"s3://crabby-images/870bf/870bfb674340e59afcd9720f8f6eead4fd0f13a2" alt=""
Remove the keyword trigger to isolate the submission as the flow variable @results.message (Split by Flow Result actions may only evaluate flow results variables). To do so, create a Split Action that splits the initial message by expression. In the example pictured below, we apply the @(REMOVE_FIRST_WORD()) function to the incoming message (referenced using @input.text). The resulting expression should read @(REMOVE_FIRST_WORD(input.text)).
Save the resulting flow variable as "Fields" to yield only the values delimited by a plus sign. To review, the values we'll submit will follow the format [gender]+[name]+[mother's birth year]. Each bracket value is assigned its own field. Gender is the first field, Name the second, and Mother's Birth Year the third.
data:image/s3,"s3://crabby-images/b92d2/b92d23ce6e27717946c7ac2f69510e6b14c9c6fc" alt=""
Add a Split by Flow Result action to evaluate Gender, the first field delimited by a plus sign. Create a response rule for each gender that categorizes the short form values "m" or "f" as their long form counterparts, and save the resulting flow variable as "Gender."
data:image/s3,"s3://crabby-images/99542/9954262a44443cf84701894e60d7e30bec45894e" alt=""
Note that you will need to click the "Advanced" tab at the top of the node to delimit your result for each of your Split by Flow Result actions:
data:image/s3,"s3://crabby-images/426b6/426b6eed775c5f2e72cba7b44a7e34bebecad46d" alt=""
Add a Send Message action that addresses incorrectly formatted "Gender" values and asks the contact to resubmit the message.
data:image/s3,"s3://crabby-images/7d6ab/7d6aba45fcea5df9c893fdb646c55ac2800ed2ee" alt=""
In the example pictured above, we've formatted the error message to repeat the contact's initial message using the @results.fields variable, so they can see how their response compares to the expected format, and ask them to resubmit.
Add a second Split by Flow Result action to evaluate "Name", the second field delimited by a plus. This time, it's the name of the child. You can create an "_is not empty_" response rule to ensure the second field has a value, then categorize it as "_Has Name_" and save the resulting flow variable as "Name." Again, be sure to check the Delimit Result box in the Advanced tab.
data:image/s3,"s3://crabby-images/7b65a/7b65a28b41c039f3f55bc0cc64007888bcc69064" alt=""
Add a Send Message action that addresses incorrectly formatted "Name" values and asks the contact to resubmit.
data:image/s3,"s3://crabby-images/fdb84/fdb849b3bdccd9c6b285c6862402fa72cf8f1c8a" alt=""
Add a third Split by Flow Result action to evaluate "Birth Year", the third field delimited by a plus. Add a "_has a number between_" response rule to ensure the third field contains a valid birth year and save the resulting flow variable as "Birth Year".
data:image/s3,"s3://crabby-images/a029a/a029a227964f52d55ab56a9f190bee26c5b974df" alt=""
Add a Send Message action that addresses invalid "Birth Year" values and asks the contact to resubmit.
data:image/s3,"s3://crabby-images/6780a/6780a691406a9d499fd9180cc101ac5cc88346ca" alt=""
Finish the flow by adding a Send Message action that confirms the message form submission by referencing the values submitted by the contact.
data:image/s3,"s3://crabby-images/4e215/4e215ed5968158867f15e9b60a1ca6aa9d310dde" alt=""
The resulting flow should look similar to the example pictured below.
data:image/s3,"s3://crabby-images/045a5/045a5dcc1e9ea7856a2436290ac6e9412aa7ee9f" alt=""
Need more than nine fields? Use the Split by Expression action and the following function:
FIELD(text, index, [delimiter])
Reference a field in a string separated by a delimiter:
@(field(results.field, 1, "+"))
As an example, you might record the birth of a child by soliciting messages in the following format: "birth [gender]+[name]+[mother's birth year]," which could yield the result "birth f+Noel+1985".
In the case above, the term "birth" acts as a keyword trigger, initiating the flow.
In the following example, we create a flow that collects and evaluates a sequence of values, Gender, Name, and Mother's Birth Year.
After sending an initial message, create a Wait for Response action with an open-ended response rule has any of the words to collect messages directed to this flow via the "birth" keyword trigger. Save the result as "Message."
Note: This response rule must remain open-ended, as it will collect all messages that contain the keyword we've designated, "Birth". Once we've stripped the initial message of its keyword, we can go about evaluating each field using a series of Split by Flow Result actions.
data:image/s3,"s3://crabby-images/870bf/870bfb674340e59afcd9720f8f6eead4fd0f13a2" alt=""
Remove the keyword trigger to isolate the submission as the flow variable @results.message (Split by Flow Result actions may only evaluate flow results variables). To do so, create a Split Action that splits the initial message by expression. In the example pictured below, we apply the @(REMOVE_FIRST_WORD()) function to the incoming message (referenced using @input.text). The resulting expression should read @(REMOVE_FIRST_WORD(input.text)).
Save the resulting flow variable as "Fields" to yield only the values delimited by a plus sign. To review, the values we'll submit will follow the format [gender]+[name]+[mother's birth year]. Each bracket value is assigned its own field. Gender is the first field, Name the second, and Mother's Birth Year the third.
data:image/s3,"s3://crabby-images/b92d2/b92d23ce6e27717946c7ac2f69510e6b14c9c6fc" alt=""
Add a Split by Flow Result action to evaluate Gender, the first field delimited by a plus sign. Create a response rule for each gender that categorizes the short form values "m" or "f" as their long form counterparts, and save the resulting flow variable as "Gender."
data:image/s3,"s3://crabby-images/99542/9954262a44443cf84701894e60d7e30bec45894e" alt=""
Note that you will need to click the "Advanced" tab at the top of the node to delimit your result for each of your Split by Flow Result actions:
data:image/s3,"s3://crabby-images/426b6/426b6eed775c5f2e72cba7b44a7e34bebecad46d" alt=""
Add a Send Message action that addresses incorrectly formatted "Gender" values and asks the contact to resubmit the message.
data:image/s3,"s3://crabby-images/7d6ab/7d6aba45fcea5df9c893fdb646c55ac2800ed2ee" alt=""
In the example pictured above, we've formatted the error message to repeat the contact's initial message using the @results.fields variable, so they can see how their response compares to the expected format, and ask them to resubmit.
Add a second Split by Flow Result action to evaluate "Name", the second field delimited by a plus. This time, it's the name of the child. You can create an "_is not empty_" response rule to ensure the second field has a value, then categorize it as "_Has Name_" and save the resulting flow variable as "Name." Again, be sure to check the Delimit Result box in the Advanced tab.
data:image/s3,"s3://crabby-images/7b65a/7b65a28b41c039f3f55bc0cc64007888bcc69064" alt=""
Add a Send Message action that addresses incorrectly formatted "Name" values and asks the contact to resubmit.
data:image/s3,"s3://crabby-images/fdb84/fdb849b3bdccd9c6b285c6862402fa72cf8f1c8a" alt=""
Add a third Split by Flow Result action to evaluate "Birth Year", the third field delimited by a plus. Add a "_has a number between_" response rule to ensure the third field contains a valid birth year and save the resulting flow variable as "Birth Year".
data:image/s3,"s3://crabby-images/a029a/a029a227964f52d55ab56a9f190bee26c5b974df" alt=""
Add a Send Message action that addresses invalid "Birth Year" values and asks the contact to resubmit.
data:image/s3,"s3://crabby-images/6780a/6780a691406a9d499fd9180cc101ac5cc88346ca" alt=""
Finish the flow by adding a Send Message action that confirms the message form submission by referencing the values submitted by the contact.
data:image/s3,"s3://crabby-images/4e215/4e215ed5968158867f15e9b60a1ca6aa9d310dde" alt=""
The resulting flow should look similar to the example pictured below.
data:image/s3,"s3://crabby-images/045a5/045a5dcc1e9ea7856a2436290ac6e9412aa7ee9f" alt=""
Need more than nine fields? Use the Split by Expression action and the following function:
FIELD(text, index, [delimiter])
Reference a field in a string separated by a delimiter:
@(field(results.field, 1, "+"))
Updated on: 19/06/2023
Thank you!