Source Expression Language
Boolean expressions
Boolean expressions yield a value of true or false. They are used to dynamically set the value for Yes/No flags such as the Required flag on a question. A Boolean expression may be a comparison such as = or >, a Boolean function such as Intersects, or a logical operation such as “and” or “not” on another Boolean expression.
Value expressions
Value expressions yield values such as strings, numbers, dates, or Boolean values. They are used to set answer values such as defaults and calculations.
Language Elements
Answer keys
Answer keys must be delimited with angle brackets < >. Dotted answer keys give access to subparts of complex answer types. For example, if <A> has an object value then <A.prop> yields property prop of that object. Similarly if <B> is an array then <B.0> is the first element of that array.
Operators
Literals
String Literals
- 
Plain String Literals: These are indicated by double quotes. For example, "Hello, world!".
- 
Localizable Strings: Should be enclosed in single quotes. These are considered "magic strings" and can include interpolated values. An example is 'Hello, <Entity_Name>!'. (Not available in Transformations).
- 
Escape Characters: The backslash ( \) serves as an escape character, allowing the inclusion of quotes within the string literals. To include a single or double quote within a string, precede it with a backslash. For instance,"He said, \"Hello!\"".
- 
Escaping Backslashes: To include a backslash itself in the string, it must be doubled. For example, to represent a single backslash in a string, use "\\".
Number Literals
Number literals are represented with a plain number or float value.
Example: 1 and 3.14 will return their own value.
Array Literals
To define an array literal, wrap a collection of expressions in square brackets [].
Example: ["hello", 12, 1 > 2, concat("hello", "world")] would return ["hello", 12, false, "hello world"]
Object Literal
- Static Keys: All object literals must be defined with static keys. Expression evaluation for keys is not valid syntax.
- Dynamic Values: The value for a given key must be a valid source expression.
Example: {"hello": "world", "nine": 9, nested: {"key": "value"}, "arr": ["test", "array"], "func": concat("hello", "world")}\
Operators
| Operator | Description | 
|---|---|
| = | Case-Insensitive Equality Operator: Returns true if both operands are equal, ignoring case differences. Example: "foo" = "FOO"returns true;"foo" = "foo"also returns true. | 
| == | Case-Sensitive Equality Operator: Returns true if both operands are exactly equal, including case. Example: "foo" == "FOO"returns false;"foo" == "foo"returns true. | 
| !=or<> | Case-Insensitive Inequality Operator: Returns true if operands are not equal, ignoring case differences. Example: "foo" != "bar"returns true;"foo" != "FOO"returns false. | 
| !== | Case-Sensitive Inequality Operator: Returns true if operands are not equal, considering case differences. Example: "foo" !== "bar"returns true;"foo" !== "FOO"also returns true. | 
| > | Greater Than Operator: Returns true if the first operand is greater than the second operand. Example: 1 > 2returns false;3 > 2returns true. | 
| >= | Greater Than or Equal To Operator: Returns true if the first operand is greater than or equal to the second operand. Example: 1 >= 2returns false;2 >= 2returns true;3 >= 2returns true. | 
| < | Less Than Operator: Returns true if the first operand is less than the second operand. Example: 3 < 2returns false;1 < 2returns true. | 
| <= | Less Than or Equal To Operator: Returns true if the first operand is less than or equal to the second operand. Example: 3 <= 2returns false;2 <= 2returns true;1 <= 2returns true. | 
| and | Binary AND Operator: Returns true if both Boolean values are true. Example: true and truereturns true;true and falsereturns false. | 
| in | Membership Operator: Returns true if a value exists within an array. Example: "a" in ["a", "b", "c"]returns true. | 
| not | Logical Negation Operator: Returns true if the following expression is false. Example: not truereturns false;not falsereturns true. | 
| or | Binary OR Operator: Returns true if at least one of the Boolean values is true. Example: true or falsereturns true;false or falsereturns false. | 
Functions
| Function | Description | 
|---|---|
| 
 | Add a number of whole or fractional days to a date. The date parameter will be coerced to a date on a best-effort basis, but ISO-8601 format is known to be reliable. | 
| 
 | Add a number of whole or fractional minutes to a date. The date parameter will be coerced to a date on a best-effort basis, but ISO-8601 format is known to be reliable. | 
| 
 | Return an array of instance IDs in the group identified by groupKey. 
 | 
| 
 | Returns true if the expression is true for each array element. The special key  | 
| 
 | Returns true if the expression is true for at least one array element. The special key  Example: | 
| 
 | ArrayMap would let you do  | 
| 
 | You can write  | 
| 
 | Returns a copy of  
 
 | 
| 
 | Removes nulls from an array | 
| 
 | Takes multiple variadic string arguments and concatenates the strings together. 
 | 
| 
 | Takes multiple variadic array arguments and concatenates the arrays together. 
 | 
| 
 | Returns the count based on the datatype of the input - string: Number of characters in the string 
 | 
| 
 | Make sure the provided argument is an array. If not, wrap the value in an array. | 
| 
 | Return the first instance id of the provided group key that matches the given filter, if provided. 
 | 
| 
 | Return the first instance id of the provided group key that matches the given filter, if provided. 
 | 
| 
 | Return the first instance id of the provided group key that matches the given filter, if provided. 
 | 
| 
 | Returns the given array as a string, separated by the delimiter 
 | 
| 
 | Determines if the specified regex successfully matches the entire string, returning true if it does and false otherwise. | 
| 
 | Determines if the specified regex successfully matches any of the strings in the provided array, returning true if it does and false otherwise. | 
| 
 | Returns a phone number without any additional information such as extension or country code. 
 | 
| 
 | Returns the country based on the phone number's country code prefix. Defaults to  
 | 
| 
 | Returns the country based on the phone number's country code prefix. Defaults to  
 | 
| 
 | Get a specific key/index from an object/array. 
 | 
| 
 | Modifies a given string by substituting parts of the string that match a specified regular expression pattern with a replacement string. The flags argument can be used to specify additional options for the regex operation, such as case insensitivity or global replacement, influencing how the matching and replacement are performed. 
 | 
| 
 | Rounds the provided value to a provided number of decimal places | 
| 
 | Removes all matching patterns from a string. 
 | 
| 
 | Converts a string to all lowercase characters 
 | 
| 
 | Coverts a string to all uppercase characters 
 | 
| 
 | Converts a given string into its URL encoded equivalent 
 | 
| 
 | Returns the provided string starting at the second argument's index (inclusive and 0 indexed) and ending at the third argument's index (non-includive and 0 indexed). | 
| 
 | Modifies the given string by replacing characters diacritical marks with the English equivalent. 
 | 
| 
 | Returns all of the keys in an object as an array. 
 | 
Updated about 1 month ago
