@digdir/designsystemet-react 0.62.0 → 1.0.0-next.14

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 (501) hide show
  1. package/dist/cjs/components/Accordion/{AccordionContent/AccordionContent.js → AccordionContent.js} +10 -5
  2. package/dist/cjs/components/Accordion/AccordionHeading.js +31 -0
  3. package/dist/cjs/components/Accordion/{AccordionItem/AccordionItem.js → AccordionItem.js} +10 -2
  4. package/dist/cjs/components/Accordion/AccordionRoot.js +16 -0
  5. package/dist/cjs/components/Accordion/index.js +22 -9
  6. package/dist/cjs/components/Alert/Alert.js +7 -4
  7. package/dist/cjs/components/Box/Box.js +1 -4
  8. package/dist/cjs/components/Button/Button.js +5 -4
  9. package/dist/cjs/components/Card/Card.js +11 -2
  10. package/dist/cjs/components/Card/CardContent.js +2 -1
  11. package/dist/cjs/components/Card/CardFooter.js +2 -1
  12. package/dist/cjs/components/Card/CardHeader.js +2 -1
  13. package/dist/cjs/components/Card/CardMedia.js +1 -1
  14. package/dist/cjs/components/Chip/Group/Group.js +2 -4
  15. package/dist/cjs/components/Chip/Removable/Removable.js +2 -4
  16. package/dist/cjs/components/Chip/Toggle/Toggle.js +2 -4
  17. package/dist/cjs/components/Divider/Divider.js +1 -1
  18. package/dist/cjs/components/DropdownMenu/DropdownMenuContent.js +4 -4
  19. package/dist/cjs/components/DropdownMenu/DropdownMenuGroup.js +3 -3
  20. package/dist/cjs/components/DropdownMenu/DropdownMenuItem.js +3 -3
  21. package/dist/cjs/components/DropdownMenu/{DropdownMenu.js → DropdownMenuRoot.js} +15 -5
  22. package/dist/cjs/components/DropdownMenu/DropdownMenuTrigger.js +2 -2
  23. package/dist/cjs/components/DropdownMenu/index.js +16 -2
  24. package/dist/cjs/components/ErrorSummary/ErrorSummaryHeading.js +1 -1
  25. package/dist/cjs/components/ErrorSummary/ErrorSummaryRoot.js +1 -1
  26. package/dist/cjs/components/ErrorSummary/index.js +9 -0
  27. package/dist/cjs/components/HelpText/HelpText.js +4 -5
  28. package/dist/cjs/components/Link/Link.js +2 -2
  29. package/dist/cjs/components/List/ListItem.js +1 -1
  30. package/dist/cjs/components/List/ListRoot.js +1 -3
  31. package/dist/cjs/components/List/Lists.js +4 -4
  32. package/dist/cjs/components/Modal/ModaContent.js +1 -1
  33. package/dist/cjs/components/Modal/ModalDialog.js +10 -9
  34. package/dist/cjs/components/Modal/ModalFooter.js +1 -1
  35. package/dist/cjs/components/Modal/ModalHeader.js +2 -2
  36. package/dist/cjs/components/Modal/ModalRoot.js +7 -1
  37. package/dist/cjs/components/Modal/index.js +1 -1
  38. package/dist/cjs/components/Pagination/Pagination.js +3 -5
  39. package/dist/cjs/components/Pagination/PaginationButton.js +2 -1
  40. package/dist/cjs/components/Pagination/PaginationContent.js +2 -1
  41. package/dist/cjs/components/Pagination/PaginationEllipsis.js +2 -5
  42. package/dist/cjs/components/Pagination/PaginationItem.js +2 -5
  43. package/dist/cjs/components/Pagination/PaginationNextPrev.js +2 -0
  44. package/dist/cjs/components/Pagination/PaginationRoot.js +2 -7
  45. package/dist/cjs/components/Pagination/index.js +6 -6
  46. package/dist/cjs/components/Popover/PopoverContent.js +5 -5
  47. package/dist/cjs/components/Popover/{Popover.js → PopoverRoot.js} +3 -5
  48. package/dist/cjs/components/Popover/PopoverTrigger.js +2 -2
  49. package/dist/cjs/components/Popover/index.js +5 -2
  50. package/dist/cjs/components/Skeleton/Circle/Circle.js +3 -3
  51. package/dist/cjs/components/Skeleton/Rectangle/Rectangle.js +3 -3
  52. package/dist/cjs/components/Skeleton/Text/Text.js +3 -3
  53. package/dist/cjs/components/SkipLink/SkipLink.js +1 -1
  54. package/dist/cjs/components/Spinner/Spinner.js +5 -7
  55. package/dist/cjs/components/Table/Table.js +2 -4
  56. package/dist/cjs/components/Table/TableCell.js +1 -1
  57. package/dist/cjs/components/Table/TableHead.js +1 -1
  58. package/dist/cjs/components/Table/TableHeaderCell.js +1 -1
  59. package/dist/cjs/components/Table/TableRow.js +1 -1
  60. package/dist/cjs/components/Tabs/Tab.js +23 -0
  61. package/dist/cjs/components/Tabs/TabContent.js +24 -0
  62. package/dist/cjs/components/Tabs/TabList.js +26 -0
  63. package/dist/cjs/components/Tabs/{Tabs.js → TabsRoot.js} +21 -6
  64. package/dist/cjs/components/Tabs/index.js +24 -5
  65. package/dist/cjs/components/Tabs/{Tab/useTab.js → useTab.js} +3 -2
  66. package/dist/cjs/components/Tag/Tag.js +7 -4
  67. package/dist/cjs/components/ToggleGroup/ToggleGroupItem/ToggleGroupItem.js +8 -3
  68. package/dist/cjs/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.js +8 -6
  69. package/dist/cjs/components/ToggleGroup/{ToggleGroup.js → ToggleGroupRoot.js} +10 -13
  70. package/dist/cjs/components/ToggleGroup/index.js +16 -2
  71. package/dist/cjs/components/Tooltip/Tooltip.js +14 -6
  72. package/dist/cjs/components/Typography/ErrorMessage/ErrorMessage.js +2 -4
  73. package/dist/cjs/components/Typography/Heading/Heading.js +8 -5
  74. package/dist/cjs/components/Typography/Ingress/Ingress.js +8 -5
  75. package/dist/cjs/components/Typography/Label/Label.js +8 -5
  76. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +13 -5
  77. package/dist/cjs/components/form/CharacterCounter.js +1 -1
  78. package/dist/cjs/components/form/Checkbox/Checkbox.js +2 -2
  79. package/dist/cjs/components/form/Checkbox/Group/Group.js +1 -1
  80. package/dist/cjs/components/form/Combobox/Combobox.js +22 -21
  81. package/dist/cjs/components/form/Combobox/Custom.js +5 -8
  82. package/dist/cjs/components/form/Combobox/Empty.js +3 -5
  83. package/dist/cjs/components/form/Combobox/Option/Description.js +2 -5
  84. package/dist/cjs/components/form/Combobox/Option/Option.js +5 -5
  85. package/dist/cjs/components/form/Combobox/Option/SelectedIcon.js +1 -4
  86. package/dist/cjs/components/form/Combobox/Option/useComboboxOption.js +7 -6
  87. package/dist/cjs/components/form/Combobox/internal/ComboboxChips.js +1 -4
  88. package/dist/cjs/components/form/Combobox/internal/ComboboxClearButton.js +4 -7
  89. package/dist/cjs/components/form/Combobox/internal/ComboboxError.js +3 -6
  90. package/dist/cjs/components/form/Combobox/internal/ComboboxInput.js +25 -21
  91. package/dist/cjs/components/form/Combobox/internal/ComboboxLabel.js +2 -5
  92. package/dist/cjs/components/form/Combobox/internal/ComboboxNative.js +4 -7
  93. package/dist/cjs/components/form/Combobox/useCombobox.js +38 -12
  94. package/dist/cjs/components/form/Combobox/useComboboxKeyboard.js +2 -2
  95. package/dist/cjs/components/form/Combobox/useFloatingCombobox.js +1 -1
  96. package/dist/cjs/components/form/Fieldset/Fieldset.js +1 -1
  97. package/dist/cjs/components/form/NativeSelect/NativeSelect.js +2 -2
  98. package/dist/cjs/components/form/NativeSelect/useNativeSelect.js +1 -3
  99. package/dist/cjs/components/form/Radio/Group/Group.js +1 -1
  100. package/dist/cjs/components/form/Radio/Radio.js +2 -2
  101. package/dist/cjs/components/form/Search/Search.js +5 -6
  102. package/dist/cjs/components/form/Search/useSearch.js +1 -3
  103. package/dist/cjs/components/form/Switch/Switch.js +2 -2
  104. package/dist/cjs/components/form/Switch/useSwitch.js +1 -0
  105. package/dist/cjs/components/form/Textarea/Textarea.js +3 -3
  106. package/dist/cjs/components/form/Textarea/useTextarea.js +1 -3
  107. package/dist/cjs/components/form/Textfield/Textfield.js +3 -3
  108. package/dist/cjs/components/form/Textfield/useTextfield.js +1 -3
  109. package/dist/cjs/components/form/useFormField.js +4 -3
  110. package/dist/cjs/index.js +34 -10
  111. package/dist/cjs/node_modules/@radix-ui/react-slot/dist/index.js +1 -1
  112. package/dist/cjs/node_modules/@tanstack/virtual-core/dist/esm/index.js +77 -71
  113. package/dist/cjs/node_modules/@tanstack/virtual-core/dist/esm/utils.js +8 -0
  114. package/dist/cjs/utilities/AnimateHeight/AnimateHeight.js +3 -3
  115. package/dist/cjs/utilities/{RovingTabIndex/RovingTabindexItem.js → RovingFocus/RovingFocusItem.js} +6 -6
  116. package/dist/cjs/utilities/{RovingTabIndex/RovingTabindexRoot.js → RovingFocus/RovingFocusRoot.js} +11 -7
  117. package/dist/cjs/utilities/{RovingTabIndex/useRovingTabindex.js → RovingFocus/useRovingFocus.js} +5 -5
  118. package/dist/cjs/utilities/{useDebounce.js → hooks/useDebounceCallback/useDebounceCallback.js} +2 -2
  119. package/dist/cjs/{hooks → utilities/hooks/useIsomorphicLayoutEffect}/useIsomorphicLayoutEffect.js +1 -0
  120. package/dist/cjs/utilities/hooks/useMediaQuery/useMediaQuery.js +49 -0
  121. package/dist/cjs/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js +46 -0
  122. package/dist/esm/components/Accordion/{AccordionContent/AccordionContent.js → AccordionContent.js} +10 -5
  123. package/dist/esm/components/Accordion/AccordionHeading.js +29 -0
  124. package/dist/esm/components/Accordion/{AccordionItem/AccordionItem.js → AccordionItem.js} +10 -2
  125. package/dist/esm/components/Accordion/AccordionRoot.js +14 -0
  126. package/dist/esm/components/Accordion/index.js +20 -8
  127. package/dist/esm/components/Alert/Alert.js +7 -4
  128. package/dist/esm/components/Box/Box.js +1 -4
  129. package/dist/esm/components/Button/Button.js +5 -4
  130. package/dist/esm/components/Card/Card.js +11 -2
  131. package/dist/esm/components/Card/CardContent.js +2 -1
  132. package/dist/esm/components/Card/CardFooter.js +2 -1
  133. package/dist/esm/components/Card/CardHeader.js +2 -1
  134. package/dist/esm/components/Card/CardMedia.js +1 -1
  135. package/dist/esm/components/Chip/Group/Group.js +2 -4
  136. package/dist/esm/components/Chip/Removable/Removable.js +2 -4
  137. package/dist/esm/components/Chip/Toggle/Toggle.js +2 -4
  138. package/dist/esm/components/Divider/Divider.js +1 -1
  139. package/dist/esm/components/DropdownMenu/DropdownMenuContent.js +3 -3
  140. package/dist/esm/components/DropdownMenu/DropdownMenuGroup.js +2 -2
  141. package/dist/esm/components/DropdownMenu/DropdownMenuItem.js +2 -2
  142. package/dist/esm/components/DropdownMenu/{DropdownMenu.js → DropdownMenuRoot.js} +15 -5
  143. package/dist/esm/components/DropdownMenu/DropdownMenuTrigger.js +1 -1
  144. package/dist/esm/components/DropdownMenu/index.js +16 -3
  145. package/dist/esm/components/ErrorSummary/ErrorSummaryHeading.js +1 -1
  146. package/dist/esm/components/ErrorSummary/ErrorSummaryRoot.js +1 -1
  147. package/dist/esm/components/ErrorSummary/index.js +9 -0
  148. package/dist/esm/components/HelpText/HelpText.js +4 -5
  149. package/dist/esm/components/Link/Link.js +2 -2
  150. package/dist/esm/components/List/ListItem.js +1 -1
  151. package/dist/esm/components/List/ListRoot.js +1 -3
  152. package/dist/esm/components/List/Lists.js +4 -4
  153. package/dist/esm/components/Modal/ModaContent.js +1 -1
  154. package/dist/esm/components/Modal/ModalDialog.js +10 -9
  155. package/dist/esm/components/Modal/ModalFooter.js +1 -1
  156. package/dist/esm/components/Modal/ModalHeader.js +2 -2
  157. package/dist/esm/components/Modal/ModalRoot.js +8 -2
  158. package/dist/esm/components/Modal/index.js +1 -1
  159. package/dist/esm/components/Pagination/Pagination.js +3 -5
  160. package/dist/esm/components/Pagination/PaginationButton.js +2 -1
  161. package/dist/esm/components/Pagination/PaginationContent.js +2 -1
  162. package/dist/esm/components/Pagination/PaginationEllipsis.js +3 -3
  163. package/dist/esm/components/Pagination/PaginationItem.js +3 -3
  164. package/dist/esm/components/Pagination/PaginationNextPrev.js +2 -0
  165. package/dist/esm/components/Pagination/PaginationRoot.js +3 -5
  166. package/dist/esm/components/Pagination/index.js +3 -3
  167. package/dist/esm/components/Popover/PopoverContent.js +4 -4
  168. package/dist/esm/components/Popover/{Popover.js → PopoverRoot.js} +3 -5
  169. package/dist/esm/components/Popover/PopoverTrigger.js +1 -1
  170. package/dist/esm/components/Popover/index.js +5 -3
  171. package/dist/esm/components/Skeleton/Circle/Circle.js +3 -3
  172. package/dist/esm/components/Skeleton/Rectangle/Rectangle.js +3 -3
  173. package/dist/esm/components/Skeleton/Text/Text.js +3 -3
  174. package/dist/esm/components/SkipLink/SkipLink.js +1 -1
  175. package/dist/esm/components/Spinner/Spinner.js +5 -7
  176. package/dist/esm/components/Table/Table.js +2 -4
  177. package/dist/esm/components/Table/TableCell.js +1 -1
  178. package/dist/esm/components/Table/TableHead.js +1 -1
  179. package/dist/esm/components/Table/TableHeaderCell.js +1 -1
  180. package/dist/esm/components/Table/TableRow.js +1 -1
  181. package/dist/esm/components/Tabs/Tab.js +21 -0
  182. package/dist/esm/components/Tabs/TabContent.js +22 -0
  183. package/dist/esm/components/Tabs/TabList.js +24 -0
  184. package/dist/esm/components/Tabs/TabsRoot.js +43 -0
  185. package/dist/esm/components/Tabs/index.js +24 -6
  186. package/dist/esm/components/Tabs/{Tab/useTab.js → useTab.js} +2 -1
  187. package/dist/esm/components/Tag/Tag.js +7 -4
  188. package/dist/esm/components/ToggleGroup/ToggleGroupItem/ToggleGroupItem.js +8 -3
  189. package/dist/esm/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.js +8 -6
  190. package/dist/esm/components/ToggleGroup/{ToggleGroup.js → ToggleGroupRoot.js} +10 -13
  191. package/dist/esm/components/ToggleGroup/index.js +16 -3
  192. package/dist/esm/components/Tooltip/Tooltip.js +14 -6
  193. package/dist/esm/components/Typography/ErrorMessage/ErrorMessage.js +2 -4
  194. package/dist/esm/components/Typography/Heading/Heading.js +8 -5
  195. package/dist/esm/components/Typography/Ingress/Ingress.js +8 -5
  196. package/dist/esm/components/Typography/Label/Label.js +8 -5
  197. package/dist/esm/components/Typography/Paragraph/Paragraph.js +13 -5
  198. package/dist/esm/components/form/CharacterCounter.js +1 -1
  199. package/dist/esm/components/form/Checkbox/Checkbox.js +2 -2
  200. package/dist/esm/components/form/Checkbox/Group/Group.js +1 -1
  201. package/dist/esm/components/form/Combobox/Combobox.js +24 -23
  202. package/dist/esm/components/form/Combobox/Custom.js +6 -6
  203. package/dist/esm/components/form/Combobox/Empty.js +4 -3
  204. package/dist/esm/components/form/Combobox/Option/Description.js +2 -2
  205. package/dist/esm/components/form/Combobox/Option/Option.js +6 -6
  206. package/dist/esm/components/form/Combobox/Option/SelectedIcon.js +2 -2
  207. package/dist/esm/components/form/Combobox/Option/useComboboxOption.js +7 -6
  208. package/dist/esm/components/form/Combobox/internal/ComboboxChips.js +1 -1
  209. package/dist/esm/components/form/Combobox/internal/ComboboxClearButton.js +5 -5
  210. package/dist/esm/components/form/Combobox/internal/ComboboxError.js +3 -3
  211. package/dist/esm/components/form/Combobox/internal/ComboboxInput.js +27 -20
  212. package/dist/esm/components/form/Combobox/internal/ComboboxLabel.js +2 -2
  213. package/dist/esm/components/form/Combobox/internal/ComboboxNative.js +4 -4
  214. package/dist/esm/components/form/Combobox/useCombobox.js +38 -14
  215. package/dist/esm/components/form/Combobox/useComboboxKeyboard.js +2 -2
  216. package/dist/esm/components/form/Combobox/useFloatingCombobox.js +1 -1
  217. package/dist/esm/components/form/Fieldset/Fieldset.js +1 -1
  218. package/dist/esm/components/form/NativeSelect/NativeSelect.js +2 -2
  219. package/dist/esm/components/form/NativeSelect/useNativeSelect.js +1 -3
  220. package/dist/esm/components/form/Radio/Group/Group.js +1 -1
  221. package/dist/esm/components/form/Radio/Radio.js +2 -2
  222. package/dist/esm/components/form/Search/Search.js +5 -6
  223. package/dist/esm/components/form/Search/useSearch.js +1 -3
  224. package/dist/esm/components/form/Switch/Switch.js +2 -2
  225. package/dist/esm/components/form/Switch/useSwitch.js +1 -0
  226. package/dist/esm/components/form/Textarea/Textarea.js +3 -3
  227. package/dist/esm/components/form/Textarea/useTextarea.js +1 -3
  228. package/dist/esm/components/form/Textfield/Textfield.js +3 -3
  229. package/dist/esm/components/form/Textfield/useTextfield.js +1 -3
  230. package/dist/esm/components/form/useFormField.js +4 -3
  231. package/dist/esm/index.js +20 -9
  232. package/dist/esm/node_modules/@radix-ui/react-slot/dist/index.js +1 -1
  233. package/dist/esm/node_modules/@tanstack/virtual-core/dist/esm/index.js +78 -73
  234. package/dist/esm/node_modules/@tanstack/virtual-core/dist/esm/utils.js +8 -1
  235. package/dist/esm/utilities/AnimateHeight/AnimateHeight.js +3 -3
  236. package/dist/esm/utilities/{RovingTabIndex/RovingTabindexItem.js → RovingFocus/RovingFocusItem.js} +6 -6
  237. package/dist/esm/utilities/{RovingTabIndex/RovingTabindexRoot.js → RovingFocus/RovingFocusRoot.js} +11 -7
  238. package/dist/esm/utilities/{RovingTabIndex/useRovingTabindex.js → RovingFocus/useRovingFocus.js} +5 -5
  239. package/dist/esm/utilities/{useDebounce.js → hooks/useDebounceCallback/useDebounceCallback.js} +2 -2
  240. package/dist/esm/{hooks → utilities/hooks/useIsomorphicLayoutEffect}/useIsomorphicLayoutEffect.js +1 -0
  241. package/dist/esm/utilities/hooks/useMediaQuery/useMediaQuery.js +47 -0
  242. package/dist/esm/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js +44 -0
  243. package/dist/types/components/Accordion/AccordionContent.d.ts +9 -0
  244. package/dist/types/components/Accordion/AccordionContent.d.ts.map +1 -0
  245. package/dist/types/components/Accordion/{AccordionHeader/AccordionHeader.d.ts → AccordionHeading.d.ts} +15 -4
  246. package/dist/types/components/Accordion/AccordionHeading.d.ts.map +1 -0
  247. package/dist/types/components/Accordion/{AccordionItem/AccordionItem.d.ts → AccordionItem.d.ts} +22 -3
  248. package/dist/types/components/Accordion/AccordionItem.d.ts.map +1 -0
  249. package/dist/types/components/Accordion/AccordionRoot.d.ts +33 -0
  250. package/dist/types/components/Accordion/AccordionRoot.d.ts.map +1 -0
  251. package/dist/types/components/Accordion/index.d.ts +19 -8
  252. package/dist/types/components/Accordion/index.d.ts.map +1 -1
  253. package/dist/types/components/Alert/Alert.d.ts +23 -17
  254. package/dist/types/components/Alert/Alert.d.ts.map +1 -1
  255. package/dist/types/components/Box/Box.d.ts +5 -8
  256. package/dist/types/components/Box/Box.d.ts.map +1 -1
  257. package/dist/types/components/Button/Button.d.ts +30 -16
  258. package/dist/types/components/Button/Button.d.ts.map +1 -1
  259. package/dist/types/components/Card/Card.d.ts +11 -10
  260. package/dist/types/components/Card/Card.d.ts.map +1 -1
  261. package/dist/types/components/Card/CardContent.d.ts.map +1 -1
  262. package/dist/types/components/Card/CardFooter.d.ts.map +1 -1
  263. package/dist/types/components/Card/CardHeader.d.ts.map +1 -1
  264. package/dist/types/components/Chip/Group/Group.d.ts +1 -5
  265. package/dist/types/components/Chip/Group/Group.d.ts.map +1 -1
  266. package/dist/types/components/Chip/Removable/Removable.d.ts +0 -2
  267. package/dist/types/components/Chip/Removable/Removable.d.ts.map +1 -1
  268. package/dist/types/components/Chip/Toggle/Toggle.d.ts +0 -2
  269. package/dist/types/components/Chip/Toggle/Toggle.d.ts.map +1 -1
  270. package/dist/types/components/Divider/Divider.d.ts +1 -1
  271. package/dist/types/components/DropdownMenu/{DropdownMenu.d.ts → DropdownMenuRoot.d.ts} +20 -10
  272. package/dist/types/components/DropdownMenu/DropdownMenuRoot.d.ts.map +1 -0
  273. package/dist/types/components/DropdownMenu/DropdownMenuTrigger.d.ts +6 -4
  274. package/dist/types/components/DropdownMenu/DropdownMenuTrigger.d.ts.map +1 -1
  275. package/dist/types/components/DropdownMenu/index.d.ts +16 -4
  276. package/dist/types/components/DropdownMenu/index.d.ts.map +1 -1
  277. package/dist/types/components/ErrorSummary/ErrorSummaryHeading.d.ts.map +1 -1
  278. package/dist/types/components/ErrorSummary/index.d.ts +9 -0
  279. package/dist/types/components/ErrorSummary/index.d.ts.map +1 -1
  280. package/dist/types/components/HelpText/HelpText.d.ts +3 -4
  281. package/dist/types/components/HelpText/HelpText.d.ts.map +1 -1
  282. package/dist/types/components/Link/Link.d.ts +10 -4
  283. package/dist/types/components/Link/Link.d.ts.map +1 -1
  284. package/dist/types/components/List/ListHeading.d.ts +1 -1
  285. package/dist/types/components/List/ListRoot.d.ts +2 -5
  286. package/dist/types/components/List/ListRoot.d.ts.map +1 -1
  287. package/dist/types/components/Modal/ModalRoot.d.ts +1 -0
  288. package/dist/types/components/Modal/ModalRoot.d.ts.map +1 -1
  289. package/dist/types/components/Modal/ModalTrigger.d.ts +6 -4
  290. package/dist/types/components/Modal/ModalTrigger.d.ts.map +1 -1
  291. package/dist/types/components/Modal/index.d.ts +1 -1
  292. package/dist/types/components/Modal/index.d.ts.map +1 -1
  293. package/dist/types/components/Pagination/Pagination.d.ts +4 -7
  294. package/dist/types/components/Pagination/Pagination.d.ts.map +1 -1
  295. package/dist/types/components/Pagination/PaginationButton.d.ts +1 -1
  296. package/dist/types/components/Pagination/PaginationButton.d.ts.map +1 -1
  297. package/dist/types/components/Pagination/PaginationEllipsis.d.ts +2 -2
  298. package/dist/types/components/Pagination/PaginationEllipsis.d.ts.map +1 -1
  299. package/dist/types/components/Pagination/PaginationItem.d.ts +2 -2
  300. package/dist/types/components/Pagination/PaginationItem.d.ts.map +1 -1
  301. package/dist/types/components/Pagination/PaginationNextPrev.d.ts +5 -4
  302. package/dist/types/components/Pagination/PaginationNextPrev.d.ts.map +1 -1
  303. package/dist/types/components/Pagination/PaginationRoot.d.ts +2 -4
  304. package/dist/types/components/Pagination/PaginationRoot.d.ts.map +1 -1
  305. package/dist/types/components/Pagination/index.d.ts +7 -7
  306. package/dist/types/components/Pagination/index.d.ts.map +1 -1
  307. package/dist/types/components/Popover/{Popover.d.ts → PopoverRoot.d.ts} +9 -12
  308. package/dist/types/components/Popover/PopoverRoot.d.ts.map +1 -0
  309. package/dist/types/components/Popover/PopoverTrigger.d.ts +6 -4
  310. package/dist/types/components/Popover/PopoverTrigger.d.ts.map +1 -1
  311. package/dist/types/components/Popover/index.d.ts +6 -5
  312. package/dist/types/components/Popover/index.d.ts.map +1 -1
  313. package/dist/types/components/Spinner/Spinner.d.ts +7 -7
  314. package/dist/types/components/Spinner/Spinner.d.ts.map +1 -1
  315. package/dist/types/components/Table/Table.d.ts +2 -6
  316. package/dist/types/components/Table/Table.d.ts.map +1 -1
  317. package/dist/types/components/Table/index.d.ts +7 -0
  318. package/dist/types/components/Table/index.d.ts.map +1 -1
  319. package/dist/types/components/Tabs/{Tab/Tab.d.ts → Tab.d.ts} +7 -2
  320. package/dist/types/components/Tabs/Tab.d.ts.map +1 -0
  321. package/dist/types/components/Tabs/{TabContent/TabContent.d.ts → TabContent.d.ts} +7 -0
  322. package/dist/types/components/Tabs/TabContent.d.ts.map +1 -0
  323. package/dist/types/components/Tabs/TabList.d.ts +13 -0
  324. package/dist/types/components/Tabs/TabList.d.ts.map +1 -0
  325. package/dist/types/components/Tabs/{Tabs.d.ts → TabsRoot.d.ts} +19 -21
  326. package/dist/types/components/Tabs/TabsRoot.d.ts.map +1 -0
  327. package/dist/types/components/Tabs/index.d.ts +21 -4
  328. package/dist/types/components/Tabs/index.d.ts.map +1 -1
  329. package/dist/types/components/Tabs/useTab.d.ts +10 -0
  330. package/dist/types/components/Tabs/useTab.d.ts.map +1 -0
  331. package/dist/types/components/Tag/Tag.d.ts +12 -7
  332. package/dist/types/components/Tag/Tag.d.ts.map +1 -1
  333. package/dist/types/components/Tag/index.d.ts +1 -2
  334. package/dist/types/components/Tag/index.d.ts.map +1 -1
  335. package/dist/types/components/ToggleGroup/ToggleGroupItem/ToggleGroupItem.d.ts +13 -2
  336. package/dist/types/components/ToggleGroup/ToggleGroupItem/ToggleGroupItem.d.ts.map +1 -1
  337. package/dist/types/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.d.ts +3 -2
  338. package/dist/types/components/ToggleGroup/ToggleGroupItem/useToggleGroupitem.d.ts.map +1 -1
  339. package/dist/types/components/ToggleGroup/{ToggleGroup.d.ts → ToggleGroupRoot.d.ts} +7 -10
  340. package/dist/types/components/ToggleGroup/ToggleGroupRoot.d.ts.map +1 -0
  341. package/dist/types/components/ToggleGroup/index.d.ts +16 -4
  342. package/dist/types/components/ToggleGroup/index.d.ts.map +1 -1
  343. package/dist/types/components/Tooltip/Tooltip.d.ts +24 -22
  344. package/dist/types/components/Tooltip/Tooltip.d.ts.map +1 -1
  345. package/dist/types/components/Typography/ErrorMessage/ErrorMessage.d.ts +2 -6
  346. package/dist/types/components/Typography/ErrorMessage/ErrorMessage.d.ts.map +1 -1
  347. package/dist/types/components/Typography/Heading/Heading.d.ts +16 -9
  348. package/dist/types/components/Typography/Heading/Heading.d.ts.map +1 -1
  349. package/dist/types/components/Typography/Ingress/Ingress.d.ts +8 -7
  350. package/dist/types/components/Typography/Ingress/Ingress.d.ts.map +1 -1
  351. package/dist/types/components/Typography/Label/Label.d.ts +18 -14
  352. package/dist/types/components/Typography/Label/Label.d.ts.map +1 -1
  353. package/dist/types/components/Typography/Paragraph/Paragraph.d.ts +20 -13
  354. package/dist/types/components/Typography/Paragraph/Paragraph.d.ts.map +1 -1
  355. package/dist/types/components/form/Combobox/Combobox.d.ts +24 -18
  356. package/dist/types/components/form/Combobox/Combobox.d.ts.map +1 -1
  357. package/dist/types/components/form/Combobox/ComboboxContext.d.ts +1 -0
  358. package/dist/types/components/form/Combobox/ComboboxContext.d.ts.map +1 -1
  359. package/dist/types/components/form/Combobox/Custom.d.ts +2 -2
  360. package/dist/types/components/form/Combobox/Custom.d.ts.map +1 -1
  361. package/dist/types/components/form/Combobox/Empty.d.ts +2 -2
  362. package/dist/types/components/form/Combobox/Empty.d.ts.map +1 -1
  363. package/dist/types/components/form/Combobox/Option/Description.d.ts +1 -1
  364. package/dist/types/components/form/Combobox/Option/Description.d.ts.map +1 -1
  365. package/dist/types/components/form/Combobox/Option/Option.d.ts +2 -1
  366. package/dist/types/components/form/Combobox/Option/Option.d.ts.map +1 -1
  367. package/dist/types/components/form/Combobox/Option/SelectedIcon.d.ts +2 -2
  368. package/dist/types/components/form/Combobox/Option/SelectedIcon.d.ts.map +1 -1
  369. package/dist/types/components/form/Combobox/Option/useComboboxOption.d.ts +1 -1
  370. package/dist/types/components/form/Combobox/Option/useComboboxOption.d.ts.map +1 -1
  371. package/dist/types/components/form/Combobox/internal/ComboboxChips.d.ts +1 -1
  372. package/dist/types/components/form/Combobox/internal/ComboboxChips.d.ts.map +1 -1
  373. package/dist/types/components/form/Combobox/internal/ComboboxClearButton.d.ts +1 -4
  374. package/dist/types/components/form/Combobox/internal/ComboboxClearButton.d.ts.map +1 -1
  375. package/dist/types/components/form/Combobox/internal/ComboboxError.d.ts +2 -2
  376. package/dist/types/components/form/Combobox/internal/ComboboxError.d.ts.map +1 -1
  377. package/dist/types/components/form/Combobox/internal/ComboboxInput.d.ts +1 -1
  378. package/dist/types/components/form/Combobox/internal/ComboboxInput.d.ts.map +1 -1
  379. package/dist/types/components/form/Combobox/internal/ComboboxLabel.d.ts +1 -1
  380. package/dist/types/components/form/Combobox/internal/ComboboxLabel.d.ts.map +1 -1
  381. package/dist/types/components/form/Combobox/internal/ComboboxNative.d.ts +1 -1
  382. package/dist/types/components/form/Combobox/internal/ComboboxNative.d.ts.map +1 -1
  383. package/dist/types/components/form/Combobox/useCombobox.d.ts +7 -0
  384. package/dist/types/components/form/Combobox/useCombobox.d.ts.map +1 -1
  385. package/dist/types/components/form/Combobox/useFloatingCombobox.d.ts +1 -1
  386. package/dist/types/components/form/Fieldset/Fieldset.d.ts.map +1 -1
  387. package/dist/types/components/form/Fieldset/useFieldset.d.ts +2 -2
  388. package/dist/types/components/form/NativeSelect/NativeSelect.d.ts +2 -6
  389. package/dist/types/components/form/NativeSelect/NativeSelect.d.ts.map +1 -1
  390. package/dist/types/components/form/NativeSelect/useNativeSelect.d.ts.map +1 -1
  391. package/dist/types/components/form/Search/Search.d.ts +4 -8
  392. package/dist/types/components/form/Search/Search.d.ts.map +1 -1
  393. package/dist/types/components/form/Search/useSearch.d.ts.map +1 -1
  394. package/dist/types/components/form/Switch/Switch.d.ts.map +1 -1
  395. package/dist/types/components/form/Switch/useSwitch.d.ts.map +1 -1
  396. package/dist/types/components/form/Textarea/Textarea.d.ts +1 -1
  397. package/dist/types/components/form/Textarea/useTextarea.d.ts.map +1 -1
  398. package/dist/types/components/form/Textfield/Textfield.d.ts +2 -6
  399. package/dist/types/components/form/Textfield/Textfield.d.ts.map +1 -1
  400. package/dist/types/components/form/Textfield/useTextfield.d.ts.map +1 -1
  401. package/dist/types/components/form/useFormField.d.ts +1 -4
  402. package/dist/types/components/form/useFormField.d.ts.map +1 -1
  403. package/dist/types/index.d.ts +1 -0
  404. package/dist/types/index.d.ts.map +1 -1
  405. package/dist/types/types/Portal.d.ts +1 -1
  406. package/dist/types/utilities/RovingFocus/RovingFocusItem.d.ts +16 -0
  407. package/dist/types/utilities/RovingFocus/RovingFocusItem.d.ts.map +1 -0
  408. package/dist/types/utilities/{RovingTabIndex/RovingTabindexRoot.d.ts → RovingFocus/RovingFocusRoot.d.ts} +9 -9
  409. package/dist/types/utilities/RovingFocus/RovingFocusRoot.d.ts.map +1 -0
  410. package/dist/types/utilities/RovingFocus/index.d.ts +4 -0
  411. package/dist/types/utilities/RovingFocus/index.d.ts.map +1 -0
  412. package/dist/types/utilities/{RovingTabIndex/useRovingTabindex.d.ts → RovingFocus/useRovingFocus.d.ts} +8 -10
  413. package/dist/types/utilities/RovingFocus/useRovingFocus.d.ts.map +1 -0
  414. package/dist/types/utilities/hooks/index.d.ts +6 -0
  415. package/dist/types/utilities/hooks/index.d.ts.map +1 -0
  416. package/dist/types/utilities/hooks/useDebounceCallback/useDebounceCallback.d.ts +4 -0
  417. package/dist/types/utilities/hooks/useDebounceCallback/useDebounceCallback.d.ts.map +1 -0
  418. package/dist/types/utilities/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.d.ts.map +1 -0
  419. package/dist/types/utilities/hooks/useMediaQuery/useMediaQuery.d.ts +7 -0
  420. package/dist/types/utilities/hooks/useMediaQuery/useMediaQuery.d.ts.map +1 -0
  421. package/dist/types/utilities/hooks/usePrevious.d.ts.map +1 -0
  422. package/dist/types/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.d.ts +14 -0
  423. package/dist/types/utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.d.ts.map +1 -0
  424. package/dist/types/utilities/index.d.ts +3 -1
  425. package/dist/types/utilities/index.d.ts.map +1 -1
  426. package/dist/types/utilities/{objectUtils.d.ts → omit/omit.d.ts} +1 -1
  427. package/dist/types/utilities/omit/omit.d.ts.map +1 -0
  428. package/package.json +10 -7
  429. package/LICENSE +0 -7
  430. package/dist/cjs/components/Accordion/Accordion.js +0 -11
  431. package/dist/cjs/components/Accordion/AccordionHeader/AccordionHeader.js +0 -26
  432. package/dist/cjs/components/Tabs/Tab/Tab.js +0 -17
  433. package/dist/cjs/components/Tabs/TabContent/TabContent.js +0 -16
  434. package/dist/cjs/components/Tabs/TabList/TabList.js +0 -14
  435. package/dist/cjs/hooks/useMediaQuery.js +0 -27
  436. package/dist/cjs/hooks/useSynchronizedAnimation.js +0 -33
  437. package/dist/cjs/utilities/getSize.js +0 -31
  438. package/dist/esm/components/Accordion/Accordion.js +0 -9
  439. package/dist/esm/components/Accordion/AccordionHeader/AccordionHeader.js +0 -24
  440. package/dist/esm/components/Tabs/Tab/Tab.js +0 -15
  441. package/dist/esm/components/Tabs/TabContent/TabContent.js +0 -14
  442. package/dist/esm/components/Tabs/TabList/TabList.js +0 -12
  443. package/dist/esm/components/Tabs/Tabs.js +0 -28
  444. package/dist/esm/hooks/useMediaQuery.js +0 -25
  445. package/dist/esm/hooks/useSynchronizedAnimation.js +0 -31
  446. package/dist/esm/utilities/getSize.js +0 -29
  447. package/dist/types/components/Accordion/Accordion.d.ts +0 -18
  448. package/dist/types/components/Accordion/Accordion.d.ts.map +0 -1
  449. package/dist/types/components/Accordion/AccordionContent/AccordionContent.d.ts +0 -10
  450. package/dist/types/components/Accordion/AccordionContent/AccordionContent.d.ts.map +0 -1
  451. package/dist/types/components/Accordion/AccordionContent/index.d.ts +0 -2
  452. package/dist/types/components/Accordion/AccordionContent/index.d.ts.map +0 -1
  453. package/dist/types/components/Accordion/AccordionHeader/AccordionHeader.d.ts.map +0 -1
  454. package/dist/types/components/Accordion/AccordionHeader/index.d.ts +0 -2
  455. package/dist/types/components/Accordion/AccordionHeader/index.d.ts.map +0 -1
  456. package/dist/types/components/Accordion/AccordionItem/AccordionItem.d.ts.map +0 -1
  457. package/dist/types/components/Accordion/AccordionItem/index.d.ts +0 -2
  458. package/dist/types/components/Accordion/AccordionItem/index.d.ts.map +0 -1
  459. package/dist/types/components/DropdownMenu/DropdownMenu.d.ts.map +0 -1
  460. package/dist/types/components/Popover/Popover.d.ts.map +0 -1
  461. package/dist/types/components/Tabs/Tab/Tab.d.ts.map +0 -1
  462. package/dist/types/components/Tabs/Tab/index.d.ts +0 -2
  463. package/dist/types/components/Tabs/Tab/index.d.ts.map +0 -1
  464. package/dist/types/components/Tabs/Tab/useTab.d.ts +0 -7
  465. package/dist/types/components/Tabs/Tab/useTab.d.ts.map +0 -1
  466. package/dist/types/components/Tabs/TabContent/TabContent.d.ts.map +0 -1
  467. package/dist/types/components/Tabs/TabContent/index.d.ts +0 -2
  468. package/dist/types/components/Tabs/TabContent/index.d.ts.map +0 -1
  469. package/dist/types/components/Tabs/TabList/TabList.d.ts +0 -3
  470. package/dist/types/components/Tabs/TabList/TabList.d.ts.map +0 -1
  471. package/dist/types/components/Tabs/TabList/index.d.ts +0 -2
  472. package/dist/types/components/Tabs/TabList/index.d.ts.map +0 -1
  473. package/dist/types/components/Tabs/Tabs.d.ts.map +0 -1
  474. package/dist/types/components/ToggleGroup/ToggleGroup.d.ts.map +0 -1
  475. package/dist/types/hooks/index.d.ts +0 -5
  476. package/dist/types/hooks/index.d.ts.map +0 -1
  477. package/dist/types/hooks/useIsomorphicLayoutEffect.d.ts.map +0 -1
  478. package/dist/types/hooks/useMediaQuery.d.ts +0 -2
  479. package/dist/types/hooks/useMediaQuery.d.ts.map +0 -1
  480. package/dist/types/hooks/usePrevious.d.ts.map +0 -1
  481. package/dist/types/hooks/useSynchronizedAnimation.d.ts +0 -2
  482. package/dist/types/hooks/useSynchronizedAnimation.d.ts.map +0 -1
  483. package/dist/types/utilities/RovingTabIndex/RovingTabindexItem.d.ts +0 -16
  484. package/dist/types/utilities/RovingTabIndex/RovingTabindexItem.d.ts.map +0 -1
  485. package/dist/types/utilities/RovingTabIndex/RovingTabindexRoot.d.ts.map +0 -1
  486. package/dist/types/utilities/RovingTabIndex/index.d.ts +0 -4
  487. package/dist/types/utilities/RovingTabIndex/index.d.ts.map +0 -1
  488. package/dist/types/utilities/RovingTabIndex/useRovingTabindex.d.ts.map +0 -1
  489. package/dist/types/utilities/getSize.d.ts +0 -2
  490. package/dist/types/utilities/getSize.d.ts.map +0 -1
  491. package/dist/types/utilities/objectUtils.d.ts.map +0 -1
  492. package/dist/types/utilities/useDebounce.d.ts +0 -4
  493. package/dist/types/utilities/useDebounce.d.ts.map +0 -1
  494. /package/dist/cjs/node_modules/{@radix-ui/react-slot/node_modules/@babel → @babel}/runtime/helpers/esm/extends.js +0 -0
  495. /package/dist/cjs/{hooks → utilities/hooks}/usePrevious.js +0 -0
  496. /package/dist/cjs/utilities/{objectUtils.js → omit/omit.js} +0 -0
  497. /package/dist/esm/node_modules/{@radix-ui/react-slot/node_modules/@babel → @babel}/runtime/helpers/esm/extends.js +0 -0
  498. /package/dist/esm/{hooks → utilities/hooks}/usePrevious.js +0 -0
  499. /package/dist/esm/utilities/{objectUtils.js → omit/omit.js} +0 -0
  500. /package/dist/types/{hooks → utilities/hooks/useIsomorphicLayoutEffect}/useIsomorphicLayoutEffect.d.ts +0 -0
  501. /package/dist/types/{hooks → utilities/hooks}/usePrevious.d.ts +0 -0
@@ -1,18 +1,20 @@
1
1
  'use client';
2
- import { useContext, useId } from 'react';
3
- import { ToggleGroupContext } from '../ToggleGroup.js';
2
+ import { useId, useContext } from 'react';
3
+ import { ToggleGroupContext } from '../ToggleGroupRoot.js';
4
4
 
5
- /** Handles props for `ToggleGroup.Item` in context with `ToggleGroup` and `RovingTabIndex` */
5
+ /** Handles props for `ToggleGroup.Item` in context with `ToggleGroup` and `RovingFocus` */
6
6
  const useToggleGroupItem = (props) => {
7
7
  const { ...rest } = props;
8
+ const genValue = useId();
8
9
  const toggleGroup = useContext(ToggleGroupContext);
9
- const itemValue = props.value ?? (typeof props.children === 'string' ? props.children : '');
10
- const active = toggleGroup.value == itemValue;
10
+ const value = props.value ?? genValue;
11
+ const active = toggleGroup.value == value;
11
12
  const buttonId = `togglegroup-item-${useId()}`;
12
13
  return {
13
14
  ...rest,
14
15
  active: active,
15
16
  size: toggleGroup?.size,
17
+ value,
16
18
  buttonProps: {
17
19
  id: buttonId,
18
20
  'aria-checked': active,
@@ -20,7 +22,7 @@ const useToggleGroupItem = (props) => {
20
22
  role: 'radio',
21
23
  name: toggleGroup.name,
22
24
  onClick: () => {
23
- toggleGroup.onChange?.(itemValue);
25
+ toggleGroup.onChange?.(value);
24
26
  },
25
27
  },
26
28
  };
@@ -2,22 +2,19 @@
2
2
  import { jsx, jsxs } from 'react/jsx-runtime';
3
3
  import { createContext, forwardRef, useId, useState } from 'react';
4
4
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
- import { getSize } from '../../utilities/getSize.js';
6
- import { RovingTabindexRoot } from '../../utilities/RovingTabIndex/RovingTabindexRoot.js';
5
+ import { RovingFocusRoot } from '../../utilities/RovingFocus/RovingFocusRoot.js';
7
6
 
8
7
  const ToggleGroupContext = createContext({});
9
- /** `ToggleGroup` component.
8
+ /**
9
+ * Display a group of buttons that can be toggled between.
10
10
  * @example
11
- * ```tsx
12
- * <ToggleGroup onChange={(value) => console.log(value)}>
11
+ * <ToggleGroup.Root onChange={(value) => console.log(value)}>
13
12
  * <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
14
13
  * <ToggleGroup.Item value='2'>Toggle 2</ToggleGroup.Item>
15
14
  * <ToggleGroup.Item value='3'>Toggle 3</ToggleGroup.Item>
16
- * </ToggleGroup>
17
- * ```
15
+ * </ToggleGroup.Root>
18
16
  */
19
- const ToggleGroup = forwardRef(({ children, value, defaultValue, onChange, name, className, ...rest }, ref) => {
20
- const size = getSize(rest.size || 'md');
17
+ const ToggleGroupRoot = forwardRef(({ size = 'md', children, value, defaultValue, onChange, name, className, ...rest }, ref) => {
21
18
  const nameId = useId();
22
19
  const isControlled = value !== undefined;
23
20
  const [uncontrolledValue, setUncontrolledValue] = useState(defaultValue);
@@ -29,14 +26,14 @@ const ToggleGroup = forwardRef(({ children, value, defaultValue, onChange, name,
29
26
  };
30
27
  value = uncontrolledValue;
31
28
  }
32
- return (jsx("div", { className: clsx('fds-togglegroup', className), ref: ref, ...rest, children: jsxs(ToggleGroupContext.Provider, { value: {
29
+ return (jsx("div", { className: clsx('ds-togglegroup', className), ref: ref, ...rest, children: jsxs(ToggleGroupContext.Provider, { value: {
33
30
  value,
34
31
  defaultValue,
35
32
  name: name ?? `togglegroup-name-${nameId}`,
36
33
  onChange: onValueChange,
37
34
  size,
38
- }, children: [name && (jsx("input", { className: 'fds-togglegroup__input', name: name, value: value })), jsx(RovingTabindexRoot, { asChild: true, valueId: value, children: jsx("div", { className: 'fds-togglegroup__content', role: 'radiogroup', children: children }) })] }) }));
35
+ }, children: [name && (jsx("input", { className: 'ds-togglegroup__input', name: name, value: value })), jsx(RovingFocusRoot, { asChild: true, activeValue: value, children: jsx("div", { className: 'ds-togglegroup__content', role: 'radiogroup', children: children }) })] }) }));
39
36
  });
40
- ToggleGroup.displayName = 'ToggleGroup';
37
+ ToggleGroupRoot.displayName = 'ToggleGroupRoot';
41
38
 
42
- export { ToggleGroup, ToggleGroupContext };
39
+ export { ToggleGroupContext, ToggleGroupRoot };
@@ -1,9 +1,22 @@
1
1
  'use client';
2
- import { ToggleGroup as ToggleGroup$1 } from './ToggleGroup.js';
2
+ import { ToggleGroupRoot } from './ToggleGroupRoot.js';
3
3
  import { ToggleGroupItem } from './ToggleGroupItem/ToggleGroupItem.js';
4
4
 
5
- const ToggleGroup = ToggleGroup$1;
5
+ /**
6
+ * Display a group of buttons that can be toggled between.
7
+ * @example
8
+ * ```tsx
9
+ * <ToggleGroup.Root onChange={(value) => console.log(value)}>
10
+ * <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
11
+ * <ToggleGroup.Item value='2'>Toggle 2</ToggleGroup.Item>
12
+ * <ToggleGroup.Item value='3'>Toggle 3</ToggleGroup.Item>
13
+ * </ToggleGroup.Root>
14
+ * ```
15
+ */
16
+ const ToggleGroup = {};
17
+ ToggleGroup.Root = ToggleGroupRoot;
6
18
  ToggleGroup.Item = ToggleGroupItem;
19
+ ToggleGroup.Root.displayName = 'ToggleGroup.Root';
7
20
  ToggleGroup.Item.displayName = 'ToggleGroup.Item';
8
21
 
9
- export { ToggleGroup, ToggleGroupItem };
22
+ export { ToggleGroup, ToggleGroupItem, ToggleGroupRoot };
@@ -7,10 +7,18 @@ import { useFloating, useTransitionStyles, useInteractions, useHover, useFocus,
7
7
  import { autoUpdate, flip, shift } from '../../node_modules/@floating-ui/dom/dist/floating-ui.dom.js';
8
8
  import { offset } from '../../node_modules/@floating-ui/core/dist/floating-ui.core.js';
9
9
  import { arrow } from '../../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js';
10
+ import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
10
11
 
11
12
  const ARROW_HEIGHT = 7;
12
13
  const ARROW_GAP = 4;
13
- const Tooltip = forwardRef(({ children, content, placement = 'top', delay = 150, open: userOpen, defaultOpen = false, portal = true, inverted, className, style, ...rest }, ref) => {
14
+ /**
15
+ * Tooltip component that displays a small piece of information when hovering or focusing on an element.
16
+ * @example
17
+ * <Tooltip content='This is a tooltip'>
18
+ * <button>Hover me</button>
19
+ * </Tooltip>
20
+ */
21
+ const Tooltip = forwardRef(({ children, content, placement = 'top', delay = 150, open: userOpen, defaultOpen = false, portal = false, className, style, ...rest }, ref) => {
14
22
  const [isOpen, setIsOpen] = useState(defaultOpen);
15
23
  const Container = portal ? FloatingPortal : React.Fragment;
16
24
  const arrowRef = React.useRef(null);
@@ -57,11 +65,11 @@ const Tooltip = forwardRef(({ children, content, placement = 'top', delay = 150,
57
65
  }
58
66
  return (jsxs(Fragment, { children: [cloneElement(children, getReferenceProps({
59
67
  ref: childMergedRef,
60
- })), internalOpen && (jsx(Container, { children: jsxs("div", { ref: refs.setFloating, style: { ...floatingStyles, ...animationStyles, ...style }, role: 'tooltip', ...getFloatingProps({
61
- className: clsx('fds-tooltip', inverted && 'fds-tooltip--inverted', className),
62
- ref: mergedRef,
63
- ...rest,
64
- }), children: [content, jsx(FloatingArrow, { ref: arrowRef, context: context, className: 'fds-tooltip__arrow', height: ARROW_HEIGHT })] }) }))] }));
68
+ })), internalOpen && (jsx(Container, { children: jsx(Paragraph, { size: 'xs', asChild: true, children: jsxs("div", { ref: refs.setFloating, style: { ...floatingStyles, ...animationStyles, ...style }, role: 'tooltip', ...getFloatingProps({
69
+ className: clsx('ds-tooltip', className),
70
+ ref: mergedRef,
71
+ ...rest,
72
+ }), children: [content, jsx(FloatingArrow, { ref: arrowRef, context: context, className: 'ds-tooltip__arrow', height: ARROW_HEIGHT })] }) }) }))] }));
65
73
  });
66
74
  Tooltip.displayName = 'Tooltip';
67
75
 
@@ -3,13 +3,11 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef } from 'react';
4
4
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
5
5
  import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../../node_modules/@radix-ui/react-slot/dist/index.js';
6
- import { getSize } from '../../../utilities/getSize.js';
7
6
 
8
7
  /** Use `ErrorMessage` to display text as error message. */
9
- const ErrorMessage = forwardRef(({ className, spacing, asChild, error = true, ...rest }, ref) => {
8
+ const ErrorMessage = forwardRef(({ size = 'md', className, spacing, asChild, error = true, ...rest }, ref) => {
10
9
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : 'div';
11
- const size = getSize(rest.size || 'md');
12
- return (jsx(Component, { ref: ref, className: clsx('fds-error-message', `fds-error-message--${size}`, spacing && 'fds-error-message--spacing', error && 'fds-error-message--error', className), ...rest }));
10
+ return (jsx(Component, { ref: ref, className: clsx('ds-error-message', `ds-error_message--${size}`, spacing && 'ds-error-message--spacing', error && 'ds-error-message--error', className), ...rest }));
13
11
  });
14
12
  ErrorMessage.displayName = 'ErrorMessage';
15
13
 
@@ -3,13 +3,16 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef } from 'react';
4
4
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
5
5
  import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../../node_modules/@radix-ui/react-slot/dist/index.js';
6
- import { getSize } from '../../../utilities/getSize.js';
7
6
 
8
- /** Use `Heading` to render h1-6 elements with heading text styles. */
9
- const Heading = forwardRef(({ level = 1, spacing = false, className, asChild, ...rest }, ref) => {
7
+ /**
8
+ * Use `Heading` to render h1-6 elements with heading text styles.
9
+ *
10
+ * @example
11
+ * <Heading size='lg' level={2}>Heading</Heading>
12
+ */
13
+ const Heading = forwardRef(({ size = 'xl', level = 1, spacing = false, className, asChild, ...rest }, ref) => {
10
14
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : `h${level ?? 1}`;
11
- const size = getSize(rest.size || 'xl');
12
- return (jsx(Component, { ref: ref, className: clsx('fds-heading', `fds-heading--${size}`, spacing && 'fds-heading--spacing', className), ...rest }));
15
+ return (jsx(Component, { ref: ref, className: clsx('ds-heading', `ds-heading--${size}`, spacing && 'ds-heading--spacing', className), ...rest }));
13
16
  });
14
17
  Heading.displayName = 'Heading';
15
18
 
@@ -3,13 +3,16 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef } from 'react';
4
4
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
5
5
  import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../../node_modules/@radix-ui/react-slot/dist/index.js';
6
- import { getSize } from '../../../utilities/getSize.js';
7
6
 
8
- /** Use `Ingress` to display text as ingress. */
9
- const Ingress = forwardRef(({ className, spacing, asChild, ...rest }, ref) => {
7
+ /**
8
+ * Use `Ingress` to display text as ingress.
9
+ *
10
+ * @example
11
+ * <Ingress size='lg'>Ingress</Ingress>
12
+ */
13
+ const Ingress = forwardRef(({ size = 'md', className, spacing, asChild, ...rest }, ref) => {
10
14
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : 'p';
11
- const size = getSize(rest.size || 'md');
12
- return (jsx(Component, { ref: ref, className: clsx(`fds-ingress`, `fds-ingress--${size}`, spacing && 'fds-ingress--spacing', className), ...rest }));
15
+ return (jsx(Component, { ref: ref, className: clsx(`ds-ingress`, `ds-ingress--${size}`, spacing && 'ds-ingress--spacing', className), ...rest }));
13
16
  });
14
17
  Ingress.displayName = 'Ingress';
15
18
 
@@ -3,13 +3,16 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef } from 'react';
4
4
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
5
5
  import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../../node_modules/@radix-ui/react-slot/dist/index.js';
6
- import { getSize } from '../../../utilities/getSize.js';
7
6
 
8
- /** Use `Label` for labels. */
9
- const Label = forwardRef(({ className, spacing, weight = 'medium', asChild, ...rest }, ref) => {
7
+ /**
8
+ * Use `Label` for labels.
9
+ *
10
+ * @example
11
+ * <Label size='lg'>Label</Label>
12
+ */
13
+ const Label = forwardRef(({ className, spacing, size = 'md', weight = 'medium', asChild, ...rest }, ref) => {
10
14
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : 'label';
11
- const size = getSize(rest.size || 'md');
12
- return (jsx(Component, { ref: ref, className: clsx('fds-label', `fds-label--${size}`, spacing && 'fds-label--spacing', weight && `fds-label--${weight}-weight`, className), ...rest }));
15
+ return (jsx(Component, { ref: ref, className: clsx('ds-label', `ds-label--${size}`, spacing && 'ds-label--spacing', weight && `ds-font-weight--${weight}`, className), ...rest }));
13
16
  });
14
17
  Label.displayName = 'Label';
15
18
 
@@ -3,13 +3,21 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef } from 'react';
4
4
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
5
5
  import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../../node_modules/@radix-ui/react-slot/dist/index.js';
6
- import { getSize } from '../../../utilities/getSize.js';
7
6
 
8
- /** Use `Paragraph` to display text with paragraph text styles. */
9
- const Paragraph = forwardRef(({ className, spacing, asChild, variant, ...rest }, ref) => {
7
+ const lineHeightMap = {
8
+ short: 'ds-line-height--sm',
9
+ default: 'ds-line-height--md',
10
+ long: 'ds-line-height--lg',
11
+ };
12
+ /**
13
+ * Use `Paragraph` to display text with paragraph text styles.
14
+ *
15
+ * @example
16
+ * <Paragraph size='lg'>Paragraph</Paragraph>
17
+ */
18
+ const Paragraph = forwardRef(({ className, spacing, size = 'md', asChild, variant, ...rest }, ref) => {
10
19
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : 'p';
11
- const size = getSize(rest.size || 'md');
12
- return (jsx(Component, { ref: ref, className: clsx('fds-paragraph', `fds-paragraph--${size}`, spacing && 'fds-paragraph--spacing', variant && `fds-paragraph--${variant}`, className), ...rest }));
20
+ return (jsx(Component, { ref: ref, className: clsx('ds-paragraph', spacing && 'ds-paragraph--spacing', `ds-paragraph--${size}`, lineHeightMap[variant ?? 'default'], className), ...rest }));
13
21
  });
14
22
  Paragraph.displayName = 'Paragraph';
15
23
 
@@ -8,7 +8,7 @@ const CharacterCounter = ({ label = defaultLabel, srLabel: propsSrLabel, maxCoun
8
8
  const currentCount = maxCount - value.length;
9
9
  const hasExceededLimit = value.length > maxCount;
10
10
  const srLabel = propsSrLabel ? propsSrLabel : defaultSrLabel(maxCount);
11
- return (jsxs(Fragment, { children: [jsx("span", { className: `fds-sr-only`, id: id, children: srLabel }), jsx(ErrorMessage, { asChild: true, size: size, error: hasExceededLimit, children: jsx("span", { "aria-live": hasExceededLimit ? 'polite' : 'off', children: label(currentCount) }) })] }));
11
+ return (jsxs(Fragment, { children: [jsx("span", { className: `ds-sr-only`, id: id, children: srLabel }), jsx(ErrorMessage, { asChild: true, size: size, error: hasExceededLimit, children: jsx("span", { "aria-live": hasExceededLimit ? 'polite' : 'off', children: label(currentCount) }) })] }));
12
12
  };
13
13
  CharacterCounter.displayName = 'CharacterCounter';
14
14
 
@@ -5,7 +5,7 @@ import { clsx } from '../../../node_modules/clsx/dist/lite.js';
5
5
  import { useMergeRefs } from '../../../node_modules/@floating-ui/react/dist/floating-ui.react.js';
6
6
  import { useCheckbox } from './useCheckbox.js';
7
7
  import { Paragraph } from '../../Typography/Paragraph/Paragraph.js';
8
- import { omit } from '../../../utilities/objectUtils.js';
8
+ import { omit } from '../../../utilities/omit/omit.js';
9
9
  import { Label } from '../../Typography/Label/Label.js';
10
10
 
11
11
  const Checkbox = forwardRef((props, ref) => {
@@ -19,7 +19,7 @@ const Checkbox = forwardRef((props, ref) => {
19
19
  }
20
20
  },
21
21
  ]);
22
- return (jsx(Paragraph, { asChild: true, size: size, children: jsxs("div", { className: clsx('fds-checkbox', `fds-checkbox--${size}`, inputProps.disabled && `fds-checkbox--disabled`, hasError && `fds-checkbox--error`, readOnly && `fds-checkbox--readonly`, className), style: style, children: [jsx("input", { className: `fds-checkbox__input`, ref: inputRef, ...omit(['size', 'error', 'indeterminate'], rest), ...inputProps, type: 'checkbox', "aria-checked": rest.indeterminate ? 'mixed' : inputProps.checked }), children && (jsxs(Fragment, { children: [jsx(Label, { className: `fds-checkbox__label`, htmlFor: inputProps.id, size: size, weight: 'regular', children: jsx("span", { children: children }) }), description && (jsx(Paragraph, { asChild: true, size: size, children: jsx("div", { id: descriptionId, className: `fds-checkbox__description`, children: description }) }))] }))] }) }));
22
+ return (jsx(Paragraph, { asChild: true, size: size, children: jsxs("div", { className: clsx('ds-checkbox', `ds-checkbox--${size}`, hasError && `ds-checkbox--error`, readOnly && `ds-checkbox--readonly`, className), style: style, children: [jsx("input", { className: `ds-checkbox__input`, ref: inputRef, ...omit(['size', 'error', 'indeterminate'], rest), ...inputProps, type: 'checkbox', disabled: inputProps.disabled, "aria-checked": rest.indeterminate ? 'mixed' : inputProps.checked }), children && (jsxs(Fragment, { children: [jsx(Label, { className: clsx(`ds-checkbox__label`), htmlFor: inputProps.id, size: size, weight: 'regular', children: jsx("span", { children: children }) }), description && (jsx(Paragraph, { asChild: true, size: size, children: jsx("div", { id: descriptionId, className: `ds-checkbox__description`, children: description }) }))] }))] }) }));
23
23
  });
24
24
  Checkbox.displayName = 'Checkbox';
25
25
 
@@ -20,7 +20,7 @@ const CheckboxGroup = forwardRef(({ onChange, children, value, readOnly, default
20
20
  value,
21
21
  defaultValue,
22
22
  toggleValue,
23
- }, children: jsx("div", { children: children }) }) }));
23
+ }, children: jsx("div", { className: 'ds-checkbox__group', children: children }) }) }));
24
24
  });
25
25
  CheckboxGroup.displayName = 'CheckboxGroup';
26
26
 
@@ -5,24 +5,22 @@ import { FloatingPortal, FloatingFocusManager } from '../../../node_modules/@flo
5
5
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
6
6
  import { useVirtualizer } from '../../../node_modules/@tanstack/react-virtual/dist/esm/index.js';
7
7
  import { useFormField } from '../useFormField.js';
8
- import useDebounce from '../../../utilities/useDebounce.js';
9
- import { getSize } from '../../../utilities/getSize.js';
10
- import useCombobox from './useCombobox.js';
8
+ import useCombobox, { prefix, removePrefix } from './useCombobox.js';
11
9
  import ComboboxInput from './internal/ComboboxInput.js';
12
10
  import ComboboxLabel from './internal/ComboboxLabel.js';
13
11
  import ComboboxError from './internal/ComboboxError.js';
14
12
  import ComboboxNative from './internal/ComboboxNative.js';
15
- import ComboboxCustom from './Custom.js';
13
+ import { ComboboxCustom } from './Custom.js';
16
14
  import { useFloatingCombobox } from './useFloatingCombobox.js';
17
15
  import { useComboboxKeyboard } from './useComboboxKeyboard.js';
18
16
  import { ComboboxIdProvider } from './ComboboxIdContext.js';
19
17
  import { ComboboxContext } from './ComboboxContext.js';
20
18
  import { Box } from '../../Box/Box.js';
21
19
  import { Spinner } from '../../Spinner/Spinner.js';
22
- import { omit } from '../../../utilities/objectUtils.js';
20
+ import { useDebounceCallback } from '../../../utilities/hooks/useDebounceCallback/useDebounceCallback.js';
21
+ import { omit } from '../../../utilities/omit/omit.js';
23
22
 
24
- const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange, label, hideLabel = false, description, multiple = false, disabled = false, readOnly = false, hideChips = false, clearButtonLabel = 'Fjern alt', hideClearButton = false, error, errorId, id, name, portal = true, htmlSize = 0, virtual = false, children, style, loading, loadingLabel = 'Laster...', filter, chipSrLabel = (option) => 'Slett ' + option.label, className, ...rest }, forwareddRef) => {
25
- const size = getSize(rest.size || 'md');
23
+ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange, label, hideLabel = false, description, multiple = false, disabled = false, readOnly = false, hideChips = false, clearButtonLabel = 'Fjern alt', hideClearButton = false, error, errorId, id, name, portal = true, htmlSize = 0, virtual = false, children, style, size = 'md', loading, loadingLabel = 'Laster...', filter, chipSrLabel = (option) => 'Slett ' + option.label, className, ...rest }, forwareddRef) => {
26
24
  const inputRef = useRef(null);
27
25
  const portalRef = useRef(null);
28
26
  const listRef = useRef([]);
@@ -50,18 +48,18 @@ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange,
50
48
  // if value is set, set input value to the label of the value
51
49
  useEffect(() => {
52
50
  if (value && value.length > 0 && !multiple) {
53
- const option = options[value[0]];
51
+ const option = options[prefix(value[0])];
54
52
  setInputValue(option?.label || '');
55
53
  }
56
54
  }, [multiple, value, options]);
57
55
  useEffect(() => {
58
56
  if (value && Object.keys(options).length >= 0) {
59
57
  const updatedSelectedOptions = value.map((option) => {
60
- const value = options[option];
58
+ const value = options[prefix(option)];
61
59
  return value;
62
60
  });
63
61
  setSelectedOptions(updatedSelectedOptions.reduce((acc, value) => {
64
- acc[value.value] = value;
62
+ acc[prefix(value.value)] = value;
65
63
  return acc;
66
64
  }, {}));
67
65
  }
@@ -79,18 +77,18 @@ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange,
79
77
  return;
80
78
  if (remove) {
81
79
  const newSelectedOptions = { ...selectedOptions };
82
- delete newSelectedOptions[option.value];
80
+ delete newSelectedOptions[prefix(option.value)];
83
81
  setSelectedOptions(newSelectedOptions);
84
- onValueChange?.(Object.keys(newSelectedOptions));
82
+ onValueChange?.(Object.keys(newSelectedOptions).map((key) => removePrefix(key)));
85
83
  return;
86
84
  }
87
85
  const newSelectedOptions = { ...selectedOptions };
88
86
  if (multiple) {
89
- if (newSelectedOptions[option.value]) {
90
- delete newSelectedOptions[option.value];
87
+ if (newSelectedOptions[prefix(option.value)]) {
88
+ delete newSelectedOptions[prefix(option.value)];
91
89
  }
92
90
  else {
93
- newSelectedOptions[option.value] = option;
91
+ newSelectedOptions[prefix(option.value)] = option;
94
92
  }
95
93
  setInputValue('');
96
94
  inputRef.current?.focus();
@@ -100,7 +98,7 @@ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange,
100
98
  Object.keys(newSelectedOptions).forEach((key) => {
101
99
  delete newSelectedOptions[key];
102
100
  });
103
- newSelectedOptions[option.value] = option;
101
+ newSelectedOptions[prefix(option.value)] = option;
104
102
  setInputValue(option?.label || '');
105
103
  // move cursor to the end of the input
106
104
  setTimeout(() => {
@@ -108,11 +106,11 @@ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange,
108
106
  }, 0);
109
107
  }
110
108
  setSelectedOptions(newSelectedOptions);
111
- onValueChange?.(Object.keys(newSelectedOptions));
109
+ onValueChange?.(Object.keys(newSelectedOptions).map((key) => removePrefix(key)));
112
110
  !multiple && setOpen(false);
113
111
  refs.domReference.current?.focus();
114
112
  };
115
- const debouncedHandleSelectOption = useDebounce(handleSelectOption, 50);
113
+ const debouncedHandleSelectOption = useDebounceCallback(handleSelectOption, 50);
116
114
  const handleKeyDown = useComboboxKeyboard({
117
115
  filteredOptions,
118
116
  selectedOptions,
@@ -134,7 +132,7 @@ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange,
134
132
  measureElement: (elem) => {
135
133
  return elem.getBoundingClientRect().height;
136
134
  },
137
- overscan: 1,
135
+ overscan: 7,
138
136
  });
139
137
  return (jsxs(ComboboxContext.Provider, { value: {
140
138
  size,
@@ -162,19 +160,22 @@ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange,
162
160
  return;
163
161
  if (disabled)
164
162
  return;
165
- const option = options[value];
163
+ const option = options[prefix(value)];
166
164
  debouncedHandleSelectOption({ option: option });
167
165
  },
168
166
  handleSelectOption: debouncedHandleSelectOption,
169
167
  chipSrLabel,
170
168
  listRef,
171
169
  forwareddRef,
172
- }, children: [jsxs(Box, { className: clsx('fds-combobox', `fds-combobox--${size}`, disabled && 'fds-combobox__disabled', className), style: style, ref: portalRef, children: [name && (jsx(ComboboxNative, { name: name, selectedOptions: selectedOptions, multiple: multiple })), jsx(ComboboxLabel, { label: label, description: description, size: size, readOnly: readOnly, hideLabel: hideLabel, formFieldProps: formFieldProps }), jsx(ComboboxInput, { ...omit(['inputValue'], rest), hideClearButton: hideClearButton, listId: listId, error: error, hideChips: hideChips, handleKeyDown: handleKeyDown, "aria-busy": loading }), jsx(ComboboxError, { size: size, error: error, formFieldProps: formFieldProps })] }), open && (jsx(FloatingPortal, { root: portal ? null : portalRef, children: jsx(FloatingFocusManager, { context: context, initialFocus: -1, visuallyHiddenDismiss: true, children: jsxs(Box, { id: listId, shadow: 'md', borderRadius: 'md', borderColor: 'default', "aria-labelledby": formFieldProps.inputProps.id, "aria-autocomplete": 'list', tabIndex: -1, ...getFloatingProps({
170
+ setListRef: (index, node) => {
171
+ return (listRef.current[index] = node);
172
+ },
173
+ }, children: [jsxs(Box, { className: clsx('ds-combobox', `ds-combobox--${size}`, disabled && 'ds-combobox__disabled', className), style: style, ref: portalRef, children: [name && (jsx(ComboboxNative, { name: name, selectedOptions: selectedOptions, multiple: multiple })), jsx(ComboboxLabel, { label: label, description: description, size: size, readOnly: readOnly, hideLabel: hideLabel, formFieldProps: formFieldProps }), jsx(ComboboxInput, { ...omit(['inputValue'], rest), hideClearButton: hideClearButton, listId: listId, error: error, hideChips: hideChips, handleKeyDown: handleKeyDown, "aria-busy": loading }), jsx(ComboboxError, { size: size, error: error, formFieldProps: formFieldProps })] }), open && (jsx(FloatingPortal, { root: portal ? null : portalRef, children: jsx(FloatingFocusManager, { context: context, initialFocus: -1, visuallyHiddenDismiss: true, children: jsxs(Box, { id: listId, shadow: 'md', borderRadius: 'md', borderColor: 'default', "aria-labelledby": formFieldProps.inputProps.id, "aria-autocomplete": 'list', tabIndex: -1, ...getFloatingProps({
173
174
  ref: refs.setFloating,
174
175
  style: {
175
176
  ...floatingStyles,
176
177
  },
177
- }), className: clsx('fds-combobox__options-wrapper', `fds-combobox--${size}`), children: [virtual && (jsx("div", { style: {
178
+ }), className: clsx('ds-combobox__options-wrapper', `ds-combobox--${size}`), children: [virtual && (jsx("div", { style: {
178
179
  height: `${rowVirtualizer.getTotalSize()}px`,
179
180
  width: '100%',
180
181
  position: 'relative',
@@ -184,7 +185,7 @@ const ComboboxComponent = forwardRef(({ value, initialValue = [], onValueChange,
184
185
  left: 0,
185
186
  width: '100%',
186
187
  transform: `translateY(${virtualRow.start}px)`,
187
- }, children: filteredOptionsChildren[virtualRow.index] }, virtualRow.index))) })), loading ? (jsxs(ComboboxCustom, { className: 'fds-combobox__loading', children: [jsx(Spinner, { title: 'Laster', size: 'sm' }), loadingLabel] })) : (jsxs(Fragment, { children: [restChildren, !virtual && filteredOptionsChildren] }))] }) }) }))] }));
188
+ }, children: filteredOptionsChildren[virtualRow.index] }, virtualRow.index))) })), loading ? (jsxs(ComboboxCustom, { className: 'ds-combobox__loading', children: [jsx(Spinner, { title: 'Laster', size: 'sm' }), loadingLabel] })) : (jsxs(Fragment, { children: [restChildren, !virtual && filteredOptionsChildren] }))] }) }) }))] }));
188
189
  });
189
190
  const Combobox = forwardRef((props, ref) => (jsx(ComboboxIdProvider, { children: jsx(ComboboxComponent, { ...props, ref: ref }) })));
190
191
  Combobox.displayName = 'Combobox';
@@ -6,7 +6,8 @@ import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../../node
6
6
  import { useMergeRefs } from '../../../node_modules/@floating-ui/react/dist/floating-ui.react.js';
7
7
  import { ComboboxContext } from './ComboboxContext.js';
8
8
  import { useComboboxId } from './ComboboxIdContext.js';
9
- import { omit } from '../../../utilities/objectUtils.js';
9
+ import { Label } from '../../Typography/Label/Label.js';
10
+ import { omit } from '../../../utilities/omit/omit.js';
10
11
 
11
12
  const ComboboxCustom = forwardRef(({ asChild, interactive, id, className, ...rest }, ref) => {
12
13
  if (interactive && !id) {
@@ -19,16 +20,15 @@ const ComboboxCustom = forwardRef(({ asChild, interactive, id, className, ...res
19
20
  if (!context) {
20
21
  throw new Error('ComboboxCustom must be used within a Combobox');
21
22
  }
22
- const { customIds, listRef, getItemProps } = context;
23
+ const { customIds, setListRef, getItemProps, size } = context;
23
24
  const index = useMemo(() => (id && customIds.indexOf(id)) || 0, [id, customIds]);
24
25
  const combinedRef = useMergeRefs([
25
26
  (node) => {
26
- listRef.current[index] = node;
27
+ setListRef(index, node);
27
28
  },
28
29
  ref,
29
30
  ]);
30
- return (jsx(Component, { ref: combinedRef, tabIndex: -1, className: clsx('fds-combobox__custom', className), id: id || randomId, role: 'option', "aria-selected": activeIndex === index, "data-active": activeIndex === index, ...omit(['interactive'], rest), ...omit(['onClick', 'onPointerLeave'], getItemProps()) }));
31
+ return (jsx(Label, { size: size, asChild: true, children: jsx(Component, { ref: combinedRef, tabIndex: -1, className: clsx('ds-combobox__custom', className), id: id || randomId, role: 'option', "aria-selected": activeIndex === index, "data-active": activeIndex === index, ...omit(['interactive'], rest), ...omit(['onClick', 'onPointerLeave'], getItemProps()) }) }));
31
32
  });
32
- var ComboboxCustom$1 = ComboboxCustom;
33
33
 
34
- export { ComboboxCustom, ComboboxCustom$1 as default };
34
+ export { ComboboxCustom };
@@ -3,15 +3,16 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef, useContext } from 'react';
4
4
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
5
5
  import { ComboboxContext } from './ComboboxContext.js';
6
+ import { Label } from '../../Typography/Label/Label.js';
6
7
 
7
8
  const ComboboxEmpty = forwardRef(({ children, className, ...rest }, ref) => {
8
9
  const context = useContext(ComboboxContext);
9
10
  if (!context) {
10
11
  throw new Error('ComboboxEmpty must be used within a Combobox');
11
12
  }
12
- const { filteredOptions } = context;
13
- return (filteredOptions.length === 0 && (jsx("div", { ref: ref, className: clsx('fds-combobox__empty', className), ...rest, children: children })));
13
+ const { filteredOptions, size } = context;
14
+ return (filteredOptions.length === 0 && (jsx(Label, { size: size, asChild: true, children: jsx("div", { ref: ref, className: clsx('ds-combobox__empty', className), ...rest, children: children }) })));
14
15
  });
15
16
  ComboboxEmpty.displayName = 'ComboboxEmpty';
16
17
 
17
- export { ComboboxEmpty, ComboboxEmpty as default };
18
+ export { ComboboxEmpty };
@@ -4,9 +4,9 @@ import { forwardRef } from 'react';
4
4
  import { clsx } from '../../../../node_modules/clsx/dist/lite.js';
5
5
 
6
6
  const ComboboxOptionDescription = forwardRef(({ children, className, ...rest }, ref) => {
7
- return (jsx("span", { className: clsx('fds-combobox__option__description', className), ref: ref, ...rest, children: children }));
7
+ return (jsx("span", { className: clsx('ds-combobox__option__description', className), ref: ref, ...rest, children: children }));
8
8
  });
9
9
  ComboboxOptionDescription.displayName = 'ComboboxOptionDescription';
10
10
  var ComboboxOptionDescription$1 = ComboboxOptionDescription;
11
11
 
12
- export { ComboboxOptionDescription, ComboboxOptionDescription$1 as default };
12
+ export { ComboboxOptionDescription$1 as default };
@@ -1,13 +1,13 @@
1
1
  'use client';
2
- import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { jsx, jsxs } from 'react/jsx-runtime';
3
3
  import { memo, forwardRef, useId, useContext } from 'react';
4
4
  import { clsx } from '../../../../node_modules/clsx/dist/lite.js';
5
5
  import { ComboboxContext } from '../ComboboxContext.js';
6
6
  import { SelectedIcon } from './SelectedIcon.js';
7
7
  import ComboboxOptionDescription from './Description.js';
8
8
  import useComboboxOption from './useComboboxOption.js';
9
- import { omit } from '../../../../utilities/objectUtils.js';
10
9
  import { Label } from '../../../Typography/Label/Label.js';
10
+ import { omit } from '../../../../utilities/omit/omit.js';
11
11
 
12
12
  const ComboboxOption = memo(forwardRef(({ value, description, children, className, ...rest }, forwardedRef) => {
13
13
  const labelId = useId();
@@ -22,10 +22,10 @@ const ComboboxOption = memo(forwardRef(({ value, description, children, classNam
22
22
  }
23
23
  const { size, multiple, getItemProps } = context;
24
24
  const props = getItemProps();
25
- return (jsxs("button", { ref: ref, id: id, role: 'option', type: 'button', "aria-selected": !!selected, "aria-labelledby": labelId, tabIndex: -1, onClick: (e) => {
26
- onOptionClick();
27
- rest.onClick?.(e);
28
- }, className: clsx('fds-combobox__option', active && 'fds-combobox__option--active', multiple && 'fds-combobox__option--multiple', className), ...omit(['displayValue'], rest), ...omit(['onClick', 'onPointerLeave'], props), children: [jsx(Label, { asChild: true, size: size, children: jsx("span", { children: jsx(SelectedIcon, { multiple: multiple, selected: !!selected }) }) }), jsxs(Label, { className: 'fds-combobox__option__label', size: size, id: labelId, children: [children, description && (jsx(ComboboxOptionDescription, { children: description }))] })] }));
25
+ return (jsx(Label, { size: 'md', asChild: true, children: jsxs("button", { ref: ref, id: id, role: 'option', type: 'button', "aria-selected": !!selected, "aria-labelledby": labelId, tabIndex: -1, onClick: (e) => {
26
+ onOptionClick();
27
+ rest.onClick?.(e);
28
+ }, className: clsx('ds-combobox__option', active && 'ds-combobox__option--active', multiple && 'ds-combobox__option--multiple', className), ...omit(['displayValue'], rest), ...omit(['onClick', 'onPointerLeave'], props), children: [jsx(Label, { asChild: true, size: size, children: jsx("span", { children: jsx(SelectedIcon, { multiple: multiple, selected: !!selected }) }) }), jsxs(Label, { className: 'ds-combobox__option__label', size: size, id: labelId, children: [children, description && (jsx(ComboboxOptionDescription, { children: description }))] })] }) }));
29
29
  }));
30
30
  ComboboxOption.displayName = 'ComboboxOption';
31
31
 
@@ -4,8 +4,8 @@ import { CheckmarkIcon } from '@navikt/aksel-icons';
4
4
  import { clsx } from '../../../../node_modules/clsx/dist/lite.js';
5
5
 
6
6
  const SelectedIcon = ({ multiple, selected }) => {
7
- return (jsx("div", { className: clsx(multiple && 'fds-combobox__option__icon-wrapper', selected && 'fds-combobox__option__icon-wrapper--selected'), children: selected && (jsx(CheckmarkIcon, { className: 'fds-combobox__option__icon-wrapper__icon', "aria-hidden": true })) }));
7
+ return (jsx("div", { className: clsx(multiple && 'ds-combobox__option__icon-wrapper', selected && 'ds-combobox__option__icon-wrapper--selected'), children: selected && (jsx(CheckmarkIcon, { className: 'ds-combobox__option__icon-wrapper__icon', "aria-hidden": true })) }));
8
8
  };
9
9
  SelectedIcon.displayName = 'SelectedIcon';
10
10
 
11
- export { SelectedIcon, SelectedIcon as default };
11
+ export { SelectedIcon };
@@ -2,8 +2,9 @@
2
2
  import { useId, useContext, useMemo, useEffect } from 'react';
3
3
  import { useMergeRefs } from '../../../../node_modules/@floating-ui/react/dist/floating-ui.react.js';
4
4
  import { ComboboxContext } from '../ComboboxContext.js';
5
- import useDebounce from '../../../../utilities/useDebounce.js';
6
5
  import { useComboboxId, useComboboxIdDispatch } from '../ComboboxIdContext.js';
6
+ import { prefix } from '../useCombobox.js';
7
+ import { useDebounceCallback } from '../../../../utilities/hooks/useDebounceCallback/useDebounceCallback.js';
7
8
 
8
9
  function useComboboxOption({ id, ref, value, }) {
9
10
  const generatedId = useId();
@@ -14,25 +15,25 @@ function useComboboxOption({ id, ref, value, }) {
14
15
  if (!context) {
15
16
  throw new Error('ComboboxOption must be used within a Combobox');
16
17
  }
17
- const { selectedOptions, onOptionClick, listRef, customIds, filteredOptions, } = context;
18
- const index = useMemo(() => filteredOptions.indexOf(value) + customIds.length, [customIds.length, filteredOptions, value]);
18
+ const { selectedOptions, onOptionClick, setListRef, customIds, filteredOptions, } = context;
19
+ const index = useMemo(() => filteredOptions.indexOf(prefix(String(value))) + customIds.length, [customIds.length, filteredOptions, value]);
19
20
  const combinedRef = useMergeRefs([
20
21
  (node) => {
21
- listRef.current[index] = node;
22
+ setListRef(index, node);
22
23
  },
23
24
  ref,
24
25
  ]);
25
26
  if (index === -1) {
26
27
  throw new Error('Internal error: ComboboxOption did not find index');
27
28
  }
28
- const selected = selectedOptions[value];
29
+ const selected = selectedOptions[prefix(value)];
29
30
  const active = activeIndex === index;
30
31
  useEffect(() => {
31
32
  if (active) {
32
33
  dispatch?.({ type: 'SET_ACTIVE_INDEX', payload: index });
33
34
  }
34
35
  }, [generatedId, id, dispatch, active, index]);
35
- const onOptionClickDebounced = useDebounce(() => onOptionClick(value), 50);
36
+ const onOptionClickDebounced = useDebounceCallback(() => onOptionClick(value), 50);
36
37
  return {
37
38
  id: newId,
38
39
  ref: combinedRef,
@@ -41,4 +41,4 @@ const ComboboxChips = () => {
41
41
  ComboboxChips.displayName = 'ComboboxChips';
42
42
  var ComboboxChips$1 = ComboboxChips;
43
43
 
44
- export { ComboboxChips, ComboboxChips$1 as default };
44
+ export { ComboboxChips$1 as default };