@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,357 @@
1
+ import { type DragEvent, useMemo, useCallback } from 'react';
2
+ import Box from '@mui/material/Box';
3
+ import TableCell, { type TableCellProps } from '@mui/material/TableCell';
4
+ import { useTheme } from '@mui/material/styles';
5
+ import { type Theme } from '@mui/material/styles';
6
+ import { MRT_TableHeadCellColumnActionsButton } from './MRT_TableHeadCellColumnActionsButton';
7
+ import { MRT_TableHeadCellFilterContainer } from './MRT_TableHeadCellFilterContainer';
8
+ import { MRT_TableHeadCellFilterLabel } from './MRT_TableHeadCellFilterLabel';
9
+ import { MRT_TableHeadCellGrabHandle } from './MRT_TableHeadCellGrabHandle';
10
+ import { MRT_TableHeadCellResizeHandle } from './MRT_TableHeadCellResizeHandle';
11
+ import { MRT_TableHeadCellSortLabel } from './MRT_TableHeadCellSortLabel';
12
+ import {
13
+ type MRT_ColumnVirtualizer,
14
+ type MRT_Header,
15
+ type MRT_RowData,
16
+ type MRT_TableInstance,
17
+ } from '../../types';
18
+ import { getCommonMRTCellStyles } from '../../utils/style.utils';
19
+ import { parseFromValuesOrFunc } from '../../utils/utils';
20
+ import { cellKeyboardShortcuts } from '../../utils/cell.utils';
21
+
22
+ export interface MRT_TableHeadCellProps<TData extends MRT_RowData>
23
+ extends TableCellProps {
24
+ columnVirtualizer?: MRT_ColumnVirtualizer;
25
+ header: MRT_Header<TData>;
26
+ staticColumnIndex?: number;
27
+ table: MRT_TableInstance<TData>;
28
+ }
29
+
30
+ export const MRT_TableHeadCell = <TData extends MRT_RowData>({
31
+ columnVirtualizer,
32
+ header,
33
+ staticColumnIndex,
34
+ table,
35
+ ...rest
36
+ }: MRT_TableHeadCellProps<TData>) => {
37
+ const theme = useTheme();
38
+ const {
39
+ getState,
40
+ options: {
41
+ columnFilterDisplayMode,
42
+ columnResizeDirection,
43
+ columnResizeMode,
44
+ enableKeyboardShortcuts,
45
+ enableColumnActions,
46
+ enableColumnDragging,
47
+ enableColumnOrdering,
48
+ enableColumnPinning,
49
+ enableGrouping,
50
+ enableMultiSort,
51
+ layoutMode,
52
+ mrtTheme: { draggingBorderColor },
53
+ muiTableHeadCellProps,
54
+ },
55
+ refs: { tableHeadCellRefs },
56
+ setHoveredColumn,
57
+ } = table;
58
+ const {
59
+ columnSizingInfo,
60
+ density,
61
+ draggingColumn,
62
+ grouping,
63
+ hoveredColumn,
64
+ showColumnFilters,
65
+ } = getState();
66
+ const { column } = header;
67
+ const { columnDef } = column;
68
+ const { columnDefType } = columnDef;
69
+
70
+ const tableCellProps = {
71
+ ...parseFromValuesOrFunc(muiTableHeadCellProps, { column, table }),
72
+ ...parseFromValuesOrFunc(columnDef.muiTableHeadCellProps, {
73
+ column,
74
+ table,
75
+ }),
76
+ ...rest,
77
+ };
78
+
79
+ const isColumnPinned =
80
+ enableColumnPinning &&
81
+ columnDef.columnDefType !== 'group' &&
82
+ column.getIsPinned();
83
+
84
+ const showColumnActions =
85
+ (enableColumnActions || columnDef.enableColumnActions) &&
86
+ columnDef.enableColumnActions !== false;
87
+
88
+ const showDragHandle =
89
+ enableColumnDragging !== false &&
90
+ columnDef.enableColumnDragging !== false &&
91
+ (enableColumnDragging ||
92
+ (enableColumnOrdering && columnDef.enableColumnOrdering !== false) ||
93
+ (enableGrouping &&
94
+ columnDef.enableGrouping !== false &&
95
+ !grouping.includes(column.id)));
96
+
97
+ const headerPL = useMemo(() => {
98
+ let pl = 0;
99
+ if (column.getCanSort()) pl += 1;
100
+ if (showColumnActions) pl += 1.75;
101
+ if (showDragHandle) pl += 1.5;
102
+ return pl;
103
+ }, [showColumnActions, showDragHandle]);
104
+
105
+ const draggingBorders = useMemo(() => {
106
+ const showResizeBorder =
107
+ columnSizingInfo.isResizingColumn === column.id &&
108
+ columnResizeMode === 'onChange' &&
109
+ !header.subHeaders.length;
110
+
111
+ const borderStyle = showResizeBorder
112
+ ? `2px solid ${draggingBorderColor} !important`
113
+ : draggingColumn?.id === column.id
114
+ ? `1px dashed ${theme.palette.grey[500]}`
115
+ : hoveredColumn?.id === column.id
116
+ ? `2px dashed ${draggingBorderColor}`
117
+ : undefined;
118
+
119
+ if (showResizeBorder) {
120
+ return columnResizeDirection === 'ltr'
121
+ ? { borderRight: borderStyle }
122
+ : { borderLeft: borderStyle };
123
+ }
124
+ const draggingBorders = borderStyle
125
+ ? {
126
+ borderLeft: borderStyle,
127
+ borderRight: borderStyle,
128
+ borderTop: borderStyle,
129
+ }
130
+ : undefined;
131
+
132
+ return draggingBorders;
133
+ }, [draggingColumn, hoveredColumn, columnSizingInfo.isResizingColumn]);
134
+
135
+ const handleDragEnter = (_e: DragEvent) => {
136
+ if (enableGrouping && hoveredColumn?.id === 'drop-zone') {
137
+ setHoveredColumn(null);
138
+ }
139
+ if (enableColumnOrdering && draggingColumn && columnDefType !== 'group') {
140
+ setHoveredColumn(
141
+ columnDef.enableColumnOrdering !== false ? column : null,
142
+ );
143
+ }
144
+ };
145
+
146
+ const handleDragOver = (e: DragEvent) => {
147
+ if (columnDef.enableColumnOrdering !== false) {
148
+ e.preventDefault();
149
+ }
150
+ };
151
+
152
+ const handleKeyDown = (event: React.KeyboardEvent<HTMLTableCellElement>) => {
153
+ tableCellProps?.onKeyDown?.(event);
154
+ cellKeyboardShortcuts({
155
+ event,
156
+ cellValue: header.column.columnDef.header,
157
+ table,
158
+ header,
159
+ });
160
+ };
161
+
162
+ const handleRef = useCallback(
163
+ (node: HTMLTableCellElement) => {
164
+ if (node) {
165
+ if (tableHeadCellRefs.current) {
166
+ tableHeadCellRefs.current[column.id] = node;
167
+ }
168
+ if (columnDefType !== 'group') {
169
+ columnVirtualizer?.measureElement?.(node);
170
+ }
171
+ }
172
+ },
173
+ [column.id, columnDefType, columnVirtualizer, tableHeadCellRefs],
174
+ );
175
+
176
+ const HeaderElement =
177
+ parseFromValuesOrFunc(columnDef.Header, {
178
+ column,
179
+ header,
180
+ table,
181
+ }) ?? columnDef.header;
182
+
183
+ return (
184
+ <TableCell
185
+ align={
186
+ columnDefType === 'group'
187
+ ? 'center'
188
+ : theme.direction === 'rtl'
189
+ ? 'right'
190
+ : 'left'
191
+ }
192
+ aria-sort={
193
+ column.getIsSorted()
194
+ ? column.getIsSorted() === 'asc'
195
+ ? 'ascending'
196
+ : 'descending'
197
+ : 'none'
198
+ }
199
+ colSpan={header.colSpan}
200
+ data-can-sort={column.getCanSort() || undefined}
201
+ data-index={staticColumnIndex}
202
+ data-pinned={!!isColumnPinned || undefined}
203
+ data-sort={column.getIsSorted() || undefined}
204
+ onDragEnter={handleDragEnter}
205
+ onDragOver={handleDragOver}
206
+ ref={handleRef}
207
+ tabIndex={enableKeyboardShortcuts ? 0 : undefined}
208
+ {...tableCellProps}
209
+ onKeyDown={handleKeyDown}
210
+ sx={[
211
+ (theme: Theme) => ({
212
+ '& :hover': {
213
+ '.MuiButtonBase-root': {
214
+ opacity: 1,
215
+ },
216
+ },
217
+ flexDirection: layoutMode?.startsWith('grid') ? 'column' : undefined,
218
+ fontWeight: 'bold',
219
+ overflow: 'visible',
220
+ p:
221
+ density === 'compact'
222
+ ? '0.5rem'
223
+ : density === 'comfortable'
224
+ ? columnDefType === 'display'
225
+ ? '0.75rem'
226
+ : '1rem'
227
+ : columnDefType === 'display'
228
+ ? '1rem 1.25rem'
229
+ : '1.5rem',
230
+ pb:
231
+ columnDefType === 'display'
232
+ ? 0
233
+ : showColumnFilters || density === 'compact'
234
+ ? '0.4rem'
235
+ : '0.6rem',
236
+ pt:
237
+ columnDefType === 'group' || density === 'compact'
238
+ ? '0.25rem'
239
+ : density === 'comfortable'
240
+ ? '.75rem'
241
+ : '1.25rem',
242
+ userSelect:
243
+ enableMultiSort && column.getCanSort() ? 'none' : undefined,
244
+ verticalAlign: 'top',
245
+ ...getCommonMRTCellStyles({
246
+ column,
247
+ header,
248
+ table,
249
+ tableCellProps,
250
+ theme,
251
+ }),
252
+ ...draggingBorders,
253
+ }),
254
+ ...(Array.isArray(tableCellProps.sx)
255
+ ? tableCellProps.sx
256
+ : [tableCellProps.sx]),
257
+ ]}
258
+ >
259
+ {header.isPlaceholder
260
+ ? null
261
+ : (tableCellProps.children ?? (
262
+ <Box
263
+ className="Mui-TableHeadCell-Content"
264
+ sx={{
265
+ alignItems: 'center',
266
+ display: 'flex',
267
+ flexDirection:
268
+ tableCellProps?.align === 'right' ? 'row-reverse' : 'row',
269
+ justifyContent:
270
+ columnDefType === 'group' ||
271
+ tableCellProps?.align === 'center'
272
+ ? 'center'
273
+ : column.getCanResize()
274
+ ? 'space-between'
275
+ : 'flex-start',
276
+ position: 'relative',
277
+ width: '100%',
278
+ }}
279
+ >
280
+ <Box
281
+ className="Mui-TableHeadCell-Content-Labels"
282
+ onClick={column.getToggleSortingHandler()}
283
+ sx={{
284
+ alignItems: 'center',
285
+ cursor:
286
+ column.getCanSort() && columnDefType !== 'group'
287
+ ? 'pointer'
288
+ : undefined,
289
+ display: 'flex',
290
+ flexDirection:
291
+ tableCellProps?.align === 'right' ? 'row-reverse' : 'row',
292
+ overflow: columnDefType === 'data' ? 'hidden' : undefined,
293
+ pl:
294
+ tableCellProps?.align === 'center'
295
+ ? `${headerPL}rem`
296
+ : undefined,
297
+ }}
298
+ >
299
+ <Box
300
+ className="Mui-TableHeadCell-Content-Wrapper"
301
+ sx={{
302
+ '&:hover': {
303
+ textOverflow: 'clip',
304
+ },
305
+ minWidth: `${Math.min(columnDef.header?.length ?? 0, 4)}ch`,
306
+ overflow: columnDefType === 'data' ? 'hidden' : undefined,
307
+ textOverflow: 'ellipsis',
308
+ whiteSpace:
309
+ (columnDef.header?.length ?? 0) < 20
310
+ ? 'nowrap'
311
+ : 'normal',
312
+ }}
313
+ >
314
+ {HeaderElement}
315
+ </Box>
316
+ {column.getCanFilter() && (
317
+ <MRT_TableHeadCellFilterLabel header={header} table={table} />
318
+ )}
319
+ {column.getCanSort() && (
320
+ <MRT_TableHeadCellSortLabel header={header} table={table} />
321
+ )}
322
+ </Box>
323
+ {columnDefType !== 'group' && (
324
+ <Box
325
+ className="Mui-TableHeadCell-Content-Actions"
326
+ sx={{
327
+ whiteSpace: 'nowrap',
328
+ }}
329
+ >
330
+ {showDragHandle && (
331
+ <MRT_TableHeadCellGrabHandle
332
+ column={column}
333
+ table={table}
334
+ tableHeadCellRef={{
335
+ current: tableHeadCellRefs.current?.[column.id]!,
336
+ }}
337
+ />
338
+ )}
339
+ {showColumnActions && (
340
+ <MRT_TableHeadCellColumnActionsButton
341
+ header={header}
342
+ table={table}
343
+ />
344
+ )}
345
+ </Box>
346
+ )}
347
+ {column.getCanResize() && (
348
+ <MRT_TableHeadCellResizeHandle header={header} table={table} />
349
+ )}
350
+ </Box>
351
+ ))}
352
+ {columnFilterDisplayMode === 'subheader' && column.getCanFilter() && (
353
+ <MRT_TableHeadCellFilterContainer header={header} table={table} />
354
+ )}
355
+ </TableCell>
356
+ );
357
+ };
@@ -0,0 +1,100 @@
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 {
5
+ type MRT_Header,
6
+ type MRT_RowData,
7
+ type MRT_TableInstance,
8
+ } from '../../types';
9
+ import { getCommonTooltipProps } from '../../utils/style.utils';
10
+ import { parseFromValuesOrFunc } from '../../utils/utils';
11
+ import { MRT_ColumnActionMenu } from '../menus/MRT_ColumnActionMenu';
12
+
13
+ export interface MRT_TableHeadCellColumnActionsButtonProps<
14
+ TData extends MRT_RowData,
15
+ > extends IconButtonProps {
16
+ header: MRT_Header<TData>;
17
+ table: MRT_TableInstance<TData>;
18
+ }
19
+
20
+ export const MRT_TableHeadCellColumnActionsButton = <
21
+ TData extends MRT_RowData,
22
+ >({
23
+ header,
24
+ table,
25
+ ...rest
26
+ }: MRT_TableHeadCellColumnActionsButtonProps<TData>) => {
27
+ const {
28
+ options: {
29
+ icons: { MoreVertIcon },
30
+ localization,
31
+ muiColumnActionsButtonProps,
32
+ },
33
+ } = table;
34
+ const { column } = header;
35
+ const { columnDef } = column;
36
+
37
+ const [anchorEl, setAnchorEl] = useState<HTMLElement | null>(null);
38
+
39
+ const handleClick = (event: MouseEvent<HTMLElement>) => {
40
+ event.stopPropagation();
41
+ event.preventDefault();
42
+ setAnchorEl(event.currentTarget);
43
+ };
44
+
45
+ const iconButtonProps = {
46
+ ...parseFromValuesOrFunc(muiColumnActionsButtonProps, {
47
+ column,
48
+ table,
49
+ }),
50
+ ...parseFromValuesOrFunc(columnDef.muiColumnActionsButtonProps, {
51
+ column,
52
+ table,
53
+ }),
54
+ ...rest,
55
+ };
56
+
57
+ return (
58
+ <>
59
+ <Tooltip
60
+ {...getCommonTooltipProps('top')}
61
+ title={iconButtonProps?.title ?? localization.columnActions}
62
+ >
63
+ <IconButton
64
+ aria-label={localization.columnActions}
65
+ onClick={handleClick}
66
+ size="small"
67
+ {...iconButtonProps}
68
+ sx={[
69
+ {
70
+ '&:hover': {
71
+ opacity: 1,
72
+ },
73
+ height: '2rem',
74
+ m: '-8px -4px',
75
+ opacity: 0.3,
76
+ transition: 'all 150ms',
77
+ width: '2rem',
78
+ },
79
+ ...(Array.isArray(iconButtonProps?.sx)
80
+ ? iconButtonProps.sx
81
+ : [iconButtonProps?.sx]),
82
+ ]}
83
+ title={undefined}
84
+ >
85
+ {iconButtonProps?.children ?? (
86
+ <MoreVertIcon style={{ transform: 'scale(0.9)' }} />
87
+ )}
88
+ </IconButton>
89
+ </Tooltip>
90
+ {anchorEl && (
91
+ <MRT_ColumnActionMenu
92
+ anchorEl={anchorEl}
93
+ header={header}
94
+ setAnchorEl={setAnchorEl}
95
+ table={table}
96
+ />
97
+ )}
98
+ </>
99
+ );
100
+ };
@@ -0,0 +1,52 @@
1
+ import Collapse, { type CollapseProps } from '@mui/material/Collapse';
2
+ import {
3
+ type MRT_Header,
4
+ type MRT_RowData,
5
+ type MRT_TableInstance,
6
+ } from '../../types';
7
+ import { getColumnFilterInfo } from '../../utils/column.utils';
8
+ import { MRT_FilterCheckbox } from '../inputs/MRT_FilterCheckbox';
9
+ import { MRT_FilterRangeFields } from '../inputs/MRT_FilterRangeFields';
10
+ import { MRT_FilterRangeSlider } from '../inputs/MRT_FilterRangeSlider';
11
+ import { MRT_FilterTextField } from '../inputs/MRT_FilterTextField';
12
+
13
+ export interface MRT_TableHeadCellFilterContainerProps<
14
+ TData extends MRT_RowData,
15
+ > extends CollapseProps {
16
+ header: MRT_Header<TData>;
17
+ table: MRT_TableInstance<TData>;
18
+ }
19
+
20
+ export const MRT_TableHeadCellFilterContainer = <TData extends MRT_RowData>({
21
+ header,
22
+ table,
23
+ ...rest
24
+ }: MRT_TableHeadCellFilterContainerProps<TData>) => {
25
+ const {
26
+ getState,
27
+ options: { columnFilterDisplayMode },
28
+ } = table;
29
+ const { showColumnFilters } = getState();
30
+ const { column } = header;
31
+ const { columnDef } = column;
32
+ const { isRangeFilter } = getColumnFilterInfo({ header, table });
33
+
34
+ return (
35
+ <Collapse
36
+ in={showColumnFilters || columnFilterDisplayMode === 'popover'}
37
+ mountOnEnter
38
+ unmountOnExit
39
+ {...rest}
40
+ >
41
+ {columnDef.filterVariant === 'checkbox' ? (
42
+ <MRT_FilterCheckbox column={column} table={table} />
43
+ ) : columnDef.filterVariant === 'range-slider' ? (
44
+ <MRT_FilterRangeSlider header={header} table={table} />
45
+ ) : isRangeFilter ? (
46
+ <MRT_FilterRangeFields header={header} table={table} />
47
+ ) : (
48
+ <MRT_FilterTextField header={header} table={table} />
49
+ )}
50
+ </Collapse>
51
+ );
52
+ };
@@ -0,0 +1,180 @@
1
+ import { type MouseEvent, useState } from 'react';
2
+ import Box from '@mui/material/Box';
3
+ import Grow from '@mui/material/Grow';
4
+ import IconButton, { type IconButtonProps } from '@mui/material/IconButton';
5
+ import Popover from '@mui/material/Popover';
6
+ import Tooltip from '@mui/material/Tooltip';
7
+ import { MRT_TableHeadCellFilterContainer } from './MRT_TableHeadCellFilterContainer';
8
+ import {
9
+ type MRT_Header,
10
+ type MRT_RowData,
11
+ type MRT_TableInstance,
12
+ } from '../../types';
13
+ import {
14
+ getColumnFilterInfo,
15
+ useDropdownOptions,
16
+ } from '../../utils/column.utils';
17
+ import { getValueAndLabel } from '../../utils/utils';
18
+
19
+ export interface MRT_TableHeadCellFilterLabelProps<TData extends MRT_RowData>
20
+ extends IconButtonProps {
21
+ header: MRT_Header<TData>;
22
+ table: MRT_TableInstance<TData>;
23
+ }
24
+
25
+ export const MRT_TableHeadCellFilterLabel = <TData extends MRT_RowData = {}>({
26
+ header,
27
+ table,
28
+ ...rest
29
+ }: MRT_TableHeadCellFilterLabelProps<TData>) => {
30
+ const {
31
+ options: {
32
+ columnFilterDisplayMode,
33
+ icons: { FilterAltIcon },
34
+ localization,
35
+ },
36
+ refs: { filterInputRefs },
37
+ setShowColumnFilters,
38
+ } = table;
39
+ const { column } = header;
40
+ const { columnDef } = column;
41
+
42
+ const filterValue = column.getFilterValue() as [string, string] | string;
43
+
44
+ const [anchorEl, setAnchorEl] = useState<HTMLButtonElement | null>(null);
45
+
46
+ const {
47
+ currentFilterOption,
48
+ isMultiSelectFilter,
49
+ isRangeFilter,
50
+ isSelectFilter,
51
+ } = getColumnFilterInfo({ header, table });
52
+
53
+ const dropdownOptions = useDropdownOptions({ header, table });
54
+
55
+ const getSelectLabel = (index?: number) =>
56
+ getValueAndLabel(
57
+ dropdownOptions?.find(
58
+ (option) =>
59
+ getValueAndLabel(option).value ===
60
+ (index !== undefined ? filterValue[index] : filterValue),
61
+ ),
62
+ ).label;
63
+
64
+ const isFilterActive =
65
+ (Array.isArray(filterValue) && filterValue.some(Boolean)) ||
66
+ (!!filterValue && !Array.isArray(filterValue));
67
+
68
+ const filterTooltip =
69
+ columnFilterDisplayMode === 'popover' && !isFilterActive
70
+ ? localization.filterByColumn?.replace(
71
+ '{column}',
72
+ String(columnDef.header),
73
+ )
74
+ : localization.filteringByColumn
75
+ .replace('{column}', String(columnDef.header))
76
+ .replace(
77
+ '{filterType}',
78
+ currentFilterOption
79
+ ? localization[
80
+ `filter${
81
+ currentFilterOption.charAt(0).toUpperCase() +
82
+ currentFilterOption.slice(1)
83
+ }` as keyof typeof localization
84
+ ]
85
+ : '',
86
+ )
87
+ .replace(
88
+ '{filterValue}',
89
+ `"${
90
+ Array.isArray(filterValue)
91
+ ? (filterValue as [string, string])
92
+ .map((value, index) =>
93
+ isMultiSelectFilter ? getSelectLabel(index) : value,
94
+ )
95
+ .join(
96
+ `" ${isRangeFilter ? localization.and : localization.or} "`,
97
+ )
98
+ : isSelectFilter
99
+ ? getSelectLabel()
100
+ : (filterValue as string)
101
+ }"`,
102
+ )
103
+ .replace('" "', '');
104
+
105
+ return (
106
+ <>
107
+ <Grow
108
+ in={
109
+ columnFilterDisplayMode === 'popover' ||
110
+ (!!filterValue && !isRangeFilter) ||
111
+ (isRangeFilter && (!!filterValue?.[0] || !!filterValue?.[1]))
112
+ }
113
+ unmountOnExit
114
+ >
115
+ <Box component="span" sx={{ flex: '0 0' }}>
116
+ <Tooltip placement="top" title={filterTooltip}>
117
+ <IconButton
118
+ disableRipple
119
+ onClick={(event: MouseEvent<HTMLButtonElement>) => {
120
+ if (columnFilterDisplayMode === 'popover') {
121
+ setAnchorEl(event.currentTarget);
122
+ } else {
123
+ setShowColumnFilters(true);
124
+ }
125
+ queueMicrotask(() => {
126
+ filterInputRefs.current?.[`${column.id}-0`]?.focus?.();
127
+ filterInputRefs.current?.[`${column.id}-0`]?.select?.();
128
+ });
129
+ event.stopPropagation();
130
+ }}
131
+ size="small"
132
+ {...rest}
133
+ sx={[
134
+ {
135
+ height: '16px',
136
+ ml: '4px',
137
+ opacity: isFilterActive ? 1 : 0.3,
138
+ p: '8px',
139
+ transform: 'scale(0.75)',
140
+ transition: 'all 150ms ease-in-out',
141
+ width: '16px',
142
+ },
143
+ ...(Array.isArray(rest?.sx) ? rest.sx : [rest?.sx]),
144
+ ]}
145
+ >
146
+ <FilterAltIcon />
147
+ </IconButton>
148
+ </Tooltip>
149
+ </Box>
150
+ </Grow>
151
+ {columnFilterDisplayMode === 'popover' && (
152
+ <Popover
153
+ anchorEl={anchorEl}
154
+ anchorOrigin={{
155
+ horizontal: 'center',
156
+ vertical: 'top',
157
+ }}
158
+ disableScrollLock
159
+ onClick={(event) => event.stopPropagation()}
160
+ onClose={(event) => {
161
+ //@ts-expect-error
162
+ event.stopPropagation();
163
+ setAnchorEl(null);
164
+ }}
165
+ onKeyDown={(event) => event.key === 'Enter' && setAnchorEl(null)}
166
+ open={!!anchorEl}
167
+ slotProps={{ paper: { sx: { overflow: 'visible' } } }}
168
+ transformOrigin={{
169
+ horizontal: 'center',
170
+ vertical: 'bottom',
171
+ }}
172
+ >
173
+ <Box sx={{ p: '1rem' }}>
174
+ <MRT_TableHeadCellFilterContainer header={header} table={table} />
175
+ </Box>
176
+ </Popover>
177
+ )}
178
+ </>
179
+ );
180
+ };