UNPKG

@mui/x-data-grid

Version:

The community edition of the data grid component (MUI X).

112 lines (102 loc) 3.78 kB
import { createSelector, createSelectorMemoized } from '../../../utils/createSelector'; /** * Get the columns state * @category Columns */ export var gridColumnsStateSelector = function gridColumnsStateSelector(state) { return state.columns; }; /** * Get an array of column fields in the order rendered on screen. * @category Columns */ export var gridColumnFieldsSelector = createSelector(gridColumnsStateSelector, function (columnsState) { return columnsState.orderedFields; }); /** * Get the columns as a lookup (an object containing the field for keys and the definition for values). * @category Columns */ export var gridColumnLookupSelector = createSelector(gridColumnsStateSelector, function (columnsState) { return columnsState.lookup; }); /** * Get an array of column definitions in the order rendered on screen.. * @category Columns */ export var gridColumnDefinitionsSelector = createSelectorMemoized(gridColumnFieldsSelector, gridColumnLookupSelector, function (allFields, lookup) { return allFields.map(function (field) { return lookup[field]; }); }); /** * Get the column visibility model, containing the visibility status of each column. * If a column is not registered in the model, it is visible. * @category Visible Columns */ export var gridColumnVisibilityModelSelector = createSelector(gridColumnsStateSelector, function (columnsState) { return columnsState.columnVisibilityModel; }); /** * Get the visible columns as a lookup (an object containing the field for keys and the definition for values). * @category Visible Columns */ export var gridVisibleColumnDefinitionsSelector = createSelectorMemoized(gridColumnDefinitionsSelector, gridColumnVisibilityModelSelector, function (columns, columnVisibilityModel) { return columns.filter(function (column) { return columnVisibilityModel[column.field] !== false; }); }); /** * Get the field of each visible column. * @category Visible Columns */ export var gridVisibleColumnFieldsSelector = createSelectorMemoized(gridVisibleColumnDefinitionsSelector, function (visibleColumns) { return visibleColumns.map(function (column) { return column.field; }); }); /** * Get the left position in pixel of each visible columns relative to the left of the first column. * @category Visible Columns */ export var gridColumnPositionsSelector = createSelectorMemoized(gridVisibleColumnDefinitionsSelector, function (visibleColumns) { var positions = []; var currentPosition = 0; for (var i = 0; i < visibleColumns.length; i += 1) { positions.push(currentPosition); currentPosition += visibleColumns[i].computedWidth; } return positions; }); /** * Get the summed width of all the visible columns. * @category Visible Columns */ export var gridColumnsTotalWidthSelector = createSelector(gridVisibleColumnDefinitionsSelector, gridColumnPositionsSelector, function (visibleColumns, positions) { var colCount = visibleColumns.length; if (colCount === 0) { return 0; } return positions[colCount - 1] + visibleColumns[colCount - 1].computedWidth; }); /** * Get the filterable columns as an array. * @category Columns */ export var gridFilterableColumnDefinitionsSelector = createSelectorMemoized(gridColumnDefinitionsSelector, function (columns) { return columns.filter(function (col) { return col.filterable; }); }); /** * Get the filterable columns as a lookup (an object containing the field for keys and the definition for values). * @category Columns */ export var gridFilterableColumnLookupSelector = createSelectorMemoized(gridColumnDefinitionsSelector, function (columns) { return columns.reduce(function (acc, col) { if (col.filterable) { acc[col.field] = col; } return acc; }, {}); });