@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,8 +1,9 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
- import { createContext, useRef, useState } from 'react';
3
+ import { createContext, useRef, useState, useCallback } from 'react';
4
4
 
5
5
  const ModalContext = createContext({
6
+ setCloseModal: () => { },
6
7
  modalRef: { current: null },
7
8
  open: false,
8
9
  setOpen: () => { },
@@ -10,8 +11,13 @@ const ModalContext = createContext({
10
11
  const ModalRoot = ({ children }) => {
11
12
  const modalRef = useRef(null);
12
13
  const [open, setOpen] = useState(false);
14
+ const [closeModal, setCloseModal] = useState();
15
+ const setCloseModalInContext = useCallback((fn) => {
16
+ setCloseModal(() => fn);
17
+ }, []);
13
18
  return (jsx(ModalContext.Provider, { value: {
14
- closeModal: () => { },
19
+ setCloseModal: setCloseModalInContext,
20
+ closeModal,
15
21
  modalRef,
16
22
  open,
17
23
  setOpen,
@@ -6,7 +6,7 @@ import { ModalFooter } from './ModalFooter.js';
6
6
  import { ModalHeader } from './ModalHeader.js';
7
7
  import { ModalTrigger } from './ModalTrigger.js';
8
8
 
9
- const Modal = ModalDialog;
9
+ const Modal = {};
10
10
  Modal.Root = ModalRoot;
11
11
  Modal.Content = ModalContent;
12
12
  Modal.Footer = ModalFooter;
@@ -3,7 +3,6 @@ import { jsx, jsxs } from 'react/jsx-runtime';
3
3
  import { forwardRef } from 'react';
4
4
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
5
  import { ChevronLeftIcon, ChevronRightIcon } from '@navikt/aksel-icons';
6
- import { getSize } from '../../utilities/getSize.js';
7
6
  import { PaginationRoot } from './PaginationRoot.js';
8
7
  import { PaginationContent } from './PaginationContent.js';
9
8
  import { PaginationItem } from './PaginationItem.js';
@@ -17,20 +16,19 @@ const iconSize = {
17
16
  md: '1.5rem',
18
17
  lg: '2rem',
19
18
  };
20
- const Pagination = forwardRef(({ nextLabel = '', previousLabel = '', compact = false, hideLabels = false, currentPage = 1, totalPages, onChange, itemLabel = (num) => `Side ${num}`, ...rest }, ref) => {
19
+ const Pagination = forwardRef(({ nextLabel = '', previousLabel = '', compact = false, hideLabels = false, currentPage = 1, totalPages, size = 'md', onChange, itemLabel = (num) => `Side ${num}`, ...rest }, ref) => {
21
20
  const { pages, showNextPage, showPreviousPage } = usePagination({
22
21
  compact,
23
22
  currentPage,
24
23
  totalPages,
25
24
  });
26
- const size = getSize(rest.size || 'md');
27
- return (jsx(PaginationRoot, { ref: ref, "aria-label": 'Pagination', size: size, compact: compact, ...rest, children: jsxs(PaginationContent, { children: [jsx(PaginationItem, { children: jsxs(PaginationPrevious, { className: clsx(!showPreviousPage && 'fds-pagination--hidden'), onClick: () => {
25
+ return (jsx(PaginationRoot, { ref: ref, "aria-label": 'Pagination', size: size, compact: compact, ...rest, children: jsxs(PaginationContent, { children: [jsx(PaginationItem, { children: jsxs(PaginationPrevious, { className: clsx(!showPreviousPage && 'ds-pagination--hidden'), onClick: () => {
28
26
  onChange(currentPage - 1);
29
27
  }, "aria-label": previousLabel, children: [jsx(ChevronLeftIcon, { "aria-hidden": true, fontSize: iconSize[size] }), !hideLabels && previousLabel] }) }), pages.map((page, i) => (jsx(PaginationItem, { children: page === 'ellipsis' ? (jsx(PaginationEllipsis, {})) : (jsx(PaginationButton, { "aria-current": currentPage === page, isActive: currentPage === page, "aria-label": itemLabel(page), onClick: () => {
30
28
  onChange(page);
31
29
  }, children: page })) }, `${page}${i}`))), jsx(PaginationItem, { children: jsxs(PaginationNext, { "aria-label": nextLabel, onClick: () => {
32
30
  onChange(currentPage + 1);
33
- }, className: clsx(!showNextPage && 'fds-pagination--hidden'), children: [!hideLabels && nextLabel, jsx(ChevronRightIcon, { "aria-hidden": true, fontSize: iconSize[size] })] }) })] }) }));
31
+ }, className: clsx(!showNextPage && 'ds-pagination--hidden'), children: [!hideLabels && nextLabel, jsx(ChevronRightIcon, { "aria-hidden": true, fontSize: iconSize[size] })] }) })] }) }));
34
32
  });
35
33
  Pagination.displayName = 'Pagination';
36
34
 
@@ -6,7 +6,8 @@ import { Button } from '../Button/Button.js';
6
6
 
7
7
  const PaginationButton = forwardRef(({ isActive, ...rest }, ref) => {
8
8
  const { size } = useContext(PaginationContext);
9
- return (jsx(Button, { ref: ref, variant: isActive ? 'primary' : 'tertiary', "aria-current": isActive, color: 'first', size: size, ...rest }));
9
+ return (jsx(Button, { ref: ref, variant: isActive ? 'primary' : 'tertiary', "aria-current": isActive, size: size, ...rest }));
10
10
  });
11
+ PaginationButton.displayName = 'PaginationButton';
11
12
 
12
13
  export { PaginationButton };
@@ -8,7 +8,8 @@ import { PaginationContext } from './PaginationRoot.js';
8
8
  const PaginationContent = forwardRef(({ asChild, className, ...rest }, ref) => {
9
9
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : 'ul';
10
10
  const { size } = useContext(PaginationContext);
11
- return (jsx(Component, { ref: ref, className: clsx('fds-pagination', `fds-pagination--${size}`, className), ...rest }));
11
+ return (jsx(Component, { ref: ref, className: clsx('ds-pagination', `ds-pagination--${size}`, className), ...rest }));
12
12
  });
13
+ PaginationContent.displayName = 'PaginationContent';
13
14
 
14
15
  export { PaginationContent };
@@ -7,8 +7,8 @@ import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
7
7
 
8
8
  const PaginationEllipsis = forwardRef(({ className, ...rest }, ref) => {
9
9
  const { size } = useContext(PaginationContext);
10
- return (jsx(Paragraph, { ref: ref, className: clsx('fds-pagination__ellipsis', className), size: size, ...rest, children: "\u2026" }));
10
+ return (jsx(Paragraph, { ref: ref, className: clsx('ds-pagination__ellipsis', className), size: size, ...rest, children: "\u2026" }));
11
11
  });
12
- var PaginationEllipsis$1 = PaginationEllipsis;
12
+ PaginationEllipsis.displayName = 'PaginationEllipsis';
13
13
 
14
- export { PaginationEllipsis, PaginationEllipsis$1 as default };
14
+ export { PaginationEllipsis };
@@ -8,8 +8,8 @@ import { PaginationContext } from './PaginationRoot.js';
8
8
  const PaginationItem = forwardRef(({ asChild, className, ...rest }, ref) => {
9
9
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : 'li';
10
10
  const { size, compact } = useContext(PaginationContext);
11
- return (jsx(Component, { ref: ref, className: clsx('fds-pagination__item', `fds-pagination--${size}`, compact && 'fds-pagination--compact', className), ...rest }));
11
+ return (jsx(Component, { ref: ref, className: clsx('ds-pagination__item', `ds-pagination--${size}`, compact && 'ds-pagination--compact', className), ...rest }));
12
12
  });
13
- var PaginationItem$1 = PaginationItem;
13
+ PaginationItem.displayName = 'PaginationItem';
14
14
 
15
- export { PaginationItem, PaginationItem$1 as default };
15
+ export { PaginationItem };
@@ -6,8 +6,10 @@ import { PaginationButton } from './PaginationButton.js';
6
6
  const PaginationNext = forwardRef(({ ...rest }, ref) => {
7
7
  return (jsx(PaginationButton, { ref: ref, "aria-label": rest.children != null ? undefined : 'Neste side', ...rest }));
8
8
  });
9
+ PaginationNext.displayName = 'PaginationNext';
9
10
  const PaginationPrevious = forwardRef(({ ...rest }, ref) => {
10
11
  return (jsx(PaginationButton, { ref: ref, "aria-label": rest.children != null ? undefined : 'Forrige side', ...rest }));
11
12
  });
13
+ PaginationPrevious.displayName = 'PaginationPrevious';
12
14
 
13
15
  export { PaginationNext, PaginationPrevious };
@@ -2,17 +2,15 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../node_modules/@radix-ui/react-slot/dist/index.js';
4
4
  import { createContext, forwardRef } from 'react';
5
- import { getSize } from '../../utilities/getSize.js';
6
5
 
7
6
  const PaginationContext = createContext({
8
7
  size: 'md',
9
8
  compact: false,
10
9
  });
11
- const PaginationRoot = forwardRef(({ asChild, compact = false, ...rest }, ref) => {
10
+ const PaginationRoot = forwardRef(({ asChild, compact = false, size = 'md', ...rest }, ref) => {
12
11
  const Component = asChild ? $5e63c961fc1ce211$export$8c6ed5c666ac1360 : 'nav';
13
- const size = getSize(rest.size || 'md');
14
12
  return (jsx(PaginationContext.Provider, { value: { size, compact }, children: jsx(Component, { ref: ref, "aria-label": 'Pagination', ...rest }) }));
15
13
  });
16
- var PaginationRoot$1 = PaginationRoot;
14
+ PaginationRoot.displayName = 'PaginationRoot';
17
15
 
18
- export { PaginationContext, PaginationRoot, PaginationRoot$1 as default };
16
+ export { PaginationContext, PaginationRoot };
@@ -1,11 +1,11 @@
1
1
  'use client';
2
2
  import { Pagination as Pagination$1 } from './Pagination.js';
3
3
  import { PaginationContent } from './PaginationContent.js';
4
- import PaginationEllipsis from './PaginationEllipsis.js';
5
- import PaginationItem from './PaginationItem.js';
4
+ import { PaginationEllipsis } from './PaginationEllipsis.js';
5
+ import { PaginationItem } from './PaginationItem.js';
6
6
  import { PaginationButton } from './PaginationButton.js';
7
7
  import { PaginationPrevious, PaginationNext } from './PaginationNextPrev.js';
8
- import PaginationRoot from './PaginationRoot.js';
8
+ import { PaginationRoot } from './PaginationRoot.js';
9
9
 
10
10
  const Pagination = Pagination$1;
11
11
  Pagination.Root = PaginationRoot;
@@ -4,11 +4,11 @@ import * as React from 'react';
4
4
  import { forwardRef, useContext, useRef, useEffect, useMemo } from 'react';
5
5
  import { useFloating, useInteractions, useFocus, useClick, useDismiss, useRole, useMergeRefs, FloatingPortal } from '../../node_modules/@floating-ui/react/dist/floating-ui.react.js';
6
6
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
7
- import { PopoverContext } from './Popover.js';
7
+ import { PopoverContext } from './PopoverRoot.js';
8
8
  import { autoUpdate, flip, shift } from '../../node_modules/@floating-ui/dom/dist/floating-ui.dom.js';
9
9
  import { offset } from '../../node_modules/@floating-ui/core/dist/floating-ui.core.js';
10
10
  import { arrow } from '../../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.js';
11
- import { useIsomorphicLayoutEffect } from '../../hooks/useIsomorphicLayoutEffect.js';
11
+ import { useIsomorphicLayoutEffect } from '../../utilities/hooks/useIsomorphicLayoutEffect/useIsomorphicLayoutEffect.js';
12
12
  import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
13
13
 
14
14
  const ARROW_HEIGHT = 7;
@@ -70,10 +70,10 @@ const PopoverContent = forwardRef(({ className, children, style, id, ...rest },
70
70
  const arrowPlacement = useMemo(() => {
71
71
  return ARROW_PLACEMENT[flPlacement.split('-')[0]];
72
72
  }, [flPlacement]);
73
- return (jsx(Fragment, { children: internalOpen && (jsx(Container, { children: jsx(Paragraph, { asChild: true, size: size, children: jsxs("div", { ref: floatingEl, className: clsx('fds-popover', `fds-popover--${variant}`, `fds-popover--${size}`, className), "data-placement": flPlacement, ...getFloatingProps({
73
+ return (jsx(Fragment, { children: internalOpen && (jsx(Container, { children: jsx(Paragraph, { asChild: true, size: size, children: jsxs("div", { ref: floatingEl, className: clsx('ds-popover', `ds-popover--${variant}`, `ds-popover--${size}`, className), "data-placement": flPlacement, ...getFloatingProps({
74
74
  ref: floatingRef,
75
75
  tabIndex: undefined,
76
- }), style: { ...floatingStyles, ...style }, id: popoverId, "aria-labelledby": triggerId, ...rest, children: [children, jsx("div", { ref: arrowRef, className: clsx('fds-popover__arrow', `fds-popover__arrow--${arrowPlacement}`), style: {
76
+ }), style: { ...floatingStyles, ...style }, id: popoverId, "aria-labelledby": triggerId, ...rest, children: [children, jsx("div", { ref: arrowRef, className: clsx('ds-popover__arrow', `ds-popover__arrow--${arrowPlacement}`), style: {
77
77
  height: ARROW_HEIGHT,
78
78
  width: ARROW_HEIGHT,
79
79
  ...(arrowX != null ? { left: arrowX } : {}),
@@ -2,10 +2,8 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import * as React from 'react';
4
4
  import { useRef, useState, useId } from 'react';
5
- import { getSize } from '../../utilities/getSize.js';
6
5
 
7
- const Popover = ({ children, placement = 'top', open, variant = 'default', portal, onOpenChange, onClose, ...rest }) => {
8
- const size = getSize(rest.size || 'md');
6
+ const PopoverRoot = ({ children, placement = 'top', open, variant = 'default', portal, size = 'md', onOpenChange, onClose, }) => {
9
7
  const triggerRef = useRef(null);
10
8
  const [internalOpen, setInternalOpen] = useState(open ?? false);
11
9
  const randomPopoverId = useId();
@@ -44,6 +42,6 @@ const PopoverContext = React.createContext({
44
42
  internalOpen: false,
45
43
  setInternalOpen: () => { },
46
44
  });
47
- Popover.displayName = 'Popover';
45
+ PopoverRoot.displayName = 'PopoverRoot';
48
46
 
49
- export { Popover, PopoverContext };
47
+ export { PopoverContext, PopoverRoot };
@@ -3,7 +3,7 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef, useContext, useEffect } from 'react';
4
4
  import { useMergeRefs } from '../../node_modules/@floating-ui/react/dist/floating-ui.react.js';
5
5
  import { Slot as $5e63c961fc1ce211$export$8c6ed5c666ac1360 } from '../../node_modules/@radix-ui/react-slot/dist/index.js';
6
- import { PopoverContext } from './Popover.js';
6
+ import { PopoverContext } from './PopoverRoot.js';
7
7
  import { Button } from '../Button/Button.js';
8
8
 
9
9
  const PopoverTrigger = forwardRef(({ id, asChild, ...rest }, ref) => {
@@ -1,12 +1,14 @@
1
1
  'use client';
2
- import { Popover as Popover$1 } from './Popover.js';
2
+ import { PopoverRoot } from './PopoverRoot.js';
3
3
  import { PopoverContent } from './PopoverContent.js';
4
4
  import { PopoverTrigger } from './PopoverTrigger.js';
5
5
 
6
- const Popover = Popover$1;
6
+ const Popover = {};
7
+ Popover.Root = PopoverRoot;
7
8
  Popover.Content = PopoverContent;
8
9
  Popover.Trigger = PopoverTrigger;
10
+ Popover.Root.displayName = 'Popover.Root';
9
11
  Popover.Content.displayName = 'Popover.Content';
10
12
  Popover.Trigger.displayName = 'Popover.Trigger';
11
13
 
12
- export { Popover, PopoverContent, PopoverTrigger };
14
+ export { Popover, PopoverContent, PopoverRoot, PopoverTrigger };
@@ -1,12 +1,12 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
4
- import { useSynchronizedAnimation } from '../../../hooks/useSynchronizedAnimation.js';
4
+ import { useSynchronizedAnimation } from '../../../utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js';
5
5
 
6
6
  /** Skeleton component used for indicating loading elements of circular shape */
7
7
  const Circle = ({ width, height, className, children, style, ...rest }) => {
8
- const ref = useSynchronizedAnimation('fds-skeleton-opacity-fade');
9
- return (jsx("div", { ref: ref, className: clsx('fds-skeleton', 'fds-skeleton--circle', Boolean(children) && 'fds-skeleton--has-children', className), style: { width, height, ...style }, "aria-hidden": true, ...rest, children: children }));
8
+ const ref = useSynchronizedAnimation('ds-skeleton-opacity-fade');
9
+ return (jsx("div", { ref: ref, className: clsx('ds-skeleton', 'ds-skeleton--circle', Boolean(children) && 'ds-skeleton--has-children', className), style: { width, height, ...style }, "aria-hidden": true, ...rest, children: children }));
10
10
  };
11
11
  Circle.displayName = 'SkeletonCircle';
12
12
 
@@ -1,12 +1,12 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
4
- import { useSynchronizedAnimation } from '../../../hooks/useSynchronizedAnimation.js';
4
+ import { useSynchronizedAnimation } from '../../../utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js';
5
5
 
6
6
  /** Skeleton component used for indicating loading elements of rectangle shape */
7
7
  const Rectangle = ({ width, height, className, children, style, ...rest }) => {
8
- const ref = useSynchronizedAnimation('fds-skeleton-opacity-fade');
9
- return (jsx("div", { ref: ref, className: clsx('fds-skeleton', 'fds-skeleton--rectangle', Boolean(children) && 'fds-skeleton--has-children', className), style: { width, height, ...style }, "aria-hidden": true, ...rest, children: children }));
8
+ const ref = useSynchronizedAnimation('ds-skeleton-opacity-fade');
9
+ return (jsx("div", { ref: ref, className: clsx('ds-skeleton', 'ds-skeleton--rectangle', Boolean(children) && 'ds-skeleton--has-children', className), style: { width, height, ...style }, "aria-hidden": true, ...rest, children: children }));
10
10
  };
11
11
  Rectangle.displayName = 'SkeletonRectangle';
12
12
 
@@ -1,12 +1,12 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { clsx } from '../../../node_modules/clsx/dist/lite.js';
4
- import { useSynchronizedAnimation } from '../../../hooks/useSynchronizedAnimation.js';
4
+ import { useSynchronizedAnimation } from '../../../utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js';
5
5
 
6
6
  /** Skeleton component used for indicating loading elements of text */
7
7
  const Text = ({ width, height, className, style, children, ...rest }) => {
8
- const ref = useSynchronizedAnimation('fds-skeleton-opacity-fade');
9
- return (jsx("div", { ref: ref, className: clsx('fds-skeleton', 'fds-skeleton--text', Boolean(children) && 'fds-skeleton--has-children', className), style: { width, height, ...style }, "aria-hidden": true, ...rest, children: children }));
8
+ const ref = useSynchronizedAnimation('ds-skeleton-opacity-fade');
9
+ return (jsx("div", { ref: ref, className: clsx('ds-skeleton', 'ds-skeleton--text', Boolean(children) && 'ds-skeleton--has-children', className), style: { width, height, ...style }, "aria-hidden": true, ...rest, children: children }));
10
10
  };
11
11
  Text.displayName = 'SkeletonText';
12
12
 
@@ -3,7 +3,7 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
4
4
 
5
5
  const SkipLink = ({ href, children, className, ...rest }) => {
6
- return (jsx("a", { href: href, className: clsx(`fds-sr-only`, 'fds-skiplink', className), ...rest, children: children }));
6
+ return (jsx("a", { href: href, className: clsx(`ds-sr-only`, 'ds-skiplink', className), ...rest, children: jsx("p", { className: 'ds-skiplink__content', children: children }) }));
7
7
  };
8
8
  SkipLink.displayName = 'SkipLink';
9
9
 
@@ -1,8 +1,7 @@
1
1
  'use client';
2
2
  import { jsxs, jsx } from 'react/jsx-runtime';
3
3
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
4
- import { getSize } from '../../utilities/getSize.js';
5
- import { useSynchronizedAnimation } from '../../hooks/useSynchronizedAnimation.js';
4
+ import { useSynchronizedAnimation } from '../../utilities/hooks/useSynchronizedAnimation/useSynchronizedAnimation.js';
6
5
 
7
6
  const sizeMap = {
8
7
  '2xs': 13,
@@ -13,11 +12,10 @@ const sizeMap = {
13
12
  xl: 79,
14
13
  };
15
14
  /** Spinner component used for indicating busy or indeterminate loading */
16
- const Spinner = ({ title, variant = 'default', className, style, ...rest }) => {
17
- const size = getSize(rest.size || 'md');
18
- const svgRef = useSynchronizedAnimation('fds-spinner-rotate-animation');
19
- const strokeRef = useSynchronizedAnimation('fds-spinner-stroke-animation');
20
- return (jsxs("svg", { className: clsx('fds-spinner', `fds-spinner--${variant}`, className), style: { width: sizeMap[size], height: sizeMap[size], ...style }, viewBox: '0 0 50 50', ref: svgRef, ...rest, children: [jsx("title", { children: title }), jsx("circle", { className: clsx('fds-spinner__background', variant === 'inverted' && 'fds-spinner__background--inverted'), cx: '25', cy: '25', r: '20', fill: 'none', strokeWidth: '5' }), jsx("circle", { className: clsx(`fds-spinner__circle`), cx: '25', cy: '25', r: '20', fill: 'none', strokeWidth: '5', ref: strokeRef })] }));
15
+ const Spinner = ({ title, color = 'neutral', size = 'md', className, style, ...rest }) => {
16
+ const svgRef = useSynchronizedAnimation('ds-spinner-rotate-animation');
17
+ const strokeRef = useSynchronizedAnimation('ds-spinner-stroke-animation');
18
+ return (jsxs("svg", { className: clsx('ds-spinner', `ds-spinner--${color}`, className), style: { width: sizeMap[size], height: sizeMap[size], ...style }, viewBox: '0 0 50 50', ref: svgRef, ...rest, children: [jsx("title", { children: title }), jsx("circle", { className: clsx('ds-spinner__background'), cx: '25', cy: '25', r: '20', fill: 'none', strokeWidth: '5' }), jsx("circle", { className: clsx(`ds-spinner__circle`), cx: '25', cy: '25', r: '20', fill: 'none', strokeWidth: '5', ref: strokeRef })] }));
21
19
  };
22
20
  Spinner.displayName = 'Spinner';
23
21
 
@@ -2,12 +2,10 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import * as React from 'react';
4
4
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
- import { getSize } from '../../utilities/getSize.js';
6
5
  import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
7
6
 
8
- const Table = React.forwardRef(({ zebra = false, stickyHeader = false, border = false, className, children, ...rest }, ref) => {
9
- const size = getSize(rest.size || 'md');
10
- return (jsx(Paragraph, { asChild: true, size: size, children: jsx("table", { ref: ref, className: clsx('fds-table', `fds-table--${size}`, zebra && 'fds-table--zebra', stickyHeader && 'fds-table--sticky-header', border && 'fds-table--border', className), ...rest, children: children }) }));
7
+ const Table = React.forwardRef(({ zebra = false, stickyHeader = false, border = false, size = 'md', className, children, ...rest }, ref) => {
8
+ return (jsx(Paragraph, { asChild: true, size: size, children: jsx("table", { ref: ref, className: clsx('ds-table', `ds-table--${size}`, zebra && 'ds-table--zebra', stickyHeader && 'ds-table--sticky-header', border && 'ds-table--border', `ds-paragraph--${size}`, className), ...rest, children: children }) }));
11
9
  });
12
10
  Table.displayName = 'Table';
13
11
 
@@ -4,7 +4,7 @@ import * as React from 'react';
4
4
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
5
 
6
6
  const TableCell = React.forwardRef(({ className, children, ...rest }, ref) => {
7
- return (jsx("td", { ref: ref, className: clsx('fds-table__cell', className), ...rest, children: children }));
7
+ return (jsx("td", { ref: ref, className: clsx('ds-table__cell', className), ...rest, children: children }));
8
8
  });
9
9
  TableCell.displayName = 'TableCell';
10
10
 
@@ -4,7 +4,7 @@ import * as React from 'react';
4
4
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
5
 
6
6
  const TableHead = React.forwardRef(({ className, children, ...rest }, ref) => {
7
- return (jsx("thead", { ref: ref, className: clsx('fds-table__head', className), ...rest, children: children }));
7
+ return (jsx("thead", { ref: ref, className: clsx('ds-table__head', className), ...rest, children: children }));
8
8
  });
9
9
  TableHead.displayName = 'TableHead';
10
10
 
@@ -10,7 +10,7 @@ const SORT_ICON = {
10
10
  };
11
11
  const TableHeaderCell = React.forwardRef(({ sortable = false, sort, onSortClick, className, children, ...rest }, ref) => {
12
12
  const sortIcon = sort === 'ascending' || sort === 'descending' ? (SORT_ICON[sort]) : (jsx(ChevronUpDownIcon, {}));
13
- return (jsxs("th", { className: clsx('fds-table__header__cell', sortable && 'fds-table__header__cell--sortable', sort && `fds-table__header__cell--sorted`, className), "aria-sort": sort, ref: ref, ...rest, children: [sortable && (jsxs("button", { className: `fds-focus`, onClick: onSortClick, children: [children, sortIcon] })), !sortable && children] }));
13
+ return (jsxs("th", { className: clsx('ds-table__header__cell', 'ds-font-weight--medium', sortable && 'ds-table__header__cell--sortable', sort && `ds-table__header__cell--sorted`, className), "aria-sort": sort, ref: ref, ...rest, children: [sortable && (jsxs("button", { className: 'ds-focus', onClick: onSortClick, children: [children, sortIcon] })), !sortable && children] }));
14
14
  });
15
15
  TableHeaderCell.displayName = 'TableHeaderCell';
16
16
 
@@ -4,7 +4,7 @@ import * as React from 'react';
4
4
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
5
 
6
6
  const TableRow = React.forwardRef(({ className, children, ...rest }, ref) => {
7
- return (jsx("tr", { className: clsx('fds-table__row', className), ref: ref, ...rest, children: children }));
7
+ return (jsx("tr", { className: clsx('ds-table__row', className), ref: ref, ...rest, children: children }));
8
8
  });
9
9
  TableRow.displayName = 'TableRow';
10
10
 
@@ -0,0 +1,21 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { forwardRef } from 'react';
4
+ import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
+ import { useTabItem } from './useTab.js';
6
+ import { RovingFocusItem } from '../../utilities/RovingFocus/RovingFocusItem.js';
7
+ import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
8
+
9
+ /**
10
+ * A single item in a Tabs component.
11
+ * @example
12
+ * <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
13
+ */
14
+ const Tab = forwardRef((props, ref) => {
15
+ const { children, className, ...rest } = props;
16
+ const { size, ...useTabRest } = useTabItem(props);
17
+ return (jsx(RovingFocusItem, { ...rest, asChild: true, children: jsx(Paragraph, { asChild: true, variant: 'short', size: size, children: jsx("button", { ...useTabRest, type: 'button', className: clsx('ds-tabs__tab', 'ds-focus', className), ref: ref, children: children }) }) }));
18
+ });
19
+ Tab.displayName = 'Tab';
20
+
21
+ export { Tab };
@@ -0,0 +1,22 @@
1
+ 'use client';
2
+ import { jsx, Fragment } from 'react/jsx-runtime';
3
+ import { forwardRef, useContext } from 'react';
4
+ import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
+ import { TabsContext } from './TabsRoot.js';
6
+ import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
7
+
8
+ /**
9
+ * A single content item in a Tabs component.
10
+ * @example
11
+ * ```tsx
12
+ * <Tabs.Content value='1'>content 1</Tabs.Content>
13
+ * ```
14
+ */
15
+ const TabContent = forwardRef(({ children, value, className, ...rest }, ref) => {
16
+ const { value: tabsValue, size } = useContext(TabsContext);
17
+ const active = value == tabsValue;
18
+ return (jsx(Fragment, { children: active && (jsx(Paragraph, { asChild: true, variant: 'short', size: size, children: jsx("div", { className: clsx('ds-tabs__content', className), ref: ref, ...rest, children: children }) })) }));
19
+ });
20
+ TabContent.displayName = 'TabContent';
21
+
22
+ export { TabContent };
@@ -0,0 +1,24 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { forwardRef, useContext } from 'react';
4
+ import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
+ import { TabsContext } from './TabsRoot.js';
6
+ import { RovingFocusRoot } from '../../utilities/RovingFocus/RovingFocusRoot.js';
7
+
8
+ /**
9
+ * The container for all `Tab` components.
10
+ * @example
11
+ * ```tsx
12
+ * <Tabs.List>
13
+ * <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
14
+ * <Tabs.Tab value='2'>Tab 2</Tabs.Tab>
15
+ * </Tabs.List>
16
+ * ```
17
+ */
18
+ const TabList = forwardRef(({ children, className, ...rest }, ref) => {
19
+ const { value } = useContext(TabsContext);
20
+ return (jsx(RovingFocusRoot, { role: 'tablist', activeValue: value, className: clsx('ds-tabs__tablist', className), ref: ref, ...rest, children: children }));
21
+ });
22
+ TabList.displayName = 'TabList';
23
+
24
+ export { TabList };
@@ -0,0 +1,43 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { createContext, forwardRef, useState } from 'react';
4
+ import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
+
6
+ const TabsContext = createContext({});
7
+ /**
8
+ * Display a group of tabs that can be toggled between.
9
+ * @example
10
+ * ```tsx
11
+ * <Tabs.Root onChange={(value) => console.log(value)}>
12
+ * <Tabs.List>
13
+ * <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
14
+ * <Tabs.Tab value='2'>Tab 2</Tabs.Tab>
15
+ * <Tabs.Tab value='3'>Tab 3</Tabs.Tab>
16
+ * </Tabs.List>
17
+ * <Tabs.Content value='1'>content 1</Tabs.Content>
18
+ * <Tabs.Content value='2'>content 2</Tabs.Content>
19
+ * <Tabs.Content value='3'>content 3</Tabs.Content>
20
+ * </Tabs.Root>
21
+ * ```
22
+ */
23
+ const TabsRoot = forwardRef(({ size = 'md', children, value, defaultValue, className, onChange, ...rest }, ref) => {
24
+ const isControlled = value !== undefined;
25
+ const [uncontrolledValue, setUncontrolledValue] = useState(defaultValue);
26
+ let onValueChange = onChange;
27
+ if (!isControlled) {
28
+ onValueChange = (newValue) => {
29
+ setUncontrolledValue(newValue);
30
+ onChange?.(newValue);
31
+ };
32
+ value = uncontrolledValue;
33
+ }
34
+ return (jsx(TabsContext.Provider, { value: {
35
+ value,
36
+ defaultValue,
37
+ onChange: onValueChange,
38
+ size,
39
+ }, children: jsx("div", { className: clsx('ds-tabs', `ds-tabs--${size}`, className), ref: ref, ...rest, children: children }) }));
40
+ });
41
+ TabsRoot.displayName = 'TabsRoot';
42
+
43
+ export { TabsContext, TabsRoot };
@@ -1,15 +1,33 @@
1
1
  'use client';
2
- import { Tabs as Tabs$1 } from './Tabs.js';
3
- import { Tab } from './Tab/Tab.js';
4
- import { TabList } from './TabList/TabList.js';
5
- import { TabContent } from './TabContent/TabContent.js';
2
+ import { TabsRoot } from './TabsRoot.js';
3
+ import { Tab } from './Tab.js';
4
+ import { TabList } from './TabList.js';
5
+ import { TabContent } from './TabContent.js';
6
6
 
7
- const Tabs = Tabs$1;
7
+ /**
8
+ * Display a group of tabs that can be toggled between.
9
+ * @example
10
+ * ```tsx
11
+ * <Tabs.Root onChange={(value) => console.log(value)}>
12
+ * <Tabs.List>
13
+ * <Tabs.Tab value='1'>Tab 1</Tabs.Tab>
14
+ * <Tabs.Tab value='2'>Tab 2</Tabs.Tab>
15
+ * <Tabs.Tab value='3'>Tab 3</Tabs.Tab>
16
+ * </Tabs.List>
17
+ * <Tabs.Content value='1'>content 1</Tabs.Content>
18
+ * <Tabs.Content value='2'>content 2</Tabs.Content>
19
+ * <Tabs.Content value='3'>content 3</Tabs.Content>
20
+ * </Tabs.Root>
21
+ * ```
22
+ */
23
+ const Tabs = {};
24
+ Tabs.Root = TabsRoot;
8
25
  Tabs.Tab = Tab;
9
26
  Tabs.List = TabList;
10
27
  Tabs.Content = TabContent;
28
+ Tabs.Root.displayName = 'Tabs.Root';
11
29
  Tabs.Tab.displayName = 'Tabs.Tab';
12
30
  Tabs.List.displayName = 'Tabs.List';
13
31
  Tabs.Content.displayName = 'Tabs.Content';
14
32
 
15
- export { Tab, TabContent, TabList, Tabs };
33
+ export { Tab, TabContent, TabList, Tabs, TabsRoot };
@@ -1,6 +1,6 @@
1
1
  'use client';
2
2
  import { useContext, useId } from 'react';
3
- import { TabsContext } from '../Tabs.js';
3
+ import { TabsContext } from './TabsRoot.js';
4
4
 
5
5
  /** Handles props for `Tab` in context with `Tabs` */
6
6
  const useTabItem = (props) => {
@@ -12,6 +12,7 @@ const useTabItem = (props) => {
12
12
  id: buttonId,
13
13
  'aria-selected': tabs.value == value,
14
14
  role: 'tab',
15
+ size: tabs.size,
15
16
  onClick: () => {
16
17
  tabs.onChange?.(value);
17
18
  },
@@ -2,12 +2,15 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef } from 'react';
4
4
  import { clsx } from '../../node_modules/clsx/dist/lite.js';
5
- import { getSize } from '../../utilities/getSize.js';
6
5
  import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
7
6
 
8
- const Tag = forwardRef(({ children, color = 'neutral', className, ...rest }, ref) => {
9
- const size = getSize(rest.size || 'md');
10
- return (jsx(Paragraph, { asChild: true, size: size, children: jsx("span", { className: clsx('fds-tag', `fds-tag--${color}`, `fds-tag--${size}`, className), ref: ref, ...rest, children: children }) }));
7
+ /**
8
+ * Use `Tag` to display a small piece of information.
9
+ * @example
10
+ * <Tag color='success'>Success</Tag>
11
+ */
12
+ const Tag = forwardRef(({ size = 'md', color = 'neutral', children, className, ...rest }, ref) => {
13
+ return (jsx(Paragraph, { asChild: true, size: size, children: jsx("span", { className: clsx('ds-tag', `ds-tag--${color}`, `ds-tag--${size}`, className), ref: ref, ...rest, children: children }) }));
11
14
  });
12
15
  Tag.displayName = 'Tag';
13
16
 
@@ -3,13 +3,18 @@ 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 { useToggleGroupItem } from './useToggleGroupitem.js';
6
- import { RovingTabindexItem } from '../../../utilities/RovingTabIndex/RovingTabindexItem.js';
6
+ import { RovingFocusItem } from '../../../utilities/RovingFocus/RovingFocusItem.js';
7
7
  import { Button } from '../../Button/Button.js';
8
8
 
9
+ /**
10
+ * A single item in a ToggleGroup.
11
+ * @example
12
+ * <ToggleGroup.Item value='1'>Toggle 1</ToggleGroup.Item>
13
+ */
9
14
  const ToggleGroupItem = forwardRef((props, ref) => {
10
15
  const { children, icon, className, ...rest } = props;
11
- const { active, size = 'md', buttonProps } = useToggleGroupItem(props);
12
- return (jsx(RovingTabindexItem, { asChild: true, value: rest.value, children: jsx(Button, { className: clsx('fds-togglegroup__item', className), icon: icon, color: 'first', variant: active ? 'primary' : 'tertiary', size: size, ref: ref, ...rest, ...buttonProps, children: children }) }));
16
+ const { active, size = 'md', buttonProps, value } = useToggleGroupItem(props);
17
+ return (jsx(RovingFocusItem, { asChild: true, value: value, children: jsx(Button, { className: clsx('ds-togglegroup__item', className), icon: icon, variant: active ? 'primary' : 'tertiary', size: size, ref: ref, ...rest, ...buttonProps, children: children }) }));
13
18
  });
14
19
  ToggleGroupItem.displayName = 'ToggleGroupItem';
15
20