@mui/x-data-grid-premium 9.0.0-alpha.3 → 9.0.0-beta.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
@@ -1,5 +1,234 @@
1
1
  # Changelog
2
2
 
3
+ ## 9.0.0-beta.0
4
+
5
+ <!-- generated comparing v9.0.0-alpha.4..master -->
6
+
7
+ _Mar 27, 2026_
8
+
9
+ We'd like to extend a big thank you to the 10 contributors who made this release possible. Here are some highlights ✨:
10
+
11
+ - 🔊 New Charts voiceover component for improved screen reader support
12
+ - ⌨️ Charts keyboard navigation improvements: axis tooltip now shows when navigating with the keyboard
13
+ - 📊 Charts axes now can be set to automatically resize to fit their content
14
+ - 📝 New `rowCheckbox` slot in Data Grid for easier checkbox column customization
15
+ - ⚡️ `fetchRows()` API in Data Grid Pro now defaults `start` and `end` based on scroll position with lazy loading
16
+ - 🐞 Bugfixes and internal improvements
17
+
18
+ The following team members contributed to this release:
19
+ @aemartos, @alexfauquette, @arminmeh, @cherniavskii, @Janpot, @JCQuintas, @mapache-salvaje, @michelengelen, @noraleonte, @rita-codes
20
+
21
+ ### Data Grid
22
+
23
+ #### `@mui/x-data-grid@9.0.0-beta.0`
24
+
25
+ - [DataGrid] Add `rowCheckbox` slot for easier customization (#21797) @michelengelen
26
+ - [DataGrid] Prevent repeated `hasScrollbar` state updates (#21820) @arminmeh
27
+
28
+ #### `@mui/x-data-grid-pro@9.0.0-beta.0` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
29
+
30
+ Same changes as in `@mui/x-data-grid@9.0.0-beta.0`, plus:
31
+
32
+ - [DataGridPro] `fetchRows()` API's default `start` and `end` params based on scroll position with lazy loading (#21742) @arminmeh
33
+
34
+ #### `@mui/x-data-grid-premium@9.0.0-beta.0` [![premium](https://mui.com/r/x-premium-svg)](https://mui.com/r/x-premium-svg-link 'Premium plan')
35
+
36
+ Same changes as in `@mui/x-data-grid-pro@9.0.0-beta.0`.
37
+
38
+ ### Date and Time Pickers
39
+
40
+ #### `@mui/x-date-pickers@9.0.0-beta.0`
41
+
42
+ Internal changes.
43
+
44
+ #### `@mui/x-date-pickers-pro@9.0.0-beta.0` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
45
+
46
+ Same changes as in `@mui/x-date-pickers@9.0.0-beta.0`.
47
+
48
+ ### Charts
49
+
50
+ #### `@mui/x-charts@9.0.0-beta.0`
51
+
52
+ - [charts] Add `className` prop to Pro chart plot components (#21793) @JCQuintas
53
+ - [charts] Add experimental position-based pointer interaction for line series (#21809) @JCQuintas
54
+ - [charts] Add l10n to the bar accessibility (#21815) @alexfauquette
55
+ - [charts] Add localization for the basic charts (#21822) @alexfauquette
56
+ - [charts] Add voiceover component (#21344) @alexfauquette
57
+ - [charts] Allow axes to automatically resize to content (#21087) @JCQuintas
58
+ - [charts] Document multiple use-cases for references (#21768) @alexfauquette
59
+ - [charts] Remove compatibility layer for React vs native events (#21780) @JCQuintas
60
+ - [charts] Remove deprecated `barLabel` props (#21783) @alexfauquette
61
+ - [charts] Show axis tooltip when navigating with keyboard (#21689) @Copilot
62
+
63
+ #### `@mui/x-charts-pro@9.0.0-beta.0` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
64
+
65
+ Same changes as in `@mui/x-charts@9.0.0-beta.0`.
66
+
67
+ #### `@mui/x-charts-premium@9.0.0-beta.0` [![premium](https://mui.com/r/x-premium-svg)](https://mui.com/r/x-premium-svg-link 'Premium plan')
68
+
69
+ Same changes as in `@mui/x-charts-pro@9.0.0-beta.0`.
70
+
71
+ ### Tree View
72
+
73
+ #### `@mui/x-tree-view@9.0.0-alpha.4`
74
+
75
+ Internal changes.
76
+
77
+ #### `@mui/x-tree-view-pro@9.0.0-alpha.4` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
78
+
79
+ Same changes as in `@mui/x-tree-view@9.0.0-alpha.4`.
80
+
81
+ ### Codemod
82
+
83
+ #### `@mui/x-codemod@9.0.0-alpha.4`
84
+
85
+ Internal changes.
86
+
87
+ ### Docs
88
+
89
+ - [docs] Document how to customize voiceover announcement (#21833) @alexfauquette
90
+ - [docs] Remove Discord mention from docs (#21855) @mapache-salvaje
91
+ - [docs] Remove stabilized experimental feature from demo (#21869) @JCQuintas
92
+ - [docs] Update telemetry guide to reflect pseudonymous data collection and license compliance (#21812) @aemartos
93
+ - [docs] Revise the Sparkline doc (#21614) @mapache-salvaje
94
+ - [docs] Revise the Gauge doc (#21673) @mapache-salvaje
95
+ - [docs] Revise the Heatmap doc (#21676) @mapache-salvaje
96
+
97
+ ### Core
98
+
99
+ - [code-infra] Remove unused deps and unify es-toolkit via catalog (#21840) @Janpot
100
+ - [code-infra] Update @mui/internal-bundle-size-checker to canary.68 (#21836) @Janpot
101
+ - [code-infra] Update next (#21837) @Janpot
102
+ - [internal] Remove headless data grid packages (#21843) @cherniavskii
103
+
104
+ ### Miscellaneous
105
+
106
+ - Add @romgrk to CODEOWNERS for `x-virtualizer` and `x-internals` (#21819) @Copilot
107
+ - [x-license] add 2022 plan version (#21814) @aemartos
108
+
109
+ ## 9.0.0-alpha.4
110
+
111
+ _Mar 19, 2026_
112
+
113
+ We'd like to extend a big thank you to the 12 contributors who made this release possible. Here are some highlights ✨:
114
+
115
+ - 🐞 Bugfixes and internal improvements
116
+
117
+ The following team members contributed to this release:
118
+ @aemartos, @alexfauquette, @bernardobelchior, @Janpot, @JCQuintas, @LukasTy, @mapache-salvaje, @michelengelen, @noraleonte, @rita-codes, @sai6855, @siriwatknp
119
+
120
+ ### Data Grid
121
+
122
+ #### `@mui/x-data-grid@9.0.0-alpha.4`
123
+
124
+ - [DataGrid] Mark charts integration as stable (#21764) @JCQuintas
125
+ - [DataGrid] Move `elementOverrides` to constants and remove duplicates (#21618) @sai6855
126
+ - [DataGrid] Migrate from deprecated Material UI APIs (#21682) @siriwatknp
127
+
128
+ #### `@mui/x-data-grid-pro@9.0.0-alpha.4` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
129
+
130
+ Same changes as in `@mui/x-data-grid@9.0.0-alpha.4`.
131
+
132
+ #### `@mui/x-data-grid-premium@9.0.0-alpha.4` [![premium](https://mui.com/r/x-premium-svg)](https://mui.com/r/x-premium-svg-link 'Premium plan')
133
+
134
+ Same changes as in `@mui/x-data-grid-pro@9.0.0-alpha.4`.
135
+
136
+ ### Date and Time Pickers
137
+
138
+ #### `@mui/x-date-pickers@9.0.0-alpha.4`
139
+
140
+ - [pickers] Avoid stealing focus on click away (#13434) @LukasTy
141
+ - [pickers] Promote `fieldRef` to stable and add `clearValue` method (#21655) @michelengelen
142
+
143
+ #### `@mui/x-date-pickers-pro@9.0.0-alpha.4` [![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@9.0.0-alpha.4`.
146
+
147
+ ### Charts
148
+
149
+ #### `@mui/x-charts@9.0.0-alpha.4`
150
+
151
+ - [charts] Add v9 chart series types and helper functions migration (#21009) @bernardobelchior
152
+ - [charts] Extract event listener to the layer container (#21751) @alexfauquette
153
+ - [charts] Fix WebGL print export canvas stretching (#21738) @JCQuintas
154
+ - [charts] Improve deprecation warnings (#21760) @alexfauquette
155
+ - [charts] Improve type safety in `identifierCleaner` (#21719) @bernardobelchior
156
+ - [charts] Make `preferStrictDomainInLineCharts` the default (#21744) @JCQuintas
157
+ - [charts] Move title and description to the layer container (#21757) @alexfauquette
158
+ - [charts] Refactor `FunnelChart` classes structure (#21652) @JCQuintas
159
+ - [charts] Refactor `Heatmap` classes structure (#21653) @JCQuintas
160
+ - [charts] Refactor `RadarChart` classes structure (#21650) @JCQuintas
161
+ - [charts] Refactor `SankeyChart` classes structure (#21654) @JCQuintas
162
+ - [charts] Refactor legend getters to use utility functions (#21628) @sai6855
163
+ - [charts] Remove deprecated `ChartContainer` and `ChartDataProvider` (#21777) @alexfauquette
164
+ - [charts] Remove deprecated `itemId` from `SeriesLegendItemContext` (#21788) @alexfauquette
165
+ - [charts] Remove deprecated `useMouseTracker()` (#21787) @alexfauquette
166
+ - [charts] Remove deprecated classes (#21775) @alexfauquette
167
+ - [charts] Remove deprecated props from PieArcLabel animation (#21789) @alexfauquette
168
+ - [charts] Remove get\*UtilityClass from public exports (#21769) @JCQuintas
169
+ - [charts] Remove the deprecated `disableHover` property (#21785) @alexfauquette
170
+ - [charts] Remove the deprecated `message` prop (#21784) @alexfauquette
171
+ - [charts] Remove deprecated props about voronoi (#21796) @alexfauquette
172
+ - [charts] Remove deprecated pieArcClasses (#21795) @alexfauquette
173
+ - [charts] Rename `data-series-id` by `data-series` (#21761) @alexfauquette
174
+ - [charts] Rename `voronoiMaxRadius`/`disableVoronoi` to `hitAreaRadius`/`disableHitArea` (#21750) @bernardobelchior
175
+ - [charts] Update pt-PT locale (#21296) @bernardobelchior
176
+ - [charts] Use different shape per series by default (#21713) @alexfauquette
177
+ - [charts] Add className prop to Radar components (#21794) @JCQuintas
178
+ - [charts] Add className prop to shared chart components (#21792) @JCQuintas
179
+ - [charts] Add className prop to BarPlot (#21791) @JCQuintas
180
+ - [charts] Portal tooltip into ChartsLayerContainer (#21801) @JCQuintas
181
+
182
+ #### `@mui/x-charts-pro@9.0.0-alpha.4` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
183
+
184
+ Same changes as in `@mui/x-charts@9.0.0-alpha.4`, plus:
185
+
186
+ - [charts-pro] Allow `brush` interaction to accept `requiredKeys/pointerMode` (#21716) @JCQuintas
187
+ - [charts-pro] Remove deprecated `onAxisClick` for Heatmap (#21786) @alexfauquette
188
+
189
+ #### `@mui/x-charts-premium@9.0.0-alpha.4` [![premium](https://mui.com/r/x-premium-svg)](https://mui.com/r/x-premium-svg-link 'Premium plan')
190
+
191
+ Same changes as in `@mui/x-charts-pro@9.0.0-alpha.4`, plus:
192
+
193
+ - [charts-premium] Add candlestick chart (#21129) @bernardobelchior
194
+
195
+ ### Tree View
196
+
197
+ #### `@mui/x-tree-view@9.0.0-alpha.4`
198
+
199
+ Internal changes.
200
+
201
+ #### `@mui/x-tree-view-pro@9.0.0-alpha.4` [![pro](https://mui.com/r/x-pro-svg)](https://mui.com/r/x-pro-svg-link 'Pro plan')
202
+
203
+ Same changes as in `@mui/x-tree-view@9.0.0-alpha.4`.
204
+
205
+ ### Codemod
206
+
207
+ #### `@mui/x-codemod@9.0.0-alpha.4`
208
+
209
+ Internal changes.
210
+
211
+ ### Docs
212
+
213
+ - [docs-infra] Exclude `ServerSideLazyLoadingRevalidation` from argos (#21734) @sai6855
214
+ - [docs] Update charts v9 migration guide to include premium package (#21743) @bernardobelchior
215
+ - [docs] Update v9 migration guides to install next tag (#21741) @bernardobelchior
216
+ - [docs] Revise the Pie chart docs (#21565) @mapache-salvaje
217
+ - [docs] Revise the Bar Chart docs (#21482) @mapache-salvaje
218
+ - [docs] Removed a `console.log` from an aggregation demo (#21698) @michelengelen
219
+
220
+ ### Core
221
+
222
+ - [code-infra] Add pkg-pr-new as dev dependency (#21754) @Janpot
223
+ - [code-infra] Prevent `combiner` to have default parameters (#21707) @JCQuintas
224
+ - [code-infra] Remove CI coverage collection and upload to Codecov (#21671) @Janpot
225
+ - [internal] Remove @bernardobelchior from Charts CODEOWNERS (#21776) @Copilot
226
+
227
+ ### Miscellaneous
228
+
229
+ - [x-license] Fix process.env.MUI_VERSION not being replaced during build (#21727) @aemartos
230
+ - [x-license] Add new watermark license status message (#21720) @aemartos
231
+
3
232
  ## 9.0.0-alpha.3
4
233
 
5
234
  _Mar 12, 2026_
@@ -51,8 +51,8 @@ const configuration = {
51
51
  }
52
52
  };
53
53
  const packageInfo = {
54
- releaseDate: "MTc3MzI3MzYwMDAwMA==",
55
- version: process.env.MUI_VERSION,
54
+ releaseDate: "MTc3NDU2OTYwMDAwMA==",
55
+ version: "9.0.0-beta.0",
56
56
  name: 'x-data-grid-premium'
57
57
  };
58
58
  const watermark = /*#__PURE__*/(0, _jsxRuntime.jsx)(_internals.Watermark, {
@@ -501,7 +501,6 @@ process.env.NODE_ENV !== "production" ? DataGridPremiumRaw.propTypes = {
501
501
  * For each feature, if the flag is not explicitly set to `true`, then the feature is fully disabled, and neither property nor method calls will have any effect.
502
502
  */
503
503
  experimentalFeatures: _propTypes.default.shape({
504
- charts: _propTypes.default.bool,
505
504
  warnIfFocusStateIsNotSynced: _propTypes.default.bool
506
505
  }),
507
506
  /**
@@ -44,8 +44,8 @@ const configuration = {
44
44
  }
45
45
  };
46
46
  const packageInfo = {
47
- releaseDate: "MTc3MzI3MzYwMDAwMA==",
48
- version: process.env.MUI_VERSION,
47
+ releaseDate: "MTc3NDU2OTYwMDAwMA==",
48
+ version: "9.0.0-beta.0",
49
49
  name: 'x-data-grid-premium'
50
50
  };
51
51
  const watermark = /*#__PURE__*/_jsx(Watermark, {
@@ -494,7 +494,6 @@ process.env.NODE_ENV !== "production" ? DataGridPremiumRaw.propTypes = {
494
494
  * For each feature, if the flag is not explicitly set to `true`, then the feature is fully disabled, and neither property nor method calls will have any effect.
495
495
  */
496
496
  experimentalFeatures: PropTypes.shape({
497
- charts: PropTypes.bool,
498
497
  warnIfFocusStateIsNotSynced: PropTypes.bool
499
498
  }),
500
499
  /**
@@ -86,7 +86,7 @@ function GridPremiumToolbar(props) {
86
86
  })
87
87
  }))
88
88
  })
89
- }), rootProps.experimentalFeatures?.charts && rootProps.chartsIntegration && /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsPanelTrigger.ChartsPanelTrigger, {
89
+ }), rootProps.chartsIntegration && /*#__PURE__*/(0, _jsxRuntime.jsx)(_ChartsPanelTrigger.ChartsPanelTrigger, {
90
90
  render: triggerProps => /*#__PURE__*/(0, _jsxRuntime.jsx)(rootProps.slots.baseTooltip, {
91
91
  title: apiRef.current.getLocaleText('toolbarCharts'),
92
92
  children: /*#__PURE__*/(0, _jsxRuntime.jsx)(_xDataGridPro.ToolbarButton, (0, _extends2.default)({}, triggerProps, {
@@ -78,7 +78,7 @@ export function GridPremiumToolbar(props) {
78
78
  })
79
79
  }))
80
80
  })
81
- }), rootProps.experimentalFeatures?.charts && rootProps.chartsIntegration && /*#__PURE__*/_jsx(ChartsPanelTrigger, {
81
+ }), rootProps.chartsIntegration && /*#__PURE__*/_jsx(ChartsPanelTrigger, {
82
82
  render: triggerProps => /*#__PURE__*/_jsx(rootProps.slots.baseTooltip, {
83
83
  title: apiRef.current.getLocaleText('toolbarCharts'),
84
84
  children: /*#__PURE__*/_jsx(ToolbarButton, _extends({}, triggerProps, {
@@ -22,7 +22,7 @@ function GridColumnMenuChartsItem(props) {
22
22
  onClick(event);
23
23
  apiRef.current.setChartsPanelOpen(true);
24
24
  };
25
- if (!rootProps.experimentalFeatures?.charts || !rootProps.chartsIntegration) {
25
+ if (!rootProps.chartsIntegration) {
26
26
  return null;
27
27
  }
28
28
  return /*#__PURE__*/(0, _jsxRuntime.jsx)(rootProps.slots.baseMenuItem, {
@@ -15,7 +15,7 @@ export function GridColumnMenuChartsItem(props) {
15
15
  onClick(event);
16
16
  apiRef.current.setChartsPanelOpen(true);
17
17
  };
18
- if (!rootProps.experimentalFeatures?.charts || !rootProps.chartsIntegration) {
18
+ if (!rootProps.chartsIntegration) {
19
19
  return null;
20
20
  }
21
21
  return /*#__PURE__*/_jsx(rootProps.slots.baseMenuItem, {
@@ -3,4 +3,4 @@ import { type GridStateInitializer } from '@mui/x-data-grid-pro/internals';
3
3
  import type { GridPrivateApiPremium } from "../../../models/gridApiPremium.mjs";
4
4
  import type { DataGridPremiumProcessedProps } from "../../../models/dataGridPremiumProps.mjs";
5
5
  export declare const aiAssistantStateInitializer: GridStateInitializer<Pick<DataGridPremiumProcessedProps, 'initialState' | 'aiAssistantConversations' | 'aiAssistant'>>;
6
- export declare const useGridAiAssistant: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "aiAssistant" | "aiAssistantConversations" | "aiAssistantActiveConversationIndex" | "allowAiAssistantDataSampling" | "onAiAssistantConversationsChange" | "onAiAssistantActiveConversationIndexChange" | "onPrompt" | "slots" | "rowSelection" | "disableColumnFilter" | "disableRowGrouping" | "disableAggregation" | "disableColumnSorting" | "disablePivoting" | "chartsIntegration" | "experimentalFeatures" | "getPivotDerivedColumns">) => void;
6
+ export declare const useGridAiAssistant: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "aiAssistant" | "aiAssistantConversations" | "aiAssistantActiveConversationIndex" | "allowAiAssistantDataSampling" | "onAiAssistantConversationsChange" | "onAiAssistantActiveConversationIndexChange" | "onPrompt" | "slots" | "rowSelection" | "disableColumnFilter" | "disableRowGrouping" | "disableAggregation" | "disableColumnSorting" | "disablePivoting" | "chartsIntegration" | "getPivotDerivedColumns">) => void;
@@ -3,4 +3,4 @@ import { type GridStateInitializer } from '@mui/x-data-grid-pro/internals';
3
3
  import type { GridPrivateApiPremium } from "../../../models/gridApiPremium.js";
4
4
  import type { DataGridPremiumProcessedProps } from "../../../models/dataGridPremiumProps.js";
5
5
  export declare const aiAssistantStateInitializer: GridStateInitializer<Pick<DataGridPremiumProcessedProps, 'initialState' | 'aiAssistantConversations' | 'aiAssistant'>>;
6
- export declare const useGridAiAssistant: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "aiAssistant" | "aiAssistantConversations" | "aiAssistantActiveConversationIndex" | "allowAiAssistantDataSampling" | "onAiAssistantConversationsChange" | "onAiAssistantActiveConversationIndexChange" | "onPrompt" | "slots" | "rowSelection" | "disableColumnFilter" | "disableRowGrouping" | "disableAggregation" | "disableColumnSorting" | "disablePivoting" | "chartsIntegration" | "experimentalFeatures" | "getPivotDerivedColumns">) => void;
6
+ export declare const useGridAiAssistant: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "aiAssistant" | "aiAssistantConversations" | "aiAssistantActiveConversationIndex" | "allowAiAssistantDataSampling" | "onAiAssistantConversationsChange" | "onAiAssistantActiveConversationIndexChange" | "onPrompt" | "slots" | "rowSelection" | "disableColumnFilter" | "disableRowGrouping" | "disableAggregation" | "disableColumnSorting" | "disablePivoting" | "chartsIntegration" | "getPivotDerivedColumns">) => void;
@@ -47,7 +47,6 @@ const useGridAiAssistant = (apiRef, props) => {
47
47
  disableColumnSorting,
48
48
  disablePivoting,
49
49
  chartsIntegration,
50
- experimentalFeatures,
51
50
  getPivotDerivedColumns
52
51
  } = props;
53
52
  const previousUnwrappedGroupingModel = React.useRef([]);
@@ -217,7 +216,7 @@ const useGridAiAssistant = (apiRef, props) => {
217
216
  } else {
218
217
  result.sorting = [];
219
218
  }
220
- if (experimentalFeatures?.charts && chartsIntegration && activeChartId && result.chart) {
219
+ if (chartsIntegration && activeChartId && result.chart) {
221
220
  if (appliedPivoting) {
222
221
  const unsubscribe = apiRef.current.subscribeEvent('rowsSet', () => {
223
222
  const unwrappedGroupingModel = Object.keys((0, _xDataGridPro.gridColumnGroupsUnwrappedModelSelector)(apiRef));
@@ -256,7 +255,7 @@ const useGridAiAssistant = (apiRef, props) => {
256
255
  apiRef.current.setRowSelectionModel(rowSelectionModel);
257
256
  const targetIndex = Number(columnsLookup[_xDataGridPro.GRID_CHECKBOX_SELECTION_FIELD] !== undefined) + Number(result.grouping.length);
258
257
  interestColumns.reverse().forEach(c => apiRef.current.setColumnIndex(c, targetIndex));
259
- }, [apiRef, updateChart, rowSelection, disableColumnFilter, disableRowGrouping, disableAggregation, disableColumnSorting, disablePivoting, columnsLookup, isAiAssistantAvailable, activeChartId, chartsIntegration, experimentalFeatures?.charts]);
258
+ }, [apiRef, updateChart, rowSelection, disableColumnFilter, disableRowGrouping, disableAggregation, disableColumnSorting, disablePivoting, columnsLookup, isAiAssistantAvailable, activeChartId, chartsIntegration]);
260
259
  const setActiveConversationId = React.useCallback(id => {
261
260
  if (!isAiAssistantAvailable) {
262
261
  return;
@@ -39,7 +39,6 @@ export const useGridAiAssistant = (apiRef, props) => {
39
39
  disableColumnSorting,
40
40
  disablePivoting,
41
41
  chartsIntegration,
42
- experimentalFeatures,
43
42
  getPivotDerivedColumns
44
43
  } = props;
45
44
  const previousUnwrappedGroupingModel = React.useRef([]);
@@ -209,7 +208,7 @@ export const useGridAiAssistant = (apiRef, props) => {
209
208
  } else {
210
209
  result.sorting = [];
211
210
  }
212
- if (experimentalFeatures?.charts && chartsIntegration && activeChartId && result.chart) {
211
+ if (chartsIntegration && activeChartId && result.chart) {
213
212
  if (appliedPivoting) {
214
213
  const unsubscribe = apiRef.current.subscribeEvent('rowsSet', () => {
215
214
  const unwrappedGroupingModel = Object.keys(gridColumnGroupsUnwrappedModelSelector(apiRef));
@@ -248,7 +247,7 @@ export const useGridAiAssistant = (apiRef, props) => {
248
247
  apiRef.current.setRowSelectionModel(rowSelectionModel);
249
248
  const targetIndex = Number(columnsLookup[GRID_CHECKBOX_SELECTION_FIELD] !== undefined) + Number(result.grouping.length);
250
249
  interestColumns.reverse().forEach(c => apiRef.current.setColumnIndex(c, targetIndex));
251
- }, [apiRef, updateChart, rowSelection, disableColumnFilter, disableRowGrouping, disableAggregation, disableColumnSorting, disablePivoting, columnsLookup, isAiAssistantAvailable, activeChartId, chartsIntegration, experimentalFeatures?.charts]);
250
+ }, [apiRef, updateChart, rowSelection, disableColumnFilter, disableRowGrouping, disableAggregation, disableColumnSorting, disablePivoting, columnsLookup, isAiAssistantAvailable, activeChartId, chartsIntegration]);
252
251
  const setActiveConversationId = React.useCallback(id => {
253
252
  if (!isAiAssistantAvailable) {
254
253
  return;
@@ -4,5 +4,5 @@ import type { DataGridPremiumProcessedProps } from "../../../models/dataGridPrem
4
4
  import type { GridPrivateApiPremium } from "../../../models/gridApiPremium.mjs";
5
5
  import type { ChartState } from "../../../models/gridChartsIntegration.mjs";
6
6
  export declare const EMPTY_CHART_INTEGRATION_CONTEXT_STATE: ChartState;
7
- export declare const chartsIntegrationStateInitializer: GridStateInitializer<Pick<DataGridPremiumProcessedProps, 'chartsIntegration' | 'initialState' | 'activeChartId' | 'rowGroupingModel' | 'pivotModel' | 'experimentalFeatures'>, GridPrivateApiPremium>;
8
- export declare const useGridChartsIntegration: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "chartsIntegration" | "activeChartId" | "onActiveChartIdChange" | "initialState" | "slots" | "slotProps" | "aggregationFunctions" | "dataSource" | "experimentalFeatures">) => void;
7
+ export declare const chartsIntegrationStateInitializer: GridStateInitializer<Pick<DataGridPremiumProcessedProps, 'chartsIntegration' | 'initialState' | 'activeChartId' | 'rowGroupingModel' | 'pivotModel'>, GridPrivateApiPremium>;
8
+ export declare const useGridChartsIntegration: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "chartsIntegration" | "activeChartId" | "onActiveChartIdChange" | "initialState" | "slots" | "slotProps" | "aggregationFunctions" | "dataSource">) => void;
@@ -4,5 +4,5 @@ import type { DataGridPremiumProcessedProps } from "../../../models/dataGridPrem
4
4
  import type { GridPrivateApiPremium } from "../../../models/gridApiPremium.js";
5
5
  import type { ChartState } from "../../../models/gridChartsIntegration.js";
6
6
  export declare const EMPTY_CHART_INTEGRATION_CONTEXT_STATE: ChartState;
7
- export declare const chartsIntegrationStateInitializer: GridStateInitializer<Pick<DataGridPremiumProcessedProps, 'chartsIntegration' | 'initialState' | 'activeChartId' | 'rowGroupingModel' | 'pivotModel' | 'experimentalFeatures'>, GridPrivateApiPremium>;
8
- export declare const useGridChartsIntegration: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "chartsIntegration" | "activeChartId" | "onActiveChartIdChange" | "initialState" | "slots" | "slotProps" | "aggregationFunctions" | "dataSource" | "experimentalFeatures">) => void;
7
+ export declare const chartsIntegrationStateInitializer: GridStateInitializer<Pick<DataGridPremiumProcessedProps, 'chartsIntegration' | 'initialState' | 'activeChartId' | 'rowGroupingModel' | 'pivotModel'>, GridPrivateApiPremium>;
8
+ export declare const useGridChartsIntegration: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "chartsIntegration" | "activeChartId" | "onActiveChartIdChange" | "initialState" | "slots" | "slotProps" | "aggregationFunctions" | "dataSource">) => void;
@@ -34,7 +34,7 @@ const EMPTY_CHART_INTEGRATION_CONTEXT_STATE = exports.EMPTY_CHART_INTEGRATION_CO
34
34
  configuration: {}
35
35
  };
36
36
  const chartsIntegrationStateInitializer = (state, props) => {
37
- if (!props.chartsIntegration || !props.experimentalFeatures?.charts) {
37
+ if (!props.chartsIntegration) {
38
38
  return (0, _extends2.default)({}, state, {
39
39
  chartsIntegration: {
40
40
  activeChartId: '',
@@ -68,7 +68,7 @@ const useGridChartsIntegration = (apiRef, props) => {
68
68
  const visibleValues = React.useRef({});
69
69
  const schema = React.useMemo(() => props.slotProps?.chartsPanel?.schema || {}, [props.slotProps?.chartsPanel?.schema]);
70
70
  const context = (0, _useGridChartIntegration.useGridChartsIntegrationContext)(true);
71
- const isChartsIntegrationAvailable = !!props.chartsIntegration && !!props.experimentalFeatures?.charts && !!context;
71
+ const isChartsIntegrationAvailable = !!props.chartsIntegration && !!context;
72
72
  const activeChartId = (0, _gridChartsIntegrationSelectors.gridChartsIntegrationActiveChartIdSelector)(apiRef);
73
73
  const aggregationModel = (0, _gridAggregationSelectors.gridAggregationModelSelector)(apiRef);
74
74
  const pivotActive = (0, _internals.gridPivotActiveSelector)(apiRef);
@@ -494,7 +494,7 @@ const useGridChartsIntegration = (apiRef, props) => {
494
494
  getColumnName
495
495
  }
496
496
  }, 'private');
497
- (0, _internals.useGridApiMethod)(apiRef, props.experimentalFeatures?.charts ? {
497
+ (0, _internals.useGridApiMethod)(apiRef, props.chartsIntegration ? {
498
498
  setChartsPanelOpen,
499
499
  setActiveChartId,
500
500
  setChartType,
@@ -508,7 +508,7 @@ const useGridChartsIntegration = (apiRef, props) => {
508
508
  (0, _internals.useGridEvent)(apiRef, 'sortedRowsSet', (0, _internals.runIf)(isChartsIntegrationAvailable, () => debouncedHandleRowDataUpdate(syncedChartIds)));
509
509
  (0, _internals.useGridEvent)(apiRef, 'aggregationLookupSet', (0, _internals.runIf)(isChartsIntegrationAvailable, () => debouncedHandleRowDataUpdate(syncedChartIds)));
510
510
  const stateExportPreProcessing = React.useCallback((prevState, exportContext) => {
511
- if (!props.chartsIntegration || !props.experimentalFeatures?.charts) {
511
+ if (!props.chartsIntegration) {
512
512
  return prevState;
513
513
  }
514
514
  const currentActiveChartId = (0, _gridChartsIntegrationSelectors.gridChartsIntegrationActiveChartIdSelector)(apiRef);
@@ -539,7 +539,7 @@ const useGridChartsIntegration = (apiRef, props) => {
539
539
  return (0, _extends2.default)({}, prevState, {
540
540
  chartsIntegration: chartStateToExport
541
541
  });
542
- }, [apiRef, chartStateLookup, props.chartsIntegration, props.experimentalFeatures?.charts, props.initialState?.chartsIntegration]);
542
+ }, [apiRef, chartStateLookup, props.chartsIntegration, props.initialState?.chartsIntegration]);
543
543
  const stateRestorePreProcessing = React.useCallback((params, restoreContext) => {
544
544
  const chartsRestoreState = restoreContext.stateToRestore.chartsIntegration;
545
545
  if (!chartsRestoreState) {
@@ -27,7 +27,7 @@ export const EMPTY_CHART_INTEGRATION_CONTEXT_STATE = {
27
27
  configuration: {}
28
28
  };
29
29
  export const chartsIntegrationStateInitializer = (state, props) => {
30
- if (!props.chartsIntegration || !props.experimentalFeatures?.charts) {
30
+ if (!props.chartsIntegration) {
31
31
  return _extends({}, state, {
32
32
  chartsIntegration: {
33
33
  activeChartId: '',
@@ -60,7 +60,7 @@ export const useGridChartsIntegration = (apiRef, props) => {
60
60
  const visibleValues = React.useRef({});
61
61
  const schema = React.useMemo(() => props.slotProps?.chartsPanel?.schema || {}, [props.slotProps?.chartsPanel?.schema]);
62
62
  const context = useGridChartsIntegrationContext(true);
63
- const isChartsIntegrationAvailable = !!props.chartsIntegration && !!props.experimentalFeatures?.charts && !!context;
63
+ const isChartsIntegrationAvailable = !!props.chartsIntegration && !!context;
64
64
  const activeChartId = gridChartsIntegrationActiveChartIdSelector(apiRef);
65
65
  const aggregationModel = gridAggregationModelSelector(apiRef);
66
66
  const pivotActive = gridPivotActiveSelector(apiRef);
@@ -486,7 +486,7 @@ export const useGridChartsIntegration = (apiRef, props) => {
486
486
  getColumnName
487
487
  }
488
488
  }, 'private');
489
- useGridApiMethod(apiRef, props.experimentalFeatures?.charts ? {
489
+ useGridApiMethod(apiRef, props.chartsIntegration ? {
490
490
  setChartsPanelOpen,
491
491
  setActiveChartId,
492
492
  setChartType,
@@ -500,7 +500,7 @@ export const useGridChartsIntegration = (apiRef, props) => {
500
500
  useGridEvent(apiRef, 'sortedRowsSet', runIf(isChartsIntegrationAvailable, () => debouncedHandleRowDataUpdate(syncedChartIds)));
501
501
  useGridEvent(apiRef, 'aggregationLookupSet', runIf(isChartsIntegrationAvailable, () => debouncedHandleRowDataUpdate(syncedChartIds)));
502
502
  const stateExportPreProcessing = React.useCallback((prevState, exportContext) => {
503
- if (!props.chartsIntegration || !props.experimentalFeatures?.charts) {
503
+ if (!props.chartsIntegration) {
504
504
  return prevState;
505
505
  }
506
506
  const currentActiveChartId = gridChartsIntegrationActiveChartIdSelector(apiRef);
@@ -531,7 +531,7 @@ export const useGridChartsIntegration = (apiRef, props) => {
531
531
  return _extends({}, prevState, {
532
532
  chartsIntegration: chartStateToExport
533
533
  });
534
- }, [apiRef, chartStateLookup, props.chartsIntegration, props.experimentalFeatures?.charts, props.initialState?.chartsIntegration]);
534
+ }, [apiRef, chartStateLookup, props.chartsIntegration, props.initialState?.chartsIntegration]);
535
535
  const stateRestorePreProcessing = React.useCallback((params, restoreContext) => {
536
536
  const chartsRestoreState = restoreContext.stateToRestore.chartsIntegration;
537
537
  if (!chartsRestoreState) {
package/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @mui/x-data-grid-premium v9.0.0-alpha.3
2
+ * @mui/x-data-grid-premium v9.0.0-beta.0
3
3
  *
4
4
  * @license SEE LICENSE IN LICENSE
5
5
  * This source code is licensed under the SEE LICENSE IN LICENSE license found in the
package/index.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @mui/x-data-grid-premium v9.0.0-alpha.3
2
+ * @mui/x-data-grid-premium v9.0.0-beta.0
3
3
  *
4
4
  * @license SEE LICENSE IN LICENSE
5
5
  * This source code is licensed under the SEE LICENSE IN LICENSE license found in the
@@ -12,9 +12,7 @@ import type { GridPivotingColDefOverrides, PivotingColDefCallback, GridPivotMode
12
12
  import type { GridDataSourcePremium as GridDataSource, GridGetRowsParamsPremium as GridGetRowsParams } from "../hooks/features/dataSource/models.mjs";
13
13
  import type { Conversation, PromptResponse, PromptSuggestion } from "../hooks/features/aiAssistant/gridAiAssistantInterfaces.mjs";
14
14
  import type { GridHistoryEventHandler } from "../hooks/features/history/gridHistoryInterfaces.mjs";
15
- export interface GridExperimentalPremiumFeatures extends GridExperimentalProFeatures {
16
- charts?: boolean;
17
- }
15
+ export interface GridExperimentalPremiumFeatures extends GridExperimentalProFeatures {}
18
16
  export interface DataGridPremiumPropsWithComplexDefaultValueBeforeProcessing extends Pick<DataGridPropsWithComplexDefaultValueBeforeProcessing, 'localeText'> {
19
17
  /**
20
18
  * Overridable components.
@@ -12,9 +12,7 @@ import type { GridPivotingColDefOverrides, PivotingColDefCallback, GridPivotMode
12
12
  import type { GridDataSourcePremium as GridDataSource, GridGetRowsParamsPremium as GridGetRowsParams } from "../hooks/features/dataSource/models.js";
13
13
  import type { Conversation, PromptResponse, PromptSuggestion } from "../hooks/features/aiAssistant/gridAiAssistantInterfaces.js";
14
14
  import type { GridHistoryEventHandler } from "../hooks/features/history/gridHistoryInterfaces.js";
15
- export interface GridExperimentalPremiumFeatures extends GridExperimentalProFeatures {
16
- charts?: boolean;
17
- }
15
+ export interface GridExperimentalPremiumFeatures extends GridExperimentalProFeatures {}
18
16
  export interface DataGridPremiumPropsWithComplexDefaultValueBeforeProcessing extends Pick<DataGridPropsWithComplexDefaultValueBeforeProcessing, 'localeText'> {
19
17
  /**
20
18
  * Overridable components.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mui/x-data-grid-premium",
3
- "version": "9.0.0-alpha.3",
3
+ "version": "9.0.0-beta.0",
4
4
  "author": "MUI Team",
5
5
  "description": "The Premium plan edition of the MUI X Data Grid Components.",
6
6
  "license": "SEE LICENSE IN LICENSE",
@@ -38,10 +38,10 @@
38
38
  "@mui/x-internal-exceljs-fork": "4.4.4",
39
39
  "clsx": "^2.1.1",
40
40
  "prop-types": "^15.8.1",
41
- "@mui/x-data-grid-pro": "9.0.0-alpha.3",
42
- "@mui/x-internals": "9.0.0-alpha.2",
43
- "@mui/x-data-grid": "9.0.0-alpha.3",
44
- "@mui/x-license": "9.0.0-alpha.3"
41
+ "@mui/x-data-grid": "9.0.0-beta.0",
42
+ "@mui/x-data-grid-pro": "9.0.0-beta.0",
43
+ "@mui/x-internals": "9.0.0-alpha.4",
44
+ "@mui/x-license": "9.0.0-beta.0"
45
45
  },
46
46
  "peerDependencies": {
47
47
  "@emotion/react": "^11.9.0",