@mui/x-data-grid 5.8.0 → 5.11.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 +333 -66
- package/DataGrid/DataGrid.js +36 -2
- package/DataGrid/useDataGridComponent.js +3 -1
- package/DataGrid/useDataGridProps.js +2 -1
- package/LICENSE +21 -0
- package/README.md +7 -5
- package/colDef/gridActionsColDef.js +2 -1
- package/colDef/gridBooleanColDef.js +2 -1
- package/colDef/gridCheckboxSelectionColDef.js +1 -0
- package/colDef/gridDateColDef.js +4 -2
- package/colDef/gridNumericColDef.js +3 -2
- package/colDef/gridNumericOperators.d.ts +2 -0
- package/colDef/gridNumericOperators.js +11 -0
- package/colDef/gridSingleSelectColDef.js +3 -2
- package/colDef/gridSingleSelectOperators.d.ts +3 -0
- package/colDef/gridSingleSelectOperators.js +52 -0
- package/colDef/gridStringColDef.js +3 -2
- package/colDef/gridStringOperators.d.ts +2 -0
- package/colDef/gridStringOperators.js +12 -0
- package/components/GridFooter.d.ts +4 -2
- package/components/GridFooter.js +11 -2
- package/components/GridRow.d.ts +4 -0
- package/components/GridRow.js +58 -28
- package/components/GridRowCount.d.ts +4 -1
- package/components/GridRowCount.js +1 -0
- package/components/GridScrollArea.js +3 -4
- package/components/GridSelectedRowCount.d.ts +4 -1
- package/components/GridSelectedRowCount.js +2 -1
- package/components/base/GridBody.js +1 -2
- package/components/base/GridOverlays.js +5 -5
- package/components/cell/GridActionsCell.d.ts +5 -1
- package/components/cell/GridActionsCell.js +179 -21
- package/components/cell/GridActionsCellItem.d.ts +66 -4
- package/components/cell/GridActionsCellItem.js +7 -5
- package/components/cell/GridCell.d.ts +1 -0
- package/components/cell/GridCell.js +36 -15
- package/components/cell/GridEditBooleanCell.d.ts +15 -3
- package/components/cell/GridEditBooleanCell.js +101 -6
- package/components/cell/GridEditDateCell.d.ts +16 -4
- package/components/cell/GridEditDateCell.js +99 -5
- package/components/cell/GridEditInputCell.d.ts +11 -5
- package/components/cell/GridEditInputCell.js +30 -6
- package/components/cell/GridEditSingleSelectCell.d.ts +12 -4
- package/components/cell/GridEditSingleSelectCell.js +50 -18
- package/components/cell/index.d.ts +2 -0
- package/components/cell/index.js +2 -0
- package/components/columnHeaders/GridColumnHeaderItem.js +19 -23
- package/components/columnHeaders/GridColumnHeaders.d.ts +2 -1
- package/components/columnHeaders/GridColumnHeaders.js +1 -1
- package/components/columnHeaders/GridColumnHeadersInner.d.ts +2 -0
- package/components/columnSelection/GridCellCheckboxRenderer.d.ts +3 -3
- package/components/columnSelection/GridCellCheckboxRenderer.js +22 -6
- package/components/columnSelection/GridHeaderCheckbox.js +4 -5
- package/components/containers/GridFooterContainer.d.ts +8 -2
- package/components/containers/GridFooterContainer.js +11 -2
- package/components/containers/GridRootStyles.js +36 -1
- package/components/containers/GridToolbarContainer.d.ts +8 -2
- package/components/containers/GridToolbarContainer.js +12 -2
- package/components/menu/GridMenu.js +1 -0
- package/components/panel/GridPanel.js +1 -0
- package/components/panel/GridPanelContent.d.ts +8 -1
- package/components/panel/GridPanelContent.js +13 -2
- package/components/panel/GridPanelFooter.d.ts +8 -1
- package/components/panel/GridPanelFooter.js +13 -2
- package/components/panel/GridPanelHeader.d.ts +8 -1
- package/components/panel/GridPanelHeader.js +13 -2
- package/components/panel/filterPanel/GridFilterForm.js +14 -10
- package/components/panel/filterPanel/GridFilterInputBoolean.js +13 -8
- package/components/panel/filterPanel/GridFilterInputSingleSelect.js +22 -15
- package/components/panel/filterPanel/GridFilterInputValue.js +22 -15
- package/components/toolbar/GridToolbar.d.ts +12 -2
- package/components/toolbar/GridToolbar.js +30 -7
- package/components/toolbar/GridToolbarDensitySelector.js +1 -1
- package/components/toolbar/GridToolbarExport.d.ts +5 -4
- package/components/toolbar/GridToolbarExport.js +15 -20
- package/components/toolbar/GridToolbarFilterButton.d.ts +1 -1
- package/components/toolbar/GridToolbarQuickFilter.d.ts +20 -0
- package/components/toolbar/GridToolbarQuickFilter.js +88 -0
- package/components/toolbar/index.d.ts +3 -1
- package/components/toolbar/index.js +3 -2
- package/components/virtualization/GridVirtualScroller.d.ts +4 -1
- package/components/virtualization/GridVirtualScroller.js +2 -0
- package/components/virtualization/GridVirtualScrollerContent.d.ts +4 -1
- package/components/virtualization/GridVirtualScrollerContent.js +1 -3
- package/components/virtualization/GridVirtualScrollerRenderZone.d.ts +4 -1
- package/constants/defaultGridSlotsComponents.js +3 -2
- package/constants/gridClasses.d.ts +20 -0
- package/constants/gridClasses.js +1 -1
- package/constants/gridDetailPanelToggleField.d.ts +1 -0
- package/constants/gridDetailPanelToggleField.js +2 -0
- package/constants/localeTextConstants.js +8 -1
- package/hooks/core/pipeProcessing/gridPipeProcessingApi.d.ts +39 -15
- package/hooks/core/pipeProcessing/index.d.ts +1 -0
- package/hooks/core/pipeProcessing/index.js +2 -1
- package/hooks/core/pipeProcessing/useGridPipeProcessing.d.ts +8 -3
- package/hooks/core/pipeProcessing/useGridPipeProcessing.js +53 -19
- package/hooks/core/pipeProcessing/useGridRegisterPipeApplier.d.ts +3 -0
- package/hooks/core/pipeProcessing/useGridRegisterPipeApplier.js +27 -0
- package/hooks/core/pipeProcessing/useGridRegisterPipeProcessor.d.ts +0 -3
- package/hooks/core/pipeProcessing/useGridRegisterPipeProcessor.js +0 -4
- package/hooks/core/strategyProcessing/useGridStrategyProcessing.d.ts +4 -4
- package/hooks/core/strategyProcessing/useGridStrategyProcessing.js +6 -7
- package/hooks/core/useGridApiInitialization.js +3 -3
- package/hooks/core/useGridErrorHandler.js +1 -2
- package/hooks/core/useGridStateInitialization.js +1 -2
- package/hooks/features/columnHeaders/useGridColumnHeaders.d.ts +0 -1
- package/hooks/features/columnHeaders/useGridColumnHeaders.js +81 -16
- package/hooks/features/columnMenu/useGridColumnMenu.js +3 -3
- package/hooks/features/columns/gridColumnsInterfaces.d.ts +3 -1
- package/hooks/features/columns/gridColumnsUtils.d.ts +19 -1
- package/hooks/features/columns/gridColumnsUtils.js +61 -8
- package/hooks/features/columns/useGridColumnSpanning.d.ts +7 -0
- package/hooks/features/columns/useGridColumnSpanning.js +108 -0
- package/hooks/features/columns/useGridColumns.d.ts +1 -1
- package/hooks/features/columns/useGridColumns.js +30 -25
- package/hooks/features/dimensions/useGridDimensions.d.ts +1 -1
- package/hooks/features/dimensions/useGridDimensions.js +10 -11
- package/hooks/features/editRows/useGridCellEditing.new.d.ts +1 -1
- package/hooks/features/editRows/useGridCellEditing.new.js +151 -42
- package/hooks/features/editRows/useGridCellEditing.old.js +20 -21
- package/hooks/features/editRows/useGridEditing.new.js +7 -3
- package/hooks/features/editRows/useGridEditing.old.js +4 -5
- package/hooks/features/editRows/useGridRowEditing.new.d.ts +1 -1
- package/hooks/features/editRows/useGridRowEditing.new.js +145 -57
- package/hooks/features/editRows/useGridRowEditing.old.js +21 -22
- package/hooks/features/events/useGridEvents.js +17 -18
- package/hooks/features/export/serializers/csvSerializer.js +5 -5
- package/hooks/features/export/useGridCsvExport.js +23 -16
- package/hooks/features/export/useGridPrintExport.js +22 -0
- package/hooks/features/export/utils.d.ts +3 -1
- package/hooks/features/export/utils.js +13 -0
- package/hooks/features/filter/gridFilterState.d.ts +1 -2
- package/hooks/features/filter/gridFilterState.js +3 -1
- package/hooks/features/filter/gridFilterUtils.d.ts +8 -0
- package/hooks/features/filter/gridFilterUtils.js +84 -2
- package/hooks/features/filter/useGridFilter.js +32 -15
- package/hooks/features/focus/useGridFocus.d.ts +1 -1
- package/hooks/features/focus/useGridFocus.js +48 -42
- package/hooks/features/keyboardNavigation/useGridKeyboardNavigation.d.ts +1 -0
- package/hooks/features/keyboardNavigation/useGridKeyboardNavigation.js +43 -12
- package/hooks/features/pagination/useGridPage.js +3 -4
- package/hooks/features/pagination/useGridPageSize.js +2 -3
- package/hooks/features/preferencesPanel/useGridPreferencesPanel.js +4 -6
- package/hooks/features/rows/gridRowsSelector.d.ts +2 -0
- package/hooks/features/rows/gridRowsSelector.js +2 -0
- package/hooks/features/rows/gridRowsState.d.ts +7 -7
- package/hooks/features/rows/gridRowsUtils.d.ts +2 -1
- package/hooks/features/rows/gridRowsUtils.js +25 -1
- package/hooks/features/rows/useGridRows.d.ts +2 -2
- package/hooks/features/rows/useGridRows.js +121 -61
- package/hooks/features/rows/useGridRowsMeta.js +6 -13
- package/hooks/features/rows/useGridRowsPreProcessors.js +2 -0
- package/hooks/features/scroll/useGridScroll.d.ts +2 -0
- package/hooks/features/scroll/useGridScroll.js +31 -4
- package/hooks/features/selection/useGridSelection.d.ts +1 -1
- package/hooks/features/selection/useGridSelection.js +15 -11
- package/hooks/features/sorting/useGridSorting.js +17 -18
- package/hooks/features/virtualization/useGridVirtualScroller.d.ts +9 -0
- package/hooks/features/virtualization/useGridVirtualScroller.js +68 -32
- package/hooks/utils/useGridApiEventHandler.d.ts +4 -1
- package/hooks/utils/useGridApiEventHandler.js +22 -9
- package/hooks/utils/useGridNativeEventListener.js +1 -2
- package/hooks/utils/useGridSelector.js +1 -1
- package/index.d.ts +2 -0
- package/index.js +1 -1
- package/internals/index.d.ts +5 -1
- package/internals/index.js +6 -2
- package/legacy/DataGrid/DataGrid.js +36 -2
- package/legacy/DataGrid/useDataGridComponent.js +3 -1
- package/legacy/DataGrid/useDataGridProps.js +2 -1
- package/legacy/colDef/gridActionsColDef.js +2 -1
- package/legacy/colDef/gridBooleanColDef.js +2 -1
- package/legacy/colDef/gridCheckboxSelectionColDef.js +1 -0
- package/legacy/colDef/gridDateColDef.js +4 -2
- package/legacy/colDef/gridNumericColDef.js +3 -2
- package/legacy/colDef/gridNumericOperators.js +28 -18
- package/legacy/colDef/gridSingleSelectColDef.js +3 -2
- package/legacy/colDef/gridSingleSelectOperators.js +55 -6
- package/legacy/colDef/gridStringColDef.js +3 -2
- package/legacy/colDef/gridStringOperators.js +25 -14
- package/legacy/components/GridFooter.js +11 -2
- package/legacy/components/GridRow.js +56 -28
- package/legacy/components/GridRowCount.js +1 -0
- package/legacy/components/GridScrollArea.js +3 -4
- package/legacy/components/GridSelectedRowCount.js +2 -1
- package/legacy/components/base/GridBody.js +1 -2
- package/legacy/components/base/GridOverlays.js +5 -5
- package/legacy/components/cell/GridActionsCell.js +197 -27
- package/legacy/components/cell/GridActionsCellItem.js +7 -5
- package/legacy/components/cell/GridCell.js +37 -15
- package/legacy/components/cell/GridEditBooleanCell.js +132 -11
- package/legacy/components/cell/GridEditDateCell.js +148 -42
- package/legacy/components/cell/GridEditInputCell.js +62 -13
- package/legacy/components/cell/GridEditSingleSelectCell.js +65 -28
- package/legacy/components/cell/index.js +2 -0
- package/legacy/components/columnHeaders/GridColumnHeaderItem.js +19 -23
- package/legacy/components/columnHeaders/GridColumnHeaders.js +2 -3
- package/legacy/components/columnSelection/GridCellCheckboxRenderer.js +23 -6
- package/legacy/components/columnSelection/GridHeaderCheckbox.js +4 -5
- package/legacy/components/containers/GridFooterContainer.js +11 -2
- package/legacy/components/containers/GridRootStyles.js +26 -5
- package/legacy/components/containers/GridToolbarContainer.js +12 -2
- package/legacy/components/menu/GridMenu.js +1 -0
- package/legacy/components/panel/GridPanel.js +1 -0
- package/legacy/components/panel/GridPanelContent.js +13 -2
- package/legacy/components/panel/GridPanelFooter.js +13 -2
- package/legacy/components/panel/GridPanelHeader.js +13 -2
- package/legacy/components/panel/filterPanel/GridFilterForm.js +14 -10
- package/legacy/components/panel/filterPanel/GridFilterInputBoolean.js +13 -8
- package/legacy/components/panel/filterPanel/GridFilterInputSingleSelect.js +22 -17
- package/legacy/components/panel/filterPanel/GridFilterInputValue.js +22 -17
- package/legacy/components/toolbar/GridToolbar.js +31 -6
- package/legacy/components/toolbar/GridToolbarDensitySelector.js +1 -1
- package/legacy/components/toolbar/GridToolbarExport.js +18 -19
- package/legacy/components/toolbar/GridToolbarQuickFilter.js +103 -0
- package/legacy/components/toolbar/index.js +3 -2
- package/legacy/components/virtualization/GridVirtualScroller.js +2 -0
- package/legacy/components/virtualization/GridVirtualScrollerContent.js +1 -3
- package/legacy/constants/defaultGridSlotsComponents.js +3 -2
- package/legacy/constants/gridClasses.js +1 -1
- package/legacy/constants/gridDetailPanelToggleField.js +2 -0
- package/legacy/constants/localeTextConstants.js +8 -1
- package/legacy/hooks/core/pipeProcessing/index.js +2 -1
- package/legacy/hooks/core/pipeProcessing/useGridPipeProcessing.js +60 -24
- package/legacy/hooks/core/pipeProcessing/useGridRegisterPipeApplier.js +27 -0
- package/legacy/hooks/core/pipeProcessing/useGridRegisterPipeProcessor.js +0 -4
- package/legacy/hooks/core/strategyProcessing/useGridStrategyProcessing.js +6 -7
- package/legacy/hooks/core/useGridApiInitialization.js +3 -3
- package/legacy/hooks/core/useGridErrorHandler.js +1 -2
- package/legacy/hooks/core/useGridStateInitialization.js +1 -2
- package/legacy/hooks/features/columnHeaders/useGridColumnHeaders.js +94 -16
- package/legacy/hooks/features/columnMenu/useGridColumnMenu.js +3 -3
- package/legacy/hooks/features/columns/gridColumnsUtils.js +79 -22
- package/legacy/hooks/features/columns/useGridColumnSpanning.js +106 -0
- package/legacy/hooks/features/columns/useGridColumns.js +30 -25
- package/legacy/hooks/features/dimensions/useGridDimensions.js +10 -11
- package/legacy/hooks/features/editRows/useGridCellEditing.new.js +225 -89
- package/legacy/hooks/features/editRows/useGridCellEditing.old.js +20 -21
- package/legacy/hooks/features/editRows/useGridEditing.new.js +7 -3
- package/legacy/hooks/features/editRows/useGridEditing.old.js +4 -5
- package/legacy/hooks/features/editRows/useGridRowEditing.new.js +157 -65
- package/legacy/hooks/features/editRows/useGridRowEditing.old.js +20 -21
- package/legacy/hooks/features/events/useGridEvents.js +17 -18
- package/legacy/hooks/features/export/serializers/csvSerializer.js +5 -5
- package/legacy/hooks/features/export/useGridCsvExport.js +24 -17
- package/legacy/hooks/features/export/useGridPrintExport.js +22 -0
- package/legacy/hooks/features/export/utils.js +14 -0
- package/legacy/hooks/features/filter/gridFilterState.js +3 -1
- package/legacy/hooks/features/filter/gridFilterUtils.js +96 -2
- package/legacy/hooks/features/filter/useGridFilter.js +32 -15
- package/legacy/hooks/features/focus/useGridFocus.js +50 -44
- package/legacy/hooks/features/keyboardNavigation/useGridKeyboardNavigation.js +43 -11
- package/legacy/hooks/features/pagination/useGridPage.js +3 -4
- package/legacy/hooks/features/pagination/useGridPageSize.js +2 -3
- package/legacy/hooks/features/preferencesPanel/useGridPreferencesPanel.js +4 -6
- package/legacy/hooks/features/rows/gridRowsSelector.js +6 -0
- package/legacy/hooks/features/rows/gridRowsUtils.js +27 -1
- package/legacy/hooks/features/rows/useGridRows.js +131 -61
- package/legacy/hooks/features/rows/useGridRowsMeta.js +6 -13
- package/legacy/hooks/features/rows/useGridRowsPreProcessors.js +2 -0
- package/legacy/hooks/features/scroll/useGridScroll.js +31 -4
- package/legacy/hooks/features/selection/useGridSelection.js +15 -11
- package/legacy/hooks/features/sorting/useGridSorting.js +12 -15
- package/legacy/hooks/features/virtualization/useGridVirtualScroller.js +79 -42
- package/legacy/hooks/utils/useGridApiEventHandler.js +20 -9
- package/legacy/hooks/utils/useGridNativeEventListener.js +1 -2
- package/legacy/hooks/utils/useGridSelector.js +1 -1
- package/legacy/index.js +1 -1
- package/legacy/internals/index.js +6 -2
- package/legacy/locales/arSD.js +8 -1
- package/legacy/locales/bgBG.js +8 -1
- package/legacy/locales/csCZ.js +7 -0
- package/legacy/locales/daDK.js +8 -1
- package/legacy/locales/deDE.js +10 -3
- package/legacy/locales/elGR.js +7 -0
- package/legacy/locales/esES.js +7 -0
- package/legacy/locales/faIR.js +8 -1
- package/legacy/locales/fiFI.js +7 -0
- package/legacy/locales/frFR.js +7 -0
- package/legacy/locales/heIL.js +8 -1
- package/legacy/locales/huHU.js +127 -0
- package/legacy/locales/index.js +1 -0
- package/legacy/locales/itIT.js +7 -0
- package/legacy/locales/jaJP.js +7 -0
- package/legacy/locales/koKR.js +7 -0
- package/legacy/locales/nlNL.js +7 -0
- package/legacy/locales/plPL.js +8 -1
- package/legacy/locales/ptBR.js +8 -1
- package/legacy/locales/ruRU.js +7 -0
- package/legacy/locales/skSK.js +7 -0
- package/legacy/locales/trTR.js +8 -1
- package/legacy/locales/ukUA.js +7 -0
- package/legacy/locales/viVN.js +7 -0
- package/legacy/locales/zhCN.js +7 -0
- package/legacy/models/api/gridColumnSpanning.js +1 -0
- package/legacy/models/events/gridEvents.js +10 -3
- package/legacy/models/gridColumnSpanning.js +1 -0
- package/legacy/models/index.js +4 -3
- package/legacy/utils/createSelector.js +18 -2
- package/legacy/utils/exportAs.js +1 -1
- package/locales/arSD.js +8 -1
- package/locales/bgBG.js +8 -1
- package/locales/csCZ.js +7 -0
- package/locales/daDK.js +8 -1
- package/locales/deDE.js +10 -3
- package/locales/elGR.js +7 -0
- package/locales/esES.js +7 -0
- package/locales/faIR.js +8 -1
- package/locales/fiFI.js +7 -0
- package/locales/frFR.js +7 -0
- package/locales/heIL.js +8 -1
- package/locales/huHU.d.ts +2 -0
- package/locales/huHU.js +115 -0
- package/locales/index.d.ts +1 -0
- package/locales/index.js +1 -0
- package/locales/itIT.js +7 -0
- package/locales/jaJP.js +7 -0
- package/locales/koKR.js +7 -0
- package/locales/nlNL.js +7 -0
- package/locales/plPL.js +8 -1
- package/locales/ptBR.js +8 -1
- package/locales/ruRU.js +7 -0
- package/locales/skSK.js +7 -0
- package/locales/trTR.js +8 -1
- package/locales/ukUA.js +7 -0
- package/locales/viVN.js +7 -0
- package/locales/zhCN.js +7 -0
- package/models/api/gridApiCommon.d.ts +2 -1
- package/models/api/gridColumnSpanning.d.ts +28 -0
- package/models/api/gridColumnSpanning.js +1 -0
- package/models/api/gridCoreApi.d.ts +10 -0
- package/models/api/gridEditingApi.d.ts +72 -7
- package/models/api/gridFilterApi.d.ts +5 -0
- package/models/api/gridFocusApi.d.ts +1 -0
- package/models/api/gridLocaleTextApi.d.ts +5 -0
- package/models/api/gridRowApi.d.ts +34 -0
- package/models/api/index.d.ts +1 -1
- package/models/colDef/gridColDef.d.ts +18 -0
- package/models/events/gridEventLookup.d.ts +296 -11
- package/models/events/gridEvents.d.ts +10 -258
- package/models/events/gridEvents.js +10 -3
- package/models/gridColumnSpanning.d.ts +12 -0
- package/models/gridColumnSpanning.js +1 -0
- package/models/gridEditRowModel.d.ts +1 -1
- package/models/gridExport.d.ts +29 -2
- package/models/gridFilterModel.d.ts +11 -0
- package/models/gridFilterOperator.d.ts +1 -1
- package/models/gridIconSlotsComponent.d.ts +5 -0
- package/models/gridStateCommunity.d.ts +0 -2
- package/models/index.d.ts +1 -1
- package/models/index.js +4 -3
- package/models/params/gridCellParams.d.ts +12 -2
- package/models/params/gridRowParams.d.ts +5 -0
- package/models/props/DataGridProps.d.ts +57 -29
- package/modern/DataGrid/DataGrid.js +36 -2
- package/modern/DataGrid/useDataGridComponent.js +3 -1
- package/modern/DataGrid/useDataGridProps.js +2 -1
- package/modern/colDef/gridActionsColDef.js +2 -1
- package/modern/colDef/gridBooleanColDef.js +2 -1
- package/modern/colDef/gridCheckboxSelectionColDef.js +1 -0
- package/modern/colDef/gridDateColDef.js +4 -2
- package/modern/colDef/gridNumericColDef.js +3 -2
- package/modern/colDef/gridNumericOperators.js +11 -0
- package/modern/colDef/gridSingleSelectColDef.js +3 -2
- package/modern/colDef/gridSingleSelectOperators.js +52 -0
- package/modern/colDef/gridStringColDef.js +3 -2
- package/modern/colDef/gridStringOperators.js +12 -0
- package/modern/components/GridFooter.js +11 -2
- package/modern/components/GridRow.js +56 -26
- package/modern/components/GridRowCount.js +1 -0
- package/modern/components/GridScrollArea.js +3 -4
- package/modern/components/GridSelectedRowCount.js +2 -1
- package/modern/components/base/GridBody.js +1 -2
- package/modern/components/base/GridOverlays.js +5 -5
- package/modern/components/cell/GridActionsCell.js +179 -21
- package/modern/components/cell/GridActionsCellItem.js +7 -5
- package/modern/components/cell/GridCell.js +36 -15
- package/modern/components/cell/GridEditBooleanCell.js +101 -6
- package/modern/components/cell/GridEditDateCell.js +99 -5
- package/modern/components/cell/GridEditInputCell.js +30 -6
- package/modern/components/cell/GridEditSingleSelectCell.js +48 -16
- package/modern/components/cell/index.js +2 -0
- package/modern/components/columnHeaders/GridColumnHeaderItem.js +19 -23
- package/modern/components/columnHeaders/GridColumnHeaders.js +1 -1
- package/modern/components/columnSelection/GridCellCheckboxRenderer.js +22 -6
- package/modern/components/columnSelection/GridHeaderCheckbox.js +4 -5
- package/modern/components/containers/GridFooterContainer.js +11 -2
- package/modern/components/containers/GridRootStyles.js +36 -1
- package/modern/components/containers/GridToolbarContainer.js +12 -2
- package/modern/components/menu/GridMenu.js +1 -0
- package/modern/components/panel/GridPanel.js +1 -0
- package/modern/components/panel/GridPanelContent.js +13 -2
- package/modern/components/panel/GridPanelFooter.js +13 -2
- package/modern/components/panel/GridPanelHeader.js +13 -2
- package/modern/components/panel/filterPanel/GridFilterForm.js +10 -6
- package/modern/components/panel/filterPanel/GridFilterInputBoolean.js +11 -6
- package/modern/components/panel/filterPanel/GridFilterInputSingleSelect.js +20 -13
- package/modern/components/panel/filterPanel/GridFilterInputValue.js +20 -13
- package/modern/components/toolbar/GridToolbar.js +30 -7
- package/modern/components/toolbar/GridToolbarDensitySelector.js +1 -1
- package/modern/components/toolbar/GridToolbarExport.js +15 -20
- package/modern/components/toolbar/GridToolbarQuickFilter.js +86 -0
- package/modern/components/toolbar/index.js +3 -2
- package/modern/components/virtualization/GridVirtualScroller.js +2 -0
- package/modern/components/virtualization/GridVirtualScrollerContent.js +1 -3
- package/modern/constants/defaultGridSlotsComponents.js +3 -2
- package/modern/constants/gridClasses.js +1 -1
- package/modern/constants/gridDetailPanelToggleField.js +2 -0
- package/modern/constants/localeTextConstants.js +8 -1
- package/modern/hooks/core/pipeProcessing/index.js +2 -1
- package/modern/hooks/core/pipeProcessing/useGridPipeProcessing.js +53 -19
- package/modern/hooks/core/pipeProcessing/useGridRegisterPipeApplier.js +27 -0
- package/modern/hooks/core/pipeProcessing/useGridRegisterPipeProcessor.js +0 -4
- package/modern/hooks/core/strategyProcessing/useGridStrategyProcessing.js +6 -7
- package/modern/hooks/core/useGridApiInitialization.js +3 -3
- package/modern/hooks/core/useGridErrorHandler.js +1 -2
- package/modern/hooks/core/useGridStateInitialization.js +1 -2
- package/modern/hooks/features/columnHeaders/useGridColumnHeaders.js +81 -16
- package/modern/hooks/features/columnMenu/useGridColumnMenu.js +3 -3
- package/modern/hooks/features/columns/gridColumnsUtils.js +61 -8
- package/modern/hooks/features/columns/useGridColumnSpanning.js +106 -0
- package/modern/hooks/features/columns/useGridColumns.js +30 -25
- package/modern/hooks/features/dimensions/useGridDimensions.js +10 -11
- package/modern/hooks/features/editRows/useGridCellEditing.new.js +149 -42
- package/modern/hooks/features/editRows/useGridCellEditing.old.js +20 -21
- package/modern/hooks/features/editRows/useGridEditing.new.js +7 -3
- package/modern/hooks/features/editRows/useGridEditing.old.js +4 -5
- package/modern/hooks/features/editRows/useGridRowEditing.new.js +143 -57
- package/modern/hooks/features/editRows/useGridRowEditing.old.js +21 -22
- package/modern/hooks/features/events/useGridEvents.js +17 -18
- package/modern/hooks/features/export/serializers/csvSerializer.js +5 -5
- package/modern/hooks/features/export/useGridCsvExport.js +21 -16
- package/modern/hooks/features/export/useGridPrintExport.js +20 -0
- package/modern/hooks/features/export/utils.js +13 -0
- package/modern/hooks/features/filter/gridFilterState.js +3 -1
- package/modern/hooks/features/filter/gridFilterUtils.js +80 -2
- package/modern/hooks/features/filter/useGridFilter.js +32 -15
- package/modern/hooks/features/focus/useGridFocus.js +48 -42
- package/modern/hooks/features/keyboardNavigation/useGridKeyboardNavigation.js +41 -12
- package/modern/hooks/features/pagination/useGridPage.js +3 -4
- package/modern/hooks/features/pagination/useGridPageSize.js +2 -3
- package/modern/hooks/features/preferencesPanel/useGridPreferencesPanel.js +4 -6
- package/modern/hooks/features/rows/gridRowsSelector.js +2 -0
- package/modern/hooks/features/rows/gridRowsUtils.js +23 -1
- package/modern/hooks/features/rows/useGridRows.js +121 -61
- package/modern/hooks/features/rows/useGridRowsMeta.js +6 -13
- package/modern/hooks/features/rows/useGridRowsPreProcessors.js +2 -0
- package/modern/hooks/features/scroll/useGridScroll.js +29 -4
- package/modern/hooks/features/selection/useGridSelection.js +15 -11
- package/modern/hooks/features/sorting/useGridSorting.js +17 -18
- package/modern/hooks/features/virtualization/useGridVirtualScroller.js +68 -28
- package/modern/hooks/utils/useGridApiEventHandler.js +20 -9
- package/modern/hooks/utils/useGridNativeEventListener.js +1 -2
- package/modern/hooks/utils/useGridSelector.js +1 -1
- package/modern/index.js +1 -1
- package/modern/internals/index.js +6 -2
- package/modern/locales/arSD.js +8 -1
- package/modern/locales/bgBG.js +8 -1
- package/modern/locales/csCZ.js +7 -0
- package/modern/locales/daDK.js +8 -1
- package/modern/locales/deDE.js +10 -3
- package/modern/locales/elGR.js +7 -0
- package/modern/locales/esES.js +7 -0
- package/modern/locales/faIR.js +8 -1
- package/modern/locales/fiFI.js +7 -0
- package/modern/locales/frFR.js +7 -0
- package/modern/locales/heIL.js +8 -1
- package/modern/locales/huHU.js +115 -0
- package/modern/locales/index.js +1 -0
- package/modern/locales/itIT.js +7 -0
- package/modern/locales/jaJP.js +7 -0
- package/modern/locales/koKR.js +7 -0
- package/modern/locales/nlNL.js +7 -0
- package/modern/locales/plPL.js +8 -1
- package/modern/locales/ptBR.js +8 -1
- package/modern/locales/ruRU.js +7 -0
- package/modern/locales/skSK.js +7 -0
- package/modern/locales/trTR.js +8 -1
- package/modern/locales/ukUA.js +7 -0
- package/modern/locales/viVN.js +7 -0
- package/modern/locales/zhCN.js +7 -0
- package/modern/models/api/gridColumnSpanning.js +1 -0
- package/modern/models/events/gridEvents.js +10 -3
- package/modern/models/gridColumnSpanning.js +1 -0
- package/modern/models/index.js +4 -3
- package/modern/utils/createSelector.js +20 -2
- package/modern/utils/exportAs.js +1 -1
- package/node/DataGrid/DataGrid.js +36 -2
- package/node/DataGrid/useDataGridComponent.js +4 -1
- package/node/DataGrid/useDataGridProps.js +2 -1
- package/node/colDef/gridActionsColDef.js +2 -1
- package/node/colDef/gridBooleanColDef.js +2 -1
- package/node/colDef/gridCheckboxSelectionColDef.js +1 -0
- package/node/colDef/gridDateColDef.js +4 -2
- package/node/colDef/gridNumericColDef.js +2 -1
- package/node/colDef/gridNumericOperators.js +15 -1
- package/node/colDef/gridSingleSelectColDef.js +2 -1
- package/node/colDef/gridSingleSelectOperators.js +56 -1
- package/node/colDef/gridStringColDef.js +2 -1
- package/node/colDef/gridStringOperators.js +16 -1
- package/node/components/GridFooter.js +10 -1
- package/node/components/GridRow.js +59 -29
- package/node/components/GridRowCount.js +1 -0
- package/node/components/GridScrollArea.js +3 -5
- package/node/components/GridSelectedRowCount.js +2 -1
- package/node/components/base/GridBody.js +1 -3
- package/node/components/base/GridOverlays.js +4 -5
- package/node/components/cell/GridActionsCell.js +181 -21
- package/node/components/cell/GridActionsCellItem.js +7 -4
- package/node/components/cell/GridCell.js +35 -14
- package/node/components/cell/GridEditBooleanCell.js +100 -5
- package/node/components/cell/GridEditDateCell.js +98 -4
- package/node/components/cell/GridEditInputCell.js +30 -6
- package/node/components/cell/GridEditSingleSelectCell.js +50 -18
- package/node/components/cell/index.js +26 -0
- package/node/components/columnHeaders/GridColumnHeaderItem.js +19 -24
- package/node/components/columnHeaders/GridColumnHeaders.js +1 -1
- package/node/components/columnSelection/GridCellCheckboxRenderer.js +22 -7
- package/node/components/columnSelection/GridHeaderCheckbox.js +4 -6
- package/node/components/containers/GridFooterContainer.js +10 -1
- package/node/components/containers/GridRootStyles.js +36 -1
- package/node/components/containers/GridToolbarContainer.js +11 -1
- package/node/components/menu/GridMenu.js +1 -0
- package/node/components/panel/GridPanel.js +1 -0
- package/node/components/panel/GridPanelContent.js +11 -1
- package/node/components/panel/GridPanelFooter.js +11 -1
- package/node/components/panel/GridPanelHeader.js +11 -1
- package/node/components/panel/filterPanel/GridFilterForm.js +15 -10
- package/node/components/panel/filterPanel/GridFilterInputBoolean.js +14 -8
- package/node/components/panel/filterPanel/GridFilterInputSingleSelect.js +23 -15
- package/node/components/panel/filterPanel/GridFilterInputValue.js +23 -15
- package/node/components/toolbar/GridToolbar.js +32 -7
- package/node/components/toolbar/GridToolbarDensitySelector.js +1 -1
- package/node/components/toolbar/GridToolbarExport.js +14 -19
- package/node/components/toolbar/GridToolbarQuickFilter.js +111 -0
- package/node/components/toolbar/index.js +42 -11
- package/node/components/virtualization/GridVirtualScroller.js +2 -0
- package/node/components/virtualization/GridVirtualScrollerContent.js +1 -3
- package/node/constants/defaultGridSlotsComponents.js +2 -1
- package/node/constants/gridClasses.js +1 -1
- package/node/constants/gridDetailPanelToggleField.js +9 -0
- package/node/constants/localeTextConstants.js +8 -1
- package/node/hooks/core/pipeProcessing/index.js +13 -0
- package/node/hooks/core/pipeProcessing/useGridPipeProcessing.js +51 -20
- package/node/hooks/core/pipeProcessing/useGridRegisterPipeApplier.js +42 -0
- package/node/hooks/core/pipeProcessing/useGridRegisterPipeProcessor.js +0 -3
- package/node/hooks/core/strategyProcessing/useGridStrategyProcessing.js +6 -8
- package/node/hooks/core/useGridApiInitialization.js +3 -4
- package/node/hooks/core/useGridErrorHandler.js +1 -3
- package/node/hooks/core/useGridStateInitialization.js +1 -3
- package/node/hooks/features/columnHeaders/useGridColumnHeaders.js +85 -17
- package/node/hooks/features/columnMenu/useGridColumnMenu.js +3 -4
- package/node/hooks/features/columns/gridColumnsUtils.js +65 -9
- package/node/hooks/features/columns/useGridColumnSpanning.js +128 -0
- package/node/hooks/features/columns/useGridColumns.js +29 -25
- package/node/hooks/features/dimensions/useGridDimensions.js +10 -12
- package/node/hooks/features/editRows/useGridCellEditing.new.js +151 -42
- package/node/hooks/features/editRows/useGridCellEditing.old.js +20 -22
- package/node/hooks/features/editRows/useGridEditing.new.js +6 -2
- package/node/hooks/features/editRows/useGridEditing.old.js +4 -6
- package/node/hooks/features/editRows/useGridRowEditing.new.js +143 -57
- package/node/hooks/features/editRows/useGridRowEditing.old.js +21 -23
- package/node/hooks/features/events/useGridEvents.js +17 -19
- package/node/hooks/features/export/serializers/csvSerializer.js +5 -5
- package/node/hooks/features/export/useGridCsvExport.js +26 -17
- package/node/hooks/features/export/useGridPrintExport.js +25 -0
- package/node/hooks/features/export/utils.js +19 -2
- package/node/hooks/features/filter/gridFilterState.js +3 -1
- package/node/hooks/features/filter/gridFilterUtils.js +92 -3
- package/node/hooks/features/filter/useGridFilter.js +33 -16
- package/node/hooks/features/focus/useGridFocus.js +48 -43
- package/node/hooks/features/keyboardNavigation/useGridKeyboardNavigation.js +44 -13
- package/node/hooks/features/pagination/useGridPage.js +3 -5
- package/node/hooks/features/pagination/useGridPageSize.js +2 -4
- package/node/hooks/features/preferencesPanel/useGridPreferencesPanel.js +4 -8
- package/node/hooks/features/rows/gridRowsSelector.js +5 -1
- package/node/hooks/features/rows/gridRowsUtils.js +29 -1
- package/node/hooks/features/rows/useGridRows.js +122 -61
- package/node/hooks/features/rows/useGridRowsMeta.js +6 -14
- package/node/hooks/features/rows/useGridRowsPreProcessors.js +2 -0
- package/node/hooks/features/scroll/useGridScroll.js +32 -3
- package/node/hooks/features/selection/useGridSelection.js +16 -12
- package/node/hooks/features/sorting/useGridSorting.js +17 -19
- package/node/hooks/features/virtualization/useGridVirtualScroller.js +73 -33
- package/node/hooks/utils/useGridApiEventHandler.js +22 -10
- package/node/hooks/utils/useGridNativeEventListener.js +1 -3
- package/node/hooks/utils/useGridSelector.js +1 -1
- package/node/index.js +1 -1
- package/node/internals/index.js +47 -3
- package/node/locales/arSD.js +8 -1
- package/node/locales/bgBG.js +8 -1
- package/node/locales/csCZ.js +7 -0
- package/node/locales/daDK.js +8 -1
- package/node/locales/deDE.js +10 -3
- package/node/locales/elGR.js +7 -0
- package/node/locales/esES.js +7 -0
- package/node/locales/faIR.js +8 -1
- package/node/locales/fiFI.js +7 -0
- package/node/locales/frFR.js +7 -0
- package/node/locales/heIL.js +8 -1
- package/node/locales/huHU.js +125 -0
- package/node/locales/index.js +13 -0
- package/node/locales/itIT.js +7 -0
- package/node/locales/jaJP.js +7 -0
- package/node/locales/koKR.js +7 -0
- package/node/locales/nlNL.js +7 -0
- package/node/locales/plPL.js +8 -1
- package/node/locales/ptBR.js +8 -1
- package/node/locales/ruRU.js +7 -0
- package/node/locales/skSK.js +7 -0
- package/node/locales/trTR.js +8 -1
- package/node/locales/ukUA.js +7 -0
- package/node/locales/viVN.js +7 -0
- package/node/locales/zhCN.js +7 -0
- package/node/models/api/gridColumnSpanning.js +5 -0
- package/node/models/events/gridEvents.js +10 -3
- package/node/models/gridColumnSpanning.js +5 -0
- package/node/models/index.js +0 -13
- package/node/utils/createSelector.js +25 -4
- package/node/utils/exportAs.js +1 -1
- package/package.json +4 -4
- package/utils/createSelector.d.ts +2 -1
- package/utils/createSelector.js +20 -2
- package/utils/domUtils.d.ts +2 -2
- package/utils/exportAs.d.ts +2 -2
- package/utils/exportAs.js +1 -1
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
3
|
-
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "className", "getValue", "hasFocus", "isValidating", "isProcessingProps", "error"];
|
|
3
|
+
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "className", "getValue", "hasFocus", "isValidating", "isProcessingProps", "error", "onValueChange"];
|
|
4
4
|
import * as React from 'react';
|
|
5
|
+
import PropTypes from 'prop-types';
|
|
5
6
|
import clsx from 'clsx';
|
|
6
7
|
import { unstable_composeClasses as composeClasses } from '@mui/material';
|
|
7
8
|
import { unstable_useId as useId, unstable_useEnhancedEffect as useEnhancedEffect } from '@mui/material/utils';
|
|
@@ -19,7 +20,7 @@ const useUtilityClasses = ownerState => {
|
|
|
19
20
|
return composeClasses(slots, getDataGridUtilityClass, classes);
|
|
20
21
|
};
|
|
21
22
|
|
|
22
|
-
|
|
23
|
+
function GridEditBooleanCell(props) {
|
|
23
24
|
var _rootProps$components;
|
|
24
25
|
|
|
25
26
|
const {
|
|
@@ -28,7 +29,8 @@ export function GridEditBooleanCell(props) {
|
|
|
28
29
|
api,
|
|
29
30
|
field,
|
|
30
31
|
className,
|
|
31
|
-
hasFocus
|
|
32
|
+
hasFocus,
|
|
33
|
+
onValueChange
|
|
32
34
|
} = props,
|
|
33
35
|
other = _objectWithoutPropertiesLoose(props, _excluded);
|
|
34
36
|
|
|
@@ -40,15 +42,20 @@ export function GridEditBooleanCell(props) {
|
|
|
40
42
|
classes: rootProps.classes
|
|
41
43
|
};
|
|
42
44
|
const classes = useUtilityClasses(ownerState);
|
|
43
|
-
const handleChange = React.useCallback(event => {
|
|
45
|
+
const handleChange = React.useCallback(async event => {
|
|
44
46
|
const newValue = event.target.checked;
|
|
47
|
+
|
|
48
|
+
if (onValueChange) {
|
|
49
|
+
await onValueChange(event, newValue);
|
|
50
|
+
}
|
|
51
|
+
|
|
45
52
|
setValueState(newValue);
|
|
46
|
-
api.setEditCellValue({
|
|
53
|
+
await api.setEditCellValue({
|
|
47
54
|
id: idProp,
|
|
48
55
|
field,
|
|
49
56
|
value: newValue
|
|
50
57
|
}, event);
|
|
51
|
-
}, [api, field, idProp]);
|
|
58
|
+
}, [api, field, idProp, onValueChange]);
|
|
52
59
|
React.useEffect(() => {
|
|
53
60
|
setValueState(value);
|
|
54
61
|
}, [value]);
|
|
@@ -70,4 +77,92 @@ export function GridEditBooleanCell(props) {
|
|
|
70
77
|
}, (_rootProps$components = rootProps.componentsProps) == null ? void 0 : _rootProps$components.baseCheckbox))
|
|
71
78
|
}));
|
|
72
79
|
}
|
|
80
|
+
|
|
81
|
+
process.env.NODE_ENV !== "production" ? GridEditBooleanCell.propTypes = {
|
|
82
|
+
// ----------------------------- Warning --------------------------------
|
|
83
|
+
// | These PropTypes are generated from the TypeScript type definitions |
|
|
84
|
+
// | To update them edit the TypeScript types and run "yarn proptypes" |
|
|
85
|
+
// ----------------------------------------------------------------------
|
|
86
|
+
|
|
87
|
+
/**
|
|
88
|
+
* GridApi that let you manipulate the grid.
|
|
89
|
+
* @deprecated Use the `apiRef` returned by `useGridApiContext` or `useGridApiRef` (only available in `@mui/x-data-grid-pro`)
|
|
90
|
+
*/
|
|
91
|
+
api: PropTypes.any.isRequired,
|
|
92
|
+
|
|
93
|
+
/**
|
|
94
|
+
* The mode of the cell.
|
|
95
|
+
*/
|
|
96
|
+
cellMode: PropTypes.oneOf(['edit', 'view']).isRequired,
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* The column of the row that the current cell belongs to.
|
|
100
|
+
*/
|
|
101
|
+
colDef: PropTypes.object.isRequired,
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* The column field of the cell that triggered the event.
|
|
105
|
+
*/
|
|
106
|
+
field: PropTypes.string.isRequired,
|
|
107
|
+
|
|
108
|
+
/**
|
|
109
|
+
* The cell value formatted with the column valueFormatter.
|
|
110
|
+
*/
|
|
111
|
+
formattedValue: PropTypes.any,
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Get the cell value of a row and field.
|
|
115
|
+
* @param {GridRowId} id The row id.
|
|
116
|
+
* @param {string} field The field.
|
|
117
|
+
* @returns {any} The cell value.
|
|
118
|
+
* @deprecated Use `params.row` to directly access the fields you want instead.
|
|
119
|
+
*/
|
|
120
|
+
getValue: PropTypes.func.isRequired,
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* If true, the cell is the active element.
|
|
124
|
+
*/
|
|
125
|
+
hasFocus: PropTypes.bool.isRequired,
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* The grid row id.
|
|
129
|
+
*/
|
|
130
|
+
id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* If true, the cell is editable.
|
|
134
|
+
*/
|
|
135
|
+
isEditable: PropTypes.bool,
|
|
136
|
+
isProcessingProps: PropTypes.bool,
|
|
137
|
+
isValidating: PropTypes.bool,
|
|
138
|
+
|
|
139
|
+
/**
|
|
140
|
+
* Callback called when the value is changed by the user.
|
|
141
|
+
* @param {React.ChangeEvent<HTMLInputElement>} event The event source of the callback.
|
|
142
|
+
* @param {boolean} newValue The value that is going to be passed to `apiRef.current.setEditCellValue`.
|
|
143
|
+
* @returns {Promise<void> | void} A promise to be awaited before calling `apiRef.current.setEditCellValue`
|
|
144
|
+
*/
|
|
145
|
+
onValueChange: PropTypes.func,
|
|
146
|
+
|
|
147
|
+
/**
|
|
148
|
+
* The row model of the row that the current cell belongs to.
|
|
149
|
+
*/
|
|
150
|
+
row: PropTypes.object.isRequired,
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* The node of the row that the current cell belongs to.
|
|
154
|
+
*/
|
|
155
|
+
rowNode: PropTypes.object.isRequired,
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* the tabIndex value.
|
|
159
|
+
*/
|
|
160
|
+
tabIndex: PropTypes.oneOf([-1, 0]).isRequired,
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* The cell value, but if the column has valueGetter, use getValue.
|
|
164
|
+
*/
|
|
165
|
+
value: PropTypes.any
|
|
166
|
+
} : void 0;
|
|
167
|
+
export { GridEditBooleanCell };
|
|
73
168
|
export const renderEditBooleanCell = params => /*#__PURE__*/_jsx(GridEditBooleanCell, _extends({}, params));
|
|
@@ -1,6 +1,18 @@
|
|
|
1
|
-
|
|
1
|
+
import * as React from 'react';
|
|
2
2
|
import { InputBaseProps } from '@mui/material/InputBase';
|
|
3
3
|
import { GridRenderEditCellParams } from '../../models/params/gridCellParams';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
4
|
+
export interface GridEditDateCellProps extends GridRenderEditCellParams, Omit<InputBaseProps, 'id' | 'value' | 'tabIndex'> {
|
|
5
|
+
/**
|
|
6
|
+
* Callback called when the value is changed by the user.
|
|
7
|
+
* @param {React.ChangeEvent<HTMLInputElement>} event The event source of the callback.
|
|
8
|
+
* @param {Date | null} newValue The value that is going to be passed to `apiRef.current.setEditCellValue`.
|
|
9
|
+
* @returns {Promise<void> | void} A promise to be awaited before calling `apiRef.current.setEditCellValue`
|
|
10
|
+
*/
|
|
11
|
+
onValueChange?: (event: React.ChangeEvent<HTMLInputElement>, newValue: Date | null) => Promise<void> | void;
|
|
12
|
+
}
|
|
13
|
+
declare function GridEditDateCell(props: GridEditDateCellProps): JSX.Element;
|
|
14
|
+
declare namespace GridEditDateCell {
|
|
15
|
+
var propTypes: any;
|
|
16
|
+
}
|
|
17
|
+
export { GridEditDateCell };
|
|
18
|
+
export declare const renderEditDateCell: (params: GridRenderEditCellParams) => JSX.Element;
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
3
|
-
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "hasFocus", "getValue", "inputProps", "isValidating", "isProcessingProps"];
|
|
3
|
+
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "hasFocus", "getValue", "inputProps", "isValidating", "isProcessingProps", "onValueChange"];
|
|
4
4
|
import * as React from 'react';
|
|
5
|
+
import PropTypes from 'prop-types';
|
|
5
6
|
import { unstable_composeClasses as composeClasses } from '@mui/material';
|
|
6
7
|
import { unstable_useEnhancedEffect as useEnhancedEffect } from '@mui/material/utils';
|
|
7
8
|
import InputBase from '@mui/material/InputBase';
|
|
@@ -19,7 +20,7 @@ const useUtilityClasses = ownerState => {
|
|
|
19
20
|
return composeClasses(slots, getDataGridUtilityClass, classes);
|
|
20
21
|
};
|
|
21
22
|
|
|
22
|
-
|
|
23
|
+
function GridEditDateCell(props) {
|
|
23
24
|
const {
|
|
24
25
|
id,
|
|
25
26
|
value: valueProp,
|
|
@@ -27,7 +28,8 @@ export function GridEditDateCell(props) {
|
|
|
27
28
|
field,
|
|
28
29
|
colDef,
|
|
29
30
|
hasFocus,
|
|
30
|
-
inputProps
|
|
31
|
+
inputProps,
|
|
32
|
+
onValueChange
|
|
31
33
|
} = props,
|
|
32
34
|
other = _objectWithoutPropertiesLoose(props, _excluded);
|
|
33
35
|
|
|
@@ -64,7 +66,7 @@ export function GridEditDateCell(props) {
|
|
|
64
66
|
classes: rootProps.classes
|
|
65
67
|
};
|
|
66
68
|
const classes = useUtilityClasses(ownerState);
|
|
67
|
-
const handleChange = React.useCallback(event => {
|
|
69
|
+
const handleChange = React.useCallback(async event => {
|
|
68
70
|
const newFormattedDate = event.target.value;
|
|
69
71
|
let newParsedDate;
|
|
70
72
|
|
|
@@ -83,6 +85,10 @@ export function GridEditDateCell(props) {
|
|
|
83
85
|
}
|
|
84
86
|
}
|
|
85
87
|
|
|
88
|
+
if (onValueChange) {
|
|
89
|
+
await onValueChange(event, newParsedDate);
|
|
90
|
+
}
|
|
91
|
+
|
|
86
92
|
setValueState({
|
|
87
93
|
parsed: newParsedDate,
|
|
88
94
|
formatted: newFormattedDate
|
|
@@ -92,7 +98,7 @@ export function GridEditDateCell(props) {
|
|
|
92
98
|
field,
|
|
93
99
|
value: newParsedDate
|
|
94
100
|
}, event);
|
|
95
|
-
}, [api, field, id]);
|
|
101
|
+
}, [api, field, id, onValueChange]);
|
|
96
102
|
React.useEffect(() => {
|
|
97
103
|
setValueState(state => {
|
|
98
104
|
var _valueTransformed$par, _state$parsed;
|
|
@@ -121,4 +127,92 @@ export function GridEditDateCell(props) {
|
|
|
121
127
|
onChange: handleChange
|
|
122
128
|
}, other));
|
|
123
129
|
}
|
|
130
|
+
|
|
131
|
+
process.env.NODE_ENV !== "production" ? GridEditDateCell.propTypes = {
|
|
132
|
+
// ----------------------------- Warning --------------------------------
|
|
133
|
+
// | These PropTypes are generated from the TypeScript type definitions |
|
|
134
|
+
// | To update them edit the TypeScript types and run "yarn proptypes" |
|
|
135
|
+
// ----------------------------------------------------------------------
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* GridApi that let you manipulate the grid.
|
|
139
|
+
* @deprecated Use the `apiRef` returned by `useGridApiContext` or `useGridApiRef` (only available in `@mui/x-data-grid-pro`)
|
|
140
|
+
*/
|
|
141
|
+
api: PropTypes.any.isRequired,
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* The mode of the cell.
|
|
145
|
+
*/
|
|
146
|
+
cellMode: PropTypes.oneOf(['edit', 'view']).isRequired,
|
|
147
|
+
|
|
148
|
+
/**
|
|
149
|
+
* The column of the row that the current cell belongs to.
|
|
150
|
+
*/
|
|
151
|
+
colDef: PropTypes.object.isRequired,
|
|
152
|
+
|
|
153
|
+
/**
|
|
154
|
+
* The column field of the cell that triggered the event.
|
|
155
|
+
*/
|
|
156
|
+
field: PropTypes.string.isRequired,
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* The cell value formatted with the column valueFormatter.
|
|
160
|
+
*/
|
|
161
|
+
formattedValue: PropTypes.any,
|
|
162
|
+
|
|
163
|
+
/**
|
|
164
|
+
* Get the cell value of a row and field.
|
|
165
|
+
* @param {GridRowId} id The row id.
|
|
166
|
+
* @param {string} field The field.
|
|
167
|
+
* @returns {any} The cell value.
|
|
168
|
+
* @deprecated Use `params.row` to directly access the fields you want instead.
|
|
169
|
+
*/
|
|
170
|
+
getValue: PropTypes.func.isRequired,
|
|
171
|
+
|
|
172
|
+
/**
|
|
173
|
+
* If true, the cell is the active element.
|
|
174
|
+
*/
|
|
175
|
+
hasFocus: PropTypes.bool.isRequired,
|
|
176
|
+
|
|
177
|
+
/**
|
|
178
|
+
* The grid row id.
|
|
179
|
+
*/
|
|
180
|
+
id: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired,
|
|
181
|
+
|
|
182
|
+
/**
|
|
183
|
+
* If true, the cell is editable.
|
|
184
|
+
*/
|
|
185
|
+
isEditable: PropTypes.bool,
|
|
186
|
+
isProcessingProps: PropTypes.bool,
|
|
187
|
+
isValidating: PropTypes.bool,
|
|
188
|
+
|
|
189
|
+
/**
|
|
190
|
+
* Callback called when the value is changed by the user.
|
|
191
|
+
* @param {React.ChangeEvent<HTMLInputElement>} event The event source of the callback.
|
|
192
|
+
* @param {Date | null} newValue The value that is going to be passed to `apiRef.current.setEditCellValue`.
|
|
193
|
+
* @returns {Promise<void> | void} A promise to be awaited before calling `apiRef.current.setEditCellValue`
|
|
194
|
+
*/
|
|
195
|
+
onValueChange: PropTypes.func,
|
|
196
|
+
|
|
197
|
+
/**
|
|
198
|
+
* The row model of the row that the current cell belongs to.
|
|
199
|
+
*/
|
|
200
|
+
row: PropTypes.object.isRequired,
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
* The node of the row that the current cell belongs to.
|
|
204
|
+
*/
|
|
205
|
+
rowNode: PropTypes.object.isRequired,
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* the tabIndex value.
|
|
209
|
+
*/
|
|
210
|
+
tabIndex: PropTypes.oneOf([-1, 0]).isRequired,
|
|
211
|
+
|
|
212
|
+
/**
|
|
213
|
+
* The cell value, but if the column has valueGetter, use getValue.
|
|
214
|
+
*/
|
|
215
|
+
value: PropTypes.any
|
|
216
|
+
} : void 0;
|
|
217
|
+
export { GridEditDateCell };
|
|
124
218
|
export const renderEditDateCell = params => /*#__PURE__*/_jsx(GridEditDateCell, _extends({}, params));
|
|
@@ -1,13 +1,19 @@
|
|
|
1
|
-
|
|
1
|
+
import * as React from 'react';
|
|
2
2
|
import { InputBaseProps } from '@mui/material/InputBase';
|
|
3
3
|
import { GridRenderEditCellParams } from '../../models/params/gridCellParams';
|
|
4
|
-
|
|
5
|
-
interface GridEditInputCellProps {
|
|
4
|
+
export interface GridEditInputCellProps extends GridRenderEditCellParams, Omit<InputBaseProps, 'id' | 'value' | 'tabIndex'> {
|
|
6
5
|
debounceMs?: number;
|
|
6
|
+
/**
|
|
7
|
+
* Callback called when the value is changed by the user.
|
|
8
|
+
* @param {React.ChangeEvent<HTMLInputElement>} event The event source of the callback.
|
|
9
|
+
* @param {Date | null} newValue The value that is going to be passed to `apiRef.current.setEditCellValue`.
|
|
10
|
+
* @returns {Promise<void> | void} A promise to be awaited before calling `apiRef.current.setEditCellValue`
|
|
11
|
+
*/
|
|
12
|
+
onValueChange?: (event: React.ChangeEvent<HTMLInputElement>, newValue: string) => Promise<void> | void;
|
|
7
13
|
}
|
|
8
|
-
declare function GridEditInputCell(props: GridEditInputCellProps
|
|
14
|
+
declare function GridEditInputCell(props: GridEditInputCellProps): JSX.Element;
|
|
9
15
|
declare namespace GridEditInputCell {
|
|
10
16
|
var propTypes: any;
|
|
11
17
|
}
|
|
12
18
|
export { GridEditInputCell };
|
|
13
|
-
export declare const renderEditInputCell:
|
|
19
|
+
export declare const renderEditInputCell: (params: GridEditInputCellProps) => JSX.Element;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
2
2
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
3
|
-
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "hasFocus", "getValue", "isValidating", "debounceMs", "isProcessingProps"];
|
|
3
|
+
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "hasFocus", "getValue", "isValidating", "debounceMs", "isProcessingProps", "onValueChange"];
|
|
4
4
|
import * as React from 'react';
|
|
5
5
|
import PropTypes from 'prop-types';
|
|
6
6
|
import { unstable_composeClasses as composeClasses } from '@mui/material';
|
|
@@ -50,7 +50,8 @@ function GridEditInputCell(props) {
|
|
|
50
50
|
colDef,
|
|
51
51
|
hasFocus,
|
|
52
52
|
debounceMs = (_rootProps$experiment = rootProps.experimentalFeatures) != null && _rootProps$experiment.newEditingApi ? 200 : SUBMIT_FILTER_STROKE_TIME,
|
|
53
|
-
isProcessingProps
|
|
53
|
+
isProcessingProps,
|
|
54
|
+
onValueChange
|
|
54
55
|
} = props,
|
|
55
56
|
other = _objectWithoutPropertiesLoose(props, _excluded);
|
|
56
57
|
|
|
@@ -60,8 +61,13 @@ function GridEditInputCell(props) {
|
|
|
60
61
|
classes: rootProps.classes
|
|
61
62
|
};
|
|
62
63
|
const classes = useUtilityClasses(ownerState);
|
|
63
|
-
const handleChange = React.useCallback(event => {
|
|
64
|
+
const handleChange = React.useCallback(async event => {
|
|
64
65
|
const newValue = event.target.value;
|
|
66
|
+
|
|
67
|
+
if (onValueChange) {
|
|
68
|
+
await onValueChange(event, newValue);
|
|
69
|
+
}
|
|
70
|
+
|
|
65
71
|
setValueState(newValue);
|
|
66
72
|
api.setEditCellValue({
|
|
67
73
|
id,
|
|
@@ -69,7 +75,7 @@ function GridEditInputCell(props) {
|
|
|
69
75
|
value: newValue,
|
|
70
76
|
debounceMs
|
|
71
77
|
}, event);
|
|
72
|
-
}, [api, debounceMs, field, id]);
|
|
78
|
+
}, [api, debounceMs, field, id, onValueChange]);
|
|
73
79
|
React.useEffect(() => {
|
|
74
80
|
setValueState(value);
|
|
75
81
|
}, [value]);
|
|
@@ -120,7 +126,7 @@ process.env.NODE_ENV !== "production" ? GridEditInputCell.propTypes = {
|
|
|
120
126
|
/**
|
|
121
127
|
* The cell value formatted with the column valueFormatter.
|
|
122
128
|
*/
|
|
123
|
-
formattedValue: PropTypes.any
|
|
129
|
+
formattedValue: PropTypes.any,
|
|
124
130
|
|
|
125
131
|
/**
|
|
126
132
|
* Get the cell value of a row and field.
|
|
@@ -148,6 +154,14 @@ process.env.NODE_ENV !== "production" ? GridEditInputCell.propTypes = {
|
|
|
148
154
|
isProcessingProps: PropTypes.bool,
|
|
149
155
|
isValidating: PropTypes.bool,
|
|
150
156
|
|
|
157
|
+
/**
|
|
158
|
+
* Callback called when the value is changed by the user.
|
|
159
|
+
* @param {React.ChangeEvent<HTMLInputElement>} event The event source of the callback.
|
|
160
|
+
* @param {Date | null} newValue The value that is going to be passed to `apiRef.current.setEditCellValue`.
|
|
161
|
+
* @returns {Promise<void> | void} A promise to be awaited before calling `apiRef.current.setEditCellValue`
|
|
162
|
+
*/
|
|
163
|
+
onValueChange: PropTypes.func,
|
|
164
|
+
|
|
151
165
|
/**
|
|
152
166
|
* The row model of the row that the current cell belongs to.
|
|
153
167
|
*/
|
|
@@ -156,7 +170,17 @@ process.env.NODE_ENV !== "production" ? GridEditInputCell.propTypes = {
|
|
|
156
170
|
/**
|
|
157
171
|
* The node of the row that the current cell belongs to.
|
|
158
172
|
*/
|
|
159
|
-
rowNode: PropTypes.object.isRequired
|
|
173
|
+
rowNode: PropTypes.object.isRequired,
|
|
174
|
+
|
|
175
|
+
/**
|
|
176
|
+
* the tabIndex value.
|
|
177
|
+
*/
|
|
178
|
+
tabIndex: PropTypes.oneOf([-1, 0]).isRequired,
|
|
179
|
+
|
|
180
|
+
/**
|
|
181
|
+
* The cell value, but if the column has valueGetter, use getValue.
|
|
182
|
+
*/
|
|
183
|
+
value: PropTypes.any
|
|
160
184
|
} : void 0;
|
|
161
185
|
export { GridEditInputCell };
|
|
162
186
|
export const renderEditInputCell = params => /*#__PURE__*/_jsx(GridEditInputCell, _extends({}, params));
|
|
@@ -1,10 +1,18 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
import { SelectProps } from '@mui/material/Select';
|
|
2
|
+
import { SelectProps, SelectChangeEvent } from '@mui/material/Select';
|
|
3
3
|
import { GridRenderEditCellParams } from '../../models/params/gridCellParams';
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
export interface GridEditSingleSelectCellProps extends GridRenderEditCellParams, Omit<SelectProps, 'id' | 'tabIndex' | 'value'> {
|
|
5
|
+
/**
|
|
6
|
+
* Callback called when the value is changed by the user.
|
|
7
|
+
* @param {SelectChangeEvent<any>} event The event source of the callback.
|
|
8
|
+
* @param {any} newValue The value that is going to be passed to `apiRef.current.setEditCellValue`.
|
|
9
|
+
* @returns {Promise<void> | void} A promise to be awaited before calling `apiRef.current.setEditCellValue`
|
|
10
|
+
*/
|
|
11
|
+
onValueChange?: (event: SelectChangeEvent<any>, newValue: any) => Promise<void> | void;
|
|
12
|
+
}
|
|
13
|
+
declare function GridEditSingleSelectCell(props: GridEditSingleSelectCellProps): JSX.Element;
|
|
6
14
|
declare namespace GridEditSingleSelectCell {
|
|
7
15
|
var propTypes: any;
|
|
8
16
|
}
|
|
9
17
|
export { GridEditSingleSelectCell };
|
|
10
|
-
export declare const renderEditSingleSelectCell:
|
|
18
|
+
export declare const renderEditSingleSelectCell: (params: GridEditSingleSelectCellProps) => JSX.Element;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
|
|
3
|
-
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "className", "getValue", "hasFocus", "isValidating", "isProcessingProps", "error"];
|
|
3
|
+
const _excluded = ["id", "value", "formattedValue", "api", "field", "row", "rowNode", "colDef", "cellMode", "isEditable", "tabIndex", "className", "getValue", "hasFocus", "isValidating", "isProcessingProps", "error", "onValueChange"];
|
|
4
4
|
import * as React from 'react';
|
|
5
5
|
import PropTypes from 'prop-types';
|
|
6
6
|
import { unstable_useEnhancedEffect as useEnhancedEffect } from '@mui/material/utils';
|
|
@@ -8,19 +8,22 @@ import MenuItem from '@mui/material/MenuItem';
|
|
|
8
8
|
import { isEscapeKey } from '../../utils/keyboardUtils';
|
|
9
9
|
import { useGridRootProps } from '../../hooks/utils/useGridRootProps';
|
|
10
10
|
import { GridEditModes } from '../../models/gridEditRowModel';
|
|
11
|
-
import {
|
|
11
|
+
import { getValueFromValueOptions } from '../panel/filterPanel/filterPanelUtils';
|
|
12
12
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
13
13
|
|
|
14
|
-
const renderSingleSelectOptions = option =>
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
14
|
+
const renderSingleSelectOptions = (option, OptionComponent) => {
|
|
15
|
+
const isOptionTypeObject = typeof option === 'object';
|
|
16
|
+
const key = isOptionTypeObject ? option.value : option;
|
|
17
|
+
const value = isOptionTypeObject ? option.value : option;
|
|
18
|
+
const content = isOptionTypeObject ? option.label : option;
|
|
19
|
+
return /*#__PURE__*/_jsx(OptionComponent, {
|
|
20
|
+
value: value,
|
|
21
|
+
children: content
|
|
22
|
+
}, key);
|
|
23
|
+
};
|
|
21
24
|
|
|
22
25
|
function GridEditSingleSelectCell(props) {
|
|
23
|
-
var _rootProps$components;
|
|
26
|
+
var _rootProps$components, _baseSelectProps$nati, _rootProps$components2;
|
|
24
27
|
|
|
25
28
|
const {
|
|
26
29
|
id,
|
|
@@ -30,7 +33,8 @@ function GridEditSingleSelectCell(props) {
|
|
|
30
33
|
row,
|
|
31
34
|
colDef,
|
|
32
35
|
hasFocus,
|
|
33
|
-
error
|
|
36
|
+
error,
|
|
37
|
+
onValueChange
|
|
34
38
|
} = props,
|
|
35
39
|
other = _objectWithoutPropertiesLoose(props, _excluded);
|
|
36
40
|
|
|
@@ -38,6 +42,8 @@ function GridEditSingleSelectCell(props) {
|
|
|
38
42
|
const inputRef = React.useRef();
|
|
39
43
|
const rootProps = useGridRootProps();
|
|
40
44
|
const [open, setOpen] = React.useState(rootProps.editMode === 'cell');
|
|
45
|
+
const baseSelectProps = ((_rootProps$components = rootProps.componentsProps) == null ? void 0 : _rootProps$components.baseSelect) || {};
|
|
46
|
+
const isSelectNative = (_baseSelectProps$nati = baseSelectProps.native) != null ? _baseSelectProps$nati : false;
|
|
41
47
|
let valueOptionsFormatted;
|
|
42
48
|
|
|
43
49
|
if (typeof colDef.valueOptions === 'function') {
|
|
@@ -72,11 +78,18 @@ function GridEditSingleSelectCell(props) {
|
|
|
72
78
|
var _rootProps$experiment;
|
|
73
79
|
|
|
74
80
|
setOpen(false);
|
|
75
|
-
const target = event.target;
|
|
81
|
+
const target = event.target; // NativeSelect casts the value to a string.
|
|
82
|
+
|
|
83
|
+
const formattedTargetValue = getValueFromValueOptions(target.value, valueOptionsFormatted);
|
|
84
|
+
|
|
85
|
+
if (onValueChange) {
|
|
86
|
+
await onValueChange(event, formattedTargetValue);
|
|
87
|
+
}
|
|
88
|
+
|
|
76
89
|
const isValid = await api.setEditCellValue({
|
|
77
90
|
id,
|
|
78
91
|
field,
|
|
79
|
-
value:
|
|
92
|
+
value: formattedTargetValue
|
|
80
93
|
}, event);
|
|
81
94
|
|
|
82
95
|
if ((_rootProps$experiment = rootProps.experimentalFeatures) != null && _rootProps$experiment.newEditingApi) {
|
|
@@ -99,7 +112,7 @@ function GridEditSingleSelectCell(props) {
|
|
|
99
112
|
if (event.key) {
|
|
100
113
|
// TODO v6: remove once we stop ignoring events fired from portals
|
|
101
114
|
const params = api.getCellParams(id, field);
|
|
102
|
-
api.publishEvent(
|
|
115
|
+
api.publishEvent('cellNavigationKeyDown', params, event);
|
|
103
116
|
}
|
|
104
117
|
}
|
|
105
118
|
};
|
|
@@ -145,9 +158,10 @@ function GridEditSingleSelectCell(props) {
|
|
|
145
158
|
onClose: handleClose
|
|
146
159
|
},
|
|
147
160
|
error: error,
|
|
161
|
+
native: isSelectNative,
|
|
148
162
|
fullWidth: true
|
|
149
|
-
}, other, (_rootProps$
|
|
150
|
-
children: valueOptionsFormatted.map(renderSingleSelectOptions)
|
|
163
|
+
}, other, (_rootProps$components2 = rootProps.componentsProps) == null ? void 0 : _rootProps$components2.baseSelect, {
|
|
164
|
+
children: valueOptionsFormatted.map(valueOptions => renderSingleSelectOptions(valueOptions, isSelectNative ? 'option' : MenuItem))
|
|
151
165
|
}));
|
|
152
166
|
}
|
|
153
167
|
|
|
@@ -181,7 +195,7 @@ process.env.NODE_ENV !== "production" ? GridEditSingleSelectCell.propTypes = {
|
|
|
181
195
|
/**
|
|
182
196
|
* The cell value formatted with the column valueFormatter.
|
|
183
197
|
*/
|
|
184
|
-
formattedValue: PropTypes.any
|
|
198
|
+
formattedValue: PropTypes.any,
|
|
185
199
|
|
|
186
200
|
/**
|
|
187
201
|
* Get the cell value of a row and field.
|
|
@@ -209,6 +223,14 @@ process.env.NODE_ENV !== "production" ? GridEditSingleSelectCell.propTypes = {
|
|
|
209
223
|
isProcessingProps: PropTypes.bool,
|
|
210
224
|
isValidating: PropTypes.bool,
|
|
211
225
|
|
|
226
|
+
/**
|
|
227
|
+
* Callback called when the value is changed by the user.
|
|
228
|
+
* @param {SelectChangeEvent<any>} event The event source of the callback.
|
|
229
|
+
* @param {any} newValue The value that is going to be passed to `apiRef.current.setEditCellValue`.
|
|
230
|
+
* @returns {Promise<void> | void} A promise to be awaited before calling `apiRef.current.setEditCellValue`
|
|
231
|
+
*/
|
|
232
|
+
onValueChange: PropTypes.func,
|
|
233
|
+
|
|
212
234
|
/**
|
|
213
235
|
* The row model of the row that the current cell belongs to.
|
|
214
236
|
*/
|
|
@@ -217,7 +239,17 @@ process.env.NODE_ENV !== "production" ? GridEditSingleSelectCell.propTypes = {
|
|
|
217
239
|
/**
|
|
218
240
|
* The node of the row that the current cell belongs to.
|
|
219
241
|
*/
|
|
220
|
-
rowNode: PropTypes.object.isRequired
|
|
242
|
+
rowNode: PropTypes.object.isRequired,
|
|
243
|
+
|
|
244
|
+
/**
|
|
245
|
+
* the tabIndex value.
|
|
246
|
+
*/
|
|
247
|
+
tabIndex: PropTypes.oneOf([-1, 0]).isRequired,
|
|
248
|
+
|
|
249
|
+
/**
|
|
250
|
+
* The cell value, but if the column has valueGetter, use getValue.
|
|
251
|
+
*/
|
|
252
|
+
value: PropTypes.any
|
|
221
253
|
} : void 0;
|
|
222
254
|
export { GridEditSingleSelectCell };
|
|
223
255
|
export const renderEditSingleSelectCell = params => /*#__PURE__*/_jsx(GridEditSingleSelectCell, _extends({}, params));
|