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

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 +203 -0
  3. package/dist/index.cjs +5207 -0
  4. package/dist/index.cjs.map +1 -0
  5. package/dist/index.d.ts +1871 -0
  6. package/dist/index.js +5101 -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 +107 -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 +629 -0
  237. package/src/components/inputs/MRT_GlobalFilterTextField.tsx +165 -0
  238. package/src/components/inputs/MRT_SelectCheckbox.tsx +142 -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 +250 -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 +1295 -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,46 @@
1
+ import IconButton, { type IconButtonProps } from '@mui/material/IconButton';
2
+ import Tooltip from '@mui/material/Tooltip';
3
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
4
+
5
+ export interface MRT_ToggleGlobalFilterButtonProps<TData extends MRT_RowData>
6
+ extends IconButtonProps {
7
+ table: MRT_TableInstance<TData>;
8
+ }
9
+
10
+ export const MRT_ToggleGlobalFilterButton = <TData extends MRT_RowData>({
11
+ table,
12
+ ...rest
13
+ }: MRT_ToggleGlobalFilterButtonProps<TData>) => {
14
+ const {
15
+ getState,
16
+ options: {
17
+ icons: { SearchIcon, SearchOffIcon },
18
+
19
+ localization,
20
+ },
21
+ refs: { searchInputRef },
22
+ setShowGlobalFilter,
23
+ } = table;
24
+ const { globalFilter, showGlobalFilter } = getState();
25
+
26
+ const handleToggleSearch = () => {
27
+ setShowGlobalFilter(!showGlobalFilter);
28
+ queueMicrotask(() => searchInputRef.current?.focus());
29
+ };
30
+
31
+ return (
32
+ <Tooltip title={rest?.title ?? localization.showHideSearch}>
33
+ <span>
34
+ <IconButton
35
+ aria-label={rest?.title ?? localization.showHideSearch}
36
+ disabled={!!globalFilter && showGlobalFilter}
37
+ onClick={handleToggleSearch}
38
+ {...rest}
39
+ title={undefined}
40
+ >
41
+ {showGlobalFilter ? <SearchOffIcon /> : <SearchIcon />}
42
+ </IconButton>
43
+ </span>
44
+ </Tooltip>
45
+ );
46
+ };
@@ -0,0 +1,126 @@
1
+ import { type MouseEvent, useState } from 'react';
2
+ import IconButton, { type IconButtonProps } from '@mui/material/IconButton';
3
+ import Tooltip from '@mui/material/Tooltip';
4
+ import { MRT_EditActionButtons } from './MRT_EditActionButtons';
5
+ import {
6
+ type MRT_Cell,
7
+ type MRT_Row,
8
+ type MRT_RowData,
9
+ type MRT_TableInstance,
10
+ } from '../../types';
11
+ import { getCommonTooltipProps } from '../../utils/style.utils';
12
+ import { parseFromValuesOrFunc } from '../../utils/utils';
13
+ import { MRT_RowActionMenu } from '../menus/MRT_RowActionMenu';
14
+
15
+ const commonIconButtonStyles = {
16
+ '&:hover': {
17
+ opacity: 1,
18
+ },
19
+ height: '2rem',
20
+ ml: '10px',
21
+ opacity: 0.5,
22
+ transition: 'opacity 150ms',
23
+ width: '2rem',
24
+ };
25
+
26
+ export interface MRT_ToggleRowActionMenuButtonProps<TData extends MRT_RowData>
27
+ extends IconButtonProps {
28
+ cell: MRT_Cell<TData>;
29
+ row: MRT_Row<TData>;
30
+ staticRowIndex?: number;
31
+ table: MRT_TableInstance<TData>;
32
+ }
33
+
34
+ export const MRT_ToggleRowActionMenuButton = <TData extends MRT_RowData>({
35
+ cell,
36
+ row,
37
+ staticRowIndex,
38
+ table,
39
+ ...rest
40
+ }: MRT_ToggleRowActionMenuButtonProps<TData>) => {
41
+ const {
42
+ getState,
43
+ options: {
44
+ createDisplayMode,
45
+ editDisplayMode,
46
+ enableEditing,
47
+ icons: { EditIcon, MoreHorizIcon },
48
+ localization,
49
+ renderRowActionMenuItems,
50
+ renderRowActions,
51
+ },
52
+ setEditingRow,
53
+ } = table;
54
+
55
+ const { creatingRow, editingRow } = getState();
56
+
57
+ const isCreating = creatingRow?.id === row.id;
58
+ const isEditing = editingRow?.id === row.id;
59
+
60
+ const showEditActionButtons =
61
+ (isCreating && createDisplayMode === 'row') ||
62
+ (isEditing && editDisplayMode === 'row');
63
+
64
+ const [anchorEl, setAnchorEl] = useState<HTMLElement | null>(null);
65
+
66
+ const handleOpenRowActionMenu = (event: MouseEvent<HTMLElement>) => {
67
+ event.stopPropagation();
68
+ event.preventDefault();
69
+ setAnchorEl(event.currentTarget);
70
+ };
71
+
72
+ const handleStartEditMode = (event: MouseEvent) => {
73
+ event.stopPropagation();
74
+ setEditingRow({ ...row });
75
+ setAnchorEl(null);
76
+ };
77
+
78
+ return (
79
+ <>
80
+ {renderRowActions && !showEditActionButtons ? (
81
+ renderRowActions({ cell, row, staticRowIndex, table })
82
+ ) : showEditActionButtons ? (
83
+ <MRT_EditActionButtons row={row} table={table} />
84
+ ) : !renderRowActionMenuItems &&
85
+ parseFromValuesOrFunc(enableEditing, row) &&
86
+ ['modal', 'row'].includes(editDisplayMode!) ? (
87
+ <Tooltip placement="right" title={localization.edit}>
88
+ <IconButton
89
+ aria-label={localization.edit}
90
+ onClick={handleStartEditMode}
91
+ sx={commonIconButtonStyles}
92
+ {...rest}
93
+ >
94
+ <EditIcon />
95
+ </IconButton>
96
+ </Tooltip>
97
+ ) : renderRowActionMenuItems?.({
98
+ row,
99
+ staticRowIndex,
100
+ table,
101
+ } as any)?.length ? (
102
+ <>
103
+ <Tooltip {...getCommonTooltipProps()} title={localization.rowActions}>
104
+ <IconButton
105
+ aria-label={localization.rowActions}
106
+ onClick={handleOpenRowActionMenu}
107
+ size="small"
108
+ sx={commonIconButtonStyles}
109
+ {...rest}
110
+ >
111
+ <MoreHorizIcon />
112
+ </IconButton>
113
+ </Tooltip>
114
+ <MRT_RowActionMenu
115
+ anchorEl={anchorEl}
116
+ handleEdit={handleStartEditMode}
117
+ row={row}
118
+ setAnchorEl={setAnchorEl}
119
+ staticRowIndex={staticRowIndex}
120
+ table={table}
121
+ />
122
+ </>
123
+ ) : null}
124
+ </>
125
+ );
126
+ };
@@ -0,0 +1,92 @@
1
+ import TableFooter, { type TableFooterProps } from '@mui/material/TableFooter';
2
+ import { MRT_TableFooterRow } from './MRT_TableFooterRow';
3
+ import {
4
+ type MRT_ColumnVirtualizer,
5
+ type MRT_RowData,
6
+ type MRT_TableInstance,
7
+ } from '../../types';
8
+ import { parseFromValuesOrFunc } from '../../utils/utils';
9
+
10
+ export interface MRT_TableFooterProps<TData extends MRT_RowData>
11
+ extends TableFooterProps {
12
+ columnVirtualizer?: MRT_ColumnVirtualizer;
13
+ table: MRT_TableInstance<TData>;
14
+ }
15
+
16
+ export const MRT_TableFooter = <TData extends MRT_RowData>({
17
+ columnVirtualizer,
18
+ table,
19
+ ...rest
20
+ }: MRT_TableFooterProps<TData>) => {
21
+ const {
22
+ getState,
23
+ options: { enableStickyFooter, layoutMode, muiTableFooterProps },
24
+ refs: { tableFooterRef },
25
+ } = table;
26
+ const { isFullScreen } = getState();
27
+
28
+ const tableFooterProps = {
29
+ ...parseFromValuesOrFunc(muiTableFooterProps, {
30
+ table,
31
+ }),
32
+ ...rest,
33
+ };
34
+
35
+ const stickFooter =
36
+ (isFullScreen || enableStickyFooter) && enableStickyFooter !== false;
37
+
38
+ const footerGroups = table.getFooterGroups();
39
+
40
+ //if no footer cells at all, skip footer
41
+ if (
42
+ !footerGroups.some((footerGroup) =>
43
+ footerGroup.headers?.some(
44
+ (header) =>
45
+ (typeof header.column.columnDef.footer === 'string' &&
46
+ !!header.column.columnDef.footer) ||
47
+ header.column.columnDef.Footer,
48
+ ),
49
+ )
50
+ ) {
51
+ return null;
52
+ }
53
+
54
+ return (
55
+ <TableFooter
56
+ {...tableFooterProps}
57
+ ref={(ref: HTMLTableSectionElement) => {
58
+ tableFooterRef.current = ref;
59
+ if (tableFooterProps?.ref) {
60
+ // @ts-expect-error
61
+ tableFooterProps.ref.current = ref;
62
+ }
63
+ }}
64
+ sx={[
65
+ (theme) => ({
66
+ bottom: stickFooter ? 0 : undefined,
67
+ display: layoutMode?.startsWith('grid') ? 'grid' : undefined,
68
+ opacity: stickFooter ? 0.97 : undefined,
69
+ outline: stickFooter
70
+ ? theme.palette.mode === 'light'
71
+ ? `1px solid ${theme.palette.grey[300]}`
72
+ : `1px solid ${theme.palette.grey[700]}`
73
+ : undefined,
74
+ position: stickFooter ? 'sticky' : 'relative',
75
+ zIndex: stickFooter ? 1 : undefined,
76
+ }),
77
+ ...(Array.isArray(tableFooterProps?.sx)
78
+ ? tableFooterProps.sx
79
+ : [tableFooterProps?.sx]),
80
+ ]}
81
+ >
82
+ {footerGroups.map((footerGroup) => (
83
+ <MRT_TableFooterRow
84
+ columnVirtualizer={columnVirtualizer}
85
+ footerGroup={footerGroup as any}
86
+ key={footerGroup.id}
87
+ table={table}
88
+ />
89
+ ))}
90
+ </TableFooter>
91
+ );
92
+ };
@@ -0,0 +1,111 @@
1
+ import TableCell, { type TableCellProps } from '@mui/material/TableCell';
2
+ import { useTheme } from '@mui/material/styles';
3
+ import {
4
+ type MRT_Header,
5
+ type MRT_RowData,
6
+ type MRT_TableInstance,
7
+ } from '../../types';
8
+ import { getCommonMRTCellStyles } from '../../utils/style.utils';
9
+ import { parseFromValuesOrFunc } from '../../utils/utils';
10
+ import { cellKeyboardShortcuts } from '../../utils/cell.utils';
11
+
12
+ export interface MRT_TableFooterCellProps<TData extends MRT_RowData>
13
+ extends TableCellProps {
14
+ footer: MRT_Header<TData>;
15
+ staticColumnIndex?: number;
16
+ table: MRT_TableInstance<TData>;
17
+ }
18
+
19
+ export const MRT_TableFooterCell = <TData extends MRT_RowData>({
20
+ footer,
21
+ staticColumnIndex,
22
+ table,
23
+ ...rest
24
+ }: MRT_TableFooterCellProps<TData>) => {
25
+ const theme = useTheme();
26
+ const {
27
+ getState,
28
+ options: {
29
+ enableColumnPinning,
30
+ muiTableFooterCellProps,
31
+ enableKeyboardShortcuts,
32
+ },
33
+ } = table;
34
+ const { density } = getState();
35
+ const { column } = footer;
36
+ const { columnDef } = column;
37
+ const { columnDefType } = columnDef;
38
+
39
+ const isColumnPinned =
40
+ enableColumnPinning &&
41
+ columnDef.columnDefType !== 'group' &&
42
+ column.getIsPinned();
43
+
44
+ const args = { column, table };
45
+ const tableCellProps = {
46
+ ...parseFromValuesOrFunc(muiTableFooterCellProps, args),
47
+ ...parseFromValuesOrFunc(columnDef.muiTableFooterCellProps, args),
48
+ ...rest,
49
+ };
50
+
51
+ const handleKeyDown = (event: React.KeyboardEvent<HTMLTableCellElement>) => {
52
+ tableCellProps?.onKeyDown?.(event);
53
+ cellKeyboardShortcuts({
54
+ event,
55
+ cellValue: footer.column.columnDef.footer,
56
+ table,
57
+ });
58
+ };
59
+
60
+ return (
61
+ <TableCell
62
+ align={
63
+ columnDefType === 'group'
64
+ ? 'center'
65
+ : theme.direction === 'rtl'
66
+ ? 'right'
67
+ : 'left'
68
+ }
69
+ colSpan={footer.colSpan}
70
+ data-index={staticColumnIndex}
71
+ data-pinned={!!isColumnPinned || undefined}
72
+ tabIndex={enableKeyboardShortcuts ? 0 : undefined}
73
+ variant="footer"
74
+ {...tableCellProps}
75
+ onKeyDown={handleKeyDown}
76
+ sx={[
77
+ (theme) => ({
78
+ fontWeight: 'bold',
79
+ p:
80
+ density === 'compact'
81
+ ? '0.5rem'
82
+ : density === 'comfortable'
83
+ ? '1rem'
84
+ : '1.5rem',
85
+ verticalAlign: 'top',
86
+ ...getCommonMRTCellStyles({
87
+ column,
88
+ header: footer,
89
+ table,
90
+ tableCellProps,
91
+ theme,
92
+ }),
93
+ }),
94
+ ...(Array.isArray(tableCellProps.sx)
95
+ ? tableCellProps.sx
96
+ : [tableCellProps.sx]),
97
+ ]}
98
+ >
99
+ {tableCellProps.children ??
100
+ (footer.isPlaceholder
101
+ ? null
102
+ : (parseFromValuesOrFunc(columnDef.Footer, {
103
+ column,
104
+ footer,
105
+ table,
106
+ }) ??
107
+ columnDef.footer ??
108
+ null))}
109
+ </TableCell>
110
+ );
111
+ };
@@ -0,0 +1,99 @@
1
+ import TableRow, { type TableRowProps } from '@mui/material/TableRow';
2
+ import { MRT_TableFooterCell } from './MRT_TableFooterCell';
3
+ import {
4
+ type MRT_ColumnVirtualizer,
5
+ type MRT_Header,
6
+ type MRT_HeaderGroup,
7
+ type MRT_RowData,
8
+ type MRT_TableInstance,
9
+ type MRT_VirtualItem,
10
+ } from '../../types';
11
+ import { parseFromValuesOrFunc } from '../../utils/utils';
12
+
13
+ export interface MRT_TableFooterRowProps<TData extends MRT_RowData>
14
+ extends TableRowProps {
15
+ columnVirtualizer?: MRT_ColumnVirtualizer;
16
+ footerGroup: MRT_HeaderGroup<TData>;
17
+ table: MRT_TableInstance<TData>;
18
+ }
19
+
20
+ export const MRT_TableFooterRow = <TData extends MRT_RowData>({
21
+ columnVirtualizer,
22
+ footerGroup,
23
+ table,
24
+ ...rest
25
+ }: MRT_TableFooterRowProps<TData>) => {
26
+ const {
27
+ options: {
28
+ layoutMode,
29
+ mrtTheme: { baseBackgroundColor },
30
+ muiTableFooterRowProps,
31
+ },
32
+ } = table;
33
+
34
+ const { virtualColumns, virtualPaddingLeft, virtualPaddingRight } =
35
+ columnVirtualizer ?? {};
36
+
37
+ // if no content in row, skip row
38
+ if (
39
+ !footerGroup.headers?.some(
40
+ (header) =>
41
+ (typeof header.column.columnDef.footer === 'string' &&
42
+ !!header.column.columnDef.footer) ||
43
+ header.column.columnDef.Footer,
44
+ )
45
+ ) {
46
+ return null;
47
+ }
48
+
49
+ const tableRowProps = {
50
+ ...parseFromValuesOrFunc(muiTableFooterRowProps, {
51
+ footerGroup,
52
+ table,
53
+ }),
54
+ ...rest,
55
+ };
56
+
57
+ return (
58
+ <TableRow
59
+ {...tableRowProps}
60
+ sx={[
61
+ {
62
+ backgroundColor: baseBackgroundColor,
63
+ display: layoutMode?.startsWith('grid') ? 'flex' : undefined,
64
+ position: 'relative',
65
+ width: '100%',
66
+ },
67
+ ...(Array.isArray(tableRowProps?.sx)
68
+ ? tableRowProps.sx
69
+ : [tableRowProps?.sx]),
70
+ ]}
71
+ >
72
+ {virtualPaddingLeft ? (
73
+ <th style={{ display: 'flex', width: virtualPaddingLeft }} />
74
+ ) : null}
75
+ {(virtualColumns ?? footerGroup.headers).map(
76
+ (footerOrVirtualFooter, staticColumnIndex) => {
77
+ let footer = footerOrVirtualFooter as MRT_Header<TData>;
78
+ if (columnVirtualizer) {
79
+ staticColumnIndex = (footerOrVirtualFooter as MRT_VirtualItem)
80
+ .index;
81
+ footer = footerGroup.headers[staticColumnIndex];
82
+ }
83
+
84
+ return footer ? (
85
+ <MRT_TableFooterCell
86
+ footer={footer}
87
+ key={footer.id}
88
+ staticColumnIndex={staticColumnIndex}
89
+ table={table}
90
+ />
91
+ ) : null;
92
+ },
93
+ )}
94
+ {virtualPaddingRight ? (
95
+ <th style={{ display: 'flex', width: virtualPaddingRight }} />
96
+ ) : null}
97
+ </TableRow>
98
+ );
99
+ };
@@ -0,0 +1,95 @@
1
+ import TableHead, { type TableHeadProps } from '@mui/material/TableHead';
2
+ import { MRT_TableHeadRow } from './MRT_TableHeadRow';
3
+ import {
4
+ type MRT_ColumnVirtualizer,
5
+ type MRT_RowData,
6
+ type MRT_TableInstance,
7
+ } from '../../types';
8
+ import { parseFromValuesOrFunc } from '../../utils/utils';
9
+ import { MRT_ToolbarAlertBanner } from '../toolbar/MRT_ToolbarAlertBanner';
10
+
11
+ export interface MRT_TableHeadProps<TData extends MRT_RowData>
12
+ extends TableHeadProps {
13
+ columnVirtualizer?: MRT_ColumnVirtualizer;
14
+ table: MRT_TableInstance<TData>;
15
+ }
16
+
17
+ export const MRT_TableHead = <TData extends MRT_RowData>({
18
+ columnVirtualizer,
19
+ table,
20
+ ...rest
21
+ }: MRT_TableHeadProps<TData>) => {
22
+ const {
23
+ getState,
24
+ options: {
25
+ enableStickyHeader,
26
+ layoutMode,
27
+ muiTableHeadProps,
28
+ positionToolbarAlertBanner,
29
+ },
30
+ refs: { tableHeadRef },
31
+ } = table;
32
+ const { isFullScreen, showAlertBanner } = getState();
33
+
34
+ const tableHeadProps = {
35
+ ...parseFromValuesOrFunc(muiTableHeadProps, { table }),
36
+ ...rest,
37
+ };
38
+
39
+ const stickyHeader = enableStickyHeader || isFullScreen;
40
+
41
+ return (
42
+ <TableHead
43
+ {...tableHeadProps}
44
+ ref={(ref: HTMLTableSectionElement) => {
45
+ tableHeadRef.current = ref;
46
+ if (tableHeadProps?.ref) {
47
+ // @ts-expect-error
48
+ tableHeadProps.ref.current = ref;
49
+ }
50
+ }}
51
+ sx={[
52
+ {
53
+ display: layoutMode?.startsWith('grid') ? 'grid' : undefined,
54
+ opacity: 0.97,
55
+ position: stickyHeader ? 'sticky' : 'relative',
56
+ top: stickyHeader && layoutMode?.startsWith('grid') ? 0 : undefined,
57
+ zIndex: stickyHeader ? 2 : undefined,
58
+ },
59
+ ...(Array.isArray(tableHeadProps?.sx)
60
+ ? tableHeadProps.sx
61
+ : [tableHeadProps?.sx]),
62
+ ]}
63
+ >
64
+ {positionToolbarAlertBanner === 'head-overlay' &&
65
+ (showAlertBanner || table.getSelectedRowModel().rows.length > 0) ? (
66
+ <tr
67
+ style={{
68
+ display: layoutMode?.startsWith('grid') ? 'grid' : undefined,
69
+ }}
70
+ >
71
+ <th
72
+ colSpan={table.getVisibleLeafColumns().length}
73
+ style={{
74
+ display: layoutMode?.startsWith('grid') ? 'grid' : undefined,
75
+ padding: 0,
76
+ }}
77
+ >
78
+ <MRT_ToolbarAlertBanner table={table} />
79
+ </th>
80
+ </tr>
81
+ ) : (
82
+ table
83
+ .getHeaderGroups()
84
+ .map((headerGroup) => (
85
+ <MRT_TableHeadRow
86
+ columnVirtualizer={columnVirtualizer}
87
+ headerGroup={headerGroup as any}
88
+ key={headerGroup.id}
89
+ table={table}
90
+ />
91
+ ))
92
+ )}
93
+ </TableHead>
94
+ );
95
+ };