@kissesses/mantine-react-table-open 9.0.3
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/LICENSE +21 -0
- package/README.md +196 -0
- package/dist/index.cjs +3769 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +1488 -0
- package/dist/index.esm.d.mts +1488 -0
- package/dist/index.esm.mjs +3664 -0
- package/dist/index.esm.mjs.map +1 -0
- package/locales/ar/index.cjs +97 -0
- package/locales/ar/index.d.cts +3 -0
- package/locales/ar/index.esm.d.mts +3 -0
- package/locales/ar/index.esm.mjs +95 -0
- package/locales/ar/package.json +19 -0
- package/locales/az/index.cjs +97 -0
- package/locales/az/index.d.cts +3 -0
- package/locales/az/index.esm.d.mts +3 -0
- package/locales/az/index.esm.mjs +95 -0
- package/locales/az/package.json +19 -0
- package/locales/bg/index.cjs +97 -0
- package/locales/bg/index.d.cts +3 -0
- package/locales/bg/index.esm.d.mts +3 -0
- package/locales/bg/index.esm.mjs +95 -0
- package/locales/bg/package.json +19 -0
- package/locales/cs/index.cjs +97 -0
- package/locales/cs/index.d.cts +3 -0
- package/locales/cs/index.esm.d.mts +3 -0
- package/locales/cs/index.esm.mjs +95 -0
- package/locales/cs/package.json +19 -0
- package/locales/da/index.cjs +97 -0
- package/locales/da/index.d.cts +3 -0
- package/locales/da/index.esm.d.mts +3 -0
- package/locales/da/index.esm.mjs +95 -0
- package/locales/da/package.json +19 -0
- package/locales/de/index.cjs +97 -0
- package/locales/de/index.d.cts +3 -0
- package/locales/de/index.esm.d.mts +3 -0
- package/locales/de/index.esm.mjs +95 -0
- package/locales/de/package.json +19 -0
- package/locales/el/index.cjs +97 -0
- package/locales/el/index.d.cts +3 -0
- package/locales/el/index.esm.d.mts +3 -0
- package/locales/el/index.esm.mjs +95 -0
- package/locales/el/package.json +19 -0
- package/locales/en/index.cjs +97 -0
- package/locales/en/index.d.cts +3 -0
- package/locales/en/index.esm.d.mts +3 -0
- package/locales/en/index.esm.mjs +95 -0
- package/locales/en/package.json +19 -0
- package/locales/es/index.cjs +97 -0
- package/locales/es/index.d.cts +3 -0
- package/locales/es/index.esm.d.mts +3 -0
- package/locales/es/index.esm.mjs +95 -0
- package/locales/es/package.json +19 -0
- package/locales/et/index.cjs +97 -0
- package/locales/et/index.d.cts +3 -0
- package/locales/et/index.esm.d.mts +3 -0
- package/locales/et/index.esm.mjs +95 -0
- package/locales/et/package.json +19 -0
- package/locales/fa/index.cjs +97 -0
- package/locales/fa/index.d.cts +3 -0
- package/locales/fa/index.esm.d.mts +3 -0
- package/locales/fa/index.esm.mjs +95 -0
- package/locales/fa/package.json +19 -0
- package/locales/fi/index.cjs +97 -0
- package/locales/fi/index.d.cts +3 -0
- package/locales/fi/index.esm.d.mts +3 -0
- package/locales/fi/index.esm.mjs +95 -0
- package/locales/fi/package.json +19 -0
- package/locales/fr/index.cjs +97 -0
- package/locales/fr/index.d.cts +3 -0
- package/locales/fr/index.esm.d.mts +3 -0
- package/locales/fr/index.esm.mjs +95 -0
- package/locales/fr/package.json +19 -0
- package/locales/he/index.cjs +97 -0
- package/locales/he/index.d.cts +3 -0
- package/locales/he/index.esm.d.mts +3 -0
- package/locales/he/index.esm.mjs +95 -0
- package/locales/he/package.json +19 -0
- package/locales/hr/index.cjs +97 -0
- package/locales/hr/index.d.cts +3 -0
- package/locales/hr/index.esm.d.mts +3 -0
- package/locales/hr/index.esm.mjs +95 -0
- package/locales/hr/package.json +19 -0
- package/locales/hu/index.cjs +97 -0
- package/locales/hu/index.d.cts +3 -0
- package/locales/hu/index.esm.d.mts +3 -0
- package/locales/hu/index.esm.mjs +95 -0
- package/locales/hu/package.json +19 -0
- package/locales/hy/index.cjs +97 -0
- package/locales/hy/index.d.cts +3 -0
- package/locales/hy/index.esm.d.mts +3 -0
- package/locales/hy/index.esm.mjs +95 -0
- package/locales/hy/package.json +19 -0
- package/locales/id/index.cjs +97 -0
- package/locales/id/index.d.cts +3 -0
- package/locales/id/index.esm.d.mts +3 -0
- package/locales/id/index.esm.mjs +95 -0
- package/locales/id/package.json +19 -0
- package/locales/it/index.cjs +97 -0
- package/locales/it/index.d.cts +3 -0
- package/locales/it/index.esm.d.mts +3 -0
- package/locales/it/index.esm.mjs +95 -0
- package/locales/it/package.json +19 -0
- package/locales/ja/index.cjs +97 -0
- package/locales/ja/index.d.cts +3 -0
- package/locales/ja/index.esm.d.mts +3 -0
- package/locales/ja/index.esm.mjs +95 -0
- package/locales/ja/package.json +19 -0
- package/locales/ko/index.cjs +97 -0
- package/locales/ko/index.d.cts +3 -0
- package/locales/ko/index.esm.d.mts +3 -0
- package/locales/ko/index.esm.mjs +95 -0
- package/locales/ko/package.json +19 -0
- package/locales/nl/index.cjs +97 -0
- package/locales/nl/index.d.cts +3 -0
- package/locales/nl/index.esm.d.mts +3 -0
- package/locales/nl/index.esm.mjs +95 -0
- package/locales/nl/package.json +19 -0
- package/locales/no/index.cjs +97 -0
- package/locales/no/index.d.cts +3 -0
- package/locales/no/index.esm.d.mts +3 -0
- package/locales/no/index.esm.mjs +95 -0
- package/locales/no/package.json +19 -0
- package/locales/np/index.cjs +97 -0
- package/locales/np/index.d.cts +3 -0
- package/locales/np/index.esm.d.mts +3 -0
- package/locales/np/index.esm.mjs +95 -0
- package/locales/np/package.json +19 -0
- package/locales/pl/index.cjs +97 -0
- package/locales/pl/index.d.cts +3 -0
- package/locales/pl/index.esm.d.mts +3 -0
- package/locales/pl/index.esm.mjs +95 -0
- package/locales/pl/package.json +19 -0
- package/locales/pt/index.cjs +97 -0
- package/locales/pt/index.d.cts +3 -0
- package/locales/pt/index.esm.d.mts +3 -0
- package/locales/pt/index.esm.mjs +95 -0
- package/locales/pt/package.json +19 -0
- package/locales/pt-BR/index.cjs +97 -0
- package/locales/pt-BR/index.d.cts +3 -0
- package/locales/pt-BR/index.esm.d.mts +3 -0
- package/locales/pt-BR/index.esm.mjs +95 -0
- package/locales/pt-BR/package.json +19 -0
- package/locales/ro/index.cjs +97 -0
- package/locales/ro/index.d.cts +3 -0
- package/locales/ro/index.esm.d.mts +3 -0
- package/locales/ro/index.esm.mjs +95 -0
- package/locales/ro/package.json +19 -0
- package/locales/ru/index.cjs +97 -0
- package/locales/ru/index.d.cts +3 -0
- package/locales/ru/index.esm.d.mts +3 -0
- package/locales/ru/index.esm.mjs +95 -0
- package/locales/ru/package.json +19 -0
- package/locales/sk/index.cjs +97 -0
- package/locales/sk/index.d.cts +3 -0
- package/locales/sk/index.esm.d.mts +3 -0
- package/locales/sk/index.esm.mjs +95 -0
- package/locales/sk/package.json +19 -0
- package/locales/sr-Cyrl-RS/index.cjs +97 -0
- package/locales/sr-Cyrl-RS/index.d.cts +3 -0
- package/locales/sr-Cyrl-RS/index.esm.d.mts +3 -0
- package/locales/sr-Cyrl-RS/index.esm.mjs +95 -0
- package/locales/sr-Cyrl-RS/package.json +19 -0
- package/locales/sr-Latn-RS/index.cjs +97 -0
- package/locales/sr-Latn-RS/index.d.cts +3 -0
- package/locales/sr-Latn-RS/index.esm.d.mts +3 -0
- package/locales/sr-Latn-RS/index.esm.mjs +95 -0
- package/locales/sr-Latn-RS/package.json +19 -0
- package/locales/sv/index.cjs +97 -0
- package/locales/sv/index.d.cts +3 -0
- package/locales/sv/index.esm.d.mts +3 -0
- package/locales/sv/index.esm.mjs +95 -0
- package/locales/sv/package.json +19 -0
- package/locales/tr/index.cjs +97 -0
- package/locales/tr/index.d.cts +3 -0
- package/locales/tr/index.esm.d.mts +3 -0
- package/locales/tr/index.esm.mjs +95 -0
- package/locales/tr/package.json +19 -0
- package/locales/uk/index.cjs +97 -0
- package/locales/uk/index.d.cts +3 -0
- package/locales/uk/index.esm.d.mts +3 -0
- package/locales/uk/index.esm.mjs +95 -0
- package/locales/uk/package.json +19 -0
- package/locales/vi/index.cjs +97 -0
- package/locales/vi/index.d.cts +3 -0
- package/locales/vi/index.esm.d.mts +3 -0
- package/locales/vi/index.esm.mjs +95 -0
- package/locales/vi/package.json +19 -0
- package/locales/zh-Hans/index.cjs +97 -0
- package/locales/zh-Hans/index.d.cts +3 -0
- package/locales/zh-Hans/index.esm.d.mts +3 -0
- package/locales/zh-Hans/index.esm.mjs +95 -0
- package/locales/zh-Hans/package.json +19 -0
- package/locales/zh-Hant/index.cjs +97 -0
- package/locales/zh-Hant/index.d.cts +3 -0
- package/locales/zh-Hant/index.esm.d.mts +3 -0
- package/locales/zh-Hant/index.esm.mjs +95 -0
- package/locales/zh-Hant/package.json +19 -0
- package/package.json +154 -0
- package/src/components/MantineReactTable.tsx +37 -0
- package/src/components/body/MRT_TableBody.module.css +42 -0
- package/src/components/body/MRT_TableBody.tsx +215 -0
- package/src/components/body/MRT_TableBodyCell.module.css +107 -0
- package/src/components/body/MRT_TableBodyCell.tsx +351 -0
- package/src/components/body/MRT_TableBodyCellValue.tsx +113 -0
- package/src/components/body/MRT_TableBodyEmptyRow.tsx +110 -0
- package/src/components/body/MRT_TableBodyRow.module.css +252 -0
- package/src/components/body/MRT_TableBodyRow.tsx +263 -0
- package/src/components/body/MRT_TableBodyRowGrabHandle.tsx +58 -0
- package/src/components/body/MRT_TableBodyRowPinButton.tsx +58 -0
- package/src/components/body/MRT_TableDetailPanel.module.css +35 -0
- package/src/components/body/MRT_TableDetailPanel.tsx +131 -0
- package/src/components/buttons/MRT_ColumnPinningButtons.module.css +11 -0
- package/src/components/buttons/MRT_ColumnPinningButtons.tsx +68 -0
- package/src/components/buttons/MRT_CopyButton.module.css +27 -0
- package/src/components/buttons/MRT_CopyButton.tsx +83 -0
- package/src/components/buttons/MRT_EditActionButtons.module.css +4 -0
- package/src/components/buttons/MRT_EditActionButtons.tsx +128 -0
- package/src/components/buttons/MRT_ExpandAllButton.module.css +26 -0
- package/src/components/buttons/MRT_ExpandAllButton.tsx +83 -0
- package/src/components/buttons/MRT_ExpandButton.module.css +37 -0
- package/src/components/buttons/MRT_ExpandButton.tsx +120 -0
- package/src/components/buttons/MRT_GrabHandleButton.module.css +6 -0
- package/src/components/buttons/MRT_GrabHandleButton.tsx +64 -0
- package/src/components/buttons/MRT_RowPinButton.tsx +83 -0
- package/src/components/buttons/MRT_ShowHideColumnsButton.tsx +45 -0
- package/src/components/buttons/MRT_ToggleDensePaddingButton.tsx +65 -0
- package/src/components/buttons/MRT_ToggleFiltersButton.tsx +44 -0
- package/src/components/buttons/MRT_ToggleFullScreenButton.tsx +58 -0
- package/src/components/buttons/MRT_ToggleGlobalFilterButton.tsx +51 -0
- package/src/components/buttons/MRT_ToggleRowActionMenuButton.tsx +86 -0
- package/src/components/footer/MRT_TableFooter.module.css +17 -0
- package/src/components/footer/MRT_TableFooter.tsx +72 -0
- package/src/components/footer/MRT_TableFooterCell.module.css +50 -0
- package/src/components/footer/MRT_TableFooterCell.tsx +122 -0
- package/src/components/footer/MRT_TableFooterRow.module.css +10 -0
- package/src/components/footer/MRT_TableFooterRow.tsx +94 -0
- package/src/components/head/MRT_TableHead.module.css +32 -0
- package/src/components/head/MRT_TableHead.tsx +108 -0
- package/src/components/head/MRT_TableHeadCell.module.css +163 -0
- package/src/components/head/MRT_TableHeadCell.tsx +322 -0
- package/src/components/head/MRT_TableHeadCellFilterContainer.module.css +5 -0
- package/src/components/head/MRT_TableHeadCellFilterContainer.tsx +147 -0
- package/src/components/head/MRT_TableHeadCellFilterLabel.module.css +14 -0
- package/src/components/head/MRT_TableHeadCellFilterLabel.tsx +171 -0
- package/src/components/head/MRT_TableHeadCellGrabHandle.tsx +81 -0
- package/src/components/head/MRT_TableHeadCellResizeHandle.module.css +44 -0
- package/src/components/head/MRT_TableHeadCellResizeHandle.tsx +67 -0
- package/src/components/head/MRT_TableHeadCellSortLabel.module.css +22 -0
- package/src/components/head/MRT_TableHeadCellSortLabel.tsx +89 -0
- package/src/components/head/MRT_TableHeadRow.module.css +12 -0
- package/src/components/head/MRT_TableHeadRow.tsx +87 -0
- package/src/components/inputs/MRT_EditCellTextInput.tsx +218 -0
- package/src/components/inputs/MRT_FilterCheckBox.module.css +4 -0
- package/src/components/inputs/MRT_FilterCheckbox.tsx +79 -0
- package/src/components/inputs/MRT_FilterRangeFields.module.css +5 -0
- package/src/components/inputs/MRT_FilterRangeFields.tsx +35 -0
- package/src/components/inputs/MRT_FilterRangeSlider.module.css +6 -0
- package/src/components/inputs/MRT_FilterRangeSlider.tsx +106 -0
- package/src/components/inputs/MRT_FilterTextInput.module.css +27 -0
- package/src/components/inputs/MRT_FilterTextInput.tsx +417 -0
- package/src/components/inputs/MRT_GlobalFilterTextInput.module.css +11 -0
- package/src/components/inputs/MRT_GlobalFilterTextInput.tsx +141 -0
- package/src/components/inputs/MRT_SelectCheckbox.tsx +137 -0
- package/src/components/menus/MRT_ColumnActionMenu.module.css +7 -0
- package/src/components/menus/MRT_ColumnActionMenu.tsx +287 -0
- package/src/components/menus/MRT_FilterOptionMenu.module.css +6 -0
- package/src/components/menus/MRT_FilterOptionMenu.tsx +274 -0
- package/src/components/menus/MRT_RowActionMenu.tsx +74 -0
- package/src/components/menus/MRT_ShowHideColumnsMenu.module.css +10 -0
- package/src/components/menus/MRT_ShowHideColumnsMenu.tsx +135 -0
- package/src/components/menus/MRT_ShowHideColumnsMenuItems.module.css +35 -0
- package/src/components/menus/MRT_ShowHideColumnsMenuItems.tsx +170 -0
- package/src/components/modals/MRT_EditRowModal.tsx +97 -0
- package/src/components/table/MRT_Table.module.css +7 -0
- package/src/components/table/MRT_Table.tsx +110 -0
- package/src/components/table/MRT_TableContainer.module.css +20 -0
- package/src/components/table/MRT_TableContainer.tsx +109 -0
- package/src/components/table/MRT_TablePaper.module.css +88 -0
- package/src/components/table/MRT_TablePaper.tsx +92 -0
- package/src/components/toolbar/MRT_BottomToolbar.module.css +40 -0
- package/src/components/toolbar/MRT_BottomToolbar.tsx +100 -0
- package/src/components/toolbar/MRT_ProgressBar.module.css +10 -0
- package/src/components/toolbar/MRT_ProgressBar.tsx +53 -0
- package/src/components/toolbar/MRT_TablePagination.module.css +20 -0
- package/src/components/toolbar/MRT_TablePagination.tsx +166 -0
- package/src/components/toolbar/MRT_ToolbarAlertBanner.module.css +37 -0
- package/src/components/toolbar/MRT_ToolbarAlertBanner.tsx +168 -0
- package/src/components/toolbar/MRT_ToolbarDropZone.module.css +23 -0
- package/src/components/toolbar/MRT_ToolbarDropZone.tsx +67 -0
- package/src/components/toolbar/MRT_ToolbarInternalButtons.module.css +6 -0
- package/src/components/toolbar/MRT_ToolbarInternalButtons.tsx +73 -0
- package/src/components/toolbar/MRT_TopToolbar.module.css +24 -0
- package/src/components/toolbar/MRT_TopToolbar.tsx +128 -0
- package/src/components/toolbar/common.styles.module.css +10 -0
- package/src/fns/aggregationFns.ts +3 -0
- package/src/fns/filterFns.ts +272 -0
- package/src/fns/sortingFns.ts +34 -0
- package/src/hooks/display-columns/getMRT_RowActionsColumnDef.tsx +23 -0
- package/src/hooks/display-columns/getMRT_RowDragColumnDef.tsx +30 -0
- package/src/hooks/display-columns/getMRT_RowExpandColumnDef.tsx +92 -0
- package/src/hooks/display-columns/getMRT_RowNumbersColumnDef.tsx +30 -0
- package/src/hooks/display-columns/getMRT_RowPinningColumnDef.tsx +24 -0
- package/src/hooks/display-columns/getMRT_RowSelectColumnDef.tsx +34 -0
- package/src/hooks/display-columns/getMRT_RowSpacerColumnDef.tsx +34 -0
- package/src/hooks/useMRT_ColumnVirtualizer.ts +129 -0
- package/src/hooks/useMRT_Effects.ts +105 -0
- package/src/hooks/useMRT_RowVirtualizer.ts +95 -0
- package/src/hooks/useMRT_Rows.ts +46 -0
- package/src/hooks/useMRT_TableInstance.ts +314 -0
- package/src/hooks/useMRT_TableOptions.ts +264 -0
- package/src/hooks/useMantineReactTable.ts +14 -0
- package/src/icons.ts +73 -0
- package/src/index.ts +90 -0
- package/src/locales/ar.ts +96 -0
- package/src/locales/az.ts +96 -0
- package/src/locales/bg.ts +96 -0
- package/src/locales/cs.ts +97 -0
- package/src/locales/da.ts +96 -0
- package/src/locales/de.ts +96 -0
- package/src/locales/el.ts +96 -0
- package/src/locales/en.ts +96 -0
- package/src/locales/es.ts +96 -0
- package/src/locales/et.ts +97 -0
- package/src/locales/fa.ts +96 -0
- package/src/locales/fi.ts +97 -0
- package/src/locales/fr.ts +96 -0
- package/src/locales/he.ts +96 -0
- package/src/locales/hr.ts +96 -0
- package/src/locales/hu.ts +96 -0
- package/src/locales/hy.ts +96 -0
- package/src/locales/id.ts +97 -0
- package/src/locales/it.ts +96 -0
- package/src/locales/ja.ts +96 -0
- package/src/locales/ko.ts +96 -0
- package/src/locales/nl.ts +96 -0
- package/src/locales/no.ts +97 -0
- package/src/locales/np.ts +97 -0
- package/src/locales/pl.ts +96 -0
- package/src/locales/pt-BR.ts +96 -0
- package/src/locales/pt.ts +96 -0
- package/src/locales/ro.ts +96 -0
- package/src/locales/ru.ts +96 -0
- package/src/locales/sk.ts +97 -0
- package/src/locales/sr-Cyrl-RS.ts +96 -0
- package/src/locales/sr-Latn-RS.ts +96 -0
- package/src/locales/sv.ts +96 -0
- package/src/locales/tr.ts +96 -0
- package/src/locales/uk.ts +96 -0
- package/src/locales/vi.ts +96 -0
- package/src/locales/zh-Hans.ts +95 -0
- package/src/locales/zh-Hant.ts +95 -0
- package/src/types.ts +1276 -0
- package/src/typings.d.ts +1 -0
- package/src/utils/column.utils.ts +124 -0
- package/src/utils/displayColumn.utils.ts +153 -0
- package/src/utils/row.utils.ts +263 -0
- package/src/utils/style.utils.ts +32 -0
- package/src/utils/tanstack.helpers.ts +66 -0
- package/src/utils/utils.ts +4 -0
- package/src/utils/virtualization.utils.ts +19 -0
- package/styles.css +1320 -0
package/src/typings.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
declare module '*.module.css';
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { type Row } from '@tanstack/react-table';
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
type MRT_Column,
|
|
5
|
+
type MRT_ColumnDef,
|
|
6
|
+
type MRT_ColumnOrderState,
|
|
7
|
+
type MRT_DefinedColumnDef,
|
|
8
|
+
type MRT_DefinedTableOptions,
|
|
9
|
+
type MRT_FilterOption,
|
|
10
|
+
type MRT_RowData,
|
|
11
|
+
} from '../types';
|
|
12
|
+
|
|
13
|
+
export const getColumnId = <TData extends MRT_RowData>(
|
|
14
|
+
columnDef: MRT_ColumnDef<TData>,
|
|
15
|
+
): string =>
|
|
16
|
+
columnDef.id ?? columnDef.accessorKey?.toString?.() ?? columnDef.header;
|
|
17
|
+
|
|
18
|
+
export const getAllLeafColumnDefs = <TData extends MRT_RowData>(
|
|
19
|
+
columns: MRT_ColumnDef<TData>[],
|
|
20
|
+
): MRT_ColumnDef<TData>[] => {
|
|
21
|
+
const allLeafColumnDefs: MRT_ColumnDef<TData>[] = [];
|
|
22
|
+
const getLeafColumns = (cols: MRT_ColumnDef<TData>[]) => {
|
|
23
|
+
cols.forEach((col) => {
|
|
24
|
+
if (col.columns) {
|
|
25
|
+
getLeafColumns(col.columns);
|
|
26
|
+
} else {
|
|
27
|
+
allLeafColumnDefs.push(col);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
};
|
|
31
|
+
getLeafColumns(columns);
|
|
32
|
+
return allLeafColumnDefs;
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
export const prepareColumns = <TData extends MRT_RowData>({
|
|
36
|
+
columnDefs,
|
|
37
|
+
tableOptions,
|
|
38
|
+
}: {
|
|
39
|
+
columnDefs: MRT_ColumnDef<TData>[];
|
|
40
|
+
tableOptions: MRT_DefinedTableOptions<TData>;
|
|
41
|
+
}): MRT_DefinedColumnDef<TData>[] => {
|
|
42
|
+
const {
|
|
43
|
+
aggregationFns = {},
|
|
44
|
+
defaultDisplayColumn,
|
|
45
|
+
filterFns = {},
|
|
46
|
+
sortingFns = {},
|
|
47
|
+
state: { columnFilterFns = {} } = {},
|
|
48
|
+
} = tableOptions;
|
|
49
|
+
return columnDefs.map((columnDef) => {
|
|
50
|
+
//assign columnId
|
|
51
|
+
if (!columnDef.id) columnDef.id = getColumnId(columnDef);
|
|
52
|
+
//assign columnDefType
|
|
53
|
+
if (!columnDef.columnDefType) columnDef.columnDefType = 'data';
|
|
54
|
+
if (columnDef.columns?.length) {
|
|
55
|
+
columnDef.columnDefType = 'group';
|
|
56
|
+
//recursively prepare columns if this is a group column
|
|
57
|
+
columnDef.columns = prepareColumns({
|
|
58
|
+
columnDefs: columnDef.columns,
|
|
59
|
+
tableOptions,
|
|
60
|
+
});
|
|
61
|
+
} else if (columnDef.columnDefType === 'data') {
|
|
62
|
+
//assign aggregationFns if multiple aggregationFns are provided
|
|
63
|
+
if (Array.isArray(columnDef.aggregationFn)) {
|
|
64
|
+
const aggFns = columnDef.aggregationFn as string[];
|
|
65
|
+
columnDef.aggregationFn = (
|
|
66
|
+
columnId: string,
|
|
67
|
+
leafRows: Row<TData>[],
|
|
68
|
+
childRows: Row<TData>[],
|
|
69
|
+
) =>
|
|
70
|
+
aggFns.map((fn) =>
|
|
71
|
+
aggregationFns[fn]?.(columnId, leafRows, childRows),
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
//assign filterFns
|
|
76
|
+
if (Object.keys(filterFns).includes(columnFilterFns[columnDef.id])) {
|
|
77
|
+
columnDef.filterFn =
|
|
78
|
+
filterFns[columnFilterFns[columnDef.id]] ?? filterFns.fuzzy;
|
|
79
|
+
(columnDef as MRT_DefinedColumnDef<TData>)._filterFn =
|
|
80
|
+
columnFilterFns[columnDef.id];
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
//assign sortingFns
|
|
84
|
+
if (Object.keys(sortingFns).includes(columnDef.sortingFn as string)) {
|
|
85
|
+
// @ts-ignore
|
|
86
|
+
columnDef.sortingFn = sortingFns[columnDef.sortingFn];
|
|
87
|
+
}
|
|
88
|
+
} else if (columnDef.columnDefType === 'display') {
|
|
89
|
+
columnDef = {
|
|
90
|
+
...(defaultDisplayColumn as MRT_ColumnDef<TData>),
|
|
91
|
+
...columnDef,
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
return columnDef;
|
|
95
|
+
}) as MRT_DefinedColumnDef<TData>[];
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
export const reorderColumn = <TData extends MRT_RowData>(
|
|
99
|
+
draggedColumn: MRT_Column<TData>,
|
|
100
|
+
targetColumn: MRT_Column<TData>,
|
|
101
|
+
columnOrder: MRT_ColumnOrderState,
|
|
102
|
+
): MRT_ColumnOrderState => {
|
|
103
|
+
if (draggedColumn.getCanPin()) {
|
|
104
|
+
draggedColumn.pin(targetColumn.getIsPinned());
|
|
105
|
+
}
|
|
106
|
+
const newColumnOrder = [...columnOrder];
|
|
107
|
+
newColumnOrder.splice(
|
|
108
|
+
newColumnOrder.indexOf(targetColumn.id),
|
|
109
|
+
0,
|
|
110
|
+
newColumnOrder.splice(newColumnOrder.indexOf(draggedColumn.id), 1)[0],
|
|
111
|
+
);
|
|
112
|
+
return newColumnOrder;
|
|
113
|
+
};
|
|
114
|
+
|
|
115
|
+
export const getDefaultColumnFilterFn = <TData extends MRT_RowData>(
|
|
116
|
+
columnDef: MRT_ColumnDef<TData>,
|
|
117
|
+
): MRT_FilterOption => {
|
|
118
|
+
const { filterVariant } = columnDef;
|
|
119
|
+
if (filterVariant === 'multi-select') return 'arrIncludesSome';
|
|
120
|
+
if (filterVariant?.includes('range')) return 'betweenInclusive';
|
|
121
|
+
if (['checkbox', 'date', 'select'].includes(filterVariant || ''))
|
|
122
|
+
return 'equals';
|
|
123
|
+
return 'fuzzy';
|
|
124
|
+
};
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type MRT_ColumnDef,
|
|
3
|
+
type MRT_DefinedTableOptions,
|
|
4
|
+
type MRT_DisplayColumnIds,
|
|
5
|
+
type MRT_Localization,
|
|
6
|
+
type MRT_RowData,
|
|
7
|
+
type MRT_StatefulTableOptions,
|
|
8
|
+
} from '../types';
|
|
9
|
+
import { getAllLeafColumnDefs, getColumnId } from './column.utils';
|
|
10
|
+
|
|
11
|
+
export function defaultDisplayColumnProps<TData extends MRT_RowData>({
|
|
12
|
+
header,
|
|
13
|
+
id,
|
|
14
|
+
size,
|
|
15
|
+
tableOptions,
|
|
16
|
+
}: {
|
|
17
|
+
header?: keyof MRT_Localization;
|
|
18
|
+
id: MRT_DisplayColumnIds;
|
|
19
|
+
size: number;
|
|
20
|
+
tableOptions: MRT_DefinedTableOptions<TData>;
|
|
21
|
+
}): MRT_ColumnDef<TData> {
|
|
22
|
+
const { defaultDisplayColumn, displayColumnDefOptions, localization } =
|
|
23
|
+
tableOptions;
|
|
24
|
+
return {
|
|
25
|
+
...defaultDisplayColumn,
|
|
26
|
+
header: header ? localization[header]! : '',
|
|
27
|
+
size,
|
|
28
|
+
...displayColumnDefOptions?.[id],
|
|
29
|
+
id,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export const showRowPinningColumn = <TData extends MRT_RowData>(
|
|
34
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
35
|
+
): boolean => {
|
|
36
|
+
const { enableRowPinning, rowPinningDisplayMode } = tableOptions;
|
|
37
|
+
return !!(enableRowPinning && !rowPinningDisplayMode?.startsWith('select'));
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export const showRowDragColumn = <TData extends MRT_RowData>(
|
|
41
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
42
|
+
): boolean => {
|
|
43
|
+
const { enableRowDragging, enableRowOrdering } = tableOptions;
|
|
44
|
+
return !!(enableRowDragging || enableRowOrdering);
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export const showRowExpandColumn = <TData extends MRT_RowData>(
|
|
48
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
49
|
+
): boolean => {
|
|
50
|
+
const {
|
|
51
|
+
enableExpanding,
|
|
52
|
+
enableGrouping,
|
|
53
|
+
renderDetailPanel,
|
|
54
|
+
state: { grouping },
|
|
55
|
+
} = tableOptions;
|
|
56
|
+
return !!(
|
|
57
|
+
enableExpanding ||
|
|
58
|
+
(enableGrouping && grouping?.length) ||
|
|
59
|
+
renderDetailPanel
|
|
60
|
+
);
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
export const showRowActionsColumn = <TData extends MRT_RowData>(
|
|
64
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
65
|
+
): boolean => {
|
|
66
|
+
const {
|
|
67
|
+
createDisplayMode,
|
|
68
|
+
editDisplayMode,
|
|
69
|
+
enableEditing,
|
|
70
|
+
enableRowActions,
|
|
71
|
+
state: { creatingRow },
|
|
72
|
+
} = tableOptions;
|
|
73
|
+
return !!(
|
|
74
|
+
enableRowActions ||
|
|
75
|
+
(creatingRow && createDisplayMode === 'row') ||
|
|
76
|
+
(enableEditing && ['modal', 'row'].includes(editDisplayMode ?? ''))
|
|
77
|
+
);
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export const showRowSelectionColumn = <TData extends MRT_RowData>(
|
|
81
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
82
|
+
): boolean => !!tableOptions.enableRowSelection;
|
|
83
|
+
|
|
84
|
+
export const showRowNumbersColumn = <TData extends MRT_RowData>(
|
|
85
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
86
|
+
): boolean => !!tableOptions.enableRowNumbers;
|
|
87
|
+
|
|
88
|
+
export const showRowSpacerColumn = <TData extends MRT_RowData>(
|
|
89
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
90
|
+
): boolean => tableOptions.layoutMode === 'grid-no-grow';
|
|
91
|
+
|
|
92
|
+
export const getLeadingDisplayColumnIds = <TData extends MRT_RowData>(
|
|
93
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
94
|
+
) =>
|
|
95
|
+
[
|
|
96
|
+
showRowPinningColumn(tableOptions) && 'mrt-row-pin',
|
|
97
|
+
showRowDragColumn(tableOptions) && 'mrt-row-drag',
|
|
98
|
+
tableOptions.positionActionsColumn === 'first' &&
|
|
99
|
+
showRowActionsColumn(tableOptions) &&
|
|
100
|
+
'mrt-row-actions',
|
|
101
|
+
tableOptions.positionExpandColumn === 'first' &&
|
|
102
|
+
showRowExpandColumn(tableOptions) &&
|
|
103
|
+
'mrt-row-expand',
|
|
104
|
+
showRowSelectionColumn(tableOptions) && 'mrt-row-select',
|
|
105
|
+
showRowNumbersColumn(tableOptions) && 'mrt-row-numbers',
|
|
106
|
+
].filter(Boolean) as MRT_DisplayColumnIds[];
|
|
107
|
+
|
|
108
|
+
export const getTrailingDisplayColumnIds = <TData extends MRT_RowData>(
|
|
109
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
110
|
+
) =>
|
|
111
|
+
[
|
|
112
|
+
tableOptions.positionActionsColumn === 'last' &&
|
|
113
|
+
showRowActionsColumn(tableOptions) &&
|
|
114
|
+
'mrt-row-actions',
|
|
115
|
+
tableOptions.positionExpandColumn === 'last' &&
|
|
116
|
+
showRowExpandColumn(tableOptions) &&
|
|
117
|
+
'mrt-row-expand',
|
|
118
|
+
showRowSpacerColumn(tableOptions) && 'mrt-row-spacer',
|
|
119
|
+
].filter(Boolean) as MRT_DisplayColumnIds[];
|
|
120
|
+
|
|
121
|
+
export const getDefaultColumnOrderIds = <TData extends MRT_RowData>(
|
|
122
|
+
tableOptions: MRT_StatefulTableOptions<TData>,
|
|
123
|
+
reset = false,
|
|
124
|
+
) => {
|
|
125
|
+
const {
|
|
126
|
+
state: { columnOrder: currentColumnOrderIds = [] },
|
|
127
|
+
} = tableOptions;
|
|
128
|
+
|
|
129
|
+
const leadingDisplayColIds: string[] =
|
|
130
|
+
getLeadingDisplayColumnIds(tableOptions);
|
|
131
|
+
const trailingDisplayColIds: string[] =
|
|
132
|
+
getTrailingDisplayColumnIds(tableOptions);
|
|
133
|
+
|
|
134
|
+
const defaultColumnDefIds = getAllLeafColumnDefs(tableOptions.columns).map(
|
|
135
|
+
(columnDef) => getColumnId(columnDef),
|
|
136
|
+
);
|
|
137
|
+
|
|
138
|
+
let allLeafColumnDefIds = reset
|
|
139
|
+
? defaultColumnDefIds
|
|
140
|
+
: Array.from(new Set([...currentColumnOrderIds, ...defaultColumnDefIds]));
|
|
141
|
+
|
|
142
|
+
allLeafColumnDefIds = allLeafColumnDefIds.filter(
|
|
143
|
+
(colId) =>
|
|
144
|
+
!leadingDisplayColIds.includes(colId) &&
|
|
145
|
+
!trailingDisplayColIds.includes(colId),
|
|
146
|
+
);
|
|
147
|
+
|
|
148
|
+
return [
|
|
149
|
+
...leadingDisplayColIds,
|
|
150
|
+
...allLeafColumnDefIds,
|
|
151
|
+
...trailingDisplayColIds,
|
|
152
|
+
];
|
|
153
|
+
};
|
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
import { type ChangeEvent, type MouseEvent } from 'react';
|
|
2
|
+
|
|
3
|
+
import { rankGlobalFuzzy } from '../fns/sortingFns';
|
|
4
|
+
import {
|
|
5
|
+
type MRT_Row,
|
|
6
|
+
type MRT_RowData,
|
|
7
|
+
type MRT_TableInstance,
|
|
8
|
+
} from '../types';
|
|
9
|
+
import { parseFromValuesOrFunc } from './utils';
|
|
10
|
+
|
|
11
|
+
export const getMRT_Rows = <TData extends MRT_RowData>(
|
|
12
|
+
table: MRT_TableInstance<TData>,
|
|
13
|
+
all?: boolean,
|
|
14
|
+
): MRT_Row<TData>[] => {
|
|
15
|
+
const {
|
|
16
|
+
getCenterRows,
|
|
17
|
+
getPrePaginationRowModel,
|
|
18
|
+
getRowModel,
|
|
19
|
+
getState,
|
|
20
|
+
getTopRows,
|
|
21
|
+
options: {
|
|
22
|
+
createDisplayMode,
|
|
23
|
+
enablePagination,
|
|
24
|
+
enableRowPinning,
|
|
25
|
+
manualPagination,
|
|
26
|
+
positionCreatingRow,
|
|
27
|
+
rowPinningDisplayMode,
|
|
28
|
+
},
|
|
29
|
+
} = table;
|
|
30
|
+
const { creatingRow, pagination } = getState();
|
|
31
|
+
|
|
32
|
+
const isRankingRows = getIsRankingRows(table);
|
|
33
|
+
|
|
34
|
+
let rows: MRT_Row<TData>[] = [];
|
|
35
|
+
if (!isRankingRows) {
|
|
36
|
+
rows =
|
|
37
|
+
!enableRowPinning || rowPinningDisplayMode?.includes('sticky')
|
|
38
|
+
? all
|
|
39
|
+
? getPrePaginationRowModel().rows
|
|
40
|
+
: getRowModel().rows
|
|
41
|
+
: getCenterRows();
|
|
42
|
+
} else {
|
|
43
|
+
// fuzzy ranking adjustments
|
|
44
|
+
rows = getPrePaginationRowModel().rows.sort((a, b) =>
|
|
45
|
+
rankGlobalFuzzy(a, b),
|
|
46
|
+
);
|
|
47
|
+
if (enablePagination && !manualPagination && !all) {
|
|
48
|
+
const start = pagination.pageIndex * pagination.pageSize;
|
|
49
|
+
rows = rows.slice(start, start + pagination.pageSize);
|
|
50
|
+
}
|
|
51
|
+
if (enableRowPinning && !rowPinningDisplayMode?.includes('sticky')) {
|
|
52
|
+
// "re-center-ize" the rows (no top or bottom pinned rows unless sticky)
|
|
53
|
+
rows = rows.filter((row) => !row.getIsPinned());
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
// row pinning adjustments
|
|
57
|
+
if (enableRowPinning && rowPinningDisplayMode?.includes('sticky')) {
|
|
58
|
+
const centerPinnedRowIds = rows
|
|
59
|
+
.filter((row) => row.getIsPinned())
|
|
60
|
+
.map((r) => r.id);
|
|
61
|
+
|
|
62
|
+
rows = [
|
|
63
|
+
...getTopRows().filter((row) => !centerPinnedRowIds.includes(row.id)),
|
|
64
|
+
...rows,
|
|
65
|
+
];
|
|
66
|
+
}
|
|
67
|
+
// blank inserted creating row adjustments
|
|
68
|
+
if (
|
|
69
|
+
positionCreatingRow !== undefined &&
|
|
70
|
+
creatingRow &&
|
|
71
|
+
createDisplayMode === 'row'
|
|
72
|
+
) {
|
|
73
|
+
const creatingRowIndex = !isNaN(+positionCreatingRow)
|
|
74
|
+
? +positionCreatingRow
|
|
75
|
+
: positionCreatingRow === 'top'
|
|
76
|
+
? 0
|
|
77
|
+
: rows.length;
|
|
78
|
+
rows = [
|
|
79
|
+
...rows.slice(0, creatingRowIndex),
|
|
80
|
+
creatingRow,
|
|
81
|
+
...rows.slice(creatingRowIndex),
|
|
82
|
+
];
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
return rows;
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
export const getCanRankRows = <TData extends MRT_RowData>(
|
|
89
|
+
table: MRT_TableInstance<TData>,
|
|
90
|
+
) => {
|
|
91
|
+
const {
|
|
92
|
+
getState,
|
|
93
|
+
options: {
|
|
94
|
+
enableGlobalFilterRankedResults,
|
|
95
|
+
manualExpanding,
|
|
96
|
+
manualFiltering,
|
|
97
|
+
manualGrouping,
|
|
98
|
+
manualSorting,
|
|
99
|
+
},
|
|
100
|
+
} = table;
|
|
101
|
+
const { expanded, globalFilterFn } = getState();
|
|
102
|
+
|
|
103
|
+
return (
|
|
104
|
+
!manualExpanding &&
|
|
105
|
+
!manualFiltering &&
|
|
106
|
+
!manualGrouping &&
|
|
107
|
+
!manualSorting &&
|
|
108
|
+
enableGlobalFilterRankedResults &&
|
|
109
|
+
globalFilterFn === 'fuzzy' &&
|
|
110
|
+
expanded !== true &&
|
|
111
|
+
!Object.values(expanded).some(Boolean)
|
|
112
|
+
);
|
|
113
|
+
};
|
|
114
|
+
|
|
115
|
+
export const getIsRankingRows = <TData extends MRT_RowData>(
|
|
116
|
+
table: MRT_TableInstance<TData>,
|
|
117
|
+
) => {
|
|
118
|
+
const { globalFilter, sorting } = table.getState();
|
|
119
|
+
|
|
120
|
+
return (
|
|
121
|
+
getCanRankRows(table) &&
|
|
122
|
+
globalFilter &&
|
|
123
|
+
!Object.values(sorting).some(Boolean)
|
|
124
|
+
);
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
export const getIsRowSelected = <TData extends MRT_RowData>({
|
|
128
|
+
row,
|
|
129
|
+
table,
|
|
130
|
+
}: {
|
|
131
|
+
row: MRT_Row<TData>;
|
|
132
|
+
table: MRT_TableInstance<TData>;
|
|
133
|
+
}) => {
|
|
134
|
+
const {
|
|
135
|
+
options: { enableRowSelection },
|
|
136
|
+
} = table;
|
|
137
|
+
|
|
138
|
+
return (
|
|
139
|
+
row.getIsSelected() ||
|
|
140
|
+
(parseFromValuesOrFunc(enableRowSelection, row) &&
|
|
141
|
+
row.getCanSelectSubRows() &&
|
|
142
|
+
row.getIsAllSubRowsSelected())
|
|
143
|
+
);
|
|
144
|
+
};
|
|
145
|
+
|
|
146
|
+
export const getMRT_RowSelectionHandler =
|
|
147
|
+
<TData extends MRT_RowData>({
|
|
148
|
+
renderedRowIndex = 0,
|
|
149
|
+
row,
|
|
150
|
+
table,
|
|
151
|
+
}: {
|
|
152
|
+
renderedRowIndex?: number;
|
|
153
|
+
row: MRT_Row<TData>;
|
|
154
|
+
table: MRT_TableInstance<TData>;
|
|
155
|
+
}) =>
|
|
156
|
+
(
|
|
157
|
+
event: ChangeEvent<HTMLInputElement> | MouseEvent<HTMLTableRowElement>,
|
|
158
|
+
value?: boolean,
|
|
159
|
+
) => {
|
|
160
|
+
const {
|
|
161
|
+
getState,
|
|
162
|
+
options: {
|
|
163
|
+
enableBatchRowSelection,
|
|
164
|
+
enableMultiRowSelection,
|
|
165
|
+
enableRowPinning,
|
|
166
|
+
manualPagination,
|
|
167
|
+
rowPinningDisplayMode,
|
|
168
|
+
},
|
|
169
|
+
refs: { lastSelectedRowId: lastSelectedRowId },
|
|
170
|
+
} = table;
|
|
171
|
+
const {
|
|
172
|
+
pagination: { pageIndex, pageSize },
|
|
173
|
+
} = getState();
|
|
174
|
+
|
|
175
|
+
const paginationOffset = manualPagination ? 0 : pageSize * pageIndex;
|
|
176
|
+
|
|
177
|
+
const wasCurrentRowChecked = getIsRowSelected({ row, table });
|
|
178
|
+
|
|
179
|
+
// toggle selection of this row
|
|
180
|
+
row.toggleSelected(value ?? !wasCurrentRowChecked);
|
|
181
|
+
|
|
182
|
+
const changedRowIds = new Set<string>([row.id]);
|
|
183
|
+
|
|
184
|
+
// if shift key is pressed, select all rows between last selected and this one
|
|
185
|
+
if (
|
|
186
|
+
enableBatchRowSelection &&
|
|
187
|
+
enableMultiRowSelection &&
|
|
188
|
+
(event as any).nativeEvent.shiftKey &&
|
|
189
|
+
lastSelectedRowId.current !== null
|
|
190
|
+
) {
|
|
191
|
+
const rows = getMRT_Rows(table, true);
|
|
192
|
+
|
|
193
|
+
const lastIndex = rows.findIndex(
|
|
194
|
+
(r) => r.id === lastSelectedRowId.current,
|
|
195
|
+
);
|
|
196
|
+
|
|
197
|
+
if (lastIndex !== -1) {
|
|
198
|
+
const isLastIndexChecked = getIsRowSelected({
|
|
199
|
+
row: rows?.[lastIndex],
|
|
200
|
+
table,
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
const currentIndex = renderedRowIndex + paginationOffset;
|
|
204
|
+
const [start, end] =
|
|
205
|
+
lastIndex < currentIndex
|
|
206
|
+
? [lastIndex, currentIndex]
|
|
207
|
+
: [currentIndex, lastIndex];
|
|
208
|
+
|
|
209
|
+
// toggle selection of all rows between last selected and this one
|
|
210
|
+
// but only if the last selected row is not the same as the current one
|
|
211
|
+
if (wasCurrentRowChecked !== isLastIndexChecked) {
|
|
212
|
+
for (let i = start; i <= end; i++) {
|
|
213
|
+
rows[i].toggleSelected(!wasCurrentRowChecked);
|
|
214
|
+
changedRowIds.add(rows[i].id);
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
// record the last selected row id
|
|
221
|
+
lastSelectedRowId.current = row.id;
|
|
222
|
+
|
|
223
|
+
// if all sub rows were selected, unselect them
|
|
224
|
+
if (row.getCanSelectSubRows() && row.getIsAllSubRowsSelected()) {
|
|
225
|
+
row.subRows?.forEach((r) => r.toggleSelected(false));
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
if (enableRowPinning && rowPinningDisplayMode?.includes('select')) {
|
|
229
|
+
changedRowIds.forEach((rowId) => {
|
|
230
|
+
const rowToTogglePin = table.getRow(rowId);
|
|
231
|
+
rowToTogglePin.pin(
|
|
232
|
+
!wasCurrentRowChecked //was not previously pinned or selected
|
|
233
|
+
? rowPinningDisplayMode?.includes('bottom')
|
|
234
|
+
? 'bottom'
|
|
235
|
+
: 'top'
|
|
236
|
+
: false,
|
|
237
|
+
);
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
|
|
242
|
+
export const getMRT_SelectAllHandler =
|
|
243
|
+
<TData extends MRT_RowData>({ table }: { table: MRT_TableInstance<TData> }) =>
|
|
244
|
+
(
|
|
245
|
+
event: ChangeEvent<HTMLInputElement> | MouseEvent<HTMLButtonElement>,
|
|
246
|
+
value?: boolean,
|
|
247
|
+
forceAll?: boolean,
|
|
248
|
+
) => {
|
|
249
|
+
const {
|
|
250
|
+
options: { enableRowPinning, rowPinningDisplayMode, selectAllMode },
|
|
251
|
+
refs: { lastSelectedRowId },
|
|
252
|
+
} = table;
|
|
253
|
+
|
|
254
|
+
if (selectAllMode === 'all' || forceAll) {
|
|
255
|
+
table.toggleAllRowsSelected(value ?? (event as any).target.checked);
|
|
256
|
+
} else {
|
|
257
|
+
table.toggleAllPageRowsSelected(value ?? (event as any).target.checked);
|
|
258
|
+
}
|
|
259
|
+
if (enableRowPinning && rowPinningDisplayMode?.includes('select')) {
|
|
260
|
+
table.setRowPinning({ bottom: [], top: [] });
|
|
261
|
+
}
|
|
262
|
+
lastSelectedRowId.current = null;
|
|
263
|
+
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { type MantineTheme } from '@mantine/core';
|
|
2
|
+
|
|
3
|
+
import { type MantineShade } from '../types';
|
|
4
|
+
|
|
5
|
+
export const parseCSSVarId = (id: string) => id.replace(/[^a-zA-Z0-9]/g, '_');
|
|
6
|
+
|
|
7
|
+
export const getPrimaryShade = (theme: MantineTheme): number =>
|
|
8
|
+
typeof theme.primaryShade === 'number'
|
|
9
|
+
? theme.primaryShade
|
|
10
|
+
: (theme.primaryShade?.dark ?? 7);
|
|
11
|
+
|
|
12
|
+
export const getPrimaryColor = (
|
|
13
|
+
theme: MantineTheme,
|
|
14
|
+
shade?: MantineShade,
|
|
15
|
+
): string => theme.colors[theme.primaryColor][shade ?? getPrimaryShade(theme)];
|
|
16
|
+
|
|
17
|
+
export function dataVariable(
|
|
18
|
+
name: string,
|
|
19
|
+
value: boolean | number | string | undefined,
|
|
20
|
+
) {
|
|
21
|
+
const key = `data-${name}`;
|
|
22
|
+
switch (typeof value) {
|
|
23
|
+
case 'boolean':
|
|
24
|
+
return value ? { [key]: '' } : null;
|
|
25
|
+
case 'number':
|
|
26
|
+
return { [key]: `${value}` };
|
|
27
|
+
case 'string':
|
|
28
|
+
return { [key]: value };
|
|
29
|
+
default:
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { type JSX, type ReactNode } from 'react';
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
createRow as _createRow,
|
|
5
|
+
flexRender as _flexRender,
|
|
6
|
+
type Renderable,
|
|
7
|
+
} from '@tanstack/react-table';
|
|
8
|
+
|
|
9
|
+
import {
|
|
10
|
+
type MRT_ColumnHelper,
|
|
11
|
+
type MRT_DisplayColumnDef,
|
|
12
|
+
type MRT_GroupColumnDef,
|
|
13
|
+
type MRT_Row,
|
|
14
|
+
type MRT_RowData,
|
|
15
|
+
type MRT_TableInstance,
|
|
16
|
+
} from '../types';
|
|
17
|
+
import { getAllLeafColumnDefs, getColumnId } from './column.utils';
|
|
18
|
+
|
|
19
|
+
export const flexRender = _flexRender as (
|
|
20
|
+
Comp: Renderable<any>,
|
|
21
|
+
props: any,
|
|
22
|
+
) => JSX.Element | ReactNode;
|
|
23
|
+
|
|
24
|
+
export function createMRTColumnHelper<
|
|
25
|
+
TData extends MRT_RowData,
|
|
26
|
+
>(): MRT_ColumnHelper<TData> {
|
|
27
|
+
return {
|
|
28
|
+
accessor: (accessor, column) => {
|
|
29
|
+
return typeof accessor === 'function'
|
|
30
|
+
? ({
|
|
31
|
+
...column,
|
|
32
|
+
accessorFn: accessor,
|
|
33
|
+
} as any)
|
|
34
|
+
: {
|
|
35
|
+
...column,
|
|
36
|
+
accessorKey: accessor,
|
|
37
|
+
};
|
|
38
|
+
},
|
|
39
|
+
display: (column) => column as MRT_DisplayColumnDef<TData>,
|
|
40
|
+
group: (column) => column as MRT_GroupColumnDef<TData>,
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
export const createRow = <TData extends MRT_RowData>(
|
|
45
|
+
table: MRT_TableInstance<TData>,
|
|
46
|
+
originalRow?: TData,
|
|
47
|
+
rowIndex = -1,
|
|
48
|
+
depth = 0,
|
|
49
|
+
subRows?: MRT_Row<TData>[],
|
|
50
|
+
parentId?: string,
|
|
51
|
+
): MRT_Row<TData> =>
|
|
52
|
+
_createRow(
|
|
53
|
+
table as any,
|
|
54
|
+
'mrt-row-create',
|
|
55
|
+
originalRow ??
|
|
56
|
+
Object.assign(
|
|
57
|
+
{},
|
|
58
|
+
...getAllLeafColumnDefs(table.options.columns).map((col) => ({
|
|
59
|
+
[getColumnId(col)]: '',
|
|
60
|
+
})),
|
|
61
|
+
),
|
|
62
|
+
rowIndex,
|
|
63
|
+
depth,
|
|
64
|
+
subRows as any,
|
|
65
|
+
parentId,
|
|
66
|
+
) as MRT_Row<TData>;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { defaultRangeExtractor, type Range } from '@tanstack/react-virtual';
|
|
2
|
+
|
|
3
|
+
export const extraIndexRangeExtractor = (
|
|
4
|
+
range: Range,
|
|
5
|
+
draggingIndex?: number,
|
|
6
|
+
) => {
|
|
7
|
+
const newIndexes = defaultRangeExtractor(range);
|
|
8
|
+
if (draggingIndex === undefined) return newIndexes;
|
|
9
|
+
if (
|
|
10
|
+
draggingIndex >= 0 &&
|
|
11
|
+
draggingIndex < Math.max(range.startIndex - range.overscan, 0)
|
|
12
|
+
) {
|
|
13
|
+
newIndexes.unshift(draggingIndex);
|
|
14
|
+
}
|
|
15
|
+
if (draggingIndex >= 0 && draggingIndex > range.endIndex + range.overscan) {
|
|
16
|
+
newIndexes.push(draggingIndex);
|
|
17
|
+
}
|
|
18
|
+
return newIndexes;
|
|
19
|
+
};
|