@navikt/ds-react 8.9.0 → 8.10.0

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 (439) hide show
  1. package/cjs/alert/base-alert/content/BaseAlertContent.js +4 -1
  2. package/cjs/alert/base-alert/content/BaseAlertContent.js.map +1 -1
  3. package/cjs/data/drag-and-drop/drag-handler/DragAndDropDragHandler.d.ts +3 -0
  4. package/cjs/data/drag-and-drop/drag-handler/DragAndDropDragHandler.js +41 -20
  5. package/cjs/data/drag-and-drop/drag-handler/DragAndDropDragHandler.js.map +1 -1
  6. package/cjs/data/drag-and-drop/item/DragAndDropItem.d.ts +7 -2
  7. package/cjs/data/drag-and-drop/item/DragAndDropItem.js +6 -8
  8. package/cjs/data/drag-and-drop/item/DragAndDropItem.js.map +1 -1
  9. package/cjs/data/drag-and-drop/root/DragAndDrop.context.d.ts +2 -1
  10. package/cjs/data/drag-and-drop/root/DragAndDrop.context.js.map +1 -1
  11. package/cjs/data/drag-and-drop/root/DragAndDropRoot.d.ts +7 -30
  12. package/cjs/data/drag-and-drop/root/DragAndDropRoot.js +124 -65
  13. package/cjs/data/drag-and-drop/root/DragAndDropRoot.js.map +1 -1
  14. package/cjs/data/drag-and-drop/types.d.ts +4 -0
  15. package/cjs/data/table/base-cell/DataTableBaseCell.d.ts +46 -0
  16. package/cjs/data/table/base-cell/DataTableBaseCell.js +63 -0
  17. package/cjs/data/table/base-cell/DataTableBaseCell.js.map +1 -0
  18. package/cjs/data/table/column-header/DataTableColumnHeader.d.ts +32 -0
  19. package/cjs/data/table/column-header/DataTableColumnHeader.js +108 -0
  20. package/cjs/data/table/column-header/DataTableColumnHeader.js.map +1 -0
  21. package/cjs/data/table/column-header/useTableColumnResize.js.map +1 -0
  22. package/cjs/data/table/empty-state/DataTableEmptyState.d.ts +6 -2
  23. package/cjs/data/table/empty-state/DataTableEmptyState.js +2 -2
  24. package/cjs/data/table/empty-state/DataTableEmptyState.js.map +1 -1
  25. package/cjs/data/table/helpers/selection/getMultipleSelectProps.d.ts +10 -10
  26. package/cjs/data/table/helpers/selection/getMultipleSelectProps.js +29 -28
  27. package/cjs/data/table/helpers/selection/getMultipleSelectProps.js.map +1 -1
  28. package/cjs/data/table/helpers/selection/getSingleSelectProps.d.ts +7 -5
  29. package/cjs/data/table/helpers/selection/getSingleSelectProps.js +8 -9
  30. package/cjs/data/table/helpers/selection/getSingleSelectProps.js.map +1 -1
  31. package/cjs/data/table/helpers/selection/selection.types.d.ts +44 -21
  32. package/cjs/data/table/hooks/useColumnOptions.d.ts +19 -0
  33. package/cjs/data/table/hooks/useColumnOptions.js +19 -0
  34. package/cjs/data/table/hooks/useColumnOptions.js.map +1 -0
  35. package/cjs/data/table/hooks/useTableExpansion.d.ts +26 -0
  36. package/cjs/data/table/hooks/useTableExpansion.js +68 -0
  37. package/cjs/data/table/hooks/useTableExpansion.js.map +1 -0
  38. package/cjs/data/table/hooks/useTableKeyboardNav.d.ts +2 -1
  39. package/cjs/data/table/hooks/useTableKeyboardNav.js +3 -1
  40. package/cjs/data/table/hooks/useTableKeyboardNav.js.map +1 -1
  41. package/cjs/data/table/hooks/useTableSelection.d.ts +14 -7
  42. package/cjs/data/table/hooks/useTableSelection.js +40 -27
  43. package/cjs/data/table/hooks/useTableSelection.js.map +1 -1
  44. package/cjs/data/table/hooks/useTableSort.d.ts +37 -0
  45. package/cjs/data/table/hooks/useTableSort.js +49 -0
  46. package/cjs/data/table/hooks/useTableSort.js.map +1 -0
  47. package/cjs/data/table/loading-state/DataTableLoadingState.d.ts +6 -2
  48. package/cjs/data/table/loading-state/DataTableLoadingState.js +2 -2
  49. package/cjs/data/table/loading-state/DataTableLoadingState.js.map +1 -1
  50. package/cjs/data/table/root/DataTable.types.d.ts +55 -4
  51. package/cjs/data/table/root/DataTableAuto.d.ts +97 -1
  52. package/cjs/data/table/root/DataTableAuto.js +92 -41
  53. package/cjs/data/table/root/DataTableAuto.js.map +1 -1
  54. package/cjs/data/table/root/DataTableRoot.context.d.ts +22 -1
  55. package/cjs/data/table/root/DataTableRoot.context.js +7 -1
  56. package/cjs/data/table/root/DataTableRoot.context.js.map +1 -1
  57. package/cjs/data/table/root/DataTableRoot.d.ts +0 -6
  58. package/cjs/data/table/root/DataTableRoot.js +5 -4
  59. package/cjs/data/table/root/DataTableRoot.js.map +1 -1
  60. package/cjs/data/table/tbody/DataTableTbody.js +7 -1
  61. package/cjs/data/table/tbody/DataTableTbody.js.map +1 -1
  62. package/cjs/data/table/td/DataTableTd.d.ts +3 -19
  63. package/cjs/data/table/td/DataTableTd.js +3 -5
  64. package/cjs/data/table/td/DataTableTd.js.map +1 -1
  65. package/cjs/data/table/tfoot/DataTableTfoot.js +3 -1
  66. package/cjs/data/table/tfoot/DataTableTfoot.js.map +1 -1
  67. package/cjs/data/table/th/DataTableTh.d.ts +3 -44
  68. package/cjs/data/table/th/DataTableTh.js +3 -54
  69. package/cjs/data/table/th/DataTableTh.js.map +1 -1
  70. package/cjs/data/table/thead/DataTableThead.js +2 -2
  71. package/cjs/data/table/thead/DataTableThead.js.map +1 -1
  72. package/cjs/data/table/tr/DataTableTr.d.ts +8 -0
  73. package/cjs/data/table/tr/DataTableTr.js +131 -9
  74. package/cjs/data/table/tr/DataTableTr.js.map +1 -1
  75. package/cjs/data/token-filter/FilterChip.d.ts +10 -0
  76. package/cjs/data/token-filter/FilterChip.js +65 -0
  77. package/cjs/data/token-filter/FilterChip.js.map +1 -0
  78. package/cjs/data/token-filter/TokenFilter.js +3 -10
  79. package/cjs/data/token-filter/TokenFilter.js.map +1 -1
  80. package/cjs/date/datepicker/hooks/useRangeDatepicker.js +1 -1
  81. package/cjs/date/datepicker/hooks/useRangeDatepicker.js.map +1 -1
  82. package/cjs/date/datepicker/parts/DatePicker.DayButton.js +3 -1
  83. package/cjs/date/datepicker/parts/DatePicker.DayButton.js.map +1 -1
  84. package/cjs/date/datepicker/parts/DatePicker.RDP.d.ts +1 -1
  85. package/cjs/date/datepicker/parts/DatePicker.RDP.js +26 -11
  86. package/cjs/date/datepicker/parts/DatePicker.RDP.js.map +1 -1
  87. package/cjs/date/monthpicker/parts/MonthPicker.Button.js +7 -5
  88. package/cjs/date/monthpicker/parts/MonthPicker.Button.js.map +1 -1
  89. package/cjs/date/monthpicker/parts/MonthPicker.Standalone.d.ts +1 -1
  90. package/cjs/dialog/popup/DialogPopupInternal.js +1 -1
  91. package/cjs/dialog/popup/DialogPopupInternal.js.map +1 -1
  92. package/cjs/form/checkbox/Checkbox.js +19 -33
  93. package/cjs/form/checkbox/Checkbox.js.map +1 -1
  94. package/cjs/form/checkbox/CheckboxGroup.context.d.ts +6 -0
  95. package/cjs/form/checkbox/CheckboxGroup.context.js +6 -0
  96. package/cjs/form/checkbox/CheckboxGroup.context.js.map +1 -0
  97. package/cjs/form/checkbox/CheckboxGroup.d.ts +0 -6
  98. package/cjs/form/checkbox/CheckboxGroup.js +8 -8
  99. package/cjs/form/checkbox/CheckboxGroup.js.map +1 -1
  100. package/cjs/form/checkbox/checkbox-input/CheckboxInput.d.ts +21 -0
  101. package/cjs/form/checkbox/checkbox-input/CheckboxInput.js +65 -0
  102. package/cjs/form/checkbox/checkbox-input/CheckboxInput.js.map +1 -0
  103. package/cjs/form/checkbox/types.d.ts +1 -1
  104. package/cjs/form/checkbox/useCheckbox.js +2 -2
  105. package/cjs/form/checkbox/useCheckbox.js.map +1 -1
  106. package/cjs/form/combobox/ComboboxWrapper.js +1 -3
  107. package/cjs/form/combobox/ComboboxWrapper.js.map +1 -1
  108. package/cjs/form/error-summary/ErrorSummary.js +1 -3
  109. package/cjs/form/error-summary/ErrorSummary.js.map +1 -1
  110. package/cjs/form/fieldset/Fieldset.d.ts +0 -4
  111. package/cjs/form/fieldset/Fieldset.js +5 -9
  112. package/cjs/form/fieldset/Fieldset.js.map +1 -1
  113. package/cjs/form/fieldset/useFieldset.d.ts +5 -3
  114. package/cjs/form/fieldset/useFieldset.js +9 -4
  115. package/cjs/form/fieldset/useFieldset.js.map +1 -1
  116. package/cjs/form/radio/Radio.js +9 -7
  117. package/cjs/form/radio/Radio.js.map +1 -1
  118. package/cjs/form/radio/RadioGroup.context.d.ts +8 -0
  119. package/cjs/form/radio/RadioGroup.context.js +6 -0
  120. package/cjs/form/radio/RadioGroup.context.js.map +1 -0
  121. package/cjs/form/radio/RadioGroup.d.ts +0 -8
  122. package/cjs/form/radio/RadioGroup.js +10 -10
  123. package/cjs/form/radio/RadioGroup.js.map +1 -1
  124. package/cjs/form/radio/radio-input/RadioInput.d.ts +19 -0
  125. package/cjs/{data/table/thead/DataTableThead.context.js → form/radio/radio-input/RadioInput.js} +19 -9
  126. package/cjs/form/radio/radio-input/RadioInput.js.map +1 -0
  127. package/cjs/form/radio/useRadio.js +2 -2
  128. package/cjs/form/radio/useRadio.js.map +1 -1
  129. package/cjs/form/search/Search.js +1 -3
  130. package/cjs/form/search/Search.js.map +1 -1
  131. package/cjs/inline-message/root/InlineMessage.js +2 -5
  132. package/cjs/inline-message/root/InlineMessage.js.map +1 -1
  133. package/cjs/modal/Modal.js +1 -3
  134. package/cjs/modal/Modal.js.map +1 -1
  135. package/cjs/modal/ModalUtils.js +1 -1
  136. package/cjs/modal/ModalUtils.js.map +1 -1
  137. package/cjs/primitives/box/Box.d.ts +1 -1
  138. package/cjs/process/Process.js +1 -5
  139. package/cjs/process/Process.js.map +1 -1
  140. package/cjs/tabs/useTabs.js +3 -7
  141. package/cjs/tabs/useTabs.js.map +1 -1
  142. package/cjs/timeline/Timeline.js +25 -62
  143. package/cjs/timeline/Timeline.js.map +1 -1
  144. package/cjs/timeline/TimelineRow.js +10 -14
  145. package/cjs/timeline/TimelineRow.js.map +1 -1
  146. package/cjs/timeline/hooks/TimelineKeyboardNavProvider.d.ts +16 -0
  147. package/cjs/timeline/hooks/TimelineKeyboardNavProvider.js +179 -0
  148. package/cjs/timeline/hooks/TimelineKeyboardNavProvider.js.map +1 -0
  149. package/cjs/timeline/hooks/usePeriodContext.d.ts +0 -1
  150. package/cjs/timeline/hooks/usePeriodContext.js +0 -1
  151. package/cjs/timeline/hooks/usePeriodContext.js.map +1 -1
  152. package/cjs/timeline/hooks/useRowContext.d.ts +0 -1
  153. package/cjs/timeline/hooks/useRowContext.js +0 -1
  154. package/cjs/timeline/hooks/useRowContext.js.map +1 -1
  155. package/cjs/timeline/hooks/useTimelineContext.d.ts +0 -4
  156. package/cjs/timeline/hooks/useTimelineContext.js +0 -4
  157. package/cjs/timeline/hooks/useTimelineContext.js.map +1 -1
  158. package/cjs/timeline/period/ClickablePeriod.js +6 -20
  159. package/cjs/timeline/period/ClickablePeriod.js.map +1 -1
  160. package/cjs/timeline/period/NonClickablePeriod.js +1 -1
  161. package/cjs/timeline/period/NonClickablePeriod.js.map +1 -1
  162. package/cjs/timeline/pin/PinInternal.js +9 -10
  163. package/cjs/timeline/pin/PinInternal.js.map +1 -1
  164. package/cjs/toggle-group/useToggleGroup.js +1 -1
  165. package/cjs/toggle-group/useToggleGroup.js.map +1 -1
  166. package/cjs/utils/components/HighlightText/HighlightText.js +1 -4
  167. package/cjs/utils/components/HighlightText/HighlightText.js.map +1 -1
  168. package/cjs/utils/components/dismissablelayer/DismissableLayer.js +1 -1
  169. package/cjs/utils/components/dismissablelayer/DismissableLayer.js.map +1 -1
  170. package/cjs/utils/helpers/create-strict-context.js +1 -1
  171. package/cjs/utils/helpers/create-strict-context.js.map +1 -1
  172. package/cjs/utils/hooks/useEventCallback.js +1 -1
  173. package/cjs/utils/hooks/useEventCallback.js.map +1 -1
  174. package/cjs/utils/hooks/useMedia.js +1 -1
  175. package/cjs/utils/hooks/useMedia.js.map +1 -1
  176. package/esm/alert/base-alert/content/BaseAlertContent.js +4 -1
  177. package/esm/alert/base-alert/content/BaseAlertContent.js.map +1 -1
  178. package/esm/data/drag-and-drop/drag-handler/DragAndDropDragHandler.d.ts +3 -0
  179. package/esm/data/drag-and-drop/drag-handler/DragAndDropDragHandler.js +41 -20
  180. package/esm/data/drag-and-drop/drag-handler/DragAndDropDragHandler.js.map +1 -1
  181. package/esm/data/drag-and-drop/item/DragAndDropItem.d.ts +7 -2
  182. package/esm/data/drag-and-drop/item/DragAndDropItem.js +6 -8
  183. package/esm/data/drag-and-drop/item/DragAndDropItem.js.map +1 -1
  184. package/esm/data/drag-and-drop/root/DragAndDrop.context.d.ts +2 -1
  185. package/esm/data/drag-and-drop/root/DragAndDrop.context.js.map +1 -1
  186. package/esm/data/drag-and-drop/root/DragAndDropRoot.d.ts +7 -30
  187. package/esm/data/drag-and-drop/root/DragAndDropRoot.js +125 -66
  188. package/esm/data/drag-and-drop/root/DragAndDropRoot.js.map +1 -1
  189. package/esm/data/drag-and-drop/types.d.ts +4 -0
  190. package/esm/data/table/base-cell/DataTableBaseCell.d.ts +46 -0
  191. package/esm/data/table/base-cell/DataTableBaseCell.js +27 -0
  192. package/esm/data/table/base-cell/DataTableBaseCell.js.map +1 -0
  193. package/esm/data/table/column-header/DataTableColumnHeader.d.ts +32 -0
  194. package/esm/data/table/column-header/DataTableColumnHeader.js +72 -0
  195. package/esm/data/table/column-header/DataTableColumnHeader.js.map +1 -0
  196. package/esm/data/table/column-header/useTableColumnResize.js.map +1 -0
  197. package/esm/data/table/empty-state/DataTableEmptyState.d.ts +6 -2
  198. package/esm/data/table/empty-state/DataTableEmptyState.js +2 -2
  199. package/esm/data/table/empty-state/DataTableEmptyState.js.map +1 -1
  200. package/esm/data/table/helpers/selection/getMultipleSelectProps.d.ts +10 -10
  201. package/esm/data/table/helpers/selection/getMultipleSelectProps.js +29 -28
  202. package/esm/data/table/helpers/selection/getMultipleSelectProps.js.map +1 -1
  203. package/esm/data/table/helpers/selection/getSingleSelectProps.d.ts +7 -5
  204. package/esm/data/table/helpers/selection/getSingleSelectProps.js +8 -9
  205. package/esm/data/table/helpers/selection/getSingleSelectProps.js.map +1 -1
  206. package/esm/data/table/helpers/selection/selection.types.d.ts +44 -21
  207. package/esm/data/table/hooks/useColumnOptions.d.ts +19 -0
  208. package/esm/data/table/hooks/useColumnOptions.js +17 -0
  209. package/esm/data/table/hooks/useColumnOptions.js.map +1 -0
  210. package/esm/data/table/hooks/useTableExpansion.d.ts +26 -0
  211. package/esm/data/table/hooks/useTableExpansion.js +31 -0
  212. package/esm/data/table/hooks/useTableExpansion.js.map +1 -0
  213. package/esm/data/table/hooks/useTableKeyboardNav.d.ts +2 -1
  214. package/esm/data/table/hooks/useTableKeyboardNav.js +4 -2
  215. package/esm/data/table/hooks/useTableKeyboardNav.js.map +1 -1
  216. package/esm/data/table/hooks/useTableSelection.d.ts +14 -7
  217. package/esm/data/table/hooks/useTableSelection.js +40 -29
  218. package/esm/data/table/hooks/useTableSelection.js.map +1 -1
  219. package/esm/data/table/hooks/useTableSort.d.ts +37 -0
  220. package/esm/data/table/hooks/useTableSort.js +47 -0
  221. package/esm/data/table/hooks/useTableSort.js.map +1 -0
  222. package/esm/data/table/loading-state/DataTableLoadingState.d.ts +6 -2
  223. package/esm/data/table/loading-state/DataTableLoadingState.js +2 -2
  224. package/esm/data/table/loading-state/DataTableLoadingState.js.map +1 -1
  225. package/esm/data/table/root/DataTable.types.d.ts +55 -4
  226. package/esm/data/table/root/DataTableAuto.d.ts +97 -1
  227. package/esm/data/table/root/DataTableAuto.js +94 -43
  228. package/esm/data/table/root/DataTableAuto.js.map +1 -1
  229. package/esm/data/table/root/DataTableRoot.context.d.ts +22 -1
  230. package/esm/data/table/root/DataTableRoot.context.js +5 -1
  231. package/esm/data/table/root/DataTableRoot.context.js.map +1 -1
  232. package/esm/data/table/root/DataTableRoot.d.ts +0 -6
  233. package/esm/data/table/root/DataTableRoot.js +6 -5
  234. package/esm/data/table/root/DataTableRoot.js.map +1 -1
  235. package/esm/data/table/tbody/DataTableTbody.js +8 -2
  236. package/esm/data/table/tbody/DataTableTbody.js.map +1 -1
  237. package/esm/data/table/td/DataTableTd.d.ts +3 -19
  238. package/esm/data/table/td/DataTableTd.js +3 -5
  239. package/esm/data/table/td/DataTableTd.js.map +1 -1
  240. package/esm/data/table/tfoot/DataTableTfoot.js +3 -1
  241. package/esm/data/table/tfoot/DataTableTfoot.js.map +1 -1
  242. package/esm/data/table/th/DataTableTh.d.ts +3 -44
  243. package/esm/data/table/th/DataTableTh.js +4 -55
  244. package/esm/data/table/th/DataTableTh.js.map +1 -1
  245. package/esm/data/table/thead/DataTableThead.js +2 -2
  246. package/esm/data/table/thead/DataTableThead.js.map +1 -1
  247. package/esm/data/table/tr/DataTableTr.d.ts +8 -0
  248. package/esm/data/table/tr/DataTableTr.js +134 -12
  249. package/esm/data/table/tr/DataTableTr.js.map +1 -1
  250. package/esm/data/token-filter/FilterChip.d.ts +10 -0
  251. package/esm/data/token-filter/FilterChip.js +30 -0
  252. package/esm/data/token-filter/FilterChip.js.map +1 -0
  253. package/esm/data/token-filter/TokenFilter.js +3 -10
  254. package/esm/data/token-filter/TokenFilter.js.map +1 -1
  255. package/esm/date/datepicker/hooks/useRangeDatepicker.js +1 -1
  256. package/esm/date/datepicker/hooks/useRangeDatepicker.js.map +1 -1
  257. package/esm/date/datepicker/parts/DatePicker.DayButton.js +3 -1
  258. package/esm/date/datepicker/parts/DatePicker.DayButton.js.map +1 -1
  259. package/esm/date/datepicker/parts/DatePicker.RDP.d.ts +1 -1
  260. package/esm/date/datepicker/parts/DatePicker.RDP.js +27 -12
  261. package/esm/date/datepicker/parts/DatePicker.RDP.js.map +1 -1
  262. package/esm/date/monthpicker/parts/MonthPicker.Button.js +7 -5
  263. package/esm/date/monthpicker/parts/MonthPicker.Button.js.map +1 -1
  264. package/esm/date/monthpicker/parts/MonthPicker.Standalone.d.ts +1 -1
  265. package/esm/dialog/popup/DialogPopupInternal.js +1 -1
  266. package/esm/dialog/popup/DialogPopupInternal.js.map +1 -1
  267. package/esm/form/checkbox/Checkbox.js +19 -33
  268. package/esm/form/checkbox/Checkbox.js.map +1 -1
  269. package/esm/form/checkbox/CheckboxGroup.context.d.ts +6 -0
  270. package/esm/form/checkbox/CheckboxGroup.context.js +3 -0
  271. package/esm/form/checkbox/CheckboxGroup.context.js.map +1 -0
  272. package/esm/form/checkbox/CheckboxGroup.d.ts +0 -6
  273. package/esm/form/checkbox/CheckboxGroup.js +8 -8
  274. package/esm/form/checkbox/CheckboxGroup.js.map +1 -1
  275. package/esm/form/checkbox/checkbox-input/CheckboxInput.d.ts +21 -0
  276. package/esm/form/checkbox/checkbox-input/CheckboxInput.js +29 -0
  277. package/esm/form/checkbox/checkbox-input/CheckboxInput.js.map +1 -0
  278. package/esm/form/checkbox/types.d.ts +1 -1
  279. package/esm/form/checkbox/useCheckbox.js +1 -1
  280. package/esm/form/checkbox/useCheckbox.js.map +1 -1
  281. package/esm/form/combobox/ComboboxWrapper.js +1 -3
  282. package/esm/form/combobox/ComboboxWrapper.js.map +1 -1
  283. package/esm/form/error-summary/ErrorSummary.js +1 -3
  284. package/esm/form/error-summary/ErrorSummary.js.map +1 -1
  285. package/esm/form/fieldset/Fieldset.d.ts +0 -4
  286. package/esm/form/fieldset/Fieldset.js +5 -9
  287. package/esm/form/fieldset/Fieldset.js.map +1 -1
  288. package/esm/form/fieldset/useFieldset.d.ts +5 -3
  289. package/esm/form/fieldset/useFieldset.js +10 -5
  290. package/esm/form/fieldset/useFieldset.js.map +1 -1
  291. package/esm/form/radio/Radio.js +9 -7
  292. package/esm/form/radio/Radio.js.map +1 -1
  293. package/esm/form/radio/RadioGroup.context.d.ts +8 -0
  294. package/esm/form/radio/RadioGroup.context.js +3 -0
  295. package/esm/form/radio/RadioGroup.context.js.map +1 -0
  296. package/esm/form/radio/RadioGroup.d.ts +0 -8
  297. package/esm/form/radio/RadioGroup.js +9 -9
  298. package/esm/form/radio/RadioGroup.js.map +1 -1
  299. package/esm/form/radio/radio-input/RadioInput.d.ts +19 -0
  300. package/esm/form/radio/radio-input/RadioInput.js +19 -0
  301. package/esm/form/radio/radio-input/RadioInput.js.map +1 -0
  302. package/esm/form/radio/useRadio.js +1 -1
  303. package/esm/form/radio/useRadio.js.map +1 -1
  304. package/esm/form/search/Search.js +1 -3
  305. package/esm/form/search/Search.js.map +1 -1
  306. package/esm/inline-message/root/InlineMessage.js +2 -5
  307. package/esm/inline-message/root/InlineMessage.js.map +1 -1
  308. package/esm/modal/Modal.js +1 -3
  309. package/esm/modal/Modal.js.map +1 -1
  310. package/esm/modal/ModalUtils.js +1 -1
  311. package/esm/modal/ModalUtils.js.map +1 -1
  312. package/esm/primitives/box/Box.d.ts +1 -1
  313. package/esm/process/Process.js +1 -5
  314. package/esm/process/Process.js.map +1 -1
  315. package/esm/tabs/useTabs.js +3 -7
  316. package/esm/tabs/useTabs.js.map +1 -1
  317. package/esm/timeline/Timeline.js +26 -63
  318. package/esm/timeline/Timeline.js.map +1 -1
  319. package/esm/timeline/TimelineRow.js +10 -14
  320. package/esm/timeline/TimelineRow.js.map +1 -1
  321. package/esm/timeline/hooks/TimelineKeyboardNavProvider.d.ts +16 -0
  322. package/esm/timeline/hooks/TimelineKeyboardNavProvider.js +141 -0
  323. package/esm/timeline/hooks/TimelineKeyboardNavProvider.js.map +1 -0
  324. package/esm/timeline/hooks/usePeriodContext.d.ts +0 -1
  325. package/esm/timeline/hooks/usePeriodContext.js +0 -1
  326. package/esm/timeline/hooks/usePeriodContext.js.map +1 -1
  327. package/esm/timeline/hooks/useRowContext.d.ts +0 -1
  328. package/esm/timeline/hooks/useRowContext.js +0 -1
  329. package/esm/timeline/hooks/useRowContext.js.map +1 -1
  330. package/esm/timeline/hooks/useTimelineContext.d.ts +0 -4
  331. package/esm/timeline/hooks/useTimelineContext.js +0 -4
  332. package/esm/timeline/hooks/useTimelineContext.js.map +1 -1
  333. package/esm/timeline/period/ClickablePeriod.js +7 -21
  334. package/esm/timeline/period/ClickablePeriod.js.map +1 -1
  335. package/esm/timeline/period/NonClickablePeriod.js +1 -1
  336. package/esm/timeline/period/NonClickablePeriod.js.map +1 -1
  337. package/esm/timeline/pin/PinInternal.js +10 -11
  338. package/esm/timeline/pin/PinInternal.js.map +1 -1
  339. package/esm/toggle-group/useToggleGroup.js +1 -1
  340. package/esm/toggle-group/useToggleGroup.js.map +1 -1
  341. package/esm/utils/components/HighlightText/HighlightText.js +1 -4
  342. package/esm/utils/components/HighlightText/HighlightText.js.map +1 -1
  343. package/esm/utils/components/dismissablelayer/DismissableLayer.js +1 -1
  344. package/esm/utils/components/dismissablelayer/DismissableLayer.js.map +1 -1
  345. package/esm/utils/helpers/create-strict-context.js +1 -1
  346. package/esm/utils/helpers/create-strict-context.js.map +1 -1
  347. package/esm/utils/hooks/useEventCallback.js +1 -1
  348. package/esm/utils/hooks/useEventCallback.js.map +1 -1
  349. package/esm/utils/hooks/useMedia.js +1 -1
  350. package/esm/utils/hooks/useMedia.js.map +1 -1
  351. package/package.json +9 -7
  352. package/src/alert/base-alert/content/BaseAlertContent.tsx +7 -2
  353. package/src/data/drag-and-drop/drag-handler/DragAndDropDragHandler.tsx +73 -29
  354. package/src/data/drag-and-drop/item/DragAndDropItem.tsx +28 -18
  355. package/src/data/drag-and-drop/root/DragAndDrop.context.tsx +4 -2
  356. package/src/data/drag-and-drop/root/DragAndDropRoot.tsx +303 -209
  357. package/src/data/drag-and-drop/types.ts +5 -0
  358. package/src/data/table/base-cell/DataTableBaseCell.tsx +92 -0
  359. package/src/data/table/column-header/DataTableColumnHeader.tsx +180 -0
  360. package/src/data/table/empty-state/DataTableEmptyState.tsx +5 -3
  361. package/src/data/table/helpers/selection/getMultipleSelectProps.ts +49 -45
  362. package/src/data/table/helpers/selection/getSingleSelectProps.ts +15 -13
  363. package/src/data/table/helpers/selection/selection.types.ts +46 -21
  364. package/src/data/table/hooks/__tests__/useTableSelection.test.ts +93 -56
  365. package/src/data/table/hooks/useColumnOptions.ts +48 -0
  366. package/src/data/table/hooks/useTableExpansion.tsx +100 -0
  367. package/src/data/table/hooks/useTableKeyboardNav.ts +7 -5
  368. package/src/data/table/hooks/useTableSelection.ts +77 -46
  369. package/src/data/table/hooks/useTableSort.ts +103 -0
  370. package/src/data/table/loading-state/DataTableLoadingState.tsx +5 -3
  371. package/src/data/table/root/DataTable.types.ts +64 -5
  372. package/src/data/table/root/DataTableAuto.tsx +383 -95
  373. package/src/data/table/root/DataTableRoot.context.ts +30 -1
  374. package/src/data/table/root/DataTableRoot.tsx +14 -11
  375. package/src/data/table/tbody/DataTableTbody.tsx +17 -6
  376. package/src/data/table/td/DataTableTd.tsx +10 -33
  377. package/src/data/table/tfoot/DataTableTfoot.tsx +10 -7
  378. package/src/data/table/th/DataTableTh.tsx +11 -172
  379. package/src/data/table/thead/DataTableThead.tsx +3 -3
  380. package/src/data/table/tr/DataTableTr.tsx +300 -11
  381. package/src/data/token-filter/FilterChip.tsx +100 -0
  382. package/src/data/token-filter/TokenFilter.tsx +8 -24
  383. package/src/date/datepicker/hooks/useRangeDatepicker.tsx +1 -1
  384. package/src/date/datepicker/parts/DatePicker.DayButton.tsx +2 -1
  385. package/src/date/datepicker/parts/DatePicker.RDP.tsx +34 -15
  386. package/src/date/monthpicker/parts/MonthPicker.Button.tsx +11 -9
  387. package/src/date/monthpicker/parts/MonthPicker.Standalone.tsx +1 -1
  388. package/src/dialog/popup/DialogPopupInternal.tsx +1 -1
  389. package/src/form/checkbox/Checkbox.tsx +37 -64
  390. package/src/form/checkbox/CheckboxGroup.context.ts +10 -0
  391. package/src/form/checkbox/CheckboxGroup.tsx +18 -28
  392. package/src/form/checkbox/checkbox-input/CheckboxInput.tsx +69 -0
  393. package/src/form/checkbox/types.ts +1 -1
  394. package/src/form/checkbox/useCheckbox.ts +1 -1
  395. package/src/form/fieldset/Fieldset.tsx +8 -14
  396. package/src/form/fieldset/useFieldset.ts +13 -6
  397. package/src/form/radio/Radio.tsx +43 -38
  398. package/src/form/radio/RadioGroup.context.ts +13 -0
  399. package/src/form/radio/RadioGroup.tsx +22 -31
  400. package/src/form/radio/radio-input/RadioInput.tsx +32 -0
  401. package/src/form/radio/useRadio.ts +1 -1
  402. package/src/inline-message/root/InlineMessage.tsx +3 -13
  403. package/src/modal/ModalUtils.ts +1 -1
  404. package/src/primitives/box/Box.tsx +1 -1
  405. package/src/tabs/useTabs.ts +3 -7
  406. package/src/timeline/Timeline.tsx +62 -91
  407. package/src/timeline/TimelineRow.tsx +19 -17
  408. package/src/timeline/hooks/TimelineKeyboardNavProvider.tsx +237 -0
  409. package/src/timeline/hooks/usePeriodContext.tsx +0 -2
  410. package/src/timeline/hooks/useRowContext.tsx +0 -2
  411. package/src/timeline/hooks/useTimelineContext.tsx +0 -8
  412. package/src/timeline/period/ClickablePeriod.tsx +8 -19
  413. package/src/timeline/period/NonClickablePeriod.tsx +2 -0
  414. package/src/timeline/pin/PinInternal.tsx +10 -13
  415. package/src/toggle-group/useToggleGroup.ts +1 -1
  416. package/src/utils/components/dismissablelayer/DismissableLayer.tsx +1 -1
  417. package/src/utils/helpers/create-strict-context.tsx +1 -1
  418. package/src/utils/hooks/useEventCallback.ts +1 -1
  419. package/src/utils/hooks/useMedia.ts +1 -1
  420. package/cjs/data/table/th/DataTableThActions.d.ts +0 -5
  421. package/cjs/data/table/th/DataTableThActions.js +0 -23
  422. package/cjs/data/table/th/DataTableThActions.js.map +0 -1
  423. package/cjs/data/table/th/useTableColumnResize.js.map +0 -1
  424. package/cjs/data/table/thead/DataTableThead.context.d.ts +0 -4
  425. package/cjs/data/table/thead/DataTableThead.context.js.map +0 -1
  426. package/esm/data/table/th/DataTableThActions.d.ts +0 -5
  427. package/esm/data/table/th/DataTableThActions.js +0 -18
  428. package/esm/data/table/th/DataTableThActions.js.map +0 -1
  429. package/esm/data/table/th/useTableColumnResize.js.map +0 -1
  430. package/esm/data/table/thead/DataTableThead.context.d.ts +0 -4
  431. package/esm/data/table/thead/DataTableThead.context.js +0 -8
  432. package/esm/data/table/thead/DataTableThead.context.js.map +0 -1
  433. package/src/data/table/th/DataTableThActions.tsx +0 -32
  434. package/src/data/table/thead/DataTableThead.context.ts +0 -10
  435. /package/cjs/data/table/{th → column-header}/useTableColumnResize.d.ts +0 -0
  436. /package/cjs/data/table/{th → column-header}/useTableColumnResize.js +0 -0
  437. /package/esm/data/table/{th → column-header}/useTableColumnResize.d.ts +0 -0
  438. /package/esm/data/table/{th → column-header}/useTableColumnResize.js +0 -0
  439. /package/src/data/table/{th → column-header}/useTableColumnResize.ts +0 -0
@@ -0,0 +1,180 @@
1
+ import React, { forwardRef, useState } from "react";
2
+ import {
3
+ ArrowsUpDownIcon,
4
+ CaretLeftCircleFillIcon,
5
+ CaretRightCircleFillIcon,
6
+ SortDownIcon,
7
+ SortUpIcon,
8
+ } from "@navikt/aksel-icons";
9
+ import { cl } from "../../../utils/helpers";
10
+ import { useMergeRefs } from "../../../utils/hooks";
11
+ import {
12
+ DataTableBaseCell,
13
+ type DataTableBaseCellProps,
14
+ } from "../base-cell/DataTableBaseCell";
15
+ import type { SortDirection } from "../root/DataTable.types";
16
+ import { type ResizeProps, useTableColumnResize } from "./useTableColumnResize";
17
+
18
+ interface DataTableColumnHeaderProps
19
+ extends ResizeProps, DataTableBaseCellProps {
20
+ resizeHandler?: (
21
+ event:
22
+ | React.MouseEvent<HTMLButtonElement>
23
+ | React.TouchEvent<HTMLButtonElement>,
24
+ ) => void;
25
+ /**
26
+ * Makes the column header sortable. The entire header cell content becomes
27
+ * a clickable button when true.
28
+ */
29
+ sortable?: boolean;
30
+ /**
31
+ * Current sort direction. Only relevant when `sortable` is true.
32
+ * Uses values matching the `aria-sort` attribute directly.
33
+ * @default "none"
34
+ */
35
+ sortDirection?: SortDirection;
36
+ /**
37
+ * Called when the user clicks the sortable header.
38
+ * The consumer is responsible for determining and setting the next sort state.
39
+ */
40
+ onSortClick?: (event: React.MouseEvent<HTMLElement>) => void;
41
+ }
42
+
43
+ const SORT_ICON: Record<SortDirection, React.ElementType | null> = {
44
+ asc: SortUpIcon,
45
+ desc: SortDownIcon,
46
+ none: ArrowsUpDownIcon,
47
+ };
48
+
49
+ /**
50
+ * TODO:
51
+ * - Plan for pinning: Move it into "settings" dialog like here: https://cloudscape.design/examples/react/table.html
52
+ * - Keyboard-nav breaks in headers now because of the resize-handles.
53
+ * Toggling `data-block-keyboard-nav` does not work since the created "grid" does not update when toggling this attribute.
54
+ */
55
+ const DataTableColumnHeader = forwardRef<
56
+ HTMLTableCellElement,
57
+ DataTableColumnHeaderProps
58
+ >(
59
+ (
60
+ {
61
+ className,
62
+ children,
63
+ sortable = false,
64
+ sortDirection = "none",
65
+ onSortClick,
66
+ style,
67
+ width,
68
+ minWidth,
69
+ maxWidth,
70
+ onWidthChange,
71
+ defaultWidth,
72
+ colSpan,
73
+ rowSpan,
74
+ UNSAFE_isSelection,
75
+ ...rest
76
+ },
77
+ forwardedRef,
78
+ ) => {
79
+ const [isOverflowing, setIsOverflowing] = React.useState(false);
80
+ const contentRef = React.useRef<HTMLDivElement>(null);
81
+ const [thRefState, setThRefState] = useState<HTMLTableCellElement | null>(
82
+ null,
83
+ );
84
+ const mergedRef = useMergeRefs(forwardedRef, setThRefState);
85
+
86
+ const resizeResult = useTableColumnResize({
87
+ ref: thRefState,
88
+ width,
89
+ defaultWidth,
90
+ minWidth,
91
+ maxWidth,
92
+ onWidthChange,
93
+ style,
94
+ colSpan,
95
+ });
96
+
97
+ const SortIcon = sortable ? SORT_ICON[sortDirection] : null;
98
+
99
+ return (
100
+ <DataTableBaseCell
101
+ as="th"
102
+ {...rest}
103
+ ref={mergedRef}
104
+ className={cl("aksel-data-table__column-header", className)}
105
+ data-sortable={sortable}
106
+ style={resizeResult.style}
107
+ aria-sort={sortable ? getAriaSort(sortDirection) : undefined}
108
+ onPointerEnter={() => {
109
+ const el = contentRef.current;
110
+ setIsOverflowing(el ? el.scrollWidth > el.offsetWidth : false);
111
+ console.info("is overflowing", isOverflowing);
112
+ }}
113
+ onPointerLeave={() => setIsOverflowing(false)}
114
+ UNSAFE_isSelection={UNSAFE_isSelection}
115
+ colSpan={colSpan}
116
+ rowSpan={rowSpan}
117
+ >
118
+ {sortable ? (
119
+ <button
120
+ className="aksel-data-table__th-sort-button"
121
+ onClick={onSortClick}
122
+ >
123
+ <div ref={contentRef} className="aksel-data-table__th-content">
124
+ {children}
125
+ </div>
126
+ {SortIcon && (
127
+ <SortIcon
128
+ aria-hidden
129
+ data-sort-direction={sortDirection}
130
+ className="aksel-data-table__th-sort-icon"
131
+ fontSize="1.25rem"
132
+ />
133
+ )}
134
+ </button>
135
+ ) : (
136
+ <div
137
+ ref={contentRef}
138
+ className={cl({
139
+ "aksel-data-table__th-content": !UNSAFE_isSelection,
140
+ })}
141
+ >
142
+ {children}
143
+ </div>
144
+ )}
145
+
146
+ {resizeResult.enabled && !UNSAFE_isSelection && (
147
+ <button
148
+ {...resizeResult.resizeHandlerProps}
149
+ className="aksel-data-table__th-resize-handle"
150
+ data-active={resizeResult.isResizingWithKeyboard}
151
+ data-block-keyboard-nav
152
+ >
153
+ {resizeResult.isResizingWithKeyboard && (
154
+ <>
155
+ <span className="aksel-data-table__th-resize-handle-indicator aksel-data-table__th-resize-handle-indicator--start">
156
+ <CaretLeftCircleFillIcon aria-hidden fontSize="1.5rem" />
157
+ </span>
158
+ <span className="aksel-data-table__th-resize-handle-indicator aksel-data-table__th-resize-handle-indicator--end">
159
+ <CaretRightCircleFillIcon aria-hidden fontSize="1.5rem" />
160
+ </span>
161
+ </>
162
+ )}
163
+ </button>
164
+ )}
165
+ </DataTableBaseCell>
166
+ );
167
+ },
168
+ );
169
+
170
+ function getAriaSort(
171
+ sortDirection: SortDirection | undefined,
172
+ ): "ascending" | "descending" | "none" | undefined {
173
+ if (sortDirection === "asc") return "ascending";
174
+ if (sortDirection === "desc") return "descending";
175
+ if (sortDirection === "none") return "none";
176
+ return undefined;
177
+ }
178
+
179
+ export { DataTableColumnHeader };
180
+ export type { DataTableColumnHeaderProps };
@@ -1,15 +1,17 @@
1
1
  import React, { forwardRef } from "react";
2
2
  import { cl } from "../../../utils/helpers";
3
3
 
4
- type DataTableEmptyStateProps = React.HTMLAttributes<HTMLDivElement>;
4
+ type DataTableEmptyStateProps = React.HTMLAttributes<HTMLDivElement> & {
5
+ colSpan?: number;
6
+ };
5
7
 
6
8
  const DataTableEmptyState = forwardRef<
7
9
  HTMLDivElement,
8
10
  DataTableEmptyStateProps
9
- >(({ className, children, ...rest }, forwardedRef) => {
11
+ >(({ className, children, colSpan = 999, ...rest }, forwardedRef) => {
10
12
  return (
11
13
  <tr>
12
- <td colSpan={999}>
14
+ <td colSpan={colSpan}>
13
15
  <div
14
16
  {...rest}
15
17
  ref={forwardedRef}
@@ -1,69 +1,73 @@
1
- import type { CheckboxProps } from "../../../../form/checkbox/types";
2
- import type { SelectionT } from "./selection.types";
1
+ import type { CheckboxInputProps } from "../../../../form/checkbox/checkbox-input/CheckboxInput";
3
2
 
4
3
  type GetMultipleSelectPropsArgs = {
5
- selectedKeys: SelectionT;
6
- setSelectedKeys: (keys: SelectionT) => void;
7
- disabledKeys: (string | number)[];
8
- allKeys: (string | number)[];
9
- totalCount: number;
4
+ selectedKeysSet: Set<string | number>;
5
+ selectedKeys: (string | number)[];
6
+ setSelectedKeys: (keys: (string | number)[]) => void;
7
+ disabledKeysSet: Set<string | number>;
8
+ allRowKeys: (string | number)[];
10
9
  };
11
10
 
12
11
  function getMultipleSelectProps({
12
+ selectedKeysSet,
13
13
  selectedKeys,
14
14
  setSelectedKeys,
15
- disabledKeys,
16
- allKeys,
17
- totalCount,
15
+ disabledKeysSet,
16
+ allRowKeys,
18
17
  }: GetMultipleSelectPropsArgs) {
19
- const handleToggleAll = () => {
20
- const allSelected =
21
- selectedKeys === "all" ||
22
- (Array.isArray(selectedKeys) && selectedKeys.length === totalCount);
18
+ const allRowKeysSet = new Set(allRowKeys);
19
+ const selectableKeys = allRowKeys.filter((k) => !disabledKeysSet.has(k));
20
+
21
+ const selectedSelectableCount = selectableKeys.filter((k) =>
22
+ selectedKeysSet.has(k),
23
+ ).length;
24
+
25
+ const allSelectableSelected =
26
+ selectableKeys.length > 0 &&
27
+ selectedSelectableCount === selectableKeys.length;
23
28
 
24
- setSelectedKeys(allSelected ? [] : allKeys);
29
+ const indeterminate =
30
+ selectedSelectableCount > 0 &&
31
+ selectedSelectableCount < selectableKeys.length;
32
+
33
+ const selectedKeysNotInView = selectedKeys.filter(
34
+ (k) => !allRowKeysSet.has(k),
35
+ );
36
+ const disabledSelected = selectedKeys.filter((k) => disabledKeysSet.has(k));
37
+ const preservedKeys = [...selectedKeysNotInView, ...disabledSelected];
38
+
39
+ const handleToggleAll = () => {
40
+ if (allSelectableSelected) {
41
+ setSelectedKeys(preservedKeys);
42
+ } else {
43
+ setSelectedKeys([...new Set([...preservedKeys, ...selectableKeys])]);
44
+ }
25
45
  };
26
46
 
27
47
  const handleToggleRow = (key: string | number) => {
28
- if (selectedKeys === "all") {
29
- setSelectedKeys(allKeys.filter((id) => id !== key));
30
- } else if (selectedKeys.includes(key)) {
48
+ if (disabledKeysSet.has(key)) {
49
+ return;
50
+ }
51
+ if (selectedKeysSet.has(key)) {
31
52
  setSelectedKeys(selectedKeys.filter((k) => k !== key));
32
53
  } else {
33
54
  setSelectedKeys([...selectedKeys, key]);
34
55
  }
35
56
  };
36
57
 
37
- const isChecked = (key: string | number) =>
38
- selectedKeys === "all" ||
39
- (Array.isArray(selectedKeys) && selectedKeys.includes(key));
40
-
41
58
  return {
42
- getTheadCheckboxProps: (): CheckboxProps => {
43
- const indeterminate =
44
- Array.isArray(selectedKeys) &&
45
- selectedKeys.length > 0 &&
46
- selectedKeys.length < totalCount;
47
-
48
- return {
49
- children: "Select all rows",
50
- onChange: handleToggleAll,
51
- checked:
52
- (selectedKeys === "all" ||
53
- (Array.isArray(selectedKeys) && selectedKeys.length > 0)) &&
54
- !indeterminate,
55
- indeterminate,
56
- disabled: disabledKeys.length === totalCount,
57
- hideLabel: true,
58
- };
59
- },
60
- getRowCheckboxProps: (key: string | number): CheckboxProps => ({
61
- children: `Select row with id ${key}`,
59
+ getTheadCheckboxProps: (): CheckboxInputProps => ({
60
+ onChange: handleToggleAll,
61
+ checked: allSelectableSelected,
62
+ indeterminate,
63
+ disabled: selectableKeys.length === 0,
64
+ }),
65
+ getRowCheckboxProps: (key: string | number): CheckboxInputProps => ({
62
66
  onChange: () => handleToggleRow(key),
63
- checked: isChecked(key),
64
- disabled: disabledKeys.includes(key),
65
- hideLabel: true,
67
+ checked: selectedKeysSet.has(key),
68
+ disabled: disabledKeysSet.has(key),
66
69
  }),
70
+ toggleSelection: handleToggleRow,
67
71
  };
68
72
  }
69
73
 
@@ -1,32 +1,34 @@
1
- import type { RadioProps } from "../../../../form/radio/types";
1
+ import type { RadioInputProps } from "../../../../form/radio/radio-input/RadioInput";
2
2
 
3
3
  type GetSingleSelectPropsArgs = {
4
- selectedKeys: (string | number)[];
4
+ selectedKeysSet: Set<string | number>;
5
5
  setSelectedKeys: (keys: (string | number)[]) => void;
6
- disabledKeys: (string | number)[];
6
+ disabledKeysSet: Set<string | number>;
7
+ name: string;
7
8
  };
8
9
 
9
10
  function getSingleSelectProps({
10
- selectedKeys,
11
+ selectedKeysSet,
11
12
  setSelectedKeys,
12
- disabledKeys,
13
+ disabledKeysSet,
14
+ name,
13
15
  }: GetSingleSelectPropsArgs) {
14
16
  const handleSelectionChange = (key: string | number) => {
15
- if (selectedKeys.includes(key)) {
16
- setSelectedKeys([]);
17
- } else {
18
- setSelectedKeys([key]);
17
+ if (disabledKeysSet.has(key)) {
18
+ return;
19
19
  }
20
+ setSelectedKeys([key]);
20
21
  };
21
22
 
22
23
  return {
23
- getRowRadioProps: (key: string | number): RadioProps => ({
24
- children: `Select row with id ${key}`,
25
- checked: selectedKeys.includes(key),
24
+ getRowRadioProps: (key: string | number): RadioInputProps => ({
25
+ checked: selectedKeysSet.has(key),
26
26
  onChange: () => handleSelectionChange(key),
27
- disabled: disabledKeys.includes(key),
27
+ disabled: disabledKeysSet.has(key),
28
28
  value: key,
29
+ name,
29
30
  }),
31
+ toggleSelection: handleSelectionChange,
30
32
  };
31
33
  }
32
34
 
@@ -1,7 +1,7 @@
1
- import type { CheckboxProps } from "../../../../form/checkbox/types";
2
- import type { RadioProps } from "../../../../form/radio/types";
1
+ import type { CheckboxInputProps } from "../../../../form/checkbox/checkbox-input/CheckboxInput";
2
+ import type { RadioInputProps } from "../../../../form/radio/radio-input/RadioInput";
3
3
 
4
- type SelectionT = (string | number)[] | "all";
4
+ type SelectedKeysT = (string | number)[];
5
5
 
6
6
  type SelectionProps = {
7
7
  /**
@@ -14,43 +14,68 @@ type SelectionProps = {
14
14
  * @default "none"
15
15
  */
16
16
  selectionMode?: "none" | "single" | "multiple";
17
- selectedKeys?: SelectionT;
18
- defaultSelectedKeys?: SelectionT;
19
- onSelectionChange?: (keys: SelectionT) => void;
20
- disabledKeys?: (string | number)[];
17
+ /**
18
+ * Controlled selected keys. Should be used in conjunction with `onSelectionChange`.
19
+ */
20
+ selectedKeys?: SelectedKeysT;
21
+ /**
22
+ * Default selected keys when using uncontrolled selection. Should not be used together with `selectedKeys`.
23
+ */
24
+ defaultSelectedKeys?: SelectedKeysT;
25
+ /**
26
+ * Callback with array of selected keys.
27
+ */
28
+ onSelectionChange?: (keys: SelectedKeysT) => void;
29
+ /**
30
+ * Keys that should be disabled for selection. These keys will not be selectable and will be styled as disabled.
31
+ *
32
+ *
33
+ * TODO: Consider making this optionally a callback with (rowData:T) => boolean, to allow for more dynamic disabling of selection based on row data.
34
+ */
35
+ disabledSelectionKeys?: SelectedKeysT;
36
+ /**
37
+ * If true, stops clicking a row from toggling its selection state. This can be used if you want to only allow selection through the checkboxes/radios, and not have the entire row be clickable for selection.
38
+ *
39
+ * @default false
40
+ */
41
+ disableRowSelectionOnClick?: boolean;
21
42
  };
22
43
 
23
44
  type NoneSelection = {
24
45
  selectionMode: "none";
25
- allKeys: (string | number)[];
26
- selectedKeys: (string | number)[];
27
- disabledKeys: (string | number)[];
46
+ selectedKeys: SelectedKeysT;
47
+ disabledSelectionKeys: SelectedKeysT;
28
48
  };
29
49
 
30
50
  type SingleSelection = {
31
51
  selectionMode: "single";
32
- allKeys: (string | number)[];
33
- selectedKeys: (string | number)[];
34
- disabledKeys: (string | number)[];
35
- getRowRadioProps: (key: string | number) => RadioProps;
52
+ selectedKeys: SelectedKeysT;
53
+ disabledSelectionKeys: SelectedKeysT;
54
+ getRowRadioProps: (key: string | number) => RadioInputProps;
55
+ toggleSelection: (key: string | number) => void;
36
56
  };
37
57
 
38
58
  type MultipleSelection = {
39
59
  selectionMode: "multiple";
40
- allKeys: (string | number)[];
41
- selectedKeys: SelectionT;
42
- disabledKeys: (string | number)[];
43
- getTheadCheckboxProps: () => CheckboxProps;
44
- getRowCheckboxProps: (key: string | number) => CheckboxProps;
60
+ selectedKeys: SelectedKeysT;
61
+ disabledSelectionKeys: SelectedKeysT;
62
+ getTheadCheckboxProps: () => CheckboxInputProps;
63
+ getRowCheckboxProps: (key: string | number) => CheckboxInputProps;
64
+ toggleSelection: (key: string | number) => void;
65
+ };
66
+
67
+ type TableSelectionBase = {
68
+ isRowSelected: (rowId: string | number) => boolean;
45
69
  };
46
70
 
47
- type TableSelection = NoneSelection | SingleSelection | MultipleSelection;
71
+ type TableSelection = TableSelectionBase &
72
+ (NoneSelection | SingleSelection | MultipleSelection);
48
73
 
49
74
  export type {
50
75
  MultipleSelection,
51
76
  NoneSelection,
52
77
  SelectionProps,
53
- SelectionT,
54
78
  SingleSelection,
55
79
  TableSelection,
80
+ SelectedKeysT,
56
81
  };