@mui/x-data-grid-pro 7.16.0 → 7.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -3,6 +3,186 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## 7.18.0
7
+
8
+ _Sep 20, 2024_
9
+
10
+ We'd like to offer a big thanks to the 14 contributors who made this release possible. Here are some highlights ✨:
11
+
12
+ - 💫 Support [Row spanning](https://mui.com/x/react-data-grid/row-spanning/) on the Data Grid that automatically merges the consecutive cells in a column based on the cell value
13
+
14
+ <img width="600" src="https://github.com/user-attachments/assets/d32ec936-d238-4c92-9e1a-af6788d74cdf" alt="data grid row spanning" />
15
+
16
+ - ⏰ Support `date-fns` v4 (#14673) @LukasTy
17
+ - 🎉 Add option for Pickers to change the order of displayed years (#11780) @thomasmoon
18
+ - 🐞 Bugfixes
19
+ - 📚 Documentation improvements
20
+
21
+ <!--/ HIGHLIGHT_ABOVE_SEPARATOR /-->
22
+
23
+ ### Data Grid
24
+
25
+ #### `@mui/x-data-grid@7.18.0`
26
+
27
+ - [DataGrid] Add default reset value in row edit mode (#14050) @michelengelen
28
+ - [DataGrid] Add `columnGroupHeaderHeight` prop for sizing column group headers (#14637) @KenanYusuf
29
+ - [DataGrid] Fix `document` reference when the grid is rendered in a popup window (#14649) @arminmeh
30
+ - [DataGrid] Remove `minFirstColumn` from `GetHeadersParams` interface (#14450) @k-rajat19
31
+ - [DataGrid] Row spanning (#14124) @MBilalShafi
32
+
33
+ #### `@mui/x-data-grid-pro@7.18.0` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
34
+
35
+ Same changes as in `@mui/x-data-grid@7.18.0`, plus:
36
+
37
+ - [DataGridPro] Fix `onRowsScrollEnd` being triggered instantly when bottom pinned row is present (#14602) @arminmeh
38
+ - [DataGridPro] Fix header filters rendering issue for `isEmpty` and `isNotEmpty` filter operators (#14493) @k-rajat19
39
+ - [DataGridPro] Fix pinned columns in RTL mode (#14586) @KenanYusuf
40
+
41
+ #### `@mui/x-data-grid-premium@7.18.0` [![premium](https://mui.com/r/x-premium-svg)](https://mui.com/r/x-premium-svg-link 'Premium plan')
42
+
43
+ Same changes as in `@mui/x-data-grid-pro@7.18.0`.
44
+
45
+ ### Date and Time Pickers
46
+
47
+ #### `@mui/x-date-pickers@7.18.0`
48
+
49
+ - [pickers] Add option to change the order of displayed years (#11780) @thomasmoon
50
+ - [pickers] Support `date-fns` v4 (#14673) @LukasTy
51
+
52
+ #### `@mui/x-date-pickers-pro@7.18.0` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
53
+
54
+ Same changes as in `@mui/x-date-pickers@7.18.0`.
55
+
56
+ ### Charts
57
+
58
+ #### `@mui/x-charts@7.18.0`
59
+
60
+ - [charts] Add a `PolarProvider` to manage polar axes (#14642) @alexfauquette
61
+ - [charts] Fix `LineChart` animation being stuck with initial drawing area value (#14553) @JCQuintas
62
+ - [charts] Fix legend slot typing (#14657) @alexfauquette
63
+ - [charts] Pass the axis index to extremum getter (#14641) @alexfauquette
64
+ - [charts] Provide hooks to create custom tooltip (#14377) @alexfauquette
65
+
66
+ #### `@mui/x-charts-pro@7.0.0-beta.1` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
67
+
68
+ Same changes as in `@mui/x-charts@7.18.0`.
69
+
70
+ ### Tree View
71
+
72
+ #### `@mui/x-tree-view@7.18.0`
73
+
74
+ - [TreeView] Add `"use client"` directive to every public component and hook (#14579) @flaviendelangle
75
+
76
+ ### Docs
77
+
78
+ - [docs] Add `groupingValueGetter` callout in column definition docs (#14599) @michelengelen
79
+ - [docs] Clean v6 => v7 migration guide (#14652) @flaviendelangle
80
+ - [docs] Copy `vale-action.yml` from main repo @oliviertassinari
81
+ - [docs] Edit the Pickers Getting started doc (#14555) @samuelsycamore
82
+ - [docs] Fix TypeScript capitalization @oliviertassinari
83
+ - [docs] Fix Vale error @oliviertassinari
84
+ - [docs] Make the migration guide diff a bit easier to read @oliviertassinari
85
+ - [docs] Report Vale at warning level (#14660) @oliviertassinari
86
+ - [docs] Warn about the `valueGetter` and `valueFormatter` signature change (#14613) @cherniavskii
87
+ - [docs] Polish code formatting (#14603) @oliviertassinari
88
+ - [test] Spy on `observe` method to avoid flaky wait for a callback (#14640) @arminmeh
89
+
90
+ ### Core
91
+
92
+ - [core] Fix 301 link to Next.js and git diff @oliviertassinari
93
+ - [core] Fix failing CI on `master` (#14644) @cherniavskii
94
+ - [core] Fix `package.json` repository rule @oliviertassinari
95
+ - [core] MUI X repository moved to a new location @oliviertassinari
96
+ - [docs-infra] Strengthen CSP (#14581) @oliviertassinari
97
+ - [license] Finish renaming of LicensingModel (#14615) @oliviertassinari
98
+
99
+ ## 7.17.0
100
+
101
+ _Sep 13, 2024_
102
+
103
+ We'd like to offer a big thanks to the 12 contributors who made this release possible. Here are some highlights ✨:
104
+
105
+ - 📊 Charts performance improvement
106
+ - 🧑‍💻 New Data Grid [custom columns demo](https://mui.com/x/react-data-grid/custom-columns/#full-example)
107
+ - 🐞 Bugfixes
108
+ - 📚 Documentation improvements
109
+ - 🌍 Improve Hungarian (hu-HU) locale on the Data Grid
110
+
111
+ <!--/ HIGHLIGHT_ABOVE_SEPARATOR /-->
112
+
113
+ ### Data Grid
114
+
115
+ #### `@mui/x-data-grid@7.17.0`
116
+
117
+ - [DataGrid] Add "does not equal" and "does not contain" filter operators (#14489) @KenanYusuf
118
+ - [DataGrid] Add demo to the "Custom columns" page that does not use generator (#13695) @arminmeh
119
+ - [DataGrid] Fix Voice Over reading the column name twice (#14482) @arminmeh
120
+ - [DataGrid] Fix bug in CRUD example (#14513) @michelengelen
121
+ - [DataGrid] Fix failing jsdom tests caused by `:has()` selectors (#14559) @KenanYusuf
122
+ - [DataGrid] Refactor string operator filter functions (#14564) @KenanYusuf
123
+ - [l10n] Improve Hungarian (hu-HU) locale (#14506) @ntamas
124
+
125
+ #### `@mui/x-data-grid-pro@7.17.0` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
126
+
127
+ Same changes as in `@mui/x-data-grid@7.17.0`.
128
+
129
+ #### `@mui/x-data-grid-premium@7.17.0` [![premium](https://mui.com/r/x-premium-svg)](https://mui.com/r/x-premium-svg-link 'Premium plan')
130
+
131
+ Same changes as in `@mui/x-data-grid-pro@7.17.0`.
132
+
133
+ ### Date and Time Pickers
134
+
135
+ #### `@mui/x-date-pickers@7.17.0`
136
+
137
+ - [fields] Improve `useSplitFieldProps` and make it public (#14514) @flaviendelangle
138
+ - [pickers] Improve clear action label (#14243) @oliviertassinari
139
+ - [pickers] Add `"use client"` directive to every public component and hook (#14562) @flaviendelangle
140
+ - [pickers] Allow custom fields to validate the value (#14486) @flaviendelangle
141
+ - [pickers] Stop using utils in locales (#14505) @flaviendelangle
142
+
143
+ #### `@mui/x-date-pickers-pro@7.17.0` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
144
+
145
+ Same changes as in `@mui/x-date-pickers@7.17.0`, plus:
146
+
147
+ - [DateRangePicker] Fix `currentMonthCalendarPosition` not scrolling to future sibling (#14442) @GMchris
148
+
149
+ ### Charts
150
+
151
+ #### `@mui/x-charts@7.17.0`
152
+
153
+ - [charts] Add `"use client"` directive to every public component and hook (#14578) @flaviendelangle
154
+ - [charts] Allow `onItemClick` on the `Legend` component (#14231) @JCQuintas
155
+ - [charts] Fix `onAxisClick` with `layout='horizontal'` (#14547) @alexfauquette
156
+ - [charts] Replace `path` with `circle` for performance improvement (#14518) @alexfauquette
157
+
158
+ #### `@mui/x-charts-pro@7.0.0-beta.1` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
159
+
160
+ Same changes as in `@mui/x-charts@7.17.0`.
161
+
162
+ ### Tree View
163
+
164
+ #### `@mui/x-tree-view@7.17.0`
165
+
166
+ - [TreeView] Make `useTreeItem2` stable (#14498) @flaviendelangle
167
+
168
+ ### Docs
169
+
170
+ - [docs] Add missing callout on "Imperative API" tree view sections (#14503) @flaviendelangle
171
+ - [docs] Fix broken redirection to MUI X v5 @oliviertassinari
172
+ - [docs] Fix multiple `console.error` messages on `charts` docs (#14554) @JCQuintas
173
+ - [docs] Fixed typo in Row Grouping recipes (#14549) @Miodini
174
+ - [docs] Match title with blog posts @oliviertassinari
175
+
176
+ ### Core
177
+
178
+ - [core] Move warning methods to `@mui/x-internals` (#14528) @k-rajat19
179
+ - [core] Sync with core release flow @oliviertassinari
180
+ - [code-infra] Fix charts benchmark workflow (#14573) @JCQuintas
181
+ - [docs-infra] Type interface API pages (#14138) @alexfauquette
182
+ - [infra] Create `ESLint plugins` renovate group (#14574) @LukasTy
183
+ - [license] Clean-up terminology to match codebase (#14531) @oliviertassinari
184
+ - [test] Remove dead `act()` logic (#14529) @oliviertassinari
185
+
6
186
  ## 7.16.0
7
187
 
8
188
  _Sep 5, 2024_
@@ -108,7 +288,7 @@ We'd like to offer a big thanks to the 8 contributors who made this release poss
108
288
 
109
289
  - 💫 Support Material UI v6 (`@mui/material@6`) peer dependency (#14142) @cherniavskii
110
290
 
111
- You can now use MUI X components with either v5 or v6 of `@mui/material` package 🎉
291
+ You can now use MUI X components with either v5 or v6 of `@mui/material` package 🎉
112
292
 
113
293
  - 🐞 Bugfixes
114
294
 
@@ -153,7 +333,7 @@ Same changes as in `@mui/x-charts@7.15.0`, plus:
153
333
 
154
334
  - [docs] Fix sentence case `h2` @oliviertassinari
155
335
  - [docs] Clarify contribution guide references @oliviertassinari
156
- - [docs] Fix Stack Overflow issue canned response @oliviertassinari
336
+ - [docs] Fix Stack Overflow issue canned response @oliviertassinari
157
337
  - [docs] Fix outdated link to support page @oliviertassinari
158
338
  - [docs] Fix use of Material UI @oliviertassinari
159
339
  - [docs] Update deprecated props in docs (#14295) @JCQuintas
@@ -411,7 +591,7 @@ The [Pro plan](https://mui.com/x/introduction/licensing/#pro-plan) is receiving
411
591
 
412
592
  As always, every feature released as part of the MIT plan will remain free and MIT licensed forever.
413
593
 
414
- This expansion of the Pro plan comes with some adjustments to our pricing strategy. Learn more about those in the [Upcoming changes to MUI X pricing in 2024](https://mui.com/blog/mui-x-sep-2024-price-update/) blog post.
594
+ This expansion of the Pro plan comes with some adjustments to our pricing strategy. Learn more about those in the [Upcoming changes to MUI X pricing in 2024](https://mui.com/blog/mui-x-sep-2024-price-update/) blog post.
415
595
 
416
596
  ### Highlights
417
597
 
@@ -476,7 +656,7 @@ Same changes as in `@mui/x-date-pickers@7.12.0`.
476
656
  #### `@mui/x-charts@7.12.0`
477
657
 
478
658
  - [charts] Fix incorrect `axisId` prop being allowed in xAxis/yAxis config. Use `id` instead. (#13986) @JCQuintas
479
- - [charts] Use vendor to have Common JS bundle working out of the box (#13608) @alexfauquette
659
+ - [charts] Use vendor to have CommonJS bundle working out of the box (#13608) @alexfauquette
480
660
  - [charts] Divide the `SeriesProvider` to use in filtering (#14026) @JCQuintas
481
661
 
482
662
  ### Tree View
@@ -134,6 +134,11 @@ DataGridProRaw.propTypes = {
134
134
  * @default 150
135
135
  */
136
136
  columnBufferPx: _propTypes.default.number,
137
+ /**
138
+ * Sets the height in pixels of the column group headers in the Data Grid.
139
+ * Inherits the `columnHeaderHeight` value if not set.
140
+ */
141
+ columnGroupHeaderHeight: _propTypes.default.number,
137
142
  columnGroupingModel: _propTypes.default.arrayOf(_propTypes.default.object),
138
143
  /**
139
144
  * Sets the height in pixel of the column headers in the Data Grid.
@@ -935,5 +940,10 @@ DataGridProRaw.propTypes = {
935
940
  get: _propTypes.default.func.isRequired,
936
941
  set: _propTypes.default.func.isRequired
937
942
  }),
938
- unstable_onDataSourceError: _propTypes.default.func
943
+ unstable_onDataSourceError: _propTypes.default.func,
944
+ /**
945
+ * If `true`, the Data Grid will auto span the cells over the rows having the same value.
946
+ * @default false
947
+ */
948
+ unstable_rowSpanning: _propTypes.default.bool
939
949
  };
@@ -57,6 +57,7 @@ const useDataGridProComponent = (inputApiRef, props) => {
57
57
  (0, _internals.useGridInitializeState)(_internals.sortingStateInitializer, apiRef, props);
58
58
  (0, _internals.useGridInitializeState)(_internals.preferencePanelStateInitializer, apiRef, props);
59
59
  (0, _internals.useGridInitializeState)(_internals.filterStateInitializer, apiRef, props);
60
+ (0, _internals.useGridInitializeState)(_internals.rowSpanningStateInitializer, apiRef, props);
60
61
  (0, _internals.useGridInitializeState)(_internals.densityStateInitializer, apiRef, props);
61
62
  (0, _internals.useGridInitializeState)(_useGridColumnReorder.columnReorderStateInitializer, apiRef, props);
62
63
  (0, _internals.useGridInitializeState)(_internals.columnResizeStateInitializer, apiRef, props);
@@ -74,6 +75,7 @@ const useDataGridProComponent = (inputApiRef, props) => {
74
75
  (0, _useGridRowPinning.useGridRowPinning)(apiRef, props);
75
76
  (0, _internals.useGridColumns)(apiRef, props);
76
77
  (0, _internals.useGridRows)(apiRef, props);
78
+ (0, _internals.useGridRowSpanning)(apiRef, props);
77
79
  (0, _internals.useGridParamsApi)(apiRef);
78
80
  (0, _useGridDetailPanel.useGridDetailPanel)(apiRef, props);
79
81
  (0, _internals.useGridColumnSpanning)(apiRef);
@@ -38,6 +38,16 @@ const dateSx = {
38
38
  color: 'transparent'
39
39
  }
40
40
  };
41
+ const defaultInputComponents = {
42
+ string: _xDataGrid.GridFilterInputValue,
43
+ number: _xDataGrid.GridFilterInputValue,
44
+ date: _xDataGrid.GridFilterInputDate,
45
+ dateTime: _xDataGrid.GridFilterInputDate,
46
+ boolean: _xDataGrid.GridFilterInputBoolean,
47
+ singleSelect: _xDataGrid.GridFilterInputSingleSelect,
48
+ actions: null,
49
+ custom: null
50
+ };
41
51
  const GridHeaderFilterCell = /*#__PURE__*/React.forwardRef((props, ref) => {
42
52
  const {
43
53
  colIndex,
@@ -86,7 +96,7 @@ const GridHeaderFilterCell = /*#__PURE__*/React.forwardRef((props, ref) => {
86
96
  return filterModelItem ? !filterableColumnsLookup[filterModelItem.field] : false;
87
97
  }, [colDef.field, filterModel, filterableColumnsLookup]);
88
98
  const currentOperator = React.useMemo(() => filterOperators.find(operator => operator.value === item.operator) ?? filterOperators[0], [item.operator, filterOperators]);
89
- const InputComponent = colDef.filterable || isFilterReadOnly ? currentOperator.InputComponent : null;
99
+ const InputComponent = colDef.filterable || isFilterReadOnly ? currentOperator.InputComponent ?? defaultInputComponents[colDef.type] : null;
90
100
  const applyFilterChanges = React.useCallback(updatedItem => {
91
101
  if (item.value && !updatedItem.value) {
92
102
  apiRef.current.deleteFilterItem(updatedItem);
@@ -127,6 +127,11 @@ DataGridProRaw.propTypes = {
127
127
  * @default 150
128
128
  */
129
129
  columnBufferPx: PropTypes.number,
130
+ /**
131
+ * Sets the height in pixels of the column group headers in the Data Grid.
132
+ * Inherits the `columnHeaderHeight` value if not set.
133
+ */
134
+ columnGroupHeaderHeight: PropTypes.number,
130
135
  columnGroupingModel: PropTypes.arrayOf(PropTypes.object),
131
136
  /**
132
137
  * Sets the height in pixel of the column headers in the Data Grid.
@@ -928,5 +933,10 @@ DataGridProRaw.propTypes = {
928
933
  get: PropTypes.func.isRequired,
929
934
  set: PropTypes.func.isRequired
930
935
  }),
931
- unstable_onDataSourceError: PropTypes.func
936
+ unstable_onDataSourceError: PropTypes.func,
937
+ /**
938
+ * If `true`, the Data Grid will auto span the cells over the rows having the same value.
939
+ * @default false
940
+ */
941
+ unstable_rowSpanning: PropTypes.bool
932
942
  };
@@ -1,4 +1,4 @@
1
- import { useGridInitialization, useGridInitializeState, useGridClipboard, useGridColumnMenu, useGridColumns, columnsStateInitializer, useGridDensity, useGridCsvExport, useGridPrintExport, useGridFilter, filterStateInitializer, useGridFocus, useGridKeyboardNavigation, useGridPagination, paginationStateInitializer, useGridPreferencesPanel, useGridEditing, editingStateInitializer, useGridRows, useGridRowsPreProcessors, rowsStateInitializer, useGridRowsMeta, useGridParamsApi, useGridRowSelection, useGridSorting, sortingStateInitializer, useGridScroll, useGridEvents, dimensionsStateInitializer, useGridDimensions, useGridStatePersistence, useGridRowSelectionPreProcessors, useGridColumnSpanning, columnMenuStateInitializer, densityStateInitializer, focusStateInitializer, preferencePanelStateInitializer, rowsMetaStateInitializer, rowSelectionStateInitializer, useGridColumnGrouping, columnGroupsStateInitializer, headerFilteringStateInitializer, useGridHeaderFiltering, virtualizationStateInitializer, useGridVirtualization, useGridColumnResize, columnResizeStateInitializer } from '@mui/x-data-grid/internals';
1
+ import { useGridInitialization, useGridInitializeState, useGridClipboard, useGridColumnMenu, useGridColumns, columnsStateInitializer, useGridDensity, useGridCsvExport, useGridPrintExport, useGridFilter, filterStateInitializer, useGridFocus, useGridKeyboardNavigation, useGridPagination, paginationStateInitializer, useGridPreferencesPanel, useGridEditing, editingStateInitializer, useGridRows, useGridRowsPreProcessors, rowsStateInitializer, useGridRowsMeta, useGridParamsApi, useGridRowSelection, useGridSorting, sortingStateInitializer, useGridScroll, useGridEvents, dimensionsStateInitializer, useGridDimensions, useGridStatePersistence, useGridRowSelectionPreProcessors, useGridColumnSpanning, columnMenuStateInitializer, densityStateInitializer, focusStateInitializer, preferencePanelStateInitializer, rowsMetaStateInitializer, rowSelectionStateInitializer, useGridColumnGrouping, columnGroupsStateInitializer, headerFilteringStateInitializer, useGridHeaderFiltering, virtualizationStateInitializer, useGridVirtualization, useGridColumnResize, columnResizeStateInitializer, useGridRowSpanning, rowSpanningStateInitializer } from '@mui/x-data-grid/internals';
2
2
  // Pro-only features
3
3
  import { useGridInfiniteLoader } from "../hooks/features/infiniteLoader/useGridInfiniteLoader.js";
4
4
  import { useGridColumnReorder, columnReorderStateInitializer } from "../hooks/features/columnReorder/useGridColumnReorder.js";
@@ -50,6 +50,7 @@ export const useDataGridProComponent = (inputApiRef, props) => {
50
50
  useGridInitializeState(sortingStateInitializer, apiRef, props);
51
51
  useGridInitializeState(preferencePanelStateInitializer, apiRef, props);
52
52
  useGridInitializeState(filterStateInitializer, apiRef, props);
53
+ useGridInitializeState(rowSpanningStateInitializer, apiRef, props);
53
54
  useGridInitializeState(densityStateInitializer, apiRef, props);
54
55
  useGridInitializeState(columnReorderStateInitializer, apiRef, props);
55
56
  useGridInitializeState(columnResizeStateInitializer, apiRef, props);
@@ -67,6 +68,7 @@ export const useDataGridProComponent = (inputApiRef, props) => {
67
68
  useGridRowPinning(apiRef, props);
68
69
  useGridColumns(apiRef, props);
69
70
  useGridRows(apiRef, props);
71
+ useGridRowSpanning(apiRef, props);
70
72
  useGridParamsApi(apiRef);
71
73
  useGridDetailPanel(apiRef, props);
72
74
  useGridColumnSpanning(apiRef);
@@ -6,7 +6,7 @@ import PropTypes from 'prop-types';
6
6
  import clsx from 'clsx';
7
7
  import { unstable_useForkRef as useForkRef, unstable_composeClasses as composeClasses, unstable_capitalize as capitalize } from '@mui/utils';
8
8
  import { fastMemo } from '@mui/x-internals/fastMemo';
9
- import { gridVisibleColumnFieldsSelector, getDataGridUtilityClass, useGridSelector, gridFilterModelSelector, gridFilterableColumnLookupSelector } from '@mui/x-data-grid';
9
+ import { gridVisibleColumnFieldsSelector, getDataGridUtilityClass, useGridSelector, GridFilterInputValue, GridFilterInputDate, GridFilterInputBoolean, GridFilterInputSingleSelect, gridFilterModelSelector, gridFilterableColumnLookupSelector } from '@mui/x-data-grid';
10
10
  import { useGridPrivateApiContext, gridHeaderFilteringEditFieldSelector, gridHeaderFilteringMenuSelector, isNavigationKey, shouldCellShowLeftBorder, shouldCellShowRightBorder } from '@mui/x-data-grid/internals';
11
11
  import { useGridRootProps } from "../../hooks/utils/useGridRootProps.js";
12
12
  import { GridHeaderFilterMenuContainer } from "./GridHeaderFilterMenuContainer.js";
@@ -30,6 +30,16 @@ const dateSx = {
30
30
  color: 'transparent'
31
31
  }
32
32
  };
33
+ const defaultInputComponents = {
34
+ string: GridFilterInputValue,
35
+ number: GridFilterInputValue,
36
+ date: GridFilterInputDate,
37
+ dateTime: GridFilterInputDate,
38
+ boolean: GridFilterInputBoolean,
39
+ singleSelect: GridFilterInputSingleSelect,
40
+ actions: null,
41
+ custom: null
42
+ };
33
43
  const GridHeaderFilterCell = /*#__PURE__*/React.forwardRef((props, ref) => {
34
44
  const {
35
45
  colIndex,
@@ -78,7 +88,7 @@ const GridHeaderFilterCell = /*#__PURE__*/React.forwardRef((props, ref) => {
78
88
  return filterModelItem ? !filterableColumnsLookup[filterModelItem.field] : false;
79
89
  }, [colDef.field, filterModel, filterableColumnsLookup]);
80
90
  const currentOperator = React.useMemo(() => filterOperators.find(operator => operator.value === item.operator) ?? filterOperators[0], [item.operator, filterOperators]);
81
- const InputComponent = colDef.filterable || isFilterReadOnly ? currentOperator.InputComponent : null;
91
+ const InputComponent = colDef.filterable || isFilterReadOnly ? currentOperator.InputComponent ?? defaultInputComponents[colDef.type] : null;
82
92
  const applyFilterChanges = React.useCallback(updatedItem => {
83
93
  if (item.value && !updatedItem.value) {
84
94
  apiRef.current.deleteFilterItem(updatedItem);
@@ -124,16 +124,13 @@ export const useGridColumnHeaders = props => {
124
124
  children: [leftRenderContext && getColumnFilters({
125
125
  position: GridPinnedColumnPosition.LEFT,
126
126
  renderContext: leftRenderContext,
127
- minFirstColumn: leftRenderContext.firstColumnIndex,
128
127
  maxLastColumn: leftRenderContext.lastColumnIndex
129
128
  }), getColumnFilters({
130
129
  renderContext,
131
- minFirstColumn: pinnedColumns.left.length,
132
130
  maxLastColumn: visibleColumns.length - pinnedColumns.right.length
133
131
  }), rightRenderContext && getColumnFilters({
134
132
  position: GridPinnedColumnPosition.RIGHT,
135
133
  renderContext: rightRenderContext,
136
- minFirstColumn: rightRenderContext.firstColumnIndex,
137
134
  maxLastColumn: rightRenderContext.lastColumnIndex
138
135
  })]
139
136
  });
@@ -25,5 +25,9 @@ export const GRID_DETAIL_PANEL_TOGGLE_COL_DEF = _extends({}, GRID_STRING_COL_DEF
25
25
  return expandedRowIds.includes(rowId);
26
26
  },
27
27
  renderCell: params => /*#__PURE__*/_jsx(GridDetailPanelToggleCell, _extends({}, params)),
28
- renderHeader: () => null
28
+ renderHeader: ({
29
+ colDef
30
+ }) => /*#__PURE__*/_jsx("div", {
31
+ "aria-label": colDef.headerName
32
+ })
29
33
  });
@@ -1,6 +1,6 @@
1
1
  import { ponyfillGlobal } from '@mui/utils';
2
2
  export const getReleaseInfo = () => {
3
- const releaseInfo = "MTcyNTQ4MzYwMDAwMA==";
3
+ const releaseInfo = "MTcyNjc4NjgwMDAwMA==";
4
4
  if (process.env.NODE_ENV !== 'production') {
5
5
  // A simple hack to set the value in the test environment (has no build step).
6
6
  // eslint-disable-next-line no-useless-concat
@@ -132,16 +132,13 @@ const useGridColumnHeaders = props => {
132
132
  children: [leftRenderContext && getColumnFilters({
133
133
  position: _xDataGrid.GridPinnedColumnPosition.LEFT,
134
134
  renderContext: leftRenderContext,
135
- minFirstColumn: leftRenderContext.firstColumnIndex,
136
135
  maxLastColumn: leftRenderContext.lastColumnIndex
137
136
  }), getColumnFilters({
138
137
  renderContext,
139
- minFirstColumn: pinnedColumns.left.length,
140
138
  maxLastColumn: visibleColumns.length - pinnedColumns.right.length
141
139
  }), rightRenderContext && getColumnFilters({
142
140
  position: _xDataGrid.GridPinnedColumnPosition.RIGHT,
143
141
  renderContext: rightRenderContext,
144
- minFirstColumn: rightRenderContext.firstColumnIndex,
145
142
  maxLastColumn: rightRenderContext.lastColumnIndex
146
143
  })]
147
144
  });
@@ -33,5 +33,9 @@ const GRID_DETAIL_PANEL_TOGGLE_COL_DEF = exports.GRID_DETAIL_PANEL_TOGGLE_COL_DE
33
33
  return expandedRowIds.includes(rowId);
34
34
  },
35
35
  renderCell: params => /*#__PURE__*/(0, _jsxRuntime.jsx)(_GridDetailPanelToggleCell.GridDetailPanelToggleCell, (0, _extends2.default)({}, params)),
36
- renderHeader: () => null
36
+ renderHeader: ({
37
+ colDef
38
+ }) => /*#__PURE__*/(0, _jsxRuntime.jsx)("div", {
39
+ "aria-label": colDef.headerName
40
+ })
37
41
  });
package/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @mui/x-data-grid-pro v7.16.0
2
+ * @mui/x-data-grid-pro v7.18.0
3
3
  *
4
4
  * @license MUI X Commercial
5
5
  * This source code is licensed under the commercial license found in the
@@ -127,6 +127,11 @@ DataGridProRaw.propTypes = {
127
127
  * @default 150
128
128
  */
129
129
  columnBufferPx: PropTypes.number,
130
+ /**
131
+ * Sets the height in pixels of the column group headers in the Data Grid.
132
+ * Inherits the `columnHeaderHeight` value if not set.
133
+ */
134
+ columnGroupHeaderHeight: PropTypes.number,
130
135
  columnGroupingModel: PropTypes.arrayOf(PropTypes.object),
131
136
  /**
132
137
  * Sets the height in pixel of the column headers in the Data Grid.
@@ -928,5 +933,10 @@ DataGridProRaw.propTypes = {
928
933
  get: PropTypes.func.isRequired,
929
934
  set: PropTypes.func.isRequired
930
935
  }),
931
- unstable_onDataSourceError: PropTypes.func
936
+ unstable_onDataSourceError: PropTypes.func,
937
+ /**
938
+ * If `true`, the Data Grid will auto span the cells over the rows having the same value.
939
+ * @default false
940
+ */
941
+ unstable_rowSpanning: PropTypes.bool
932
942
  };
@@ -1,4 +1,4 @@
1
- import { useGridInitialization, useGridInitializeState, useGridClipboard, useGridColumnMenu, useGridColumns, columnsStateInitializer, useGridDensity, useGridCsvExport, useGridPrintExport, useGridFilter, filterStateInitializer, useGridFocus, useGridKeyboardNavigation, useGridPagination, paginationStateInitializer, useGridPreferencesPanel, useGridEditing, editingStateInitializer, useGridRows, useGridRowsPreProcessors, rowsStateInitializer, useGridRowsMeta, useGridParamsApi, useGridRowSelection, useGridSorting, sortingStateInitializer, useGridScroll, useGridEvents, dimensionsStateInitializer, useGridDimensions, useGridStatePersistence, useGridRowSelectionPreProcessors, useGridColumnSpanning, columnMenuStateInitializer, densityStateInitializer, focusStateInitializer, preferencePanelStateInitializer, rowsMetaStateInitializer, rowSelectionStateInitializer, useGridColumnGrouping, columnGroupsStateInitializer, headerFilteringStateInitializer, useGridHeaderFiltering, virtualizationStateInitializer, useGridVirtualization, useGridColumnResize, columnResizeStateInitializer } from '@mui/x-data-grid/internals';
1
+ import { useGridInitialization, useGridInitializeState, useGridClipboard, useGridColumnMenu, useGridColumns, columnsStateInitializer, useGridDensity, useGridCsvExport, useGridPrintExport, useGridFilter, filterStateInitializer, useGridFocus, useGridKeyboardNavigation, useGridPagination, paginationStateInitializer, useGridPreferencesPanel, useGridEditing, editingStateInitializer, useGridRows, useGridRowsPreProcessors, rowsStateInitializer, useGridRowsMeta, useGridParamsApi, useGridRowSelection, useGridSorting, sortingStateInitializer, useGridScroll, useGridEvents, dimensionsStateInitializer, useGridDimensions, useGridStatePersistence, useGridRowSelectionPreProcessors, useGridColumnSpanning, columnMenuStateInitializer, densityStateInitializer, focusStateInitializer, preferencePanelStateInitializer, rowsMetaStateInitializer, rowSelectionStateInitializer, useGridColumnGrouping, columnGroupsStateInitializer, headerFilteringStateInitializer, useGridHeaderFiltering, virtualizationStateInitializer, useGridVirtualization, useGridColumnResize, columnResizeStateInitializer, useGridRowSpanning, rowSpanningStateInitializer } from '@mui/x-data-grid/internals';
2
2
  // Pro-only features
3
3
  import { useGridInfiniteLoader } from "../hooks/features/infiniteLoader/useGridInfiniteLoader.js";
4
4
  import { useGridColumnReorder, columnReorderStateInitializer } from "../hooks/features/columnReorder/useGridColumnReorder.js";
@@ -50,6 +50,7 @@ export const useDataGridProComponent = (inputApiRef, props) => {
50
50
  useGridInitializeState(sortingStateInitializer, apiRef, props);
51
51
  useGridInitializeState(preferencePanelStateInitializer, apiRef, props);
52
52
  useGridInitializeState(filterStateInitializer, apiRef, props);
53
+ useGridInitializeState(rowSpanningStateInitializer, apiRef, props);
53
54
  useGridInitializeState(densityStateInitializer, apiRef, props);
54
55
  useGridInitializeState(columnReorderStateInitializer, apiRef, props);
55
56
  useGridInitializeState(columnResizeStateInitializer, apiRef, props);
@@ -67,6 +68,7 @@ export const useDataGridProComponent = (inputApiRef, props) => {
67
68
  useGridRowPinning(apiRef, props);
68
69
  useGridColumns(apiRef, props);
69
70
  useGridRows(apiRef, props);
71
+ useGridRowSpanning(apiRef, props);
70
72
  useGridParamsApi(apiRef);
71
73
  useGridDetailPanel(apiRef, props);
72
74
  useGridColumnSpanning(apiRef);
@@ -6,7 +6,7 @@ import PropTypes from 'prop-types';
6
6
  import clsx from 'clsx';
7
7
  import { unstable_useForkRef as useForkRef, unstable_composeClasses as composeClasses, unstable_capitalize as capitalize } from '@mui/utils';
8
8
  import { fastMemo } from '@mui/x-internals/fastMemo';
9
- import { gridVisibleColumnFieldsSelector, getDataGridUtilityClass, useGridSelector, gridFilterModelSelector, gridFilterableColumnLookupSelector } from '@mui/x-data-grid';
9
+ import { gridVisibleColumnFieldsSelector, getDataGridUtilityClass, useGridSelector, GridFilterInputValue, GridFilterInputDate, GridFilterInputBoolean, GridFilterInputSingleSelect, gridFilterModelSelector, gridFilterableColumnLookupSelector } from '@mui/x-data-grid';
10
10
  import { useGridPrivateApiContext, gridHeaderFilteringEditFieldSelector, gridHeaderFilteringMenuSelector, isNavigationKey, shouldCellShowLeftBorder, shouldCellShowRightBorder } from '@mui/x-data-grid/internals';
11
11
  import { useGridRootProps } from "../../hooks/utils/useGridRootProps.js";
12
12
  import { GridHeaderFilterMenuContainer } from "./GridHeaderFilterMenuContainer.js";
@@ -30,6 +30,16 @@ const dateSx = {
30
30
  color: 'transparent'
31
31
  }
32
32
  };
33
+ const defaultInputComponents = {
34
+ string: GridFilterInputValue,
35
+ number: GridFilterInputValue,
36
+ date: GridFilterInputDate,
37
+ dateTime: GridFilterInputDate,
38
+ boolean: GridFilterInputBoolean,
39
+ singleSelect: GridFilterInputSingleSelect,
40
+ actions: null,
41
+ custom: null
42
+ };
33
43
  const GridHeaderFilterCell = /*#__PURE__*/React.forwardRef((props, ref) => {
34
44
  const {
35
45
  colIndex,
@@ -78,7 +88,7 @@ const GridHeaderFilterCell = /*#__PURE__*/React.forwardRef((props, ref) => {
78
88
  return filterModelItem ? !filterableColumnsLookup[filterModelItem.field] : false;
79
89
  }, [colDef.field, filterModel, filterableColumnsLookup]);
80
90
  const currentOperator = React.useMemo(() => filterOperators.find(operator => operator.value === item.operator) ?? filterOperators[0], [item.operator, filterOperators]);
81
- const InputComponent = colDef.filterable || isFilterReadOnly ? currentOperator.InputComponent : null;
91
+ const InputComponent = colDef.filterable || isFilterReadOnly ? currentOperator.InputComponent ?? defaultInputComponents[colDef.type] : null;
82
92
  const applyFilterChanges = React.useCallback(updatedItem => {
83
93
  if (item.value && !updatedItem.value) {
84
94
  apiRef.current.deleteFilterItem(updatedItem);
@@ -124,16 +124,13 @@ export const useGridColumnHeaders = props => {
124
124
  children: [leftRenderContext && getColumnFilters({
125
125
  position: GridPinnedColumnPosition.LEFT,
126
126
  renderContext: leftRenderContext,
127
- minFirstColumn: leftRenderContext.firstColumnIndex,
128
127
  maxLastColumn: leftRenderContext.lastColumnIndex
129
128
  }), getColumnFilters({
130
129
  renderContext,
131
- minFirstColumn: pinnedColumns.left.length,
132
130
  maxLastColumn: visibleColumns.length - pinnedColumns.right.length
133
131
  }), rightRenderContext && getColumnFilters({
134
132
  position: GridPinnedColumnPosition.RIGHT,
135
133
  renderContext: rightRenderContext,
136
- minFirstColumn: rightRenderContext.firstColumnIndex,
137
134
  maxLastColumn: rightRenderContext.lastColumnIndex
138
135
  })]
139
136
  });
@@ -25,5 +25,9 @@ export const GRID_DETAIL_PANEL_TOGGLE_COL_DEF = _extends({}, GRID_STRING_COL_DEF
25
25
  return expandedRowIds.includes(rowId);
26
26
  },
27
27
  renderCell: params => /*#__PURE__*/_jsx(GridDetailPanelToggleCell, _extends({}, params)),
28
- renderHeader: () => null
28
+ renderHeader: ({
29
+ colDef
30
+ }) => /*#__PURE__*/_jsx("div", {
31
+ "aria-label": colDef.headerName
32
+ })
29
33
  });
package/modern/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @mui/x-data-grid-pro v7.16.0
2
+ * @mui/x-data-grid-pro v7.18.0
3
3
  *
4
4
  * @license MUI X Commercial
5
5
  * This source code is licensed under the commercial license found in the
@@ -1,6 +1,6 @@
1
1
  import { ponyfillGlobal } from '@mui/utils';
2
2
  export const getReleaseInfo = () => {
3
- const releaseInfo = "MTcyNTQ4MzYwMDAwMA==";
3
+ const releaseInfo = "MTcyNjc4NjgwMDAwMA==";
4
4
  if (process.env.NODE_ENV !== 'production') {
5
5
  // A simple hack to set the value in the test environment (has no build step).
6
6
  // eslint-disable-next-line no-useless-concat
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mui/x-data-grid-pro",
3
- "version": "7.16.0",
3
+ "version": "7.18.0",
4
4
  "description": "The Pro plan edition of the Data Grid components (MUI X).",
5
5
  "author": "MUI Team",
6
6
  "main": "./index.js",
@@ -29,7 +29,7 @@
29
29
  ],
30
30
  "repository": {
31
31
  "type": "git",
32
- "url": "https://github.com/mui/mui-x.git",
32
+ "url": "git+https://github.com/mui/mui-x.git",
33
33
  "directory": "packages/x-data-grid-pro"
34
34
  },
35
35
  "dependencies": {
@@ -39,9 +39,9 @@
39
39
  "clsx": "^2.1.1",
40
40
  "prop-types": "^15.8.1",
41
41
  "reselect": "^5.1.1",
42
- "@mui/x-data-grid": "7.16.0",
43
- "@mui/x-internals": "7.16.0",
44
- "@mui/x-license": "7.16.0"
42
+ "@mui/x-data-grid": "7.18.0",
43
+ "@mui/x-internals": "7.18.0",
44
+ "@mui/x-license": "7.18.0"
45
45
  },
46
46
  "peerDependencies": {
47
47
  "@emotion/react": "^11.9.0",
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.getReleaseInfo = void 0;
7
7
  var _utils = require("@mui/utils");
8
8
  const getReleaseInfo = () => {
9
- const releaseInfo = "MTcyNTQ4MzYwMDAwMA==";
9
+ const releaseInfo = "MTcyNjc4NjgwMDAwMA==";
10
10
  if (process.env.NODE_ENV !== 'production') {
11
11
  // A simple hack to set the value in the test environment (has no build step).
12
12
  // eslint-disable-next-line no-useless-concat