@kissesses/mantine-react-table-open 9.0.3

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 (362) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +196 -0
  3. package/dist/index.cjs +3769 -0
  4. package/dist/index.cjs.map +1 -0
  5. package/dist/index.d.cts +1488 -0
  6. package/dist/index.esm.d.mts +1488 -0
  7. package/dist/index.esm.mjs +3664 -0
  8. package/dist/index.esm.mjs.map +1 -0
  9. package/locales/ar/index.cjs +97 -0
  10. package/locales/ar/index.d.cts +3 -0
  11. package/locales/ar/index.esm.d.mts +3 -0
  12. package/locales/ar/index.esm.mjs +95 -0
  13. package/locales/ar/package.json +19 -0
  14. package/locales/az/index.cjs +97 -0
  15. package/locales/az/index.d.cts +3 -0
  16. package/locales/az/index.esm.d.mts +3 -0
  17. package/locales/az/index.esm.mjs +95 -0
  18. package/locales/az/package.json +19 -0
  19. package/locales/bg/index.cjs +97 -0
  20. package/locales/bg/index.d.cts +3 -0
  21. package/locales/bg/index.esm.d.mts +3 -0
  22. package/locales/bg/index.esm.mjs +95 -0
  23. package/locales/bg/package.json +19 -0
  24. package/locales/cs/index.cjs +97 -0
  25. package/locales/cs/index.d.cts +3 -0
  26. package/locales/cs/index.esm.d.mts +3 -0
  27. package/locales/cs/index.esm.mjs +95 -0
  28. package/locales/cs/package.json +19 -0
  29. package/locales/da/index.cjs +97 -0
  30. package/locales/da/index.d.cts +3 -0
  31. package/locales/da/index.esm.d.mts +3 -0
  32. package/locales/da/index.esm.mjs +95 -0
  33. package/locales/da/package.json +19 -0
  34. package/locales/de/index.cjs +97 -0
  35. package/locales/de/index.d.cts +3 -0
  36. package/locales/de/index.esm.d.mts +3 -0
  37. package/locales/de/index.esm.mjs +95 -0
  38. package/locales/de/package.json +19 -0
  39. package/locales/el/index.cjs +97 -0
  40. package/locales/el/index.d.cts +3 -0
  41. package/locales/el/index.esm.d.mts +3 -0
  42. package/locales/el/index.esm.mjs +95 -0
  43. package/locales/el/package.json +19 -0
  44. package/locales/en/index.cjs +97 -0
  45. package/locales/en/index.d.cts +3 -0
  46. package/locales/en/index.esm.d.mts +3 -0
  47. package/locales/en/index.esm.mjs +95 -0
  48. package/locales/en/package.json +19 -0
  49. package/locales/es/index.cjs +97 -0
  50. package/locales/es/index.d.cts +3 -0
  51. package/locales/es/index.esm.d.mts +3 -0
  52. package/locales/es/index.esm.mjs +95 -0
  53. package/locales/es/package.json +19 -0
  54. package/locales/et/index.cjs +97 -0
  55. package/locales/et/index.d.cts +3 -0
  56. package/locales/et/index.esm.d.mts +3 -0
  57. package/locales/et/index.esm.mjs +95 -0
  58. package/locales/et/package.json +19 -0
  59. package/locales/fa/index.cjs +97 -0
  60. package/locales/fa/index.d.cts +3 -0
  61. package/locales/fa/index.esm.d.mts +3 -0
  62. package/locales/fa/index.esm.mjs +95 -0
  63. package/locales/fa/package.json +19 -0
  64. package/locales/fi/index.cjs +97 -0
  65. package/locales/fi/index.d.cts +3 -0
  66. package/locales/fi/index.esm.d.mts +3 -0
  67. package/locales/fi/index.esm.mjs +95 -0
  68. package/locales/fi/package.json +19 -0
  69. package/locales/fr/index.cjs +97 -0
  70. package/locales/fr/index.d.cts +3 -0
  71. package/locales/fr/index.esm.d.mts +3 -0
  72. package/locales/fr/index.esm.mjs +95 -0
  73. package/locales/fr/package.json +19 -0
  74. package/locales/he/index.cjs +97 -0
  75. package/locales/he/index.d.cts +3 -0
  76. package/locales/he/index.esm.d.mts +3 -0
  77. package/locales/he/index.esm.mjs +95 -0
  78. package/locales/he/package.json +19 -0
  79. package/locales/hr/index.cjs +97 -0
  80. package/locales/hr/index.d.cts +3 -0
  81. package/locales/hr/index.esm.d.mts +3 -0
  82. package/locales/hr/index.esm.mjs +95 -0
  83. package/locales/hr/package.json +19 -0
  84. package/locales/hu/index.cjs +97 -0
  85. package/locales/hu/index.d.cts +3 -0
  86. package/locales/hu/index.esm.d.mts +3 -0
  87. package/locales/hu/index.esm.mjs +95 -0
  88. package/locales/hu/package.json +19 -0
  89. package/locales/hy/index.cjs +97 -0
  90. package/locales/hy/index.d.cts +3 -0
  91. package/locales/hy/index.esm.d.mts +3 -0
  92. package/locales/hy/index.esm.mjs +95 -0
  93. package/locales/hy/package.json +19 -0
  94. package/locales/id/index.cjs +97 -0
  95. package/locales/id/index.d.cts +3 -0
  96. package/locales/id/index.esm.d.mts +3 -0
  97. package/locales/id/index.esm.mjs +95 -0
  98. package/locales/id/package.json +19 -0
  99. package/locales/it/index.cjs +97 -0
  100. package/locales/it/index.d.cts +3 -0
  101. package/locales/it/index.esm.d.mts +3 -0
  102. package/locales/it/index.esm.mjs +95 -0
  103. package/locales/it/package.json +19 -0
  104. package/locales/ja/index.cjs +97 -0
  105. package/locales/ja/index.d.cts +3 -0
  106. package/locales/ja/index.esm.d.mts +3 -0
  107. package/locales/ja/index.esm.mjs +95 -0
  108. package/locales/ja/package.json +19 -0
  109. package/locales/ko/index.cjs +97 -0
  110. package/locales/ko/index.d.cts +3 -0
  111. package/locales/ko/index.esm.d.mts +3 -0
  112. package/locales/ko/index.esm.mjs +95 -0
  113. package/locales/ko/package.json +19 -0
  114. package/locales/nl/index.cjs +97 -0
  115. package/locales/nl/index.d.cts +3 -0
  116. package/locales/nl/index.esm.d.mts +3 -0
  117. package/locales/nl/index.esm.mjs +95 -0
  118. package/locales/nl/package.json +19 -0
  119. package/locales/no/index.cjs +97 -0
  120. package/locales/no/index.d.cts +3 -0
  121. package/locales/no/index.esm.d.mts +3 -0
  122. package/locales/no/index.esm.mjs +95 -0
  123. package/locales/no/package.json +19 -0
  124. package/locales/np/index.cjs +97 -0
  125. package/locales/np/index.d.cts +3 -0
  126. package/locales/np/index.esm.d.mts +3 -0
  127. package/locales/np/index.esm.mjs +95 -0
  128. package/locales/np/package.json +19 -0
  129. package/locales/pl/index.cjs +97 -0
  130. package/locales/pl/index.d.cts +3 -0
  131. package/locales/pl/index.esm.d.mts +3 -0
  132. package/locales/pl/index.esm.mjs +95 -0
  133. package/locales/pl/package.json +19 -0
  134. package/locales/pt/index.cjs +97 -0
  135. package/locales/pt/index.d.cts +3 -0
  136. package/locales/pt/index.esm.d.mts +3 -0
  137. package/locales/pt/index.esm.mjs +95 -0
  138. package/locales/pt/package.json +19 -0
  139. package/locales/pt-BR/index.cjs +97 -0
  140. package/locales/pt-BR/index.d.cts +3 -0
  141. package/locales/pt-BR/index.esm.d.mts +3 -0
  142. package/locales/pt-BR/index.esm.mjs +95 -0
  143. package/locales/pt-BR/package.json +19 -0
  144. package/locales/ro/index.cjs +97 -0
  145. package/locales/ro/index.d.cts +3 -0
  146. package/locales/ro/index.esm.d.mts +3 -0
  147. package/locales/ro/index.esm.mjs +95 -0
  148. package/locales/ro/package.json +19 -0
  149. package/locales/ru/index.cjs +97 -0
  150. package/locales/ru/index.d.cts +3 -0
  151. package/locales/ru/index.esm.d.mts +3 -0
  152. package/locales/ru/index.esm.mjs +95 -0
  153. package/locales/ru/package.json +19 -0
  154. package/locales/sk/index.cjs +97 -0
  155. package/locales/sk/index.d.cts +3 -0
  156. package/locales/sk/index.esm.d.mts +3 -0
  157. package/locales/sk/index.esm.mjs +95 -0
  158. package/locales/sk/package.json +19 -0
  159. package/locales/sr-Cyrl-RS/index.cjs +97 -0
  160. package/locales/sr-Cyrl-RS/index.d.cts +3 -0
  161. package/locales/sr-Cyrl-RS/index.esm.d.mts +3 -0
  162. package/locales/sr-Cyrl-RS/index.esm.mjs +95 -0
  163. package/locales/sr-Cyrl-RS/package.json +19 -0
  164. package/locales/sr-Latn-RS/index.cjs +97 -0
  165. package/locales/sr-Latn-RS/index.d.cts +3 -0
  166. package/locales/sr-Latn-RS/index.esm.d.mts +3 -0
  167. package/locales/sr-Latn-RS/index.esm.mjs +95 -0
  168. package/locales/sr-Latn-RS/package.json +19 -0
  169. package/locales/sv/index.cjs +97 -0
  170. package/locales/sv/index.d.cts +3 -0
  171. package/locales/sv/index.esm.d.mts +3 -0
  172. package/locales/sv/index.esm.mjs +95 -0
  173. package/locales/sv/package.json +19 -0
  174. package/locales/tr/index.cjs +97 -0
  175. package/locales/tr/index.d.cts +3 -0
  176. package/locales/tr/index.esm.d.mts +3 -0
  177. package/locales/tr/index.esm.mjs +95 -0
  178. package/locales/tr/package.json +19 -0
  179. package/locales/uk/index.cjs +97 -0
  180. package/locales/uk/index.d.cts +3 -0
  181. package/locales/uk/index.esm.d.mts +3 -0
  182. package/locales/uk/index.esm.mjs +95 -0
  183. package/locales/uk/package.json +19 -0
  184. package/locales/vi/index.cjs +97 -0
  185. package/locales/vi/index.d.cts +3 -0
  186. package/locales/vi/index.esm.d.mts +3 -0
  187. package/locales/vi/index.esm.mjs +95 -0
  188. package/locales/vi/package.json +19 -0
  189. package/locales/zh-Hans/index.cjs +97 -0
  190. package/locales/zh-Hans/index.d.cts +3 -0
  191. package/locales/zh-Hans/index.esm.d.mts +3 -0
  192. package/locales/zh-Hans/index.esm.mjs +95 -0
  193. package/locales/zh-Hans/package.json +19 -0
  194. package/locales/zh-Hant/index.cjs +97 -0
  195. package/locales/zh-Hant/index.d.cts +3 -0
  196. package/locales/zh-Hant/index.esm.d.mts +3 -0
  197. package/locales/zh-Hant/index.esm.mjs +95 -0
  198. package/locales/zh-Hant/package.json +19 -0
  199. package/package.json +154 -0
  200. package/src/components/MantineReactTable.tsx +37 -0
  201. package/src/components/body/MRT_TableBody.module.css +42 -0
  202. package/src/components/body/MRT_TableBody.tsx +215 -0
  203. package/src/components/body/MRT_TableBodyCell.module.css +107 -0
  204. package/src/components/body/MRT_TableBodyCell.tsx +351 -0
  205. package/src/components/body/MRT_TableBodyCellValue.tsx +113 -0
  206. package/src/components/body/MRT_TableBodyEmptyRow.tsx +110 -0
  207. package/src/components/body/MRT_TableBodyRow.module.css +252 -0
  208. package/src/components/body/MRT_TableBodyRow.tsx +263 -0
  209. package/src/components/body/MRT_TableBodyRowGrabHandle.tsx +58 -0
  210. package/src/components/body/MRT_TableBodyRowPinButton.tsx +58 -0
  211. package/src/components/body/MRT_TableDetailPanel.module.css +35 -0
  212. package/src/components/body/MRT_TableDetailPanel.tsx +131 -0
  213. package/src/components/buttons/MRT_ColumnPinningButtons.module.css +11 -0
  214. package/src/components/buttons/MRT_ColumnPinningButtons.tsx +68 -0
  215. package/src/components/buttons/MRT_CopyButton.module.css +27 -0
  216. package/src/components/buttons/MRT_CopyButton.tsx +83 -0
  217. package/src/components/buttons/MRT_EditActionButtons.module.css +4 -0
  218. package/src/components/buttons/MRT_EditActionButtons.tsx +128 -0
  219. package/src/components/buttons/MRT_ExpandAllButton.module.css +26 -0
  220. package/src/components/buttons/MRT_ExpandAllButton.tsx +83 -0
  221. package/src/components/buttons/MRT_ExpandButton.module.css +37 -0
  222. package/src/components/buttons/MRT_ExpandButton.tsx +120 -0
  223. package/src/components/buttons/MRT_GrabHandleButton.module.css +6 -0
  224. package/src/components/buttons/MRT_GrabHandleButton.tsx +64 -0
  225. package/src/components/buttons/MRT_RowPinButton.tsx +83 -0
  226. package/src/components/buttons/MRT_ShowHideColumnsButton.tsx +45 -0
  227. package/src/components/buttons/MRT_ToggleDensePaddingButton.tsx +65 -0
  228. package/src/components/buttons/MRT_ToggleFiltersButton.tsx +44 -0
  229. package/src/components/buttons/MRT_ToggleFullScreenButton.tsx +58 -0
  230. package/src/components/buttons/MRT_ToggleGlobalFilterButton.tsx +51 -0
  231. package/src/components/buttons/MRT_ToggleRowActionMenuButton.tsx +86 -0
  232. package/src/components/footer/MRT_TableFooter.module.css +17 -0
  233. package/src/components/footer/MRT_TableFooter.tsx +72 -0
  234. package/src/components/footer/MRT_TableFooterCell.module.css +50 -0
  235. package/src/components/footer/MRT_TableFooterCell.tsx +122 -0
  236. package/src/components/footer/MRT_TableFooterRow.module.css +10 -0
  237. package/src/components/footer/MRT_TableFooterRow.tsx +94 -0
  238. package/src/components/head/MRT_TableHead.module.css +32 -0
  239. package/src/components/head/MRT_TableHead.tsx +108 -0
  240. package/src/components/head/MRT_TableHeadCell.module.css +163 -0
  241. package/src/components/head/MRT_TableHeadCell.tsx +322 -0
  242. package/src/components/head/MRT_TableHeadCellFilterContainer.module.css +5 -0
  243. package/src/components/head/MRT_TableHeadCellFilterContainer.tsx +147 -0
  244. package/src/components/head/MRT_TableHeadCellFilterLabel.module.css +14 -0
  245. package/src/components/head/MRT_TableHeadCellFilterLabel.tsx +171 -0
  246. package/src/components/head/MRT_TableHeadCellGrabHandle.tsx +81 -0
  247. package/src/components/head/MRT_TableHeadCellResizeHandle.module.css +44 -0
  248. package/src/components/head/MRT_TableHeadCellResizeHandle.tsx +67 -0
  249. package/src/components/head/MRT_TableHeadCellSortLabel.module.css +22 -0
  250. package/src/components/head/MRT_TableHeadCellSortLabel.tsx +89 -0
  251. package/src/components/head/MRT_TableHeadRow.module.css +12 -0
  252. package/src/components/head/MRT_TableHeadRow.tsx +87 -0
  253. package/src/components/inputs/MRT_EditCellTextInput.tsx +218 -0
  254. package/src/components/inputs/MRT_FilterCheckBox.module.css +4 -0
  255. package/src/components/inputs/MRT_FilterCheckbox.tsx +79 -0
  256. package/src/components/inputs/MRT_FilterRangeFields.module.css +5 -0
  257. package/src/components/inputs/MRT_FilterRangeFields.tsx +35 -0
  258. package/src/components/inputs/MRT_FilterRangeSlider.module.css +6 -0
  259. package/src/components/inputs/MRT_FilterRangeSlider.tsx +106 -0
  260. package/src/components/inputs/MRT_FilterTextInput.module.css +27 -0
  261. package/src/components/inputs/MRT_FilterTextInput.tsx +417 -0
  262. package/src/components/inputs/MRT_GlobalFilterTextInput.module.css +11 -0
  263. package/src/components/inputs/MRT_GlobalFilterTextInput.tsx +141 -0
  264. package/src/components/inputs/MRT_SelectCheckbox.tsx +137 -0
  265. package/src/components/menus/MRT_ColumnActionMenu.module.css +7 -0
  266. package/src/components/menus/MRT_ColumnActionMenu.tsx +287 -0
  267. package/src/components/menus/MRT_FilterOptionMenu.module.css +6 -0
  268. package/src/components/menus/MRT_FilterOptionMenu.tsx +274 -0
  269. package/src/components/menus/MRT_RowActionMenu.tsx +74 -0
  270. package/src/components/menus/MRT_ShowHideColumnsMenu.module.css +10 -0
  271. package/src/components/menus/MRT_ShowHideColumnsMenu.tsx +135 -0
  272. package/src/components/menus/MRT_ShowHideColumnsMenuItems.module.css +35 -0
  273. package/src/components/menus/MRT_ShowHideColumnsMenuItems.tsx +170 -0
  274. package/src/components/modals/MRT_EditRowModal.tsx +97 -0
  275. package/src/components/table/MRT_Table.module.css +7 -0
  276. package/src/components/table/MRT_Table.tsx +110 -0
  277. package/src/components/table/MRT_TableContainer.module.css +20 -0
  278. package/src/components/table/MRT_TableContainer.tsx +109 -0
  279. package/src/components/table/MRT_TablePaper.module.css +88 -0
  280. package/src/components/table/MRT_TablePaper.tsx +92 -0
  281. package/src/components/toolbar/MRT_BottomToolbar.module.css +40 -0
  282. package/src/components/toolbar/MRT_BottomToolbar.tsx +100 -0
  283. package/src/components/toolbar/MRT_ProgressBar.module.css +10 -0
  284. package/src/components/toolbar/MRT_ProgressBar.tsx +53 -0
  285. package/src/components/toolbar/MRT_TablePagination.module.css +20 -0
  286. package/src/components/toolbar/MRT_TablePagination.tsx +166 -0
  287. package/src/components/toolbar/MRT_ToolbarAlertBanner.module.css +37 -0
  288. package/src/components/toolbar/MRT_ToolbarAlertBanner.tsx +168 -0
  289. package/src/components/toolbar/MRT_ToolbarDropZone.module.css +23 -0
  290. package/src/components/toolbar/MRT_ToolbarDropZone.tsx +67 -0
  291. package/src/components/toolbar/MRT_ToolbarInternalButtons.module.css +6 -0
  292. package/src/components/toolbar/MRT_ToolbarInternalButtons.tsx +73 -0
  293. package/src/components/toolbar/MRT_TopToolbar.module.css +24 -0
  294. package/src/components/toolbar/MRT_TopToolbar.tsx +128 -0
  295. package/src/components/toolbar/common.styles.module.css +10 -0
  296. package/src/fns/aggregationFns.ts +3 -0
  297. package/src/fns/filterFns.ts +272 -0
  298. package/src/fns/sortingFns.ts +34 -0
  299. package/src/hooks/display-columns/getMRT_RowActionsColumnDef.tsx +23 -0
  300. package/src/hooks/display-columns/getMRT_RowDragColumnDef.tsx +30 -0
  301. package/src/hooks/display-columns/getMRT_RowExpandColumnDef.tsx +92 -0
  302. package/src/hooks/display-columns/getMRT_RowNumbersColumnDef.tsx +30 -0
  303. package/src/hooks/display-columns/getMRT_RowPinningColumnDef.tsx +24 -0
  304. package/src/hooks/display-columns/getMRT_RowSelectColumnDef.tsx +34 -0
  305. package/src/hooks/display-columns/getMRT_RowSpacerColumnDef.tsx +34 -0
  306. package/src/hooks/useMRT_ColumnVirtualizer.ts +129 -0
  307. package/src/hooks/useMRT_Effects.ts +105 -0
  308. package/src/hooks/useMRT_RowVirtualizer.ts +95 -0
  309. package/src/hooks/useMRT_Rows.ts +46 -0
  310. package/src/hooks/useMRT_TableInstance.ts +314 -0
  311. package/src/hooks/useMRT_TableOptions.ts +264 -0
  312. package/src/hooks/useMantineReactTable.ts +14 -0
  313. package/src/icons.ts +73 -0
  314. package/src/index.ts +90 -0
  315. package/src/locales/ar.ts +96 -0
  316. package/src/locales/az.ts +96 -0
  317. package/src/locales/bg.ts +96 -0
  318. package/src/locales/cs.ts +97 -0
  319. package/src/locales/da.ts +96 -0
  320. package/src/locales/de.ts +96 -0
  321. package/src/locales/el.ts +96 -0
  322. package/src/locales/en.ts +96 -0
  323. package/src/locales/es.ts +96 -0
  324. package/src/locales/et.ts +97 -0
  325. package/src/locales/fa.ts +96 -0
  326. package/src/locales/fi.ts +97 -0
  327. package/src/locales/fr.ts +96 -0
  328. package/src/locales/he.ts +96 -0
  329. package/src/locales/hr.ts +96 -0
  330. package/src/locales/hu.ts +96 -0
  331. package/src/locales/hy.ts +96 -0
  332. package/src/locales/id.ts +97 -0
  333. package/src/locales/it.ts +96 -0
  334. package/src/locales/ja.ts +96 -0
  335. package/src/locales/ko.ts +96 -0
  336. package/src/locales/nl.ts +96 -0
  337. package/src/locales/no.ts +97 -0
  338. package/src/locales/np.ts +97 -0
  339. package/src/locales/pl.ts +96 -0
  340. package/src/locales/pt-BR.ts +96 -0
  341. package/src/locales/pt.ts +96 -0
  342. package/src/locales/ro.ts +96 -0
  343. package/src/locales/ru.ts +96 -0
  344. package/src/locales/sk.ts +97 -0
  345. package/src/locales/sr-Cyrl-RS.ts +96 -0
  346. package/src/locales/sr-Latn-RS.ts +96 -0
  347. package/src/locales/sv.ts +96 -0
  348. package/src/locales/tr.ts +96 -0
  349. package/src/locales/uk.ts +96 -0
  350. package/src/locales/vi.ts +96 -0
  351. package/src/locales/zh-Hans.ts +95 -0
  352. package/src/locales/zh-Hant.ts +95 -0
  353. package/src/types.ts +1276 -0
  354. package/src/typings.d.ts +1 -0
  355. package/src/utils/column.utils.ts +124 -0
  356. package/src/utils/displayColumn.utils.ts +153 -0
  357. package/src/utils/row.utils.ts +263 -0
  358. package/src/utils/style.utils.ts +32 -0
  359. package/src/utils/tanstack.helpers.ts +66 -0
  360. package/src/utils/utils.ts +4 -0
  361. package/src/utils/virtualization.utils.ts +19 -0
  362. package/styles.css +1320 -0
@@ -0,0 +1,274 @@
1
+ import classes from './MRT_FilterOptionMenu.module.css';
2
+
3
+ import { Fragment, useMemo } from 'react';
4
+
5
+ import { Menu } from '@mantine/core';
6
+
7
+ import {
8
+ type MRT_FilterOption,
9
+ type MRT_Header,
10
+ type MRT_InternalFilterOption,
11
+ type MRT_Localization,
12
+ type MRT_RowData,
13
+ type MRT_TableInstance,
14
+ } from '../../types';
15
+
16
+ export const mrtFilterOptions = (
17
+ localization: MRT_Localization,
18
+ ): MRT_InternalFilterOption[] => [
19
+ {
20
+ divider: false,
21
+ label: localization.filterFuzzy,
22
+ option: 'fuzzy',
23
+ symbol: '≈',
24
+ },
25
+ {
26
+ divider: false,
27
+ label: localization.filterContains,
28
+ option: 'contains',
29
+ symbol: '*',
30
+ },
31
+ {
32
+ divider: false,
33
+ label: localization.filterStartsWith,
34
+ option: 'startsWith',
35
+ symbol: 'a',
36
+ },
37
+ {
38
+ divider: true,
39
+ label: localization.filterEndsWith,
40
+ option: 'endsWith',
41
+ symbol: 'z',
42
+ },
43
+ {
44
+ divider: false,
45
+ label: localization.filterEquals,
46
+ option: 'equals',
47
+ symbol: '=',
48
+ },
49
+ {
50
+ divider: true,
51
+ label: localization.filterNotEquals,
52
+ option: 'notEquals',
53
+ symbol: '≠',
54
+ },
55
+ {
56
+ divider: false,
57
+ label: localization.filterBetween,
58
+ option: 'between',
59
+ symbol: '⇿',
60
+ },
61
+ {
62
+ divider: true,
63
+ label: localization.filterBetweenInclusive,
64
+ option: 'betweenInclusive',
65
+ symbol: '⬌',
66
+ },
67
+ {
68
+ divider: false,
69
+ label: localization.filterGreaterThan,
70
+ option: 'greaterThan',
71
+ symbol: '>',
72
+ },
73
+ {
74
+ divider: false,
75
+ label: localization.filterGreaterThanOrEqualTo,
76
+ option: 'greaterThanOrEqualTo',
77
+ symbol: '≥',
78
+ },
79
+ {
80
+ divider: false,
81
+ label: localization.filterLessThan,
82
+ option: 'lessThan',
83
+ symbol: '<',
84
+ },
85
+ {
86
+ divider: true,
87
+ label: localization.filterLessThanOrEqualTo,
88
+ option: 'lessThanOrEqualTo',
89
+ symbol: '≤',
90
+ },
91
+ {
92
+ divider: false,
93
+ label: localization.filterEmpty,
94
+ option: 'empty',
95
+ symbol: '∅',
96
+ },
97
+ {
98
+ divider: false,
99
+ label: localization.filterNotEmpty,
100
+ option: 'notEmpty',
101
+ symbol: '!∅',
102
+ },
103
+ ];
104
+
105
+ const rangeModes = ['between', 'betweenInclusive', 'inNumberRange'];
106
+ const emptyModes = ['empty', 'notEmpty'];
107
+ const arrModes = ['arrIncludesSome', 'arrIncludesAll', 'arrIncludes'];
108
+ const rangeVariants = ['range-slider', 'date-range', 'range'];
109
+
110
+ interface Props<TData extends MRT_RowData> {
111
+ header?: MRT_Header<TData>;
112
+ onSelect?: () => void;
113
+ table: MRT_TableInstance<TData>;
114
+ }
115
+
116
+ export const MRT_FilterOptionMenu = <TData extends MRT_RowData>({
117
+ header,
118
+ onSelect,
119
+ table,
120
+ }: Props<TData>) => {
121
+ 'use no memo';
122
+ const {
123
+ getState,
124
+ options: {
125
+ columnFilterModeOptions,
126
+ globalFilterModeOptions,
127
+ localization,
128
+ renderColumnFilterModeMenuItems,
129
+ renderGlobalFilterModeMenuItems,
130
+ },
131
+ setColumnFilterFns,
132
+ setGlobalFilterFn,
133
+ } = table;
134
+ const { globalFilterFn } = getState();
135
+ const { column } = header ?? {};
136
+ const { columnDef } = column ?? {};
137
+ const currentFilterValue = column?.getFilterValue();
138
+
139
+ let allowedColumnFilterOptions =
140
+ columnDef?.columnFilterModeOptions ?? columnFilterModeOptions;
141
+
142
+ if (rangeVariants.includes(columnDef?.filterVariant as string)) {
143
+ allowedColumnFilterOptions = [
144
+ ...rangeModes,
145
+ ...(allowedColumnFilterOptions ?? []),
146
+ ].filter((option) => rangeModes.includes(option));
147
+ }
148
+
149
+ const internalFilterOptions = useMemo(() => {
150
+ const filterOptions = mrtFilterOptions(localization).filter(
151
+ (filterOption) =>
152
+ columnDef
153
+ ? allowedColumnFilterOptions === undefined ||
154
+ allowedColumnFilterOptions?.includes(filterOption.option)
155
+ : (!globalFilterModeOptions ||
156
+ globalFilterModeOptions.includes(filterOption.option)) &&
157
+ ['contains', 'fuzzy', 'startsWith'].includes(filterOption.option),
158
+ );
159
+ if (filterOptions[filterOptions.length - 1].divider) {
160
+ filterOptions[filterOptions.length - 1].divider = false;
161
+ }
162
+ return filterOptions;
163
+ }, [columnDef, globalFilterModeOptions]);
164
+
165
+ const handleSelectFilterMode = (option: MRT_FilterOption) => {
166
+ const prevFilterMode = columnDef?._filterFn ?? '';
167
+ if (!header || !column) {
168
+ // global filter mode
169
+ setGlobalFilterFn(option);
170
+ } else if (option !== prevFilterMode) {
171
+ // column filter mode
172
+ setColumnFilterFns((prev: { [key: string]: any }) => ({
173
+ ...prev,
174
+ [header.id]: option,
175
+ }));
176
+
177
+ // reset filter value and/or perform new filter render
178
+ if (emptyModes.includes(option)) {
179
+ // will now be empty/notEmpty filter mode
180
+ if (
181
+ currentFilterValue !== ' ' &&
182
+ !emptyModes.includes(prevFilterMode)
183
+ ) {
184
+ column.setFilterValue(' ');
185
+ } else if (currentFilterValue) {
186
+ column.setFilterValue(currentFilterValue); // perform new filter render
187
+ }
188
+ } else if (
189
+ columnDef?.filterVariant === 'multi-select' ||
190
+ arrModes.includes(option as string)
191
+ ) {
192
+ // will now be array filter mode
193
+ if (
194
+ currentFilterValue instanceof String ||
195
+ (currentFilterValue as Array<any>)?.length
196
+ ) {
197
+ column.setFilterValue([]);
198
+ } else if (currentFilterValue) {
199
+ column.setFilterValue(currentFilterValue); // perform new filter render
200
+ }
201
+ } else if (
202
+ rangeVariants.includes(columnDef?.filterVariant as string) ||
203
+ rangeModes.includes(option as MRT_FilterOption)
204
+ ) {
205
+ // will now be range filter mode
206
+ if (
207
+ !Array.isArray(currentFilterValue) ||
208
+ (!(currentFilterValue as Array<any>)?.every((v) => v === '') &&
209
+ !rangeModes.includes(prevFilterMode))
210
+ ) {
211
+ column.setFilterValue(['', '']);
212
+ } else {
213
+ column.setFilterValue(currentFilterValue); // perform new filter render
214
+ }
215
+ } else {
216
+ // will now be single value filter mode
217
+ if (Array.isArray(currentFilterValue)) {
218
+ column.setFilterValue('');
219
+ } else if (
220
+ currentFilterValue === ' ' &&
221
+ emptyModes.includes(prevFilterMode)
222
+ ) {
223
+ column.setFilterValue(undefined);
224
+ } else {
225
+ column.setFilterValue(currentFilterValue); // perform new filter render
226
+ }
227
+ }
228
+ }
229
+ onSelect?.();
230
+ };
231
+
232
+ const filterOption =
233
+ !!header && columnDef ? columnDef._filterFn : globalFilterFn;
234
+
235
+ return (
236
+ <Menu.Dropdown>
237
+ {(header && column && columnDef
238
+ ? (columnDef.renderColumnFilterModeMenuItems?.({
239
+ column: column as any,
240
+ internalFilterOptions,
241
+ onSelectFilterMode: handleSelectFilterMode,
242
+ table,
243
+ }) ??
244
+ renderColumnFilterModeMenuItems?.({
245
+ column: column as any,
246
+ internalFilterOptions,
247
+ onSelectFilterMode: handleSelectFilterMode,
248
+ table,
249
+ }))
250
+ : renderGlobalFilterModeMenuItems?.({
251
+ internalFilterOptions,
252
+ onSelectFilterMode: handleSelectFilterMode,
253
+ table,
254
+ })) ??
255
+ internalFilterOptions.map(
256
+ ({ divider, label, option, symbol }, index) => (
257
+ <Fragment key={index}>
258
+ <Menu.Item
259
+ color={option === filterOption ? 'blue' : undefined}
260
+ leftSection={<span className={classes.symbol}>{symbol}</span>}
261
+ onClick={() =>
262
+ handleSelectFilterMode(option as MRT_FilterOption)
263
+ }
264
+ value={option}
265
+ >
266
+ {label}
267
+ </Menu.Item>
268
+ {divider && <Menu.Divider />}
269
+ </Fragment>
270
+ ),
271
+ )}
272
+ </Menu.Dropdown>
273
+ );
274
+ };
@@ -0,0 +1,74 @@
1
+ import { type MouseEvent } from 'react';
2
+
3
+ import { ActionIcon, type ActionIconProps, Menu, Tooltip } from '@mantine/core';
4
+
5
+ import {
6
+ type MRT_Row,
7
+ type MRT_RowData,
8
+ type MRT_TableInstance,
9
+ } from '../../types';
10
+
11
+ interface Props<TData extends MRT_RowData> extends ActionIconProps {
12
+ handleEdit: (event: MouseEvent) => void;
13
+ row: MRT_Row<TData>;
14
+ table: MRT_TableInstance<TData>;
15
+ }
16
+
17
+ export const MRT_RowActionMenu = <TData extends MRT_RowData>({
18
+ handleEdit,
19
+ row,
20
+ table,
21
+ ...rest
22
+ }: Props<TData>) => {
23
+ 'use no memo';
24
+ const {
25
+ options: {
26
+ editDisplayMode,
27
+ enableEditing,
28
+ icons: { IconDots, IconEdit },
29
+ localization,
30
+ positionActionsColumn,
31
+ renderRowActionMenuItems,
32
+ },
33
+ } = table;
34
+
35
+ return (
36
+ <Menu
37
+ closeOnItemClick
38
+ position={
39
+ positionActionsColumn === 'first'
40
+ ? 'bottom-start'
41
+ : positionActionsColumn === 'last'
42
+ ? 'bottom-end'
43
+ : undefined
44
+ }
45
+ withinPortal
46
+ >
47
+ <Tooltip label={localization.rowActions} openDelay={1000} withinPortal>
48
+ <Menu.Target>
49
+ <ActionIcon
50
+ aria-label={localization.rowActions}
51
+ color="gray"
52
+ onClick={(event) => event.stopPropagation()}
53
+ size="sm"
54
+ variant="subtle"
55
+ {...rest}
56
+ >
57
+ <IconDots />
58
+ </ActionIcon>
59
+ </Menu.Target>
60
+ </Tooltip>
61
+ <Menu.Dropdown onClick={(event) => event.stopPropagation()}>
62
+ {enableEditing && editDisplayMode !== 'table' && (
63
+ <Menu.Item leftSection={<IconEdit />} onClick={handleEdit}>
64
+ {localization.edit}
65
+ </Menu.Item>
66
+ )}
67
+ {renderRowActionMenuItems?.({
68
+ row,
69
+ table,
70
+ })}
71
+ </Menu.Dropdown>
72
+ </Menu>
73
+ );
74
+ };
@@ -0,0 +1,10 @@
1
+ .root {
2
+ max-height: calc(80vh - 100px);
3
+ overflow-y: auto;
4
+ .content {
5
+ padding-top: rem(4px);
6
+ padding-bottom: rem(4px);
7
+ gap: rem(8px);
8
+ justify-content: space-between;
9
+ }
10
+ }
@@ -0,0 +1,135 @@
1
+ import clsx from 'clsx';
2
+
3
+ import classes from './MRT_ShowHideColumnsMenu.module.css';
4
+
5
+ import { useMemo, useState } from 'react';
6
+
7
+ import { Button, Flex, Menu } from '@mantine/core';
8
+
9
+ import { MRT_ShowHideColumnsMenuItems } from './MRT_ShowHideColumnsMenuItems';
10
+
11
+ import {
12
+ type MRT_Column,
13
+ type MRT_RowData,
14
+ type MRT_TableInstance,
15
+ } from '../../types';
16
+ import { getDefaultColumnOrderIds } from '../../utils/displayColumn.utils';
17
+
18
+ interface Props<TData extends MRT_RowData> {
19
+ table: MRT_TableInstance<TData>;
20
+ }
21
+
22
+ export const MRT_ShowHideColumnsMenu = <TData extends MRT_RowData>({
23
+ table,
24
+ }: Props<TData>) => {
25
+ 'use no memo';
26
+ const {
27
+ getAllColumns,
28
+ getAllLeafColumns,
29
+ getCenterLeafColumns,
30
+ getIsAllColumnsVisible,
31
+ getIsSomeColumnsPinned,
32
+ getIsSomeColumnsVisible,
33
+ getLeftLeafColumns,
34
+ getRightLeafColumns,
35
+ getState,
36
+ options: {
37
+ enableColumnOrdering,
38
+ enableColumnPinning,
39
+ enableHiding,
40
+ localization,
41
+ },
42
+ } = table;
43
+ const { columnOrder, columnPinning } = getState();
44
+
45
+ const handleToggleAllColumns = (value?: boolean) => {
46
+ getAllLeafColumns()
47
+ .filter((col) => col.columnDef.enableHiding !== false)
48
+ .forEach((col) => col.toggleVisibility(value));
49
+ };
50
+
51
+ const allColumns = useMemo(() => {
52
+ const columns = getAllColumns();
53
+ if (
54
+ columnOrder.length > 0 &&
55
+ !columns.some((col) => col.columnDef.columnDefType === 'group')
56
+ ) {
57
+ return [
58
+ ...getLeftLeafColumns(),
59
+ ...Array.from(new Set(columnOrder)).map((colId) =>
60
+ getCenterLeafColumns().find((col) => col?.id === colId),
61
+ ),
62
+ ...getRightLeafColumns(),
63
+ ].filter(Boolean);
64
+ }
65
+ return columns;
66
+ }, [
67
+ columnOrder,
68
+ columnPinning,
69
+ getAllColumns(),
70
+ getCenterLeafColumns(),
71
+ getLeftLeafColumns(),
72
+ getRightLeafColumns(),
73
+ ]) as MRT_Column<TData>[];
74
+
75
+ const [hoveredColumn, setHoveredColumn] = useState<MRT_Column<TData> | null>(
76
+ null,
77
+ );
78
+
79
+ return (
80
+ <Menu.Dropdown className={clsx('mrt-show-hide-columns-menu', classes.root)}>
81
+ <Flex className={classes.content}>
82
+ {enableHiding && (
83
+ <Button
84
+ disabled={!getIsSomeColumnsVisible()}
85
+ onClick={() => handleToggleAllColumns(false)}
86
+ variant="subtle"
87
+ >
88
+ {localization.hideAll}
89
+ </Button>
90
+ )}
91
+ {enableColumnOrdering && (
92
+ <Button
93
+ onClick={() =>
94
+ table.setColumnOrder(
95
+ getDefaultColumnOrderIds(table.options as any, true),
96
+ )
97
+ }
98
+ variant="subtle"
99
+ >
100
+ {localization.resetOrder}
101
+ </Button>
102
+ )}
103
+ {enableColumnPinning && (
104
+ <Button
105
+ disabled={!getIsSomeColumnsPinned()}
106
+ onClick={() => table.resetColumnPinning(true)}
107
+ variant="subtle"
108
+ >
109
+ {localization.unpinAll}
110
+ </Button>
111
+ )}
112
+ {enableHiding && (
113
+ <Button
114
+ disabled={getIsAllColumnsVisible()}
115
+ onClick={() => handleToggleAllColumns(true)}
116
+ variant="subtle"
117
+ >
118
+ {localization.showAll}
119
+ </Button>
120
+ )}
121
+ </Flex>
122
+ <Menu.Divider />
123
+ {allColumns.map((column, index) => (
124
+ <MRT_ShowHideColumnsMenuItems
125
+ allColumns={allColumns}
126
+ column={column}
127
+ hoveredColumn={hoveredColumn}
128
+ key={`${index}-${column.id}`}
129
+ setHoveredColumn={setHoveredColumn}
130
+ table={table}
131
+ />
132
+ ))}
133
+ </Menu.Dropdown>
134
+ );
135
+ };
@@ -0,0 +1,35 @@
1
+ .root {
2
+ align-items: center;
3
+ cursor: default;
4
+ justify-content: flex-start;
5
+ opacity: 1;
6
+ outline: none;
7
+ padding-left: var(--_column-depth);
8
+ padding-top: rem(6px);
9
+ padding-bottom: rem(6);
10
+ &[data-dragging] {
11
+ opacity: 0.5;
12
+ outline: 1px dashed var(--mantine-color-gray-7);
13
+ }
14
+ &[data-order-hovered]:not(&[data-dragging]) {
15
+ outline: 2px dashed var(--_hover-color);
16
+ }
17
+ }
18
+ .menu {
19
+ display: flex;
20
+ align-items: center;
21
+ flex-wrap: nowrap;
22
+ gap: rem(8px);
23
+ }
24
+ .grab {
25
+ width: rem(28px);
26
+ }
27
+ .pin {
28
+ width: rem(70px);
29
+ }
30
+ .switch {
31
+ cursor: pointer !important;
32
+ }
33
+ .header {
34
+ align-self: center;
35
+ }
@@ -0,0 +1,170 @@
1
+ import classes from './MRT_ShowHideColumnsMenuItems.module.css';
2
+
3
+ import {
4
+ type Dispatch,
5
+ type DragEvent,
6
+ type SetStateAction,
7
+ useRef,
8
+ useState,
9
+ } from 'react';
10
+
11
+ import {
12
+ Box,
13
+ Menu,
14
+ Switch,
15
+ Text,
16
+ Tooltip,
17
+ useMantineTheme,
18
+ } from '@mantine/core';
19
+
20
+ import {
21
+ type MRT_CellValue,
22
+ type MRT_Column,
23
+ type MRT_RowData,
24
+ type MRT_TableInstance,
25
+ } from '../../types';
26
+ import { reorderColumn } from '../../utils/column.utils';
27
+ import { dataVariable, getPrimaryColor } from '../../utils/style.utils';
28
+ import { MRT_ColumnPinningButtons } from '../buttons/MRT_ColumnPinningButtons';
29
+ import { MRT_GrabHandleButton } from '../buttons/MRT_GrabHandleButton';
30
+
31
+ interface Props<TData extends MRT_RowData, TValue = MRT_CellValue> {
32
+ allColumns: MRT_Column<TData>[];
33
+ column: MRT_Column<TData, TValue>;
34
+ hoveredColumn: MRT_Column<TData> | null;
35
+ setHoveredColumn: Dispatch<SetStateAction<MRT_Column<TData> | null>>;
36
+ table: MRT_TableInstance<TData>;
37
+ }
38
+
39
+ export const MRT_ShowHideColumnsMenuItems = <TData extends MRT_RowData>({
40
+ allColumns,
41
+ column,
42
+ hoveredColumn,
43
+ setHoveredColumn,
44
+ table,
45
+ }: Props<TData>) => {
46
+ 'use no memo';
47
+ const theme = useMantineTheme();
48
+ const {
49
+ getState,
50
+ options: {
51
+ enableColumnOrdering,
52
+ enableColumnPinning,
53
+ enableHiding,
54
+ localization,
55
+ },
56
+ setColumnOrder,
57
+ } = table;
58
+ const { columnOrder } = getState();
59
+ const { columnDef } = column;
60
+ const { columnDefType } = columnDef;
61
+
62
+ const switchChecked =
63
+ (columnDefType !== 'group' && column.getIsVisible()) ||
64
+ (columnDefType === 'group' &&
65
+ column.getLeafColumns().some((col) => col.getIsVisible()));
66
+
67
+ const handleToggleColumnHidden = (column: MRT_Column<TData>) => {
68
+ if (columnDefType === 'group') {
69
+ column?.columns?.forEach?.((childColumn: MRT_Column<TData>) => {
70
+ childColumn.toggleVisibility(!switchChecked);
71
+ });
72
+ } else {
73
+ column.toggleVisibility();
74
+ }
75
+ };
76
+
77
+ const menuItemRef = useRef<HTMLElement | null>(null);
78
+
79
+ const [isDragging, setIsDragging] = useState(false);
80
+
81
+ const handleDragStart = (e: DragEvent<HTMLButtonElement>) => {
82
+ setIsDragging(true);
83
+ e.dataTransfer.setDragImage(menuItemRef.current as HTMLElement, 0, 0);
84
+ };
85
+
86
+ const handleDragEnd = (_e: DragEvent<HTMLButtonElement>) => {
87
+ setIsDragging(false);
88
+ setHoveredColumn(null);
89
+ if (hoveredColumn) {
90
+ setColumnOrder(reorderColumn(column, hoveredColumn, columnOrder));
91
+ }
92
+ };
93
+
94
+ const handleDragEnter = (_e: DragEvent) => {
95
+ if (!isDragging && columnDef.enableColumnOrdering !== false) {
96
+ setHoveredColumn(column);
97
+ }
98
+ };
99
+
100
+ if (!columnDef.header || columnDef.visibleInShowHideMenu === false) {
101
+ return null;
102
+ }
103
+
104
+ return (
105
+ <>
106
+ <Menu.Item
107
+ className={classes.root}
108
+ component="span"
109
+ onDragEnter={handleDragEnter}
110
+ ref={menuItemRef as any}
111
+ style={{
112
+ '--_column-depth': `${(column.depth + 0.5) * 2}rem`,
113
+ '--_hover-color': getPrimaryColor(theme),
114
+ }}
115
+ {...dataVariable('dragging', isDragging)}
116
+ {...dataVariable('order-hovered', hoveredColumn?.id === column.id)}
117
+ >
118
+ <Box className={classes.menu}>
119
+ {columnDefType !== 'group' &&
120
+ enableColumnOrdering &&
121
+ !allColumns.some(
122
+ (col) => col.columnDef.columnDefType === 'group',
123
+ ) &&
124
+ (columnDef.enableColumnOrdering !== false ? (
125
+ <MRT_GrabHandleButton
126
+ onDragEnd={handleDragEnd}
127
+ onDragStart={handleDragStart}
128
+ table={table}
129
+ />
130
+ ) : (
131
+ <Box className={classes.grab} />
132
+ ))}
133
+ {enableColumnPinning &&
134
+ (column.getCanPin() ? (
135
+ <MRT_ColumnPinningButtons column={column} table={table} />
136
+ ) : (
137
+ <Box className={classes.pin} />
138
+ ))}
139
+ {enableHiding ? (
140
+ <Tooltip
141
+ label={localization.toggleVisibility}
142
+ openDelay={1000}
143
+ withinPortal
144
+ >
145
+ <Switch
146
+ checked={switchChecked}
147
+ className={classes.switch}
148
+ disabled={!column.getCanHide()}
149
+ label={columnDef.header}
150
+ onChange={() => handleToggleColumnHidden(column)}
151
+ />
152
+ </Tooltip>
153
+ ) : (
154
+ <Text className={classes.header}>{columnDef.header}</Text>
155
+ )}
156
+ </Box>
157
+ </Menu.Item>
158
+ {column.columns?.map((c: MRT_Column<TData>, i) => (
159
+ <MRT_ShowHideColumnsMenuItems
160
+ allColumns={allColumns}
161
+ column={c}
162
+ hoveredColumn={hoveredColumn}
163
+ key={`${i}-${c.id}`}
164
+ setHoveredColumn={setHoveredColumn}
165
+ table={table}
166
+ />
167
+ ))}
168
+ </>
169
+ );
170
+ };