Migration from v6 to v7
This guide describes the changes needed to migrate the Data Grid from v6 to v7.
Start using the new release
In package.json, change the version of the data grid package to next.
-"@mui/x-data-grid": "^6.0.0",
+"@mui/x-data-grid": "next",
Since v7 is a major release, it contains changes that affect the public API. These changes were done for consistency, improved stability and to make room for new features. Described below are the steps needed to migrate from v6 to v7.
Run codemods
The preset-safe codemod will automatically adjust the bulk of your code to account for breaking changes in v7.
You can run v7.0.0/data-grid/preset-safe targeting only Data Grid or v7.0.0/preset-safe to target other MUI X components like Date and Time pickers as well.
You can either run it on a specific file, folder, or your entire codebase when choosing the <path> argument.
// Data Grid specific
npx @mui/x-codemod v7.0.0/data-grid/preset-safe <path>
// Target other MUI X components as well
npx @mui/x-codemod v7.0.0/preset-safe <path>
Breaking changes that are handled by preset-safe codemod are denoted by a ✅ emoji in the table of contents on the right side of the screen or next to the specific point that is handled by it.
If you have already applied the v7.0.0/data-grid/preset-safe (or v7.0.0/preset-safe) codemod, then you should not need to take any further action on these items. If there's a specific part of the breaking change that is not part of the codemod or needs some manual work, it will be listed in the end of each section.
All other changes must be handled manually.
Breaking changes
Since v7 is a major release, it contains some changes that affect the public API. These changes were done for consistency, improve stability and make room for new features. Below are described the steps you need to make to migrate from v6 to v7.
Removed props
The deprecated props
componentsandcomponentsPropshave been removed. UseslotsandslotPropsinstead. See components section for more details.The
slots.preferencesPanelslot and theslotProps.preferencesPanelprop were removed. Useslots.panelandslotProps.panelinstead.The
getOptionValueandgetOptionLabelprops were removed from the following components:GridEditSingleSelectCellGridFilterInputSingleSelectGridFilterInputMultipleSingleSelect
Use the
getOptionValueandgetOptionLabelproperties on thesingleSelectcolumn definition instead:const column: GridColDef = { type: 'singleSelect', field: 'country', valueOptions: [ { code: 'BR', name: 'Brazil' }, { code: 'FR', name: 'France' }, ], getOptionValue: (value: any) => value.code, getOptionLabel: (value: any) => value.name, };
State access
- Some selectors now require passing
instanceIdas a second argument:However, it's preferable to pass the- gridColumnFieldsSelector(apiRef.current.state); + gridColumnFieldsSelector(apiRef.current.state, apiRef.current.instanceId);apiRefas the first argument instead:See Direct state access for more info.gridColumnFieldsSelector(apiRef);
Columns
The
GridColDef['type']has been narrowed down to only accept the built-in column types. TypeScript users need to use theGridColDefinterface when defining columns:// 🛑 `type` is inferred as `string` and is too wide const columns = [{ type: 'number', field: 'id' }]; <DataGrid columns={columns} />; // ✅ `type` is `'number'` const columns: GridColDef[] = [{ type: 'number', field: 'id' }]; <DataGrid columns={columns} />; // ✅ Alternalively, `as const` can be used to narrow down the type const columns = [{ type: 'number' as const, field: 'id' }]; <DataGrid columns={columns} />;
Clipboard
- Clipboard paste is now enabled by default. The flag
clipboardPasteis no longer needed to be passed to theexperimentalFeaturesprop to enable it. - The clipboard related exports
ignoreValueFormatterDuringExportandsplitClipboardPastedTextare not anymore prefixed withunstable_.
Print export
- The print export will now only print the selected rows if there are any.
If there are no selected rows, it will print all rows. This makes the print export consistent with the other exports.
You can customize the rows to export by using the
getRowsToExportfunction.
Selection
✅ The
unstable_prefix has been removed from the cell selection props listed below.Old name New name unstable_cellSelectioncellSelectionunstable_cellSelectionModelcellSelectionModelunstable_onCellSelectionModelChangeonCellSelectionModelChangeThe
unstable_prefix has been removed from the cell selection API methods listed below.Old name New name unstable_getCellSelectionModelgetCellSelectionModelunstable_getSelectedCellsAsArraygetSelectedCellsAsArrayunstable_isCellSelectedisCellSelectedunstable_selectCellRangeselectCellRangeunstable_setCellSelectionModelsetCellSelectionModel
Filtering
The
getApplyFilterFnV7inGridFilterOperatorwas renamed togetApplyFilterFn. If you usegetApplyFilterFnV7directly - rename it togetApplyFilterFn.The signature of the function returned by
getApplyFilterFnhas changed for performance reasons:
const getApplyFilterFn: GetApplyFilterFn<any, unknown> = (filterItem) => {
if (!filterItem.value) {
return null;
}
const filterRegex = new RegExp(escapeRegExp(filterItem.value), 'i');
- return (cellParams) => {
- const { value } = cellParams;
+ return (value, row, colDef, apiRef) => {
return value != null ? filterRegex.test(String(value)) : false;
};
}
The
getApplyQuickFilterFnV7inGridColDefwas renamed togetApplyQuickFilterFn. If you usegetApplyQuickFilterFnV7directly - rename it togetApplyQuickFilterFn.The signature of the function returned by
getApplyQuickFilterFnhas changed for performance reasons:
const getGridStringQuickFilterFn: GetApplyQuickFilterFn<any, unknown> = (value) => {
if (!value) {
return null;
}
const filterRegex = new RegExp(escapeRegExp(value), 'i');
- return (cellParams) => {
- const { formattedValue } = cellParams;
+ return (value, row, column, apiRef) => {
+ let formattedValue = apiRef.current.getRowFormattedValue(row, column);
return formattedValue != null ? filterRegex.test(formattedValue.toString()) : false;
};
};
The Quick Filter now ignores hidden columns by default. See Including hidden columns section for more details.
The header filters feature is now stable.
unstable_prefix is removed from propheaderFiltersand the following exports.Old name New name unstable_gridFocusColumnHeaderFilterSelectorgridFocusColumnHeaderFilterSelectorunstable_gridHeaderFilteringEditFieldSelectorgridHeaderFilteringEditFieldSelectorunstable_gridHeaderFilteringMenuSelectorgridHeaderFilteringMenuSelectorunstable_gridHeaderFilteringStateSelectorgridHeaderFilteringStateSelectorunstable_gridTabIndexColumnHeaderFilterSelectorgridTabIndexColumnHeaderFilterSelectorThe filter panel no longer uses the native version of the
Selectcomponent for all components.
Other exports
The deprecated constants
SUBMIT_FILTER_STROKE_TIMEandSUBMIT_FILTER_DATE_STROKE_TIMEare no longer exported. Use thefilterDebounceMsprop to customize filter debounce time.The
GridPreferencesPanelcomponent is not exported anymore as it wasn't meant to be used outside of the Data Grid.