Creating rules in your application
With the Rules feature, you can create a dynamic user experience. Rules can make a field required, show or hide fields, activate or deactivate fields, and much more. Implementing rules in your applications guides the user through the form-filling process.
A rule is made up of:
- name: this helps the author to identify and distinguish it from other rules within their application,
- conditions: defined by the form author, it is when the state of a form object meets the specified criteria
- actions: these are the changes that will be made in the form when the condition(s) is/are met.
An example of a common pattern is to make a field visible and required when the value of another field is provided. Rules can also be more complicated, the form author can define one or more condition groups comprised of one or more conditions.
Conditions within a condition group are evaluated using the same logical operator. The operators are:
- AND: all conditions must be true
- OR: only one must be true
A rule may contain multiple condition groups which are also evaluated using a logical operator.
This page describes the rules dialog, the operators and actions that can be used and provides some examples of rules that can be created within your form.
Rule Dialog
-
The rule may be given a custom name by entering it into the Rule Name field.
-
Each Rule can perform multiple actions: hide/show, enable/disable, required/not required, valid/not valid. For example in the above screenshot, if marital status equals “Married” or "Common-law" then the "Name of spouse" field will be visible. When this condition is not met then the "Name of spouse" field will be hidden.
-
The action to perform, see Rule Actions.
-
The left-side operand of the condition.
-
The operator, see Rule Operators.
-
The right-side operand of the condition.
-
Apply will create the rule but leave the dialog open, Apply and Close will create the rule and close the dialog, and Cancel will close the dialog and it will not keep any changes made since the last time “Apply” was clicked or the dialog was opened. If you navigate to a different rule, before applying your changes you will see a dialog warning of unsaved changes. If you click “Apply Changes” then your rule modifications will be saved. If you click “Discard Changes” then any changes made will be thrown away. If you click “Cancel” then the attempt to navigate away from the current rule will be canceled.
-
Add additional actions to be performed when the conditions are true.
-
Minimize or delete a condition that is being edited.
-
Edit a condition or delete a condition. Clicking the pencil icon will expand the condition, enabling the author to edit it.
-
Change the relationship of the conditions.
-
Filters the rules shown on the left based on the field selected.
-
Changes the sort order of the rules.
-
A saved rule. Clicking on the trash can icon will prompt the user about deleting the rule; clicking 'yes' will delete the rule.
-
Click 'Add Rule' to add a new rule.
Note
In creating rules, it is important to remember that rules can affect each other and in some cases completely counteract what you have defined. You should never refer to the same item in the “Perform this action” section for multiple rules. The general rule here is that if there are conflicts then the “last” rule wins.
-
Click + Add Condition to add a new condition to the rule. Conditions added with in a group must share the same relationship operator.
-
Click + Add Condition Group to add a new condition group. The relationship operator for condition groups must be the same for all groups. Nested condition groups are not supported.
Rule Operators
The operator defines how the operands will be evaluated. The available operators will change based on the items referenced within the rule.
Operator | Description |
---|---|
After | Returns true if the date specified is “after” the exact value or the value of the other form item specified. |
Before | Returns true if the date specified is “before” the exact value or the value of the other form item specified. |
Between | Checks if the value of the selected field falls alphabetically between either two fixed/form items. Such as, “Red” is between “Green” and “Yellow” because “R” is between “G” and “Y” in the alphabet. Case matters here, as the string is evaluated against the alphabet by first scanning the uppercase letters (A-Z) and then the lowercase (a-z). For example if you specified between “Green” and “brown”, then “Red” would be valid but “red” would not, because the alphabet range would be A-Z + a-b. |
Contains | Does the specified string contain the fixed/field value. This function recognizes case. |
Day is | Compares the day of the date specified with an exact value or the value of another item. |
Does not equal | True if the fixed/field value does not equal the specified value. |
Does not include | True if the fixed/field value does not contain the specified value. |
Ends With | Does the specified string end with the fixed/field value. This function recognizes case. |
Equals | True if the specified string is equal to the fixed/field value. Case matters, “c” does not equal “C”. |
Follows | True if the specified string come after the fixed/field value in the alphabet. i.e. “Red” follows “Green”. This function recognizes case. |
Includes | Can the specified string be found in the fixed/field value. |
Matches | True if the specified string match the fixed/field value. Similar to contains, it is true if the specified string can be found anywhere in the value. This function recognizes case. |
Month is | Compares the month of the date specified with an exact value or the value of another item. |
Precedes | True if the specified string is found at the start of the fixed/field value in the alphabet. i.e. “Red” precedes “Yellow”. This function recognizes case. |
Starts with | True if the specified string start with the fixed/field value. This function recognizes case. |
Has value | True if the field has a value. |
Has no value | True if the field is empty. |
Year is | Compares the year of the date specified with an exact value or the value of another item. |
Number/Currency Operators
These are the operators for number and currency fields.
Operator |
---|
Between |
Does not equal |
Equals |
Greater than |
Greater than or equals |
Less than |
Less than or equals |
Single Line / Multi-Line Operators
These are the operators for single-line and multi-line fields.
Operator |
---|
Between |
Contains |
Ends with |
Equals |
Follows |
Matches |
Precedes |
Starts with |
Has value |
Has no value |
Select One / Checkbox / Dropdown Operators
These are the operators for select one, checkbox and dropdown fields.
Operator |
---|
Equals |
Does not equal |
Has value |
Has no value |
Select Many Operators
These are the operators for select many fields.
Operator |
---|
Matches |
Does not match |
Includes |
Does not include |
Has value |
Has no value |
Time / Timestamp Operators
These are the operators for time and timestamp fields.
Operator |
---|
After |
Before |
Between |
Has value |
Has no value |
Date Operators
These are the operators for date fields.
Operator |
---|
After |
Before |
Between |
Day is |
Equals |
Has value |
Has no value |
Month is |
Year is |
Rule Actions / Behaviors
Rules can be set for the following actions/behaviors:
Show or Hide
You can set data entry items, buttons, and containers to be hidden, or visible.
Enable or Disable
You can set buttons and data entry items as enabled or disabled.
Valid or Not Valid
In a data entry item, such as a Single Line Entry field, you can set conditions on what type of information is acceptable. For example, in a timesheet application, you can set a rule that the check-out time cannot occur before a check-in time.
Required or Not required
You can choose whether you want data entry items to be mandatory, or optional.
Additional general information on Rules
- You can add multiple Boolean operators, such as AND, and OR, for each rule. However, you cannot mix the two conditions in a rule.
- You can name and rename rules. It is useful to give each rule a unique and descriptive name. If you have several rules with similar operations, a descriptive name lets you quickly find the specific rule without having to open each one to view the details.
- You can search rules based on form item.
- To set a new rule, use the Edit rules icon in each form item. You can also create rules for pages and buttons. You can use the icon to open a rule and edit it.
- After a rule is set, a checkmark appears on the Rule icon for the form item, as well as any form item involved in the rule. This makes it easy to see which form items are used in rules.
- If you attempt to delete a form item that is used in a rule. If you agree, you delete the rule. If you duplicate a field, the rule is duplicated with it.
- A field's value is not cleared if its behavior changes because of a rule. You may need to explicitly clear the value if you do not want the previously entered value to be saved.
Note
When you set rules for Number or Currency form items, you must set the default value of the form item to zero in the Properties side panel. In the Properties side panel, set the minimum value to zero. If the Number or Currency form item is blank, it does not default to zero, and any rule you set does not work properly.
- Setting rules on form items
You can set rules that govern how form items appear in a form. - Setting rules on pages in an application
You can set rules that govern how pages are shown or hidden in a form. - Setting rules on Stages
You can direct the workflow of an application by setting rules on buttons within Stages.
Examples
Rule with an 'and' condition
This example demonstrates a rule using an 'and' condition. The field will be visible and required if both questions are 'Yes'.
The next image shows the rule in action.
Rule with an 'or' condition
This example demonstrates a rule using an 'or' condition. The field will be visible and required if either of the questions are 'Yes'.
The next image shows the rule in action.
Rule with multiple condition groups
and/or/and
This example demonstrates a rule using multiple condition groups. The field will be visible if '1' and 'a' or '2' and 'b' are selected.
or/and/or
This example demonstrates a rule using multiple condition groups. The field will be visible if '1' or '2' and 'a' or 'b' are selected.
The next image shows the rules in action.
Handling more complex logic
The Rules dialog does have its limitations and you may find that you have certain scenarios where you need additional flexibility. You can create your own customized behavior by using javaScript.
Within javaScript we can create any complex comparison. There are a few things that you need to know to get started creating your own logic:
- The AND operator in javaScript is &&
- The OR Operator in javaScript is ||
- You can control the order that conditions are evaluated by wrapping them in parenthesis. The example below, the condition will be true if a=1 AND b=2 OR if c=3 AND d=4.
if ( (a == 1 && b == 2) || (c == 3 && d == 4) ) {
// do something
}
Parent topic: Adding dynamic behavior