@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,120 @@
1
+ import clsx from 'clsx';
2
+
3
+ import classes from './MRT_ExpandButton.module.css';
4
+
5
+ import { type MouseEvent } from 'react';
6
+
7
+ import {
8
+ ActionIcon,
9
+ type ActionIconProps,
10
+ Tooltip,
11
+ useDirection,
12
+ } from '@mantine/core';
13
+
14
+ import {
15
+ type MRT_Row,
16
+ type MRT_RowData,
17
+ type MRT_TableInstance,
18
+ } from '../../types';
19
+ import { parseFromValuesOrFunc } from '../../utils/utils';
20
+ import { MRT_EditCellTextInput } from '../inputs/MRT_EditCellTextInput';
21
+
22
+ interface Props<TData extends MRT_RowData> extends ActionIconProps {
23
+ row: MRT_Row<TData>;
24
+ table: MRT_TableInstance<TData>;
25
+ }
26
+
27
+ export const MRT_ExpandButton = <TData extends MRT_RowData>({
28
+ row,
29
+ table,
30
+ ...rest
31
+ }: Props<TData>) => {
32
+ 'use no memo';
33
+ const direction = useDirection();
34
+ const {
35
+ options: {
36
+ icons: { IconChevronDown },
37
+ localization,
38
+ mantineExpandButtonProps,
39
+ positionExpandColumn,
40
+ renderDetailPanel,
41
+ },
42
+ } = table;
43
+
44
+ const actionIconProps = {
45
+ ...parseFromValuesOrFunc(mantineExpandButtonProps, {
46
+ row,
47
+ table,
48
+ }),
49
+ ...rest,
50
+ };
51
+
52
+ const internalEditComponents = row
53
+ .getAllCells()
54
+ .filter((cell) => cell.column.columnDef.columnDefType === 'data')
55
+ .map((cell) => (
56
+ <MRT_EditCellTextInput cell={cell} key={cell.id} table={table} />
57
+ ));
58
+
59
+ const canExpand = row.getCanExpand();
60
+ const isExpanded = row.getIsExpanded();
61
+
62
+ const DetailPanel = !!renderDetailPanel?.({
63
+ internalEditComponents,
64
+ row,
65
+ table,
66
+ });
67
+
68
+ const handleToggleExpand = (event: MouseEvent<HTMLButtonElement>) => {
69
+ event.stopPropagation();
70
+ row.toggleExpanded();
71
+ actionIconProps?.onClick?.(event);
72
+ };
73
+
74
+ const rtl = direction.dir === 'rtl' || positionExpandColumn === 'last';
75
+
76
+ return (
77
+ <Tooltip
78
+ disabled={!canExpand && !DetailPanel}
79
+ label={
80
+ actionIconProps?.title ??
81
+ (isExpanded ? localization.collapse : localization.expand)
82
+ }
83
+ openDelay={1000}
84
+ withinPortal
85
+ >
86
+ <ActionIcon
87
+ aria-label={localization.expand}
88
+ color="gray"
89
+ disabled={!canExpand && !DetailPanel}
90
+ variant="subtle"
91
+ {...actionIconProps}
92
+ __vars={{
93
+ '--mrt-row-depth': `${row.depth}`,
94
+ }}
95
+ className={clsx(
96
+ 'mrt-expand-button',
97
+ classes.root,
98
+ classes[`root-${rtl ? 'rtl' : 'ltr'}`],
99
+ actionIconProps?.className,
100
+ )}
101
+ onClick={handleToggleExpand}
102
+ title={undefined}
103
+ >
104
+ {actionIconProps?.children ?? (
105
+ <IconChevronDown
106
+ className={clsx(
107
+ 'mrt-expand-button-chevron',
108
+ classes.chevron,
109
+ !canExpand && !renderDetailPanel
110
+ ? classes.right
111
+ : isExpanded
112
+ ? classes.up
113
+ : undefined,
114
+ )}
115
+ />
116
+ )}
117
+ </ActionIcon>
118
+ </Tooltip>
119
+ );
120
+ };
@@ -0,0 +1,6 @@
1
+ .grab-icon {
2
+ cursor: grab;
3
+ &:active {
4
+ cursor: grabbing;
5
+ }
6
+ }
@@ -0,0 +1,64 @@
1
+ import clsx from 'clsx';
2
+
3
+ import classes from './MRT_GrabHandleButton.module.css';
4
+
5
+ import { type DragEventHandler } from 'react';
6
+
7
+ import { ActionIcon, type ActionIconProps, Tooltip } from '@mantine/core';
8
+
9
+ import {
10
+ type HTMLPropsRef,
11
+ type MRT_RowData,
12
+ type MRT_TableInstance,
13
+ } from '../../types';
14
+
15
+ interface Props<TData extends MRT_RowData> {
16
+ actionIconProps?: ActionIconProps & HTMLPropsRef<HTMLButtonElement>;
17
+ onDragEnd: DragEventHandler<HTMLButtonElement>;
18
+ onDragStart: DragEventHandler<HTMLButtonElement>;
19
+ table: MRT_TableInstance<TData>;
20
+ }
21
+
22
+ export const MRT_GrabHandleButton = <TData extends MRT_RowData>({
23
+ actionIconProps,
24
+ onDragEnd,
25
+ onDragStart,
26
+ table: {
27
+ options: {
28
+ icons: { IconGripHorizontal },
29
+ localization: { move },
30
+ },
31
+ },
32
+ }: Props<TData>) => {
33
+ 'use no memo';
34
+ return (
35
+ <Tooltip
36
+ label={actionIconProps?.title ?? move}
37
+ openDelay={1000}
38
+ withinPortal
39
+ >
40
+ <ActionIcon
41
+ aria-label={actionIconProps?.title ?? move}
42
+ draggable
43
+ {...actionIconProps}
44
+ className={clsx(
45
+ 'mrt-grab-handle-button',
46
+ classes['grab-icon'],
47
+ actionIconProps?.className,
48
+ )}
49
+ color="gray"
50
+ onClick={(e) => {
51
+ e.stopPropagation();
52
+ actionIconProps?.onClick?.(e);
53
+ }}
54
+ onDragEnd={onDragEnd}
55
+ onDragStart={onDragStart}
56
+ size="sm"
57
+ title={undefined}
58
+ variant="transparent"
59
+ >
60
+ <IconGripHorizontal size="100%" />
61
+ </ActionIcon>
62
+ </Tooltip>
63
+ );
64
+ };
@@ -0,0 +1,83 @@
1
+ import { type MouseEvent, useState } from 'react';
2
+
3
+ import { type RowPinningPosition } from '@tanstack/react-table';
4
+
5
+ import { ActionIcon, type ActionIconProps, Tooltip } from '@mantine/core';
6
+
7
+ import {
8
+ type MRT_Row,
9
+ type MRT_RowData,
10
+ type MRT_TableInstance,
11
+ } from '../../types';
12
+
13
+ interface Props<TData extends MRT_RowData> extends ActionIconProps {
14
+ pinningPosition: RowPinningPosition;
15
+ row: MRT_Row<TData>;
16
+ table: MRT_TableInstance<TData>;
17
+ }
18
+
19
+ export const MRT_RowPinButton = <TData extends MRT_RowData>({
20
+ pinningPosition,
21
+ row,
22
+ table,
23
+ ...rest
24
+ }: Props<TData>) => {
25
+ 'use no memo';
26
+ const {
27
+ options: {
28
+ icons: { IconPinned, IconX },
29
+ localization,
30
+ rowPinningDisplayMode,
31
+ },
32
+ } = table;
33
+
34
+ const isPinned = row.getIsPinned();
35
+
36
+ const [tooltipOpened, setTooltipOpened] = useState(false);
37
+
38
+ const handleTogglePin = (event: MouseEvent<HTMLButtonElement>) => {
39
+ setTooltipOpened(false);
40
+ event.stopPropagation();
41
+ row.pin(isPinned ? false : pinningPosition);
42
+ };
43
+
44
+ return (
45
+ <Tooltip
46
+ label={isPinned ? localization.unpin : localization.pin}
47
+ openDelay={1000}
48
+ opened={tooltipOpened}
49
+ >
50
+ <ActionIcon
51
+ aria-label={localization.pin}
52
+ color="gray"
53
+ onClick={handleTogglePin}
54
+ onMouseEnter={() => setTooltipOpened(true)}
55
+ onMouseLeave={() => setTooltipOpened(false)}
56
+ size="xs"
57
+ style={{
58
+ height: '24px',
59
+ width: '24px',
60
+ }}
61
+ variant="subtle"
62
+ {...rest}
63
+ >
64
+ {isPinned ? (
65
+ <IconX />
66
+ ) : (
67
+ <IconPinned
68
+ fontSize="small"
69
+ style={{
70
+ transform: `rotate(${
71
+ rowPinningDisplayMode === 'sticky'
72
+ ? 135
73
+ : pinningPosition === 'top'
74
+ ? 180
75
+ : 0
76
+ }deg)`,
77
+ }}
78
+ />
79
+ )}
80
+ </ActionIcon>
81
+ </Tooltip>
82
+ );
83
+ };
@@ -0,0 +1,45 @@
1
+ import { ActionIcon, type ActionIconProps, Menu, Tooltip } from '@mantine/core';
2
+
3
+ import {
4
+ type HTMLPropsRef,
5
+ type MRT_RowData,
6
+ type MRT_TableInstance,
7
+ } from '../../types';
8
+ import { MRT_ShowHideColumnsMenu } from '../menus/MRT_ShowHideColumnsMenu';
9
+
10
+ interface Props<TData extends MRT_RowData>
11
+ extends ActionIconProps,
12
+ HTMLPropsRef<HTMLButtonElement> {
13
+ table: MRT_TableInstance<TData>;
14
+ }
15
+
16
+ export const MRT_ShowHideColumnsButton = <TData extends MRT_RowData>({
17
+ table,
18
+ title,
19
+ ...rest
20
+ }: Props<TData>) => {
21
+ 'use no memo';
22
+ const {
23
+ icons: { IconColumns },
24
+ localization: { showHideColumns },
25
+ } = table.options;
26
+
27
+ return (
28
+ <Menu closeOnItemClick={false} withinPortal>
29
+ <Tooltip label={title ?? showHideColumns} withinPortal>
30
+ <Menu.Target>
31
+ <ActionIcon
32
+ aria-label={title ?? showHideColumns}
33
+ color="gray"
34
+ size="lg"
35
+ variant="subtle"
36
+ {...rest}
37
+ >
38
+ <IconColumns />
39
+ </ActionIcon>
40
+ </Menu.Target>
41
+ </Tooltip>
42
+ <MRT_ShowHideColumnsMenu table={table} />
43
+ </Menu>
44
+ );
45
+ };
@@ -0,0 +1,65 @@
1
+ import { ActionIcon, type ActionIconProps, Tooltip } from '@mantine/core';
2
+
3
+ import {
4
+ type HTMLPropsRef,
5
+ type MRT_DensityState,
6
+ type MRT_RowData,
7
+ type MRT_TableInstance,
8
+ } from '../../types';
9
+
10
+ interface Props<TData extends MRT_RowData>
11
+ extends ActionIconProps,
12
+ HTMLPropsRef<HTMLButtonElement> {
13
+ table: MRT_TableInstance<TData>;
14
+ }
15
+
16
+ type TogglableDensityState = Exclude<MRT_DensityState, 'lg' | 'sm'>;
17
+
18
+ const next: Record<TogglableDensityState, TogglableDensityState> = {
19
+ md: 'xs',
20
+ xl: 'md',
21
+ xs: 'xl',
22
+ };
23
+
24
+ export const MRT_ToggleDensePaddingButton = <TData extends MRT_RowData>({
25
+ table: {
26
+ getState,
27
+ options: {
28
+ icons: {
29
+ IconBaselineDensityLarge,
30
+ IconBaselineDensityMedium,
31
+ IconBaselineDensitySmall,
32
+ },
33
+ localization: { toggleDensity },
34
+ },
35
+ setDensity,
36
+ },
37
+ title,
38
+ ...rest
39
+ }: Props<TData>) => {
40
+ 'use no memo';
41
+ const { density } = getState();
42
+
43
+ return (
44
+ <Tooltip label={title ?? toggleDensity} withinPortal>
45
+ <ActionIcon
46
+ aria-label={title ?? toggleDensity}
47
+ color="gray"
48
+ onClick={() =>
49
+ setDensity((current) => next[current as TogglableDensityState])
50
+ }
51
+ size="lg"
52
+ variant="subtle"
53
+ {...rest}
54
+ >
55
+ {density === 'xs' ? (
56
+ <IconBaselineDensitySmall />
57
+ ) : density === 'md' ? (
58
+ <IconBaselineDensityMedium />
59
+ ) : (
60
+ <IconBaselineDensityLarge />
61
+ )}
62
+ </ActionIcon>
63
+ </Tooltip>
64
+ );
65
+ };
@@ -0,0 +1,44 @@
1
+ import { ActionIcon, type ActionIconProps, Tooltip } from '@mantine/core';
2
+
3
+ import {
4
+ type HTMLPropsRef,
5
+ type MRT_RowData,
6
+ type MRT_TableInstance,
7
+ } from '../../types';
8
+
9
+ interface Props<TData extends MRT_RowData>
10
+ extends ActionIconProps,
11
+ HTMLPropsRef<HTMLButtonElement> {
12
+ table: MRT_TableInstance<TData>;
13
+ }
14
+
15
+ export const MRT_ToggleFiltersButton = <TData extends MRT_RowData>({
16
+ table: {
17
+ getState,
18
+ options: {
19
+ icons: { IconFilter, IconFilterOff },
20
+ localization: { showHideFilters },
21
+ },
22
+ setShowColumnFilters,
23
+ },
24
+ title,
25
+ ...rest
26
+ }: Props<TData>) => {
27
+ 'use no memo';
28
+ const { showColumnFilters } = getState();
29
+
30
+ return (
31
+ <Tooltip label={title ?? showHideFilters} withinPortal>
32
+ <ActionIcon
33
+ aria-label={title ?? showHideFilters}
34
+ color="gray"
35
+ onClick={() => setShowColumnFilters((current) => !current)}
36
+ size="lg"
37
+ variant="subtle"
38
+ {...rest}
39
+ >
40
+ {showColumnFilters ? <IconFilterOff /> : <IconFilter />}
41
+ </ActionIcon>
42
+ </Tooltip>
43
+ );
44
+ };
@@ -0,0 +1,58 @@
1
+ import { useState } from 'react';
2
+
3
+ import { ActionIcon, type ActionIconProps, Tooltip } from '@mantine/core';
4
+
5
+ import {
6
+ type HTMLPropsRef,
7
+ type MRT_RowData,
8
+ type MRT_TableInstance,
9
+ } from '../../types';
10
+
11
+ interface Props<TData extends MRT_RowData>
12
+ extends ActionIconProps,
13
+ HTMLPropsRef<HTMLButtonElement> {
14
+ table: MRT_TableInstance<TData>;
15
+ }
16
+
17
+ export const MRT_ToggleFullScreenButton = <TData extends MRT_RowData>({
18
+ table: {
19
+ getState,
20
+ options: {
21
+ icons: { IconMaximize, IconMinimize },
22
+ localization: { toggleFullScreen },
23
+ },
24
+ setIsFullScreen,
25
+ },
26
+ title,
27
+ ...rest
28
+ }: Props<TData>) => {
29
+ 'use no memo';
30
+ const { isFullScreen } = getState();
31
+ const [tooltipOpened, setTooltipOpened] = useState(false);
32
+
33
+ const handleToggleFullScreen = () => {
34
+ setTooltipOpened(false);
35
+ setIsFullScreen((current) => !current);
36
+ };
37
+
38
+ return (
39
+ <Tooltip
40
+ label={title ?? toggleFullScreen}
41
+ opened={tooltipOpened}
42
+ withinPortal
43
+ >
44
+ <ActionIcon
45
+ aria-label={title ?? toggleFullScreen}
46
+ color="gray"
47
+ onClick={handleToggleFullScreen}
48
+ onMouseEnter={() => setTooltipOpened(true)}
49
+ onMouseLeave={() => setTooltipOpened(false)}
50
+ size="lg"
51
+ variant="subtle"
52
+ {...rest}
53
+ >
54
+ {isFullScreen ? <IconMinimize /> : <IconMaximize />}
55
+ </ActionIcon>
56
+ </Tooltip>
57
+ );
58
+ };
@@ -0,0 +1,51 @@
1
+ import { ActionIcon, type ActionIconProps, Tooltip } from '@mantine/core';
2
+
3
+ import {
4
+ type HTMLPropsRef,
5
+ type MRT_RowData,
6
+ type MRT_TableInstance,
7
+ } from '../../types';
8
+
9
+ interface Props<TData extends MRT_RowData>
10
+ extends ActionIconProps,
11
+ HTMLPropsRef<HTMLButtonElement> {
12
+ table: MRT_TableInstance<TData>;
13
+ }
14
+
15
+ export const MRT_ToggleGlobalFilterButton = <TData extends MRT_RowData>({
16
+ table: {
17
+ getState,
18
+ options: {
19
+ icons: { IconSearch, IconSearchOff },
20
+ localization: { showHideSearch },
21
+ },
22
+ refs: { searchInputRef },
23
+ setShowGlobalFilter,
24
+ },
25
+ title,
26
+ ...rest
27
+ }: Props<TData>) => {
28
+ 'use no memo';
29
+ const { globalFilter, showGlobalFilter } = getState();
30
+
31
+ const handleToggleSearch = () => {
32
+ setShowGlobalFilter(!showGlobalFilter);
33
+ setTimeout(() => searchInputRef.current?.focus(), 100);
34
+ };
35
+
36
+ return (
37
+ <Tooltip label={title ?? showHideSearch} withinPortal>
38
+ <ActionIcon
39
+ aria-label={title ?? showHideSearch}
40
+ color="gray"
41
+ disabled={!!globalFilter}
42
+ onClick={handleToggleSearch}
43
+ size="lg"
44
+ variant="subtle"
45
+ {...rest}
46
+ >
47
+ {showGlobalFilter ? <IconSearchOff /> : <IconSearch />}
48
+ </ActionIcon>
49
+ </Tooltip>
50
+ );
51
+ };
@@ -0,0 +1,86 @@
1
+ import { type MouseEvent } from 'react';
2
+
3
+ import { ActionIcon, Tooltip } from '@mantine/core';
4
+
5
+ import { MRT_EditActionButtons } from './MRT_EditActionButtons';
6
+
7
+ import {
8
+ type MRT_Cell,
9
+ type MRT_CellValue,
10
+ type MRT_Row,
11
+ type MRT_RowData,
12
+ type MRT_TableInstance,
13
+ } from '../../types';
14
+ import { parseFromValuesOrFunc } from '../../utils/utils';
15
+ import { MRT_RowActionMenu } from '../menus/MRT_RowActionMenu';
16
+
17
+ interface Props<TData extends MRT_RowData, TValue = MRT_CellValue> {
18
+ cell: MRT_Cell<TData, TValue>;
19
+ row: MRT_Row<TData>;
20
+ table: MRT_TableInstance<TData>;
21
+ }
22
+
23
+ export const MRT_ToggleRowActionMenuButton = <TData extends MRT_RowData>({
24
+ cell,
25
+ row,
26
+ table,
27
+ }: Props<TData>) => {
28
+ 'use no memo';
29
+ const {
30
+ getState,
31
+ options: {
32
+ createDisplayMode,
33
+ editDisplayMode,
34
+ enableEditing,
35
+ icons: { IconEdit },
36
+ localization: { edit },
37
+ renderRowActionMenuItems,
38
+ renderRowActions,
39
+ },
40
+ setEditingRow,
41
+ } = table;
42
+
43
+ const { creatingRow, editingRow } = getState();
44
+
45
+ const isCreating = creatingRow?.id === row.id;
46
+ const isEditing = editingRow?.id === row.id;
47
+
48
+ const handleStartEditMode = (event: MouseEvent) => {
49
+ event.stopPropagation();
50
+ setEditingRow({ ...row });
51
+ };
52
+
53
+ const showEditActionButtons =
54
+ (isCreating && createDisplayMode === 'row') ||
55
+ (isEditing && editDisplayMode === 'row');
56
+
57
+ return (
58
+ <>
59
+ {renderRowActions && !showEditActionButtons ? (
60
+ renderRowActions({ cell, row, table })
61
+ ) : showEditActionButtons ? (
62
+ <MRT_EditActionButtons row={row} table={table} />
63
+ ) : !renderRowActionMenuItems &&
64
+ parseFromValuesOrFunc(enableEditing, row) ? (
65
+ <Tooltip label={edit} openDelay={1000} position="right" withinPortal>
66
+ <ActionIcon
67
+ aria-label={edit}
68
+ color="gray"
69
+ disabled={!!editingRow && editingRow.id !== row.id}
70
+ onClick={handleStartEditMode}
71
+ size="md"
72
+ variant="subtle"
73
+ >
74
+ <IconEdit />
75
+ </ActionIcon>
76
+ </Tooltip>
77
+ ) : renderRowActionMenuItems ? (
78
+ <MRT_RowActionMenu
79
+ handleEdit={handleStartEditMode}
80
+ row={row}
81
+ table={table}
82
+ />
83
+ ) : null}
84
+ </>
85
+ );
86
+ };
@@ -0,0 +1,17 @@
1
+ .root {
2
+ background-color: var(--mrt-base-background-color);
3
+ display: table-row-group;
4
+ }
5
+
6
+ .grid {
7
+ display: grid;
8
+ }
9
+
10
+ .sticky {
11
+ bottom: 0;
12
+ opacity: 0.97;
13
+ position: sticky;
14
+ z-index: 1;
15
+ outline: 1px solid
16
+ light-dark(var(--mantine-color-gray-3), var(--mantine-color-gray-7));
17
+ }