@mui/x-data-grid
Version:
The community edition of the data grid component (MUI X).
35 lines (29 loc) • 1.85 kB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import * as React from 'react';
import { useGridRegisterPipeProcessor } from '../../core/pipeProcessing';
import { isDeepEqual } from '../../../utils/utils';
import { unwrapGroupingColumnModel, hasGroupPath } from './useGridColumnGrouping';
export const useGridColumnGroupingPreProcessors = (apiRef, props) => {
var _props$experimentalFe2;
const addHeaderGroups = React.useCallback(columnsState => {
var _props$experimentalFe;
if (!((_props$experimentalFe = props.experimentalFeatures) != null && _props$experimentalFe.columnGrouping)) {
return columnsState;
}
const unwrappedGroupingModel = unwrapGroupingColumnModel(props.columnGroupingModel);
columnsState.all.forEach(field => {
var _unwrappedGroupingMod, _unwrappedGroupingMod2;
const newGroupPath = (_unwrappedGroupingMod = unwrappedGroupingModel[field]) != null ? _unwrappedGroupingMod : [];
const lookupElement = columnsState.lookup[field];
if (hasGroupPath(lookupElement) && isDeepEqual(newGroupPath, lookupElement == null ? void 0 : lookupElement.groupPath)) {
// Avoid modifying the pointer to allow shadow comparison in https://github.com/mui/mui-x/blob/f90afbf10a1264ee8b453d7549dd7cdd6110a4ed/packages/grid/x-data-grid/src/hooks/features/columns/gridColumnsUtils.ts#L446:L453
return;
}
columnsState.lookup[field] = _extends({}, columnsState.lookup[field], {
groupPath: (_unwrappedGroupingMod2 = unwrappedGroupingModel[field]) != null ? _unwrappedGroupingMod2 : []
});
});
return columnsState;
}, [props.columnGroupingModel, (_props$experimentalFe2 = props.experimentalFeatures) == null ? void 0 : _props$experimentalFe2.columnGrouping]);
useGridRegisterPipeProcessor(apiRef, 'hydrateColumns', addHeaderGroups);
};