@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,165 @@
1
+ import {
2
+ type ChangeEvent,
3
+ type MouseEvent,
4
+ useCallback,
5
+ useEffect,
6
+ useRef,
7
+ useState,
8
+ } from 'react';
9
+ import Collapse from '@mui/material/Collapse';
10
+ import IconButton from '@mui/material/IconButton';
11
+ import InputAdornment from '@mui/material/InputAdornment';
12
+ import TextField, { type TextFieldProps } from '@mui/material/TextField';
13
+ import Tooltip from '@mui/material/Tooltip';
14
+ import { debounce } from '@mui/material/utils';
15
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
16
+ import { parseFromValuesOrFunc, resolveSlotProps } from '../../utils/utils';
17
+ import { MRT_FilterOptionMenu } from '../menus/MRT_FilterOptionMenu';
18
+
19
+ export interface MRT_GlobalFilterTextFieldProps<TData extends MRT_RowData>
20
+ extends TextFieldProps<'standard'> {
21
+ table: MRT_TableInstance<TData>;
22
+ }
23
+
24
+ export const MRT_GlobalFilterTextField = <TData extends MRT_RowData>({
25
+ table,
26
+ ...rest
27
+ }: MRT_GlobalFilterTextFieldProps<TData>) => {
28
+ const {
29
+ getState,
30
+ options: {
31
+ enableGlobalFilterModes,
32
+ icons: { CloseIcon, SearchIcon },
33
+ localization,
34
+ manualFiltering,
35
+ muiSearchTextFieldProps,
36
+ },
37
+ refs: { searchInputRef },
38
+ setGlobalFilter,
39
+ } = table;
40
+ const { globalFilter, showGlobalFilter } = getState();
41
+
42
+ const {
43
+ InputProps: muiInputProps,
44
+ inputProps: muiHtmlInputProps,
45
+ slotProps: muiSlotProps,
46
+ ...textFieldProps
47
+ } = {
48
+ ...parseFromValuesOrFunc(muiSearchTextFieldProps, {
49
+ table,
50
+ }),
51
+ ...rest,
52
+ } as any;
53
+
54
+ const isMounted = useRef(false);
55
+ const [anchorEl, setAnchorEl] = useState<HTMLElement | null>(null);
56
+ const [searchValue, setSearchValue] = useState(globalFilter ?? '');
57
+
58
+ const handleChangeDebounced = useCallback(
59
+ debounce(
60
+ (event: ChangeEvent<HTMLInputElement>) => {
61
+ setGlobalFilter(event.target.value ?? undefined);
62
+ },
63
+ manualFiltering ? 500 : 250,
64
+ ),
65
+ [],
66
+ );
67
+
68
+ const handleChange = (event: ChangeEvent<HTMLInputElement>) => {
69
+ setSearchValue(event.target.value);
70
+ handleChangeDebounced(event);
71
+ (textFieldProps as any)?.onChange?.(event);
72
+ };
73
+
74
+ const handleGlobalFilterMenuOpen = (event: MouseEvent<HTMLElement>) => {
75
+ setAnchorEl(event.currentTarget);
76
+ };
77
+
78
+ const handleClear = () => {
79
+ setSearchValue('');
80
+ setGlobalFilter(undefined);
81
+ };
82
+
83
+ useEffect(() => {
84
+ if (isMounted.current) {
85
+ setSearchValue(globalFilter ?? '');
86
+ }
87
+ isMounted.current = true;
88
+ }, [globalFilter]);
89
+
90
+ return (
91
+ <Collapse in={showGlobalFilter} orientation="horizontal">
92
+ <TextField
93
+ fullWidth
94
+ margin="none"
95
+ placeholder={localization.search}
96
+ variant="standard"
97
+ {...textFieldProps}
98
+ slotProps={{
99
+ ...muiSlotProps,
100
+ htmlInput: (ownerState: any) =>
101
+ resolveSlotProps(
102
+ muiSlotProps?.htmlInput,
103
+ { autoComplete: 'off', ...muiHtmlInputProps },
104
+ ownerState,
105
+ ),
106
+ input: (ownerState: any) =>
107
+ resolveSlotProps(
108
+ muiSlotProps?.input,
109
+ {
110
+ endAdornment: (
111
+ <InputAdornment position="end">
112
+ <Tooltip title={localization.clearSearch ?? ''}>
113
+ <span>
114
+ <IconButton
115
+ aria-label={localization.clearSearch}
116
+ disabled={!searchValue?.length}
117
+ onClick={handleClear}
118
+ size="small"
119
+ >
120
+ <CloseIcon />
121
+ </IconButton>
122
+ </span>
123
+ </Tooltip>
124
+ </InputAdornment>
125
+ ),
126
+ startAdornment: enableGlobalFilterModes ? (
127
+ <InputAdornment position="start">
128
+ <Tooltip title={localization.changeSearchMode}>
129
+ <IconButton
130
+ aria-label={localization.changeSearchMode}
131
+ onClick={handleGlobalFilterMenuOpen}
132
+ size="small"
133
+ sx={{ height: '1.75rem', width: '1.75rem' }}
134
+ >
135
+ <SearchIcon />
136
+ </IconButton>
137
+ </Tooltip>
138
+ </InputAdornment>
139
+ ) : (
140
+ <SearchIcon style={{ marginRight: '4px' }} />
141
+ ),
142
+ sx: { mb: 0 },
143
+ ...muiInputProps,
144
+ },
145
+ ownerState,
146
+ ),
147
+ }}
148
+ inputRef={(inputRef) => {
149
+ searchInputRef.current = inputRef;
150
+ if ((textFieldProps as any)?.inputRef) {
151
+ (textFieldProps as any).inputRef = inputRef;
152
+ }
153
+ }}
154
+ onChange={handleChange}
155
+ value={searchValue ?? ''}
156
+ />
157
+ <MRT_FilterOptionMenu
158
+ anchorEl={anchorEl}
159
+ onSelect={handleClear}
160
+ setAnchorEl={setAnchorEl}
161
+ table={table}
162
+ />
163
+ </Collapse>
164
+ );
165
+ };
@@ -0,0 +1,142 @@
1
+ import { type ChangeEvent, type MouseEvent } from 'react';
2
+ import Checkbox, { type CheckboxProps } from '@mui/material/Checkbox';
3
+ import Radio, { type RadioProps } from '@mui/material/Radio';
4
+ import Tooltip from '@mui/material/Tooltip';
5
+ import { type Theme } from '@mui/material/styles';
6
+ import {
7
+ type MRT_Row,
8
+ type MRT_RowData,
9
+ type MRT_TableInstance,
10
+ } from '../../types';
11
+ import {
12
+ getIsRowSelected,
13
+ getMRT_RowSelectionHandler,
14
+ getMRT_SelectAllHandler,
15
+ } from '../../utils/row.utils';
16
+ import { getCommonTooltipProps } from '../../utils/style.utils';
17
+ import { parseFromValuesOrFunc } from '../../utils/utils';
18
+
19
+ export interface MRT_SelectCheckboxProps<TData extends MRT_RowData>
20
+ extends CheckboxProps {
21
+ row?: MRT_Row<TData>;
22
+ staticRowIndex?: number;
23
+ table: MRT_TableInstance<TData>;
24
+ }
25
+
26
+ export const MRT_SelectCheckbox = <TData extends MRT_RowData>({
27
+ row,
28
+ staticRowIndex,
29
+ table,
30
+ ...rest
31
+ }: MRT_SelectCheckboxProps<TData>) => {
32
+ const {
33
+ getState,
34
+ options: {
35
+ enableMultiRowSelection,
36
+ localization,
37
+ muiSelectAllCheckboxProps,
38
+ muiSelectCheckboxProps,
39
+ selectAllMode,
40
+ },
41
+ } = table;
42
+ const { density, isLoading } = getState();
43
+
44
+ const selectAll = !row;
45
+
46
+ const allRowsSelected = selectAll
47
+ ? selectAllMode === 'page'
48
+ ? table.getIsAllPageRowsSelected()
49
+ : table.getIsAllRowsSelected()
50
+ : undefined;
51
+
52
+ const isChecked = selectAll
53
+ ? allRowsSelected
54
+ : getIsRowSelected({ row, table });
55
+
56
+ const {
57
+ inputProps: muiInputProps,
58
+ slotProps: muiSlotProps,
59
+ ...checkboxProps
60
+ } = ((selectAll
61
+ ? parseFromValuesOrFunc(muiSelectAllCheckboxProps, { table })
62
+ : parseFromValuesOrFunc(muiSelectCheckboxProps, {
63
+ row,
64
+ staticRowIndex,
65
+ table,
66
+ })) ?? {}) as any;
67
+
68
+ const onSelectionChange = row
69
+ ? getMRT_RowSelectionHandler({
70
+ row,
71
+ staticRowIndex,
72
+ table,
73
+ })
74
+ : undefined;
75
+
76
+ const onSelectAllChange = getMRT_SelectAllHandler({ table });
77
+
78
+ const commonProps = {
79
+ 'aria-label': selectAll
80
+ ? localization.toggleSelectAll
81
+ : localization.toggleSelectRow,
82
+ checked: isChecked,
83
+ disabled:
84
+ isLoading || (row && !row.getCanSelect()) || row?.id === 'mrt-row-create',
85
+ slotProps: {
86
+ ...muiSlotProps,
87
+ input: {
88
+ 'aria-label': selectAll
89
+ ? localization.toggleSelectAll
90
+ : localization.toggleSelectRow,
91
+ ...muiInputProps,
92
+ ...muiSlotProps?.input,
93
+ },
94
+ },
95
+ onChange: (event: ChangeEvent<HTMLInputElement>) => {
96
+ event.stopPropagation();
97
+ selectAll ? onSelectAllChange(event) : onSelectionChange!(event);
98
+ },
99
+ size: (density === 'compact' ? 'small' : 'medium') as 'medium' | 'small',
100
+ ...checkboxProps,
101
+ ...rest,
102
+ onClick: (e: MouseEvent<HTMLButtonElement>) => {
103
+ e.stopPropagation();
104
+ (checkboxProps as any)?.onClick?.(e);
105
+ rest?.onClick?.(e);
106
+ },
107
+ sx: (theme: Theme) => ({
108
+ height: density === 'compact' ? '1.75rem' : '2.5rem',
109
+ m: density !== 'compact' ? '-0.4rem' : undefined,
110
+ width: density === 'compact' ? '1.75rem' : '2.5rem',
111
+ zIndex: 0,
112
+ ...parseFromValuesOrFunc((checkboxProps as any)?.sx, theme),
113
+ ...parseFromValuesOrFunc(rest?.sx, theme),
114
+ }),
115
+ title: undefined,
116
+ } as unknown as CheckboxProps | RadioProps;
117
+
118
+ return (
119
+ <Tooltip
120
+ {...getCommonTooltipProps()}
121
+ title={
122
+ checkboxProps?.title ??
123
+ (selectAll
124
+ ? localization.toggleSelectAll
125
+ : localization.toggleSelectRow)
126
+ }
127
+ >
128
+ {enableMultiRowSelection === false ? (
129
+ <Radio {...(commonProps as any)} />
130
+ ) : (
131
+ <Checkbox
132
+ indeterminate={
133
+ !isChecked && selectAll
134
+ ? table.getIsSomeRowsSelected()
135
+ : row?.getIsSomeSelected() && row.getCanSelectSubRows()
136
+ }
137
+ {...commonProps}
138
+ />
139
+ )}
140
+ </Tooltip>
141
+ );
142
+ };
@@ -0,0 +1,62 @@
1
+ import { type ReactNode } from 'react';
2
+ import Box from '@mui/material/Box';
3
+ import IconButton from '@mui/material/IconButton';
4
+ import ListItemIcon from '@mui/material/ListItemIcon';
5
+ import MenuItem, { type MenuItemProps } from '@mui/material/MenuItem';
6
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
7
+
8
+ export interface MRT_ActionMenuItemProps<TData extends MRT_RowData>
9
+ extends MenuItemProps {
10
+ icon: ReactNode;
11
+ label: string;
12
+ onOpenSubMenu?: MenuItemProps['onClick'] | MenuItemProps['onMouseEnter'];
13
+ table: MRT_TableInstance<TData>;
14
+ }
15
+
16
+ export const MRT_ActionMenuItem = <TData extends MRT_RowData>({
17
+ icon,
18
+ label,
19
+ onOpenSubMenu,
20
+ table,
21
+ ...rest
22
+ }: MRT_ActionMenuItemProps<TData>) => {
23
+ const {
24
+ options: {
25
+ icons: { ArrowRightIcon },
26
+ },
27
+ } = table;
28
+
29
+ return (
30
+ <MenuItem
31
+ sx={{
32
+ alignItems: 'center',
33
+ justifyContent: 'space-between',
34
+ minWidth: '120px',
35
+ my: 0,
36
+ py: '6px',
37
+ }}
38
+ tabIndex={0}
39
+ {...rest}
40
+ >
41
+ <Box
42
+ sx={{
43
+ alignItems: 'center',
44
+ display: 'flex',
45
+ }}
46
+ >
47
+ <ListItemIcon>{icon}</ListItemIcon>
48
+ {label}
49
+ </Box>
50
+ {onOpenSubMenu && (
51
+ <IconButton
52
+ onClick={onOpenSubMenu as any}
53
+ onMouseEnter={onOpenSubMenu as any}
54
+ size="small"
55
+ sx={{ p: 0 }}
56
+ >
57
+ <ArrowRightIcon />
58
+ </IconButton>
59
+ )}
60
+ </MenuItem>
61
+ );
62
+ };
@@ -0,0 +1,109 @@
1
+ import Menu, { type MenuProps } from '@mui/material/Menu';
2
+ import { MRT_ActionMenuItem } from './MRT_ActionMenuItem';
3
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
4
+ import { openEditingCell } from '../../utils/cell.utils';
5
+ import { parseFromValuesOrFunc } from '../../utils/utils';
6
+
7
+ export interface MRT_CellActionMenuProps<TData extends MRT_RowData>
8
+ extends Partial<MenuProps> {
9
+ table: MRT_TableInstance<TData>;
10
+ }
11
+
12
+ export const MRT_CellActionMenu = <TData extends MRT_RowData>({
13
+ table,
14
+ ...rest
15
+ }: MRT_CellActionMenuProps<TData>) => {
16
+ const {
17
+ getState,
18
+ options: {
19
+ editDisplayMode,
20
+ enableClickToCopy,
21
+ enableEditing,
22
+ icons: { ContentCopy, EditIcon },
23
+ localization,
24
+ mrtTheme: { menuBackgroundColor },
25
+ renderCellActionMenuItems,
26
+ },
27
+ refs: { actionCellRef },
28
+ } = table;
29
+ const { actionCell, density } = getState();
30
+ const cell = actionCell!;
31
+ const { row } = cell;
32
+ const { column } = cell;
33
+ const { columnDef } = column;
34
+
35
+ const handleClose = (event?: any) => {
36
+ event?.stopPropagation();
37
+ table.setActionCell(null);
38
+ actionCellRef.current = null;
39
+ };
40
+
41
+ const internalMenuItems = [
42
+ (parseFromValuesOrFunc(enableClickToCopy, cell) === 'context-menu' ||
43
+ parseFromValuesOrFunc(columnDef.enableClickToCopy, cell) ===
44
+ 'context-menu') && (
45
+ <MRT_ActionMenuItem
46
+ icon={<ContentCopy />}
47
+ key={'mrt-copy'}
48
+ label={localization.copy}
49
+ onClick={(event) => {
50
+ event.stopPropagation();
51
+ navigator.clipboard.writeText(cell.getValue() as string);
52
+ handleClose();
53
+ }}
54
+ table={table}
55
+ />
56
+ ),
57
+ parseFromValuesOrFunc(enableEditing, row) && editDisplayMode === 'cell' && (
58
+ <MRT_ActionMenuItem
59
+ icon={<EditIcon />}
60
+ key={'mrt-edit'}
61
+ label={localization.edit}
62
+ onClick={() => {
63
+ openEditingCell({ cell, table });
64
+ handleClose();
65
+ }}
66
+ table={table}
67
+ />
68
+ ),
69
+ ].filter(Boolean);
70
+
71
+ const renderActionProps = {
72
+ cell,
73
+ closeMenu: handleClose,
74
+ column,
75
+ internalMenuItems,
76
+ row,
77
+ table,
78
+ };
79
+
80
+ const menuItems =
81
+ columnDef.renderCellActionMenuItems?.(renderActionProps) ??
82
+ renderCellActionMenuItems?.(renderActionProps);
83
+
84
+ return (
85
+ (!!menuItems?.length || !!internalMenuItems?.length) && (
86
+ <Menu
87
+ anchorEl={actionCellRef.current}
88
+ disableScrollLock
89
+ onClick={(event) => event.stopPropagation()}
90
+ onClose={handleClose}
91
+ open={!!cell}
92
+ slotProps={{
93
+ list: {
94
+ dense: density === 'compact',
95
+ sx: {
96
+ backgroundColor: menuBackgroundColor,
97
+ },
98
+ ...rest.slotProps?.list,
99
+ },
100
+ ...rest.slotProps,
101
+ }}
102
+ transformOrigin={{ horizontal: -100, vertical: 8 }}
103
+ {...rest}
104
+ >
105
+ {menuItems ?? internalMenuItems}
106
+ </Menu>
107
+ )
108
+ );
109
+ };