Skip to content

Commit

Permalink
[DataGrid] Support state export and restore on grid density (mui#12671)
Browse files Browse the repository at this point in the history
  • Loading branch information
MBilalShafi authored and DungTiger committed Jul 23, 2024
1 parent e77dea6 commit 28c9d42
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -78,6 +78,7 @@ const FULL_INITIAL_STATE: GridInitialState = {
sorting: {
sortModel: [{ field: 'id', sort: 'desc' }],
},
density: 'compact',
};

describe('<DataGridPro /> - State persistence', () => {
Expand Down Expand Up @@ -135,6 +136,7 @@ describe('<DataGridPro /> - State persistence', () => {
sorting: {
sortModel: [],
},
density: 'standard',
});
});

Expand Down Expand Up @@ -165,6 +167,7 @@ describe('<DataGridPro /> - State persistence', () => {
paginationMode="server"
rowCount={FULL_INITIAL_STATE.pagination?.rowCount}
pinnedColumns={FULL_INITIAL_STATE.pinnedColumns}
density={FULL_INITIAL_STATE.density}
// Some portable states don't have a controllable model
initialState={{
columns: {
Expand All @@ -191,6 +194,7 @@ describe('<DataGridPro /> - State persistence', () => {
paginationMode="server"
rowCount={FULL_INITIAL_STATE.pagination?.rowCount}
pinnedColumns={FULL_INITIAL_STATE.pinnedColumns}
density={FULL_INITIAL_STATE.density}
// Some portable states don't have a controllable model
initialState={{
columns: {
Expand Down Expand Up @@ -226,6 +230,7 @@ describe('<DataGridPro /> - State persistence', () => {
apiRef.current.setColumnIndex('category', 1);
apiRef.current.setColumnWidth('category', 75);
apiRef.current.setColumnVisibilityModel({ idBis: false });
apiRef.current.setDensity('compact');
});
expect(apiRef.current.exportState()).to.deep.equal(FULL_INITIAL_STATE);
});
Expand Down
56 changes: 49 additions & 7 deletions packages/x-data-grid/src/hooks/features/density/useGridDensity.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { GridDensityApi } from '../../../models/api/gridDensityApi';
import { DataGridProcessedProps } from '../../../models/props/DataGridProps';
import { gridDensitySelector } from './densitySelector';
import { GridStateInitializer } from '../../utils/useGridInitializeState';
import { GridPipeProcessor, useGridRegisterPipeProcessor } from '../../core/pipeProcessing';

export const densityStateInitializer: GridStateInitializer<
Pick<DataGridProcessedProps, 'initialState' | 'density'>
Expand All @@ -17,7 +18,7 @@ export const densityStateInitializer: GridStateInitializer<

export const useGridDensity = (
apiRef: React.MutableRefObject<GridPrivateApiCommunity>,
props: Pick<DataGridProcessedProps, 'density' | 'onDensityChange'>,
props: Pick<DataGridProcessedProps, 'density' | 'onDensityChange' | 'initialState'>,
): void => {
const logger = useGridLogger(apiRef, 'useDensity');

Expand All @@ -43,15 +44,56 @@ export const useGridDensity = (
}));
});

React.useEffect(() => {
if (props.density) {
apiRef.current.setDensity(props.density);
}
}, [apiRef, props.density]);

const densityApi: GridDensityApi = {
setDensity,
};

useGridApiMethod(apiRef, densityApi, 'public');

const stateExportPreProcessing = React.useCallback<GridPipeProcessor<'exportState'>>(
(prevState, context) => {
const exportedDensity = gridDensitySelector(apiRef.current.state);

const shouldExportRowCount =
// Always export if the `exportOnlyDirtyModels` property is not activated
!context.exportOnlyDirtyModels ||
// Always export if the `density` is controlled
props.density != null ||
// Always export if the `density` has been initialized
props.initialState?.density != null;

if (!shouldExportRowCount) {
return prevState;
}

return {
...prevState,
density: exportedDensity,
};
},
[apiRef, props.density, props.initialState?.density],
);

const stateRestorePreProcessing = React.useCallback<GridPipeProcessor<'restoreState'>>(
(params, context) => {
const restoredDensity = context.stateToRestore?.density
? context.stateToRestore.density
: gridDensitySelector(apiRef.current.state);
apiRef.current.setState((state) => ({
...state,
density: restoredDensity,
}));
return params;
},
[apiRef],
);

useGridRegisterPipeProcessor(apiRef, 'exportState', stateExportPreProcessing);
useGridRegisterPipeProcessor(apiRef, 'restoreState', stateRestorePreProcessing);

React.useEffect(() => {
if (props.density) {
apiRef.current.setDensity(props.density);
}
}, [apiRef, props.density]);
};

0 comments on commit 28c9d42

Please sign in to comment.