Functions
Dynamic Expressions become more powerful with the use of functions. These built-in tools help you perform calculations, transform text, and format data, allowing you to create more dynamic and personalized content.
What Are Functions?
Functions in Dynamic Expressions are special commands that take input values (called arguments) and return a result. They can be used for math operations, text manipulation, and logic-based decisions.
Functions are written inside curly braces {{ ... }}
and can be combined with data variables, literals, and operators.
Example: {{ ROUND(AVERAGE(sessionUser.stats.likes, 10)) }}
- this example calculates the average between the user’s total likes and the number 10, and rounds the result to the nearest whole number.
Text Manipulation Functions
- UPPERCASE(text): Converts the text to uppercase.
- Example:
{{ UPPERCASE("hello world") }}
→ "HELLO WORLD" (text)
- Example:
- LOWERCASE(text): Converts the text to lowercase.
- Example:
{{ LOWERCASE("HELLO") }}
→ "hello" (text)
- Example:
- CAPITALIZE(text): Capitalizes the first letter of the string.
- Example:
{{ CAPITALIZE("ideanote") }}
→ "Ideanote" (text)
- Example:
- TRIM(text): Removes leading and trailing whitespace from the string.
- Example:
{{ TRIM(" idea collection ") }}
→ "idea collection" (text)
- Example:
- REPLACE(text, search, replace): Replaces part of a string with another string.
- Example:
{{ REPLACE("Innovation Hub", "Hub", "Center") }}
→ "Innovation Center" (text)
- Example:
- TRUNCATE(text, length): Shortens a string to a specific length.
- Example:
{{ TRUNCATE("Welcome to the innovation program!", 10) }}
→ "Welcome to..." (text)
- Example:
- CONCAT(...strings): Combines multiple text strings into one.
- Example:
{{ CONCAT("Hello, ", "world") }}
→ "Hello, world" (text)
- Example:
- REPEAT(text, count): Repeats a string a specific number of times.
- Example:
{{ REPEAT("Hi! ", 3) }}
→ "Hi! Hi! Hi!" (text)
- Example:
- APPEND(text, suffix): Adds a suffix to the end of a string.
- Example:
{{ APPEND("hello", ", world") }}
→ "hello, world" (text)
- Example:
- PREPEND(text, prefix): Adds a prefix to the start of a string.
- Example:
{{ PREPEND("world", "hello, ") }}
→ "hello, world" (text)
- Example:
- STARTS_WITH(text, search): Returns whether a string starts with another string.
- Example:
{{ STARTS_WITH("hello", "he") }}
→ true (boolean)
- Example:
- ENDS_WITH(text, search): Returns whether a string ends with another string.
- Example:
{{ ENDS_WITH("hello", "lo") }}
→ true (boolean)
- Example:
- INCLUDES(text, search): Checks if a string contains another string.
- Example:
{{ INCLUDES("hello", "ell") }}
→ true (boolean)
- Example:
- LENGTH(text): Returns the length of the text.
- Example:
{{ LENGTH("Ideas") }}
→ 5 (number)
- Example:
Math Functions
- ABS(number): Returns the absolute (non-negative) value of a number.
- Example:
{{ ABS(-15) }}
→ 15 (number)
- Example:
- ADD(...numbers): Returns the sum of a list of numbers.
- Example:
{{ ADD(1, 2, 3) }}
→ 6 (number)
- Example:
- SUBTRACT(number, subtrahend): Returns the result of subtracting two numbers.
- Example:
{{ SUBTRACT(10, 2) }}
→ 8 (number)
- Example:
- MULTIPLY(number, multiplier): Returns the result of multiplying two numbers.
- Example:
{{ MULTIPLY(2, 3) }}
→ 6 (number)
- Example:
- DIVIDE(number, divisor): Divides one number by another.
- Example:
{{ DIVIDE(10, 2) }}
→ 5 (number)
- Example:
- MOD(number, divisor): Returns the remainder of dividing two numbers.
- Example:
{{ MOD(10, 3) }}
→ 1 (number)
- Example:
- ROUND(number): Rounds a number to the nearest whole number.
- Example:
{{ ROUND(4.7) }}
→ 5 (number)
- Example:
- CEIL(number): Returns the smallest integer greater than or equal to a number.
- Example:
{{ CEIL(1.5) }}
→ 2 (number)
- Example:
- FLOOR(number): Returns the largest integer less than or equal to a number.
- Example:
{{ FLOOR(1.5) }}
→ 1 (number)
- Example:
- MAX(...numbers): Returns the largest number from the list.
- Example:
{{ MAX(10, 20, 5) }}
→ 20 (number)
- Example:
- MIN(...numbers): Returns the smallest number from the list.
- Example:
{{ MIN(10, 20, 5) }}
→ 5 (number)
- Example:
- POW(number, exponent): Returns the result of raising a number to the power of another number.
- Example:
{{ POW(2, 3) }}
→ 8 (number)
- Example:
- AVERAGE(...numbers): Returns the average of a list of numbers.
- Example:
{{ AVERAGE(1, 2, 3) }}
→ 2 (number)
- Example:
Formatting and Utility Functions
- FORMAT(value): Formats a value (such as a number or date) based on user preferences.
- Example:
{{ FORMAT(10000) }}
→ "10,000" (text)
- Example:
- PREFIX(text, prefix): Adds a prefix to the start of a string.
- Example:
{{ PREFIX("world", "hello, ") }}
→ "hello, world" (text)
- Example:
- SUFFIX(text, suffix): Adds a suffix to the end of a string.
- Example:
{{ SUFFIX("hello", ", world") }}
→ "hello, world" (text)
- Example:
Error Handling Tips
- Check for null values: Make sure variables you use exist.
- Avoid dividing by zero: Use
MAX
to ensure divisors are never zero, for example by writing{{ DIVIDE(10, MAX(value, 1)) }}
. - Match parentheses: Ensure all functions and conditionals have matching parentheses.
- Review error messages: Hovering over a "Not Calculated" value in your workspace can provide clues about the underlying cause.
By mastering these functions, you can transform your workspace into a fully dynamic, personalized, and efficient environment that adapts to user input and data.