@coveord/plasma-mantine 53.1.4 → 54.0.1

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 (394) hide show
  1. package/.eslintrc.js +1 -5
  2. package/.turbo/turbo-build.log +3 -3
  3. package/.turbo/turbo-test.log +42 -37
  4. package/dist/.tsbuildinfo +1 -1
  5. package/dist/cjs/components/button/Button.d.ts +1 -2
  6. package/dist/cjs/components/button/Button.d.ts.map +1 -1
  7. package/dist/cjs/components/button/Button.js.map +1 -1
  8. package/dist/cjs/components/code-editor/CodeEditor.d.ts.map +1 -1
  9. package/dist/cjs/components/code-editor/CodeEditor.js +2 -4
  10. package/dist/cjs/components/code-editor/CodeEditor.js.map +1 -1
  11. package/dist/cjs/components/collection/Collection.d.ts.map +1 -1
  12. package/dist/cjs/components/collection/CollectionContext.d.ts +1 -1
  13. package/dist/cjs/components/collection/CollectionContext.d.ts.map +1 -1
  14. package/dist/cjs/components/collection/enhanceWithCollectionProps.d.ts +1 -6
  15. package/dist/cjs/components/collection/enhanceWithCollectionProps.d.ts.map +1 -1
  16. package/dist/cjs/components/date-range-picker/DateRangePickerPopoverCalendar.d.ts.map +1 -1
  17. package/dist/cjs/components/date-range-picker/DateRangePickerPresetSelect.d.ts.map +1 -1
  18. package/dist/cjs/components/header/Header.context.d.ts +1 -1
  19. package/dist/cjs/components/header/Header.context.d.ts.map +1 -1
  20. package/dist/cjs/components/header/__tests__/__snapshots__/Header.spec.tsx.snap +10 -15
  21. package/dist/cjs/components/inline-confirm/InlineConfirm.d.ts +10 -2
  22. package/dist/cjs/components/inline-confirm/InlineConfirm.d.ts.map +1 -1
  23. package/dist/cjs/components/inline-confirm/InlineConfirm.js +2 -1
  24. package/dist/cjs/components/inline-confirm/InlineConfirm.js.map +1 -1
  25. package/dist/cjs/components/inline-confirm/InlineConfirmContext.d.ts +1 -1
  26. package/dist/cjs/components/inline-confirm/InlineConfirmContext.d.ts.map +1 -1
  27. package/dist/cjs/components/inline-confirm/InlineConfirmPrompt.d.ts +2 -5
  28. package/dist/cjs/components/inline-confirm/InlineConfirmPrompt.d.ts.map +1 -1
  29. package/dist/cjs/components/inline-confirm/InlineConfirmPrompt.js +5 -5
  30. package/dist/cjs/components/inline-confirm/InlineConfirmPrompt.js.map +1 -1
  31. package/dist/cjs/components/inline-confirm/InlineConfirmTarget.d.ts +2 -2
  32. package/dist/cjs/components/inline-confirm/InlineConfirmTarget.d.ts.map +1 -1
  33. package/dist/cjs/components/inline-confirm/InlineConfirmTarget.js +3 -3
  34. package/dist/cjs/components/inline-confirm/InlineConfirmTarget.js.map +1 -1
  35. package/dist/cjs/components/menu/Menu.d.ts +1 -1
  36. package/dist/cjs/components/table/Table.d.ts +68 -55
  37. package/dist/cjs/components/table/Table.d.ts.map +1 -1
  38. package/dist/cjs/components/table/Table.js +129 -174
  39. package/dist/cjs/components/table/Table.js.map +1 -1
  40. package/dist/cjs/components/table/Table.module.css +8 -1
  41. package/dist/cjs/components/table/Table.types.d.ts +52 -147
  42. package/dist/cjs/components/table/Table.types.d.ts.map +1 -1
  43. package/dist/cjs/components/table/TableContext.d.ts +15 -10
  44. package/dist/cjs/components/table/TableContext.d.ts.map +1 -1
  45. package/dist/cjs/components/table/TableContext.js +5 -20
  46. package/dist/cjs/components/table/TableContext.js.map +1 -1
  47. package/dist/cjs/components/table/index.d.ts +3 -3
  48. package/dist/cjs/components/table/index.d.ts.map +1 -1
  49. package/dist/cjs/components/table/index.js +5 -1
  50. package/dist/cjs/components/table/index.js.map +1 -1
  51. package/dist/cjs/components/table/layouts/TableLayoutControl.js +6 -6
  52. package/dist/cjs/components/table/layouts/TableLayoutControl.js.map +1 -1
  53. package/dist/cjs/components/table/layouts/TableLayouts.d.ts +1 -22
  54. package/dist/cjs/components/table/layouts/TableLayouts.d.ts.map +1 -1
  55. package/dist/cjs/components/table/layouts/TableLayouts.js.map +1 -1
  56. package/dist/cjs/components/table/layouts/row-layout/RowLayout.d.ts +1 -2
  57. package/dist/cjs/components/table/layouts/row-layout/RowLayout.d.ts.map +1 -1
  58. package/dist/cjs/components/table/layouts/row-layout/RowLayout.js.map +1 -1
  59. package/dist/cjs/components/table/layouts/row-layout/RowLayoutBody.d.ts +2 -3
  60. package/dist/cjs/components/table/layouts/row-layout/RowLayoutBody.d.ts.map +1 -1
  61. package/dist/cjs/components/table/layouts/row-layout/RowLayoutBody.js +17 -18
  62. package/dist/cjs/components/table/layouts/row-layout/RowLayoutBody.js.map +1 -1
  63. package/dist/cjs/components/table/layouts/row-layout/RowLayoutContext.d.ts +1 -1
  64. package/dist/cjs/components/table/layouts/row-layout/RowLayoutContext.d.ts.map +1 -1
  65. package/dist/cjs/components/table/layouts/row-layout/RowLayoutHeader.d.ts +2 -3
  66. package/dist/cjs/components/table/layouts/row-layout/RowLayoutHeader.d.ts.map +1 -1
  67. package/dist/cjs/components/table/layouts/row-layout/RowLayoutHeader.js +9 -8
  68. package/dist/cjs/components/table/layouts/row-layout/RowLayoutHeader.js.map +1 -1
  69. package/dist/cjs/components/table/layouts/row-layout/RowLayoutIcon.d.ts +1 -5
  70. package/dist/cjs/components/table/layouts/row-layout/RowLayoutIcon.d.ts.map +1 -1
  71. package/dist/cjs/components/table/layouts/row-layout/RowLayoutIcon.js +3 -9
  72. package/dist/cjs/components/table/layouts/row-layout/RowLayoutIcon.js.map +1 -1
  73. package/dist/cjs/components/table/table-actions/TableActionContext.d.ts +9 -0
  74. package/dist/cjs/components/table/table-actions/TableActionContext.d.ts.map +1 -0
  75. package/dist/cjs/components/table/table-actions/TableActionContext.js +24 -0
  76. package/dist/cjs/components/table/table-actions/TableActionContext.js.map +1 -0
  77. package/dist/cjs/components/table/table-actions/TableActionItem.d.ts +44 -0
  78. package/dist/cjs/components/table/table-actions/TableActionItem.d.ts.map +1 -0
  79. package/dist/cjs/components/table/table-actions/TableActionItem.js +59 -0
  80. package/dist/cjs/components/table/table-actions/TableActionItem.js.map +1 -0
  81. package/dist/cjs/components/table/table-actions/TableActionsList.d.ts +37 -0
  82. package/dist/cjs/components/table/table-actions/TableActionsList.d.ts.map +1 -0
  83. package/dist/cjs/components/table/table-actions/TableActionsList.js +217 -0
  84. package/dist/cjs/components/table/table-actions/TableActionsList.js.map +1 -0
  85. package/dist/cjs/components/table/table-actions/TableHeaderActions.d.ts +11 -0
  86. package/dist/cjs/components/table/table-actions/TableHeaderActions.d.ts.map +1 -0
  87. package/dist/cjs/components/table/table-actions/TableHeaderActions.js +59 -0
  88. package/dist/cjs/components/table/table-actions/TableHeaderActions.js.map +1 -0
  89. package/dist/cjs/components/table/table-actions/index.d.ts +3 -0
  90. package/dist/cjs/components/table/table-actions/index.d.ts.map +1 -0
  91. package/dist/cjs/components/table/table-actions/index.js +9 -0
  92. package/dist/cjs/components/table/table-actions/index.js.map +1 -0
  93. package/dist/cjs/components/table/table-column/TableActionsColumn.d.ts +6 -0
  94. package/dist/cjs/components/table/table-column/TableActionsColumn.d.ts.map +1 -0
  95. package/dist/cjs/components/table/table-column/TableActionsColumn.js +53 -0
  96. package/dist/cjs/components/table/table-column/TableActionsColumn.js.map +1 -0
  97. package/dist/cjs/components/table/table-column/TableCollapsibleColumn.d.ts.map +1 -1
  98. package/dist/cjs/components/table/table-column/TableCollapsibleColumn.js +6 -2
  99. package/dist/cjs/components/table/table-column/TableCollapsibleColumn.js.map +1 -1
  100. package/dist/cjs/components/table/table-column/TableSelectableColumn.d.ts.map +1 -1
  101. package/dist/cjs/components/table/table-column/TableSelectableColumn.js +4 -0
  102. package/dist/cjs/components/table/table-column/TableSelectableColumn.js.map +1 -1
  103. package/dist/cjs/components/table/table-columns-selector/TableColumnsSelector.d.ts +7 -12
  104. package/dist/cjs/components/table/table-columns-selector/TableColumnsSelector.d.ts.map +1 -1
  105. package/dist/cjs/components/table/table-columns-selector/TableColumnsSelector.js +24 -20
  106. package/dist/cjs/components/table/table-columns-selector/TableColumnsSelector.js.map +1 -1
  107. package/dist/cjs/components/table/table-date-range-picker/TableDateRangePicker.d.ts +1 -2
  108. package/dist/cjs/components/table/table-date-range-picker/TableDateRangePicker.d.ts.map +1 -1
  109. package/dist/cjs/components/table/table-date-range-picker/TableDateRangePicker.js +7 -7
  110. package/dist/cjs/components/table/table-date-range-picker/TableDateRangePicker.js.map +1 -1
  111. package/dist/cjs/components/table/table-filter/TableFilter.d.ts +1 -2
  112. package/dist/cjs/components/table/table-filter/TableFilter.d.ts.map +1 -1
  113. package/dist/cjs/components/table/table-filter/TableFilter.js +11 -16
  114. package/dist/cjs/components/table/table-filter/TableFilter.js.map +1 -1
  115. package/dist/cjs/components/table/table-header/TableHeader.d.ts +7 -2
  116. package/dist/cjs/components/table/table-header/TableHeader.d.ts.map +1 -1
  117. package/dist/cjs/components/table/table-header/TableHeader.js +15 -12
  118. package/dist/cjs/components/table/table-header/TableHeader.js.map +1 -1
  119. package/dist/cjs/components/table/table-header/Th.d.ts +1 -2
  120. package/dist/cjs/components/table/table-header/Th.d.ts.map +1 -1
  121. package/dist/cjs/components/table/table-header/Th.js +7 -3
  122. package/dist/cjs/components/table/table-header/Th.js.map +1 -1
  123. package/dist/cjs/components/table/table-last-updated/TableLastUpdated.d.ts +1 -3
  124. package/dist/cjs/components/table/table-last-updated/TableLastUpdated.d.ts.map +1 -1
  125. package/dist/cjs/components/table/table-last-updated/TableLastUpdated.js +6 -9
  126. package/dist/cjs/components/table/table-last-updated/TableLastUpdated.js.map +1 -1
  127. package/dist/cjs/components/table/table-no-data/TableNoData.d.ts +6 -0
  128. package/dist/cjs/components/table/table-no-data/TableNoData.d.ts.map +1 -0
  129. package/dist/cjs/components/table/{table-consumer/TableConsumer.js → table-no-data/TableNoData.js} +4 -4
  130. package/dist/cjs/components/table/table-no-data/TableNoData.js.map +1 -0
  131. package/dist/cjs/components/table/table-pagination/TablePagination.d.ts.map +1 -1
  132. package/dist/cjs/components/table/table-pagination/TablePagination.js +9 -11
  133. package/dist/cjs/components/table/table-pagination/TablePagination.js.map +1 -1
  134. package/dist/cjs/components/table/table-pagination/TablePagination.types.d.ts +0 -4
  135. package/dist/cjs/components/table/table-pagination/TablePagination.types.d.ts.map +1 -1
  136. package/dist/cjs/components/table/table-per-page/TablePerPage.d.ts.map +1 -1
  137. package/dist/cjs/components/table/table-per-page/TablePerPage.js +16 -16
  138. package/dist/cjs/components/table/table-per-page/TablePerPage.js.map +1 -1
  139. package/dist/cjs/components/table/table-predicate/TablePredicate.d.ts +1 -2
  140. package/dist/cjs/components/table/table-predicate/TablePredicate.d.ts.map +1 -1
  141. package/dist/cjs/components/table/table-predicate/TablePredicate.js +12 -14
  142. package/dist/cjs/components/table/table-predicate/TablePredicate.js.map +1 -1
  143. package/dist/cjs/components/table/use-table.d.ts +182 -0
  144. package/dist/cjs/components/table/use-table.d.ts.map +1 -0
  145. package/dist/cjs/components/table/use-table.js +145 -0
  146. package/dist/cjs/components/table/use-table.js.map +1 -0
  147. package/dist/cjs/hooks/useControlledList.d.ts.map +1 -1
  148. package/dist/cjs/index.d.ts +11 -1
  149. package/dist/cjs/index.d.ts.map +1 -1
  150. package/dist/cjs/index.js.map +1 -1
  151. package/dist/cjs/theme/Theme.d.ts.map +1 -1
  152. package/dist/cjs/theme/Theme.js +0 -7
  153. package/dist/cjs/theme/Theme.js.map +1 -1
  154. package/dist/cjs/utils/createFactoryComponent.d.ts.map +1 -1
  155. package/dist/cjs/utils/overrideComponent.d.ts.map +1 -1
  156. package/dist/esm/components/button/Button.d.ts +1 -2
  157. package/dist/esm/components/button/Button.d.ts.map +1 -1
  158. package/dist/esm/components/button/Button.js.map +1 -1
  159. package/dist/esm/components/code-editor/CodeEditor.d.ts.map +1 -1
  160. package/dist/esm/components/code-editor/CodeEditor.js +2 -4
  161. package/dist/esm/components/code-editor/CodeEditor.js.map +1 -1
  162. package/dist/esm/components/collection/Collection.d.ts.map +1 -1
  163. package/dist/esm/components/collection/CollectionContext.d.ts +1 -1
  164. package/dist/esm/components/collection/CollectionContext.d.ts.map +1 -1
  165. package/dist/esm/components/collection/enhanceWithCollectionProps.d.ts +1 -6
  166. package/dist/esm/components/collection/enhanceWithCollectionProps.d.ts.map +1 -1
  167. package/dist/esm/components/date-range-picker/DateRangePickerPopoverCalendar.d.ts.map +1 -1
  168. package/dist/esm/components/date-range-picker/DateRangePickerPresetSelect.d.ts.map +1 -1
  169. package/dist/esm/components/header/Header.context.d.ts +1 -1
  170. package/dist/esm/components/header/Header.context.d.ts.map +1 -1
  171. package/dist/esm/components/header/__tests__/__snapshots__/Header.spec.tsx.snap +10 -15
  172. package/dist/esm/components/inline-confirm/InlineConfirm.d.ts +10 -2
  173. package/dist/esm/components/inline-confirm/InlineConfirm.d.ts.map +1 -1
  174. package/dist/esm/components/inline-confirm/InlineConfirm.js +1 -1
  175. package/dist/esm/components/inline-confirm/InlineConfirm.js.map +1 -1
  176. package/dist/esm/components/inline-confirm/InlineConfirmContext.d.ts +1 -1
  177. package/dist/esm/components/inline-confirm/InlineConfirmContext.d.ts.map +1 -1
  178. package/dist/esm/components/inline-confirm/InlineConfirmPrompt.d.ts +2 -5
  179. package/dist/esm/components/inline-confirm/InlineConfirmPrompt.d.ts.map +1 -1
  180. package/dist/esm/components/inline-confirm/InlineConfirmPrompt.js +4 -4
  181. package/dist/esm/components/inline-confirm/InlineConfirmPrompt.js.map +1 -1
  182. package/dist/esm/components/inline-confirm/InlineConfirmTarget.d.ts +2 -2
  183. package/dist/esm/components/inline-confirm/InlineConfirmTarget.d.ts.map +1 -1
  184. package/dist/esm/components/inline-confirm/InlineConfirmTarget.js +2 -2
  185. package/dist/esm/components/inline-confirm/InlineConfirmTarget.js.map +1 -1
  186. package/dist/esm/components/menu/Menu.d.ts +1 -1
  187. package/dist/esm/components/table/Table.d.ts +68 -55
  188. package/dist/esm/components/table/Table.d.ts.map +1 -1
  189. package/dist/esm/components/table/Table.js +122 -157
  190. package/dist/esm/components/table/Table.js.map +1 -1
  191. package/dist/esm/components/table/Table.module.css +8 -1
  192. package/dist/esm/components/table/Table.types.d.ts +52 -147
  193. package/dist/esm/components/table/Table.types.d.ts.map +1 -1
  194. package/dist/esm/components/table/Table.types.js.map +1 -1
  195. package/dist/esm/components/table/TableContext.d.ts +15 -10
  196. package/dist/esm/components/table/TableContext.d.ts.map +1 -1
  197. package/dist/esm/components/table/TableContext.js +1 -10
  198. package/dist/esm/components/table/TableContext.js.map +1 -1
  199. package/dist/esm/components/table/index.d.ts +3 -3
  200. package/dist/esm/components/table/index.d.ts.map +1 -1
  201. package/dist/esm/components/table/index.js +2 -1
  202. package/dist/esm/components/table/index.js.map +1 -1
  203. package/dist/esm/components/table/layouts/TableLayoutControl.js +4 -4
  204. package/dist/esm/components/table/layouts/TableLayoutControl.js.map +1 -1
  205. package/dist/esm/components/table/layouts/TableLayouts.d.ts +1 -22
  206. package/dist/esm/components/table/layouts/TableLayouts.d.ts.map +1 -1
  207. package/dist/esm/components/table/layouts/TableLayouts.js.map +1 -1
  208. package/dist/esm/components/table/layouts/row-layout/RowLayout.d.ts +1 -2
  209. package/dist/esm/components/table/layouts/row-layout/RowLayout.d.ts.map +1 -1
  210. package/dist/esm/components/table/layouts/row-layout/RowLayout.js.map +1 -1
  211. package/dist/esm/components/table/layouts/row-layout/RowLayoutBody.d.ts +2 -3
  212. package/dist/esm/components/table/layouts/row-layout/RowLayoutBody.d.ts.map +1 -1
  213. package/dist/esm/components/table/layouts/row-layout/RowLayoutBody.js +13 -11
  214. package/dist/esm/components/table/layouts/row-layout/RowLayoutBody.js.map +1 -1
  215. package/dist/esm/components/table/layouts/row-layout/RowLayoutContext.d.ts +1 -1
  216. package/dist/esm/components/table/layouts/row-layout/RowLayoutContext.d.ts.map +1 -1
  217. package/dist/esm/components/table/layouts/row-layout/RowLayoutHeader.d.ts +2 -3
  218. package/dist/esm/components/table/layouts/row-layout/RowLayoutHeader.d.ts.map +1 -1
  219. package/dist/esm/components/table/layouts/row-layout/RowLayoutHeader.js +5 -5
  220. package/dist/esm/components/table/layouts/row-layout/RowLayoutHeader.js.map +1 -1
  221. package/dist/esm/components/table/layouts/row-layout/RowLayoutIcon.d.ts +1 -5
  222. package/dist/esm/components/table/layouts/row-layout/RowLayoutIcon.d.ts.map +1 -1
  223. package/dist/esm/components/table/layouts/row-layout/RowLayoutIcon.js +2 -8
  224. package/dist/esm/components/table/layouts/row-layout/RowLayoutIcon.js.map +1 -1
  225. package/dist/esm/components/table/table-actions/TableActionContext.d.ts +9 -0
  226. package/dist/esm/components/table/table-actions/TableActionContext.d.ts.map +1 -0
  227. package/dist/esm/components/table/table-actions/TableActionContext.js +4 -0
  228. package/dist/esm/components/table/table-actions/TableActionContext.js.map +1 -0
  229. package/dist/esm/components/table/table-actions/TableActionItem.d.ts +44 -0
  230. package/dist/esm/components/table/table-actions/TableActionItem.d.ts.map +1 -0
  231. package/dist/esm/components/table/table-actions/TableActionItem.js +40 -0
  232. package/dist/esm/components/table/table-actions/TableActionItem.js.map +1 -0
  233. package/dist/esm/components/table/table-actions/TableActionsList.d.ts +37 -0
  234. package/dist/esm/components/table/table-actions/TableActionsList.d.ts.map +1 -0
  235. package/dist/esm/components/table/table-actions/TableActionsList.js +187 -0
  236. package/dist/esm/components/table/table-actions/TableActionsList.js.map +1 -0
  237. package/dist/esm/components/table/table-actions/TableHeaderActions.d.ts +11 -0
  238. package/dist/esm/components/table/table-actions/TableHeaderActions.d.ts.map +1 -0
  239. package/dist/esm/components/table/table-actions/TableHeaderActions.js +43 -0
  240. package/dist/esm/components/table/table-actions/TableHeaderActions.js.map +1 -0
  241. package/dist/esm/components/table/table-actions/index.d.ts +3 -0
  242. package/dist/esm/components/table/table-actions/index.d.ts.map +1 -0
  243. package/dist/esm/components/table/table-actions/index.js +4 -0
  244. package/dist/esm/components/table/table-actions/index.js.map +1 -0
  245. package/dist/esm/components/table/table-column/TableActionsColumn.d.ts +6 -0
  246. package/dist/esm/components/table/table-column/TableActionsColumn.d.ts.map +1 -0
  247. package/dist/esm/components/table/table-column/TableActionsColumn.js +40 -0
  248. package/dist/esm/components/table/table-column/TableActionsColumn.js.map +1 -0
  249. package/dist/esm/components/table/table-column/TableCollapsibleColumn.d.ts.map +1 -1
  250. package/dist/esm/components/table/table-column/TableCollapsibleColumn.js +7 -3
  251. package/dist/esm/components/table/table-column/TableCollapsibleColumn.js.map +1 -1
  252. package/dist/esm/components/table/table-column/TableSelectableColumn.d.ts.map +1 -1
  253. package/dist/esm/components/table/table-column/TableSelectableColumn.js +4 -0
  254. package/dist/esm/components/table/table-column/TableSelectableColumn.js.map +1 -1
  255. package/dist/esm/components/table/table-columns-selector/TableColumnsSelector.d.ts +7 -12
  256. package/dist/esm/components/table/table-columns-selector/TableColumnsSelector.d.ts.map +1 -1
  257. package/dist/esm/components/table/table-columns-selector/TableColumnsSelector.js +22 -20
  258. package/dist/esm/components/table/table-columns-selector/TableColumnsSelector.js.map +1 -1
  259. package/dist/esm/components/table/table-date-range-picker/TableDateRangePicker.d.ts +1 -2
  260. package/dist/esm/components/table/table-date-range-picker/TableDateRangePicker.d.ts.map +1 -1
  261. package/dist/esm/components/table/table-date-range-picker/TableDateRangePicker.js +8 -8
  262. package/dist/esm/components/table/table-date-range-picker/TableDateRangePicker.js.map +1 -1
  263. package/dist/esm/components/table/table-filter/TableFilter.d.ts +1 -2
  264. package/dist/esm/components/table/table-filter/TableFilter.d.ts.map +1 -1
  265. package/dist/esm/components/table/table-filter/TableFilter.js +14 -18
  266. package/dist/esm/components/table/table-filter/TableFilter.js.map +1 -1
  267. package/dist/esm/components/table/table-header/TableHeader.d.ts +7 -2
  268. package/dist/esm/components/table/table-header/TableHeader.d.ts.map +1 -1
  269. package/dist/esm/components/table/table-header/TableHeader.js +15 -13
  270. package/dist/esm/components/table/table-header/TableHeader.js.map +1 -1
  271. package/dist/esm/components/table/table-header/Th.d.ts +1 -2
  272. package/dist/esm/components/table/table-header/Th.d.ts.map +1 -1
  273. package/dist/esm/components/table/table-header/Th.js +8 -4
  274. package/dist/esm/components/table/table-header/Th.js.map +1 -1
  275. package/dist/esm/components/table/table-last-updated/TableLastUpdated.d.ts +1 -3
  276. package/dist/esm/components/table/table-last-updated/TableLastUpdated.d.ts.map +1 -1
  277. package/dist/esm/components/table/table-last-updated/TableLastUpdated.js +6 -8
  278. package/dist/esm/components/table/table-last-updated/TableLastUpdated.js.map +1 -1
  279. package/dist/esm/components/table/table-no-data/TableNoData.d.ts +6 -0
  280. package/dist/esm/components/table/table-no-data/TableNoData.d.ts.map +1 -0
  281. package/dist/esm/components/table/table-no-data/TableNoData.js +6 -0
  282. package/dist/esm/components/table/table-no-data/TableNoData.js.map +1 -0
  283. package/dist/esm/components/table/table-pagination/TablePagination.d.ts.map +1 -1
  284. package/dist/esm/components/table/table-pagination/TablePagination.js +10 -13
  285. package/dist/esm/components/table/table-pagination/TablePagination.js.map +1 -1
  286. package/dist/esm/components/table/table-pagination/TablePagination.types.d.ts +0 -4
  287. package/dist/esm/components/table/table-pagination/TablePagination.types.d.ts.map +1 -1
  288. package/dist/esm/components/table/table-pagination/TablePagination.types.js.map +1 -1
  289. package/dist/esm/components/table/table-per-page/TablePerPage.d.ts.map +1 -1
  290. package/dist/esm/components/table/table-per-page/TablePerPage.js +13 -12
  291. package/dist/esm/components/table/table-per-page/TablePerPage.js.map +1 -1
  292. package/dist/esm/components/table/table-predicate/TablePredicate.d.ts +1 -2
  293. package/dist/esm/components/table/table-predicate/TablePredicate.d.ts.map +1 -1
  294. package/dist/esm/components/table/table-predicate/TablePredicate.js +14 -18
  295. package/dist/esm/components/table/table-predicate/TablePredicate.js.map +1 -1
  296. package/dist/esm/components/table/use-table.d.ts +182 -0
  297. package/dist/esm/components/table/use-table.d.ts.map +1 -0
  298. package/dist/esm/components/table/use-table.js +122 -0
  299. package/dist/esm/components/table/use-table.js.map +1 -0
  300. package/dist/esm/hooks/useControlledList.d.ts.map +1 -1
  301. package/dist/esm/index.d.ts +11 -1
  302. package/dist/esm/index.d.ts.map +1 -1
  303. package/dist/esm/index.js.map +1 -1
  304. package/dist/esm/theme/Theme.d.ts.map +1 -1
  305. package/dist/esm/theme/Theme.js +1 -8
  306. package/dist/esm/theme/Theme.js.map +1 -1
  307. package/dist/esm/utils/createFactoryComponent.d.ts.map +1 -1
  308. package/dist/esm/utils/overrideComponent.d.ts.map +1 -1
  309. package/package.json +61 -46
  310. package/src/__tests__/Utils.tsx +3 -1
  311. package/src/components/button/Button.tsx +3 -1
  312. package/src/components/button/__tests__/ButtonWithDisabledTooltip.spec.tsx +1 -1
  313. package/src/components/code-editor/CodeEditor.tsx +1 -7
  314. package/src/components/date-range-picker/__tests__/DateRangePickerPopoverCalendar.spec.tsx +4 -4
  315. package/src/components/header/__tests__/Header.spec.tsx +21 -22
  316. package/src/components/header/__tests__/__snapshots__/Header.spec.tsx.snap +10 -15
  317. package/src/components/inline-confirm/InlineConfirm.tsx +12 -4
  318. package/src/components/inline-confirm/InlineConfirmPrompt.tsx +6 -9
  319. package/src/components/inline-confirm/InlineConfirmTarget.tsx +9 -4
  320. package/src/components/inline-confirm/__tests__/InlineConfirm.spec.tsx +39 -14
  321. package/src/components/table/Table.module.css +8 -1
  322. package/src/components/table/Table.tsx +148 -170
  323. package/src/components/table/Table.types.ts +57 -160
  324. package/src/components/table/TableContext.tsx +17 -16
  325. package/src/components/table/__tests__/Table.spec.tsx +176 -200
  326. package/src/components/table/__tests__/TableActions.spec.tsx +142 -31
  327. package/src/components/table/__tests__/TableCollapsibleColumn.spec.tsx +88 -0
  328. package/src/components/table/__tests__/TableColumnsSelector.spec.tsx +164 -123
  329. package/src/components/table/__tests__/TableDateRangePicker.spec.tsx +13 -17
  330. package/src/components/table/__tests__/TableFilter.spec.tsx +52 -96
  331. package/src/components/table/__tests__/TableLastUpdated.spec.tsx +18 -37
  332. package/src/components/table/__tests__/TablePagination.spec.tsx +84 -100
  333. package/src/components/table/__tests__/TablePerPage.spec.tsx +81 -104
  334. package/src/components/table/__tests__/TablePredicate.spec.tsx +26 -80
  335. package/src/components/table/__tests__/Th.spec.tsx +24 -19
  336. package/src/components/table/index.ts +3 -9
  337. package/src/components/table/layouts/TableLayoutControl.tsx +4 -4
  338. package/src/components/table/layouts/TableLayouts.tsx +0 -22
  339. package/src/components/table/layouts/__tests__/RowLayout.spec.tsx +210 -182
  340. package/src/components/table/layouts/row-layout/RowLayout.tsx +2 -2
  341. package/src/components/table/layouts/row-layout/RowLayoutBody.tsx +17 -17
  342. package/src/components/table/layouts/row-layout/RowLayoutHeader.tsx +18 -9
  343. package/src/components/table/layouts/row-layout/RowLayoutIcon.tsx +3 -8
  344. package/src/components/table/table-actions/TableActionContext.ts +9 -0
  345. package/src/components/table/table-actions/TableActionItem.tsx +80 -0
  346. package/src/components/table/table-actions/TableActionsList.tsx +209 -0
  347. package/src/components/table/table-actions/TableHeaderActions.tsx +56 -0
  348. package/src/components/table/table-actions/index.ts +2 -0
  349. package/src/components/table/table-column/TableActionsColumn.tsx +39 -0
  350. package/src/components/table/table-column/TableCollapsibleColumn.tsx +7 -3
  351. package/src/components/table/table-column/TableSelectableColumn.tsx +4 -0
  352. package/src/components/table/table-columns-selector/TableColumnsSelector.tsx +33 -28
  353. package/src/components/table/table-date-range-picker/TableDateRangePicker.tsx +9 -11
  354. package/src/components/table/table-filter/TableFilter.tsx +12 -18
  355. package/src/components/table/table-header/TableHeader.tsx +32 -15
  356. package/src/components/table/table-header/Th.tsx +8 -7
  357. package/src/components/table/table-last-updated/TableLastUpdated.tsx +7 -10
  358. package/src/components/table/table-no-data/TableNoData.tsx +7 -0
  359. package/src/components/table/table-pagination/TablePagination.tsx +8 -11
  360. package/src/components/table/table-pagination/TablePagination.types.ts +0 -4
  361. package/src/components/table/table-per-page/TablePerPage.tsx +8 -10
  362. package/src/components/table/table-predicate/TablePredicate.tsx +21 -17
  363. package/src/components/table/use-table.ts +323 -0
  364. package/src/index.ts +11 -1
  365. package/src/theme/Theme.tsx +0 -6
  366. package/dist/cjs/components/table/table-actions/TableActions.d.ts +0 -38
  367. package/dist/cjs/components/table/table-actions/TableActions.d.ts.map +0 -1
  368. package/dist/cjs/components/table/table-actions/TableActions.js +0 -47
  369. package/dist/cjs/components/table/table-actions/TableActions.js.map +0 -1
  370. package/dist/cjs/components/table/table-consumer/TableConsumer.d.ts +0 -5
  371. package/dist/cjs/components/table/table-consumer/TableConsumer.d.ts.map +0 -1
  372. package/dist/cjs/components/table/table-consumer/TableConsumer.js.map +0 -1
  373. package/dist/cjs/hooks/useRowSelection.d.ts +0 -10
  374. package/dist/cjs/hooks/useRowSelection.d.ts.map +0 -1
  375. package/dist/cjs/hooks/useRowSelection.js +0 -80
  376. package/dist/cjs/hooks/useRowSelection.js.map +0 -1
  377. package/dist/cjs/styles/Title.module.css +0 -5
  378. package/dist/esm/components/table/table-actions/TableActions.d.ts +0 -38
  379. package/dist/esm/components/table/table-actions/TableActions.d.ts.map +0 -1
  380. package/dist/esm/components/table/table-actions/TableActions.js +0 -29
  381. package/dist/esm/components/table/table-actions/TableActions.js.map +0 -1
  382. package/dist/esm/components/table/table-consumer/TableConsumer.d.ts +0 -5
  383. package/dist/esm/components/table/table-consumer/TableConsumer.d.ts.map +0 -1
  384. package/dist/esm/components/table/table-consumer/TableConsumer.js +0 -6
  385. package/dist/esm/components/table/table-consumer/TableConsumer.js.map +0 -1
  386. package/dist/esm/hooks/useRowSelection.d.ts +0 -10
  387. package/dist/esm/hooks/useRowSelection.d.ts.map +0 -1
  388. package/dist/esm/hooks/useRowSelection.js +0 -59
  389. package/dist/esm/hooks/useRowSelection.js.map +0 -1
  390. package/dist/esm/styles/Title.module.css +0 -5
  391. package/src/components/table/table-actions/TableActions.tsx +0 -67
  392. package/src/components/table/table-consumer/TableConsumer.tsx +0 -3
  393. package/src/hooks/useRowSelection.ts +0 -76
  394. package/src/styles/Title.module.css +0 -5
@@ -1,10 +1,10 @@
1
1
  import {ColumnDef, createColumnHelper} from '@tanstack/table-core';
2
- import {render, screen, userEvent, waitFor, within} from '@test-utils';
2
+ import {render, screen, userEvent, within} from '@test-utils';
3
3
 
4
4
  import {useState} from 'react';
5
5
  import {Table} from '../Table';
6
6
  import {TableLayout} from '../Table.types';
7
- import {useTable} from '../TableContext';
7
+ import {useTable} from '../use-table';
8
8
 
9
9
  type RowData = {id: string; firstName: string; lastName?: string};
10
10
 
@@ -14,20 +14,25 @@ const columns: Array<ColumnDef<RowData>> = [
14
14
  columnHelper.accessor('lastName', {enableSorting: false}),
15
15
  ];
16
16
 
17
- const EmptyState = () => {
18
- const {isFiltered} = useTable();
19
- return isFiltered ? <span data-testid="filtered-empty-state" /> : <span data-testid="empty-state" />;
20
- };
17
+ const EmptyState = (props: {isFiltered: boolean}) =>
18
+ props.isFiltered ? <span data-testid="filtered-empty-state" /> : <span data-testid="empty-state" />;
21
19
 
22
20
  describe('Table', () => {
23
- describe('when it has no data', () => {
21
+ describe('when it is vacant', () => {
24
22
  it('hides the footer and header if the table is not filtered', () => {
25
- render(
26
- <Table data={[]} columns={columns} noDataChildren={<EmptyState />}>
27
- <Table.Header data-testid="table-header">header</Table.Header>
28
- <Table.Footer data-testid="table-footer">footer</Table.Footer>
29
- </Table>,
30
- );
23
+ const Fixture = () => {
24
+ const store = useTable<RowData>({initialState: {totalEntries: 0}});
25
+ return (
26
+ <Table data={[]} store={store} columns={columns}>
27
+ <Table.Header data-testid="table-header">header</Table.Header>
28
+ <Table.Footer data-testid="table-footer">footer</Table.Footer>
29
+ <Table.NoData>
30
+ <EmptyState isFiltered={store.isFiltered} />
31
+ </Table.NoData>
32
+ </Table>
33
+ );
34
+ };
35
+ render(<Fixture />);
31
36
 
32
37
  expect(screen.queryByTestId('table-header')).not.toBeInTheDocument();
33
38
  expect(screen.queryByTestId('table-footer')).not.toBeInTheDocument();
@@ -35,17 +40,19 @@ describe('Table', () => {
35
40
  });
36
41
 
37
42
  it('does not hide the footer and header if the table is filtered', () => {
38
- render(
39
- <Table
40
- data={[]}
41
- columns={columns}
42
- noDataChildren={<EmptyState />}
43
- initialState={{globalFilter: 'something'}}
44
- >
45
- <Table.Header data-testid="table-header">header</Table.Header>
46
- <Table.Footer data-testid="table-footer">footer</Table.Footer>
47
- </Table>,
48
- );
43
+ const Fixture = () => {
44
+ const store = useTable<RowData>({initialState: {globalFilter: 'something'}});
45
+ return (
46
+ <Table store={store} data={[]} columns={columns}>
47
+ <Table.Header data-testid="table-header">header</Table.Header>
48
+ <Table.Footer data-testid="table-footer">footer</Table.Footer>
49
+ <Table.NoData>
50
+ <EmptyState isFiltered={store.isFiltered} />
51
+ </Table.NoData>
52
+ </Table>
53
+ );
54
+ };
55
+ render(<Fixture />);
49
56
 
50
57
  expect(screen.getByTestId('table-header')).toBeVisible();
51
58
  expect(screen.getByTestId('table-footer')).toBeVisible();
@@ -54,58 +61,52 @@ describe('Table', () => {
54
61
  });
55
62
  });
56
63
 
57
- it('updates the table when a component in Table.Consumer triggers a change', async () => {
58
- const user = userEvent.setup();
59
- const spy = vi.fn();
60
- const Fixture = () => {
61
- const {onChange} = useTable();
62
- return <button onClick={() => onChange()}>Click me</button>;
63
- };
64
- render(
65
- <Table onChange={spy} data={[{id: '🆔', firstName: 'first', lastName: 'last'}]} columns={columns}>
66
- <Table.Consumer>
67
- <Fixture />
68
- </Table.Consumer>
69
- </Table>,
70
- );
71
-
72
- expect(screen.getByRole('button', {name: 'Click me'})).toBeVisible();
73
- expect(spy).not.toHaveBeenCalled();
74
-
75
- await user.click(screen.getByRole('button', {name: 'Click me'}));
76
-
77
- await waitFor(() => {
78
- expect(spy).toHaveBeenCalledTimes(1);
64
+ describe('when it is loading', () => {
65
+ it('indicates the table element as loading', () => {
66
+ const Fixture = ({loading}: {loading: boolean}) => {
67
+ const store = useTable<RowData>();
68
+ return <Table store={store} loading={loading} data={[]} columns={columns} />;
69
+ };
70
+ const {rerender} = render(<Fixture loading />);
71
+ expect(screen.getByRole('table')).toHaveAttribute('data-loading', 'true');
72
+ rerender(<Fixture loading={false} />);
73
+ expect(screen.getByRole('table')).not.toHaveAttribute('data-loading');
79
74
  });
80
- });
81
75
 
82
- describe('when it is loading', () => {
83
76
  it('shows a loading animation over the no data children (filtered)', () => {
84
- render(
85
- <Table
86
- loading
87
- data={[]}
88
- columns={columns}
89
- noDataChildren={<EmptyState />}
90
- initialState={{globalFilter: 'something'}}
91
- >
92
- <Table.Header>
93
- <Table.Filter data-testid="table-filter" />
94
- </Table.Header>
95
- </Table>,
96
- );
77
+ const Fixture = () => {
78
+ const store = useTable<RowData>({initialState: {globalFilter: 'something'}});
79
+ return (
80
+ <Table store={store} loading data={[]} columns={columns}>
81
+ <Table.Header>
82
+ <Table.Filter data-testid="table-filter" />
83
+ </Table.Header>
84
+ <Table.NoData>
85
+ <EmptyState isFiltered={store.isFiltered} />
86
+ </Table.NoData>
87
+ </Table>
88
+ );
89
+ };
90
+ render(<Fixture />);
97
91
  expect(screen.getByTestId('filtered-empty-state').parentElement).toBeVisible();
98
92
  expect(screen.getByTestId('filtered-empty-state').parentElement).toHaveClass('mantine-Skeleton-root');
99
93
  });
100
94
 
101
95
  it('shows a loading animation over the no data children (unfiltered)', () => {
102
- render(
103
- <Table loading data={[]} columns={columns} noDataChildren={<EmptyState />}>
104
- <Table.Header>
105
- <Table.Filter data-testid="table-filter" />
106
- </Table.Header>
107
- </Table>,
108
- );
96
+ const Fixture = () => {
97
+ const store = useTable<RowData>();
98
+ return (
99
+ <Table store={store} loading data={[]} columns={columns}>
100
+ <Table.Header>
101
+ <Table.Filter data-testid="table-filter" />
102
+ </Table.Header>
103
+ <Table.NoData>
104
+ <EmptyState isFiltered={store.isFiltered} />
105
+ </Table.NoData>
106
+ </Table>
107
+ );
108
+ };
109
+ render(<Fixture />);
109
110
  expect(screen.getByTestId('empty-state').parentElement).toBeVisible();
110
111
  expect(screen.getByTestId('empty-state').parentElement).toHaveClass('mantine-Skeleton-root');
111
112
  });
@@ -113,19 +114,24 @@ describe('Table', () => {
113
114
 
114
115
  it('reset row selection when user click outside the table', async () => {
115
116
  const user = userEvent.setup();
116
- render(
117
- <div>
118
- <div>I'm a header</div>
119
- <Table
120
- getRowId={({id}) => id}
121
- data={[
122
- {id: '🆔-1', firstName: 'first', lastName: 'last'},
123
- {id: '🆔-2', firstName: 'patate', lastName: 'king'},
124
- ]}
125
- columns={columns}
126
- />
127
- </div>,
128
- );
117
+ const Fixture = () => {
118
+ const store = useTable<RowData>();
119
+ return (
120
+ <div>
121
+ <div>outside table</div>
122
+ <Table
123
+ store={store}
124
+ getRowId={({id}) => id}
125
+ data={[
126
+ {id: '🆔-1', firstName: 'first', lastName: 'last'},
127
+ {id: '🆔-2', firstName: 'patate', lastName: 'king'},
128
+ ]}
129
+ columns={columns}
130
+ />
131
+ </div>
132
+ );
133
+ };
134
+ render(<Fixture />);
129
135
 
130
136
  const row = screen.getByRole('row', {name: 'patate king', selected: false});
131
137
 
@@ -135,7 +141,7 @@ describe('Table', () => {
135
141
 
136
142
  expect(screen.getByRole('row', {name: 'patate king', selected: true})).toBeInTheDocument();
137
143
 
138
- await user.click(screen.getByText(/i'm a header/i));
144
+ await user.click(screen.getByText(/outside table/i));
139
145
 
140
146
  expect(screen.getByRole('row', {name: 'patate king', selected: false})).toBeInTheDocument();
141
147
  });
@@ -145,6 +151,7 @@ describe('Table', () => {
145
151
 
146
152
  const Fixture = () => {
147
153
  const [cousinNode, setCousinNode] = useState<HTMLDivElement>();
154
+ const store = useTable<RowData>();
148
155
 
149
156
  return (
150
157
  <>
@@ -155,6 +162,7 @@ describe('Table', () => {
155
162
  clicking inside here clears rows selection
156
163
  </div>
157
164
  <Table
165
+ store={store}
158
166
  getRowId={({id}) => id}
159
167
  data={[
160
168
  {id: '🆔-1', firstName: 'John', lastName: 'Doe'},
@@ -193,16 +201,21 @@ describe('Table', () => {
193
201
 
194
202
  it('handles switching layout', async () => {
195
203
  const user = userEvent.setup();
196
- render(
197
- <Table
198
- getRowId={({id}) => id}
199
- data={[{id: '🆔', firstName: 'first', lastName: 'last'}]}
200
- columns={columns}
201
- layouts={layouts}
202
- >
203
- <Table.Header data-testid="table-header" />
204
- </Table>,
205
- );
204
+ const Fixture = () => {
205
+ const store = useTable<RowData>();
206
+ return (
207
+ <Table
208
+ store={store}
209
+ getRowId={({id}) => id}
210
+ data={[{id: '🆔', firstName: 'first', lastName: 'last'}]}
211
+ columns={columns}
212
+ layouts={layouts}
213
+ >
214
+ <Table.Header data-testid="table-header" />
215
+ </Table>
216
+ );
217
+ };
218
+ render(<Fixture />);
206
219
  expect(screen.getByRole('radio', {name: /layout 1/i})).toBeChecked();
207
220
  expect(screen.getByTestId('layout1-header')).toBeInTheDocument();
208
221
  expect(screen.getByTestId('layout1-body')).toBeInTheDocument();
@@ -220,39 +233,22 @@ describe('Table', () => {
220
233
  expect(screen.queryByTestId('layout1-body')).not.toBeInTheDocument();
221
234
  });
222
235
 
223
- it('does not refetch data when switching layout', async () => {
224
- const user = userEvent.setup();
225
- const fetchDataSpy = vi.fn();
226
- render(
227
- <Table
228
- getRowId={({id}) => id}
229
- data={[{id: '🆔', firstName: 'first', lastName: 'last'}]}
230
- columns={columns}
231
- onMount={fetchDataSpy}
232
- onChange={fetchDataSpy}
233
- layouts={layouts}
234
- >
235
- <Table.Header data-testid="table-header" />
236
- </Table>,
237
- );
238
-
239
- await user.click(screen.getByRole('radio', {name: /layout 2/i}));
240
- await user.click(screen.getByRole('radio', {name: /layout 1/i}));
241
- expect(fetchDataSpy).toHaveBeenCalledTimes(1);
242
- });
243
-
244
236
  it('renders the layout specified in the initialState', () => {
245
- render(
246
- <Table
247
- getRowId={({id}) => id}
248
- data={[{id: '🆔', firstName: 'first', lastName: 'last'}]}
249
- columns={columns}
250
- layouts={layouts}
251
- initialState={{layout: 'Layout 2'}}
252
- >
253
- <Table.Header data-testid="table-header" />
254
- </Table>,
255
- );
237
+ const Fixture = () => {
238
+ const store = useTable<RowData>({initialState: {layout: 'Layout 2'}});
239
+ return (
240
+ <Table
241
+ store={store}
242
+ getRowId={({id}) => id}
243
+ data={[{id: '🆔', firstName: 'first', lastName: 'last'}]}
244
+ columns={columns}
245
+ layouts={layouts}
246
+ >
247
+ <Table.Header data-testid="table-header" />
248
+ </Table>
249
+ );
250
+ };
251
+ render(<Fixture />);
256
252
 
257
253
  expect(screen.getByRole('radio', {name: /layout 2/i})).toBeChecked();
258
254
  expect(screen.getByTestId('layout2-header')).toBeInTheDocument();
@@ -264,57 +260,26 @@ describe('Table', () => {
264
260
  });
265
261
 
266
262
  describe('when multi row selection is enabled', () => {
267
- it('calls the onRowSelectionChange prop when the row selection changes', async () => {
268
- const onRowSelectionChangeSpy = vi.fn();
269
- const user = userEvent.setup();
270
- render(
271
- <Table
272
- getRowId={({id}) => id}
273
- data={[
274
- {id: '🆔-1', firstName: 'John', lastName: 'Smith'},
275
- {id: '🆔-2', firstName: 'Jane', lastName: 'Doe'},
276
- ]}
277
- columns={columns}
278
- multiRowSelectionEnabled
279
- onRowSelectionChange={onRowSelectionChangeSpy}
280
- />,
281
- );
282
- await user.click(within(screen.getByRole('row', {name: /jane doe/i})).getByRole('checkbox'));
283
- expect(onRowSelectionChangeSpy).toHaveBeenCalledTimes(1);
284
- expect(onRowSelectionChangeSpy).toHaveBeenCalledWith([{id: '🆔-2', firstName: 'Jane', lastName: 'Doe'}]);
285
-
286
- onRowSelectionChangeSpy.mockClear();
287
-
288
- await user.click(within(screen.getByRole('row', {name: /john smith/i})).getByRole('checkbox'));
289
- expect(onRowSelectionChangeSpy).toHaveBeenCalledTimes(1);
290
- expect(onRowSelectionChangeSpy).toHaveBeenCalledWith([
291
- {id: '🆔-2', firstName: 'Jane', lastName: 'Doe'},
292
- {id: '🆔-1', firstName: 'John', lastName: 'Smith'},
293
- ]);
294
-
295
- onRowSelectionChangeSpy.mockClear();
296
-
297
- await user.click(screen.getByRole('checkbox', {name: /unselect all from this page/i}));
298
- expect(onRowSelectionChangeSpy).toHaveBeenCalledTimes(1);
299
- expect(onRowSelectionChangeSpy).toHaveBeenCalledWith([]);
300
- });
301
-
302
263
  it('does not clear the row selection when clicking outside the table', async () => {
303
264
  const user = userEvent.setup();
304
- render(
305
- <div>
306
- <div>I'm a header</div>
307
- <Table
308
- getRowId={({id}) => id}
309
- data={[
310
- {id: '🆔-1', firstName: 'first', lastName: 'last'},
311
- {id: '🆔-2', firstName: 'patate', lastName: 'king'},
312
- ]}
313
- columns={columns}
314
- multiRowSelectionEnabled
315
- />
316
- </div>,
317
- );
265
+ const Fixture = () => {
266
+ const store = useTable<RowData>({enableMultiRowSelection: true});
267
+ return (
268
+ <div>
269
+ <div>outside table</div>
270
+ <Table
271
+ store={store}
272
+ getRowId={({id}) => id}
273
+ data={[
274
+ {id: '🆔-1', firstName: 'first', lastName: 'last'},
275
+ {id: '🆔-2', firstName: 'patate', lastName: 'king'},
276
+ ]}
277
+ columns={columns}
278
+ />
279
+ </div>
280
+ );
281
+ };
282
+ render(<Fixture />);
318
283
 
319
284
  const row = screen.getByRole('row', {name: /patate king/i, selected: false});
320
285
 
@@ -324,26 +289,30 @@ describe('Table', () => {
324
289
 
325
290
  expect(screen.getByRole('row', {name: /patate king/i, selected: true})).toBeInTheDocument();
326
291
 
327
- await user.click(screen.getByText(/i'm a header/i));
292
+ await user.click(screen.getByText(/outside table/i));
328
293
 
329
294
  expect(screen.getByRole('row', {name: /patate king/i, selected: true})).toBeInTheDocument();
330
295
  });
331
296
 
332
297
  it('unselects all the selected rows when clicking on the the unselect button from the table header', async () => {
333
298
  const user = userEvent.setup();
334
- render(
335
- <Table
336
- getRowId={({id}) => id}
337
- data={[
338
- {id: '🆔-1', firstName: 'John', lastName: 'Smith'},
339
- {id: '🆔-2', firstName: 'Jane', lastName: 'Doe'},
340
- ]}
341
- columns={columns}
342
- multiRowSelectionEnabled
343
- >
344
- <Table.Header />
345
- </Table>,
346
- );
299
+ const Fixture = () => {
300
+ const store = useTable<RowData>({enableMultiRowSelection: true});
301
+ return (
302
+ <Table
303
+ store={store}
304
+ getRowId={({id}) => id}
305
+ data={[
306
+ {id: '🆔-1', firstName: 'John', lastName: 'Smith'},
307
+ {id: '🆔-2', firstName: 'Jane', lastName: 'Doe'},
308
+ ]}
309
+ columns={columns}
310
+ >
311
+ <Table.Header />
312
+ </Table>
313
+ );
314
+ };
315
+ render(<Fixture />);
347
316
 
348
317
  await user.click(screen.getByRole('checkbox', {name: /select all/i}));
349
318
  await user.click(screen.getByRole('button', {name: /2 selected/i}));
@@ -351,20 +320,27 @@ describe('Table', () => {
351
320
  });
352
321
 
353
322
  it('does not display number of selected rows if disableRowSelection is true', async () => {
354
- render(
355
- <Table
356
- getRowId={({id}) => id}
357
- data={[
358
- {id: '🆔-1', firstName: 'John', lastName: 'Smith'},
359
- {id: '🆔-2', firstName: 'Jane', lastName: 'Doe'},
360
- ]}
361
- columns={columns}
362
- multiRowSelectionEnabled
363
- initialState={{
323
+ const Fixture = () => {
324
+ const store = useTable<RowData>({
325
+ enableMultiRowSelection: true,
326
+ enableRowSelection: false,
327
+ initialState: {
364
328
  rowSelection: {'🆔-2': {id: '🆔-2', firstName: 'Jane', lastName: 'Doe'}},
365
- }}
366
- />,
367
- );
329
+ },
330
+ });
331
+ return (
332
+ <Table
333
+ store={store}
334
+ getRowId={({id}) => id}
335
+ data={[
336
+ {id: '🆔-1', firstName: 'John', lastName: 'Smith'},
337
+ {id: '🆔-2', firstName: 'Jane', lastName: 'Doe'},
338
+ ]}
339
+ columns={columns}
340
+ />
341
+ );
342
+ };
343
+ render(<Fixture />);
368
344
 
369
345
  expect(screen.queryByRole('button', {name: /1 selected/i})).not.toBeInTheDocument();
370
346
  });