@mui/x-data-grid-premium 8.0.0-alpha.11 → 8.0.0-alpha.13
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 +460 -1
- package/DataGridPremium/DataGrid.d.ts +1 -1
- package/DataGridPremium/DataGridPremium.d.ts +6 -6
- package/DataGridPremium/DataGridPremium.js +55 -30
- package/DataGridPremium/index.d.ts +3 -3
- package/DataGridPremium/useDataGridPremiumComponent.d.ts +3 -3
- package/DataGridPremium/useDataGridPremiumComponent.js +3 -2
- package/DataGridPremium/useDataGridPremiumProps.d.ts +2 -2
- package/DataGridPremium/useDataGridPremiumProps.js +2 -2
- package/components/GridAggregationHeader.d.ts +3 -3
- package/components/GridAggregationHeader.js +7 -11
- package/components/GridAggregationRowOverlay.d.ts +3 -0
- package/components/GridAggregationRowOverlay.js +44 -0
- package/components/GridBottomContainer.d.ts +3 -0
- package/components/GridBottomContainer.js +51 -0
- package/components/GridColumnMenuAggregationItem.d.ts +2 -2
- package/components/GridColumnMenuAggregationItem.js +36 -46
- package/components/GridColumnMenuRowGroupItem.d.ts +1 -1
- package/components/GridColumnMenuRowUngroupItem.d.ts +1 -1
- package/components/GridDataSourceGroupingCriteriaCell.d.ts +2 -2
- package/components/GridDataSourceGroupingCriteriaCell.js +8 -12
- package/components/GridExcelExportMenuItem.d.ts +3 -3
- package/components/GridFooterCell.d.ts +2 -2
- package/components/GridFooterCell.js +5 -6
- package/components/GridGroupingColumnFooterCell.d.ts +1 -1
- package/components/GridGroupingColumnFooterCell.js +2 -1
- package/components/GridGroupingColumnLeafCell.d.ts +1 -1
- package/components/GridGroupingColumnLeafCell.js +3 -9
- package/components/GridGroupingCriteriaCell.d.ts +2 -2
- package/components/GridGroupingCriteriaCell.js +3 -8
- package/components/GridPremiumColumnMenu.d.ts +26 -26
- package/components/index.d.ts +5 -5
- package/components/promptControl/GridToolbarPromptControl.d.ts +22 -22
- package/components/promptControl/GridToolbarPromptControl.js +34 -32
- package/components/promptControl/RecordButton.d.ts +9 -9
- package/components/promptControl/index.d.ts +1 -1
- package/components/reexports.d.ts +1 -1
- package/constants/dataGridPremiumDefaultSlotsComponents.d.ts +1 -1
- package/constants/dataGridPremiumDefaultSlotsComponents.js +3 -1
- package/esm/DataGridPremium/DataGrid.d.ts +8 -0
- package/esm/DataGridPremium/DataGridPremium.d.ts +16 -0
- package/esm/DataGridPremium/DataGridPremium.js +55 -30
- package/esm/DataGridPremium/index.d.ts +3 -0
- package/esm/DataGridPremium/useDataGridPremiumComponent.d.ts +4 -0
- package/esm/DataGridPremium/useDataGridPremiumComponent.js +4 -3
- package/esm/DataGridPremium/useDataGridPremiumProps.d.ts +6 -0
- package/esm/DataGridPremium/useDataGridPremiumProps.js +2 -2
- package/esm/components/GridAggregationHeader.d.ts +7 -0
- package/esm/components/GridAggregationHeader.js +7 -11
- package/esm/components/GridAggregationRowOverlay.d.ts +3 -0
- package/esm/components/GridAggregationRowOverlay.js +37 -0
- package/esm/components/GridBottomContainer.d.ts +3 -0
- package/esm/components/GridBottomContainer.js +43 -0
- package/esm/components/GridColumnMenuAggregationItem.d.ts +7 -0
- package/esm/components/GridColumnMenuAggregationItem.js +36 -46
- package/esm/components/GridColumnMenuRowGroupItem.d.ts +3 -0
- package/esm/components/GridColumnMenuRowUngroupItem.d.ts +3 -0
- package/esm/components/GridDataSourceGroupingCriteriaCell.d.ts +7 -0
- package/esm/components/GridDataSourceGroupingCriteriaCell.js +9 -13
- package/esm/components/GridExcelExportMenuItem.d.ts +9 -0
- package/esm/components/GridFooterCell.d.ts +9 -0
- package/esm/components/GridFooterCell.js +5 -6
- package/esm/components/GridGroupingColumnFooterCell.d.ts +4 -0
- package/esm/components/GridGroupingColumnFooterCell.js +2 -1
- package/esm/components/GridGroupingColumnLeafCell.d.ts +4 -0
- package/esm/components/GridGroupingColumnLeafCell.js +3 -8
- package/esm/components/GridGroupingCriteriaCell.d.ts +7 -0
- package/esm/components/GridGroupingCriteriaCell.js +3 -8
- package/esm/components/GridPremiumColumnMenu.d.ts +33 -0
- package/esm/components/index.d.ts +5 -0
- package/esm/components/promptControl/GridToolbarPromptControl.d.ts +26 -0
- package/esm/components/promptControl/GridToolbarPromptControl.js +34 -32
- package/esm/components/promptControl/RecordButton.d.ts +16 -0
- package/esm/components/promptControl/index.d.ts +1 -0
- package/esm/components/reexports.d.ts +1 -0
- package/esm/constants/dataGridPremiumDefaultSlotsComponents.d.ts +2 -0
- package/esm/constants/dataGridPremiumDefaultSlotsComponents.js +3 -1
- package/esm/hooks/features/aggregation/createAggregationLookup.d.ts +17 -0
- package/esm/hooks/features/aggregation/createAggregationLookup.js +3 -3
- package/esm/hooks/features/aggregation/gridAggregationFunctions.d.ts +8 -0
- package/esm/hooks/features/aggregation/gridAggregationInterfaces.d.ts +129 -0
- package/esm/hooks/features/aggregation/gridAggregationSelectors.d.ts +13 -0
- package/esm/hooks/features/aggregation/gridAggregationSelectors.js +2 -2
- package/esm/hooks/features/aggregation/gridAggregationUtils.d.ts +62 -0
- package/esm/hooks/features/aggregation/index.d.ts +4 -0
- package/esm/hooks/features/aggregation/useGridAggregation.d.ts +6 -0
- package/esm/hooks/features/aggregation/useGridAggregation.js +6 -6
- package/esm/hooks/features/aggregation/useGridAggregationPreProcessors.d.ts +4 -0
- package/esm/hooks/features/aggregation/useGridAggregationPreProcessors.js +6 -6
- package/esm/hooks/features/aggregation/wrapColumnWithAggregation.d.ts +81 -0
- package/esm/hooks/features/aggregation/wrapColumnWithAggregation.js +6 -5
- package/esm/hooks/features/cellSelection/gridCellSelectionInterfaces.d.ts +40 -0
- package/esm/hooks/features/cellSelection/gridCellSelectionSelector.d.ts +2 -0
- package/esm/hooks/features/cellSelection/gridCellSelectionSelector.js +2 -1
- package/esm/hooks/features/cellSelection/index.d.ts +1 -0
- package/esm/hooks/features/cellSelection/useGridCellSelection.d.ts +6 -0
- package/esm/hooks/features/cellSelection/useGridCellSelection.js +5 -6
- package/esm/hooks/features/clipboard/useGridClipboardImport.d.ts +4 -0
- package/esm/hooks/features/clipboard/useGridClipboardImport.js +5 -5
- package/esm/hooks/features/dataSource/models.d.ts +54 -0
- package/esm/hooks/features/dataSource/useGridDataSourcePremium.d.ts +4 -0
- package/esm/hooks/features/dataSource/useGridDataSourcePremium.js +13 -7
- package/esm/hooks/features/export/gridExcelExportInterface.d.ts +71 -0
- package/esm/hooks/features/export/index.d.ts +2 -0
- package/esm/hooks/features/export/index.js +1 -1
- package/esm/hooks/features/export/serializer/excelSerializer.d.ts +40 -0
- package/esm/hooks/features/export/serializer/excelSerializer.js +69 -180
- package/esm/hooks/features/export/serializer/setupExcelExportWebWorker.d.ts +2 -0
- package/esm/hooks/features/export/serializer/setupExcelExportWebWorker.js +53 -0
- package/esm/hooks/features/export/serializer/utils.d.ts +36 -0
- package/esm/hooks/features/export/serializer/utils.js +93 -0
- package/esm/hooks/features/export/useGridExcelExport.d.ts +11 -0
- package/esm/hooks/features/export/useGridExcelExport.js +11 -5
- package/esm/hooks/features/index.d.ts +5 -0
- package/esm/hooks/features/promptControl/api.d.ts +2 -0
- package/esm/hooks/features/promptControl/index.d.ts +2 -0
- package/esm/hooks/features/promptControl/types.d.ts +25 -0
- package/esm/hooks/features/rowGrouping/createGroupingColDef.d.ts +57 -0
- package/esm/hooks/features/rowGrouping/createGroupingColDef.js +5 -5
- package/esm/hooks/features/rowGrouping/gridRowGroupingInterfaces.d.ts +44 -0
- package/esm/hooks/features/rowGrouping/gridRowGroupingSelector.d.ts +3 -0
- package/esm/hooks/features/rowGrouping/gridRowGroupingSelector.js +2 -2
- package/esm/hooks/features/rowGrouping/gridRowGroupingUtils.d.ts +54 -0
- package/esm/hooks/features/rowGrouping/gridRowGroupingUtils.js +2 -2
- package/esm/hooks/features/rowGrouping/index.d.ts +3 -0
- package/esm/hooks/features/rowGrouping/useGridDataSourceRowGroupingPreProcessors.d.ts +4 -0
- package/esm/hooks/features/rowGrouping/useGridDataSourceRowGroupingPreProcessors.js +3 -3
- package/esm/hooks/features/rowGrouping/useGridRowGrouping.d.ts +11 -0
- package/esm/hooks/features/rowGrouping/useGridRowGrouping.js +4 -5
- package/esm/hooks/features/rowGrouping/useGridRowGroupingPreProcessors.d.ts +4 -0
- package/esm/hooks/features/rowGrouping/useGridRowGroupingPreProcessors.js +5 -5
- package/esm/hooks/features/rows/index.d.ts +1 -0
- package/esm/hooks/features/rows/useGridRowAriaAttributes.d.ts +1 -0
- package/esm/hooks/index.d.ts +2 -0
- package/esm/hooks/utils/index.d.ts +1 -0
- package/esm/hooks/utils/useGridApiContext.d.ts +4 -0
- package/esm/hooks/utils/useGridApiRef.d.ts +4 -0
- package/esm/hooks/utils/useGridAriaAttributes.d.ts +2 -0
- package/esm/hooks/utils/useGridPrivateApiContext.d.ts +2 -0
- package/esm/hooks/utils/useGridRootProps.d.ts +2 -0
- package/esm/hooks/utils/useKeepGroupedColumnsHidden.d.ts +12 -0
- package/esm/index.d.ts +23 -0
- package/esm/index.js +6 -5
- package/esm/locales.d.ts +1 -0
- package/esm/material/icons.d.ts +15 -0
- package/esm/material/index.d.ts +8 -0
- package/esm/models/dataGridPremiumProps.d.ts +162 -0
- package/esm/models/gridApiPremium.d.ts +14 -0
- package/esm/models/gridGroupingValueGetter.d.ts +4 -0
- package/esm/models/gridPastedValueParser.d.ts +4 -0
- package/esm/models/gridPremiumIconSlotsComponent.d.ts +28 -0
- package/esm/models/gridPremiumSlotsComponent.d.ts +7 -0
- package/esm/models/gridStatePremium.d.ts +18 -0
- package/esm/models/index.d.ts +4 -0
- package/esm/package.json +1 -0
- package/esm/setupExcelExportWebWorker.d.ts +1 -0
- package/esm/setupExcelExportWebWorker.js +1 -0
- package/esm/themeAugmentation/index.d.ts +2 -0
- package/esm/themeAugmentation/overrides.d.ts +7 -0
- package/esm/themeAugmentation/props.d.ts +15 -0
- package/esm/typeOverloads/index.d.ts +2 -0
- package/esm/typeOverloads/modules.d.ts +97 -0
- package/esm/typeOverloads/reexports.d.ts +17 -0
- package/esm/utils/releaseInfo.d.ts +1 -0
- package/esm/utils/releaseInfo.js +1 -1
- package/hooks/features/aggregation/createAggregationLookup.d.ts +16 -10
- package/hooks/features/aggregation/createAggregationLookup.js +2 -2
- package/hooks/features/aggregation/gridAggregationFunctions.d.ts +7 -7
- package/hooks/features/aggregation/gridAggregationInterfaces.d.ts +81 -82
- package/hooks/features/aggregation/gridAggregationSelectors.d.ts +3 -3
- package/hooks/features/aggregation/gridAggregationSelectors.js +1 -2
- package/hooks/features/aggregation/gridAggregationUtils.d.ts +42 -25
- package/hooks/features/aggregation/index.d.ts +4 -4
- package/hooks/features/aggregation/useGridAggregation.d.ts +3 -3
- package/hooks/features/aggregation/useGridAggregation.js +6 -6
- package/hooks/features/aggregation/useGridAggregationPreProcessors.d.ts +3 -3
- package/hooks/features/aggregation/useGridAggregationPreProcessors.js +6 -6
- package/hooks/features/aggregation/wrapColumnWithAggregation.d.ts +67 -62
- package/hooks/features/aggregation/wrapColumnWithAggregation.js +6 -5
- package/hooks/features/cellSelection/gridCellSelectionInterfaces.d.ts +34 -34
- package/hooks/features/cellSelection/gridCellSelectionSelector.d.ts +2 -2
- package/hooks/features/cellSelection/gridCellSelectionSelector.js +2 -2
- package/hooks/features/cellSelection/index.d.ts +1 -1
- package/hooks/features/cellSelection/useGridCellSelection.d.ts +3 -3
- package/hooks/features/cellSelection/useGridCellSelection.js +5 -6
- package/hooks/features/clipboard/useGridClipboardImport.d.ts +2 -2
- package/hooks/features/clipboard/useGridClipboardImport.js +4 -4
- package/hooks/features/dataSource/models.d.ts +41 -34
- package/hooks/features/dataSource/useGridDataSourcePremium.d.ts +3 -3
- package/hooks/features/dataSource/useGridDataSourcePremium.js +13 -7
- package/hooks/features/export/gridExcelExportInterface.d.ts +52 -52
- package/hooks/features/export/index.d.ts +2 -2
- package/hooks/features/export/index.js +2 -2
- package/hooks/features/export/serializer/excelSerializer.d.ts +23 -51
- package/hooks/features/export/serializer/excelSerializer.js +74 -187
- package/hooks/features/export/serializer/setupExcelExportWebWorker.d.ts +2 -0
- package/hooks/features/export/serializer/setupExcelExportWebWorker.js +59 -0
- package/hooks/features/export/serializer/utils.d.ts +36 -0
- package/hooks/features/export/serializer/utils.js +106 -0
- package/hooks/features/export/useGridExcelExport.d.ts +3 -3
- package/hooks/features/export/useGridExcelExport.js +10 -3
- package/hooks/features/index.d.ts +5 -5
- package/hooks/features/promptControl/api.d.ts +2 -2
- package/hooks/features/promptControl/index.d.ts +2 -2
- package/hooks/features/promptControl/types.d.ts +15 -15
- package/hooks/features/rowGrouping/createGroupingColDef.d.ts +44 -32
- package/hooks/features/rowGrouping/createGroupingColDef.js +4 -4
- package/hooks/features/rowGrouping/gridRowGroupingInterfaces.d.ts +32 -32
- package/hooks/features/rowGrouping/gridRowGroupingSelector.d.ts +2 -2
- package/hooks/features/rowGrouping/gridRowGroupingSelector.js +2 -2
- package/hooks/features/rowGrouping/gridRowGroupingUtils.d.ts +30 -22
- package/hooks/features/rowGrouping/gridRowGroupingUtils.js +1 -1
- package/hooks/features/rowGrouping/index.d.ts +3 -3
- package/hooks/features/rowGrouping/useGridDataSourceRowGroupingPreProcessors.d.ts +3 -3
- package/hooks/features/rowGrouping/useGridDataSourceRowGroupingPreProcessors.js +3 -3
- package/hooks/features/rowGrouping/useGridRowGrouping.d.ts +3 -3
- package/hooks/features/rowGrouping/useGridRowGrouping.js +4 -5
- package/hooks/features/rowGrouping/useGridRowGroupingPreProcessors.d.ts +3 -3
- package/hooks/features/rowGrouping/useGridRowGroupingPreProcessors.js +5 -5
- package/hooks/features/rows/index.d.ts +1 -1
- package/hooks/features/rows/useGridRowAriaAttributes.d.ts +1 -1
- package/hooks/index.d.ts +2 -2
- package/hooks/utils/index.d.ts +1 -1
- package/hooks/utils/useGridApiContext.d.ts +2 -2
- package/hooks/utils/useGridApiRef.d.ts +2 -2
- package/hooks/utils/useGridAriaAttributes.d.ts +1 -1
- package/hooks/utils/useGridPrivateApiContext.d.ts +2 -2
- package/hooks/utils/useGridRootProps.d.ts +2 -2
- package/hooks/utils/useKeepGroupedColumnsHidden.d.ts +4 -4
- package/index.d.ts +9 -17
- package/index.js +2 -11
- package/locales.d.ts +1 -1
- package/material/icons.d.ts +6 -6
- package/material/index.d.ts +6 -6
- package/models/dataGridPremiumProps.d.ts +140 -135
- package/models/gridApiPremium.d.ts +4 -6
- package/models/gridGroupingValueGetter.d.ts +2 -2
- package/models/gridPastedValueParser.d.ts +2 -2
- package/models/gridPremiumIconSlotsComponent.d.ts +26 -26
- package/models/gridPremiumSlotsComponent.d.ts +2 -3
- package/models/gridStatePremium.d.ts +7 -7
- package/models/index.d.ts +4 -4
- package/modern/DataGridPremium/DataGrid.d.ts +8 -0
- package/modern/DataGridPremium/DataGridPremium.d.ts +16 -0
- package/modern/DataGridPremium/DataGridPremium.js +55 -30
- package/modern/DataGridPremium/index.d.ts +3 -0
- package/modern/DataGridPremium/useDataGridPremiumComponent.d.ts +4 -0
- package/modern/DataGridPremium/useDataGridPremiumComponent.js +4 -3
- package/modern/DataGridPremium/useDataGridPremiumProps.d.ts +6 -0
- package/modern/DataGridPremium/useDataGridPremiumProps.js +2 -2
- package/modern/components/GridAggregationHeader.d.ts +7 -0
- package/modern/components/GridAggregationHeader.js +7 -11
- package/modern/components/GridAggregationRowOverlay.d.ts +3 -0
- package/modern/components/GridAggregationRowOverlay.js +37 -0
- package/modern/components/GridBottomContainer.d.ts +3 -0
- package/modern/components/GridBottomContainer.js +43 -0
- package/modern/components/GridColumnMenuAggregationItem.d.ts +7 -0
- package/modern/components/GridColumnMenuAggregationItem.js +36 -46
- package/modern/components/GridColumnMenuRowGroupItem.d.ts +3 -0
- package/modern/components/GridColumnMenuRowUngroupItem.d.ts +3 -0
- package/modern/components/GridDataSourceGroupingCriteriaCell.d.ts +7 -0
- package/modern/components/GridDataSourceGroupingCriteriaCell.js +9 -13
- package/modern/components/GridExcelExportMenuItem.d.ts +9 -0
- package/modern/components/GridFooterCell.d.ts +9 -0
- package/modern/components/GridFooterCell.js +5 -6
- package/modern/components/GridGroupingColumnFooterCell.d.ts +4 -0
- package/modern/components/GridGroupingColumnFooterCell.js +2 -1
- package/modern/components/GridGroupingColumnLeafCell.d.ts +4 -0
- package/modern/components/GridGroupingColumnLeafCell.js +3 -8
- package/modern/components/GridGroupingCriteriaCell.d.ts +7 -0
- package/modern/components/GridGroupingCriteriaCell.js +3 -8
- package/modern/components/GridPremiumColumnMenu.d.ts +33 -0
- package/modern/components/index.d.ts +5 -0
- package/modern/components/promptControl/GridToolbarPromptControl.d.ts +26 -0
- package/modern/components/promptControl/GridToolbarPromptControl.js +34 -32
- package/modern/components/promptControl/RecordButton.d.ts +16 -0
- package/modern/components/promptControl/index.d.ts +1 -0
- package/modern/components/reexports.d.ts +1 -0
- package/modern/constants/dataGridPremiumDefaultSlotsComponents.d.ts +2 -0
- package/modern/constants/dataGridPremiumDefaultSlotsComponents.js +3 -1
- package/modern/hooks/features/aggregation/createAggregationLookup.d.ts +17 -0
- package/modern/hooks/features/aggregation/createAggregationLookup.js +3 -3
- package/modern/hooks/features/aggregation/gridAggregationFunctions.d.ts +8 -0
- package/modern/hooks/features/aggregation/gridAggregationInterfaces.d.ts +129 -0
- package/modern/hooks/features/aggregation/gridAggregationSelectors.d.ts +13 -0
- package/modern/hooks/features/aggregation/gridAggregationSelectors.js +2 -2
- package/modern/hooks/features/aggregation/gridAggregationUtils.d.ts +62 -0
- package/modern/hooks/features/aggregation/index.d.ts +4 -0
- package/modern/hooks/features/aggregation/useGridAggregation.d.ts +6 -0
- package/modern/hooks/features/aggregation/useGridAggregation.js +6 -6
- package/modern/hooks/features/aggregation/useGridAggregationPreProcessors.d.ts +4 -0
- package/modern/hooks/features/aggregation/useGridAggregationPreProcessors.js +6 -6
- package/modern/hooks/features/aggregation/wrapColumnWithAggregation.d.ts +81 -0
- package/modern/hooks/features/aggregation/wrapColumnWithAggregation.js +6 -5
- package/modern/hooks/features/cellSelection/gridCellSelectionInterfaces.d.ts +40 -0
- package/modern/hooks/features/cellSelection/gridCellSelectionSelector.d.ts +2 -0
- package/modern/hooks/features/cellSelection/gridCellSelectionSelector.js +2 -1
- package/modern/hooks/features/cellSelection/index.d.ts +1 -0
- package/modern/hooks/features/cellSelection/useGridCellSelection.d.ts +6 -0
- package/modern/hooks/features/cellSelection/useGridCellSelection.js +5 -6
- package/modern/hooks/features/clipboard/useGridClipboardImport.d.ts +4 -0
- package/modern/hooks/features/clipboard/useGridClipboardImport.js +5 -5
- package/modern/hooks/features/dataSource/models.d.ts +54 -0
- package/modern/hooks/features/dataSource/useGridDataSourcePremium.d.ts +4 -0
- package/modern/hooks/features/dataSource/useGridDataSourcePremium.js +13 -7
- package/modern/hooks/features/export/gridExcelExportInterface.d.ts +71 -0
- package/modern/hooks/features/export/index.d.ts +2 -0
- package/modern/hooks/features/export/index.js +1 -1
- package/modern/hooks/features/export/serializer/excelSerializer.d.ts +40 -0
- package/modern/hooks/features/export/serializer/excelSerializer.js +69 -180
- package/modern/hooks/features/export/serializer/setupExcelExportWebWorker.d.ts +2 -0
- package/modern/hooks/features/export/serializer/setupExcelExportWebWorker.js +53 -0
- package/modern/hooks/features/export/serializer/utils.d.ts +36 -0
- package/modern/hooks/features/export/serializer/utils.js +93 -0
- package/modern/hooks/features/export/useGridExcelExport.d.ts +11 -0
- package/modern/hooks/features/export/useGridExcelExport.js +11 -5
- package/modern/hooks/features/index.d.ts +5 -0
- package/modern/hooks/features/promptControl/api.d.ts +2 -0
- package/modern/hooks/features/promptControl/index.d.ts +2 -0
- package/modern/hooks/features/promptControl/types.d.ts +25 -0
- package/modern/hooks/features/rowGrouping/createGroupingColDef.d.ts +57 -0
- package/modern/hooks/features/rowGrouping/createGroupingColDef.js +5 -5
- package/modern/hooks/features/rowGrouping/gridRowGroupingInterfaces.d.ts +44 -0
- package/modern/hooks/features/rowGrouping/gridRowGroupingSelector.d.ts +3 -0
- package/modern/hooks/features/rowGrouping/gridRowGroupingSelector.js +2 -2
- package/modern/hooks/features/rowGrouping/gridRowGroupingUtils.d.ts +54 -0
- package/modern/hooks/features/rowGrouping/gridRowGroupingUtils.js +2 -2
- package/modern/hooks/features/rowGrouping/index.d.ts +3 -0
- package/modern/hooks/features/rowGrouping/useGridDataSourceRowGroupingPreProcessors.d.ts +4 -0
- package/modern/hooks/features/rowGrouping/useGridDataSourceRowGroupingPreProcessors.js +3 -3
- package/modern/hooks/features/rowGrouping/useGridRowGrouping.d.ts +11 -0
- package/modern/hooks/features/rowGrouping/useGridRowGrouping.js +4 -5
- package/modern/hooks/features/rowGrouping/useGridRowGroupingPreProcessors.d.ts +4 -0
- package/modern/hooks/features/rowGrouping/useGridRowGroupingPreProcessors.js +5 -5
- package/modern/hooks/features/rows/index.d.ts +1 -0
- package/modern/hooks/features/rows/useGridRowAriaAttributes.d.ts +1 -0
- package/modern/hooks/index.d.ts +2 -0
- package/modern/hooks/utils/index.d.ts +1 -0
- package/modern/hooks/utils/useGridApiContext.d.ts +4 -0
- package/modern/hooks/utils/useGridApiRef.d.ts +4 -0
- package/modern/hooks/utils/useGridAriaAttributes.d.ts +2 -0
- package/modern/hooks/utils/useGridPrivateApiContext.d.ts +2 -0
- package/modern/hooks/utils/useGridRootProps.d.ts +2 -0
- package/modern/hooks/utils/useKeepGroupedColumnsHidden.d.ts +12 -0
- package/modern/index.d.ts +23 -0
- package/modern/index.js +1 -7
- package/modern/locales.d.ts +1 -0
- package/modern/material/icons.d.ts +15 -0
- package/modern/material/index.d.ts +8 -0
- package/modern/models/dataGridPremiumProps.d.ts +162 -0
- package/modern/models/gridApiPremium.d.ts +14 -0
- package/modern/models/gridGroupingValueGetter.d.ts +4 -0
- package/modern/models/gridPastedValueParser.d.ts +4 -0
- package/modern/models/gridPremiumIconSlotsComponent.d.ts +28 -0
- package/modern/models/gridPremiumSlotsComponent.d.ts +7 -0
- package/modern/models/gridStatePremium.d.ts +18 -0
- package/modern/models/index.d.ts +4 -0
- package/modern/package.json +1 -0
- package/modern/setupExcelExportWebWorker.d.ts +1 -0
- package/modern/setupExcelExportWebWorker.js +1 -0
- package/modern/themeAugmentation/index.d.ts +2 -0
- package/modern/themeAugmentation/overrides.d.ts +7 -0
- package/modern/themeAugmentation/props.d.ts +15 -0
- package/modern/typeOverloads/index.d.ts +2 -0
- package/modern/typeOverloads/modules.d.ts +97 -0
- package/modern/typeOverloads/reexports.d.ts +17 -0
- package/modern/utils/releaseInfo.d.ts +1 -0
- package/modern/utils/releaseInfo.js +1 -1
- package/package.json +39 -9
- package/setupExcelExportWebWorker.d.ts +1 -0
- package/setupExcelExportWebWorker.js +12 -0
- package/themeAugmentation/index.d.ts +2 -2
- package/themeAugmentation/overrides.d.ts +3 -4
- package/themeAugmentation/props.d.ts +9 -11
- package/tsconfig.build.tsbuildinfo +1 -0
- package/typeOverloads/index.d.ts +1 -1
- package/typeOverloads/modules.d.ts +75 -82
- package/typeOverloads/reexports.d.ts +5 -5
- package/utils/releaseInfo.d.ts +1 -1
- package/utils/releaseInfo.js +1 -1
- package/DataGridPremium/package.json +0 -6
- package/components/package.json +0 -6
- package/esm/hooks/features/dataSource/cache.js +0 -3
- package/hooks/features/dataSource/cache.d.ts +0 -2
- package/hooks/features/dataSource/cache.js +0 -9
- package/hooks/package.json +0 -6
- package/material/package.json +0 -6
- package/models/package.json +0 -6
- package/modern/hooks/features/dataSource/cache.js +0 -3
- package/themeAugmentation/package.json +0 -6
- package/typeOverloads/package.json +0 -6
|
@@ -10,7 +10,7 @@ export const useGridAggregationPreProcessors = (apiRef, props) => {
|
|
|
10
10
|
// that the pre-processor is called it will already have been updated with the current rules.
|
|
11
11
|
const rulesOnLastColumnHydration = React.useRef({});
|
|
12
12
|
const updateAggregatedColumns = React.useCallback(columnsState => {
|
|
13
|
-
const aggregationRules = props.disableAggregation ? {} : getAggregationRules(columnsState.lookup, gridAggregationModelSelector(apiRef), props.aggregationFunctions, !!props.
|
|
13
|
+
const aggregationRules = props.disableAggregation ? {} : getAggregationRules(columnsState.lookup, gridAggregationModelSelector(apiRef), props.aggregationFunctions, !!props.dataSource);
|
|
14
14
|
columnsState.orderedFields.forEach(field => {
|
|
15
15
|
const shouldHaveAggregationValue = !!aggregationRules[field];
|
|
16
16
|
const haveAggregationColumnValue = !!rulesOnLastColumnHydration.current[field];
|
|
@@ -32,9 +32,9 @@ export const useGridAggregationPreProcessors = (apiRef, props) => {
|
|
|
32
32
|
rulesOnLastColumnHydration.current = aggregationRules;
|
|
33
33
|
apiRef.current.caches.aggregation.rulesOnLastColumnHydration = aggregationRules;
|
|
34
34
|
return columnsState;
|
|
35
|
-
}, [apiRef, props.aggregationFunctions, props.disableAggregation, props.
|
|
35
|
+
}, [apiRef, props.aggregationFunctions, props.disableAggregation, props.dataSource]);
|
|
36
36
|
const addGroupFooterRows = React.useCallback(value => {
|
|
37
|
-
const aggregationRules = props.disableAggregation ? {} : getAggregationRules(gridColumnLookupSelector(apiRef), gridAggregationModelSelector(apiRef), props.aggregationFunctions, !!props.
|
|
37
|
+
const aggregationRules = props.disableAggregation ? {} : getAggregationRules(gridColumnLookupSelector(apiRef), gridAggregationModelSelector(apiRef), props.aggregationFunctions, !!props.dataSource);
|
|
38
38
|
const hasAggregationRule = Object.keys(aggregationRules).length > 0;
|
|
39
39
|
|
|
40
40
|
// If we did not have any aggregation footer before, and we still don't have any,
|
|
@@ -49,7 +49,7 @@ export const useGridAggregationPreProcessors = (apiRef, props) => {
|
|
|
49
49
|
getAggregationPosition: props.getAggregationPosition,
|
|
50
50
|
hasAggregationRule
|
|
51
51
|
});
|
|
52
|
-
}, [apiRef, props.disableAggregation, props.getAggregationPosition, props.aggregationFunctions, props.
|
|
52
|
+
}, [apiRef, props.disableAggregation, props.getAggregationPosition, props.aggregationFunctions, props.dataSource]);
|
|
53
53
|
const addColumnMenuButtons = React.useCallback((columnMenuItems, colDef) => {
|
|
54
54
|
if (props.disableAggregation || !colDef.aggregable) {
|
|
55
55
|
return columnMenuItems;
|
|
@@ -57,13 +57,13 @@ export const useGridAggregationPreProcessors = (apiRef, props) => {
|
|
|
57
57
|
const availableAggregationFunctions = getAvailableAggregationFunctions({
|
|
58
58
|
aggregationFunctions: props.aggregationFunctions,
|
|
59
59
|
colDef,
|
|
60
|
-
isDataSource: !!props.
|
|
60
|
+
isDataSource: !!props.dataSource
|
|
61
61
|
});
|
|
62
62
|
if (availableAggregationFunctions.length === 0) {
|
|
63
63
|
return columnMenuItems;
|
|
64
64
|
}
|
|
65
65
|
return [...columnMenuItems, 'columnMenuAggregationItem'];
|
|
66
|
-
}, [props.aggregationFunctions, props.disableAggregation, props.
|
|
66
|
+
}, [props.aggregationFunctions, props.disableAggregation, props.dataSource]);
|
|
67
67
|
const stateExportPreProcessing = React.useCallback(prevState => {
|
|
68
68
|
if (props.disableAggregation) {
|
|
69
69
|
return prevState;
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { RefObject } from '@mui/x-internals/types';
|
|
3
|
+
import { GridColDef, GridFilterOperator } from '@mui/x-data-grid-pro';
|
|
4
|
+
import { type GridBaseColDef } from '@mui/x-data-grid-pro/internals';
|
|
5
|
+
import { GridApiPremium } from "../../../models/gridApiPremium.js";
|
|
6
|
+
import type { GridAggregationRule } from './gridAggregationInterfaces';
|
|
7
|
+
type WrappableColumnProperty = 'valueGetter' | 'valueFormatter' | 'renderCell' | 'renderHeader' | 'filterOperators';
|
|
8
|
+
interface GridColDefWithAggregationWrappers extends GridBaseColDef {
|
|
9
|
+
aggregationWrappedProperties: {
|
|
10
|
+
name: WrappableColumnProperty;
|
|
11
|
+
originalValue: GridBaseColDef[WrappableColumnProperty];
|
|
12
|
+
wrappedValue: GridBaseColDef[WrappableColumnProperty];
|
|
13
|
+
}[];
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Add a wrapper around each wrappable property of the column to customize the behavior of the aggregation cells.
|
|
17
|
+
*/
|
|
18
|
+
export declare const wrapColumnWithAggregationValue: ({
|
|
19
|
+
column,
|
|
20
|
+
apiRef,
|
|
21
|
+
aggregationRule
|
|
22
|
+
}: {
|
|
23
|
+
column: GridBaseColDef;
|
|
24
|
+
apiRef: RefObject<GridApiPremium>;
|
|
25
|
+
aggregationRule: GridAggregationRule;
|
|
26
|
+
}) => GridBaseColDef;
|
|
27
|
+
/**
|
|
28
|
+
* Remove the aggregation wrappers around the wrappable properties of the column.
|
|
29
|
+
*/
|
|
30
|
+
export declare const unwrapColumnFromAggregation: ({
|
|
31
|
+
column
|
|
32
|
+
}: {
|
|
33
|
+
column: GridColDef | GridColDefWithAggregationWrappers;
|
|
34
|
+
}) => GridBaseColDef<any, any, any> | {
|
|
35
|
+
field: string;
|
|
36
|
+
headerName?: string;
|
|
37
|
+
description?: string;
|
|
38
|
+
width?: number;
|
|
39
|
+
flex?: number;
|
|
40
|
+
minWidth?: number;
|
|
41
|
+
maxWidth?: number;
|
|
42
|
+
hideable?: boolean;
|
|
43
|
+
sortable?: boolean;
|
|
44
|
+
sortingOrder?: readonly import("@mui/x-data-grid").GridSortDirection[];
|
|
45
|
+
resizable?: boolean;
|
|
46
|
+
editable?: boolean;
|
|
47
|
+
groupable?: boolean;
|
|
48
|
+
pinnable?: boolean;
|
|
49
|
+
sortComparator?: import("@mui/x-data-grid").GridComparatorFn<any> | undefined;
|
|
50
|
+
getSortComparator?: ((sortDirection: import("@mui/x-data-grid").GridSortDirection) => import("@mui/x-data-grid").GridComparatorFn<any> | undefined) | undefined;
|
|
51
|
+
type?: import("@mui/x-data-grid").GridColType;
|
|
52
|
+
align?: import("@mui/x-data-grid").GridAlignment;
|
|
53
|
+
valueGetter?: import("@mui/x-data-grid").GridValueGetter<import("@mui/x-data-grid").GridValidRowModel, any, any, never> | undefined;
|
|
54
|
+
rowSpanValueGetter?: import("@mui/x-data-grid").GridValueGetter<import("@mui/x-data-grid").GridValidRowModel, any, any, never> | undefined;
|
|
55
|
+
valueSetter?: import("@mui/x-data-grid").GridValueSetter<import("@mui/x-data-grid").GridValidRowModel, any, any> | undefined;
|
|
56
|
+
valueFormatter?: import("@mui/x-data-grid").GridValueFormatter<import("@mui/x-data-grid").GridValidRowModel, any, any, never> | undefined;
|
|
57
|
+
valueParser?: import("@mui/x-data-grid").GridValueParser<import("@mui/x-data-grid").GridValidRowModel, any, any> | undefined;
|
|
58
|
+
cellClassName?: import("@mui/x-data-grid").GridCellClassNamePropType<import("@mui/x-data-grid").GridValidRowModel, any> | undefined;
|
|
59
|
+
display?: "text" | "flex";
|
|
60
|
+
renderCell?: ((params: import("@mui/x-data-grid").GridRenderCellParams<import("@mui/x-data-grid").GridValidRowModel, any, any, import("@mui/x-data-grid").GridTreeNodeWithRender>) => React.ReactNode) | undefined;
|
|
61
|
+
renderEditCell?: ((params: import("@mui/x-data-grid").GridRenderEditCellParams<import("@mui/x-data-grid").GridValidRowModel, any, any, import("@mui/x-data-grid").GridTreeNodeWithRender>) => React.ReactNode) | undefined;
|
|
62
|
+
preProcessEditCellProps?: ((params: import("@mui/x-data-grid").GridPreProcessEditCellProps) => import("@mui/x-data-grid").GridEditCellProps | Promise<import("@mui/x-data-grid").GridEditCellProps>) | undefined;
|
|
63
|
+
headerClassName?: import("@mui/x-data-grid").GridColumnHeaderClassNamePropType;
|
|
64
|
+
renderHeader?: ((params: import("@mui/x-data-grid").GridColumnHeaderParams<import("@mui/x-data-grid").GridValidRowModel, any, any>) => React.ReactNode) | undefined;
|
|
65
|
+
headerAlign?: import("@mui/x-data-grid").GridAlignment;
|
|
66
|
+
hideSortIcons?: boolean;
|
|
67
|
+
disableColumnMenu?: boolean;
|
|
68
|
+
filterable?: boolean;
|
|
69
|
+
filterOperators?: readonly GridFilterOperator<import("@mui/x-data-grid").GridValidRowModel, any, any, any>[] | undefined;
|
|
70
|
+
getApplyQuickFilterFn?: import("@mui/x-data-grid").GetApplyQuickFilterFn<import("@mui/x-data-grid").GridValidRowModel, any> | undefined;
|
|
71
|
+
disableReorder?: boolean;
|
|
72
|
+
disableExport?: boolean;
|
|
73
|
+
colSpan?: number | import("@mui/x-data-grid").GridColSpanFn<import("@mui/x-data-grid").GridValidRowModel, any, any> | undefined;
|
|
74
|
+
unstable_examples?: any[] | undefined;
|
|
75
|
+
renderHeaderFilter?: (params: import("@mui/x-data-grid-pro").GridRenderHeaderFilterProps) => React.ReactNode;
|
|
76
|
+
aggregable?: boolean;
|
|
77
|
+
availableAggregationFunctions?: string[];
|
|
78
|
+
groupingValueGetter?: import("../../..").GridGroupingValueGetter<import("@mui/x-data-grid").GridValidRowModel> | undefined;
|
|
79
|
+
pastedValueParser?: import("../../..").GridPastedValueParser<import("@mui/x-data-grid").GridValidRowModel, any, any> | undefined;
|
|
80
|
+
};
|
|
81
|
+
export {};
|
|
@@ -2,17 +2,17 @@ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWith
|
|
|
2
2
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
3
3
|
const _excluded = ["aggregationWrappedProperties"];
|
|
4
4
|
import * as React from 'react';
|
|
5
|
+
import { gridRowIdSelector, gridRowNodeSelector } from '@mui/x-data-grid-pro';
|
|
5
6
|
import { gridAggregationLookupSelector } from "./gridAggregationSelectors.js";
|
|
6
7
|
import { GridFooterCell } from "../../../components/GridFooterCell.js";
|
|
7
8
|
import { GridAggregationHeader } from "../../../components/GridAggregationHeader.js";
|
|
8
9
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
9
|
-
const AGGREGATION_WRAPPABLE_PROPERTIES = ['valueGetter', 'valueFormatter', 'renderCell', 'renderHeader', 'filterOperators'];
|
|
10
10
|
const getAggregationValueWrappedValueGetter = ({
|
|
11
11
|
value: valueGetter,
|
|
12
12
|
getCellAggregationResult
|
|
13
13
|
}) => {
|
|
14
14
|
const wrappedValueGetter = (value, row, column, apiRef) => {
|
|
15
|
-
const rowId = apiRef
|
|
15
|
+
const rowId = gridRowIdSelector(apiRef, row);
|
|
16
16
|
const cellAggregationResult = rowId ? getCellAggregationResult(rowId, column.field) : null;
|
|
17
17
|
if (cellAggregationResult != null) {
|
|
18
18
|
return cellAggregationResult?.value ?? null;
|
|
@@ -35,7 +35,7 @@ const getAggregationValueWrappedValueFormatter = ({
|
|
|
35
35
|
return valueFormatter;
|
|
36
36
|
}
|
|
37
37
|
const wrappedValueFormatter = (value, row, column, apiRef) => {
|
|
38
|
-
const rowId = apiRef
|
|
38
|
+
const rowId = gridRowIdSelector(apiRef, row);
|
|
39
39
|
if (rowId != null) {
|
|
40
40
|
const cellAggregationResult = getCellAggregationResult(rowId, column.field);
|
|
41
41
|
if (cellAggregationResult != null) {
|
|
@@ -94,7 +94,8 @@ const getWrappedFilterOperators = ({
|
|
|
94
94
|
return null;
|
|
95
95
|
}
|
|
96
96
|
return (value, row, column, api) => {
|
|
97
|
-
|
|
97
|
+
const rowId = gridRowIdSelector(apiRef, row);
|
|
98
|
+
if (getCellAggregationResult(rowId, column.field) != null) {
|
|
98
99
|
return true;
|
|
99
100
|
}
|
|
100
101
|
return filterFn(value, row, column, api);
|
|
@@ -133,7 +134,7 @@ export const wrapColumnWithAggregationValue = ({
|
|
|
133
134
|
}) => {
|
|
134
135
|
const getCellAggregationResult = (id, field) => {
|
|
135
136
|
let cellAggregationPosition = null;
|
|
136
|
-
const rowNode = apiRef
|
|
137
|
+
const rowNode = gridRowNodeSelector(apiRef, id);
|
|
137
138
|
if (rowNode.type === 'group') {
|
|
138
139
|
cellAggregationPosition = 'inline';
|
|
139
140
|
} else if (id.toString().startsWith('auto-generated-group-footer-')) {
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { GridCellCoordinates, GridColDef, GridRowId } from '@mui/x-data-grid-pro';
|
|
2
|
+
export type GridCellSelectionModel = Record<GridRowId, Record<GridColDef['field'], boolean>>;
|
|
3
|
+
/**
|
|
4
|
+
* The cell selection API interface that is available in the grid [[apiRef]].
|
|
5
|
+
*/
|
|
6
|
+
export interface GridCellSelectionApi {
|
|
7
|
+
/**
|
|
8
|
+
* Determines if a cell is selected or not.
|
|
9
|
+
* @param {GridRowId} id The id of the row.
|
|
10
|
+
* @param {GridColDef['field']} field The field.
|
|
11
|
+
* @returns {boolean} A boolean indicating if the cell is selected.
|
|
12
|
+
*/
|
|
13
|
+
isCellSelected: (id: GridRowId, field: GridColDef['field']) => boolean;
|
|
14
|
+
/**
|
|
15
|
+
* Returns an object containing the selection state of the cells.
|
|
16
|
+
* The keys of the object correspond to the row IDs.
|
|
17
|
+
* The value of each key is also an object, which has a column field for a key and a boolean value for its selection state.
|
|
18
|
+
* @returns {GridCellSelectionModel} Object containing the selection state of the cells
|
|
19
|
+
*/
|
|
20
|
+
getCellSelectionModel: () => GridCellSelectionModel;
|
|
21
|
+
/**
|
|
22
|
+
* Updates the cell selection model according to the value passed to the `newModel` argument.
|
|
23
|
+
* Any cell already selected will be unselected.
|
|
24
|
+
* @param {GridCellSelectionModel} newModel The cells to select.
|
|
25
|
+
*/
|
|
26
|
+
setCellSelectionModel: (newModel: GridCellSelectionModel) => void;
|
|
27
|
+
/**
|
|
28
|
+
* Selects all cells that are inside the range given by `start` and `end` coordinates.
|
|
29
|
+
* @param {GridCellCoordinates} start Object containing the row ID and field of the first cell to select.
|
|
30
|
+
* @param {GridCellCoordinates} end Object containing the row ID and field of the last cell to select.
|
|
31
|
+
* @param {boolean} keepOtherSelected Whether to keep current selected cells or discard. Default is false.
|
|
32
|
+
*/
|
|
33
|
+
selectCellRange: (start: GridCellCoordinates, end: GridCellCoordinates, keepOtherSelected?: boolean) => void;
|
|
34
|
+
/**
|
|
35
|
+
* Returns an array containing only the selected cells.
|
|
36
|
+
* Each item is an object with the ID and field of the cell.
|
|
37
|
+
* @returns {GridCellCoordinates[]} Array with the selected cells.
|
|
38
|
+
*/
|
|
39
|
+
getSelectedCellsAsArray: () => GridCellCoordinates[];
|
|
40
|
+
}
|
|
@@ -1 +1,2 @@
|
|
|
1
|
-
|
|
1
|
+
import { createRootSelector } from '@mui/x-data-grid-pro/internals';
|
|
2
|
+
export const gridCellSelectionStateSelector = createRootSelector(state => state.cellSelection);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./gridCellSelectionInterfaces.js";
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { RefObject } from '@mui/x-internals/types';
|
|
2
|
+
import { GridStateInitializer } from '@mui/x-data-grid-pro/internals';
|
|
3
|
+
import { DataGridPremiumProcessedProps } from "../../../models/dataGridPremiumProps.js";
|
|
4
|
+
import { GridPrivateApiPremium } from "../../../models/gridApiPremium.js";
|
|
5
|
+
export declare const cellSelectionStateInitializer: GridStateInitializer<Pick<DataGridPremiumProcessedProps, 'cellSelectionModel' | 'initialState'>>;
|
|
6
|
+
export declare const useGridCellSelection: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "cellSelection" | "cellSelectionModel" | "onCellSelectionModelChange" | "pagination" | "paginationMode" | "ignoreValueFormatterDuringExport" | "clipboardCopyCellDelimiter" | "columnHeaderHeight">) => void;
|
|
@@ -40,11 +40,11 @@ export const useGridCellSelection = (apiRef, props) => {
|
|
|
40
40
|
if (!props.cellSelection) {
|
|
41
41
|
return false;
|
|
42
42
|
}
|
|
43
|
-
const cellSelectionModel = gridCellSelectionStateSelector(apiRef
|
|
43
|
+
const cellSelectionModel = gridCellSelectionStateSelector(apiRef);
|
|
44
44
|
return cellSelectionModel[id] ? !!cellSelectionModel[id][field] : false;
|
|
45
45
|
}, [apiRef, props.cellSelection]);
|
|
46
46
|
const getCellSelectionModel = React.useCallback(() => {
|
|
47
|
-
return gridCellSelectionStateSelector(apiRef
|
|
47
|
+
return gridCellSelectionStateSelector(apiRef);
|
|
48
48
|
}, [apiRef]);
|
|
49
49
|
const setCellSelectionModel = React.useCallback(newModel => {
|
|
50
50
|
if (!props.cellSelection) {
|
|
@@ -53,7 +53,6 @@ export const useGridCellSelection = (apiRef, props) => {
|
|
|
53
53
|
apiRef.current.setState(prevState => _extends({}, prevState, {
|
|
54
54
|
cellSelection: newModel
|
|
55
55
|
}));
|
|
56
|
-
apiRef.current.forceUpdate();
|
|
57
56
|
}, [apiRef, props.cellSelection]);
|
|
58
57
|
const selectCellRange = React.useCallback((start, end, keepOtherSelected = false) => {
|
|
59
58
|
const startRowIndex = apiRef.current.getRowIndexRelativeToVisibleRows(start.id);
|
|
@@ -184,7 +183,7 @@ export const useGridCellSelection = (apiRef, props) => {
|
|
|
184
183
|
if (!mousePosition.current || !apiRef.current.virtualScrollerRef?.current) {
|
|
185
184
|
return;
|
|
186
185
|
}
|
|
187
|
-
const dimensions = gridDimensionsSelector(apiRef
|
|
186
|
+
const dimensions = gridDimensionsSelector(apiRef);
|
|
188
187
|
const {
|
|
189
188
|
x: mouseX,
|
|
190
189
|
y: mouseY
|
|
@@ -244,7 +243,7 @@ export const useGridCellSelection = (apiRef, props) => {
|
|
|
244
243
|
if (!virtualScrollerRect) {
|
|
245
244
|
return;
|
|
246
245
|
}
|
|
247
|
-
const dimensions = gridDimensionsSelector(apiRef
|
|
246
|
+
const dimensions = gridDimensionsSelector(apiRef);
|
|
248
247
|
const {
|
|
249
248
|
x,
|
|
250
249
|
y
|
|
@@ -453,7 +452,7 @@ export const useGridCellSelection = (apiRef, props) => {
|
|
|
453
452
|
if (apiRef.current.getSelectedCellsAsArray().length <= 1) {
|
|
454
453
|
return value;
|
|
455
454
|
}
|
|
456
|
-
const sortedRowIds = gridSortedRowIdsSelector(apiRef
|
|
455
|
+
const sortedRowIds = gridSortedRowIdsSelector(apiRef);
|
|
457
456
|
const cellSelectionModel = apiRef.current.getCellSelectionModel();
|
|
458
457
|
const unsortedSelectedRowIds = Object.keys(cellSelectionModel);
|
|
459
458
|
const sortedSelectedRowIds = sortedRowIds.filter(id => unsortedSelectedRowIds.includes(`${id}`));
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { RefObject } from '@mui/x-internals/types';
|
|
2
|
+
import { GridPrivateApiPremium } from "../../../models/gridApiPremium.js";
|
|
3
|
+
import type { DataGridPremiumProcessedProps } from '../../../models/dataGridPremiumProps';
|
|
4
|
+
export declare const useGridClipboardImport: (apiRef: RefObject<GridPrivateApiPremium>, props: Pick<DataGridPremiumProcessedProps, "pagination" | "paginationMode" | "processRowUpdate" | "onProcessRowUpdateError" | "getRowId" | "onClipboardPasteStart" | "onClipboardPasteEnd" | "splitClipboardPastedText" | "disableClipboardPaste" | "onBeforeClipboardPasteStart">) => void;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import * as React from 'react';
|
|
3
|
-
import { GRID_CHECKBOX_SELECTION_FIELD, gridFocusCellSelector, gridVisibleColumnFieldsSelector, useGridApiOptionHandler, useGridApiEventHandler, gridPaginatedVisibleSortedGridRowIdsSelector, gridExpandedSortedRowIdsSelector } from '@mui/x-data-grid';
|
|
3
|
+
import { GRID_CHECKBOX_SELECTION_FIELD, gridFocusCellSelector, gridVisibleColumnFieldsSelector, useGridApiOptionHandler, useGridApiEventHandler, gridPaginatedVisibleSortedGridRowIdsSelector, gridExpandedSortedRowIdsSelector, gridRowSelectionIdsSelector, gridRowSelectionCountSelector } from '@mui/x-data-grid';
|
|
4
4
|
import { getRowIdFromRowModel, getActiveElement, useGridRegisterPipeProcessor, getPublicApiRef, isPasteShortcut, useGridLogger } from '@mui/x-data-grid/internals';
|
|
5
5
|
import { warnOnce } from '@mui/x-internals/warning';
|
|
6
6
|
import { GRID_DETAIL_PANEL_TOGGLE_FIELD, GRID_REORDER_COL_DEF } from '@mui/x-data-grid-pro';
|
|
@@ -193,10 +193,10 @@ function defaultPasteResolver({
|
|
|
193
193
|
}
|
|
194
194
|
return true;
|
|
195
195
|
});
|
|
196
|
-
|
|
197
|
-
if (selectedRows.size > 0 && !isSingleValuePasted) {
|
|
196
|
+
if (gridRowSelectionCountSelector(apiRef) > 0 && !isSingleValuePasted) {
|
|
198
197
|
// Multiple values are pasted starting from the first and top-most cell
|
|
199
198
|
const pastedRowsDataCount = pastedData.length;
|
|
199
|
+
const selectedRows = gridRowSelectionIdsSelector(apiRef);
|
|
200
200
|
|
|
201
201
|
// There's no guarantee that the selected rows are in the same order as the pasted rows
|
|
202
202
|
selectedRows.forEach((row, rowId) => {
|
|
@@ -255,7 +255,6 @@ export const useGridClipboardImport = (apiRef, props) => {
|
|
|
255
255
|
const onProcessRowUpdateError = props.onProcessRowUpdateError;
|
|
256
256
|
const getRowId = props.getRowId;
|
|
257
257
|
const enableClipboardPaste = !props.disableClipboardPaste;
|
|
258
|
-
const rootEl = apiRef.current.rootElementRef?.current;
|
|
259
258
|
const logger = useGridLogger(apiRef, 'useGridClipboardImport');
|
|
260
259
|
const splitClipboardPastedText = props.splitClipboardPastedText;
|
|
261
260
|
const {
|
|
@@ -278,6 +277,7 @@ export const useGridClipboardImport = (apiRef, props) => {
|
|
|
278
277
|
return;
|
|
279
278
|
}
|
|
280
279
|
}
|
|
280
|
+
const rootEl = apiRef.current.rootElementRef?.current;
|
|
281
281
|
if (!rootEl) {
|
|
282
282
|
return;
|
|
283
283
|
}
|
|
@@ -318,7 +318,7 @@ export const useGridClipboardImport = (apiRef, props) => {
|
|
|
318
318
|
paginationMode
|
|
319
319
|
});
|
|
320
320
|
cellUpdater.applyUpdates();
|
|
321
|
-
}, [apiRef, processRowUpdate, onProcessRowUpdateError, getRowId, enableClipboardPaste,
|
|
321
|
+
}, [apiRef, processRowUpdate, onProcessRowUpdateError, getRowId, enableClipboardPaste, splitClipboardPastedText, pagination, paginationMode, onBeforeClipboardPasteStart, logger]);
|
|
322
322
|
const checkIfCanStartEditing = React.useCallback((initialValue, {
|
|
323
323
|
event
|
|
324
324
|
}) => {
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import type { GridColDef, GridRowId, GridValidRowModel, GridDataSource, GridGetRowsResponse, GridGetRowsParams, GridDataSourceApiBase, GridDataSourcePrivateApi } from '@mui/x-data-grid-pro';
|
|
2
|
+
import type { GridAggregationModel } from '../aggregation/gridAggregationInterfaces';
|
|
3
|
+
export interface GridGetRowsResponsePremium extends GridGetRowsResponse {
|
|
4
|
+
/**
|
|
5
|
+
* Row to be used for aggregation footer row.
|
|
6
|
+
* It must provide the values for the aggregated columns passed in
|
|
7
|
+
* `GridGetRowsParams.aggregationModel`.
|
|
8
|
+
*/
|
|
9
|
+
aggregateRow?: GridValidRowModel;
|
|
10
|
+
}
|
|
11
|
+
export interface GridGetRowsParamsPremium extends GridGetRowsParams {
|
|
12
|
+
/**
|
|
13
|
+
* List of aggregated columns.
|
|
14
|
+
*/
|
|
15
|
+
aggregationModel?: GridAggregationModel;
|
|
16
|
+
/**
|
|
17
|
+
* List of grouped columns (only applicable with `rowGrouping`).
|
|
18
|
+
*/
|
|
19
|
+
groupFields?: GridColDef['field'][];
|
|
20
|
+
}
|
|
21
|
+
export interface GridDataSourcePremium extends Omit<GridDataSource, 'getRows'> {
|
|
22
|
+
/**
|
|
23
|
+
* This method will be called when the grid needs to fetch some rows.
|
|
24
|
+
* @param {GridGetRowsParamsPremium} params The parameters required to fetch the rows.
|
|
25
|
+
* @returns {Promise<GridGetRowsResponsePremium>} A promise that resolves to the data of type [GridGetRowsResponsePremium].
|
|
26
|
+
*/
|
|
27
|
+
getRows(params: GridGetRowsParamsPremium): Promise<GridGetRowsResponsePremium>;
|
|
28
|
+
/**
|
|
29
|
+
* Used to get the aggregated value for a parent row.
|
|
30
|
+
* @param {GridValidRowModel} row The row to extract the aggregated value from.
|
|
31
|
+
* @param {GridColDef['field']} field The field to extract the aggregated value for.
|
|
32
|
+
* @returns {string} The aggregated value for a specific aggregated column.
|
|
33
|
+
*/
|
|
34
|
+
getAggregatedValue?: (row: GridValidRowModel, field: GridColDef['field']) => string;
|
|
35
|
+
}
|
|
36
|
+
export interface GridDataSourceApiBasePremium extends Omit<GridDataSourceApiBase, 'fetchRows'> {
|
|
37
|
+
/**
|
|
38
|
+
* Fetches the rows from the server.
|
|
39
|
+
* If no `parentId` option is provided, it fetches the root rows.
|
|
40
|
+
* Any missing parameter from `params` will be filled from the state (sorting, filtering, etc.).
|
|
41
|
+
* @param {GridRowId} parentId The id of the parent node (default: `GRID_ROOT_GROUP_ID`).
|
|
42
|
+
* @param {Partial<GridGetRowsParamsPremium>} params Request parameters override.
|
|
43
|
+
*/
|
|
44
|
+
fetchRows: (parentId?: GridRowId, params?: Partial<GridGetRowsParamsPremium>) => void;
|
|
45
|
+
}
|
|
46
|
+
export interface GridDataSourceApiPremium {
|
|
47
|
+
/**
|
|
48
|
+
* The data source API.
|
|
49
|
+
*/
|
|
50
|
+
dataSource: GridDataSourceApiBasePremium;
|
|
51
|
+
}
|
|
52
|
+
export interface GridDataSourcePremiumPrivateApi extends GridDataSourcePrivateApi {
|
|
53
|
+
resolveGroupAggregation: (groupId: GridRowId, field: string) => any;
|
|
54
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { RefObject } from '@mui/x-internals/types';
|
|
2
|
+
import { GridPrivateApiPremium } from "../../../models/gridApiPremium.js";
|
|
3
|
+
import { DataGridPremiumProcessedProps } from "../../../models/dataGridPremiumProps.js";
|
|
4
|
+
export declare const useGridDataSourcePremium: (apiRef: RefObject<GridPrivateApiPremium>, props: DataGridPremiumProcessedProps) => void;
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
|
2
2
|
import * as React from 'react';
|
|
3
3
|
import { useGridApiEventHandler as addEventHandler, useGridApiMethod, GRID_ROOT_GROUP_ID } from '@mui/x-data-grid-pro';
|
|
4
|
-
import {
|
|
5
|
-
|
|
4
|
+
import { useGridDataSourceBasePro, useGridRegisterStrategyProcessor, useGridRegisterPipeProcessor } from '@mui/x-data-grid-pro/internals';
|
|
5
|
+
function getKeyPremium(params) {
|
|
6
|
+
return JSON.stringify([params.filterModel, params.sortModel, params.groupKeys, params.groupFields, params.start, params.end, params.aggregationModel]);
|
|
7
|
+
}
|
|
6
8
|
const options = {
|
|
7
9
|
cacheOptions: {
|
|
8
10
|
getKey: getKeyPremium
|
|
@@ -12,8 +14,9 @@ export const useGridDataSourcePremium = (apiRef, props) => {
|
|
|
12
14
|
const {
|
|
13
15
|
api,
|
|
14
16
|
strategyProcessor,
|
|
15
|
-
events
|
|
16
|
-
|
|
17
|
+
events,
|
|
18
|
+
setStrategyAvailability
|
|
19
|
+
} = useGridDataSourceBasePro(apiRef, props, options);
|
|
17
20
|
const aggregateRowRef = React.useRef({});
|
|
18
21
|
const processDataSourceRows = React.useCallback(({
|
|
19
22
|
params,
|
|
@@ -35,11 +38,11 @@ export const useGridDataSourcePremium = (apiRef, props) => {
|
|
|
35
38
|
}, [apiRef]);
|
|
36
39
|
const resolveGroupAggregation = React.useCallback((groupId, field) => {
|
|
37
40
|
if (groupId === GRID_ROOT_GROUP_ID) {
|
|
38
|
-
return props.
|
|
41
|
+
return props.dataSource?.getAggregatedValue?.(aggregateRowRef.current, field);
|
|
39
42
|
}
|
|
40
43
|
const row = apiRef.current.getRow(groupId);
|
|
41
|
-
return props.
|
|
42
|
-
}, [apiRef, props.
|
|
44
|
+
return props.dataSource?.getAggregatedValue?.(row, field);
|
|
45
|
+
}, [apiRef, props.dataSource]);
|
|
43
46
|
const privateApi = _extends({}, api.private, {
|
|
44
47
|
resolveGroupAggregation
|
|
45
48
|
});
|
|
@@ -50,4 +53,7 @@ export const useGridDataSourcePremium = (apiRef, props) => {
|
|
|
50
53
|
Object.entries(events).forEach(([event, handler]) => {
|
|
51
54
|
addEventHandler(apiRef, event, handler);
|
|
52
55
|
});
|
|
56
|
+
React.useEffect(() => {
|
|
57
|
+
setStrategyAvailability();
|
|
58
|
+
}, [setStrategyAvailability]);
|
|
53
59
|
};
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import type * as Excel from 'exceljs';
|
|
2
|
+
import { GridFileExportOptions, GridExportFormat as GridExportFormatCommunity, GridExportExtension as GridExportExtensionCommunity } from '@mui/x-data-grid-pro';
|
|
3
|
+
export type GridExportFormat = GridExportFormatCommunity | 'excel';
|
|
4
|
+
export type GridExportExtension = GridExportExtensionCommunity | 'xlsx';
|
|
5
|
+
export interface GridExceljsProcessInput {
|
|
6
|
+
workbook: Excel.Workbook;
|
|
7
|
+
worksheet: Excel.Worksheet;
|
|
8
|
+
}
|
|
9
|
+
export interface ColumnsStylesInterface {
|
|
10
|
+
[field: string]: Partial<Excel.Style>;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* The options to apply on the Excel export.
|
|
14
|
+
* @demos
|
|
15
|
+
* - [Excel export](/x/react-data-grid/export/#excel-export)
|
|
16
|
+
*/
|
|
17
|
+
export interface GridExcelExportOptions extends GridFileExportOptions {
|
|
18
|
+
/**
|
|
19
|
+
* Function to return the Worker instance to be called.
|
|
20
|
+
* @returns {() => Worker} A Worker instance.
|
|
21
|
+
*/
|
|
22
|
+
worker?: () => Worker;
|
|
23
|
+
/**
|
|
24
|
+
* Name given to the worksheet containing the columns valueOptions.
|
|
25
|
+
* valueOptions are added to this worksheet if they are provided as an array.
|
|
26
|
+
*/
|
|
27
|
+
valueOptionsSheetName?: string;
|
|
28
|
+
/**
|
|
29
|
+
* Method called before adding the rows to the workbook.
|
|
30
|
+
* Not supported when `worker` is set.
|
|
31
|
+
* To use with web workers, use the option in `setupExcelExportWebWorker`.
|
|
32
|
+
* @param {GridExceljsProcessInput} processInput object containing the workbook and the worksheet.
|
|
33
|
+
* @returns {Promise<void>} A promise which resolves after processing the input.
|
|
34
|
+
* */
|
|
35
|
+
exceljsPreProcess?: (processInput: GridExceljsProcessInput) => Promise<void>;
|
|
36
|
+
/**
|
|
37
|
+
* Method called after adding the rows to the workbook.
|
|
38
|
+
* Not supported when `worker` is set.
|
|
39
|
+
* To use with web workers, use the option in `setupExcelExportWebWorker`.
|
|
40
|
+
* @param {GridExceljsProcessInput} processInput object containing the workbook and the worksheet.
|
|
41
|
+
* @returns {Promise<void>} A promise which resolves after processing the input.
|
|
42
|
+
* */
|
|
43
|
+
exceljsPostProcess?: (processInput: GridExceljsProcessInput) => Promise<void>;
|
|
44
|
+
/**
|
|
45
|
+
* Object mapping column field to Exceljs style
|
|
46
|
+
* */
|
|
47
|
+
columnsStyles?: ColumnsStylesInterface;
|
|
48
|
+
/**
|
|
49
|
+
* If `true`, the headers of the column groups will be added into the file.
|
|
50
|
+
* @default true
|
|
51
|
+
*/
|
|
52
|
+
includeColumnGroupsHeaders?: boolean;
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* The excel export API interface that is available in the grid [[apiRef]].
|
|
56
|
+
*/
|
|
57
|
+
export interface GridExcelExportApi {
|
|
58
|
+
/**
|
|
59
|
+
* Returns the grid data as an exceljs workbook.
|
|
60
|
+
* This method is used internally by `exportDataAsExcel`.
|
|
61
|
+
* @param {GridExcelExportOptions} options The options to apply on the export.
|
|
62
|
+
* @returns {Promise<Excel.Workbook>} The data in a exceljs workbook object.
|
|
63
|
+
*/
|
|
64
|
+
getDataAsExcel: (options?: GridExcelExportOptions) => Promise<Excel.Workbook> | null;
|
|
65
|
+
/**
|
|
66
|
+
* Downloads and exports an Excel file of the grid's data.
|
|
67
|
+
* @param {GridExcelExportOptions} options The options to apply on the export.
|
|
68
|
+
* @returns {Promise<void>} A promise which resolves after exporting to Excel.
|
|
69
|
+
*/
|
|
70
|
+
exportDataAsExcel: (options?: GridExcelExportOptions) => Promise<void>;
|
|
71
|
+
}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export * from "./gridExcelExportInterface.js";
|
|
2
|
-
export { setupExcelExportWebWorker } from "./serializer/
|
|
2
|
+
export { setupExcelExportWebWorker } from "./serializer/setupExcelExportWebWorker.js";
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import type * as Excel from 'exceljs';
|
|
2
|
+
import { RefObject } from '@mui/x-internals/types';
|
|
3
|
+
import { GridRowId, GridColDef } from '@mui/x-data-grid-pro';
|
|
4
|
+
import { GridStateColDef } from '@mui/x-data-grid/internals';
|
|
5
|
+
import { ColumnsStylesInterface, GridExcelExportOptions } from "../gridExcelExportInterface.js";
|
|
6
|
+
import { GridPrivateApiPremium } from "../../../../models/gridApiPremium.js";
|
|
7
|
+
import { SerializedColumns, SerializedRow, ValueOptionsData } from "./utils.js";
|
|
8
|
+
export type { ExcelExportInitEvent } from './utils';
|
|
9
|
+
/**
|
|
10
|
+
* FIXME: This function mutates the colspan info, but colspan info assumes that the columns
|
|
11
|
+
* passed to it are always consistent. In this case, the exported columns may differ from the
|
|
12
|
+
* actual rendered columns.
|
|
13
|
+
* The caller of this function MUST call `resetColSpan()` before and after usage.
|
|
14
|
+
*/
|
|
15
|
+
export declare const serializeRowUnsafe: (id: GridRowId, columns: GridStateColDef[], apiRef: RefObject<GridPrivateApiPremium>, defaultValueOptionsFormulae: {
|
|
16
|
+
[field: string]: {
|
|
17
|
+
address: string;
|
|
18
|
+
};
|
|
19
|
+
}, options: Pick<BuildExcelOptions, "escapeFormulas">) => SerializedRow;
|
|
20
|
+
export declare const serializeColumn: (column: GridColDef, columnsStyles: ColumnsStylesInterface) => {
|
|
21
|
+
key: string;
|
|
22
|
+
headerText: string;
|
|
23
|
+
width: number;
|
|
24
|
+
style: {
|
|
25
|
+
numFmt?: string | undefined;
|
|
26
|
+
font?: Partial<Excel.Font> | undefined;
|
|
27
|
+
alignment?: Partial<Excel.Alignment> | undefined;
|
|
28
|
+
protection?: Partial<Excel.Protection> | undefined;
|
|
29
|
+
border?: Partial<Excel.Borders> | undefined;
|
|
30
|
+
fill?: Excel.Fill | undefined;
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
export declare function serializeColumns(columns: GridStateColDef[], styles: ColumnsStylesInterface): SerializedColumns;
|
|
34
|
+
export declare function getDataForValueOptionsSheet(columns: GridStateColDef[], valueOptionsSheetName: string, api: GridPrivateApiPremium): Promise<ValueOptionsData>;
|
|
35
|
+
interface BuildExcelOptions extends Pick<GridExcelExportOptions, 'exceljsPreProcess' | 'exceljsPostProcess'>, Pick<Required<GridExcelExportOptions>, 'valueOptionsSheetName' | 'includeHeaders' | 'includeColumnGroupsHeaders' | 'escapeFormulas'> {
|
|
36
|
+
columns: GridStateColDef[];
|
|
37
|
+
rowIds: GridRowId[];
|
|
38
|
+
columnsStyles?: ColumnsStylesInterface;
|
|
39
|
+
}
|
|
40
|
+
export declare function buildExcel(options: BuildExcelOptions, apiRef: RefObject<GridPrivateApiPremium>): Promise<Excel.Workbook>;
|