UI Multiselect Component
The Multiselect component is used to provide check box interface for a specific listing or a specific data set. The component is an extension for Column component and allows selecting either a collection of items or all items from the given set.
The Multiselect component which stores the information about the number of selected items in its template shares this data with the following components:
- Pagination
- MassAction
When making any actions which affect the item selection, like filtering, the number of selected items in the Multiselect component is flushed as currently collection contains only one item and knows nothing about the general set of data.
Multiselect is a child of the Grid component and is rendered in its view. Like any component, it can hold the sort order value which influences the order of all its child elements.
When you specify the after
or before
property in the Multiselect component, it references any existing component in the parent container and renders it in that specified position.
Multiselect JS Component Structure
The Multiselect component is implemented in the class app\code\Magento\Ui\view\base\web\js\grid\columns\multiselect.js.
Templates used by this component are:
app\code\Magento\Ui\view\base\web\templates\grid\cells\multiselect.html
- The template defines every specific field in the grid. It provides the Multiselect component with the check box interface for selecting item(s) in the grid and performing actions over them.app\code\Magento\Ui\view\base\web\templates\grid\columns\multiselect.html
- The template defines the grid header with drop-down lists and the Select All, Deselect All, and other options.
The component provides the following options:
- header template option
- body template option
Code samples available in the default configuration:
headerTmpl: 'ui/grid/columns/multiselect'
bodyTmpl: 'ui/grid/cells/multiselect'
-
imports option
The option defines from where the component receives its data.
-
actions option
You can modify the default actions by, for example, renaming their frontend labels.
-
indexField option
This option allows specifying which field represents record identifier.
Methods and Events
No events are generated. Any other component that can retrieve access to this component and its properties can get data and track its changes using subscription.
How to configure Multiselect Component already used in code
Sample of code where component configurations are performed:
Current implementation:
<column name="ids" class="Magento\Ui\Component\MassAction\Columns\Column">
<argument name="data" xsi:type="array">
<item name="js_config" xsi:type="array">
<item name="component" xsi:type="string">Magento_Ui/js/grid/columns/multiselect</item>
</item>
<item name="config" xsi:type="array">
<item name="indexField" xsi:type="string">page_id</item>
<item name="appendTo" xsi:type="string"></item>
</item>
</argument>
</column>
Example of configuration modifications:
- Redefining the link to the template
<column name="ids" class="Magento\Ui\Component\MassAction\Columns\Column">
<argument name="data" xsi:type="array">
...
<item name="config" xsi:type="array">
<item name="headerTmpl" xsi:type="string">product/grid/columns/multiselect</item>
</item>
</argument>
</column>
- Redefining the name of the property which represents record identifier
<column name="ids" class="Magento\Ui\Component\MassAction\Columns\Column">
<argument name="data" xsi:type="array">
...
<item name="config" xsi:type="array">
<item name="indexField" xsi:type="string">product_id</item>
</item>
</argument>
</column>
- Redefining a property data source
<column name="ids" class="Magento\Ui\Component\MassAction\Columns\Column">
<argument name="data" xsi:type="array">
...
<item name="config" xsi:type="array">
<item name="imports" xsi:type="array">
<item name="rows">products_prodvider:data.products</item>
</item>
</item>
</argument>
</column>
How to add a new component
Instance Replacement: One Instance of a Component
- Redefine the link to constructor:
<column name="ids" class="Magento\Ui\Component\MassAction\Columns\Column">
<argument name="data" xsi:type="array">
<item name="js_config" xsi:type="array">
<item name="component" xsi:type="string">Magento_Products/js/grid/columns/multiselect</item>
</item>
</argument>
</column>
Find us on