@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,141 @@
1
+ import clsx from 'clsx';
2
+
3
+ import classes from './MRT_GlobalFilterTextInput.module.css';
4
+
5
+ import { useEffect, useRef, useState } from 'react';
6
+
7
+ import {
8
+ ActionIcon,
9
+ Collapse,
10
+ Menu,
11
+ TextInput,
12
+ type TextInputProps,
13
+ Tooltip,
14
+ } from '@mantine/core';
15
+ import { useDebouncedValue } from '@mantine/hooks';
16
+
17
+ import { type MRT_RowData, type MRT_TableInstance } from '../../types';
18
+ import { parseFromValuesOrFunc } from '../../utils/utils';
19
+ import { MRT_FilterOptionMenu } from '../menus/MRT_FilterOptionMenu';
20
+
21
+ interface Props<TData extends MRT_RowData> extends TextInputProps {
22
+ table: MRT_TableInstance<TData>;
23
+ }
24
+
25
+ export const MRT_GlobalFilterTextInput = <TData extends MRT_RowData>({
26
+ table,
27
+ ...rest
28
+ }: Props<TData>) => {
29
+ 'use no memo';
30
+ const {
31
+ getState,
32
+ options: {
33
+ enableGlobalFilterModes,
34
+ icons: { IconSearch, IconX },
35
+ localization,
36
+ mantineSearchTextInputProps,
37
+ manualFiltering,
38
+ positionGlobalFilter,
39
+ },
40
+ refs: { searchInputRef },
41
+ setGlobalFilter,
42
+ } = table;
43
+ const { globalFilter, showGlobalFilter } = getState();
44
+
45
+ const textFieldProps = {
46
+ ...parseFromValuesOrFunc(mantineSearchTextInputProps, {
47
+ table,
48
+ }),
49
+ ...rest,
50
+ };
51
+
52
+ const isMounted = useRef(false);
53
+ const [searchValue, setSearchValue] = useState(globalFilter ?? '');
54
+
55
+ const [debouncedSearchValue] = useDebouncedValue(
56
+ searchValue,
57
+ manualFiltering ? 500 : 250,
58
+ );
59
+
60
+ useEffect(() => {
61
+ setGlobalFilter(debouncedSearchValue || undefined);
62
+ }, [debouncedSearchValue]);
63
+
64
+ const handleClear = () => {
65
+ setSearchValue('');
66
+ setGlobalFilter(undefined);
67
+ };
68
+
69
+ useEffect(() => {
70
+ if (isMounted.current) {
71
+ if (globalFilter === undefined) {
72
+ handleClear();
73
+ } else {
74
+ setSearchValue(globalFilter);
75
+ }
76
+ }
77
+ isMounted.current = true;
78
+ }, [globalFilter]);
79
+
80
+ return (
81
+ <Collapse className={classes.collapse} expanded={showGlobalFilter}>
82
+ {enableGlobalFilterModes && (
83
+ <Menu withinPortal>
84
+ <Menu.Target>
85
+ <ActionIcon
86
+ aria-label={localization.changeSearchMode}
87
+ color="gray"
88
+ size="sm"
89
+ variant="transparent"
90
+ >
91
+ <IconSearch />
92
+ </ActionIcon>
93
+ </Menu.Target>
94
+ <MRT_FilterOptionMenu onSelect={handleClear} table={table} />
95
+ </Menu>
96
+ )}
97
+ <TextInput
98
+ leftSection={!enableGlobalFilterModes && <IconSearch />}
99
+ mt={0}
100
+ mx={positionGlobalFilter !== 'left' ? 'mx' : undefined}
101
+ onChange={(event) => setSearchValue(event.target.value)}
102
+ placeholder={localization.search}
103
+ rightSection={
104
+ <ActionIcon
105
+ aria-label={localization.clearSearch}
106
+ color="gray"
107
+ disabled={!searchValue?.length}
108
+ hidden={!searchValue}
109
+ onClick={handleClear}
110
+ size="sm"
111
+ style={{
112
+ visibility: !searchValue ? 'hidden' : undefined,
113
+ }}
114
+ variant="transparent"
115
+ >
116
+ <Tooltip label={localization.clearSearch} withinPortal>
117
+ <IconX />
118
+ </Tooltip>
119
+ </ActionIcon>
120
+ }
121
+ value={searchValue ?? ''}
122
+ variant="filled"
123
+ {...textFieldProps}
124
+ className={clsx(
125
+ 'mrt-global-filter-text-input',
126
+ classes.root,
127
+ textFieldProps?.className,
128
+ )}
129
+ ref={(node) => {
130
+ if (node) {
131
+ searchInputRef.current = node;
132
+ if (textFieldProps?.ref) {
133
+ // @ts-ignore
134
+ textFieldProps.ref = node;
135
+ }
136
+ }
137
+ }}
138
+ />
139
+ </Collapse>
140
+ );
141
+ };
@@ -0,0 +1,137 @@
1
+ import { type MouseEvent } from 'react';
2
+
3
+ import {
4
+ Checkbox,
5
+ type CheckboxProps,
6
+ Radio,
7
+ type RadioProps,
8
+ Switch,
9
+ type SwitchProps,
10
+ Tooltip,
11
+ } from '@mantine/core';
12
+
13
+ import {
14
+ type MRT_Row,
15
+ type MRT_RowData,
16
+ type MRT_TableInstance,
17
+ } from '../../types';
18
+ import {
19
+ getIsRowSelected,
20
+ getMRT_RowSelectionHandler,
21
+ getMRT_SelectAllHandler,
22
+ } from '../../utils/row.utils';
23
+ import { parseFromValuesOrFunc } from '../../utils/utils';
24
+
25
+ interface Props<TData extends MRT_RowData> extends CheckboxProps {
26
+ renderedRowIndex?: number;
27
+ row?: MRT_Row<TData>;
28
+ table: MRT_TableInstance<TData>;
29
+ }
30
+
31
+ export const MRT_SelectCheckbox = <TData extends MRT_RowData>({
32
+ renderedRowIndex = 0,
33
+ row,
34
+ table,
35
+ ...rest
36
+ }: Props<TData>) => {
37
+ 'use no memo';
38
+ const {
39
+ getState,
40
+ options: {
41
+ enableMultiRowSelection,
42
+ localization,
43
+ mantineSelectAllCheckboxProps,
44
+ mantineSelectCheckboxProps,
45
+ selectAllMode,
46
+ selectDisplayMode,
47
+ },
48
+ } = table;
49
+ const { density, isLoading } = getState();
50
+
51
+ const selectAll = !row;
52
+
53
+ const allRowsSelected = selectAll
54
+ ? selectAllMode === 'page'
55
+ ? table.getIsAllPageRowsSelected()
56
+ : table.getIsAllRowsSelected()
57
+ : undefined;
58
+
59
+ const isChecked = selectAll
60
+ ? allRowsSelected
61
+ : getIsRowSelected({ row, table });
62
+
63
+ const checkboxProps = {
64
+ ...(selectAll
65
+ ? parseFromValuesOrFunc(mantineSelectAllCheckboxProps, { table })
66
+ : parseFromValuesOrFunc(mantineSelectCheckboxProps, {
67
+ row,
68
+ table,
69
+ })),
70
+ ...rest,
71
+ };
72
+
73
+ const onSelectionChange = row
74
+ ? getMRT_RowSelectionHandler({
75
+ renderedRowIndex,
76
+ row,
77
+ table,
78
+ })
79
+ : undefined;
80
+
81
+ const onSelectAllChange = getMRT_SelectAllHandler({ table });
82
+
83
+ const commonProps = {
84
+ 'aria-label': selectAll
85
+ ? localization.toggleSelectAll
86
+ : localization.toggleSelectRow,
87
+ checked: isChecked,
88
+ disabled:
89
+ isLoading || (row && !row.getCanSelect()) || row?.id === 'mrt-row-create',
90
+ onChange: (event) => {
91
+ event.stopPropagation();
92
+ if (selectAll) {
93
+ onSelectAllChange(event);
94
+ } else {
95
+ onSelectionChange!(event);
96
+ }
97
+ },
98
+ size: density === 'xs' ? 'sm' : 'md',
99
+ ...checkboxProps,
100
+ onClick: (e: MouseEvent<HTMLInputElement>) => {
101
+ e.stopPropagation();
102
+ checkboxProps?.onClick?.(e);
103
+ },
104
+ title: undefined,
105
+ } as CheckboxProps & RadioProps & SwitchProps;
106
+
107
+ return (
108
+ <Tooltip
109
+ label={
110
+ checkboxProps?.title ??
111
+ (selectAll
112
+ ? localization.toggleSelectAll
113
+ : localization.toggleSelectRow)
114
+ }
115
+ openDelay={1000}
116
+ withinPortal
117
+ >
118
+ <span>
119
+ {selectDisplayMode === 'switch' ? (
120
+ <Switch {...commonProps} />
121
+ ) : selectDisplayMode === 'radio' ||
122
+ enableMultiRowSelection === false ? (
123
+ <Radio {...commonProps} />
124
+ ) : (
125
+ <Checkbox
126
+ indeterminate={
127
+ !isChecked && selectAll
128
+ ? table.getIsSomeRowsSelected()
129
+ : row?.getIsSomeSelected() && row.getCanSelectSubRows()
130
+ }
131
+ {...commonProps}
132
+ />
133
+ )}
134
+ </span>
135
+ </Tooltip>
136
+ );
137
+ };
@@ -0,0 +1,7 @@
1
+ .left {
2
+ transform: rotate(90deg);
3
+ }
4
+
5
+ .right {
6
+ transform: rotate(-90deg);
7
+ }
@@ -0,0 +1,287 @@
1
+ import classes from './MRT_ColumnActionMenu.module.css';
2
+
3
+ import { ActionIcon, Menu, type MenuProps, Tooltip } from '@mantine/core';
4
+
5
+ import {
6
+ type MRT_Header,
7
+ type MRT_RowData,
8
+ type MRT_TableInstance,
9
+ } from '../../types';
10
+ import { parseFromValuesOrFunc } from '../../utils/utils';
11
+
12
+ interface Props<TData extends MRT_RowData> extends MenuProps {
13
+ header: MRT_Header<TData>;
14
+ table: MRT_TableInstance<TData>;
15
+ }
16
+
17
+ export const MRT_ColumnActionMenu = <TData extends MRT_RowData>({
18
+ header,
19
+ table,
20
+ ...rest
21
+ }: Props<TData>) => {
22
+ 'use no memo';
23
+ const {
24
+ getState,
25
+ options: {
26
+ columnFilterDisplayMode,
27
+ enableColumnFilters,
28
+ enableColumnPinning,
29
+ enableColumnResizing,
30
+ enableGrouping,
31
+ enableHiding,
32
+ enableSorting,
33
+ enableSortingRemoval,
34
+ icons: {
35
+ IconArrowAutofitContent,
36
+ IconBoxMultiple,
37
+ IconClearAll,
38
+ IconColumns,
39
+ IconDotsVertical,
40
+ IconEyeOff,
41
+ IconFilter,
42
+ IconFilterOff,
43
+ IconPinned,
44
+ IconPinnedOff,
45
+ IconSortAscending,
46
+ IconSortDescending,
47
+ },
48
+ localization,
49
+ mantineColumnActionsButtonProps,
50
+ renderColumnActionsMenuItems,
51
+ },
52
+ refs: { filterInputRefs },
53
+ setColumnOrder,
54
+ setColumnSizingInfo,
55
+ setShowColumnFilters,
56
+ toggleAllColumnsVisible,
57
+ } = table;
58
+ const { column } = header;
59
+ const { columnDef } = column;
60
+ const { columnSizing, columnVisibility } = getState();
61
+
62
+ const arg = { column, table };
63
+ const actionIconProps = {
64
+ ...parseFromValuesOrFunc(mantineColumnActionsButtonProps, arg),
65
+ ...parseFromValuesOrFunc(columnDef.mantineColumnActionsButtonProps, arg),
66
+ };
67
+
68
+ const handleClearSort = () => {
69
+ column.clearSorting();
70
+ };
71
+
72
+ const handleSortAsc = () => {
73
+ column.toggleSorting(false);
74
+ };
75
+
76
+ const handleSortDesc = () => {
77
+ column.toggleSorting(true);
78
+ };
79
+
80
+ const handleResetColumnSize = () => {
81
+ setColumnSizingInfo((old) => ({ ...old, isResizingColumn: false }));
82
+ column.resetSize();
83
+ };
84
+
85
+ const handleHideColumn = () => {
86
+ column.toggleVisibility(false);
87
+ };
88
+
89
+ const handlePinColumn = (pinDirection: 'left' | 'right' | false) => {
90
+ column.pin(pinDirection);
91
+ };
92
+
93
+ const handleGroupByColumn = () => {
94
+ column.toggleGrouping();
95
+ setColumnOrder((old: any) => ['mrt-row-expand', ...old]);
96
+ };
97
+
98
+ const handleClearFilter = () => {
99
+ column.setFilterValue('');
100
+ };
101
+
102
+ const handleFilterByColumn = () => {
103
+ setShowColumnFilters(true);
104
+ setTimeout(() => filterInputRefs.current[`${column.id}-0`]?.focus(), 100);
105
+ };
106
+
107
+ const handleShowAllColumns = () => {
108
+ toggleAllColumnsVisible(true);
109
+ };
110
+
111
+ const internalColumnMenuItems = (
112
+ <>
113
+ {enableSorting && column.getCanSort() && (
114
+ <>
115
+ {enableSortingRemoval !== false && (
116
+ <Menu.Item
117
+ disabled={!column.getIsSorted()}
118
+ leftSection={<IconClearAll />}
119
+ onClick={handleClearSort}
120
+ >
121
+ {localization.clearSort}
122
+ </Menu.Item>
123
+ )}
124
+ <Menu.Item
125
+ disabled={column.getIsSorted() === 'asc'}
126
+ leftSection={<IconSortAscending />}
127
+ onClick={handleSortAsc}
128
+ >
129
+ {localization.sortByColumnAsc?.replace(
130
+ '{column}',
131
+ String(columnDef.header),
132
+ )}
133
+ </Menu.Item>
134
+ <Menu.Item
135
+ disabled={column.getIsSorted() === 'desc'}
136
+ leftSection={<IconSortDescending />}
137
+ onClick={handleSortDesc}
138
+ >
139
+ {localization.sortByColumnDesc?.replace(
140
+ '{column}',
141
+ String(columnDef.header),
142
+ )}
143
+ </Menu.Item>
144
+ {(enableColumnFilters || enableGrouping || enableHiding) && (
145
+ <Menu.Divider key={3} />
146
+ )}
147
+ </>
148
+ )}
149
+ {enableColumnFilters &&
150
+ columnFilterDisplayMode !== 'popover' &&
151
+ column.getCanFilter() && (
152
+ <>
153
+ <Menu.Item
154
+ disabled={!column.getFilterValue()}
155
+ leftSection={<IconFilterOff />}
156
+ onClick={handleClearFilter}
157
+ >
158
+ {localization.clearFilter}
159
+ </Menu.Item>
160
+ <Menu.Item
161
+ leftSection={<IconFilter />}
162
+ onClick={handleFilterByColumn}
163
+ >
164
+ {localization.filterByColumn?.replace(
165
+ '{column}',
166
+ String(columnDef.header),
167
+ )}
168
+ </Menu.Item>
169
+ {(enableGrouping || enableHiding) && <Menu.Divider key={2} />}
170
+ </>
171
+ )}
172
+ {enableGrouping && column.getCanGroup() && (
173
+ <>
174
+ <Menu.Item
175
+ leftSection={<IconBoxMultiple />}
176
+ onClick={handleGroupByColumn}
177
+ >
178
+ {localization[
179
+ column.getIsGrouped() ? 'ungroupByColumn' : 'groupByColumn'
180
+ ]?.replace('{column}', String(columnDef.header))}
181
+ </Menu.Item>
182
+ {enableColumnPinning && <Menu.Divider />}
183
+ </>
184
+ )}
185
+ {enableColumnPinning && column.getCanPin() && (
186
+ <>
187
+ <Menu.Item
188
+ disabled={column.getIsPinned() === 'left' || !column.getCanPin()}
189
+ leftSection={<IconPinned className={classes.left} />}
190
+ onClick={() => handlePinColumn('left')}
191
+ >
192
+ {localization.pinToLeft}
193
+ </Menu.Item>
194
+ <Menu.Item
195
+ disabled={column.getIsPinned() === 'right' || !column.getCanPin()}
196
+ leftSection={<IconPinned className={classes.right} />}
197
+ onClick={() => handlePinColumn('right')}
198
+ >
199
+ {localization.pinToRight}
200
+ </Menu.Item>
201
+ <Menu.Item
202
+ disabled={!column.getIsPinned()}
203
+ leftSection={<IconPinnedOff />}
204
+ onClick={() => handlePinColumn(false)}
205
+ >
206
+ {localization.unpin}
207
+ </Menu.Item>
208
+ {enableHiding && <Menu.Divider />}
209
+ </>
210
+ )}
211
+ {enableColumnResizing && column.getCanResize() && (
212
+ <Menu.Item
213
+ disabled={!columnSizing[column.id]}
214
+ key={0}
215
+ leftSection={<IconArrowAutofitContent />}
216
+ onClick={handleResetColumnSize}
217
+ >
218
+ {localization.resetColumnSize}
219
+ </Menu.Item>
220
+ )}
221
+ {enableHiding && (
222
+ <>
223
+ <Menu.Item
224
+ disabled={!column.getCanHide()}
225
+ key={0}
226
+ leftSection={<IconEyeOff />}
227
+ onClick={handleHideColumn}
228
+ >
229
+ {localization.hideColumn?.replace(
230
+ '{column}',
231
+ String(columnDef.header),
232
+ )}
233
+ </Menu.Item>
234
+ <Menu.Item
235
+ disabled={
236
+ !Object.values(columnVisibility).filter((visible) => !visible)
237
+ .length
238
+ }
239
+ key={1}
240
+ leftSection={<IconColumns />}
241
+ onClick={handleShowAllColumns}
242
+ >
243
+ {localization.showAllColumns?.replace(
244
+ '{column}',
245
+ String(columnDef.header),
246
+ )}
247
+ </Menu.Item>
248
+ </>
249
+ )}
250
+ </>
251
+ );
252
+
253
+ return (
254
+ <Menu closeOnItemClick position="bottom-start" withinPortal {...rest}>
255
+ <Tooltip
256
+ label={actionIconProps?.title ?? localization.columnActions}
257
+ openDelay={1000}
258
+ withinPortal
259
+ >
260
+ <Menu.Target>
261
+ <ActionIcon
262
+ aria-label={localization.columnActions}
263
+ color="gray"
264
+ size="sm"
265
+ variant="subtle"
266
+ {...actionIconProps}
267
+ >
268
+ <IconDotsVertical size="100%" />
269
+ </ActionIcon>
270
+ </Menu.Target>
271
+ </Tooltip>
272
+ <Menu.Dropdown>
273
+ {columnDef.renderColumnActionsMenuItems?.({
274
+ column,
275
+ internalColumnMenuItems,
276
+ table,
277
+ }) ??
278
+ renderColumnActionsMenuItems?.({
279
+ column,
280
+ internalColumnMenuItems,
281
+ table,
282
+ }) ??
283
+ internalColumnMenuItems}
284
+ </Menu.Dropdown>
285
+ </Menu>
286
+ );
287
+ };
@@ -0,0 +1,6 @@
1
+ .symbol {
2
+ font-size: var(--mantine-font-size-xl);
3
+ text-align: center;
4
+ width: 2ch;
5
+ transform: translateY(-0.1em);
6
+ }