material-react-table 2.0.0-beta.0 → 2.0.0-beta.10
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/README.md +1 -1
- package/dist/index.d.ts +281 -263
- package/dist/{esm/material-react-table.esm.js → index.esm.js} +1018 -968
- package/dist/index.esm.js.map +1 -0
- package/dist/{cjs/index.js → index.js} +1098 -1135
- package/dist/index.js.map +1 -0
- package/locales/ar.d.ts +1 -0
- package/locales/ar.js +0 -3
- package/locales/{ar.esm.js → ar.mjs} +0 -1
- package/locales/az.d.ts +3 -0
- package/locales/az.js +95 -0
- package/locales/az.mjs +93 -0
- package/locales/bg.d.ts +1 -0
- package/locales/bg.js +0 -3
- package/locales/{bg.esm.js → bg.mjs} +0 -1
- package/locales/cs.d.ts +1 -0
- package/locales/cs.js +0 -3
- package/locales/{cs.esm.js → cs.mjs} +0 -1
- package/locales/da.d.ts +1 -0
- package/locales/da.js +0 -3
- package/locales/{da.esm.js → da.mjs} +0 -1
- package/locales/de.d.ts +1 -0
- package/locales/de.js +0 -3
- package/locales/{de.esm.js → de.mjs} +0 -1
- package/locales/en.d.ts +1 -0
- package/locales/en.js +0 -3
- package/locales/{en.esm.js → en.mjs} +0 -1
- package/locales/es.d.ts +1 -0
- package/locales/es.js +0 -3
- package/locales/{es.esm.js → es.mjs} +0 -1
- package/locales/et.d.ts +1 -0
- package/locales/et.js +0 -3
- package/locales/{et.esm.js → et.mjs} +0 -1
- package/locales/fa.d.ts +1 -0
- package/locales/fa.js +0 -3
- package/locales/{fa.esm.js → fa.mjs} +0 -1
- package/locales/fi.d.ts +1 -0
- package/locales/fi.js +0 -3
- package/locales/{fi.esm.js → fi.mjs} +0 -1
- package/locales/fr.d.ts +1 -0
- package/locales/fr.js +0 -3
- package/locales/{fr.esm.js → fr.mjs} +0 -1
- package/locales/hu.d.ts +1 -0
- package/locales/hu.js +0 -3
- package/locales/{hu.esm.js → hu.mjs} +0 -1
- package/locales/hy.d.ts +1 -0
- package/locales/hy.js +0 -3
- package/locales/{hy.esm.js → hy.mjs} +0 -1
- package/locales/id.d.ts +1 -0
- package/locales/id.js +0 -3
- package/locales/{id.esm.js → id.mjs} +0 -1
- package/locales/it.d.ts +1 -0
- package/locales/it.js +0 -3
- package/locales/{it.esm.js → it.mjs} +0 -1
- package/locales/ja.d.ts +1 -0
- package/locales/ja.js +0 -3
- package/locales/{ja.esm.js → ja.mjs} +0 -1
- package/locales/ko.d.ts +1 -0
- package/locales/ko.js +0 -3
- package/locales/{ko.esm.js → ko.mjs} +0 -1
- package/locales/nl.d.ts +1 -0
- package/locales/nl.js +0 -3
- package/locales/{nl.esm.js → nl.mjs} +0 -1
- package/locales/no.d.ts +2 -1
- package/locales/no.js +0 -3
- package/locales/{no.esm.js → no.mjs} +0 -1
- package/locales/np.d.ts +1 -0
- package/locales/np.js +0 -3
- package/locales/{np.esm.js → np.mjs} +0 -1
- package/locales/pl.d.ts +1 -0
- package/locales/pl.js +0 -3
- package/locales/{pl.esm.js → pl.mjs} +0 -1
- package/locales/pt-BR.d.ts +1 -0
- package/locales/pt-BR.js +0 -3
- package/locales/{pt-BR.esm.js → pt-BR.mjs} +0 -1
- package/locales/pt.d.ts +1 -0
- package/locales/pt.js +0 -3
- package/locales/{pt.esm.js → pt.mjs} +0 -1
- package/locales/ro.d.ts +1 -0
- package/locales/ro.js +0 -3
- package/locales/{ro.esm.js → ro.mjs} +0 -1
- package/locales/ru.d.ts +1 -0
- package/locales/ru.js +0 -3
- package/locales/{ru.esm.js → ru.mjs} +0 -1
- package/locales/sk.d.ts +1 -0
- package/locales/sk.js +0 -3
- package/locales/{sk.esm.js → sk.mjs} +0 -1
- package/locales/sr-Cyrl-RS.d.ts +1 -0
- package/locales/sr-Cyrl-RS.js +0 -3
- package/locales/{sr-Cyrl-RS.esm.js → sr-Cyrl-RS.mjs} +0 -1
- package/locales/sr-Latn-RS.d.ts +1 -0
- package/locales/sr-Latn-RS.js +0 -3
- package/locales/{sr-Latn-RS.esm.js → sr-Latn-RS.mjs} +0 -1
- package/locales/sv.d.ts +1 -0
- package/locales/sv.js +0 -3
- package/locales/{sv.esm.js → sv.mjs} +0 -1
- package/locales/tr.d.ts +1 -0
- package/locales/tr.js +0 -3
- package/locales/{tr.esm.js → tr.mjs} +0 -1
- package/locales/uk.d.ts +1 -0
- package/locales/uk.js +0 -3
- package/locales/{uk.esm.js → uk.mjs} +0 -1
- package/locales/vi.d.ts +1 -0
- package/locales/vi.js +0 -3
- package/locales/{vi.esm.js → vi.mjs} +0 -1
- package/locales/zh-Hans.d.ts +1 -0
- package/locales/zh-Hans.js +17 -20
- package/locales/{zh-Hans.esm.js → zh-Hans.mjs} +17 -18
- package/locales/zh-Hant.d.ts +1 -0
- package/locales/zh-Hant.js +0 -3
- package/locales/{zh-Hant.esm.js → zh-Hant.mjs} +0 -1
- package/package.json +215 -32
- package/src/MaterialReactTable.tsx +5 -4
- package/src/body/MRT_TableBody.tsx +19 -8
- package/src/body/MRT_TableBodyCell.tsx +95 -74
- package/src/body/MRT_TableBodyCellValue.tsx +13 -9
- package/src/body/MRT_TableBodyRow.tsx +27 -16
- package/src/body/MRT_TableBodyRowGrabHandle.tsx +16 -7
- package/src/body/MRT_TableBodyRowPinButton.tsx +18 -7
- package/src/body/MRT_TableDetailPanel.tsx +20 -13
- package/src/buttons/MRT_ColumnPinningButtons.tsx +21 -8
- package/src/buttons/MRT_CopyButton.tsx +12 -11
- package/src/buttons/MRT_EditActionButtons.tsx +17 -7
- package/src/buttons/MRT_ExpandAllButton.tsx +13 -11
- package/src/buttons/MRT_ExpandButton.tsx +10 -8
- package/src/buttons/MRT_GrabHandleButton.tsx +10 -8
- package/src/buttons/MRT_RowPinButton.tsx +14 -7
- package/src/buttons/MRT_ShowHideColumnsButton.tsx +4 -4
- package/src/buttons/MRT_ToggleDensePaddingButton.tsx +4 -6
- package/src/buttons/MRT_ToggleFiltersButton.tsx +4 -4
- package/src/buttons/MRT_ToggleFullScreenButton.tsx +3 -4
- package/src/buttons/MRT_ToggleGlobalFilterButton.tsx +4 -6
- package/src/buttons/MRT_ToggleRowActionMenuButton.tsx +15 -9
- package/src/column.utils.ts +46 -141
- package/src/filterFns.ts +15 -14
- package/src/footer/MRT_TableFooter.tsx +11 -7
- package/src/footer/MRT_TableFooterCell.tsx +21 -16
- package/src/footer/MRT_TableFooterRow.tsx +14 -9
- package/src/head/MRT_TableHead.tsx +10 -6
- package/src/head/MRT_TableHeadCell.tsx +122 -103
- package/src/head/MRT_TableHeadCellColumnActionsButton.tsx +13 -12
- package/src/head/MRT_TableHeadCellFilterContainer.tsx +10 -6
- package/src/head/MRT_TableHeadCellFilterLabel.tsx +15 -9
- package/src/head/MRT_TableHeadCellGrabHandle.tsx +10 -3
- package/src/head/MRT_TableHeadCellResizeHandle.tsx +21 -11
- package/src/head/MRT_TableHeadCellSortLabel.tsx +38 -18
- package/src/head/MRT_TableHeadRow.tsx +15 -9
- package/src/hooks/useMRT_DisplayColumns.tsx +14 -10
- package/src/hooks/useMRT_Effects.ts +6 -2
- package/src/hooks/useMRT_TableInstance.ts +3 -2
- package/src/hooks/useMRT_TableOptions.ts +29 -4
- package/src/index.ts +1 -0
- package/src/inputs/MRT_EditCellTextField.tsx +26 -4
- package/src/inputs/MRT_FilterCheckbox.tsx +10 -5
- package/src/inputs/MRT_FilterRangeFields.tsx +19 -5
- package/src/inputs/MRT_FilterRangeSlider.tsx +10 -4
- package/src/inputs/MRT_FilterTextField.tsx +13 -5
- package/src/inputs/MRT_GlobalFilterTextField.tsx +27 -10
- package/src/inputs/MRT_SelectCheckbox.tsx +14 -7
- package/src/locales/az.ts +94 -0
- package/src/locales/no.ts +1 -1
- package/src/locales/zh-Hans.ts +17 -17
- package/src/menus/MRT_ColumnActionMenu.tsx +10 -4
- package/src/menus/MRT_FilterOptionMenu.tsx +6 -3
- package/src/menus/MRT_RowActionMenu.tsx +10 -4
- package/src/menus/MRT_ShowHideColumnsMenu.tsx +10 -4
- package/src/menus/MRT_ShowHideColumnsMenuItems.tsx +17 -10
- package/src/modals/MRT_EditRowModal.tsx +17 -11
- package/src/sortingFns.ts +3 -3
- package/src/style.utils.ts +149 -0
- package/src/table/MRT_Table.tsx +28 -34
- package/src/table/MRT_TableContainer.tsx +17 -46
- package/src/table/MRT_TableLoadingOverlay.tsx +54 -0
- package/src/table/MRT_TablePaper.tsx +13 -6
- package/src/table/index.ts +1 -0
- package/src/toolbar/MRT_BottomToolbar.tsx +16 -14
- package/src/toolbar/MRT_LinearProgressBar.tsx +16 -10
- package/src/toolbar/MRT_TablePagination.tsx +25 -12
- package/src/toolbar/MRT_ToolbarAlertBanner.tsx +11 -7
- package/src/toolbar/MRT_ToolbarDropZone.tsx +8 -4
- package/src/toolbar/MRT_ToolbarInternalButtons.tsx +10 -6
- package/src/toolbar/MRT_TopToolbar.tsx +11 -24
- package/src/types.ts +98 -56
- package/src/useMaterialReactTable.ts +8 -7
- package/dist/cjs/index.js.map +0 -1
- package/dist/cjs/types/MaterialReactTable.d.ts +0 -7
- package/dist/cjs/types/aggregationFns.d.ts +0 -11
- package/dist/cjs/types/body/MRT_TableBody.d.ts +0 -12
- package/dist/cjs/types/body/MRT_TableBodyCell.d.ts +0 -15
- package/dist/cjs/types/body/MRT_TableBodyCellValue.d.ts +0 -7
- package/dist/cjs/types/body/MRT_TableBodyRow.d.ts +0 -18
- package/dist/cjs/types/body/MRT_TableBodyRowGrabHandle.d.ts +0 -9
- package/dist/cjs/types/body/MRT_TableBodyRowPinButton.d.ts +0 -7
- package/dist/cjs/types/body/MRT_TableDetailPanel.d.ts +0 -12
- package/dist/cjs/types/body/index.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_ColumnPinningButtons.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_CopyButton.d.ts +0 -9
- package/dist/cjs/types/buttons/MRT_EditActionButtons.d.ts +0 -8
- package/dist/cjs/types/buttons/MRT_ExpandAllButton.d.ts +0 -6
- package/dist/cjs/types/buttons/MRT_ExpandButton.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_GrabHandleButton.d.ts +0 -12
- package/dist/cjs/types/buttons/MRT_RowPinButton.d.ts +0 -9
- package/dist/cjs/types/buttons/MRT_ShowHideColumnsButton.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_ToggleDensePaddingButton.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_ToggleFiltersButton.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_ToggleFullScreenButton.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_ToggleGlobalFilterButton.d.ts +0 -7
- package/dist/cjs/types/buttons/MRT_ToggleRowActionMenuButton.d.ts +0 -8
- package/dist/cjs/types/buttons/index.d.ts +0 -13
- package/dist/cjs/types/column.utils.d.ts +0 -148
- package/dist/cjs/types/filterFns.d.ts +0 -68
- package/dist/cjs/types/footer/MRT_TableFooter.d.ts +0 -10
- package/dist/cjs/types/footer/MRT_TableFooterCell.d.ts +0 -7
- package/dist/cjs/types/footer/MRT_TableFooterRow.d.ts +0 -11
- package/dist/cjs/types/footer/index.d.ts +0 -3
- package/dist/cjs/types/head/MRT_TableHead.d.ts +0 -10
- package/dist/cjs/types/head/MRT_TableHeadCell.d.ts +0 -7
- package/dist/cjs/types/head/MRT_TableHeadCellColumnActionsButton.d.ts +0 -7
- package/dist/cjs/types/head/MRT_TableHeadCellFilterContainer.d.ts +0 -7
- package/dist/cjs/types/head/MRT_TableHeadCellFilterLabel.d.ts +0 -7
- package/dist/cjs/types/head/MRT_TableHeadCellGrabHandle.d.ts +0 -9
- package/dist/cjs/types/head/MRT_TableHeadCellResizeHandle.d.ts +0 -7
- package/dist/cjs/types/head/MRT_TableHeadCellSortLabel.d.ts +0 -9
- package/dist/cjs/types/head/MRT_TableHeadRow.d.ts +0 -11
- package/dist/cjs/types/head/index.d.ts +0 -9
- package/dist/cjs/types/hooks/useMRT_DisplayColumns.d.ts +0 -9
- package/dist/cjs/types/hooks/useMRT_Effects.d.ts +0 -2
- package/dist/cjs/types/hooks/useMRT_TableInstance.d.ts +0 -2
- package/dist/cjs/types/hooks/useMRT_TableOptions.d.ts +0 -2
- package/dist/cjs/types/icons.d.ts +0 -36
- package/dist/cjs/types/index.d.ts +0 -16
- package/dist/cjs/types/inputs/MRT_EditCellTextField.d.ts +0 -7
- package/dist/cjs/types/inputs/MRT_FilterCheckbox.d.ts +0 -7
- package/dist/cjs/types/inputs/MRT_FilterRangeFields.d.ts +0 -7
- package/dist/cjs/types/inputs/MRT_FilterRangeSlider.d.ts +0 -7
- package/dist/cjs/types/inputs/MRT_FilterTextField.d.ts +0 -8
- package/dist/cjs/types/inputs/MRT_GlobalFilterTextField.d.ts +0 -6
- package/dist/cjs/types/inputs/MRT_SelectCheckbox.d.ts +0 -8
- package/dist/cjs/types/inputs/index.d.ts +0 -7
- package/dist/cjs/types/locales/ar.d.ts +0 -2
- package/dist/cjs/types/locales/bg.d.ts +0 -2
- package/dist/cjs/types/locales/cs.d.ts +0 -2
- package/dist/cjs/types/locales/da.d.ts +0 -2
- package/dist/cjs/types/locales/de.d.ts +0 -2
- package/dist/cjs/types/locales/en.d.ts +0 -2
- package/dist/cjs/types/locales/es.d.ts +0 -2
- package/dist/cjs/types/locales/et.d.ts +0 -2
- package/dist/cjs/types/locales/fa.d.ts +0 -2
- package/dist/cjs/types/locales/fi.d.ts +0 -2
- package/dist/cjs/types/locales/fr.d.ts +0 -2
- package/dist/cjs/types/locales/hu.d.ts +0 -2
- package/dist/cjs/types/locales/hy.d.ts +0 -2
- package/dist/cjs/types/locales/id.d.ts +0 -2
- package/dist/cjs/types/locales/it.d.ts +0 -2
- package/dist/cjs/types/locales/ja.d.ts +0 -2
- package/dist/cjs/types/locales/ko.d.ts +0 -2
- package/dist/cjs/types/locales/nl.d.ts +0 -2
- package/dist/cjs/types/locales/no.d.ts +0 -2
- package/dist/cjs/types/locales/np.d.ts +0 -2
- package/dist/cjs/types/locales/pl.d.ts +0 -2
- package/dist/cjs/types/locales/pt-BR.d.ts +0 -2
- package/dist/cjs/types/locales/pt.d.ts +0 -2
- package/dist/cjs/types/locales/ro.d.ts +0 -2
- package/dist/cjs/types/locales/ru.d.ts +0 -2
- package/dist/cjs/types/locales/sk.d.ts +0 -2
- package/dist/cjs/types/locales/sr-Cyrl-RS.d.ts +0 -2
- package/dist/cjs/types/locales/sr-Latn-RS.d.ts +0 -2
- package/dist/cjs/types/locales/sv.d.ts +0 -2
- package/dist/cjs/types/locales/tr.d.ts +0 -2
- package/dist/cjs/types/locales/uk.d.ts +0 -2
- package/dist/cjs/types/locales/vi.d.ts +0 -2
- package/dist/cjs/types/locales/zh-Hans.d.ts +0 -2
- package/dist/cjs/types/locales/zh-Hant.d.ts +0 -2
- package/dist/cjs/types/menus/MRT_ColumnActionMenu.d.ts +0 -19
- package/dist/cjs/types/menus/MRT_FilterOptionMenu.d.ts +0 -12
- package/dist/cjs/types/menus/MRT_RowActionMenu.d.ts +0 -11
- package/dist/cjs/types/menus/MRT_ShowHideColumnsMenu.d.ts +0 -9
- package/dist/cjs/types/menus/MRT_ShowHideColumnsMenuItems.d.ts +0 -11
- package/dist/cjs/types/menus/index.d.ts +0 -5
- package/dist/cjs/types/modals/MRT_EditRowModal.d.ts +0 -7
- package/dist/cjs/types/modals/index.d.ts +0 -1
- package/dist/cjs/types/sortingFns.d.ts +0 -12
- package/dist/cjs/types/table/MRT_Table.d.ts +0 -6
- package/dist/cjs/types/table/MRT_TableContainer.d.ts +0 -6
- package/dist/cjs/types/table/MRT_TablePaper.d.ts +0 -6
- package/dist/cjs/types/table/index.d.ts +0 -4
- package/dist/cjs/types/toolbar/MRT_BottomToolbar.d.ts +0 -6
- package/dist/cjs/types/toolbar/MRT_LinearProgressBar.d.ts +0 -7
- package/dist/cjs/types/toolbar/MRT_TablePagination.d.ts +0 -7
- package/dist/cjs/types/toolbar/MRT_ToolbarAlertBanner.d.ts +0 -7
- package/dist/cjs/types/toolbar/MRT_ToolbarDropZone.d.ts +0 -6
- package/dist/cjs/types/toolbar/MRT_ToolbarInternalButtons.d.ts +0 -6
- package/dist/cjs/types/toolbar/MRT_TopToolbar.d.ts +0 -21
- package/dist/cjs/types/toolbar/index.d.ts +0 -7
- package/dist/cjs/types/types.d.ts +0 -818
- package/dist/cjs/types/useMaterialReactTable.d.ts +0 -2
- package/dist/esm/material-react-table.esm.js.map +0 -1
- package/dist/esm/types/MaterialReactTable.d.ts +0 -7
- package/dist/esm/types/aggregationFns.d.ts +0 -11
- package/dist/esm/types/body/MRT_TableBody.d.ts +0 -12
- package/dist/esm/types/body/MRT_TableBodyCell.d.ts +0 -15
- package/dist/esm/types/body/MRT_TableBodyCellValue.d.ts +0 -7
- package/dist/esm/types/body/MRT_TableBodyRow.d.ts +0 -18
- package/dist/esm/types/body/MRT_TableBodyRowGrabHandle.d.ts +0 -9
- package/dist/esm/types/body/MRT_TableBodyRowPinButton.d.ts +0 -7
- package/dist/esm/types/body/MRT_TableDetailPanel.d.ts +0 -12
- package/dist/esm/types/body/index.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_ColumnPinningButtons.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_CopyButton.d.ts +0 -9
- package/dist/esm/types/buttons/MRT_EditActionButtons.d.ts +0 -8
- package/dist/esm/types/buttons/MRT_ExpandAllButton.d.ts +0 -6
- package/dist/esm/types/buttons/MRT_ExpandButton.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_GrabHandleButton.d.ts +0 -12
- package/dist/esm/types/buttons/MRT_RowPinButton.d.ts +0 -9
- package/dist/esm/types/buttons/MRT_ShowHideColumnsButton.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_ToggleDensePaddingButton.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_ToggleFiltersButton.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_ToggleFullScreenButton.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_ToggleGlobalFilterButton.d.ts +0 -7
- package/dist/esm/types/buttons/MRT_ToggleRowActionMenuButton.d.ts +0 -8
- package/dist/esm/types/buttons/index.d.ts +0 -13
- package/dist/esm/types/column.utils.d.ts +0 -148
- package/dist/esm/types/filterFns.d.ts +0 -68
- package/dist/esm/types/footer/MRT_TableFooter.d.ts +0 -10
- package/dist/esm/types/footer/MRT_TableFooterCell.d.ts +0 -7
- package/dist/esm/types/footer/MRT_TableFooterRow.d.ts +0 -11
- package/dist/esm/types/footer/index.d.ts +0 -3
- package/dist/esm/types/head/MRT_TableHead.d.ts +0 -10
- package/dist/esm/types/head/MRT_TableHeadCell.d.ts +0 -7
- package/dist/esm/types/head/MRT_TableHeadCellColumnActionsButton.d.ts +0 -7
- package/dist/esm/types/head/MRT_TableHeadCellFilterContainer.d.ts +0 -7
- package/dist/esm/types/head/MRT_TableHeadCellFilterLabel.d.ts +0 -7
- package/dist/esm/types/head/MRT_TableHeadCellGrabHandle.d.ts +0 -9
- package/dist/esm/types/head/MRT_TableHeadCellResizeHandle.d.ts +0 -7
- package/dist/esm/types/head/MRT_TableHeadCellSortLabel.d.ts +0 -9
- package/dist/esm/types/head/MRT_TableHeadRow.d.ts +0 -11
- package/dist/esm/types/head/index.d.ts +0 -9
- package/dist/esm/types/hooks/useMRT_DisplayColumns.d.ts +0 -9
- package/dist/esm/types/hooks/useMRT_Effects.d.ts +0 -2
- package/dist/esm/types/hooks/useMRT_TableInstance.d.ts +0 -2
- package/dist/esm/types/hooks/useMRT_TableOptions.d.ts +0 -2
- package/dist/esm/types/icons.d.ts +0 -36
- package/dist/esm/types/index.d.ts +0 -16
- package/dist/esm/types/inputs/MRT_EditCellTextField.d.ts +0 -7
- package/dist/esm/types/inputs/MRT_FilterCheckbox.d.ts +0 -7
- package/dist/esm/types/inputs/MRT_FilterRangeFields.d.ts +0 -7
- package/dist/esm/types/inputs/MRT_FilterRangeSlider.d.ts +0 -7
- package/dist/esm/types/inputs/MRT_FilterTextField.d.ts +0 -8
- package/dist/esm/types/inputs/MRT_GlobalFilterTextField.d.ts +0 -6
- package/dist/esm/types/inputs/MRT_SelectCheckbox.d.ts +0 -8
- package/dist/esm/types/inputs/index.d.ts +0 -7
- package/dist/esm/types/locales/ar.d.ts +0 -2
- package/dist/esm/types/locales/bg.d.ts +0 -2
- package/dist/esm/types/locales/cs.d.ts +0 -2
- package/dist/esm/types/locales/da.d.ts +0 -2
- package/dist/esm/types/locales/de.d.ts +0 -2
- package/dist/esm/types/locales/en.d.ts +0 -2
- package/dist/esm/types/locales/es.d.ts +0 -2
- package/dist/esm/types/locales/et.d.ts +0 -2
- package/dist/esm/types/locales/fa.d.ts +0 -2
- package/dist/esm/types/locales/fi.d.ts +0 -2
- package/dist/esm/types/locales/fr.d.ts +0 -2
- package/dist/esm/types/locales/hu.d.ts +0 -2
- package/dist/esm/types/locales/hy.d.ts +0 -2
- package/dist/esm/types/locales/id.d.ts +0 -2
- package/dist/esm/types/locales/it.d.ts +0 -2
- package/dist/esm/types/locales/ja.d.ts +0 -2
- package/dist/esm/types/locales/ko.d.ts +0 -2
- package/dist/esm/types/locales/nl.d.ts +0 -2
- package/dist/esm/types/locales/no.d.ts +0 -2
- package/dist/esm/types/locales/np.d.ts +0 -2
- package/dist/esm/types/locales/pl.d.ts +0 -2
- package/dist/esm/types/locales/pt-BR.d.ts +0 -2
- package/dist/esm/types/locales/pt.d.ts +0 -2
- package/dist/esm/types/locales/ro.d.ts +0 -2
- package/dist/esm/types/locales/ru.d.ts +0 -2
- package/dist/esm/types/locales/sk.d.ts +0 -2
- package/dist/esm/types/locales/sr-Cyrl-RS.d.ts +0 -2
- package/dist/esm/types/locales/sr-Latn-RS.d.ts +0 -2
- package/dist/esm/types/locales/sv.d.ts +0 -2
- package/dist/esm/types/locales/tr.d.ts +0 -2
- package/dist/esm/types/locales/uk.d.ts +0 -2
- package/dist/esm/types/locales/vi.d.ts +0 -2
- package/dist/esm/types/locales/zh-Hans.d.ts +0 -2
- package/dist/esm/types/locales/zh-Hant.d.ts +0 -2
- package/dist/esm/types/menus/MRT_ColumnActionMenu.d.ts +0 -19
- package/dist/esm/types/menus/MRT_FilterOptionMenu.d.ts +0 -12
- package/dist/esm/types/menus/MRT_RowActionMenu.d.ts +0 -11
- package/dist/esm/types/menus/MRT_ShowHideColumnsMenu.d.ts +0 -9
- package/dist/esm/types/menus/MRT_ShowHideColumnsMenuItems.d.ts +0 -11
- package/dist/esm/types/menus/index.d.ts +0 -5
- package/dist/esm/types/modals/MRT_EditRowModal.d.ts +0 -7
- package/dist/esm/types/modals/index.d.ts +0 -1
- package/dist/esm/types/sortingFns.d.ts +0 -12
- package/dist/esm/types/table/MRT_Table.d.ts +0 -6
- package/dist/esm/types/table/MRT_TableContainer.d.ts +0 -6
- package/dist/esm/types/table/MRT_TablePaper.d.ts +0 -6
- package/dist/esm/types/table/index.d.ts +0 -4
- package/dist/esm/types/toolbar/MRT_BottomToolbar.d.ts +0 -6
- package/dist/esm/types/toolbar/MRT_LinearProgressBar.d.ts +0 -7
- package/dist/esm/types/toolbar/MRT_TablePagination.d.ts +0 -7
- package/dist/esm/types/toolbar/MRT_ToolbarAlertBanner.d.ts +0 -7
- package/dist/esm/types/toolbar/MRT_ToolbarDropZone.d.ts +0 -6
- package/dist/esm/types/toolbar/MRT_ToolbarInternalButtons.d.ts +0 -6
- package/dist/esm/types/toolbar/MRT_TopToolbar.d.ts +0 -21
- package/dist/esm/types/toolbar/index.d.ts +0 -7
- package/dist/esm/types/types.d.ts +0 -818
- package/dist/esm/types/useMaterialReactTable.d.ts +0 -2
- package/locales/ar.esm.d.ts +0 -2
- package/locales/ar.esm.js.map +0 -1
- package/locales/ar.js.map +0 -1
- package/locales/bg.esm.d.ts +0 -2
- package/locales/bg.esm.js.map +0 -1
- package/locales/bg.js.map +0 -1
- package/locales/cs.esm.d.ts +0 -2
- package/locales/cs.esm.js.map +0 -1
- package/locales/cs.js.map +0 -1
- package/locales/da.esm.d.ts +0 -2
- package/locales/da.esm.js.map +0 -1
- package/locales/da.js.map +0 -1
- package/locales/de.esm.d.ts +0 -2
- package/locales/de.esm.js.map +0 -1
- package/locales/de.js.map +0 -1
- package/locales/en.esm.d.ts +0 -2
- package/locales/en.esm.js.map +0 -1
- package/locales/en.js.map +0 -1
- package/locales/es.esm.d.ts +0 -2
- package/locales/es.esm.js.map +0 -1
- package/locales/es.js.map +0 -1
- package/locales/et.esm.d.ts +0 -2
- package/locales/et.esm.js.map +0 -1
- package/locales/et.js.map +0 -1
- package/locales/fa.esm.d.ts +0 -2
- package/locales/fa.esm.js.map +0 -1
- package/locales/fa.js.map +0 -1
- package/locales/fi.esm.d.ts +0 -2
- package/locales/fi.esm.js.map +0 -1
- package/locales/fi.js.map +0 -1
- package/locales/fr.esm.d.ts +0 -2
- package/locales/fr.esm.js.map +0 -1
- package/locales/fr.js.map +0 -1
- package/locales/hu.esm.d.ts +0 -2
- package/locales/hu.esm.js.map +0 -1
- package/locales/hu.js.map +0 -1
- package/locales/hy.esm.d.ts +0 -2
- package/locales/hy.esm.js.map +0 -1
- package/locales/hy.js.map +0 -1
- package/locales/id.esm.d.ts +0 -2
- package/locales/id.esm.js.map +0 -1
- package/locales/id.js.map +0 -1
- package/locales/it.esm.d.ts +0 -2
- package/locales/it.esm.js.map +0 -1
- package/locales/it.js.map +0 -1
- package/locales/ja.esm.d.ts +0 -2
- package/locales/ja.esm.js.map +0 -1
- package/locales/ja.js.map +0 -1
- package/locales/ko.esm.d.ts +0 -2
- package/locales/ko.esm.js.map +0 -1
- package/locales/ko.js.map +0 -1
- package/locales/nl.esm.d.ts +0 -2
- package/locales/nl.esm.js.map +0 -1
- package/locales/nl.js.map +0 -1
- package/locales/no.esm.d.ts +0 -2
- package/locales/no.esm.js.map +0 -1
- package/locales/no.js.map +0 -1
- package/locales/np.esm.d.ts +0 -2
- package/locales/np.esm.js.map +0 -1
- package/locales/np.js.map +0 -1
- package/locales/pl.esm.d.ts +0 -2
- package/locales/pl.esm.js.map +0 -1
- package/locales/pl.js.map +0 -1
- package/locales/pt-BR.esm.d.ts +0 -2
- package/locales/pt-BR.esm.js.map +0 -1
- package/locales/pt-BR.js.map +0 -1
- package/locales/pt.esm.d.ts +0 -2
- package/locales/pt.esm.js.map +0 -1
- package/locales/pt.js.map +0 -1
- package/locales/ro.esm.d.ts +0 -2
- package/locales/ro.esm.js.map +0 -1
- package/locales/ro.js.map +0 -1
- package/locales/ru.esm.d.ts +0 -2
- package/locales/ru.esm.js.map +0 -1
- package/locales/ru.js.map +0 -1
- package/locales/sk.esm.d.ts +0 -2
- package/locales/sk.esm.js.map +0 -1
- package/locales/sk.js.map +0 -1
- package/locales/sr-Cyrl-RS.esm.d.ts +0 -2
- package/locales/sr-Cyrl-RS.esm.js.map +0 -1
- package/locales/sr-Cyrl-RS.js.map +0 -1
- package/locales/sr-Latn-RS.esm.d.ts +0 -2
- package/locales/sr-Latn-RS.esm.js.map +0 -1
- package/locales/sr-Latn-RS.js.map +0 -1
- package/locales/sv.esm.d.ts +0 -2
- package/locales/sv.esm.js.map +0 -1
- package/locales/sv.js.map +0 -1
- package/locales/tr.esm.d.ts +0 -2
- package/locales/tr.esm.js.map +0 -1
- package/locales/tr.js.map +0 -1
- package/locales/uk.esm.d.ts +0 -2
- package/locales/uk.esm.js.map +0 -1
- package/locales/uk.js.map +0 -1
- package/locales/vi.esm.d.ts +0 -2
- package/locales/vi.esm.js.map +0 -1
- package/locales/vi.js.map +0 -1
- package/locales/zh-Hans.esm.d.ts +0 -2
- package/locales/zh-Hans.esm.js.map +0 -1
- package/locales/zh-Hans.js.map +0 -1
- package/locales/zh-Hant.esm.d.ts +0 -2
- package/locales/zh-Hant.esm.js.map +0 -1
- package/locales/zh-Hant.js.map +0 -1
package/src/sortingFns.ts
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
import { type RankingInfo, compareItems } from '@tanstack/match-sorter-utils';
|
2
2
|
import { type Row, sortingFns } from '@tanstack/react-table';
|
3
|
-
import { type MRT_Row } from './types';
|
3
|
+
import { type MRT_Row, type MRT_RowData } from './types';
|
4
4
|
|
5
|
-
const fuzzy = <TData extends
|
5
|
+
const fuzzy = <TData extends MRT_RowData>(
|
6
6
|
rowA: Row<TData>,
|
7
7
|
rowB: Row<TData>,
|
8
8
|
columnId: string,
|
@@ -25,7 +25,7 @@ export const MRT_SortingFns = {
|
|
25
25
|
fuzzy,
|
26
26
|
};
|
27
27
|
|
28
|
-
export const rankGlobalFuzzy = <TData extends
|
28
|
+
export const rankGlobalFuzzy = <TData extends MRT_RowData>(
|
29
29
|
rowA: MRT_Row<TData>,
|
30
30
|
rowB: MRT_Row<TData>,
|
31
31
|
) =>
|
@@ -0,0 +1,149 @@
|
|
1
|
+
import { type CSSProperties } from 'react';
|
2
|
+
import { type TableCellProps } from '@mui/material/TableCell';
|
3
|
+
import { alpha, darken, lighten } from '@mui/material/styles';
|
4
|
+
import { type Theme } from '@mui/material/styles';
|
5
|
+
import {
|
6
|
+
getIsFirstRightPinnedColumn,
|
7
|
+
getIsLastLeftPinnedColumn,
|
8
|
+
getTotalRight,
|
9
|
+
parseFromValuesOrFunc,
|
10
|
+
} from './column.utils';
|
11
|
+
import {
|
12
|
+
type MRT_Column,
|
13
|
+
type MRT_Header,
|
14
|
+
type MRT_RowData,
|
15
|
+
type MRT_TableInstance,
|
16
|
+
} from './types';
|
17
|
+
|
18
|
+
export const parseCSSVarId = (id: string) => id.replace(/[^a-zA-Z0-9]/g, '_');
|
19
|
+
|
20
|
+
export const getMRTTheme = <TData extends MRT_RowData>(
|
21
|
+
table: MRT_TableInstance<TData>,
|
22
|
+
theme: Theme,
|
23
|
+
) => ({
|
24
|
+
baseBackgroundColor:
|
25
|
+
theme.palette.mode === 'dark'
|
26
|
+
? lighten(theme.palette.background.default, 0.05)
|
27
|
+
: theme.palette.background.default,
|
28
|
+
draggingBorderColor: theme.palette.primary.main,
|
29
|
+
matchHighlightColor:
|
30
|
+
theme.palette.mode === 'dark'
|
31
|
+
? darken(theme.palette.warning.dark, 0.25)
|
32
|
+
: lighten(theme.palette.warning.light, 0.5),
|
33
|
+
pinnedRowBackgroundColor: alpha(theme.palette.primary.main, 0.1),
|
34
|
+
selectedRowBackgroundColor: alpha(theme.palette.primary.main, 0.2),
|
35
|
+
...parseFromValuesOrFunc(table.options.mrtTheme, theme),
|
36
|
+
});
|
37
|
+
|
38
|
+
export const getCommonMRTCellStyles = <TData extends MRT_RowData>({
|
39
|
+
column,
|
40
|
+
header,
|
41
|
+
table,
|
42
|
+
tableCellProps,
|
43
|
+
theme,
|
44
|
+
}: {
|
45
|
+
column: MRT_Column<TData>;
|
46
|
+
header?: MRT_Header<TData>;
|
47
|
+
table: MRT_TableInstance<TData>;
|
48
|
+
tableCellProps: TableCellProps;
|
49
|
+
theme: Theme;
|
50
|
+
}) => {
|
51
|
+
const {
|
52
|
+
options: { layoutMode },
|
53
|
+
} = table;
|
54
|
+
const widthStyles: CSSProperties = {
|
55
|
+
minWidth: `max(calc(var(--${header ? 'header' : 'col'}-${parseCSSVarId(
|
56
|
+
header?.id ?? column.id,
|
57
|
+
)}-size) * 1px), ${column.columnDef.minSize ?? 30}px)`,
|
58
|
+
width: `calc(var(--${header ? 'header' : 'col'}-${parseCSSVarId(
|
59
|
+
header?.id ?? column.id,
|
60
|
+
)}-size) * 1px)`,
|
61
|
+
};
|
62
|
+
|
63
|
+
if (layoutMode === 'grid') {
|
64
|
+
widthStyles.flex = `var(--${header ? 'header' : 'col'}-${parseCSSVarId(
|
65
|
+
header?.id ?? column.id,
|
66
|
+
)}-size) 0 auto`;
|
67
|
+
} else if (layoutMode === 'grid-no-grow') {
|
68
|
+
widthStyles.flex = '0 0 auto';
|
69
|
+
}
|
70
|
+
|
71
|
+
return {
|
72
|
+
backgroundColor:
|
73
|
+
column.getIsPinned() && column.columnDef.columnDefType !== 'group'
|
74
|
+
? alpha(
|
75
|
+
darken(
|
76
|
+
getMRTTheme(table, theme).baseBackgroundColor,
|
77
|
+
theme.palette.mode === 'dark' ? 0.05 : 0.01,
|
78
|
+
),
|
79
|
+
0.97,
|
80
|
+
)
|
81
|
+
: 'inherit',
|
82
|
+
backgroundImage: 'inherit',
|
83
|
+
boxShadow: getIsLastLeftPinnedColumn(table, column)
|
84
|
+
? `-4px 0 8px -6px ${alpha(theme.palette.grey[700], 0.5)} inset`
|
85
|
+
: getIsFirstRightPinnedColumn(column)
|
86
|
+
? `4px 0 8px -6px ${alpha(theme.palette.grey[700], 0.5)} inset`
|
87
|
+
: undefined,
|
88
|
+
display: layoutMode?.startsWith('grid') ? 'flex' : undefined,
|
89
|
+
left:
|
90
|
+
column.getIsPinned() === 'left'
|
91
|
+
? `${column.getStart('left')}px`
|
92
|
+
: undefined,
|
93
|
+
ml:
|
94
|
+
table.options.enableColumnVirtualization &&
|
95
|
+
column.getIsPinned() === 'left' &&
|
96
|
+
column.getPinnedIndex() === 0
|
97
|
+
? `-${
|
98
|
+
column.getSize() *
|
99
|
+
(table.getState().columnPinning.left?.length ?? 1)
|
100
|
+
}px`
|
101
|
+
: undefined,
|
102
|
+
mr:
|
103
|
+
table.options.enableColumnVirtualization &&
|
104
|
+
column.getIsPinned() === 'right' &&
|
105
|
+
column.getPinnedIndex() === table.getVisibleLeafColumns().length - 1
|
106
|
+
? `-${
|
107
|
+
column.getSize() *
|
108
|
+
(table.getState().columnPinning.right?.length ?? 1) *
|
109
|
+
1.2
|
110
|
+
}px`
|
111
|
+
: undefined,
|
112
|
+
opacity:
|
113
|
+
table.getState().draggingColumn?.id === column.id ||
|
114
|
+
table.getState().hoveredColumn?.id === column.id
|
115
|
+
? 0.5
|
116
|
+
: 1,
|
117
|
+
position:
|
118
|
+
column.getIsPinned() && column.columnDef.columnDefType !== 'group'
|
119
|
+
? 'sticky'
|
120
|
+
: undefined,
|
121
|
+
right:
|
122
|
+
column.getIsPinned() === 'right'
|
123
|
+
? `${getTotalRight(table, column)}px`
|
124
|
+
: undefined,
|
125
|
+
transition: table.options.enableColumnVirtualization
|
126
|
+
? 'none'
|
127
|
+
: `padding 150ms ease-in-out`,
|
128
|
+
...widthStyles,
|
129
|
+
...(parseFromValuesOrFunc(tableCellProps?.sx, theme) as any),
|
130
|
+
};
|
131
|
+
};
|
132
|
+
|
133
|
+
export const getCommonToolbarStyles = <TData extends MRT_RowData>({
|
134
|
+
table,
|
135
|
+
theme,
|
136
|
+
}: {
|
137
|
+
table: MRT_TableInstance<TData>;
|
138
|
+
theme: Theme;
|
139
|
+
}) => ({
|
140
|
+
alignItems: 'flex-start',
|
141
|
+
backgroundColor: getMRTTheme(table, theme).baseBackgroundColor,
|
142
|
+
display: 'grid',
|
143
|
+
flexWrap: 'wrap-reverse',
|
144
|
+
minHeight: '3.5rem',
|
145
|
+
overflow: 'hidden',
|
146
|
+
position: 'relative',
|
147
|
+
transition: 'all 150ms ease-in-out',
|
148
|
+
zIndex: 1,
|
149
|
+
});
|
package/src/table/MRT_Table.tsx
CHANGED
@@ -4,23 +4,24 @@ import {
|
|
4
4
|
type Virtualizer,
|
5
5
|
useVirtualizer,
|
6
6
|
} from '@tanstack/react-virtual';
|
7
|
-
import Table from '@mui/material/Table';
|
7
|
+
import Table, { type TableProps } from '@mui/material/Table';
|
8
8
|
import { MRT_TableBody, Memo_MRT_TableBody } from '../body/MRT_TableBody';
|
9
9
|
import {
|
10
10
|
extraIndexRangeExtractor,
|
11
|
-
parseCSSVarId,
|
12
11
|
parseFromValuesOrFunc,
|
13
12
|
} from '../column.utils';
|
14
13
|
import { MRT_TableFooter } from '../footer/MRT_TableFooter';
|
15
14
|
import { MRT_TableHead } from '../head/MRT_TableHead';
|
16
|
-
import {
|
15
|
+
import { parseCSSVarId } from '../style.utils';
|
16
|
+
import { type MRT_RowData, type MRT_TableInstance } from '../types';
|
17
17
|
|
18
|
-
interface Props<TData extends
|
18
|
+
interface Props<TData extends MRT_RowData> extends TableProps {
|
19
19
|
table: MRT_TableInstance<TData>;
|
20
20
|
}
|
21
21
|
|
22
|
-
export const MRT_Table = <TData extends
|
22
|
+
export const MRT_Table = <TData extends MRT_RowData>({
|
23
23
|
table,
|
24
|
+
...rest
|
24
25
|
}: Props<TData>) => {
|
25
26
|
const {
|
26
27
|
getFlatHeaders,
|
@@ -30,7 +31,6 @@ export const MRT_Table = <TData extends Record<string, any>>({
|
|
30
31
|
columnVirtualizerOptions,
|
31
32
|
columns,
|
32
33
|
enableColumnPinning,
|
33
|
-
enableColumnResizing,
|
34
34
|
enableColumnVirtualization,
|
35
35
|
enableStickyHeader,
|
36
36
|
enableTableFooter,
|
@@ -50,7 +50,10 @@ export const MRT_Table = <TData extends Record<string, any>>({
|
|
50
50
|
isFullScreen,
|
51
51
|
} = getState();
|
52
52
|
|
53
|
-
const tableProps =
|
53
|
+
const tableProps = {
|
54
|
+
...parseFromValuesOrFunc(muiTableProps, { table }),
|
55
|
+
...rest,
|
56
|
+
};
|
54
57
|
|
55
58
|
const columnVirtualizerProps = parseFromValuesOrFunc(
|
56
59
|
columnVirtualizerOptions,
|
@@ -157,32 +160,23 @@ export const MRT_Table = <TData extends Record<string, any>>({
|
|
157
160
|
};
|
158
161
|
|
159
162
|
return (
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
columnVirtualizer={columnVirtualizer}
|
179
|
-
{...props}
|
180
|
-
/>
|
181
|
-
) : (
|
182
|
-
<MRT_TableBody columnVirtualizer={columnVirtualizer} {...props} />
|
183
|
-
)}
|
184
|
-
{enableTableFooter && <MRT_TableFooter {...props} />}
|
185
|
-
</Table>
|
186
|
-
</>
|
163
|
+
<Table
|
164
|
+
stickyHeader={enableStickyHeader || isFullScreen}
|
165
|
+
{...tableProps}
|
166
|
+
style={{ ...columnSizeVars, ...tableProps?.style }}
|
167
|
+
sx={(theme) => ({
|
168
|
+
borderCollapse: 'separate',
|
169
|
+
display: layoutMode?.startsWith('grid') ? 'grid' : undefined,
|
170
|
+
...(parseFromValuesOrFunc(tableProps?.sx, theme) as any),
|
171
|
+
})}
|
172
|
+
>
|
173
|
+
{enableTableHead && <MRT_TableHead {...props} />}
|
174
|
+
{memoMode === 'table-body' || columnSizingInfo.isResizingColumn ? (
|
175
|
+
<Memo_MRT_TableBody columnVirtualizer={columnVirtualizer} {...props} />
|
176
|
+
) : (
|
177
|
+
<MRT_TableBody columnVirtualizer={columnVirtualizer} {...props} />
|
178
|
+
)}
|
179
|
+
{enableTableFooter && <MRT_TableFooter {...props} />}
|
180
|
+
</Table>
|
187
181
|
);
|
188
182
|
};
|
@@ -1,22 +1,23 @@
|
|
1
1
|
import { useEffect, useLayoutEffect, useState } from 'react';
|
2
|
-
import
|
3
|
-
|
4
|
-
|
5
|
-
import { alpha, lighten } from '@mui/material/styles';
|
2
|
+
import TableContainer, {
|
3
|
+
type TableContainerProps,
|
4
|
+
} from '@mui/material/TableContainer';
|
6
5
|
import { MRT_Table } from './MRT_Table';
|
6
|
+
import { MRT_TableLoadingOverlay } from './MRT_TableLoadingOverlay';
|
7
7
|
import { parseFromValuesOrFunc } from '../column.utils';
|
8
8
|
import { MRT_EditRowModal } from '../modals';
|
9
|
-
import { type MRT_TableInstance } from '../types';
|
9
|
+
import { type MRT_RowData, type MRT_TableInstance } from '../types';
|
10
10
|
|
11
11
|
const useIsomorphicLayoutEffect =
|
12
12
|
typeof window !== 'undefined' ? useLayoutEffect : useEffect;
|
13
13
|
|
14
|
-
interface Props<TData extends
|
14
|
+
interface Props<TData extends MRT_RowData> extends TableContainerProps {
|
15
15
|
table: MRT_TableInstance<TData>;
|
16
16
|
}
|
17
17
|
|
18
|
-
export const MRT_TableContainer = <TData extends
|
18
|
+
export const MRT_TableContainer = <TData extends MRT_RowData>({
|
19
19
|
table,
|
20
|
+
...rest
|
20
21
|
}: Props<TData>) => {
|
21
22
|
const {
|
22
23
|
getState,
|
@@ -24,8 +25,6 @@ export const MRT_TableContainer = <TData extends Record<string, any>>({
|
|
24
25
|
createDisplayMode,
|
25
26
|
editDisplayMode,
|
26
27
|
enableStickyHeader,
|
27
|
-
localization,
|
28
|
-
muiCircularProgressProps,
|
29
28
|
muiTableContainerProps,
|
30
29
|
},
|
31
30
|
refs: { bottomToolbarRef, tableContainerRef, topToolbarRef },
|
@@ -39,18 +38,16 @@ export const MRT_TableContainer = <TData extends Record<string, any>>({
|
|
39
38
|
} = getState();
|
40
39
|
|
41
40
|
const loading =
|
42
|
-
(isLoading || showLoadingOverlay)
|
41
|
+
showLoadingOverlay !== false && (isLoading || showLoadingOverlay);
|
43
42
|
|
44
43
|
const [totalToolbarHeight, setTotalToolbarHeight] = useState(0);
|
45
44
|
|
46
|
-
const tableContainerProps =
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
{ table },
|
53
|
-
);
|
45
|
+
const tableContainerProps = {
|
46
|
+
...parseFromValuesOrFunc(muiTableContainerProps, {
|
47
|
+
table,
|
48
|
+
}),
|
49
|
+
...rest,
|
50
|
+
};
|
54
51
|
|
55
52
|
useIsomorphicLayoutEffect(() => {
|
56
53
|
const topToolbarHeight =
|
@@ -72,7 +69,7 @@ export const MRT_TableContainer = <TData extends Record<string, any>>({
|
|
72
69
|
return (
|
73
70
|
<TableContainer
|
74
71
|
aria-busy={loading}
|
75
|
-
aria-describedby=
|
72
|
+
aria-describedby={loading ? 'mrt-progress' : undefined}
|
76
73
|
{...tableContainerProps}
|
77
74
|
ref={(node: HTMLDivElement) => {
|
78
75
|
if (node) {
|
@@ -99,33 +96,7 @@ export const MRT_TableContainer = <TData extends Record<string, any>>({
|
|
99
96
|
...(parseFromValuesOrFunc(tableContainerProps?.sx, theme) as any),
|
100
97
|
})}
|
101
98
|
>
|
102
|
-
{loading ?
|
103
|
-
<Box
|
104
|
-
sx={(theme) => ({
|
105
|
-
alignItems: 'center',
|
106
|
-
backgroundColor: alpha(
|
107
|
-
lighten(theme.palette.background.paper, 0.05),
|
108
|
-
0.5,
|
109
|
-
),
|
110
|
-
bottom: 0,
|
111
|
-
display: 'flex',
|
112
|
-
justifyContent: 'center',
|
113
|
-
left: 0,
|
114
|
-
maxHeight: '100vh',
|
115
|
-
position: 'absolute',
|
116
|
-
right: 0,
|
117
|
-
top: 0,
|
118
|
-
width: '100%',
|
119
|
-
zIndex: 2,
|
120
|
-
})}
|
121
|
-
>
|
122
|
-
<CircularProgress
|
123
|
-
aria-label={localization.noRecordsToDisplay}
|
124
|
-
id="mrt-progress"
|
125
|
-
{...circularProgressProps}
|
126
|
-
/>
|
127
|
-
</Box>
|
128
|
-
) : null}
|
99
|
+
{loading ? <MRT_TableLoadingOverlay table={table} /> : null}
|
129
100
|
<MRT_Table table={table} />
|
130
101
|
{(createModalOpen || editModalOpen) && (
|
131
102
|
<MRT_EditRowModal open table={table} />
|
@@ -0,0 +1,54 @@
|
|
1
|
+
import Box from '@mui/material/Box';
|
2
|
+
import CircularProgress, {
|
3
|
+
type CircularProgressProps,
|
4
|
+
} from '@mui/material/CircularProgress';
|
5
|
+
import { alpha } from '@mui/material/styles';
|
6
|
+
import { parseFromValuesOrFunc } from '../column.utils';
|
7
|
+
import { getMRTTheme } from '../style.utils';
|
8
|
+
import { type MRT_RowData, type MRT_TableInstance } from '../types';
|
9
|
+
|
10
|
+
interface Props<TData extends MRT_RowData> extends CircularProgressProps {
|
11
|
+
table: MRT_TableInstance<TData>;
|
12
|
+
}
|
13
|
+
|
14
|
+
export const MRT_TableLoadingOverlay = <TData extends MRT_RowData>({
|
15
|
+
table,
|
16
|
+
...rest
|
17
|
+
}: Props<TData>) => {
|
18
|
+
const {
|
19
|
+
options: { localization, muiCircularProgressProps },
|
20
|
+
} = table;
|
21
|
+
|
22
|
+
const circularProgressProps = {
|
23
|
+
...parseFromValuesOrFunc(muiCircularProgressProps, { table }),
|
24
|
+
...rest,
|
25
|
+
};
|
26
|
+
|
27
|
+
return (
|
28
|
+
<Box
|
29
|
+
sx={(theme) => ({
|
30
|
+
alignItems: 'center',
|
31
|
+
backgroundColor: alpha(
|
32
|
+
getMRTTheme(table, theme).baseBackgroundColor,
|
33
|
+
0.5,
|
34
|
+
),
|
35
|
+
bottom: 0,
|
36
|
+
display: 'flex',
|
37
|
+
justifyContent: 'center',
|
38
|
+
left: 0,
|
39
|
+
maxHeight: '100vh',
|
40
|
+
position: 'absolute',
|
41
|
+
right: 0,
|
42
|
+
top: 0,
|
43
|
+
width: '100%',
|
44
|
+
zIndex: 2,
|
45
|
+
})}
|
46
|
+
>
|
47
|
+
<CircularProgress
|
48
|
+
aria-label={localization.noRecordsToDisplay}
|
49
|
+
id="mrt-progress"
|
50
|
+
{...circularProgressProps}
|
51
|
+
/>
|
52
|
+
</Box>
|
53
|
+
);
|
54
|
+
};
|
@@ -1,16 +1,18 @@
|
|
1
|
-
import Paper from '@mui/material/Paper';
|
1
|
+
import Paper, { type PaperProps } from '@mui/material/Paper';
|
2
2
|
import { MRT_TableContainer } from './MRT_TableContainer';
|
3
3
|
import { parseFromValuesOrFunc } from '../column.utils';
|
4
|
+
import { getMRTTheme } from '../style.utils';
|
4
5
|
import { MRT_BottomToolbar } from '../toolbar/MRT_BottomToolbar';
|
5
6
|
import { MRT_TopToolbar } from '../toolbar/MRT_TopToolbar';
|
6
|
-
import { type MRT_TableInstance } from '../types';
|
7
|
+
import { type MRT_RowData, type MRT_TableInstance } from '../types';
|
7
8
|
|
8
|
-
interface Props<TData extends
|
9
|
+
interface Props<TData extends MRT_RowData> extends PaperProps {
|
9
10
|
table: MRT_TableInstance<TData>;
|
10
11
|
}
|
11
12
|
|
12
|
-
export const MRT_TablePaper = <TData extends
|
13
|
+
export const MRT_TablePaper = <TData extends MRT_RowData>({
|
13
14
|
table,
|
15
|
+
...rest
|
14
16
|
}: Props<TData>) => {
|
15
17
|
const {
|
16
18
|
getState,
|
@@ -25,7 +27,10 @@ export const MRT_TablePaper = <TData extends Record<string, any>>({
|
|
25
27
|
} = table;
|
26
28
|
const { isFullScreen } = getState();
|
27
29
|
|
28
|
-
const tablePaperProps =
|
30
|
+
const tablePaperProps = {
|
31
|
+
...parseFromValuesOrFunc(muiTablePaperProps, { table }),
|
32
|
+
...rest,
|
33
|
+
};
|
29
34
|
|
30
35
|
return (
|
31
36
|
<Paper
|
@@ -52,12 +57,14 @@ export const MRT_TablePaper = <TData extends Record<string, any>>({
|
|
52
57
|
right: 0,
|
53
58
|
top: 0,
|
54
59
|
width: '100vw',
|
55
|
-
zIndex:
|
60
|
+
zIndex: 999,
|
56
61
|
}
|
57
62
|
: {}),
|
58
63
|
...tablePaperProps?.style,
|
59
64
|
}}
|
60
65
|
sx={(theme) => ({
|
66
|
+
backgroundColor: getMRTTheme(table, theme).baseBackgroundColor,
|
67
|
+
backgroundImage: 'unset',
|
61
68
|
overflow: 'hidden',
|
62
69
|
transition: 'all 100ms ease-in-out',
|
63
70
|
...(parseFromValuesOrFunc(tablePaperProps?.sx, theme) as any),
|
package/src/table/index.ts
CHANGED
@@ -1,21 +1,21 @@
|
|
1
|
-
import
|
2
|
-
import
|
3
|
-
import { alpha } from '@mui/material/styles';
|
1
|
+
import { alpha } from '@mui/material';
|
2
|
+
import Box, { type BoxProps } from '@mui/material/Box';
|
4
3
|
import useMediaQuery from '@mui/material/useMediaQuery';
|
5
4
|
import { MRT_LinearProgressBar } from './MRT_LinearProgressBar';
|
6
5
|
import { MRT_TablePagination } from './MRT_TablePagination';
|
7
6
|
import { MRT_ToolbarAlertBanner } from './MRT_ToolbarAlertBanner';
|
8
7
|
import { MRT_ToolbarDropZone } from './MRT_ToolbarDropZone';
|
9
|
-
import { commonToolbarStyles } from './MRT_TopToolbar';
|
10
8
|
import { parseFromValuesOrFunc } from '../column.utils';
|
11
|
-
import {
|
9
|
+
import { getCommonToolbarStyles } from '../style.utils';
|
10
|
+
import { type MRT_RowData, type MRT_TableInstance } from '../types';
|
12
11
|
|
13
|
-
interface Props<TData extends
|
12
|
+
interface Props<TData extends MRT_RowData> extends BoxProps {
|
14
13
|
table: MRT_TableInstance<TData>;
|
15
14
|
}
|
16
15
|
|
17
|
-
export const MRT_BottomToolbar = <TData extends
|
16
|
+
export const MRT_BottomToolbar = <TData extends MRT_RowData>({
|
18
17
|
table,
|
18
|
+
...rest
|
19
19
|
}: Props<TData>) => {
|
20
20
|
const {
|
21
21
|
getState,
|
@@ -33,13 +33,15 @@ export const MRT_BottomToolbar = <TData extends Record<string, any>>({
|
|
33
33
|
|
34
34
|
const isMobile = useMediaQuery('(max-width:720px)');
|
35
35
|
|
36
|
-
const toolbarProps =
|
36
|
+
const toolbarProps = {
|
37
|
+
...parseFromValuesOrFunc(muiBottomToolbarProps, { table }),
|
38
|
+
...rest,
|
39
|
+
};
|
37
40
|
|
38
41
|
const stackAlertBanner = isMobile || !!renderBottomToolbarCustomActions;
|
39
42
|
|
40
43
|
return (
|
41
|
-
<
|
42
|
-
variant="dense"
|
44
|
+
<Box
|
43
45
|
{...toolbarProps}
|
44
46
|
ref={(node: HTMLDivElement) => {
|
45
47
|
if (node) {
|
@@ -51,11 +53,11 @@ export const MRT_BottomToolbar = <TData extends Record<string, any>>({
|
|
51
53
|
}
|
52
54
|
}}
|
53
55
|
sx={(theme) => ({
|
54
|
-
...
|
56
|
+
...getCommonToolbarStyles({ table, theme }),
|
55
57
|
bottom: isFullScreen ? '0' : undefined,
|
56
58
|
boxShadow: `0 1px 2px -1px ${alpha(
|
57
|
-
theme.palette.
|
58
|
-
0.
|
59
|
+
theme.palette.grey[700],
|
60
|
+
0.5,
|
59
61
|
)} inset`,
|
60
62
|
left: 0,
|
61
63
|
position: isFullScreen ? 'fixed' : 'relative',
|
@@ -103,6 +105,6 @@ export const MRT_BottomToolbar = <TData extends Record<string, any>>({
|
|
103
105
|
)}
|
104
106
|
</Box>
|
105
107
|
</Box>
|
106
|
-
</
|
108
|
+
</Box>
|
107
109
|
);
|
108
110
|
};
|
@@ -1,31 +1,37 @@
|
|
1
1
|
import Collapse from '@mui/material/Collapse';
|
2
|
-
import LinearProgress
|
2
|
+
import LinearProgress, {
|
3
|
+
type LinearProgressProps,
|
4
|
+
} from '@mui/material/LinearProgress';
|
3
5
|
import { parseFromValuesOrFunc } from '../column.utils';
|
4
|
-
import { type MRT_TableInstance } from '../types';
|
6
|
+
import { type MRT_RowData, type MRT_TableInstance } from '../types';
|
5
7
|
|
6
|
-
interface Props<TData extends
|
8
|
+
interface Props<TData extends MRT_RowData> extends LinearProgressProps {
|
7
9
|
isTopToolbar: boolean;
|
8
10
|
table: MRT_TableInstance<TData>;
|
9
11
|
}
|
10
12
|
|
11
|
-
export const MRT_LinearProgressBar = <TData extends
|
13
|
+
export const MRT_LinearProgressBar = <TData extends MRT_RowData>({
|
12
14
|
isTopToolbar,
|
13
15
|
table,
|
16
|
+
...rest
|
14
17
|
}: Props<TData>) => {
|
15
18
|
const {
|
16
19
|
getState,
|
17
20
|
options: { muiLinearProgressProps },
|
18
21
|
} = table;
|
19
|
-
const { showProgressBars } = getState();
|
22
|
+
const { isSaving, showProgressBars } = getState();
|
20
23
|
|
21
|
-
const linearProgressProps =
|
22
|
-
|
23
|
-
|
24
|
-
|
24
|
+
const linearProgressProps = {
|
25
|
+
...parseFromValuesOrFunc(muiLinearProgressProps, {
|
26
|
+
isTopToolbar,
|
27
|
+
table,
|
28
|
+
}),
|
29
|
+
...rest,
|
30
|
+
};
|
25
31
|
|
26
32
|
return (
|
27
33
|
<Collapse
|
28
|
-
in={showProgressBars}
|
34
|
+
in={showProgressBars !== false && (showProgressBars || isSaving)}
|
29
35
|
mountOnEnter
|
30
36
|
sx={{
|
31
37
|
bottom: isTopToolbar ? 0 : undefined,
|