Note: Nintex Apps is in beta release.

Merge Syntax

Merge syntax is a templating system based on mustache.js and is used primarily by writing merge variables. These variables are bits of data represented by a parameter wrapped in two or three curly brackets.

For example:

Copy
{{someVariable}}

These parameters are then "merged" into another location such as in a UI-only formula, within a component or other component elements.

Merge Variables

Merge variables often rely on context to retrieve the variable specified within the curly brackets. Context is determined by where the merge variable is used, and it can be a model record, fields within a record, or a JavaScript object (with or without properties).

Among other things, merge variables are helpful for pulling live data into a location to display to users at runtime. Imagine a builder wants to have a detail panel on the page of an account that displays the name of the account's point-of-contact. To accomplish this, they could use merge variables to fetch the name of the contact from the account record:

Copy
First Name: {{firstName}}

Last Name: {{lastName}}

When the detail panel loads in runtime, the merge variables tell Nintex Apps to check the current context—the selected record—to find the values that correspond with the "First Name" and "Last Name" parameters. When Nintex Apps finds that the account record has values for the parameters requested, it passes (or "merges") those values into the location where they were called. So, if the account's point-of-contact was Amy Meerdink, the detail panel displays:

Copy
First Name: Amy

Last Name: Meerdink

There are also global merge variables which are available in any merge context, and all start with $ . For example,

Copy
{{$Param.accountId}}, {{$Api.Session_Id}}

Builders can access related fields using dot notation within their merge variables. For example, to access related fields off of a related Account record:

Copy
{{Account.Name}} ({{Account.City}}, {{Account.State}})

This expression looks to a related object via a reference field called ( Account ). The . then tells Nintex Apps to go within the related object for the Name value.

Other examples of using dot notation include accessing child relationship data, paths to contents within REST models, or accessing global merge variables.

Merge Variable Formatting

Merge variables can be wrapped in double and triple curly brackets. The number of curly brackets around a merge variable tells Nintex Apps how to format the data represented in the variable when it pulls the data into the targeted location.

Double Curly Brackets

Copy
{{Amount}}

In most cases, double curly brackets tell Nintex Apps to apply formatting to the data returned to a variable based on the context model's field display type and the running user's locale. For example, say a builder includes the merge variable {{Amount}} , which looks to a currency field on the model called "Amount" that has a value of 3000 .

Because of the double curly brackets, Nintex Apps will check the field's display type ( Currency ) and the user's locale ( en_US ), then apply formatting inherited from those properties to return $3,000.00 .

If the Amount field had a field display type of Number, the result would be 3,000 .

Additionally, double brackets also allow characters that have special meaning in HTML ( & , < and > ) to appear as expected. Double brackets tell Nintex Apps to apply additional HTML to the returned values so that they will display as text instead of being parsed as an HTML directive.

Triple Curly brackets

Copy
{{{Amount}}}

Triple curly brackets tell Nintex Apps to display only the raw (unformatted) data. Therefore, using the sample value of 3000 , {{{Amount}}} displays as 3000 , regardless of how the field in the original object was formatted.

Merge Expressions

Merge variables can be used in a merge expression, which is a string of characters containing one or more merge variables that return a set of values. Merge expressions can be used in some component properties, action properties, UI-only fields, and in JavaScript snippets.

For example:

Copy
Full Name: {{First Name}} {{Last Name}}

Address:
        {{Street}}
        {{City}}, {{State}} {{PostalCode}}
        {{Country}}

In runtime, these expressions return:

Copy
Full Name: Amy Meerdink

Address:
        123 Cephalopod Street
        Maritime, Kentucky, 33333
        United States

Merge expressions can also incorporate logic, as Nintex Apps's implementation is based on mustacheJS sections. Builders can include limited conditional rendering logic, as well as iterate over arrays.

Merge expression logic will always begin with a pound sign and end with a slash. For example, {{#name}} and {{/name}} .

Conditional merge expressions

The # hash and ^ caret symbols are used to denote truthy or falsy merge expressions, respectively.

For example, to create a conditional merge expression that renders if a field named IsActive is true , you would use the following syntax:

Copy
{{#IsActive}}Product is active!{{/IsActive}}

The # tells Nintex Apps if the IsActive field returns true, render "Product is active!"

Conversely, using a ^ will render the content only if the value returned by the IsActive merge variable is false.

Copy
{{^IsActive}}Product is not active!{{/IsActive}}

This means that if the returned value of IsActive is false, 0, null, undefined, NaN, an empty string or an empty list, then "Product is not active!" is rendered.

You can use these true or false tags in combination to display a message based on whether a value is true or not. For example:

Copy
{{#IsActive}}Sell this product!{{/IsActive}}{{^IsActive}}Pretend this product doesn't exist!{{/IsActive}}

Another example of using the true and false syntax is displaying the quantity of a particular product—but only if the quantity was non-null and greater than 0; otherwise display a link to an Order Form:

Copy
{{#Quantity__c}}{{Quantity__c}}{{/Quantity__c}}{{^Quantity__c}}(<a href="/apex/orderForm?code={{{ProductCode}}}">Order Form</a>){{/Quantity__c}}

Looping over arrays

If the target variable of a conditional merge expression is an array (a list of items), then the content of the expression is rendered once for each element in the array. This is commonly used to iterate over records themselves or child relationship records.

Iterating over records

To make a merge expression that iterates over opportunity records to display the name, stage, and close date, write something like this:

Copy
{{#$Model.Opportunities.data}}
{{Name}} (Stage: {{StageName}}, Close: {{CloseDate}})
{{/$Model.Opportunities.data}}

Or another example, iterating over an account model's data:

Copy
{{#$Model.Account.data}}
{{Name}} ({{BillingCity}}, {{BillingState}})
{{/$Model.Account.data}}

Iterating over child relationship records

For some connections, like Salesforce, it's possible to iterate over child relationship records, if that relationship is available on the model. Nintex Apps stores child records in a special property of the field named records.

This example iterates over a product's price book entry records to generate HTML list elements:

Copy
{{#PricebookEntries.records}}
  • {{UnitPrice}} ({{Pricebook2.Name}})
{{/PricebookEntries.records}}

Notice that within the section, merge variables are relative to the current record. So, rather than {{PricebookEntries.records.UnitPrice}} , we use simply {{UnitPrice}} . Pricebook2.Name does use dot notation since it is a reference field on the child relationship.

iterating-on-child-relationships

Note:  It's important to add any fields used in a child relationship merge expression to the model through the Child Relationships tab, otherwise your merge expression may appear empty at runtime.

Merge functions

Merge functions are Nintex Apps -defined functions that can be called in any context using expression logic.

For more information, see our global merge variables and functions index.

Using Merge Expressions in JavaScript

To use merge expressions in JavaScript, call the skuid.utils.merge() API.

For example:

Copy
var model = skuid.model.getModel( 'User' ),
   row = model.getFirstRow();

var addressExpression =
   '{{Street}}\\n' +
   '{{City}}, {{State}} {{PostalCode}}\\n' +
   '{{Country}}';

element.html(
   skuid.utils.merge( 'row', addressExpression, null, model, row )
);

Nintex Apps's merge variable syntax is built on mustacheJS. To use the mustache API directly (to access pre-parsing, for example), access the API via skuid.Mustache. Note that you will not be able to use some of Nintex Apps expression features, such as merge variables.

Troubleshooting