Note: Nintex Apps is in beta release.
Drawers
A drawer is a panel that opens below a Table component row or below a List item. The drawer displays additional data, either from the component's model (to provide more information about the selected record) or from a related object by using a context condition.
Using drawers allows end users to quickly scan a Table or List consisting of multiple records, then open drawers on individual rows/items to obtain a broader view of those records. Additionally, by opening two separate drawers, users can compare different related records simultaneously—something that is more difficult with other "container" elements, such as modals or sliding panels.
Context considerations
Drawers act as context containers that display records related to the row from which they are opened. Each drawer has a default context variable—drawer_context—mapped to Id of the clicked row.
If your scenario requires more specific filtering, you can define additional context variables. These variables can then be referenced by the models and components within the drawer, ensuring they display the exact subset of data you need.
For more information about context, see the Context topic.
Use drawers to reveal details
In the example below, we're going to create a drawer on a Table that lists minimal top-level information (for example, name of company, industry, annual revenue) about client companies. Drawers can accommodate most Nintex Apps components. This drawer uses a Tab Set component to display:
- More detailed information about each company in a Table component
- Information about the contacts associated with each company in a Form component
Note: We are using a Table component for this example, but the process is the same if you are adding a drawer to a List component.
Assumptions
The steps below assume that you already have a page with:
- A model that surfaces information about client accounts. The model includes all fields needed to display top-level account information (for the Table component) as well as detailed account information (for the drawer).
- A Table component on that model displaying those top-level fields.
First, create a second functioning model on a data object that surfaces information about the contacts for client accounts. The model should include all the fields needed to display information about customer contacts at a specific account (name, title, phone number, email address, etc.)
Now, configure that model by making the following edits in the Properties pane:
- Query on page load: Uncheck
- Create Default Row if Model has none: Uncheck
Note: This ensures that the contact data for a specific account is only loaded when it's requested, making the initial page load faster. It also ensures the end user only gets the related data that is needed.
Next, be sure to include the field on the contacts data object that connects it to the account's object. This is a reference type field, often with a name like AccountId.
Important: If you do not include that reference field, you cannot create the necessary condition.
Note: Nintex Apps uses the term "condition" in several places within the app. Check out the glossary to learn more.
This model condition will allow us to filter for the contacts associated with the account record selected by the end user.
- Click the contact model.
- Click Conditions under the contact model.
- Click next to Conditions to create a new condition.
- In the Condition property pane, edit:
- Field: The reference field that links the contact object to the account object. (See warning above.)
- Operator: =
- Value: (Leave blank.)
- State: Dynamic (Default off).
- Click Save.
In this drawer, we're going to be providing additional information from the account model that's already used on the Table. We're also going to be asking for contacts for those accounts.
How does Nintex Apps know which contacts to surface? Use a Before Load action to ensure that, when the end user opens the drawer for a specific record, the correct data is pulled into it. ( This is where that model condition created earlier comes into play... )
-
To open the drawer, do one of the following:
- Click the Configure drawer icon on the Table.
- In the Display tab, under Drawers, click Configure drawer.
-
In the Drawer Properties General tab:
- Show drawer icon: Check
-
In the Before load actions tab:
-
Click
Add actions to add and configure actions:-
First action: Provide a message telling users that the drawer-opening process is underway.
- Action type: Show message and block UI
- Message: Add a helpful message.
- Timeouts (seconds): Never
-
Second action: Trigger the previously-created model condition.
-
Action type: Activate & set value of model condition
-
Model: The contacts model
-
Condition: The model condition on the contacts model
-
Value: {{Id}}
Note: Using this ID lets Nintex Apps know which record this drawer was opened for, and therefore which contact information should be passed into the drawer.
-
-
Third action: Return the appropriate data.
-
Action type: Query model
-
Model: The contacts model
-
Query behavior: Get More – merge in new Rows with old
Note: This adds new contact data to the existing contact data. This way, end users can see multiple open drawers at the same time. If Query Behavior is not set to this property, when a user opens a second drawer the first drawer goes blank because the second drawer's data completely replaces the first's.
-
-
Fourth action: Display the requested data in the drawer.
- Action type: Unblock the UI
-
-
-
Click Save.
And now for the fun part: building out the drawer.
- Click the Drawer to access the drawer.
- In the General tab, click Configure drawer.
- Drag and drop a Tab Set into the drawer and edit:
- Remember active tab: Checked.
- Click the first tab in the Tab Set and customize the tab properties:
- Tab label: Details
- Icon ( optional ): Choose an icon for the tab.
- Click the Tab Set, then click Add tab. Customize this new tab's properties:
- Tab label: Contacts
- Icon ( optional ): Choose an icon for the tab.
This Table will display additional details about selected customer accounts.
-
Drag and drop a Table component into the first tab in the drawer (the Details tab). Make sure it's on the model that collects accounts.
- Add the fields that will provide additional details about customer accounts.
-
Click the Table, then click the Context tab in the Table properties pane.
-
Click Context Conditions, and edit:
next to- Field: Id
- Merge Field: Id
- Operator: =
Note: Since this Table displays information from the accounts model, both ID fields are from the accounts model. This tells Nintex Apps that the details displayed in this Table must be from the same account record that the user clicked on. This way, if a user has multiple drawers open, Nintex Apps knows which record's data goes in each drawer.
This Form will display contacts for the selected customer account.
-
Drag and drop a Form component into the second tab in the drawer (the Contacts tab). Make sure it's on the model that collects contact information.
- Add sections and fields that provide information about customer contacts.
-
Click the Form, then click the Context tab in the Form properties pane.
- Click Context Conditions, and edit:
- Field: For this field use the ID field from the account model, not from the contacts model. This is a reference type field, often with a name like "AccountId."
- Merge Field: Id
- Operator: =
next to
Note: The Form displays contact information for the account the end user clicked on. The context condition tells Nintex Apps to display only contacts where the reference type field that defines the contact's account is the same as the ID for the account record clicked on.
- Click Context Conditions, and edit:
-
Close the Drawer Configuration window and click Save.
Preview and test
With the page completed, click Preview to see the end result.
Pick a record, then click the > at the head of the row to open that drawer. The Tab Set will offer two options: Details, which displays the Table with more details about the record; and Contacts, which provides information about the contacts for that account.
Nifty, huh? Close the drawer by clicking
a second time.Or open more than one drawer. Each one provides an entirely different set of records. ( This is how you know your Context Conditions are working correctly. )
Drawers provide lots of options:
- Drawers on a Table (or List) of customer accounts could display invoices for each—or service orders.
- Drawers on a Table cataloging products might give updated information about the product's supply chain.
- A List of customer support tickets might use a drawer to track each action taken to resolve the complaint, and the associated in-house handoffs between service providers.
It's all possible with drawers.
Properties
Show drawer icon: Determines whether or not to display an icon next to the record. If unchecked, the drawer can be opened and closed by configuring a global action (in a Table component) or row action (in a Table or List component) to run the Open/Close A Drawer action.
Icon: Click the icon picker to select a different icon.
Configure drawer: Opens the drawer configuration modal.
Before Load Actions refers to actions used before a drawer is loaded. Generally, these actions are used to activate and set the values of model conditions, and to query models to ensure that the contextually-relevant data will display in the drawer.
For more information, see Add Nested Rows to your Table with Drawers
Context variables for context containers are managed from the Context variables property section. For more information about context variables, see the Context topic.
Troubleshooting
- Is the reference field connecting the second model to the first included in the second model? (e.g. AccountId on a contact model)
- Do you have the Query model action in your Before load actions?
- Is it querying the right models?
- Is the query type Get More – Merge in new rows with old? ( It should not be Standard - Completely replace data. )
- Are the Context Conditions configured correctly?