@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
@@ -26,10 +26,6 @@ export interface FieldsetProps
26
26
  * @default true
27
27
  */
28
28
  errorPropagation?: boolean;
29
- /**
30
- * @private
31
- */
32
- _fieldsSupportNativeReadOnly?: boolean;
33
29
  }
34
30
 
35
31
  /**
@@ -60,6 +56,7 @@ export const Fieldset = forwardRef<HTMLFieldSetElement, FieldsetProps>(
60
56
  size,
61
57
  readOnly,
62
58
  inputDescriptionId,
59
+ readOnlyIconNeedsTitle,
63
60
  } = useFieldset(props, legendId);
64
61
 
65
62
  const fieldset = useContext(FieldsetContext);
@@ -71,7 +68,6 @@ export const Fieldset = forwardRef<HTMLFieldSetElement, FieldsetProps>(
71
68
  legend,
72
69
  description,
73
70
  hideLegend,
74
- _fieldsSupportNativeReadOnly = true,
75
71
  ...rest
76
72
  } = props;
77
73
 
@@ -108,23 +104,21 @@ export const Fieldset = forwardRef<HTMLFieldSetElement, FieldsetProps>(
108
104
  id={legendId}
109
105
  size={size}
110
106
  as="legend"
111
- className={cl("aksel-fieldset__legend", {
112
- "aksel-sr-only": !!hideLegend,
113
- })}
107
+ className="aksel-fieldset__legend"
108
+ visuallyHidden={!!hideLegend}
114
109
  >
115
110
  {readOnly &&
116
- (_fieldsSupportNativeReadOnly ? (
117
- <ReadOnlyIcon />
118
- ) : (
111
+ (readOnlyIconNeedsTitle ? (
119
112
  <ReadOnlyIconWithTitle />
113
+ ) : (
114
+ <ReadOnlyIcon />
120
115
  ))}
121
116
  {legend}
122
117
  </Label>
123
118
  {!!description && (
124
119
  <BodyShort
125
- className={cl("aksel-fieldset__description", {
126
- "aksel-sr-only": !!hideLegend,
127
- })}
120
+ className="aksel-fieldset__description"
121
+ visuallyHidden={!!hideLegend}
128
122
  id={inputDescriptionId}
129
123
  size={size ?? "medium"}
130
124
  as="div"
@@ -1,19 +1,26 @@
1
+ import { useContext } from "react";
1
2
  import { cl } from "../../utils/helpers";
2
- import {
3
- type FormFieldProps,
4
- containsReadMore,
5
- useFormField,
6
- } from "../useFormField";
3
+ import { CheckboxGroupContext } from "../checkbox/CheckboxGroup.context";
4
+ import { RadioGroupContext } from "../radio/RadioGroup.context";
5
+ import { containsReadMore, useFormField } from "../useFormField";
6
+ import type { FieldsetProps } from "./Fieldset";
7
7
 
8
8
  /**
9
9
  * Handles props for Fieldset in context with parent Fieldset.
10
10
  */
11
- export const useFieldset = (props: FormFieldProps, legendId: string) => {
11
+ export const useFieldset = (props: FieldsetProps, legendId: string) => {
12
12
  const formField = useFormField(props, "fieldset");
13
+ const checkboxGroupContext = useContext(CheckboxGroupContext);
14
+ const radioGroupContext = useContext(RadioGroupContext);
13
15
 
14
16
  return {
15
17
  ...formField,
18
+ readOnlyIconNeedsTitle: checkboxGroupContext || radioGroupContext,
16
19
  inputProps: {
20
+ ...(checkboxGroupContext || radioGroupContext
21
+ ? { "aria-invalid": formField.inputProps["aria-invalid"] }
22
+ : {}),
23
+
17
24
  // Having both legend and description in labelledby seems to work best, ref. https://mortentollefsen.no/demo/radio-description.html
18
25
  "aria-labelledby":
19
26
  props["aria-labelledby"] ||
@@ -2,52 +2,57 @@ import React, { forwardRef } from "react";
2
2
  import { BodyShort } from "../../typography";
3
3
  import { omit, useId } from "../../utils-external";
4
4
  import { cl } from "../../utils/helpers";
5
+ import { RadioInput } from "./radio-input/RadioInput";
5
6
  import { RadioProps } from "./types";
6
7
  import { useRadio } from "./useRadio";
7
8
 
8
- export const Radio = forwardRef<HTMLInputElement, RadioProps>((props, ref) => {
9
- const { inputProps, size, hasError, readOnly } = useRadio(props);
10
- const descriptionId = useId();
9
+ export const Radio = forwardRef<HTMLInputElement, RadioProps>(
10
+ (props: RadioProps, forwardedRef) => {
11
+ const { inputProps, size, hasError, readOnly } = useRadio(props);
12
+ const descriptionId = useId();
11
13
 
12
- return (
13
- <div
14
- className={cl(props.className, "aksel-radio", `aksel-radio--${size}`, {
15
- "aksel-radio--error": hasError,
16
- "aksel-radio--disabled": inputProps.disabled,
17
- "aksel-radio--readonly": readOnly,
18
- })}
19
- data-color={hasError ? "danger" : props["data-color"]}
20
- >
21
- <input
22
- {...omit(props, ["children", "size", "description", "readOnly"])}
23
- {...omit(inputProps, ["aria-invalid", "aria-describedby"])}
24
- aria-describedby={
25
- cl(inputProps["aria-describedby"], {
26
- [descriptionId]: props.description,
27
- }) || undefined
28
- }
29
- className="aksel-radio__input"
30
- ref={ref}
31
- />
32
- <BodyShort
33
- as="label"
34
- htmlFor={inputProps.id}
35
- className="aksel-radio__label"
36
- size={size}
14
+ const { className, description, children } = props;
15
+
16
+ return (
17
+ <div
18
+ className={cl(className, "aksel-radio", `aksel-radio--${size}`, {
19
+ "aksel-radio--error": hasError,
20
+ "aksel-radio--disabled": inputProps.disabled,
21
+ "aksel-radio--readonly": readOnly,
22
+ })}
23
+ data-color={hasError ? "danger" : props["data-color"]}
37
24
  >
38
- {props.children}
39
- </BodyShort>
40
- {props.description && (
25
+ <RadioInput
26
+ ref={forwardedRef}
27
+ {...omit(props, ["children", "size", "description", "readOnly"])}
28
+ {...omit(inputProps, ["aria-invalid", "aria-describedby"])}
29
+ aria-describedby={
30
+ cl(inputProps["aria-describedby"], {
31
+ [descriptionId]: description,
32
+ }) || undefined
33
+ }
34
+ standalone={false}
35
+ />
41
36
  <BodyShort
42
- id={descriptionId}
37
+ as="label"
38
+ htmlFor={inputProps.id}
39
+ className="aksel-radio__label"
43
40
  size={size}
44
- className="aksel-form-field__subdescription aksel-radio__description"
45
41
  >
46
- {props.description}
42
+ {children}
47
43
  </BodyShort>
48
- )}
49
- </div>
50
- );
51
- });
44
+ {description && (
45
+ <BodyShort
46
+ id={descriptionId}
47
+ size={size}
48
+ className="aksel-form-field__subdescription aksel-radio__description"
49
+ >
50
+ {description}
51
+ </BodyShort>
52
+ )}
53
+ </div>
54
+ );
55
+ },
56
+ );
52
57
 
53
58
  export default Radio;
@@ -0,0 +1,13 @@
1
+ import { createContext } from "react";
2
+
3
+ export interface RadioGroupContextProps {
4
+ name: string;
5
+ defaultValue?: any;
6
+ value?: any;
7
+ onChange: (value: any) => void;
8
+ required?: boolean;
9
+ }
10
+
11
+ export const RadioGroupContext = createContext<RadioGroupContextProps | null>(
12
+ null,
13
+ );
@@ -3,18 +3,9 @@ import { useId } from "../../utils-external";
3
3
  import { cl } from "../../utils/helpers";
4
4
  import { Fieldset, FieldsetProps } from "../fieldset";
5
5
  import { FieldsetContext } from "../fieldset/context";
6
+ import { RadioGroupContext } from "./RadioGroup.context";
6
7
 
7
- export interface RadioGroupContextProps {
8
- name: string;
9
- defaultValue?: any;
10
- value?: any;
11
- onChange: (value: any) => void;
12
- required?: boolean;
13
- }
14
-
15
- export const RadioGroupContext =
16
- React.createContext<RadioGroupContextProps | null>(null);
17
-
8
+ // TODO: Omit "role" in next major
18
9
  export interface RadioGroupProps extends Omit<
19
10
  FieldsetProps,
20
11
  "onChange" | "errorPropagation" | "defaultValue" | "nativeReadOnly"
@@ -75,29 +66,29 @@ export const RadioGroup = forwardRef<HTMLFieldSetElement, RadioGroupProps>(
75
66
  const nameId = useId();
76
67
 
77
68
  return (
78
- <Fieldset
79
- {...rest}
80
- readOnly={readOnly}
81
- ref={ref}
82
- className={cl(
83
- className,
84
- "aksel-radio-group",
85
- `aksel-radio-group--${rest.size ?? fieldset?.size ?? "medium"}`,
86
- )}
87
- _fieldsSupportNativeReadOnly={false}
69
+ <RadioGroupContext.Provider
70
+ value={{
71
+ name: name ?? `radioGroupName-${nameId}`,
72
+ defaultValue,
73
+ value,
74
+ onChange,
75
+ required,
76
+ }}
88
77
  >
89
- <RadioGroupContext.Provider
90
- value={{
91
- name: name ?? `radioGroupName-${nameId}`,
92
- defaultValue,
93
- value,
94
- onChange,
95
- required,
96
- }}
78
+ <Fieldset
79
+ role="radiogroup"
80
+ {...rest}
81
+ readOnly={readOnly}
82
+ ref={ref}
83
+ className={cl(
84
+ className,
85
+ "aksel-radio-group",
86
+ `aksel-radio-group--${rest.size ?? fieldset?.size ?? "medium"}`,
87
+ )}
97
88
  >
98
89
  <div className="aksel-radio-buttons">{children}</div>
99
- </RadioGroupContext.Provider>
100
- </Fieldset>
90
+ </Fieldset>
91
+ </RadioGroupContext.Provider>
101
92
  );
102
93
  },
103
94
  );
@@ -0,0 +1,32 @@
1
+ import React, { forwardRef } from "react";
2
+ import { cl } from "../../../utils/helpers";
3
+
4
+ type RadioInputProps = React.InputHTMLAttributes<HTMLInputElement> & {
5
+ children?: never;
6
+ standalone?: boolean;
7
+ /**
8
+ * Reduces pseudo-element target-size.
9
+ */
10
+ compact?: boolean;
11
+ };
12
+
13
+ const RadioInput = forwardRef<HTMLInputElement, RadioInputProps>(
14
+ (
15
+ { className, standalone = true, compact, ...rest }: RadioInputProps,
16
+ forwardedRef,
17
+ ) => {
18
+ return (
19
+ <input
20
+ {...rest}
21
+ ref={forwardedRef}
22
+ className={cl("aksel-radio__input", className)}
23
+ data-standalone={standalone}
24
+ data-compact={compact}
25
+ type="radio"
26
+ />
27
+ );
28
+ },
29
+ );
30
+
31
+ export { RadioInput };
32
+ export type { RadioInputProps };
@@ -1,7 +1,7 @@
1
1
  import { useContext } from "react";
2
2
  import { omit } from "../../utils-external";
3
3
  import { useFormField } from "../useFormField";
4
- import { RadioGroupContext } from "./RadioGroup";
4
+ import { RadioGroupContext } from "./RadioGroup.context";
5
5
  import { RadioProps } from "./types";
6
6
 
7
7
  /**
@@ -1,7 +1,7 @@
1
1
  import React, { forwardRef } from "react";
2
2
  import { useThemeInternal } from "../../theme/Theme";
3
3
  import { BodyLong } from "../../typography";
4
- import { type OverridableComponent, useId } from "../../utils-external";
4
+ import { type OverridableComponent } from "../../utils-external";
5
5
  import { cl } from "../../utils/helpers";
6
6
  import { useI18n } from "../../utils/i18n/i18n.hooks";
7
7
  import { InlineMessageIcon } from "../icon/InlineMessageIcon";
@@ -58,10 +58,7 @@ export const InlineMessage: OverridableComponent<
58
58
  forwardedRef,
59
59
  ) => {
60
60
  const themeContext = useThemeInternal();
61
-
62
61
  const translate = useI18n("global");
63
- const statusId = useId();
64
- const contentId = useId();
65
62
 
66
63
  return (
67
64
  <BodyLong
@@ -75,18 +72,11 @@ export const InlineMessage: OverridableComponent<
75
72
  >
76
73
  <InlineMessageIcon status={status} />
77
74
  {status && (
78
- <BodyLong id={statusId} aria-hidden visuallyHidden>
75
+ <BodyLong as="span" visuallyHidden>
79
76
  {`${translate(status)}: `}
80
77
  </BodyLong>
81
78
  )}
82
- {/** biome-ignore lint/a11y/useAriaPropsSupportedByRole: Testing shows that this works. */}
83
- <span
84
- data-color={themeContext?.color}
85
- id={contentId}
86
- aria-labelledby={cl(statusId, contentId)}
87
- >
88
- {children}
89
- </span>
79
+ <span data-color={themeContext?.color}>{children}</span>
90
80
  </BodyLong>
91
81
  );
92
82
  },
@@ -35,7 +35,7 @@ function useIsModalOpen(modalRef: HTMLDialogElement | null) {
35
35
  return;
36
36
  }
37
37
 
38
- setIsOpen(modalRef.open);
38
+ setIsOpen(modalRef.open); // eslint-disable-line react-hooks/set-state-in-effect
39
39
 
40
40
  const observer = new MutationObserver(() => {
41
41
  setIsOpen(modalRef.open);
@@ -77,7 +77,7 @@ interface BoxComponentType extends OverridableComponent<
77
77
  /**
78
78
  * @deprecated Deprecated in v8. Use `Box` from '@navikt/ds-react/Box' instead (with same props).
79
79
  *
80
- * **Run `npx @navikt/aksel@latest codemod v8-box-new`> to migrate.**
80
+ * **Run `npx @navikt/aksel@latest codemod v8-box-new` to migrate.**
81
81
  */
82
82
  New: typeof BoxNew;
83
83
  }
@@ -17,18 +17,14 @@ export function useTabs({
17
17
  onChange,
18
18
  });
19
19
 
20
- /**
21
- * Sync focused `value` with controlled `selectedValue`
22
- */
20
+ /* Sync focused `value` with controlled `selectedValue` */
23
21
  useEffect(() => {
24
22
  if (value != null) {
25
- setFocusedValue(value);
23
+ setFocusedValue(value); // eslint-disable-line react-hooks/set-state-in-effect
26
24
  }
27
25
  }, [value]);
28
26
 
29
- /**
30
- * Scope ids for better tracking
31
- */
27
+ /* Scope ids for better tracking */
32
28
  const uuid = useId();
33
29
 
34
30
  return {
@@ -1,7 +1,8 @@
1
1
  import { endOfDay, isSameDay, startOfDay } from "date-fns";
2
- import React, { forwardRef, useMemo, useRef, useState } from "react";
2
+ import React, { forwardRef, useMemo, useState } from "react";
3
3
  import { AxisLabels } from "./AxisLabels";
4
4
  import TimelineRow, { TimelineRowType } from "./TimelineRow";
5
+ import { TimelineKeyboardNavProvider } from "./hooks/TimelineKeyboardNavProvider";
5
6
  import { RowContext } from "./hooks/useRowContext";
6
7
  import { TimelineContext } from "./hooks/useTimelineContext";
7
8
  import {
@@ -92,43 +93,48 @@ export const Timeline = forwardRef<HTMLDivElement, TimelineProps>(
92
93
  axisLabelTemplates,
93
94
  ...rest
94
95
  },
95
- ref,
96
+ forwardedRef,
96
97
  ) => {
97
- const isMultipleRows = Array.isArray(children);
98
+ const childArray = useMemo(
99
+ () =>
100
+ React.Children.toArray(Array.isArray(children) ? children : [children]),
101
+ [children],
102
+ );
98
103
 
99
- const firstFocusabled = useRef<
100
- { ref: HTMLButtonElement | null; id: number }[]
101
- >([]);
104
+ const rowChildren = useMemo(() => {
105
+ return childArray.filter((c: any) => c?.type?.componentType === "row");
106
+ }, [childArray]);
102
107
 
103
- if (!isMultipleRows) {
104
- children = [children];
105
- }
106
- const rowChildren = React.Children.toArray(children).filter(
107
- (c: any) => c?.type?.componentType === "row",
108
+ const pins = useMemo(
109
+ () =>
110
+ childArray
111
+ .filter((c: any) => c?.type?.componentType === "pin")
112
+ .map((x) => () => x),
113
+ [childArray],
108
114
  );
109
115
 
110
- const pins = React.Children.toArray(children)
111
- .filter((c: any) => c?.type?.componentType === "pin")
112
- .map((x) => () => x);
113
-
114
- const zoomComponent = React.Children.toArray(children).find(
115
- (c: any) => c?.type?.componentType === "zoom",
116
+ const zoomComponent = useMemo(
117
+ () => childArray.find((c: any) => c?.type?.componentType === "zoom"),
118
+ [childArray],
116
119
  );
117
120
 
118
121
  const rowsRaw = useMemo(() => {
119
122
  return parseRows(rowChildren);
120
123
  }, [rowChildren]);
121
124
 
122
- const rows = rowsRaw.map((r) => {
123
- if (r?.periods) {
124
- return r.periods;
125
- }
126
- return [];
127
- });
125
+ const rows = useMemo(
126
+ () =>
127
+ rowsRaw.map((r) => {
128
+ if (r?.periods) {
129
+ return r.periods;
130
+ }
131
+ return [];
132
+ }),
133
+ [rowsRaw],
134
+ );
128
135
 
129
136
  const initialStartDate = startOfDay(useEarliestDate({ startDate, rows }));
130
137
  const [start, setStart] = useState(initialStartDate);
131
- const [activeRow, setActiveRow] = useState<number | null>(null);
132
138
  const [endInclusive, setEndInclusive] = useState(
133
139
  endOfDay(useLatestDate({ endDate, rows })),
134
140
  );
@@ -165,38 +171,6 @@ export const Timeline = forwardRef<HTMLDivElement, TimelineProps>(
165
171
  }
166
172
  };
167
173
 
168
- const handleActiveRowChange = (key: string) => {
169
- if (activeRow !== null && key === "ArrowDown") {
170
- for (let i = activeRow + 1; i < processedRows.length; i++) {
171
- const row = processedRows[i];
172
- if (row.periods.find((p) => !!p.children || !!p.onSelectPeriod)) {
173
- setActiveRow(i);
174
- firstFocusabled.current.find((x) => x.id === i)?.ref?.focus();
175
- break;
176
- }
177
- }
178
- return;
179
- }
180
- if (activeRow !== null && key === "ArrowUp") {
181
- for (let i = activeRow - 1; i >= 0; i--) {
182
- const row = processedRows[i];
183
- if (row.periods.find((p) => !!p.children || !!p.onSelectPeriod)) {
184
- setActiveRow(i);
185
- firstFocusabled.current.find((x) => x.id === i)?.ref?.focus();
186
- break;
187
- }
188
- }
189
- return;
190
- }
191
- };
192
-
193
- const addFocusable = (btnRef: HTMLButtonElement | null, id: number) => {
194
- let items = firstFocusabled.current;
195
- items = items.filter((x) => x.id !== id);
196
- items.push({ ref: btnRef, id });
197
- firstFocusabled.current = items;
198
- };
199
-
200
174
  return (
201
175
  <TimelineContext.Provider
202
176
  value={{
@@ -205,44 +179,41 @@ export const Timeline = forwardRef<HTMLDivElement, TimelineProps>(
205
179
  direction,
206
180
  setStart: (d) => handleZoomChange(d),
207
181
  setEndInclusive: (d) => setEndInclusive(d),
208
- activeRow,
209
- setActiveRow: (key) => handleActiveRowChange(key),
210
- initiate: (i) => setActiveRow(i),
211
- addFocusable,
212
182
  }}
213
183
  >
214
- <div {...rest} ref={ref}>
215
- <div className="aksel-timeline">
216
- <AxisLabels templates={axisLabelTemplates} />
217
-
218
- {pins.map((PinChild, i) => (
219
- <PinChild key={`pin-${i}`} />
220
- ))}
221
-
222
- {processedRows.map((row, i) => {
223
- return (
224
- <RowContext.Provider
225
- key={`row-${row.id}`}
226
- value={{
227
- periods: row.periods,
228
- id: row.id,
229
- active: activeRow === i,
230
- index: i,
231
- }}
232
- >
233
- <TimelineRow
234
- {...row?.restProps}
235
- ref={row?.ref}
236
- label={row.label}
237
- icon={row.icon}
238
- headingTag={row.headingTag}
239
- />
240
- </RowContext.Provider>
241
- );
242
- })}
184
+ <TimelineKeyboardNavProvider>
185
+ <div {...rest} ref={forwardedRef}>
186
+ <div className="aksel-timeline">
187
+ <AxisLabels templates={axisLabelTemplates} />
188
+
189
+ {pins.map((PinChild, i) => (
190
+ <PinChild key={`pin-${i}`} />
191
+ ))}
192
+
193
+ {processedRows.map((row, i) => {
194
+ return (
195
+ <RowContext.Provider
196
+ key={`row-${row.id}`}
197
+ value={{
198
+ periods: row.periods,
199
+ id: row.id,
200
+ index: i,
201
+ }}
202
+ >
203
+ <TimelineRow
204
+ {...row?.restProps}
205
+ ref={row?.ref}
206
+ label={row.label}
207
+ icon={row.icon}
208
+ headingTag={row.headingTag}
209
+ />
210
+ </RowContext.Provider>
211
+ );
212
+ })}
213
+ </div>
214
+ {zoomComponent}
243
215
  </div>
244
- {zoomComponent}
245
- </div>
216
+ </TimelineKeyboardNavProvider>
246
217
  </TimelineContext.Provider>
247
218
  );
248
219
  },