@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
@@ -1,11 +1,15 @@
1
+ /* eslint-disable jsx-a11y/no-static-element-interactions */
1
2
  import { format } from "date-fns";
2
3
  import React, { forwardRef } from "react";
3
4
  import { BodyShort } from "../typography/BodyShort";
4
5
  import { cl } from "../utils/helpers";
5
6
  import { useI18n } from "../utils/i18n/i18n.hooks";
7
+ import {
8
+ useTimelineKeyboardActiveRow,
9
+ useTimelineKeyboardContext,
10
+ } from "./hooks/TimelineKeyboardNavProvider";
6
11
  import { PeriodContext } from "./hooks/usePeriodContext";
7
12
  import { useRowContext } from "./hooks/useRowContext";
8
- import { useTimelineContext } from "./hooks/useTimelineContext";
9
13
  import Period from "./period";
10
14
  import {
11
15
  PositionedPeriod,
@@ -49,10 +53,14 @@ export interface TimelineRowType extends React.ForwardRefExoticComponent<
49
53
 
50
54
  export const TimelineRow = forwardRef<HTMLOListElement, TimelineRowProps>(
51
55
  ({ label, className, headingTag = "h3", icon, ...rest }, ref) => {
52
- const { periods, active } = useRowContext();
53
- const { setActiveRow } = useTimelineContext();
56
+ const { periods } = useRowContext();
57
+ const { updateActiveRow, handleRowKeyDown } = useTimelineKeyboardContext();
58
+ const { activeRow } = useTimelineKeyboardActiveRow();
54
59
  const translate = useI18n("Timeline");
55
60
 
61
+ const [elementRefState, setElementRefState] =
62
+ React.useState<HTMLDivElement | null>(null);
63
+
56
64
  const latest = periods.reduce((a, b) => {
57
65
  return a.end > b.end ? a : b;
58
66
  }, {} as PositionedPeriod);
@@ -61,10 +69,6 @@ export const TimelineRow = forwardRef<HTMLOListElement, TimelineRowProps>(
61
69
  return a.end < b.end ? a : b;
62
70
  }, {} as PositionedPeriod);
63
71
 
64
- const firstFocusable = periods.find(
65
- (p) => !!p.children || !!p.onSelectPeriod,
66
- );
67
-
68
72
  return (
69
73
  <>
70
74
  {label &&
@@ -80,15 +84,20 @@ export const TimelineRow = forwardRef<HTMLOListElement, TimelineRowProps>(
80
84
  ) : (
81
85
  <div className="aksel-timeline__row-label">{label}</div>
82
86
  ))}
87
+
88
+ {/** biome-ignore lint/a11y/noStaticElementInteractions: onKeyDown just captures events on child-elements here. Regular interaction patterns still works as expected. */}
83
89
  <div
84
90
  className={cl("aksel-timeline__row", {
85
- "aksel-timeline__row--active": active,
91
+ "aksel-timeline__row--active": activeRow === elementRefState,
86
92
  })}
93
+ ref={setElementRefState}
94
+ tabIndex={-1}
95
+ onFocusCapture={() => updateActiveRow(elementRefState)}
96
+ onKeyDown={handleRowKeyDown}
97
+ data-timeline-row
87
98
  >
88
- {/* eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions */}
89
99
  <ol
90
100
  {...rest}
91
- tabIndex={-1}
92
101
  ref={ref}
93
102
  aria-label={
94
103
  periods.length === 0
@@ -99,12 +108,6 @@ export const TimelineRow = forwardRef<HTMLOListElement, TimelineRowProps>(
99
108
  })
100
109
  }
101
110
  className={cl("aksel-timeline__row-periods", className)}
102
- onKeyDown={(e) => {
103
- if (e.key === "ArrowDown" || e.key === "ArrowUp") {
104
- e.preventDefault();
105
- setActiveRow(e.key);
106
- }
107
- }}
108
111
  >
109
112
  {periods?.map((period) => {
110
113
  return (
@@ -112,7 +115,6 @@ export const TimelineRow = forwardRef<HTMLOListElement, TimelineRowProps>(
112
115
  <PeriodContext.Provider
113
116
  value={{
114
117
  periodId: period.id,
115
- firstFocus: firstFocusable?.id === period.id,
116
118
  restProps: period?.restProps,
117
119
  }}
118
120
  >
@@ -0,0 +1,237 @@
1
+ import React, { useCallback, useRef } from "react";
2
+ import { Slot } from "../../utils/components/slot/Slot";
3
+ import { createStrictContext } from "../../utils/helpers";
4
+
5
+ type TimelineKeyboardNavStableContextType = {
6
+ updateActiveRow: (element: HTMLElement | null) => void;
7
+ handleRowKeyDown: (event: React.KeyboardEvent<HTMLElement>) => void;
8
+ handlePinKeyDown: (event: React.KeyboardEvent<Element>) => void;
9
+ };
10
+
11
+ type TimelineKeyboardNavActiveRowContextType = {
12
+ activeRow: HTMLElement | null;
13
+ };
14
+
15
+ const {
16
+ Provider: TimelineKeyboardNavStableContextProvider,
17
+ useContext: useTimelineKeyboardContext,
18
+ } = createStrictContext<TimelineKeyboardNavStableContextType>({
19
+ name: "TimelineKeyboardNavStableContext",
20
+ errorMessage:
21
+ "useTimelineKeyboardContext must be used within a TimelineKeyboardNavProvider",
22
+ });
23
+
24
+ const {
25
+ Provider: TimelineKeyboardNavActiveRowContextProvider,
26
+ useContext: useTimelineKeyboardActiveRow,
27
+ } = createStrictContext<TimelineKeyboardNavActiveRowContextType>({
28
+ name: "TimelineKeyboardNavActiveRowContext",
29
+ errorMessage:
30
+ "useTimelineKeyboardActiveRow must be used within a TimelineKeyboardNavProvider",
31
+ });
32
+
33
+ type TimelineKeyboardNavProviderProps = {
34
+ children: React.ReactElement;
35
+ };
36
+
37
+ function TimelineKeyboardNavProvider({
38
+ children,
39
+ }: TimelineKeyboardNavProviderProps) {
40
+ const [activeRow, setActiveRow] = React.useState<HTMLElement | null>(null);
41
+ const activeRowRef = React.useRef<HTMLElement | null>(null);
42
+
43
+ const timelineElementRef = useRef<HTMLTableElement>(null);
44
+
45
+ const updateActiveRow = React.useCallback((element: HTMLElement | null) => {
46
+ activeRowRef.current = element;
47
+ setActiveRow(element);
48
+ }, []);
49
+
50
+ const handleRowKeyDown = useCallback(
51
+ (event: React.KeyboardEvent<HTMLElement>) => {
52
+ const currentActiveRow = activeRowRef.current;
53
+ if (!currentActiveRow) {
54
+ return;
55
+ }
56
+
57
+ /* Skip interaction if focus is inside popover */
58
+ if (document.activeElement?.closest("[data-timeline-popover]")) {
59
+ return;
60
+ }
61
+
62
+ const { key } = event;
63
+
64
+ if (key === "ArrowDown" || key === "ArrowUp") {
65
+ const rows = currentActiveRow.parentElement?.querySelectorAll(
66
+ "[data-timeline-row]",
67
+ );
68
+ const firstPin = currentActiveRow.parentElement?.querySelector(
69
+ "[data-timeline-pin]",
70
+ );
71
+
72
+ if (!rows || rows.length === 0) {
73
+ return;
74
+ }
75
+
76
+ const currentIndex = Array.from(rows).indexOf(currentActiveRow);
77
+ if (currentIndex === -1) {
78
+ return;
79
+ }
80
+
81
+ const atBoundary = currentIndex === 0 && key === "ArrowUp";
82
+
83
+ if (atBoundary && firstPin) {
84
+ focusElement(firstPin, event);
85
+ return;
86
+ }
87
+
88
+ const nextIndex =
89
+ key === "ArrowDown" ? currentIndex + 1 : currentIndex - 1;
90
+
91
+ /* We want to avoid looping */
92
+ if (nextIndex < 0 || nextIndex >= rows.length) {
93
+ return;
94
+ }
95
+
96
+ const nextRow = rows[nextIndex];
97
+ const periods = nextRow?.querySelectorAll("[data-timeline-period]");
98
+
99
+ if (periods?.length > 0) {
100
+ focusElement(periods[0], event);
101
+ } else if (nextRow) {
102
+ focusElement(nextRow, event);
103
+ }
104
+ return;
105
+ }
106
+
107
+ if (key === "ArrowRight" || key === "ArrowLeft") {
108
+ event.preventDefault();
109
+ const periods = currentActiveRow.querySelectorAll(
110
+ "[data-timeline-period]",
111
+ );
112
+ if (periods.length === 0) {
113
+ return;
114
+ }
115
+
116
+ const currentIndex = Array.from(periods).indexOf(
117
+ document.activeElement as HTMLElement,
118
+ );
119
+ if (currentIndex === -1) {
120
+ /* If just the row has focus, we want to focus either the first or last period inside based on key */
121
+ focusElement(
122
+ periods[key === "ArrowRight" ? 0 : periods.length - 1],
123
+ event,
124
+ );
125
+ return;
126
+ }
127
+
128
+ const nextIndex =
129
+ key === "ArrowRight" ? currentIndex + 1 : currentIndex - 1;
130
+
131
+ /* We want to avoid looping */
132
+ if (nextIndex < 0 || nextIndex >= periods.length) {
133
+ return;
134
+ }
135
+
136
+ focusElement(periods[nextIndex], event);
137
+ }
138
+ },
139
+ [],
140
+ );
141
+
142
+ const handlePinKeyDown = useCallback(
143
+ (event: React.KeyboardEvent<Element>) => {
144
+ const timelineElement = timelineElementRef.current;
145
+ if (!timelineElement) {
146
+ return;
147
+ }
148
+
149
+ /* Skip interaction if focus is inside popover */
150
+ if (document.activeElement?.closest("[data-timeline-popover]")) {
151
+ return;
152
+ }
153
+
154
+ const { key } = event;
155
+
156
+ if (key === "ArrowDown") {
157
+ const rows = timelineElement.querySelectorAll("[data-timeline-row]");
158
+ if (rows.length === 0) {
159
+ return;
160
+ }
161
+ const rowToFocus = rows[0] as HTMLElement | null;
162
+
163
+ if (rowToFocus) {
164
+ const periods = rowToFocus?.querySelectorAll(
165
+ "[data-timeline-period]",
166
+ );
167
+
168
+ if (periods?.length > 0) {
169
+ focusElement(periods[0], event);
170
+ } else if (rowToFocus) {
171
+ focusElement(rowToFocus, event);
172
+ }
173
+ }
174
+ }
175
+
176
+ if (key === "ArrowRight" || key === "ArrowLeft") {
177
+ event.preventDefault();
178
+ const pins = timelineElement.querySelectorAll("[data-timeline-pin]");
179
+ if (pins.length === 0) {
180
+ return;
181
+ }
182
+
183
+ const currentIndex = Array.from(pins).indexOf(
184
+ document.activeElement as HTMLElement,
185
+ );
186
+ if (currentIndex === -1) {
187
+ return;
188
+ }
189
+
190
+ const nextIndex =
191
+ key === "ArrowRight" ? currentIndex + 1 : currentIndex - 1;
192
+
193
+ /* We want to avoid looping */
194
+ if (nextIndex < 0 || nextIndex >= pins.length) {
195
+ return;
196
+ }
197
+
198
+ focusElement(pins[nextIndex], event);
199
+ }
200
+ },
201
+ [],
202
+ );
203
+
204
+ return (
205
+ <TimelineKeyboardNavStableContextProvider
206
+ updateActiveRow={updateActiveRow}
207
+ handleRowKeyDown={handleRowKeyDown}
208
+ handlePinKeyDown={handlePinKeyDown}
209
+ >
210
+ <TimelineKeyboardNavActiveRowContextProvider activeRow={activeRow}>
211
+ <Slot ref={timelineElementRef}>{children}</Slot>
212
+ </TimelineKeyboardNavActiveRowContextProvider>
213
+ </TimelineKeyboardNavStableContextProvider>
214
+ );
215
+ }
216
+
217
+ /**
218
+ * Focuses the given element and prevents default behavior of the event if focus is called.
219
+ */
220
+ function focusElement(
221
+ element: HTMLElement | Element | null,
222
+ event: React.KeyboardEvent<HTMLElement | Element>,
223
+ ) {
224
+ if (!element) {
225
+ return;
226
+ }
227
+
228
+ event.preventDefault();
229
+
230
+ (element as HTMLElement).focus();
231
+ }
232
+
233
+ export {
234
+ TimelineKeyboardNavProvider,
235
+ useTimelineKeyboardContext,
236
+ useTimelineKeyboardActiveRow,
237
+ };
@@ -2,13 +2,11 @@ import { createContext, useContext } from "react";
2
2
 
3
3
  interface PeriodContextProps {
4
4
  periodId: string;
5
- firstFocus: boolean;
6
5
  restProps?: any;
7
6
  }
8
7
 
9
8
  export const PeriodContext = createContext<PeriodContextProps>({
10
9
  periodId: "",
11
- firstFocus: false,
12
10
  });
13
11
 
14
12
  export const usePeriodContext = () => {
@@ -4,14 +4,12 @@ import { PositionedPeriod } from "../utils/types.internal";
4
4
  interface RowContextProps {
5
5
  periods: PositionedPeriod[];
6
6
  id: string;
7
- active: boolean;
8
7
  index: number;
9
8
  }
10
9
 
11
10
  export const RowContext = createContext<RowContextProps>({
12
11
  periods: [],
13
12
  id: "",
14
- active: false,
15
13
  index: 0,
16
14
  });
17
15
 
@@ -6,10 +6,6 @@ interface TimelineContextProps {
6
6
  direction: "left" | "right";
7
7
  setStart: (d: Date) => void;
8
8
  setEndInclusive: (d: Date) => void;
9
- activeRow: number | null;
10
- setActiveRow: (i: string) => void;
11
- initiate: (i: number) => void;
12
- addFocusable: (ref: HTMLButtonElement | null, id: number) => void;
13
9
  }
14
10
 
15
11
  export const TimelineContext = createContext<TimelineContextProps>({
@@ -18,10 +14,6 @@ export const TimelineContext = createContext<TimelineContextProps>({
18
14
  direction: "left",
19
15
  setStart: () => null,
20
16
  setEndInclusive: () => null,
21
- activeRow: 0,
22
- setActiveRow: () => null,
23
- initiate: () => null,
24
- addFocusable: () => null,
25
17
  });
26
18
 
27
19
  export const useTimelineContext = () => {
@@ -5,6 +5,7 @@ import {
5
5
  offset,
6
6
  safePolygon,
7
7
  shift,
8
+ useClick,
8
9
  useDismiss,
9
10
  useFloating,
10
11
  useFocus,
@@ -15,9 +16,6 @@ import React, { useState } from "react";
15
16
  import { cl } from "../../utils/helpers";
16
17
  import { useMergeRefs } from "../../utils/hooks";
17
18
  import { useI18n } from "../../utils/i18n/i18n.hooks";
18
- import { usePeriodContext } from "../hooks/usePeriodContext";
19
- import { useRowContext } from "../hooks/useRowContext";
20
- import { useTimelineContext } from "../hooks/useTimelineContext";
21
19
  import { ariaLabel, getConditionalClasses } from "../utils/period";
22
20
  import type { PeriodProps } from "./types";
23
21
 
@@ -52,9 +50,6 @@ const ClickablePeriod = React.memo(
52
50
  periodRef,
53
51
  }: TimelineClickablePeriodProps) => {
54
52
  const [open, setOpen] = useState(false);
55
- const { index } = useRowContext();
56
- const { firstFocus } = usePeriodContext();
57
- const { initiate, addFocusable } = useTimelineContext();
58
53
 
59
54
  const translate = useI18n("Timeline");
60
55
 
@@ -78,8 +73,10 @@ const ClickablePeriod = React.memo(
78
73
  });
79
74
  const focus = useFocus(context);
80
75
  const dismiss = useDismiss(context);
76
+ const click = useClick(context);
81
77
 
82
78
  const { getFloatingProps, getReferenceProps } = useInteractions([
79
+ click,
83
80
  hover,
84
81
  focus,
85
82
  dismiss,
@@ -92,13 +89,11 @@ const ClickablePeriod = React.memo(
92
89
  return (
93
90
  <>
94
91
  <button
92
+ data-timeline-period
95
93
  {...restProps}
96
94
  data-color={restProps?.["data-color"] ?? status}
97
95
  type="button"
98
- ref={(r) => {
99
- firstFocus && addFocusable(r, index);
100
- mergedRef?.(r);
101
- }}
96
+ ref={mergedRef}
102
97
  aria-label={label}
103
98
  className={cl(
104
99
  "aksel-timeline__period--clickable",
@@ -111,17 +106,10 @@ const ClickablePeriod = React.memo(
111
106
  aria-expanded={children ? open : undefined}
112
107
  aria-current={isActive || undefined}
113
108
  {...getReferenceProps({
114
- onFocus: () => {
115
- initiate(index);
116
- },
117
109
  onKeyDown: (e) => {
118
- restProps?.onKeydown?.(e);
119
- if (e.key === "Enter") {
120
- setOpen((prev) => !prev);
121
- }
110
+ restProps?.onKeyDown?.(e);
122
111
  if (e.key === " ") {
123
112
  onSelectPeriod?.(e);
124
- setOpen(false);
125
113
  }
126
114
  },
127
115
  style: {
@@ -144,10 +132,11 @@ const ClickablePeriod = React.memo(
144
132
  context={context}
145
133
  modal={false}
146
134
  initialFocus={-1}
147
- returnFocus={false}
135
+ returnFocus
148
136
  >
149
137
  <div
150
138
  className="aksel-timeline__popover"
139
+ data-timeline-popover
151
140
  data-placement={placement}
152
141
  ref={refs.setFloating}
153
142
  role="dialog"
@@ -25,7 +25,9 @@ const NonClickablePeriod = ({
25
25
 
26
26
  return (
27
27
  <div
28
+ data-timeline-period
28
29
  ref={periodRef}
30
+ tabIndex={-1}
29
31
  {...restProps}
30
32
  data-color={restProps?.["data-color"] ?? status}
31
33
  className={cl(
@@ -5,6 +5,7 @@ import {
5
5
  offset,
6
6
  safePolygon,
7
7
  shift,
8
+ useClick,
8
9
  useDismiss,
9
10
  useFloating,
10
11
  useFocus,
@@ -15,6 +16,7 @@ import { format } from "date-fns";
15
16
  import React, { forwardRef, useState } from "react";
16
17
  import { useMergeRefs } from "../../utils/hooks";
17
18
  import { useI18n } from "../../utils/i18n/i18n.hooks";
19
+ import { useTimelineKeyboardContext } from "../hooks/TimelineKeyboardNavProvider";
18
20
  import { useTimelineContext } from "../hooks/useTimelineContext";
19
21
  import { position } from "../utils/calc";
20
22
 
@@ -32,17 +34,12 @@ export interface TimelinePinProps extends React.HTMLAttributes<HTMLButtonElement
32
34
  export const PinInternal = forwardRef<HTMLButtonElement, TimelinePinProps>(
33
35
  ({ date, children, ...rest }, ref) => {
34
36
  const { startDate, endDate, direction } = useTimelineContext();
37
+ const { handlePinKeyDown } = useTimelineKeyboardContext();
35
38
  const [open, setOpen] = useState(false);
36
39
 
37
40
  const translate = useI18n("Timeline");
38
41
 
39
- const {
40
- context,
41
- placement,
42
-
43
- refs,
44
- floatingStyles,
45
- } = useFloating({
42
+ const { context, placement, refs, floatingStyles } = useFloating({
46
43
  placement: "top",
47
44
  open,
48
45
  onOpenChange: (_open) => setOpen(_open),
@@ -62,8 +59,10 @@ export const PinInternal = forwardRef<HTMLButtonElement, TimelinePinProps>(
62
59
  });
63
60
  const focus = useFocus(context);
64
61
  const dismiss = useDismiss(context);
62
+ const click = useClick(context);
65
63
 
66
64
  const { getFloatingProps, getReferenceProps } = useInteractions([
65
+ click,
67
66
  hover,
68
67
  focus,
69
68
  dismiss,
@@ -82,6 +81,7 @@ export const PinInternal = forwardRef<HTMLButtonElement, TimelinePinProps>(
82
81
  style={{ [direction]: `${position(date, startDate, endDate)}%` }}
83
82
  >
84
83
  <button
84
+ data-timeline-pin
85
85
  {...rest}
86
86
  ref={mergedRef}
87
87
  className="aksel-timeline__pin-button"
@@ -91,11 +91,7 @@ export const PinInternal = forwardRef<HTMLButtonElement, TimelinePinProps>(
91
91
  {...getReferenceProps({
92
92
  onKeyDown: (e) => {
93
93
  rest?.onKeyDown?.(e as React.KeyboardEvent<HTMLButtonElement>);
94
- if (e.key === "Enter") {
95
- setOpen((prev) => !prev);
96
- } else if (e.key === " ") {
97
- setOpen(false);
98
- }
94
+ handlePinKeyDown(e);
99
95
  },
100
96
  })}
101
97
  />
@@ -105,10 +101,11 @@ export const PinInternal = forwardRef<HTMLButtonElement, TimelinePinProps>(
105
101
  context={context}
106
102
  modal={false}
107
103
  initialFocus={-1}
108
- returnFocus={false}
104
+ returnFocus
109
105
  >
110
106
  <div
111
107
  className="aksel-timeline__popover"
108
+ data-timeline-popover
112
109
  data-placement={placement}
113
110
  ref={refs.setFloating}
114
111
  role="dialog"
@@ -17,7 +17,7 @@ export function useToggleGroup({
17
17
  /* Sync focused `value` with controlled `selectedValue` */
18
18
  useEffect(() => {
19
19
  if (value != null) {
20
- setFocusedValue(value);
20
+ setFocusedValue(value); // eslint-disable-line react-hooks/set-state-in-effect
21
21
  }
22
22
  }, [value]);
23
23
 
@@ -342,7 +342,7 @@ const DismissableLayer = forwardRef<HTMLDivElement, DismissableLayerProps>(
342
342
  if (disableOutsidePointerEvents) {
343
343
  if (context.layersWithOutsidePointerEventsDisabled.size === 0) {
344
344
  originalBodyPointerEvents = ownerDoc.body.style.pointerEvents;
345
- ownerDoc.body.style.pointerEvents = "none";
345
+ ownerDoc.body.style.pointerEvents = "none"; // eslint-disable-line react-hooks/immutability
346
346
  }
347
347
  context.layersWithOutsidePointerEventsDisabled.add(node);
348
348
  }
@@ -65,7 +65,7 @@ function createStrictContext<T>(options: {
65
65
 
66
66
  function Provider({ children, ...context }: ProviderProps<T>) {
67
67
  // biome-ignore lint/correctness/useExhaustiveDependencies: Object.values(context) includes all dependencies.
68
- const value = React.useMemo(() => context, Object.values(context)) as T; // eslint-disable-line react-hooks/exhaustive-deps
68
+ const value = React.useMemo(() => context, Object.values(context)) as T; // eslint-disable-line react-hooks/exhaustive-deps, react-hooks/use-memo
69
69
 
70
70
  return <Context.Provider value={value}>{children}</Context.Provider>;
71
71
  }
@@ -46,7 +46,7 @@ type Stable<T extends Callback> = {
46
46
 
47
47
  function useEventCallback<T extends Callback>(callback: T | undefined): T {
48
48
  const stable = useRefWithInit(createStableCallback).current as Stable<T>;
49
- stable.next = callback;
49
+ stable.next = callback; // eslint-disable-line react-hooks/immutability
50
50
  useSafeInsertionEffect(stable.effect);
51
51
  return stable.trampoline;
52
52
  }
@@ -21,7 +21,7 @@ export const useMedia = (
21
21
  }
22
22
  const mediaQueryList = window.matchMedia(media);
23
23
 
24
- setMatches(mediaQueryList.matches);
24
+ setMatches(mediaQueryList.matches); // eslint-disable-line react-hooks/set-state-in-effect
25
25
 
26
26
  const listener = (evt: MediaQueryListEvent) => {
27
27
  setMatches(evt.matches);
@@ -1,5 +0,0 @@
1
- import React from "react";
2
- declare function DataTableThActions({ children }: {
3
- children?: React.ReactNode;
4
- }): React.JSX.Element | null;
5
- export { DataTableThActions };
@@ -1,23 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.DataTableThActions = DataTableThActions;
7
- const react_1 = __importDefault(require("react"));
8
- const aksel_icons_1 = require("@navikt/aksel-icons");
9
- const action_menu_1 = require("../../../action-menu");
10
- const button_1 = require("../../../button");
11
- function DataTableThActions({ children }) {
12
- const [open, setOpen] = react_1.default.useState(false);
13
- /* TODO: Fix this */
14
- // @ts-expect-error Temp hack to hide when no children present
15
- if (!children || !children.filter(Boolean).length) {
16
- return null;
17
- }
18
- return (react_1.default.createElement(action_menu_1.ActionMenu, { open: open, onOpenChange: setOpen },
19
- react_1.default.createElement(action_menu_1.ActionMenu.Trigger, null,
20
- react_1.default.createElement(button_1.Button, { "data-color": "neutral", variant: "tertiary", size: "small", icon: react_1.default.createElement(aksel_icons_1.MenuElipsisVerticalIcon, { title: "\u00C5pne kolonnemeny" }), onClick: () => setOpen(!open), "data-expanded": open, className: "aksel-data-table__th-action-button" })),
21
- react_1.default.createElement(action_menu_1.ActionMenu.Content, null, children)));
22
- }
23
- //# sourceMappingURL=DataTableThActions.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataTableThActions.js","sourceRoot":"","sources":["../../../../src/data/table/th/DataTableThActions.tsx"],"names":[],"mappings":";;;;;AA+BS,gDAAkB;AA/B3B,kDAA0B;AAC1B,qDAA8D;AAC9D,sDAAkD;AAClD,4CAAyC;AAEzC,SAAS,kBAAkB,CAAC,EAAE,QAAQ,EAAkC;IACtE,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,eAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9C,oBAAoB;IACpB,8DAA8D;IAC9D,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,CAAC;QAClD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CACL,8BAAC,wBAAU,IAAC,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO;QAC3C,8BAAC,wBAAU,CAAC,OAAO;YACjB,8BAAC,eAAM,kBACM,SAAS,EACpB,OAAO,EAAC,UAAU,EAClB,IAAI,EAAC,OAAO,EACZ,IAAI,EAAE,8BAAC,qCAAuB,IAAC,KAAK,EAAC,uBAAkB,GAAG,EAC1D,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,mBACd,IAAI,EACnB,SAAS,EAAC,oCAAoC,GAC9C,CACiB;QACrB,8BAAC,wBAAU,CAAC,OAAO,QAAE,QAAQ,CAAsB,CACxC,CACd,CAAC;AACJ,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"useTableColumnResize.js","sourceRoot":"","sources":["../../../../src/data/table/th/useTableColumnResize.ts"],"names":[],"mappings":"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"}
@@ -1,4 +0,0 @@
1
- import React from "react";
2
- declare const DataTableTheadContext: React.Context<boolean>;
3
- declare function useDataTableThead(): boolean;
4
- export { DataTableTheadContext, useDataTableThead };
@@ -1 +0,0 @@
1
- {"version":3,"file":"DataTableThead.context.js","sourceRoot":"","sources":["../../../../src/data/table/thead/DataTableThead.context.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AASgC,8CAAiB;AATjD,+CAA6C;AAE7C,MAAM,qBAAqB,GAAG,IAAA,qBAAa,EAAU,KAAK,CAAC,CAAC;AAOnD,sDAAqB;AAL9B,SAAS,iBAAiB;IACxB,MAAM,OAAO,GAAG,eAAK,CAAC,UAAU,CAAC,qBAAqB,CAAC,CAAC;IACxD,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -1,5 +0,0 @@
1
- import React from "react";
2
- declare function DataTableThActions({ children }: {
3
- children?: React.ReactNode;
4
- }): React.JSX.Element | null;
5
- export { DataTableThActions };