@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,182 @@
1
+ import { Fragment, useMemo } from 'react';
2
+ import Alert, { type AlertProps } from '@mui/material/Alert';
3
+ import AlertTitle from '@mui/material/AlertTitle';
4
+ import Box from '@mui/material/Box';
5
+ import Button from '@mui/material/Button';
6
+ import Chip from '@mui/material/Chip';
7
+ import Collapse from '@mui/material/Collapse';
8
+ import Stack from '@mui/material/Stack';
9
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
10
+ import { getMRT_SelectAllHandler } from '../../utils/row.utils';
11
+ import { parseFromValuesOrFunc } from '../../utils/utils';
12
+ import { MRT_SelectCheckbox } from '../inputs/MRT_SelectCheckbox';
13
+
14
+ export interface MRT_ToolbarAlertBannerProps<TData extends MRT_RowData>
15
+ extends AlertProps {
16
+ stackAlertBanner?: boolean;
17
+ table: MRT_TableInstance<TData>;
18
+ }
19
+
20
+ export const MRT_ToolbarAlertBanner = <TData extends MRT_RowData>({
21
+ stackAlertBanner,
22
+ table,
23
+ ...rest
24
+ }: MRT_ToolbarAlertBannerProps<TData>) => {
25
+ const {
26
+ getFilteredSelectedRowModel,
27
+ getCoreRowModel,
28
+ getState,
29
+ options: {
30
+ enableRowSelection,
31
+ enableSelectAll,
32
+ localization,
33
+ manualPagination,
34
+ muiToolbarAlertBannerChipProps,
35
+ muiToolbarAlertBannerProps,
36
+ positionToolbarAlertBanner,
37
+ renderToolbarAlertBannerContent,
38
+ rowCount,
39
+ },
40
+ refs: { tablePaperRef },
41
+ } = table;
42
+ const { density, grouping, rowSelection, showAlertBanner } = getState();
43
+
44
+ const alertProps = {
45
+ ...parseFromValuesOrFunc(muiToolbarAlertBannerProps, {
46
+ table,
47
+ }),
48
+ ...rest,
49
+ };
50
+
51
+ const chipProps = parseFromValuesOrFunc(muiToolbarAlertBannerChipProps, {
52
+ table,
53
+ });
54
+
55
+ const totalRowCount = rowCount ?? getCoreRowModel().rows.length;
56
+ const filteredRowCount = getFilteredSelectedRowModel().rows.length;
57
+
58
+ const selectedRowCount = useMemo(
59
+ () =>
60
+ manualPagination
61
+ ? Object.values(rowSelection).filter(Boolean).length
62
+ : filteredRowCount,
63
+ [rowSelection, totalRowCount, manualPagination, filteredRowCount],
64
+ );
65
+ const selectedAlert =
66
+ selectedRowCount > 0 ? (
67
+ <Stack sx={{ alignItems: 'center', gap: '16px' }} direction="row">
68
+ {localization.selectedCountOfRowCountRowsSelected
69
+ ?.replace(
70
+ '{selectedCount}',
71
+ selectedRowCount.toLocaleString(localization.language),
72
+ )
73
+ ?.replace(
74
+ '{rowCount}',
75
+ totalRowCount.toLocaleString(localization.language),
76
+ )}
77
+ <Button
78
+ onClick={(event) =>
79
+ getMRT_SelectAllHandler({ table })(event, false, true)
80
+ }
81
+ size="small"
82
+ sx={{ p: '2px' }}
83
+ >
84
+ {localization.clearSelection}
85
+ </Button>
86
+ </Stack>
87
+ ) : null;
88
+
89
+ const groupedAlert =
90
+ grouping.length > 0 ? (
91
+ <span>
92
+ {localization.groupedBy}{' '}
93
+ {grouping.map((columnId, index) => (
94
+ <Fragment key={`${index}-${columnId}`}>
95
+ {index > 0 ? localization.thenBy : ''}
96
+ <Chip
97
+ label={table.getColumn(columnId).columnDef.header}
98
+ onDelete={() => table.getColumn(columnId).toggleGrouping()}
99
+ {...chipProps}
100
+ />
101
+ </Fragment>
102
+ ))}
103
+ </span>
104
+ ) : null;
105
+
106
+ return (
107
+ <Collapse
108
+ in={showAlertBanner || !!selectedAlert || !!groupedAlert}
109
+ timeout={stackAlertBanner ? 200 : 0}
110
+ >
111
+ <Alert
112
+ color="info"
113
+ icon={false}
114
+ {...alertProps}
115
+ sx={[
116
+ () => ({
117
+ '& .MuiAlert-message': {
118
+ maxWidth: `calc(${
119
+ tablePaperRef.current?.clientWidth ?? 360
120
+ }px - 1rem)`,
121
+ width: '100%',
122
+ },
123
+ borderRadius: 0,
124
+ fontSize: '1rem',
125
+ left: 0,
126
+ mb: stackAlertBanner
127
+ ? 0
128
+ : positionToolbarAlertBanner === 'bottom'
129
+ ? '-1rem'
130
+ : undefined,
131
+ p: 0,
132
+ position: 'relative',
133
+ right: 0,
134
+ top: 0,
135
+ width: '100%',
136
+ zIndex: 2,
137
+ }),
138
+ ...(Array.isArray(alertProps?.sx)
139
+ ? alertProps.sx
140
+ : [alertProps?.sx]),
141
+ ]}
142
+ >
143
+ {renderToolbarAlertBannerContent?.({
144
+ groupedAlert,
145
+ selectedAlert,
146
+ table,
147
+ }) ?? (
148
+ <>
149
+ {alertProps?.title && <AlertTitle>{alertProps.title}</AlertTitle>}
150
+ <Stack
151
+ sx={{
152
+ p:
153
+ positionToolbarAlertBanner !== 'head-overlay'
154
+ ? '0.5rem 1rem'
155
+ : density === 'spacious'
156
+ ? '0.75rem 1.25rem'
157
+ : density === 'comfortable'
158
+ ? '0.5rem 0.75rem'
159
+ : '0.25rem 0.5rem',
160
+ }}
161
+ >
162
+ {alertProps?.children}
163
+ {alertProps?.children && (selectedAlert || groupedAlert) && (
164
+ <br />
165
+ )}
166
+ <Box sx={{ display: 'flex' }}>
167
+ {enableRowSelection &&
168
+ enableSelectAll &&
169
+ positionToolbarAlertBanner === 'head-overlay' && (
170
+ <MRT_SelectCheckbox table={table} />
171
+ )}{' '}
172
+ {selectedAlert}
173
+ </Box>
174
+ {selectedAlert && groupedAlert && <br />}
175
+ {groupedAlert}
176
+ </Stack>
177
+ </>
178
+ )}
179
+ </Alert>
180
+ </Collapse>
181
+ );
182
+ };
@@ -0,0 +1,82 @@
1
+ import { type DragEvent, useEffect } from 'react';
2
+ import Box, { type BoxProps } from '@mui/material/Box';
3
+ import Fade from '@mui/material/Fade';
4
+ import Typography from '@mui/material/Typography';
5
+ import { alpha } from '@mui/material/styles';
6
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
7
+
8
+ export interface MRT_ToolbarDropZoneProps<TData extends MRT_RowData>
9
+ extends BoxProps {
10
+ table: MRT_TableInstance<TData>;
11
+ }
12
+
13
+ export const MRT_ToolbarDropZone = <TData extends MRT_RowData>({
14
+ table,
15
+ ...rest
16
+ }: MRT_ToolbarDropZoneProps<TData>) => {
17
+ const {
18
+ getState,
19
+ options: { enableGrouping, localization },
20
+ setHoveredColumn,
21
+ setShowToolbarDropZone,
22
+ } = table;
23
+
24
+ const { draggingColumn, grouping, hoveredColumn, showToolbarDropZone } =
25
+ getState();
26
+
27
+ const handleDragEnter = (_event: DragEvent<HTMLDivElement>) => {
28
+ setHoveredColumn({ id: 'drop-zone' });
29
+ };
30
+
31
+ const handleDragOver = (e: DragEvent) => {
32
+ e.preventDefault();
33
+ };
34
+
35
+ useEffect(() => {
36
+ if (table.options.state?.showToolbarDropZone !== undefined) {
37
+ setShowToolbarDropZone(
38
+ !!enableGrouping &&
39
+ !!draggingColumn &&
40
+ draggingColumn.columnDef.enableGrouping !== false &&
41
+ !grouping.includes(draggingColumn.id),
42
+ );
43
+ }
44
+ }, [enableGrouping, draggingColumn, grouping]);
45
+
46
+ return (
47
+ <Fade in={showToolbarDropZone}>
48
+ <Box
49
+ className="Mui-ToolbarDropZone"
50
+ onDragEnter={handleDragEnter}
51
+ onDragOver={handleDragOver}
52
+ {...rest}
53
+ sx={[
54
+ (theme) => ({
55
+ alignItems: 'center',
56
+ backdropFilter: 'blur(4px)',
57
+ backgroundColor: alpha(
58
+ theme.palette.info.main,
59
+ hoveredColumn?.id === 'drop-zone' ? 0.2 : 0.1,
60
+ ),
61
+ border: `dashed ${theme.palette.info.main} 2px`,
62
+ boxSizing: 'border-box',
63
+ display: 'flex',
64
+ height: '100%',
65
+ justifyContent: 'center',
66
+ position: 'absolute',
67
+ width: '100%',
68
+ zIndex: 4,
69
+ }),
70
+ ...(Array.isArray(rest?.sx) ? rest.sx : [rest?.sx]),
71
+ ]}
72
+ >
73
+ <Typography sx={{ fontStyle: 'italic' }}>
74
+ {localization.dropToGroupBy.replace(
75
+ '{column}',
76
+ draggingColumn?.columnDef?.header ?? '',
77
+ )}
78
+ </Typography>
79
+ </Box>
80
+ </Fade>
81
+ );
82
+ };
@@ -0,0 +1,73 @@
1
+ import Box, { type BoxProps } from '@mui/material/Box';
2
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
3
+ import { MRT_ShowHideColumnsButton } from '../buttons/MRT_ShowHideColumnsButton';
4
+ import { MRT_ToggleDensePaddingButton } from '../buttons/MRT_ToggleDensePaddingButton';
5
+ import { MRT_ToggleFiltersButton } from '../buttons/MRT_ToggleFiltersButton';
6
+ import { MRT_ToggleFullScreenButton } from '../buttons/MRT_ToggleFullScreenButton';
7
+ import { MRT_ToggleGlobalFilterButton } from '../buttons/MRT_ToggleGlobalFilterButton';
8
+
9
+ export interface MRT_ToolbarInternalButtonsProps<TData extends MRT_RowData>
10
+ extends BoxProps {
11
+ table: MRT_TableInstance<TData>;
12
+ }
13
+
14
+ export const MRT_ToolbarInternalButtons = <TData extends MRT_RowData>({
15
+ table,
16
+ ...rest
17
+ }: MRT_ToolbarInternalButtonsProps<TData>) => {
18
+ const {
19
+ options: {
20
+ columnFilterDisplayMode,
21
+ enableColumnFilters,
22
+ enableColumnOrdering,
23
+ enableColumnPinning,
24
+ enableDensityToggle,
25
+ enableFilters,
26
+ enableFullScreenToggle,
27
+ enableGlobalFilter,
28
+ enableHiding,
29
+ initialState,
30
+ renderToolbarInternalActions,
31
+ },
32
+ } = table;
33
+
34
+ return (
35
+ <Box
36
+ {...rest}
37
+ sx={[
38
+ {
39
+ alignItems: 'center',
40
+ display: 'flex',
41
+ zIndex: 3,
42
+ },
43
+ ...(Array.isArray(rest?.sx) ? rest.sx : [rest?.sx]),
44
+ ]}
45
+ >
46
+ {renderToolbarInternalActions?.({
47
+ table,
48
+ }) ?? (
49
+ <>
50
+ {enableFilters &&
51
+ enableGlobalFilter &&
52
+ !initialState?.showGlobalFilter && (
53
+ <MRT_ToggleGlobalFilterButton table={table} />
54
+ )}
55
+ {enableFilters &&
56
+ enableColumnFilters &&
57
+ columnFilterDisplayMode !== 'popover' && (
58
+ <MRT_ToggleFiltersButton table={table} />
59
+ )}
60
+ {(enableHiding || enableColumnOrdering || enableColumnPinning) && (
61
+ <MRT_ShowHideColumnsButton table={table} />
62
+ )}
63
+ {enableDensityToggle && (
64
+ <MRT_ToggleDensePaddingButton table={table} />
65
+ )}
66
+ {enableFullScreenToggle && (
67
+ <MRT_ToggleFullScreenButton table={table} />
68
+ )}
69
+ </>
70
+ )}
71
+ </Box>
72
+ );
73
+ };
@@ -0,0 +1,134 @@
1
+ import Box from '@mui/material/Box';
2
+ import useMediaQuery from '@mui/material/useMediaQuery';
3
+ import { MRT_LinearProgressBar } from './MRT_LinearProgressBar';
4
+ import { MRT_TablePagination } from './MRT_TablePagination';
5
+ import { MRT_ToolbarAlertBanner } from './MRT_ToolbarAlertBanner';
6
+ import { MRT_ToolbarDropZone } from './MRT_ToolbarDropZone';
7
+ import { MRT_ToolbarInternalButtons } from './MRT_ToolbarInternalButtons';
8
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
9
+ import { getCommonToolbarStyles } from '../../utils/style.utils';
10
+ import { parseFromValuesOrFunc } from '../../utils/utils';
11
+ import { MRT_GlobalFilterTextField } from '../inputs/MRT_GlobalFilterTextField';
12
+
13
+ export interface MRT_TopToolbarProps<TData extends MRT_RowData> {
14
+ table: MRT_TableInstance<TData>;
15
+ }
16
+
17
+ export const MRT_TopToolbar = <TData extends MRT_RowData>({
18
+ table,
19
+ }: MRT_TopToolbarProps<TData>) => {
20
+ const {
21
+ getState,
22
+ options: {
23
+ enableGlobalFilter,
24
+ enablePagination,
25
+ enableToolbarInternalActions,
26
+ muiTopToolbarProps,
27
+ positionGlobalFilter,
28
+ positionPagination,
29
+ positionToolbarAlertBanner,
30
+ positionToolbarDropZone,
31
+ renderTopToolbarCustomActions,
32
+ },
33
+ refs: { topToolbarRef },
34
+ } = table;
35
+
36
+ const { isFullScreen, showGlobalFilter } = getState();
37
+
38
+ const isMobile = useMediaQuery('(max-width:720px)');
39
+ const isTablet = useMediaQuery('(max-width:1024px)');
40
+
41
+ const toolbarProps = parseFromValuesOrFunc(muiTopToolbarProps, { table });
42
+
43
+ const stackAlertBanner =
44
+ isMobile ||
45
+ !!renderTopToolbarCustomActions ||
46
+ (showGlobalFilter && isTablet);
47
+
48
+ const globalFilterProps = {
49
+ sx: !isTablet
50
+ ? {
51
+ zIndex: 2,
52
+ }
53
+ : undefined,
54
+ table,
55
+ };
56
+
57
+ return (
58
+ <Box
59
+ {...toolbarProps}
60
+ ref={(ref: HTMLDivElement) => {
61
+ topToolbarRef.current = ref;
62
+ if (toolbarProps?.ref) {
63
+ // @ts-expect-error
64
+ toolbarProps.ref.current = ref;
65
+ }
66
+ }}
67
+ sx={[
68
+ (theme) => ({
69
+ ...getCommonToolbarStyles({ table, theme }),
70
+ position: isFullScreen ? 'sticky' : 'relative',
71
+ top: isFullScreen ? '0' : undefined,
72
+ }),
73
+ ...(Array.isArray(toolbarProps?.sx)
74
+ ? toolbarProps.sx
75
+ : [toolbarProps?.sx]),
76
+ ]}
77
+ >
78
+ {positionToolbarAlertBanner === 'top' && (
79
+ <MRT_ToolbarAlertBanner
80
+ stackAlertBanner={stackAlertBanner}
81
+ table={table}
82
+ />
83
+ )}
84
+ {['both', 'top'].includes(positionToolbarDropZone ?? '') && (
85
+ <MRT_ToolbarDropZone table={table} />
86
+ )}
87
+ <Box
88
+ sx={{
89
+ alignItems: 'flex-start',
90
+ boxSizing: 'border-box',
91
+ display: 'flex',
92
+ gap: '0.5rem',
93
+ justifyContent: 'space-between',
94
+ p: '0.5rem',
95
+ position: stackAlertBanner ? 'relative' : 'absolute',
96
+ right: 0,
97
+ top: 0,
98
+ width: '100%',
99
+ }}
100
+ >
101
+ {enableGlobalFilter && positionGlobalFilter === 'left' && (
102
+ <MRT_GlobalFilterTextField {...globalFilterProps} />
103
+ )}
104
+ {renderTopToolbarCustomActions?.({ table }) ?? <span />}
105
+ {enableToolbarInternalActions ? (
106
+ <Box
107
+ sx={{
108
+ alignItems: 'center',
109
+ display: 'flex',
110
+ flexWrap: 'wrap-reverse',
111
+ gap: '0.5rem',
112
+ justifyContent: 'flex-end',
113
+ }}
114
+ >
115
+ {enableGlobalFilter && positionGlobalFilter === 'right' && (
116
+ <MRT_GlobalFilterTextField {...globalFilterProps} />
117
+ )}
118
+ <MRT_ToolbarInternalButtons table={table} />
119
+ </Box>
120
+ ) : (
121
+ enableGlobalFilter &&
122
+ positionGlobalFilter === 'right' && (
123
+ <MRT_GlobalFilterTextField {...globalFilterProps} />
124
+ )
125
+ )}
126
+ </Box>
127
+ {enablePagination &&
128
+ ['both', 'top'].includes(positionPagination ?? '') && (
129
+ <MRT_TablePagination position="top" table={table} />
130
+ )}
131
+ <MRT_LinearProgressBar isTopToolbar table={table} />
132
+ </Box>
133
+ );
134
+ };
@@ -0,0 +1,3 @@
1
+ import { aggregationFns } from '@tanstack/react-table';
2
+
3
+ export const MRT_AggregationFns = { ...aggregationFns };
@@ -0,0 +1,196 @@
1
+ import {
2
+ type RankingInfo,
3
+ rankItem,
4
+ rankings,
5
+ } from '@tanstack/match-sorter-utils';
6
+ import { type Row, filterFns } from '@tanstack/react-table';
7
+ import { type MRT_RowData } from '../types';
8
+
9
+ const fuzzy = <TData extends MRT_RowData>(
10
+ row: Row<TData>,
11
+ columnId: string,
12
+ filterValue: number | string,
13
+ addMeta: (item: RankingInfo) => void,
14
+ ): boolean => {
15
+ const itemRank = rankItem(
16
+ row.getValue<string | number | null>(columnId),
17
+ filterValue as string,
18
+ {
19
+ threshold: rankings.MATCHES,
20
+ },
21
+ );
22
+ addMeta(itemRank);
23
+ return itemRank.passed;
24
+ };
25
+
26
+ fuzzy.autoRemove = (val: any) => !val;
27
+
28
+ const contains = <TData extends MRT_RowData>(
29
+ row: Row<TData>,
30
+ id: string,
31
+ filterValue: number | string,
32
+ ): boolean =>
33
+ !!row
34
+ .getValue<number | string | null>(id)
35
+ ?.toString()
36
+ .toLowerCase()
37
+ .trim()
38
+ .includes(filterValue.toString().toLowerCase().trim());
39
+
40
+ contains.autoRemove = (val: any) => !val;
41
+
42
+ const startsWith = <TData extends MRT_RowData>(
43
+ row: Row<TData>,
44
+ id: string,
45
+ filterValue: number | string,
46
+ ): boolean =>
47
+ !!row
48
+ .getValue<number | string | null>(id)
49
+ ?.toString()
50
+ .toLowerCase()
51
+ .trim()
52
+ .startsWith(filterValue.toString().toLowerCase().trim());
53
+
54
+ startsWith.autoRemove = (val: any) => !val;
55
+
56
+ const endsWith = <TData extends MRT_RowData>(
57
+ row: Row<TData>,
58
+ id: string,
59
+ filterValue: number | string,
60
+ ): boolean =>
61
+ !!row
62
+ .getValue<number | string | null>(id)
63
+ ?.toString()
64
+ .toLowerCase()
65
+ .trim()
66
+ .endsWith(filterValue.toString().toLowerCase().trim());
67
+
68
+ endsWith.autoRemove = (val: any) => !val;
69
+
70
+ const equals = <TData extends MRT_RowData>(
71
+ row: Row<TData>,
72
+ id: string,
73
+ filterValue: number | string,
74
+ ): boolean =>
75
+ row.getValue<number | string | null>(id)?.toString().toLowerCase().trim() ===
76
+ filterValue.toString().toLowerCase().trim();
77
+
78
+ equals.autoRemove = (val: any) => !val;
79
+
80
+ const notEquals = <TData extends MRT_RowData>(
81
+ row: Row<TData>,
82
+ id: string,
83
+ filterValue: number | string,
84
+ ): boolean =>
85
+ row.getValue<number | string | null>(id)?.toString().toLowerCase().trim() !==
86
+ filterValue.toString().toLowerCase().trim();
87
+
88
+ notEquals.autoRemove = (val: any) => !val;
89
+
90
+ const greaterThan = <TData extends MRT_RowData>(
91
+ row: Row<TData>,
92
+ id: string,
93
+ filterValue: number | string,
94
+ ): boolean =>
95
+ !isNaN(+filterValue) && !isNaN(+row.getValue<number | string>(id))
96
+ ? +(row.getValue<number | string | null>(id) ?? 0) > +filterValue
97
+ : (row.getValue<number | string | null>(id) ?? '')
98
+ ?.toString()
99
+ .toLowerCase()
100
+ .trim() > filterValue.toString().toLowerCase().trim();
101
+
102
+ greaterThan.autoRemove = (val: any) => !val;
103
+
104
+ const greaterThanOrEqualTo = <TData extends MRT_RowData>(
105
+ row: Row<TData>,
106
+ id: string,
107
+ filterValue: number | string,
108
+ ): boolean => equals(row, id, filterValue) || greaterThan(row, id, filterValue);
109
+
110
+ greaterThanOrEqualTo.autoRemove = (val: any) => !val;
111
+
112
+ const lessThan = <TData extends MRT_RowData>(
113
+ row: Row<TData>,
114
+ id: string,
115
+ filterValue: number | string,
116
+ ): boolean =>
117
+ !isNaN(+filterValue) && !isNaN(+row.getValue<number | string>(id))
118
+ ? +(row.getValue<number | string | null>(id) ?? 0) < +filterValue
119
+ : (row.getValue<number | string | null>(id) ?? '')
120
+ ?.toString()
121
+ .toLowerCase()
122
+ .trim() < filterValue.toString().toLowerCase().trim();
123
+
124
+ lessThan.autoRemove = (val: any) => !val;
125
+
126
+ const lessThanOrEqualTo = <TData extends MRT_RowData>(
127
+ row: Row<TData>,
128
+ id: string,
129
+ filterValue: number | string,
130
+ ): boolean => equals(row, id, filterValue) || lessThan(row, id, filterValue);
131
+
132
+ lessThanOrEqualTo.autoRemove = (val: any) => !val;
133
+
134
+ const between = <TData extends MRT_RowData>(
135
+ row: Row<TData>,
136
+ id: string,
137
+ filterValues: [number | string, number | string],
138
+ ): boolean =>
139
+ ((['', undefined] as any[]).includes(filterValues[0]) ||
140
+ greaterThan(row, id, filterValues[0])) &&
141
+ ((!isNaN(+filterValues[0]) &&
142
+ !isNaN(+filterValues[1]) &&
143
+ +filterValues[0] > +filterValues[1]) ||
144
+ (['', undefined] as any[]).includes(filterValues[1]) ||
145
+ lessThan(row, id, filterValues[1]));
146
+
147
+ between.autoRemove = (val: any) => !val;
148
+
149
+ const betweenInclusive = <TData extends MRT_RowData>(
150
+ row: Row<TData>,
151
+ id: string,
152
+ filterValues: [number | string, number | string],
153
+ ): boolean =>
154
+ ((['', undefined] as any[]).includes(filterValues[0]) ||
155
+ greaterThanOrEqualTo(row, id, filterValues[0])) &&
156
+ ((!isNaN(+filterValues[0]) &&
157
+ !isNaN(+filterValues[1]) &&
158
+ +filterValues[0] > +filterValues[1]) ||
159
+ (['', undefined] as any[]).includes(filterValues[1]) ||
160
+ lessThanOrEqualTo(row, id, filterValues[1]));
161
+
162
+ betweenInclusive.autoRemove = (val: any) => !val;
163
+
164
+ const empty = <TData extends MRT_RowData>(
165
+ row: Row<TData>,
166
+ id: string,
167
+ _filterValue: number | string,
168
+ ): boolean => !row.getValue<number | string | null>(id)?.toString().trim();
169
+
170
+ empty.autoRemove = (val: any) => !val;
171
+
172
+ const notEmpty = <TData extends MRT_RowData>(
173
+ row: Row<TData>,
174
+ id: string,
175
+ _filterValue: number | string,
176
+ ): boolean => !!row.getValue<number | string | null>(id)?.toString().trim();
177
+
178
+ notEmpty.autoRemove = (val: any) => !val;
179
+
180
+ export const MRT_FilterFns = {
181
+ ...filterFns,
182
+ between,
183
+ betweenInclusive,
184
+ contains,
185
+ empty,
186
+ endsWith,
187
+ equals,
188
+ fuzzy,
189
+ greaterThan,
190
+ greaterThanOrEqualTo,
191
+ lessThan,
192
+ lessThanOrEqualTo,
193
+ notEmpty,
194
+ notEquals,
195
+ startsWith,
196
+ };
@@ -0,0 +1,33 @@
1
+ import { type RankingInfo, compareItems } from '@tanstack/match-sorter-utils';
2
+ import { type Row, sortingFns } from '@tanstack/react-table';
3
+ import { type MRT_Row, type MRT_RowData } from '../types';
4
+
5
+ const fuzzy = <TData extends MRT_RowData>(
6
+ rowA: Row<TData>,
7
+ rowB: Row<TData>,
8
+ columnId: string,
9
+ ) => {
10
+ let dir = 0;
11
+ if (rowA.columnFiltersMeta[columnId]) {
12
+ dir = compareItems(
13
+ rowA.columnFiltersMeta[columnId] as RankingInfo,
14
+ rowB.columnFiltersMeta[columnId] as RankingInfo,
15
+ );
16
+ }
17
+ // Provide a fallback for when the item ranks are equal
18
+ return dir === 0
19
+ ? sortingFns.alphanumeric(rowA as Row<any>, rowB as Row<any>, columnId)
20
+ : dir;
21
+ };
22
+
23
+ export const MRT_SortingFns = {
24
+ ...sortingFns,
25
+ fuzzy,
26
+ };
27
+
28
+ export const rankGlobalFuzzy = <TData extends MRT_RowData>(
29
+ rowA: MRT_Row<TData>,
30
+ rowB: MRT_Row<TData>,
31
+ ) =>
32
+ Math.max(...Object.values(rowB.columnFiltersMeta).map((v: any) => v.rank)) -
33
+ Math.max(...Object.values(rowA.columnFiltersMeta).map((v: any) => v.rank));