List widget

The List widget displays data records in a custom list view. It uses a card design as a container for a few short descriptions of related information with the option to include a button to view additional details. You can choose from several templates to build the card layout. The templates include image, button, and text widgets. You can also choose a blank template to design your own. The data source for the list is defined by a feature layer. Each item card in the list represents a record and the widgets on a card can be used to display the record’s attributes. To design the list, you can customize the style settings and modify the layout of the first card to update all the cards in the list.

Examples

Use this widget to support app design requirements such as the following:

  • You want to build an app that allows end users to select a record in the list and view it on the map.
  • You want to display records from a data source in a custom list view. The records to display must meet certain criteria.
  • You want to provide a list for end users to interact with, such as filtering the list, sorting the list with predefined options, and selecting records in the list.

Usage notes

When you add a List widget, first choose a template design for the item cards in the list, and click Start. On the canvas, the first item in the List widget is activated and you can modify the layout of the widgets within it or add more by dragging widgets from the Insert panel into the first card. Currently, the List widget only supports Text, Button, and Image widgets.

The List widget requires a data source. You can use the List widget on a page with or without a displayed map. If you include a Map widget that uses the same layer, clicking a feature in the list, highlights the corresponding feature in the map. When designing the contents of item cards in the list, specify what you want to display by configuring the widgets in the first item, selecting respective dynamic content to populate records from the connected data source. (By default, widgets that you add to the list inherit the list’s data.) You can also set actions for a List widget to interact with other widgets in your app, such as zooming to the selected feature on a map in a Map widget or displaying the selected feature’s attributes in a Feature Info widget.

If you configure the List widget with multiple states (Regular, Hover, and Selected), a Linked to button Linked to appears when you select the nested widgets. The button indicates whether the widget’s settings are isolated or synchronized across the states.

  • For synchronized widgets, the widget content and style settings (background, border, and shadow) are the same, and the size and positions can be different across states.
  • For isolated widgets, you can configure properties without affecting any other widgets in another state.
  • To use the same widget in another state or synchronize the widget’s size and position as well, select the widget and apply it to the target state.
  • When you delete a synchronized widget, the same widget in different states is also deleted unless you isolate the widget first.

Settings

The List widget includes the following settings:

  • Select a template—Choose from predefined list designs or start with an empty list template. (If you choose a template, you can customize its appearance later.)
  • Data—Specify the data to include in the list.
    • Select data—Select the data source for a feature layer with features to show in the widget.
    • Filter and sortFilter the source data to restrict what appears in the widget. Sort the data to display list items in a particular order. The applied filter and sort does not affect other widgets that use the same data.
    • Maximum items—Limit the number of features that appear in the widget.
  • Arrangement—Define how to display the items in the list.
    • Direction—Display items in a horizontal or vertical list.
    • Item width or height—Specify the size of list items in pixels.
      • For a horizontal list, define the list item’s width by typing a precise pixel number in this setting or dragging the resize bar on the canvas. The item’s height is defined by the widget’s height.
      • For a vertical list, define the list item’s height by typing a precise pixel number in this setting or dragging the resize bar on the canvas. The item’s width is defined by the widget’s width.
    • Lock width/height ratio—Lock the width/height ratio of list items when the widget is resized.
    • Horizontal or Vertical spacing—Define the spacing between list items in pixels.
    • Paging style—Define how to load list items that don’t fit on the first page:
      • Scroll—Load more items when users scroll down in the list.
        • Scroll bar—Show a scroll bar.
        • Navigator—Include up and down navigation controls for scrolling the list. For Step, define the number of items to scroll for each click in the navigator control.
      • Multi-page—Divide a long list into several pages using pagination. For Items per page, define the number of items to display on a page.
  • States—Provide a visual representation to communicate the three states of list items: Regular (default state for the item without user interaction), Hover (user initiates this state by pointing to a list item), and Selected (user selects the list item).
    Tip:

    If you change the corresponding states for nested widgets, you can isolate the changes so they don't apply to all the states. Select the List widget, click the button for the state you want to change, click a nested widget, click the Linked to button Linked to that appears, choose Isolate, and then configure the nested widget's settings. (If you configure settings first and then click Isolate, the changes will have already been applied to the other states.)

    • Background—Set the background for list items in their regular state (no current user interaction). Choose a fill color or image. If you choose an image, you can position it within the list item’s border using FitFillCenterTile, or Stretch. If you choose Fit, the background fill color appears around the image.
    • Border—Set the border for list items in their regular state by choosing the border color, style (such as dashed or dotted), and width in pixels.
    • Border radius—Change the radius size (by pixels or percent) to shape the corners of list items in their regular state. Lock the settings to synchronize the radius of all four corners.
    • Hover—Specify whether the appearance of a list item changes when end users hover over it. When the hover state is enabled, its settings appear in the configuration panel with options to change the background, border, and border radius of the hovered list item.
      • A Hover tab appears next to the first list item in the canvas, which updates to show how the item will appear when users hover over it. You can also add widgets or delete, resize, and reposition existing widgets for the hover state only.
    • Selected—Specify whether the item card in the list can be selected and how its appearance changes when end users click to select it. When the selected state is enabled, its settings appear in the configuration panel with options to allow multiselect and change the background, border, and border radius of the selected list item. With Select mode, you can limit selections to only one item at a time (clicking another item clears the current selection) or allow end users to select multiple items at the same time (clicking another item adds it to the current selection set).
      • A Selected tab appears next to the first list item in the canvas, which updates to show how the item will appear when users select it. You can also add widgets or delete, resize, and reposition existing widgets for the selected state only.
  • Tools—Provide tools for end users to interact with the list.
    • Search—Provide a search box in the list.
      • Select searching fields—Choose one or more fields to search.
      • Exact match—Limit search results to only records that match the search phrase.
    • Sort—Provide a menu for end users to sort the list by specific fields and sequence. Type a custom name for each menu option.
    • Filter—Add filters for end users to interact with the list.
    • Show selected—Provide the option for end users to update the list to only display the selected items.