Selected Fields Providers 

The selected fields providers must implement interface Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsProviderInterface. Selected fields provider returns an array of field names which must be present in the select statement of the datasource query according to the given datagrid configuration and parameters. In other words, depending on the datagrid configuration and parameters (request- and user-specific), it must return the fields needed to be displayed/processed for the datagrid to be rendered correctly.

Keep in mind that the word field here does not mean an entity field or extended field, but rather a field that must be present in the select statement of a query.

OroDatagridBundle provides two selected fields providers out-of-box:

  • oro_datagrid.provider.selected_fields.columns (Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsFromColumnsProvider)

  • oro_datagrid.provider.selected_fields.sorters (Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsFromSortersProvider)

These providers are collected in the oro_datagrid.provider.selected_fields (Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsProvider) service, which calls all its inner providers and returns an array of unique field names.

How to Use 

Selected fields providers enable fetching field names which must be present in the datasource query of the datagrid. This data can be used in datagrid extensions which modify the datagrid configuration, add new columns, sorters, etc. The purpose is to detect whether it is necessary to add a certain field or join the datasource query, as not every field added to the query is actually displayed to the end user. This can significantly help improve the performance of datagrids that work with tables with many records.

For example, the oro_datagrid.provider.selected_fields service is used in the oro_entity_extend.datagrid.extension.dynamic_fields datagrid extension to prevent adding joins for extended fields which are not going to be displayed to the end user.

Selected Fields Provider 

The Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsProvider composite provider is declared as the oro_datagrid.provider.selected_fields service that returns selected fields from all inner providers.

Example:

$selectedFieldsStateProvider = $this->container->get('oro_datagrid.provider.selected_fields');
$selectedFields = $selectedFieldsStateProvider->getSelectedFields($datagridConfiguration, $datagridParameters);
var_export($selectedFields);
// Will output
//['sampleField1', 'sampleColumn2']

Fields Required by Columns 

The Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsFromColumnsProvider provider is declared as the oro_datagrid.provider.selected_fields.columns service. It returns fields (used in renderable columns) that must be present in the select statement of the datasource query.

It uses Oro\Bundle\DataGridBundle\Provider\State\ColumnsStateProvider to fetch the current state of columns, then collects data_name configuration options from columns which are currently renderable (visible).

Keep in mind that the resulting array of fields can differ depending on the moment when the provider is called because it fetches data from the datagrid configuration and state, which can be changed by extensions and listeners.

The oro_datagrid.provider.selected_fields.columns service is not intended to be used directly. Use the oro_datagrid.provider.selected_fields service instead to get a full list of selected fields. However, you can use it if you specifically need those fields that are used in renderable columns.

Fields Required by Sorters 

The Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsFromSortersProvider provider is declared as a oro_datagrid.provider.selected_fields.sorters service. It returns an array of field names (required by applied sorters) which must be present in the select statement of the datasource query.

It uses Oro\Bundle\DataGridBundle\Provider\State\SortersStateProvider to fetch the current state of sorters, then collects data_name configuration options from sorters that are currently applied.

Keep in mind that the resulting array of fields can differ depending on the moment when a provider is called because it fetches data from the datagrid configuration and state that can be changed by extensions and listeners.

The oro_datagrid.provider.selected_fields.sorters service is not intended to be used directly. Use oro_datagrid.provider.selected_fields service instead to get a full list of selected fields. However, you can use it if you specifically need those fields that are required by applied sorters.

How to Customize 

You can create your own selected fields provider by implementing Oro\Bundle\DataGridBundle\Provider\SelectedFields\SelectedFieldsProviderInterface. Define it as a service with the oro_datagrid.selected_fields_provider tag.