Skip to main content

Conditional logic

Conditional logic is a powerful feature of the Tray.io workflow editor. It can be used to ask key questions whose answers will then determine what path your workflow will take.

Tray has two key conditional logic connectors:

  • The Boolean connector can ask simple true/false questions such as 'did the new customer opt-in to marketing?' or 'is it more than 3 months since we last contacted this person?'

  • The Branch connector can be used to set multiple pathways depending on multiple different outcomes being picked up from your data. For example you may receive support tickets of 3 or 4 different types and want to set paths for each one to notify the relevant people to take appropriate action.

The Boolean connector

The following example shows using Recurly (a subscription billing management tool) to find inactive accounts.

This loops through each individual account and the boolean step checks if its state is 'inactive':

recurly-boolean-example

The Branch connector

The branch connector is essentially a 'switch statement' generator.

So it allows you to take actions based on multiple possible conditions.

To illustrate we can look at the following payload:

{
"event_id": "01HBJB40Y2RX8JFQ9ZTR36QARJ",
"event_type": "form_response",
"form_response": {
"answers": [
{
"type": "choice",
"choice": {
"id": "iw6D4ljxDd7G",
"label": "Very Satisfied",
"ref": "eb3d389e-9838-4060-92da-26eb6c894f38"
},
"field": {
"id": "lsaGBN45qcBn",
"type": "multiple_choice",
"ref": "47969b6b-7dd7-4f7f-99fb-d39d99682df2"
}
},
{
"type": "choice",
"choice": {
"id": "QLvsfypbiSgr",
"label": "Construction",
"ref": "ff85f603-202e-431b-92e5-5a7af03f5bea"
},
"field": {
"id": "e4cxUxSqos5p",
"type": "dropdown",
"ref": "ac185360-3406-4d55-af72-f24f132f489b"
}
},
{
"type": "choice",
"choice": {
"id": "2u87p0hxKDu9",
"label": "6 months to 1 year",
"ref": "d27a0951-9510-43c5-bcc5-54849d1a16f1"
},
"field": {
"id": "rFIJoo1k7Wly",
"type": "multiple_choice",
"ref": "e7606153-14fa-4952-aed2-ccea78d603dd"
}
}
}
]
}
}

If we want to extract these answers into a simple list such as:

[
"Very Satisfied",
"Construction",
"6 months to 1 year"
]

Then we can do this using a script connector with a switch statement:

exports.step = function(input, fileInput) {

function transformJSON(inputJSON) {
let outputJSON = [];
let formResponse = inputJSON.form_response;
let answers = formResponse.answers;

answers.forEach(answer => {
switch (answer.type) {
case "number":
outputJSON.push(answer.number);
break;
case "boolean":
outputJSON.push(answer.boolean);
break;
case "choice":
outputJSON.push(answer.choice.label);
break;
case "email":
outputJSON.push(answer.email);
break;
case "text":
outputJSON.push(answer.text);
break;
// Add more cases for other types if needed
default:
// Handle the default case if necessary
break;
}
});

return outputJSON;
}

return transformJSON(input.inputJSON);
};

Or we could loop through the answers and use the Branch connector to replicate a switch statement.

Each time we 'push' the answer using the Data storage 'append to list' operation.

After all answers have been looped through, we can then use the Data storage 'get value' operation to retrieve the final list:

branch-connector-as-switch-statement