@novastera-oss/material-react-table 4.0.0-beta.7

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.
Files changed (324) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +233 -0
  3. package/dist/index.cjs +5190 -0
  4. package/dist/index.cjs.map +1 -0
  5. package/dist/index.d.ts +1871 -0
  6. package/dist/index.js +5084 -0
  7. package/dist/index.js.map +1 -0
  8. package/locales/ar/index.d.ts +3 -0
  9. package/locales/ar/index.esm.d.ts +3 -0
  10. package/locales/ar/index.esm.js +96 -0
  11. package/locales/ar/index.js +98 -0
  12. package/locales/ar/package.json +6 -0
  13. package/locales/az/index.d.ts +3 -0
  14. package/locales/az/index.esm.d.ts +3 -0
  15. package/locales/az/index.esm.js +96 -0
  16. package/locales/az/index.js +98 -0
  17. package/locales/az/package.json +6 -0
  18. package/locales/bg/index.d.ts +3 -0
  19. package/locales/bg/index.esm.d.ts +3 -0
  20. package/locales/bg/index.esm.js +96 -0
  21. package/locales/bg/index.js +98 -0
  22. package/locales/bg/package.json +6 -0
  23. package/locales/cs/index.d.ts +3 -0
  24. package/locales/cs/index.esm.d.ts +3 -0
  25. package/locales/cs/index.esm.js +96 -0
  26. package/locales/cs/index.js +98 -0
  27. package/locales/cs/package.json +6 -0
  28. package/locales/da/index.d.ts +3 -0
  29. package/locales/da/index.esm.d.ts +3 -0
  30. package/locales/da/index.esm.js +96 -0
  31. package/locales/da/index.js +98 -0
  32. package/locales/da/package.json +6 -0
  33. package/locales/de/index.d.ts +3 -0
  34. package/locales/de/index.esm.d.ts +3 -0
  35. package/locales/de/index.esm.js +96 -0
  36. package/locales/de/index.js +98 -0
  37. package/locales/de/package.json +6 -0
  38. package/locales/el/index.d.ts +3 -0
  39. package/locales/el/index.esm.d.ts +3 -0
  40. package/locales/el/index.esm.js +96 -0
  41. package/locales/el/index.js +98 -0
  42. package/locales/el/package.json +6 -0
  43. package/locales/en/index.d.ts +3 -0
  44. package/locales/en/index.esm.d.ts +3 -0
  45. package/locales/en/index.esm.js +96 -0
  46. package/locales/en/index.js +98 -0
  47. package/locales/en/package.json +6 -0
  48. package/locales/es/index.d.ts +3 -0
  49. package/locales/es/index.esm.d.ts +3 -0
  50. package/locales/es/index.esm.js +96 -0
  51. package/locales/es/index.js +98 -0
  52. package/locales/es/package.json +6 -0
  53. package/locales/et/index.d.ts +3 -0
  54. package/locales/et/index.esm.d.ts +3 -0
  55. package/locales/et/index.esm.js +96 -0
  56. package/locales/et/index.js +98 -0
  57. package/locales/et/package.json +6 -0
  58. package/locales/fa/index.d.ts +3 -0
  59. package/locales/fa/index.esm.d.ts +3 -0
  60. package/locales/fa/index.esm.js +96 -0
  61. package/locales/fa/index.js +98 -0
  62. package/locales/fa/package.json +6 -0
  63. package/locales/fi/index.d.ts +3 -0
  64. package/locales/fi/index.esm.d.ts +3 -0
  65. package/locales/fi/index.esm.js +96 -0
  66. package/locales/fi/index.js +98 -0
  67. package/locales/fi/package.json +6 -0
  68. package/locales/fr/index.d.ts +3 -0
  69. package/locales/fr/index.esm.d.ts +3 -0
  70. package/locales/fr/index.esm.js +96 -0
  71. package/locales/fr/index.js +98 -0
  72. package/locales/fr/package.json +6 -0
  73. package/locales/he/index.d.ts +3 -0
  74. package/locales/he/index.esm.d.ts +3 -0
  75. package/locales/he/index.esm.js +96 -0
  76. package/locales/he/index.js +98 -0
  77. package/locales/he/package.json +6 -0
  78. package/locales/hr/index.d.ts +3 -0
  79. package/locales/hr/index.esm.d.ts +3 -0
  80. package/locales/hr/index.esm.js +96 -0
  81. package/locales/hr/index.js +98 -0
  82. package/locales/hr/package.json +6 -0
  83. package/locales/hu/index.d.ts +3 -0
  84. package/locales/hu/index.esm.d.ts +3 -0
  85. package/locales/hu/index.esm.js +96 -0
  86. package/locales/hu/index.js +98 -0
  87. package/locales/hu/package.json +6 -0
  88. package/locales/hy/index.d.ts +3 -0
  89. package/locales/hy/index.esm.d.ts +3 -0
  90. package/locales/hy/index.esm.js +96 -0
  91. package/locales/hy/index.js +98 -0
  92. package/locales/hy/package.json +6 -0
  93. package/locales/id/index.d.ts +3 -0
  94. package/locales/id/index.esm.d.ts +3 -0
  95. package/locales/id/index.esm.js +96 -0
  96. package/locales/id/index.js +98 -0
  97. package/locales/id/package.json +6 -0
  98. package/locales/it/index.d.ts +3 -0
  99. package/locales/it/index.esm.d.ts +3 -0
  100. package/locales/it/index.esm.js +96 -0
  101. package/locales/it/index.js +98 -0
  102. package/locales/it/package.json +6 -0
  103. package/locales/ja/index.d.ts +3 -0
  104. package/locales/ja/index.esm.d.ts +3 -0
  105. package/locales/ja/index.esm.js +96 -0
  106. package/locales/ja/index.js +98 -0
  107. package/locales/ja/package.json +6 -0
  108. package/locales/ko/index.d.ts +3 -0
  109. package/locales/ko/index.esm.d.ts +3 -0
  110. package/locales/ko/index.esm.js +96 -0
  111. package/locales/ko/index.js +98 -0
  112. package/locales/ko/package.json +6 -0
  113. package/locales/nl/index.d.ts +3 -0
  114. package/locales/nl/index.esm.d.ts +3 -0
  115. package/locales/nl/index.esm.js +96 -0
  116. package/locales/nl/index.js +98 -0
  117. package/locales/nl/package.json +6 -0
  118. package/locales/no/index.d.ts +3 -0
  119. package/locales/no/index.esm.d.ts +3 -0
  120. package/locales/no/index.esm.js +96 -0
  121. package/locales/no/index.js +98 -0
  122. package/locales/no/package.json +6 -0
  123. package/locales/np/index.d.ts +3 -0
  124. package/locales/np/index.esm.d.ts +3 -0
  125. package/locales/np/index.esm.js +96 -0
  126. package/locales/np/index.js +98 -0
  127. package/locales/np/package.json +6 -0
  128. package/locales/pl/index.d.ts +3 -0
  129. package/locales/pl/index.esm.d.ts +3 -0
  130. package/locales/pl/index.esm.js +96 -0
  131. package/locales/pl/index.js +98 -0
  132. package/locales/pl/package.json +6 -0
  133. package/locales/pt/index.d.ts +3 -0
  134. package/locales/pt/index.esm.d.ts +3 -0
  135. package/locales/pt/index.esm.js +96 -0
  136. package/locales/pt/index.js +98 -0
  137. package/locales/pt/package.json +6 -0
  138. package/locales/pt-BR/index.d.ts +3 -0
  139. package/locales/pt-BR/index.esm.d.ts +3 -0
  140. package/locales/pt-BR/index.esm.js +96 -0
  141. package/locales/pt-BR/index.js +98 -0
  142. package/locales/pt-BR/package.json +6 -0
  143. package/locales/ro/index.d.ts +3 -0
  144. package/locales/ro/index.esm.d.ts +3 -0
  145. package/locales/ro/index.esm.js +96 -0
  146. package/locales/ro/index.js +98 -0
  147. package/locales/ro/package.json +6 -0
  148. package/locales/ru/index.d.ts +3 -0
  149. package/locales/ru/index.esm.d.ts +3 -0
  150. package/locales/ru/index.esm.js +96 -0
  151. package/locales/ru/index.js +98 -0
  152. package/locales/ru/package.json +6 -0
  153. package/locales/sk/index.d.ts +3 -0
  154. package/locales/sk/index.esm.d.ts +3 -0
  155. package/locales/sk/index.esm.js +96 -0
  156. package/locales/sk/index.js +98 -0
  157. package/locales/sk/package.json +6 -0
  158. package/locales/sr-Cyrl-RS/index.d.ts +3 -0
  159. package/locales/sr-Cyrl-RS/index.esm.d.ts +3 -0
  160. package/locales/sr-Cyrl-RS/index.esm.js +96 -0
  161. package/locales/sr-Cyrl-RS/index.js +98 -0
  162. package/locales/sr-Cyrl-RS/package.json +6 -0
  163. package/locales/sr-Latn-RS/index.d.ts +3 -0
  164. package/locales/sr-Latn-RS/index.esm.d.ts +3 -0
  165. package/locales/sr-Latn-RS/index.esm.js +96 -0
  166. package/locales/sr-Latn-RS/index.js +98 -0
  167. package/locales/sr-Latn-RS/package.json +6 -0
  168. package/locales/sv/index.d.ts +3 -0
  169. package/locales/sv/index.esm.d.ts +3 -0
  170. package/locales/sv/index.esm.js +96 -0
  171. package/locales/sv/index.js +98 -0
  172. package/locales/sv/package.json +6 -0
  173. package/locales/tr/index.d.ts +3 -0
  174. package/locales/tr/index.esm.d.ts +3 -0
  175. package/locales/tr/index.esm.js +96 -0
  176. package/locales/tr/index.js +98 -0
  177. package/locales/tr/package.json +6 -0
  178. package/locales/uk/index.d.ts +3 -0
  179. package/locales/uk/index.esm.d.ts +3 -0
  180. package/locales/uk/index.esm.js +96 -0
  181. package/locales/uk/index.js +98 -0
  182. package/locales/uk/package.json +6 -0
  183. package/locales/vi/index.d.ts +3 -0
  184. package/locales/vi/index.esm.d.ts +3 -0
  185. package/locales/vi/index.esm.js +96 -0
  186. package/locales/vi/index.js +98 -0
  187. package/locales/vi/package.json +6 -0
  188. package/locales/zh-Hans/index.d.ts +3 -0
  189. package/locales/zh-Hans/index.esm.d.ts +3 -0
  190. package/locales/zh-Hans/index.esm.js +96 -0
  191. package/locales/zh-Hans/index.js +98 -0
  192. package/locales/zh-Hans/package.json +6 -0
  193. package/locales/zh-Hant/index.d.ts +3 -0
  194. package/locales/zh-Hant/index.esm.d.ts +3 -0
  195. package/locales/zh-Hant/index.esm.js +96 -0
  196. package/locales/zh-Hant/index.js +98 -0
  197. package/locales/zh-Hant/package.json +6 -0
  198. package/package.json +103 -0
  199. package/src/components/MaterialReactTable.tsx +36 -0
  200. package/src/components/body/MRT_TableBody.tsx +233 -0
  201. package/src/components/body/MRT_TableBodyCell.tsx +356 -0
  202. package/src/components/body/MRT_TableBodyCellValue.tsx +130 -0
  203. package/src/components/body/MRT_TableBodyRow.tsx +306 -0
  204. package/src/components/body/MRT_TableBodyRowGrabHandle.tsx +61 -0
  205. package/src/components/body/MRT_TableBodyRowPinButton.tsx +58 -0
  206. package/src/components/body/MRT_TableDetailPanel.tsx +118 -0
  207. package/src/components/buttons/MRT_ColumnPinningButtons.tsx +73 -0
  208. package/src/components/buttons/MRT_CopyButton.tsx +91 -0
  209. package/src/components/buttons/MRT_EditActionButtons.tsx +135 -0
  210. package/src/components/buttons/MRT_ExpandAllButton.tsx +82 -0
  211. package/src/components/buttons/MRT_ExpandButton.tsx +106 -0
  212. package/src/components/buttons/MRT_GrabHandleButton.tsx +66 -0
  213. package/src/components/buttons/MRT_RowPinButton.tsx +84 -0
  214. package/src/components/buttons/MRT_ShowHideColumnsButton.tsx +50 -0
  215. package/src/components/buttons/MRT_ToggleDensePaddingButton.tsx +52 -0
  216. package/src/components/buttons/MRT_ToggleFiltersButton.tsx +40 -0
  217. package/src/components/buttons/MRT_ToggleFullScreenButton.tsx +51 -0
  218. package/src/components/buttons/MRT_ToggleGlobalFilterButton.tsx +46 -0
  219. package/src/components/buttons/MRT_ToggleRowActionMenuButton.tsx +126 -0
  220. package/src/components/footer/MRT_TableFooter.tsx +92 -0
  221. package/src/components/footer/MRT_TableFooterCell.tsx +111 -0
  222. package/src/components/footer/MRT_TableFooterRow.tsx +99 -0
  223. package/src/components/head/MRT_TableHead.tsx +95 -0
  224. package/src/components/head/MRT_TableHeadCell.tsx +357 -0
  225. package/src/components/head/MRT_TableHeadCellColumnActionsButton.tsx +100 -0
  226. package/src/components/head/MRT_TableHeadCellFilterContainer.tsx +52 -0
  227. package/src/components/head/MRT_TableHeadCellFilterLabel.tsx +180 -0
  228. package/src/components/head/MRT_TableHeadCellGrabHandle.tsx +91 -0
  229. package/src/components/head/MRT_TableHeadCellResizeHandle.tsx +96 -0
  230. package/src/components/head/MRT_TableHeadCellSortLabel.tsx +102 -0
  231. package/src/components/head/MRT_TableHeadRow.tsx +94 -0
  232. package/src/components/inputs/MRT_EditCellTextField.tsx +195 -0
  233. package/src/components/inputs/MRT_FilterCheckbox.tsx +94 -0
  234. package/src/components/inputs/MRT_FilterRangeFields.tsx +42 -0
  235. package/src/components/inputs/MRT_FilterRangeSlider.tsx +145 -0
  236. package/src/components/inputs/MRT_FilterTextField.tsx +610 -0
  237. package/src/components/inputs/MRT_GlobalFilterTextField.tsx +166 -0
  238. package/src/components/inputs/MRT_SelectCheckbox.tsx +133 -0
  239. package/src/components/menus/MRT_ActionMenuItem.tsx +62 -0
  240. package/src/components/menus/MRT_CellActionMenu.tsx +109 -0
  241. package/src/components/menus/MRT_ColumnActionMenu.tsx +354 -0
  242. package/src/components/menus/MRT_FilterOptionMenu.tsx +294 -0
  243. package/src/components/menus/MRT_RowActionMenu.tsx +90 -0
  244. package/src/components/menus/MRT_ShowHideColumnsMenu.tsx +181 -0
  245. package/src/components/menus/MRT_ShowHideColumnsMenuItems.tsx +204 -0
  246. package/src/components/modals/MRT_EditRowModal.tsx +114 -0
  247. package/src/components/table/MRT_Table.tsx +86 -0
  248. package/src/components/table/MRT_TableContainer.tsx +115 -0
  249. package/src/components/table/MRT_TableLoadingOverlay.tsx +58 -0
  250. package/src/components/table/MRT_TablePaper.tsx +91 -0
  251. package/src/components/toolbar/MRT_BottomToolbar.tsx +112 -0
  252. package/src/components/toolbar/MRT_LinearProgressBar.tsx +53 -0
  253. package/src/components/toolbar/MRT_TablePagination.tsx +241 -0
  254. package/src/components/toolbar/MRT_ToolbarAlertBanner.tsx +182 -0
  255. package/src/components/toolbar/MRT_ToolbarDropZone.tsx +82 -0
  256. package/src/components/toolbar/MRT_ToolbarInternalButtons.tsx +73 -0
  257. package/src/components/toolbar/MRT_TopToolbar.tsx +134 -0
  258. package/src/fns/aggregationFns.ts +3 -0
  259. package/src/fns/filterFns.ts +196 -0
  260. package/src/fns/sortingFns.ts +33 -0
  261. package/src/hooks/display-columns/getMRT_RowActionsColumnDef.tsx +28 -0
  262. package/src/hooks/display-columns/getMRT_RowDragColumnDef.tsx +29 -0
  263. package/src/hooks/display-columns/getMRT_RowExpandColumnDef.tsx +91 -0
  264. package/src/hooks/display-columns/getMRT_RowNumbersColumnDef.tsx +30 -0
  265. package/src/hooks/display-columns/getMRT_RowPinningColumnDef.tsx +24 -0
  266. package/src/hooks/display-columns/getMRT_RowSelectColumnDef.tsx +34 -0
  267. package/src/hooks/display-columns/getMRT_RowSpacerColumnDef.tsx +33 -0
  268. package/src/hooks/useMRT_ColumnVirtualizer.ts +124 -0
  269. package/src/hooks/useMRT_Effects.ts +106 -0
  270. package/src/hooks/useMRT_RowVirtualizer.ts +88 -0
  271. package/src/hooks/useMRT_Rows.ts +44 -0
  272. package/src/hooks/useMRT_TableInstance.ts +317 -0
  273. package/src/hooks/useMRT_TableOptions.ts +270 -0
  274. package/src/hooks/useMaterialReactTable.ts +12 -0
  275. package/src/icons.ts +73 -0
  276. package/src/index.ts +91 -0
  277. package/src/locales/ar.ts +97 -0
  278. package/src/locales/az.ts +97 -0
  279. package/src/locales/bg.ts +97 -0
  280. package/src/locales/cs.ts +98 -0
  281. package/src/locales/da.ts +97 -0
  282. package/src/locales/de.ts +97 -0
  283. package/src/locales/el.ts +97 -0
  284. package/src/locales/en.ts +97 -0
  285. package/src/locales/es.ts +97 -0
  286. package/src/locales/et.ts +98 -0
  287. package/src/locales/fa.ts +97 -0
  288. package/src/locales/fi.ts +98 -0
  289. package/src/locales/fr.ts +97 -0
  290. package/src/locales/he.ts +97 -0
  291. package/src/locales/hr.ts +97 -0
  292. package/src/locales/hu.ts +97 -0
  293. package/src/locales/hy.ts +97 -0
  294. package/src/locales/id.ts +98 -0
  295. package/src/locales/it.ts +97 -0
  296. package/src/locales/ja.ts +97 -0
  297. package/src/locales/ko.ts +97 -0
  298. package/src/locales/mk.ts +96 -0
  299. package/src/locales/nl.ts +97 -0
  300. package/src/locales/no.ts +99 -0
  301. package/src/locales/np.ts +98 -0
  302. package/src/locales/pl.ts +97 -0
  303. package/src/locales/pt-BR.ts +97 -0
  304. package/src/locales/pt.ts +97 -0
  305. package/src/locales/ro.ts +97 -0
  306. package/src/locales/ru.ts +97 -0
  307. package/src/locales/sk.ts +98 -0
  308. package/src/locales/sr-Cyrl-RS.ts +97 -0
  309. package/src/locales/sr-Latn-RS.ts +97 -0
  310. package/src/locales/sv.ts +97 -0
  311. package/src/locales/tr.ts +97 -0
  312. package/src/locales/uk.ts +97 -0
  313. package/src/locales/vi.ts +97 -0
  314. package/src/locales/zh-Hans.ts +96 -0
  315. package/src/locales/zh-Hant.ts +96 -0
  316. package/src/types.ts +1298 -0
  317. package/src/utils/cell.utils.ts +234 -0
  318. package/src/utils/column.utils.ts +209 -0
  319. package/src/utils/displayColumn.utils.ts +152 -0
  320. package/src/utils/row.utils.ts +260 -0
  321. package/src/utils/style.utils.ts +221 -0
  322. package/src/utils/tanstack.helpers.ts +64 -0
  323. package/src/utils/utils.ts +56 -0
  324. package/src/utils/virtualization.utils.ts +24 -0
@@ -0,0 +1,90 @@
1
+ import { ReactNode, useMemo, type MouseEvent } from 'react';
2
+ import Menu, { type MenuProps } from '@mui/material/Menu';
3
+ import { MRT_ActionMenuItem } from './MRT_ActionMenuItem';
4
+ import {
5
+ type MRT_Row,
6
+ type MRT_RowData,
7
+ type MRT_TableInstance,
8
+ } from '../../types';
9
+ import { parseFromValuesOrFunc } from '../../utils/utils';
10
+
11
+ export interface MRT_RowActionMenuProps<TData extends MRT_RowData>
12
+ extends Partial<MenuProps> {
13
+ anchorEl: HTMLElement | null;
14
+ handleEdit: (event: MouseEvent) => void;
15
+ row: MRT_Row<TData>;
16
+ setAnchorEl: (anchorEl: HTMLElement | null) => void;
17
+ staticRowIndex?: number;
18
+ table: MRT_TableInstance<TData>;
19
+ }
20
+
21
+ export const MRT_RowActionMenu = <TData extends MRT_RowData>({
22
+ anchorEl,
23
+ handleEdit,
24
+ row,
25
+ setAnchorEl,
26
+ staticRowIndex,
27
+ table,
28
+ ...rest
29
+ }: MRT_RowActionMenuProps<TData>) => {
30
+ const {
31
+ getState,
32
+ options: {
33
+ editDisplayMode,
34
+ enableEditing,
35
+ icons: { EditIcon },
36
+ localization,
37
+ mrtTheme: { menuBackgroundColor },
38
+ renderRowActionMenuItems,
39
+ },
40
+ } = table;
41
+ const { density } = getState();
42
+
43
+ const menuItems = useMemo(() => {
44
+ const items: ReactNode[] = [];
45
+ const editItem = parseFromValuesOrFunc(enableEditing, row) &&
46
+ ['modal', 'row'].includes(editDisplayMode!) && (
47
+ <MRT_ActionMenuItem
48
+ key={'edit'}
49
+ icon={<EditIcon />}
50
+ label={localization.edit}
51
+ onClick={handleEdit}
52
+ table={table}
53
+ />
54
+ );
55
+ if (editItem) items.push(editItem);
56
+ const rowActionMenuItems = renderRowActionMenuItems?.({
57
+ closeMenu: () => setAnchorEl(null),
58
+ row,
59
+ staticRowIndex,
60
+ table,
61
+ });
62
+ if (rowActionMenuItems?.length) items.push(...rowActionMenuItems);
63
+ return items;
64
+ }, [renderRowActionMenuItems, row, staticRowIndex, table]);
65
+
66
+ if (!menuItems.length) return null;
67
+
68
+ return (
69
+ <Menu
70
+ anchorEl={anchorEl}
71
+ disableScrollLock
72
+ onClick={(event) => event.stopPropagation()}
73
+ onClose={() => setAnchorEl(null)}
74
+ open={!!anchorEl}
75
+ slotProps={{
76
+ list: {
77
+ dense: density === 'compact',
78
+ sx: {
79
+ backgroundColor: menuBackgroundColor,
80
+ },
81
+ ...rest.slotProps?.list,
82
+ },
83
+ ...rest.slotProps,
84
+ }}
85
+ {...rest}
86
+ >
87
+ {menuItems}
88
+ </Menu>
89
+ );
90
+ };
@@ -0,0 +1,181 @@
1
+ import { useMemo, useState } from 'react';
2
+ import Box from '@mui/material/Box';
3
+ import Button from '@mui/material/Button';
4
+ import Divider from '@mui/material/Divider';
5
+ import Menu, { type MenuProps } from '@mui/material/Menu';
6
+ import { MRT_ShowHideColumnsMenuItems } from './MRT_ShowHideColumnsMenuItems';
7
+ import {
8
+ type MRT_Column,
9
+ type MRT_RowData,
10
+ type MRT_TableInstance,
11
+ type MRT_VisibilityState
12
+ } from '../../types';
13
+ import { getDefaultColumnOrderIds } from '../../utils/displayColumn.utils';
14
+
15
+ export interface MRT_ShowHideColumnsMenuProps<TData extends MRT_RowData>
16
+ extends Partial<MenuProps> {
17
+ anchorEl: HTMLElement | null;
18
+ isSubMenu?: boolean;
19
+ setAnchorEl: (anchorEl: HTMLElement | null) => void;
20
+ table: MRT_TableInstance<TData>;
21
+ }
22
+
23
+ export const MRT_ShowHideColumnsMenu = <TData extends MRT_RowData>({
24
+ anchorEl,
25
+ setAnchorEl,
26
+ table,
27
+ ...rest
28
+ }: MRT_ShowHideColumnsMenuProps<TData>) => {
29
+ const {
30
+ getAllColumns,
31
+ getAllLeafColumns,
32
+ getCenterLeafColumns,
33
+ getIsAllColumnsVisible,
34
+ getIsSomeColumnsPinned,
35
+ getIsSomeColumnsVisible,
36
+ getLeftLeafColumns,
37
+ getRightLeafColumns,
38
+ getState,
39
+ initialState,
40
+ options: {
41
+ enableColumnOrdering,
42
+ enableColumnPinning,
43
+ enableHiding,
44
+ localization,
45
+ mrtTheme: { menuBackgroundColor },
46
+ },
47
+ } = table;
48
+ const { columnOrder, columnPinning, density } = getState();
49
+
50
+ const handleToggleAllColumns = (value?: boolean) => {
51
+ const updates =
52
+ getAllLeafColumns()
53
+ .filter((column) => column.columnDef.enableHiding !== false)
54
+ .reduce((acc, column) => {
55
+ acc[column.id] = value ?? !column.getIsVisible()
56
+ return acc;
57
+ }, {} as MRT_VisibilityState);
58
+
59
+ table.setColumnVisibility((old) => ({ ...old, ...updates }));
60
+ };
61
+
62
+ const allColumns = useMemo(() => {
63
+ const columns = getAllColumns();
64
+ if (
65
+ columnOrder.length > 0 &&
66
+ !columns.some((col) => col.columnDef.columnDefType === 'group')
67
+ ) {
68
+ return [
69
+ ...getLeftLeafColumns(),
70
+ ...Array.from(new Set(columnOrder)).map((colId) =>
71
+ getCenterLeafColumns().find((col) => col?.id === colId),
72
+ ),
73
+ ...getRightLeafColumns(),
74
+ ].filter(Boolean);
75
+ }
76
+ return columns;
77
+ }, [
78
+ columnOrder,
79
+ columnPinning,
80
+ getAllColumns(),
81
+ getCenterLeafColumns(),
82
+ getLeftLeafColumns(),
83
+ getRightLeafColumns(),
84
+ ]) as MRT_Column<TData>[];
85
+
86
+ const isNestedColumns = allColumns.some(
87
+ (col) => col.columnDef.columnDefType === 'group',
88
+ );
89
+
90
+ const hasColumnOrderChanged = useMemo(
91
+ () =>
92
+ columnOrder.length !== initialState.columnOrder.length ||
93
+ !columnOrder.every(
94
+ (column, index) => column === initialState.columnOrder[index],
95
+ ),
96
+
97
+ [columnOrder, initialState.columnOrder],
98
+ );
99
+
100
+ const [hoveredColumn, setHoveredColumn] = useState<MRT_Column<TData> | null>(
101
+ null,
102
+ );
103
+
104
+ return (
105
+ <Menu
106
+ anchorEl={anchorEl}
107
+ disableScrollLock
108
+ onClose={() => setAnchorEl(null)}
109
+ open={!!anchorEl}
110
+ slotProps={{
111
+ list: {
112
+ dense: density === 'compact',
113
+ sx: {
114
+ backgroundColor: menuBackgroundColor,
115
+ },
116
+ ...rest.slotProps?.list,
117
+ },
118
+ ...rest.slotProps,
119
+ }}
120
+ {...rest}
121
+ >
122
+ <Box
123
+ sx={{
124
+ display: 'flex',
125
+ justifyContent: 'space-between',
126
+ p: '0.5rem',
127
+ pt: 0,
128
+ }}
129
+ >
130
+ {enableHiding && (
131
+ <Button
132
+ disabled={!getIsSomeColumnsVisible()}
133
+ onClick={() => handleToggleAllColumns(false)}
134
+ >
135
+ {localization.hideAll}
136
+ </Button>
137
+ )}
138
+ {enableColumnOrdering && (
139
+ <Button
140
+ onClick={() =>
141
+ table.setColumnOrder(
142
+ getDefaultColumnOrderIds(table.options, true),
143
+ )
144
+ }
145
+ disabled={!hasColumnOrderChanged}
146
+ >
147
+ {localization.resetOrder}
148
+ </Button>
149
+ )}
150
+ {enableColumnPinning && (
151
+ <Button
152
+ disabled={!getIsSomeColumnsPinned()}
153
+ onClick={() => table.resetColumnPinning(true)}
154
+ >
155
+ {localization.unpinAll}
156
+ </Button>
157
+ )}
158
+ {enableHiding && (
159
+ <Button
160
+ disabled={getIsAllColumnsVisible()}
161
+ onClick={() => handleToggleAllColumns(true)}
162
+ >
163
+ {localization.showAll}
164
+ </Button>
165
+ )}
166
+ </Box>
167
+ <Divider />
168
+ {allColumns.map((column, index) => (
169
+ <MRT_ShowHideColumnsMenuItems
170
+ allColumns={allColumns}
171
+ column={column}
172
+ hoveredColumn={hoveredColumn}
173
+ isNestedColumns={isNestedColumns}
174
+ key={`${index}-${column.id}`}
175
+ setHoveredColumn={setHoveredColumn}
176
+ table={table}
177
+ />
178
+ ))}
179
+ </Menu>
180
+ );
181
+ };
@@ -0,0 +1,204 @@
1
+ import {
2
+ type Dispatch,
3
+ type DragEvent,
4
+ type SetStateAction,
5
+ useRef,
6
+ useState,
7
+ } from 'react';
8
+ import Box from '@mui/material/Box';
9
+ import FormControlLabel from '@mui/material/FormControlLabel';
10
+ import MenuItem, { type MenuItemProps } from '@mui/material/MenuItem';
11
+ import Switch from '@mui/material/Switch';
12
+ import Tooltip from '@mui/material/Tooltip';
13
+ import Typography from '@mui/material/Typography';
14
+ import {
15
+ type MRT_Column,
16
+ type MRT_RowData,
17
+ type MRT_TableInstance,
18
+ } from '../../types';
19
+ import { reorderColumn } from '../../utils/column.utils';
20
+ import { getCommonTooltipProps } from '../../utils/style.utils';
21
+ import { MRT_ColumnPinningButtons } from '../buttons/MRT_ColumnPinningButtons';
22
+ import { MRT_GrabHandleButton } from '../buttons/MRT_GrabHandleButton';
23
+
24
+ export interface MRT_ShowHideColumnsMenuItemsProps<TData extends MRT_RowData>
25
+ extends MenuItemProps {
26
+ allColumns: MRT_Column<TData>[];
27
+ column: MRT_Column<TData>;
28
+ hoveredColumn: MRT_Column<TData> | null;
29
+ isNestedColumns: boolean;
30
+ setHoveredColumn: Dispatch<SetStateAction<MRT_Column<TData> | null>>;
31
+ table: MRT_TableInstance<TData>;
32
+ }
33
+
34
+ export const MRT_ShowHideColumnsMenuItems = <TData extends MRT_RowData>({
35
+ allColumns,
36
+ column,
37
+ hoveredColumn,
38
+ isNestedColumns,
39
+ setHoveredColumn,
40
+ table,
41
+ ...rest
42
+ }: MRT_ShowHideColumnsMenuItemsProps<TData>) => {
43
+ const {
44
+ getState,
45
+ options: {
46
+ enableColumnOrdering,
47
+ enableColumnPinning,
48
+ enableHiding,
49
+ localization,
50
+ mrtTheme: { draggingBorderColor },
51
+ },
52
+ setColumnOrder,
53
+ setColumnPinning,
54
+ } = table;
55
+ const { columnOrder } = getState();
56
+ const { columnDef } = column;
57
+ const { columnDefType } = columnDef;
58
+
59
+ const switchChecked = column.getIsVisible();
60
+
61
+ const handleToggleColumnHidden = (column: MRT_Column<TData>) => {
62
+ if (columnDefType === 'group') {
63
+ column?.columns?.forEach?.((childColumn: MRT_Column<TData>) => {
64
+ childColumn.toggleVisibility(!switchChecked);
65
+ });
66
+ } else {
67
+ column.toggleVisibility();
68
+ }
69
+ };
70
+
71
+ const menuItemRef = useRef<HTMLElement>(null);
72
+
73
+ const [isDragging, setIsDragging] = useState(false);
74
+
75
+ const handleDragStart = (e: DragEvent<HTMLButtonElement>) => {
76
+ setIsDragging(true);
77
+ try {
78
+ e.dataTransfer.setDragImage(menuItemRef.current as HTMLElement, 0, 0);
79
+ } catch (e) {
80
+ console.error(e);
81
+ }
82
+ };
83
+
84
+ const handleDragEnd = (_e: DragEvent<HTMLButtonElement>) => {
85
+ setIsDragging(false);
86
+ setHoveredColumn(null);
87
+ if (hoveredColumn) {
88
+ const reorderedColumns = reorderColumn(
89
+ column,
90
+ hoveredColumn,
91
+ columnOrder,
92
+ );
93
+ setColumnOrder(reorderedColumns);
94
+ setColumnPinning(({ left = [], right = [] }) => ({
95
+ left: reorderedColumns.filter((header) => left.includes(header)),
96
+ right: reorderedColumns.filter((header) => right.includes(header)),
97
+ }));
98
+ }
99
+ };
100
+
101
+ const handleDragEnter = (_e: DragEvent) => {
102
+ if (!isDragging && columnDef.enableColumnOrdering !== false) {
103
+ setHoveredColumn(column);
104
+ }
105
+ };
106
+
107
+ if (!columnDef.header || columnDef.visibleInShowHideMenu === false) {
108
+ return null;
109
+ }
110
+
111
+ return (
112
+ <>
113
+ <MenuItem
114
+ disableRipple
115
+ onDragEnter={handleDragEnter}
116
+ ref={menuItemRef as any}
117
+ {...rest}
118
+ sx={[
119
+ (theme) => ({
120
+ alignItems: 'center',
121
+ justifyContent: 'flex-start',
122
+ my: 0,
123
+ opacity: isDragging ? 0.5 : 1,
124
+ outline: isDragging
125
+ ? `2px dashed ${theme.palette.grey[500]}`
126
+ : hoveredColumn?.id === column.id
127
+ ? `2px dashed ${draggingBorderColor}`
128
+ : 'none',
129
+ outlineOffset: '-2px',
130
+ pl: `${(column.depth + 0.5) * 2}rem`,
131
+ py: '6px',
132
+ }),
133
+ ...(Array.isArray(rest?.sx) ? rest.sx : [rest?.sx]),
134
+ ]}
135
+ >
136
+ <Box
137
+ sx={{
138
+ display: 'flex',
139
+ flexWrap: 'nowrap',
140
+ gap: '8px',
141
+ }}
142
+ >
143
+ {columnDefType !== 'group' &&
144
+ enableColumnOrdering &&
145
+ !isNestedColumns &&
146
+ (columnDef.enableColumnOrdering !== false ? (
147
+ <MRT_GrabHandleButton
148
+ onDragEnd={handleDragEnd}
149
+ onDragStart={handleDragStart}
150
+ table={table}
151
+ />
152
+ ) : (
153
+ <Box sx={{ width: '28px' }} />
154
+ ))}
155
+ {enableColumnPinning &&
156
+ (column.getCanPin() ? (
157
+ <MRT_ColumnPinningButtons column={column} table={table} />
158
+ ) : (
159
+ <Box sx={{ width: '70px' }} />
160
+ ))}
161
+ {enableHiding ? (
162
+ <FormControlLabel
163
+ checked={switchChecked}
164
+ slotProps={{
165
+ typography: {
166
+ sx: {
167
+ mb: 0,
168
+ opacity: columnDefType !== 'display' ? 1 : 0.5,
169
+ },
170
+ },
171
+ }}
172
+ control={
173
+ <Tooltip
174
+ {...getCommonTooltipProps()}
175
+ title={localization.toggleVisibility}
176
+ >
177
+ <Switch />
178
+ </Tooltip>
179
+ }
180
+ disabled={!column.getCanHide()}
181
+ label={columnDef.header}
182
+ onChange={() => handleToggleColumnHidden(column)}
183
+ />
184
+ ) : (
185
+ <Typography sx={{ alignSelf: 'center' }}>
186
+ {columnDef.header}
187
+ </Typography>
188
+ )}
189
+ </Box>
190
+ </MenuItem>
191
+ {column.columns?.map((c: MRT_Column<TData>, i) => (
192
+ <MRT_ShowHideColumnsMenuItems
193
+ allColumns={allColumns}
194
+ column={c}
195
+ hoveredColumn={hoveredColumn}
196
+ isNestedColumns={isNestedColumns}
197
+ key={`${i}-${c.id}`}
198
+ setHoveredColumn={setHoveredColumn}
199
+ table={table}
200
+ />
201
+ ))}
202
+ </>
203
+ );
204
+ };
@@ -0,0 +1,114 @@
1
+ import Dialog, { type DialogProps } from '@mui/material/Dialog';
2
+ import DialogActions from '@mui/material/DialogActions';
3
+ import DialogContent from '@mui/material/DialogContent';
4
+ import DialogTitle from '@mui/material/DialogTitle';
5
+ import Stack from '@mui/material/Stack';
6
+ import {
7
+ type MRT_Row,
8
+ type MRT_RowData,
9
+ type MRT_TableInstance,
10
+ } from '../../types';
11
+ import { parseFromValuesOrFunc } from '../../utils/utils';
12
+ import { MRT_EditActionButtons } from '../buttons/MRT_EditActionButtons';
13
+ import { MRT_EditCellTextField } from '../inputs/MRT_EditCellTextField';
14
+
15
+ export interface MRT_EditRowModalProps<TData extends MRT_RowData>
16
+ extends Partial<DialogProps> {
17
+ open: boolean;
18
+ table: MRT_TableInstance<TData>;
19
+ }
20
+
21
+ export const MRT_EditRowModal = <TData extends MRT_RowData>({
22
+ open,
23
+ table,
24
+ ...rest
25
+ }: MRT_EditRowModalProps<TData>) => {
26
+ const {
27
+ getState,
28
+ options: {
29
+ localization,
30
+ muiCreateRowModalProps,
31
+ muiEditRowDialogProps,
32
+ onCreatingRowCancel,
33
+ onEditingRowCancel,
34
+ renderCreateRowDialogContent,
35
+ renderEditRowDialogContent,
36
+ },
37
+ setCreatingRow,
38
+ setEditingRow,
39
+ } = table;
40
+ const { creatingRow, editingRow } = getState();
41
+ const row = (creatingRow ?? editingRow) as MRT_Row<TData>;
42
+
43
+ const dialogProps = {
44
+ ...parseFromValuesOrFunc(muiEditRowDialogProps, { row, table }),
45
+ ...(creatingRow &&
46
+ parseFromValuesOrFunc(muiCreateRowModalProps, { row, table })),
47
+ ...rest,
48
+ };
49
+
50
+ const internalEditComponents = row
51
+ .getAllCells()
52
+ .filter((cell) => cell.column.columnDef.columnDefType === 'data')
53
+ .map((cell) => (
54
+ <MRT_EditCellTextField
55
+ cell={cell as any}
56
+ key={cell.id}
57
+ table={table as any}
58
+ />
59
+ ));
60
+
61
+ return (
62
+ <Dialog
63
+ fullWidth
64
+ maxWidth="xs"
65
+ onClose={(event, reason) => {
66
+ if (creatingRow) {
67
+ onCreatingRowCancel?.({ row, table });
68
+ setCreatingRow(null);
69
+ } else {
70
+ onEditingRowCancel?.({ row, table });
71
+ setEditingRow(null);
72
+ }
73
+ row._valuesCache = {} as any; //reset values cache
74
+ dialogProps.onClose?.(event, reason);
75
+ }}
76
+ open={open}
77
+ {...dialogProps}
78
+ >
79
+ {((creatingRow &&
80
+ renderCreateRowDialogContent?.({
81
+ internalEditComponents,
82
+ row,
83
+ table,
84
+ })) ||
85
+ renderEditRowDialogContent?.({
86
+ internalEditComponents,
87
+ row,
88
+ table,
89
+ })) ?? (
90
+ <>
91
+ <DialogTitle sx={{ textAlign: 'center' }}>
92
+ {localization.edit}
93
+ </DialogTitle>
94
+ <DialogContent>
95
+ <form onSubmit={(e) => e.preventDefault()}>
96
+ <Stack
97
+ sx={{
98
+ gap: '32px',
99
+ paddingTop: '16px',
100
+ width: '100%',
101
+ }}
102
+ >
103
+ {internalEditComponents}
104
+ </Stack>
105
+ </form>
106
+ </DialogContent>
107
+ <DialogActions sx={{ p: '1.25rem' }}>
108
+ <MRT_EditActionButtons row={row} table={table} variant="text" />
109
+ </DialogActions>
110
+ </>
111
+ )}
112
+ </Dialog>
113
+ );
114
+ };
@@ -0,0 +1,86 @@
1
+ import { useMemo } from 'react';
2
+ import Table, { type TableProps } from '@mui/material/Table';
3
+ import { useMRT_ColumnVirtualizer } from '../../hooks/useMRT_ColumnVirtualizer';
4
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
5
+ import { parseCSSVarId } from '../../utils/style.utils';
6
+ import { parseFromValuesOrFunc } from '../../utils/utils';
7
+ import { MRT_TableBody, Memo_MRT_TableBody } from '../body/MRT_TableBody';
8
+ import { MRT_TableFooter } from '../footer/MRT_TableFooter';
9
+ import { MRT_TableHead } from '../head/MRT_TableHead';
10
+
11
+ export interface MRT_TableProps<TData extends MRT_RowData> extends TableProps {
12
+ table: MRT_TableInstance<TData>;
13
+ }
14
+
15
+ export const MRT_Table = <TData extends MRT_RowData>({
16
+ table,
17
+ ...rest
18
+ }: MRT_TableProps<TData>) => {
19
+ const {
20
+ getFlatHeaders,
21
+ getState,
22
+ options: {
23
+ columns,
24
+ enableStickyHeader,
25
+ enableTableFooter,
26
+ enableTableHead,
27
+ layoutMode,
28
+ memoMode,
29
+ muiTableProps,
30
+ renderCaption,
31
+ },
32
+ } = table;
33
+ const { columnSizing, columnSizingInfo, columnVisibility, isFullScreen } =
34
+ getState();
35
+
36
+ const tableProps = {
37
+ ...parseFromValuesOrFunc(muiTableProps, { table }),
38
+ ...rest,
39
+ };
40
+
41
+ const Caption = parseFromValuesOrFunc(renderCaption, { table });
42
+
43
+ const columnSizeVars = useMemo(() => {
44
+ const headers = getFlatHeaders();
45
+ const colSizes: { [key: string]: number } = {};
46
+ for (let i = 0; i < headers.length; i++) {
47
+ const header = headers[i];
48
+ const colSize = header.getSize();
49
+ colSizes[`--header-${parseCSSVarId(header.id)}-size`] = colSize;
50
+ colSizes[`--col-${parseCSSVarId(header.column.id)}-size`] = colSize;
51
+ }
52
+ return colSizes;
53
+ }, [columns, columnSizing, columnSizingInfo, columnVisibility]);
54
+
55
+ const columnVirtualizer = useMRT_ColumnVirtualizer(table);
56
+
57
+ const commonTableGroupProps = {
58
+ columnVirtualizer,
59
+ table,
60
+ };
61
+
62
+ return (
63
+ <Table
64
+ stickyHeader={enableStickyHeader || isFullScreen}
65
+ {...tableProps}
66
+ style={{ ...columnSizeVars, ...tableProps?.style }}
67
+ sx={[
68
+ {
69
+ borderCollapse: 'separate',
70
+ display: layoutMode?.startsWith('grid') ? 'grid' : undefined,
71
+ position: 'relative',
72
+ },
73
+ ...(Array.isArray(tableProps?.sx) ? tableProps.sx : [tableProps?.sx]),
74
+ ]}
75
+ >
76
+ {!!Caption && <caption>{Caption}</caption>}
77
+ {enableTableHead && <MRT_TableHead {...commonTableGroupProps} />}
78
+ {memoMode === 'table-body' || columnSizingInfo.isResizingColumn ? (
79
+ <Memo_MRT_TableBody {...commonTableGroupProps} />
80
+ ) : (
81
+ <MRT_TableBody {...commonTableGroupProps} />
82
+ )}
83
+ {enableTableFooter && <MRT_TableFooter {...commonTableGroupProps} />}
84
+ </Table>
85
+ );
86
+ };