@digdir/designsystemet-react 1.0.0-next.34 → 1.0.0-next.36

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 (542) hide show
  1. package/README.md +1 -2
  2. package/dist/cjs/components/Accordion/Accordion.js +1 -1
  3. package/dist/cjs/components/Accordion/AccordionContent.js +1 -2
  4. package/dist/cjs/components/Accordion/AccordionHeading.js +4 -6
  5. package/dist/cjs/components/Accordion/AccordionItem.js +16 -52
  6. package/dist/cjs/components/Alert/Alert.js +2 -3
  7. package/dist/cjs/components/Avatar/Avatar.js +5 -10
  8. package/dist/cjs/components/Badge/Badge.js +4 -10
  9. package/dist/cjs/components/Breadcrumbs/Breadcrumbs.js +1 -2
  10. package/dist/cjs/components/Button/Button.js +5 -5
  11. package/dist/cjs/components/Card/Card.js +24 -6
  12. package/dist/cjs/components/Card/{CardMedia.js → CardBlock.js} +3 -4
  13. package/dist/cjs/components/Card/index.js +6 -17
  14. package/dist/cjs/components/Chip/Chips.js +51 -0
  15. package/dist/cjs/components/Chip/index.js +12 -11
  16. package/dist/cjs/components/Dropdown/Dropdown.js +2 -12
  17. package/dist/cjs/components/Dropdown/DropdownButton.js +12 -0
  18. package/dist/cjs/components/Dropdown/DropdownHeading.js +3 -6
  19. package/dist/cjs/components/Dropdown/DropdownItem.js +2 -5
  20. package/dist/cjs/components/Dropdown/DropdownList.js +1 -2
  21. package/dist/cjs/components/Dropdown/DropdownTriggerContext.js +26 -0
  22. package/dist/cjs/components/Dropdown/index.js +13 -7
  23. package/dist/cjs/components/ErrorSummary/ErrorSummary.js +2 -3
  24. package/dist/cjs/components/ErrorSummary/ErrorSummaryHeading.js +3 -8
  25. package/dist/cjs/components/ErrorSummary/ErrorSummaryList.js +1 -3
  26. package/dist/cjs/components/{Typography/Heading → Heading}/Heading.js +3 -4
  27. package/dist/cjs/components/HelpText/HelpText.js +2 -2
  28. package/dist/cjs/components/{Typography/Label → Label}/Label.js +3 -4
  29. package/dist/cjs/components/Link/Link.js +2 -2
  30. package/dist/cjs/components/List/Lists.js +2 -3
  31. package/dist/cjs/components/Modal/Modal.js +51 -0
  32. package/dist/cjs/components/Modal/ModalBlock.js +14 -0
  33. package/dist/cjs/components/Modal/ModalTrigger.js +4 -5
  34. package/dist/cjs/components/Modal/ModalTriggerContext.js +17 -0
  35. package/dist/cjs/components/Modal/index.js +12 -22
  36. package/dist/cjs/components/Pagination/Pagination.js +5 -14
  37. package/dist/cjs/components/Pagination/PaginationButton.js +2 -4
  38. package/dist/cjs/components/Pagination/PaginationItem.js +1 -4
  39. package/dist/cjs/components/Pagination/PaginationList.js +2 -5
  40. package/dist/cjs/components/Pagination/index.js +5 -19
  41. package/dist/cjs/components/Pagination/usePagination.js +46 -51
  42. package/dist/cjs/components/Paragraph/Paragraph.js +20 -0
  43. package/dist/cjs/components/Popover/Popover.js +41 -19
  44. package/dist/cjs/components/Popover/PopoverTrigger.js +2 -2
  45. package/dist/cjs/components/Popover/{PopoverContext.js → PopoverTriggerContext.js} +3 -3
  46. package/dist/cjs/components/Popover/index.js +4 -4
  47. package/dist/cjs/components/SkipLink/SkipLink.js +4 -4
  48. package/dist/cjs/components/Table/Table.js +2 -3
  49. package/dist/cjs/components/Table/TableFoot.js +11 -0
  50. package/dist/cjs/components/Table/index.js +11 -6
  51. package/dist/cjs/components/Tabs/Tabs.js +2 -3
  52. package/dist/cjs/components/Tabs/TabsPanel.js +2 -3
  53. package/dist/cjs/components/Tabs/TabsTab.js +1 -2
  54. package/dist/cjs/components/Tag/Tag.js +2 -3
  55. package/dist/cjs/components/ToggleGroup/ToggleGroup.js +1 -2
  56. package/dist/cjs/components/ToggleGroup/ToggleGroupItem.js +2 -2
  57. package/dist/cjs/components/ToggleGroup/useToggleGroupitem.js +0 -1
  58. package/dist/cjs/components/Tooltip/Tooltip.js +51 -22
  59. package/dist/cjs/components/{Typography/ValidationMessage → ValidationMessage}/ValidationMessage.js +2 -2
  60. package/dist/cjs/components/form/Checkbox/Checkbox.js +11 -19
  61. package/dist/cjs/components/form/Combobox/Combobox.js +3 -4
  62. package/dist/cjs/components/form/Combobox/Custom.js +2 -2
  63. package/dist/cjs/components/form/Combobox/Empty.js +2 -2
  64. package/dist/cjs/components/form/Combobox/Option/Option.js +5 -3
  65. package/dist/cjs/components/form/Combobox/internal/ComboboxChips.js +2 -2
  66. package/dist/cjs/components/form/Combobox/internal/ComboboxError.js +2 -2
  67. package/dist/cjs/components/form/Combobox/internal/ComboboxInput.js +2 -2
  68. package/dist/cjs/components/form/Combobox/internal/ComboboxLabel.js +3 -3
  69. package/dist/cjs/components/form/Field/Field.js +17 -0
  70. package/dist/cjs/components/form/Field/FieldAffix.js +16 -0
  71. package/dist/cjs/components/form/Field/FieldCounter.js +28 -0
  72. package/dist/cjs/components/form/Field/FieldDescription.js +11 -0
  73. package/dist/cjs/components/form/Field/fieldObserver.js +97 -0
  74. package/dist/cjs/components/form/Field/index.js +33 -0
  75. package/dist/cjs/components/form/Fieldset/Fieldset.js +2 -16
  76. package/dist/cjs/components/form/Fieldset/FieldsetDescription.js +12 -0
  77. package/dist/cjs/components/form/Fieldset/FieldsetLegend.js +12 -0
  78. package/dist/cjs/components/form/Fieldset/index.js +25 -0
  79. package/dist/cjs/components/form/Input/Input.js +23 -0
  80. package/dist/cjs/components/form/Radio/Radio.js +11 -10
  81. package/dist/cjs/components/form/Search/Search.js +2 -39
  82. package/dist/cjs/components/form/Search/SearchButton.js +12 -0
  83. package/dist/cjs/components/form/Search/SearchClear.js +28 -0
  84. package/dist/cjs/components/form/Search/SearchInput.js +14 -0
  85. package/dist/cjs/components/form/Search/index.js +33 -0
  86. package/dist/cjs/components/form/Select/Select.js +12 -10
  87. package/dist/cjs/components/form/Select/index.js +4 -3
  88. package/dist/cjs/components/form/Switch/Switch.js +10 -11
  89. package/dist/cjs/components/form/Textarea/Textarea.js +3 -20
  90. package/dist/cjs/components/form/Textfield/Textfield.js +14 -21
  91. package/dist/cjs/components/form/useFormField.js +1 -3
  92. package/dist/cjs/components/loaders/Skeleton/Skeleton.js +2 -1
  93. package/dist/cjs/components/loaders/Spinner/Spinner.js +6 -4
  94. package/dist/cjs/index.js +66 -63
  95. package/dist/cjs/utilities/hooks/useCheckboxGroup/useCheckboxGroup.js +121 -0
  96. package/dist/cjs/utilities/hooks/useRadioGroup/useRadioGroup.js +99 -0
  97. package/dist/esm/components/Accordion/Accordion.js +1 -1
  98. package/dist/esm/components/Accordion/AccordionContent.js +1 -2
  99. package/dist/esm/components/Accordion/AccordionHeading.js +4 -6
  100. package/dist/esm/components/Accordion/AccordionItem.js +17 -53
  101. package/dist/esm/components/Alert/Alert.js +2 -3
  102. package/dist/esm/components/Avatar/Avatar.js +5 -10
  103. package/dist/esm/components/Badge/Badge.js +4 -10
  104. package/dist/esm/components/Breadcrumbs/Breadcrumbs.js +1 -2
  105. package/dist/esm/components/Button/Button.js +6 -6
  106. package/dist/esm/components/Card/Card.js +25 -7
  107. package/dist/esm/components/Card/{CardMedia.js → CardBlock.js} +3 -4
  108. package/dist/esm/components/Card/index.js +6 -14
  109. package/dist/esm/components/Chip/Chips.js +46 -0
  110. package/dist/esm/components/Chip/index.js +9 -9
  111. package/dist/esm/components/Dropdown/Dropdown.js +4 -13
  112. package/dist/esm/components/Dropdown/DropdownButton.js +10 -0
  113. package/dist/esm/components/Dropdown/DropdownHeading.js +4 -7
  114. package/dist/esm/components/Dropdown/DropdownItem.js +3 -6
  115. package/dist/esm/components/Dropdown/DropdownList.js +1 -2
  116. package/dist/esm/components/Dropdown/DropdownTriggerContext.js +24 -0
  117. package/dist/esm/components/Dropdown/index.js +12 -7
  118. package/dist/esm/components/ErrorSummary/ErrorSummary.js +2 -3
  119. package/dist/esm/components/ErrorSummary/ErrorSummaryHeading.js +3 -8
  120. package/dist/esm/components/ErrorSummary/ErrorSummaryList.js +2 -4
  121. package/dist/esm/components/Heading/Heading.js +18 -0
  122. package/dist/esm/components/HelpText/HelpText.js +2 -2
  123. package/dist/esm/components/{Typography/Label → Label}/Label.js +3 -4
  124. package/dist/esm/components/Link/Link.js +2 -2
  125. package/dist/esm/components/List/Lists.js +2 -3
  126. package/dist/esm/components/Modal/Modal.js +49 -0
  127. package/dist/esm/components/Modal/ModalBlock.js +12 -0
  128. package/dist/esm/components/Modal/ModalTrigger.js +4 -5
  129. package/dist/esm/components/Modal/ModalTriggerContext.js +14 -0
  130. package/dist/esm/components/Modal/index.js +11 -18
  131. package/dist/esm/components/Pagination/Pagination.js +6 -15
  132. package/dist/esm/components/Pagination/PaginationButton.js +3 -5
  133. package/dist/esm/components/Pagination/PaginationItem.js +2 -5
  134. package/dist/esm/components/Pagination/PaginationList.js +3 -6
  135. package/dist/esm/components/Pagination/index.js +6 -16
  136. package/dist/esm/components/Pagination/usePagination.js +47 -52
  137. package/dist/esm/components/Paragraph/Paragraph.js +18 -0
  138. package/dist/esm/components/Popover/Popover.js +40 -18
  139. package/dist/esm/components/Popover/PopoverTrigger.js +1 -1
  140. package/dist/esm/components/Popover/{PopoverContext.js → PopoverTriggerContext.js} +3 -3
  141. package/dist/esm/components/Popover/index.js +4 -4
  142. package/dist/esm/components/SkipLink/SkipLink.js +4 -4
  143. package/dist/esm/components/Table/Table.js +2 -3
  144. package/dist/esm/components/Table/TableFoot.js +9 -0
  145. package/dist/esm/components/Table/index.js +11 -7
  146. package/dist/esm/components/Tabs/Tabs.js +2 -3
  147. package/dist/esm/components/Tabs/TabsPanel.js +2 -3
  148. package/dist/esm/components/Tabs/TabsTab.js +1 -2
  149. package/dist/esm/components/Tag/Tag.js +2 -3
  150. package/dist/esm/components/ToggleGroup/ToggleGroup.js +1 -2
  151. package/dist/esm/components/ToggleGroup/ToggleGroupItem.js +2 -2
  152. package/dist/esm/components/ToggleGroup/useToggleGroupitem.js +0 -1
  153. package/dist/esm/components/Tooltip/Tooltip.js +53 -24
  154. package/dist/esm/components/{Typography/ValidationMessage → ValidationMessage}/ValidationMessage.js +2 -2
  155. package/dist/esm/components/form/Checkbox/Checkbox.js +12 -20
  156. package/dist/esm/components/form/Combobox/Combobox.js +4 -5
  157. package/dist/esm/components/form/Combobox/Custom.js +2 -2
  158. package/dist/esm/components/form/Combobox/Empty.js +2 -2
  159. package/dist/esm/components/form/Combobox/Option/Option.js +5 -3
  160. package/dist/esm/components/form/Combobox/internal/ComboboxChips.js +2 -2
  161. package/dist/esm/components/form/Combobox/internal/ComboboxError.js +2 -2
  162. package/dist/esm/components/form/Combobox/internal/ComboboxInput.js +2 -2
  163. package/dist/esm/components/form/Combobox/internal/ComboboxLabel.js +3 -3
  164. package/dist/esm/components/form/Field/Field.js +15 -0
  165. package/dist/esm/components/form/Field/FieldAffix.js +13 -0
  166. package/dist/esm/components/form/Field/FieldCounter.js +26 -0
  167. package/dist/esm/components/form/Field/FieldDescription.js +9 -0
  168. package/dist/esm/components/form/Field/fieldObserver.js +95 -0
  169. package/dist/esm/components/form/Field/index.js +27 -0
  170. package/dist/esm/components/form/Fieldset/Fieldset.js +4 -18
  171. package/dist/esm/components/form/Fieldset/FieldsetDescription.js +10 -0
  172. package/dist/esm/components/form/Fieldset/FieldsetLegend.js +10 -0
  173. package/dist/esm/components/form/Fieldset/index.js +21 -0
  174. package/dist/esm/components/form/Input/Input.js +21 -0
  175. package/dist/esm/components/form/Radio/Radio.js +12 -11
  176. package/dist/esm/components/form/Search/Search.js +4 -41
  177. package/dist/esm/components/form/Search/SearchButton.js +10 -0
  178. package/dist/esm/components/form/Search/SearchClear.js +26 -0
  179. package/dist/esm/components/form/Search/SearchInput.js +12 -0
  180. package/dist/esm/components/form/Search/index.js +28 -0
  181. package/dist/esm/components/form/Select/Select.js +13 -11
  182. package/dist/esm/components/form/Select/index.js +4 -3
  183. package/dist/esm/components/form/Switch/Switch.js +11 -12
  184. package/dist/esm/components/form/Textarea/Textarea.js +5 -22
  185. package/dist/esm/components/form/Textfield/Textfield.js +16 -23
  186. package/dist/esm/components/form/useFormField.js +1 -3
  187. package/dist/esm/components/loaders/Skeleton/Skeleton.js +2 -1
  188. package/dist/esm/components/loaders/Spinner/Spinner.js +6 -4
  189. package/dist/esm/index.js +28 -28
  190. package/dist/esm/utilities/hooks/useCheckboxGroup/useCheckboxGroup.js +119 -0
  191. package/dist/esm/utilities/hooks/useRadioGroup/useRadioGroup.js +97 -0
  192. package/dist/types/colors.d.ts +4 -0
  193. package/dist/types/colors.d.ts.map +1 -0
  194. package/dist/types/components/Accordion/Accordion.d.ts +276 -16
  195. package/dist/types/components/Accordion/Accordion.d.ts.map +1 -1
  196. package/dist/types/components/Accordion/AccordionContent.d.ts.map +1 -1
  197. package/dist/types/components/Accordion/AccordionHeading.d.ts +2 -2
  198. package/dist/types/components/Accordion/AccordionHeading.d.ts.map +1 -1
  199. package/dist/types/components/Accordion/AccordionItem.d.ts +8 -8
  200. package/dist/types/components/Accordion/AccordionItem.d.ts.map +1 -1
  201. package/dist/types/components/Alert/Alert.d.ts +275 -23
  202. package/dist/types/components/Alert/Alert.d.ts.map +1 -1
  203. package/dist/types/components/Avatar/Avatar.d.ts +282 -36
  204. package/dist/types/components/Avatar/Avatar.d.ts.map +1 -1
  205. package/dist/types/components/Badge/Badge.d.ts +281 -50
  206. package/dist/types/components/Badge/Badge.d.ts.map +1 -1
  207. package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts +273 -18
  208. package/dist/types/components/Breadcrumbs/Breadcrumbs.d.ts.map +1 -1
  209. package/dist/types/components/Breadcrumbs/BreadcrumbsLink.d.ts +277 -5
  210. package/dist/types/components/Breadcrumbs/BreadcrumbsLink.d.ts.map +1 -1
  211. package/dist/types/components/Breadcrumbs/index.d.ts +546 -8
  212. package/dist/types/components/Breadcrumbs/index.d.ts.map +1 -1
  213. package/dist/types/components/Button/Button.d.ts +289 -41
  214. package/dist/types/components/Button/Button.d.ts.map +1 -1
  215. package/dist/types/components/Card/Card.d.ts +280 -34
  216. package/dist/types/components/Card/Card.d.ts.map +1 -1
  217. package/dist/types/components/Card/{CardMedia.d.ts → CardBlock.d.ts} +3 -3
  218. package/dist/types/components/Card/{CardMedia.d.ts.map → CardBlock.d.ts.map} +1 -1
  219. package/dist/types/components/Card/index.d.ts +278 -16
  220. package/dist/types/components/Card/index.d.ts.map +1 -1
  221. package/dist/types/components/Chip/Chips.d.ts +1204 -0
  222. package/dist/types/components/Chip/Chips.d.ts.map +1 -0
  223. package/dist/types/components/Chip/index.d.ts +1166 -21
  224. package/dist/types/components/Chip/index.d.ts.map +1 -1
  225. package/dist/types/components/Dropdown/Dropdown.d.ts +283 -15
  226. package/dist/types/components/Dropdown/Dropdown.d.ts.map +1 -1
  227. package/dist/types/components/Dropdown/DropdownButton.d.ts +4 -0
  228. package/dist/types/components/Dropdown/DropdownButton.d.ts.map +1 -0
  229. package/dist/types/components/Dropdown/DropdownHeading.d.ts +7 -3
  230. package/dist/types/components/Dropdown/DropdownHeading.d.ts.map +1 -1
  231. package/dist/types/components/Dropdown/DropdownItem.d.ts +3 -3
  232. package/dist/types/components/Dropdown/DropdownItem.d.ts.map +1 -1
  233. package/dist/types/components/Dropdown/DropdownList.d.ts.map +1 -1
  234. package/dist/types/components/Dropdown/DropdownTrigger.d.ts +285 -15
  235. package/dist/types/components/Dropdown/DropdownTrigger.d.ts.map +1 -1
  236. package/dist/types/components/Dropdown/DropdownTriggerContext.d.ts +22 -0
  237. package/dist/types/components/Dropdown/DropdownTriggerContext.d.ts.map +1 -0
  238. package/dist/types/components/Dropdown/index.d.ts +577 -25
  239. package/dist/types/components/Dropdown/index.d.ts.map +1 -1
  240. package/dist/types/components/ErrorSummary/ErrorSummary.d.ts +3 -8
  241. package/dist/types/components/ErrorSummary/ErrorSummary.d.ts.map +1 -1
  242. package/dist/types/components/ErrorSummary/ErrorSummaryHeading.d.ts +2 -3
  243. package/dist/types/components/ErrorSummary/ErrorSummaryHeading.d.ts.map +1 -1
  244. package/dist/types/components/ErrorSummary/ErrorSummaryList.d.ts +1 -2
  245. package/dist/types/components/ErrorSummary/ErrorSummaryList.d.ts.map +1 -1
  246. package/dist/types/components/ErrorSummary/index.d.ts +3 -7
  247. package/dist/types/components/ErrorSummary/index.d.ts.map +1 -1
  248. package/dist/types/components/{Typography/Heading → Heading}/Heading.d.ts +3 -11
  249. package/dist/types/components/Heading/Heading.d.ts.map +1 -0
  250. package/dist/types/components/Heading/index.d.ts.map +1 -0
  251. package/dist/types/components/HelpText/HelpText.d.ts +286 -22
  252. package/dist/types/components/HelpText/HelpText.d.ts.map +1 -1
  253. package/dist/types/components/{Typography/Label → Label}/Label.d.ts +4 -17
  254. package/dist/types/components/Label/Label.d.ts.map +1 -0
  255. package/dist/types/components/Label/index.d.ts.map +1 -0
  256. package/dist/types/components/Link/Link.d.ts +284 -20
  257. package/dist/types/components/Link/Link.d.ts.map +1 -1
  258. package/dist/types/components/List/Lists.d.ts +16 -9
  259. package/dist/types/components/List/Lists.d.ts.map +1 -1
  260. package/dist/types/components/List/index.d.ts +2 -4
  261. package/dist/types/components/List/index.d.ts.map +1 -1
  262. package/dist/types/components/Modal/Modal.d.ts +297 -0
  263. package/dist/types/components/Modal/Modal.d.ts.map +1 -0
  264. package/dist/types/components/{Card/CardFooter.d.ts → Modal/ModalBlock.d.ts} +3 -3
  265. package/dist/types/components/Modal/ModalBlock.d.ts.map +1 -0
  266. package/dist/types/components/Modal/ModalTrigger.d.ts +282 -7
  267. package/dist/types/components/Modal/ModalTrigger.d.ts.map +1 -1
  268. package/dist/types/components/Modal/ModalTriggerContext.d.ts +10 -0
  269. package/dist/types/components/Modal/ModalTriggerContext.d.ts.map +1 -0
  270. package/dist/types/components/Modal/index.d.ts +576 -20
  271. package/dist/types/components/Modal/index.d.ts.map +1 -1
  272. package/dist/types/components/Pagination/Pagination.d.ts +287 -45
  273. package/dist/types/components/Pagination/Pagination.d.ts.map +1 -1
  274. package/dist/types/components/Pagination/PaginationButton.d.ts +289 -5
  275. package/dist/types/components/Pagination/PaginationButton.d.ts.map +1 -1
  276. package/dist/types/components/Pagination/PaginationItem.d.ts.map +1 -1
  277. package/dist/types/components/Pagination/PaginationList.d.ts +1 -1
  278. package/dist/types/components/Pagination/PaginationList.d.ts.map +1 -1
  279. package/dist/types/components/Pagination/index.d.ts +565 -17
  280. package/dist/types/components/Pagination/index.d.ts.map +1 -1
  281. package/dist/types/components/Pagination/usePagination.d.ts +41 -17
  282. package/dist/types/components/Pagination/usePagination.d.ts.map +1 -1
  283. package/dist/types/components/{Typography/Paragraph → Paragraph}/Paragraph.d.ts +3 -13
  284. package/dist/types/components/Paragraph/Paragraph.d.ts.map +1 -0
  285. package/dist/types/components/Paragraph/index.d.ts.map +1 -0
  286. package/dist/types/components/Popover/Popover.d.ts +287 -43
  287. package/dist/types/components/Popover/Popover.d.ts.map +1 -1
  288. package/dist/types/components/Popover/PopoverTrigger.d.ts +285 -13
  289. package/dist/types/components/Popover/PopoverTrigger.d.ts.map +1 -1
  290. package/dist/types/components/Popover/PopoverTriggerContext.d.ts +13 -0
  291. package/dist/types/components/Popover/PopoverTriggerContext.d.ts.map +1 -0
  292. package/dist/types/components/Popover/index.d.ts +4 -4
  293. package/dist/types/components/Popover/index.d.ts.map +1 -1
  294. package/dist/types/components/SkipLink/SkipLink.d.ts +283 -7
  295. package/dist/types/components/SkipLink/SkipLink.d.ts.map +1 -1
  296. package/dist/types/components/Table/Table.d.ts +3 -12
  297. package/dist/types/components/Table/Table.d.ts.map +1 -1
  298. package/dist/types/components/Table/TableFoot.d.ts +4 -0
  299. package/dist/types/components/Table/TableFoot.d.ts.map +1 -0
  300. package/dist/types/components/Table/TableHeaderCell.d.ts.map +1 -1
  301. package/dist/types/components/Table/index.d.ts +18 -10
  302. package/dist/types/components/Table/index.d.ts.map +1 -1
  303. package/dist/types/components/Tabs/Tabs.d.ts +278 -20
  304. package/dist/types/components/Tabs/Tabs.d.ts.map +1 -1
  305. package/dist/types/components/Tabs/TabsPanel.d.ts.map +1 -1
  306. package/dist/types/components/Tabs/TabsTab.d.ts.map +1 -1
  307. package/dist/types/components/Tabs/index.d.ts +270 -5
  308. package/dist/types/components/Tabs/index.d.ts.map +1 -1
  309. package/dist/types/components/Tag/Tag.d.ts +276 -23
  310. package/dist/types/components/Tag/Tag.d.ts.map +1 -1
  311. package/dist/types/components/ToggleGroup/ToggleGroup.d.ts +279 -23
  312. package/dist/types/components/ToggleGroup/ToggleGroup.d.ts.map +1 -1
  313. package/dist/types/components/ToggleGroup/ToggleGroupItem.d.ts +285 -2
  314. package/dist/types/components/ToggleGroup/ToggleGroupItem.d.ts.map +1 -1
  315. package/dist/types/components/ToggleGroup/useToggleGroupitem.d.ts +0 -2
  316. package/dist/types/components/ToggleGroup/useToggleGroupitem.d.ts.map +1 -1
  317. package/dist/types/components/Tooltip/Tooltip.d.ts +286 -33
  318. package/dist/types/components/Tooltip/Tooltip.d.ts.map +1 -1
  319. package/dist/types/components/ValidationMessage/ValidationMessage.d.ts +285 -0
  320. package/dist/types/components/ValidationMessage/ValidationMessage.d.ts.map +1 -0
  321. package/dist/types/components/ValidationMessage/index.d.ts.map +1 -0
  322. package/dist/types/components/form/CharacterCounter.d.ts +2 -2
  323. package/dist/types/components/form/CharacterCounter.d.ts.map +1 -1
  324. package/dist/types/components/form/Checkbox/Checkbox.d.ts +36 -19
  325. package/dist/types/components/form/Checkbox/Checkbox.d.ts.map +1 -1
  326. package/dist/types/components/form/Checkbox/index.d.ts +2 -21
  327. package/dist/types/components/form/Checkbox/index.d.ts.map +1 -1
  328. package/dist/types/components/form/Combobox/Combobox.d.ts +3 -3
  329. package/dist/types/components/form/Combobox/Combobox.d.ts.map +1 -1
  330. package/dist/types/components/form/Combobox/Option/Option.d.ts.map +1 -1
  331. package/dist/types/components/form/Combobox/internal/ComboboxLabel.d.ts.map +1 -1
  332. package/dist/types/components/form/Field/Field.d.ts +15 -0
  333. package/dist/types/components/form/Field/Field.d.ts.map +1 -0
  334. package/dist/types/components/form/Field/FieldAffix.d.ts +6 -0
  335. package/dist/types/components/form/Field/FieldAffix.d.ts.map +1 -0
  336. package/dist/types/components/form/Field/FieldCounter.d.ts +296 -0
  337. package/dist/types/components/form/Field/FieldCounter.d.ts.map +1 -0
  338. package/dist/types/components/form/Field/FieldDescription.d.ts +4 -0
  339. package/dist/types/components/form/Field/FieldDescription.d.ts.map +1 -0
  340. package/dist/types/components/form/Field/fieldObserver.d.ts +2 -0
  341. package/dist/types/components/form/Field/fieldObserver.d.ts.map +1 -0
  342. package/dist/types/components/form/Field/index.d.ts +300 -0
  343. package/dist/types/components/form/Field/index.d.ts.map +1 -0
  344. package/dist/types/components/form/Fieldset/Fieldset.d.ts +276 -25
  345. package/dist/types/components/form/Fieldset/Fieldset.d.ts.map +1 -1
  346. package/dist/types/components/form/Fieldset/FieldsetContext.d.ts +1 -1
  347. package/dist/types/components/form/Fieldset/FieldsetContext.d.ts.map +1 -1
  348. package/dist/types/components/form/Fieldset/FieldsetDescription.d.ts +8 -0
  349. package/dist/types/components/form/Fieldset/FieldsetDescription.d.ts.map +1 -0
  350. package/dist/types/components/form/Fieldset/FieldsetLegend.d.ts +5 -0
  351. package/dist/types/components/form/Fieldset/FieldsetLegend.d.ts.map +1 -0
  352. package/dist/types/components/form/Fieldset/index.d.ts +295 -1
  353. package/dist/types/components/form/Fieldset/index.d.ts.map +1 -1
  354. package/dist/types/components/form/Input/Input.d.ts +334 -0
  355. package/dist/types/components/form/Input/Input.d.ts.map +1 -0
  356. package/dist/types/components/form/Input/index.d.ts +3 -0
  357. package/dist/types/components/form/Input/index.d.ts.map +1 -0
  358. package/dist/types/components/form/Radio/Radio.d.ts +37 -12
  359. package/dist/types/components/form/Radio/Radio.d.ts.map +1 -1
  360. package/dist/types/components/form/Radio/index.d.ts +2 -19
  361. package/dist/types/components/form/Radio/index.d.ts.map +1 -1
  362. package/dist/types/components/form/Search/Search.d.ts +3 -75
  363. package/dist/types/components/form/Search/Search.d.ts.map +1 -1
  364. package/dist/types/components/form/Search/SearchButton.d.ts +295 -0
  365. package/dist/types/components/form/Search/SearchButton.d.ts.map +1 -0
  366. package/dist/types/components/form/Search/SearchClear.d.ts +299 -0
  367. package/dist/types/components/form/Search/SearchClear.d.ts.map +1 -0
  368. package/dist/types/components/form/Search/SearchInput.d.ts +4 -0
  369. package/dist/types/components/form/Search/SearchInput.d.ts.map +1 -0
  370. package/dist/types/components/form/Search/index.d.ts +593 -1
  371. package/dist/types/components/form/Search/index.d.ts.map +1 -1
  372. package/dist/types/components/form/Select/Select.d.ts +283 -57
  373. package/dist/types/components/form/Select/Select.d.ts.map +1 -1
  374. package/dist/types/components/form/Select/index.d.ts +283 -5
  375. package/dist/types/components/form/Select/index.d.ts.map +1 -1
  376. package/dist/types/components/form/Switch/Switch.d.ts +43 -18
  377. package/dist/types/components/form/Switch/Switch.d.ts.map +1 -1
  378. package/dist/types/components/form/Textarea/Textarea.d.ts +5 -44
  379. package/dist/types/components/form/Textarea/Textarea.d.ts.map +1 -1
  380. package/dist/types/components/form/Textfield/Textfield.d.ts +38 -61
  381. package/dist/types/components/form/Textfield/Textfield.d.ts.map +1 -1
  382. package/dist/types/components/form/useFormField.d.ts +2 -1
  383. package/dist/types/components/form/useFormField.d.ts.map +1 -1
  384. package/dist/types/components/index.d.ts +6 -1
  385. package/dist/types/components/index.d.ts.map +1 -1
  386. package/dist/types/components/loaders/Skeleton/Skeleton.d.ts +8 -17
  387. package/dist/types/components/loaders/Skeleton/Skeleton.d.ts.map +1 -1
  388. package/dist/types/components/loaders/Spinner/Spinner.d.ts +15 -14
  389. package/dist/types/components/loaders/Spinner/Spinner.d.ts.map +1 -1
  390. package/dist/types/components/loaders/Spinner/index.d.ts +1 -2
  391. package/dist/types/components/loaders/Spinner/index.d.ts.map +1 -1
  392. package/dist/types/types.d.ts +19 -0
  393. package/dist/types/types.d.ts.map +1 -0
  394. package/dist/types/utilities/RovingFocus/useRovingFocus.d.ts +1 -1
  395. package/dist/types/utilities/hooks/useCheckboxGroup/useCheckboxGroup.d.ts +377 -0
  396. package/dist/types/utilities/hooks/useCheckboxGroup/useCheckboxGroup.d.ts.map +1 -0
  397. package/dist/types/utilities/hooks/useRadioGroup/useRadioGroup.d.ts +365 -0
  398. package/dist/types/utilities/hooks/useRadioGroup/useRadioGroup.d.ts.map +1 -0
  399. package/dist/types/utilities/index.d.ts +1 -0
  400. package/dist/types/utilities/index.d.ts.map +1 -1
  401. package/dist/types/utilities/types.d.ts +10 -0
  402. package/dist/types/utilities/types.d.ts.map +1 -0
  403. package/package.json +3 -3
  404. package/dist/cjs/components/Card/CardContent.js +0 -16
  405. package/dist/cjs/components/Card/CardFooter.js +0 -16
  406. package/dist/cjs/components/Card/CardHeader.js +0 -16
  407. package/dist/cjs/components/Chip/Group/Group.js +0 -15
  408. package/dist/cjs/components/Chip/Removable/Removable.js +0 -17
  409. package/dist/cjs/components/Chip/Toggle/Toggle.js +0 -18
  410. package/dist/cjs/components/Dropdown/DropdownContext.js +0 -26
  411. package/dist/cjs/components/Modal/ModaContent.js +0 -15
  412. package/dist/cjs/components/Modal/ModalDialog.js +0 -73
  413. package/dist/cjs/components/Modal/ModalFooter.js +0 -15
  414. package/dist/cjs/components/Modal/ModalHeader.js +0 -20
  415. package/dist/cjs/components/Modal/ModalRoot.js +0 -31
  416. package/dist/cjs/components/Modal/useModalState.js +0 -30
  417. package/dist/cjs/components/Modal/useScrollLock.js +0 -29
  418. package/dist/cjs/components/Pagination/PaginationEllipsis.js +0 -15
  419. package/dist/cjs/components/Pagination/PaginationNextPrev.js +0 -16
  420. package/dist/cjs/components/Pagination/PaginationRoot.js +0 -18
  421. package/dist/cjs/components/Typography/Ingress/Ingress.js +0 -21
  422. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +0 -26
  423. package/dist/cjs/components/form/CharacterCounter.js +0 -17
  424. package/dist/cjs/components/form/Checkbox/CheckboxGroup.js +0 -31
  425. package/dist/cjs/components/form/Checkbox/index.js +0 -13
  426. package/dist/cjs/components/form/Checkbox/useCheckbox.js +0 -44
  427. package/dist/cjs/components/form/Radio/RadioGroup.js +0 -23
  428. package/dist/cjs/components/form/Radio/index.js +0 -13
  429. package/dist/cjs/components/form/Radio/useRadio.js +0 -46
  430. package/dist/cjs/components/form/Search/useSearch.js +0 -39
  431. package/dist/cjs/components/form/Select/useSelect.js +0 -49
  432. package/dist/cjs/components/form/Switch/useSwitch.js +0 -46
  433. package/dist/cjs/components/form/Textarea/useTextarea.js +0 -37
  434. package/dist/cjs/components/form/Textfield/useTextfield.js +0 -37
  435. package/dist/esm/components/Card/CardContent.js +0 -14
  436. package/dist/esm/components/Card/CardFooter.js +0 -14
  437. package/dist/esm/components/Card/CardHeader.js +0 -14
  438. package/dist/esm/components/Chip/Group/Group.js +0 -12
  439. package/dist/esm/components/Chip/Removable/Removable.js +0 -15
  440. package/dist/esm/components/Chip/Toggle/Toggle.js +0 -16
  441. package/dist/esm/components/Dropdown/DropdownContext.js +0 -24
  442. package/dist/esm/components/Modal/ModaContent.js +0 -13
  443. package/dist/esm/components/Modal/ModalDialog.js +0 -71
  444. package/dist/esm/components/Modal/ModalFooter.js +0 -13
  445. package/dist/esm/components/Modal/ModalHeader.js +0 -18
  446. package/dist/esm/components/Modal/ModalRoot.js +0 -28
  447. package/dist/esm/components/Modal/useModalState.js +0 -28
  448. package/dist/esm/components/Modal/useScrollLock.js +0 -27
  449. package/dist/esm/components/Pagination/PaginationEllipsis.js +0 -13
  450. package/dist/esm/components/Pagination/PaginationNextPrev.js +0 -13
  451. package/dist/esm/components/Pagination/PaginationRoot.js +0 -15
  452. package/dist/esm/components/Typography/Heading/Heading.js +0 -19
  453. package/dist/esm/components/Typography/Ingress/Ingress.js +0 -19
  454. package/dist/esm/components/Typography/Paragraph/Paragraph.js +0 -24
  455. package/dist/esm/components/form/CharacterCounter.js +0 -15
  456. package/dist/esm/components/form/Checkbox/CheckboxGroup.js +0 -28
  457. package/dist/esm/components/form/Checkbox/index.js +0 -10
  458. package/dist/esm/components/form/Checkbox/useCheckbox.js +0 -42
  459. package/dist/esm/components/form/Radio/RadioGroup.js +0 -20
  460. package/dist/esm/components/form/Radio/index.js +0 -10
  461. package/dist/esm/components/form/Radio/useRadio.js +0 -44
  462. package/dist/esm/components/form/Search/useSearch.js +0 -37
  463. package/dist/esm/components/form/Select/useSelect.js +0 -47
  464. package/dist/esm/components/form/Switch/useSwitch.js +0 -44
  465. package/dist/esm/components/form/Textarea/useTextarea.js +0 -35
  466. package/dist/esm/components/form/Textfield/useTextfield.js +0 -35
  467. package/dist/types/components/Card/CardContent.d.ts +0 -16
  468. package/dist/types/components/Card/CardContent.d.ts.map +0 -1
  469. package/dist/types/components/Card/CardFooter.d.ts.map +0 -1
  470. package/dist/types/components/Card/CardHeader.d.ts +0 -16
  471. package/dist/types/components/Card/CardHeader.d.ts.map +0 -1
  472. package/dist/types/components/Chip/Group/Group.d.ts +0 -20
  473. package/dist/types/components/Chip/Group/Group.d.ts.map +0 -1
  474. package/dist/types/components/Chip/Removable/Removable.d.ts +0 -17
  475. package/dist/types/components/Chip/Removable/Removable.d.ts.map +0 -1
  476. package/dist/types/components/Chip/Toggle/Toggle.d.ts +0 -33
  477. package/dist/types/components/Chip/Toggle/Toggle.d.ts.map +0 -1
  478. package/dist/types/components/Dropdown/DropdownContext.d.ts +0 -22
  479. package/dist/types/components/Dropdown/DropdownContext.d.ts.map +0 -1
  480. package/dist/types/components/Modal/ModaContent.d.ts +0 -16
  481. package/dist/types/components/Modal/ModaContent.d.ts.map +0 -1
  482. package/dist/types/components/Modal/ModalDialog.d.ts +0 -38
  483. package/dist/types/components/Modal/ModalDialog.d.ts.map +0 -1
  484. package/dist/types/components/Modal/ModalFooter.d.ts +0 -16
  485. package/dist/types/components/Modal/ModalFooter.d.ts.map +0 -1
  486. package/dist/types/components/Modal/ModalHeader.d.ts +0 -44
  487. package/dist/types/components/Modal/ModalHeader.d.ts.map +0 -1
  488. package/dist/types/components/Modal/ModalRoot.d.ts +0 -17
  489. package/dist/types/components/Modal/ModalRoot.d.ts.map +0 -1
  490. package/dist/types/components/Modal/useModalState.d.ts +0 -2
  491. package/dist/types/components/Modal/useModalState.d.ts.map +0 -1
  492. package/dist/types/components/Modal/useScrollLock.d.ts +0 -2
  493. package/dist/types/components/Modal/useScrollLock.d.ts.map +0 -1
  494. package/dist/types/components/Pagination/PaginationEllipsis.d.ts +0 -4
  495. package/dist/types/components/Pagination/PaginationEllipsis.d.ts.map +0 -1
  496. package/dist/types/components/Pagination/PaginationNextPrev.d.ts +0 -10
  497. package/dist/types/components/Pagination/PaginationNextPrev.d.ts.map +0 -1
  498. package/dist/types/components/Pagination/PaginationRoot.d.ts +0 -53
  499. package/dist/types/components/Pagination/PaginationRoot.d.ts.map +0 -1
  500. package/dist/types/components/Popover/PopoverContext.d.ts +0 -13
  501. package/dist/types/components/Popover/PopoverContext.d.ts.map +0 -1
  502. package/dist/types/components/Typography/Heading/Heading.d.ts.map +0 -1
  503. package/dist/types/components/Typography/Heading/index.d.ts.map +0 -1
  504. package/dist/types/components/Typography/Ingress/Ingress.d.ts +0 -34
  505. package/dist/types/components/Typography/Ingress/Ingress.d.ts.map +0 -1
  506. package/dist/types/components/Typography/Ingress/index.d.ts +0 -2
  507. package/dist/types/components/Typography/Ingress/index.d.ts.map +0 -1
  508. package/dist/types/components/Typography/Label/Label.d.ts.map +0 -1
  509. package/dist/types/components/Typography/Label/index.d.ts.map +0 -1
  510. package/dist/types/components/Typography/Paragraph/Paragraph.d.ts.map +0 -1
  511. package/dist/types/components/Typography/Paragraph/index.d.ts.map +0 -1
  512. package/dist/types/components/Typography/ValidationMessage/ValidationMessage.d.ts +0 -35
  513. package/dist/types/components/Typography/ValidationMessage/ValidationMessage.d.ts.map +0 -1
  514. package/dist/types/components/Typography/ValidationMessage/index.d.ts.map +0 -1
  515. package/dist/types/components/Typography/index.d.ts +0 -6
  516. package/dist/types/components/Typography/index.d.ts.map +0 -1
  517. package/dist/types/components/form/Checkbox/CheckboxGroup.d.ts +0 -29
  518. package/dist/types/components/form/Checkbox/CheckboxGroup.d.ts.map +0 -1
  519. package/dist/types/components/form/Checkbox/useCheckbox.d.ts +0 -10
  520. package/dist/types/components/form/Checkbox/useCheckbox.d.ts.map +0 -1
  521. package/dist/types/components/form/Radio/RadioGroup.d.ts +0 -43
  522. package/dist/types/components/form/Radio/RadioGroup.d.ts.map +0 -1
  523. package/dist/types/components/form/Radio/useRadio.d.ts +0 -10
  524. package/dist/types/components/form/Radio/useRadio.d.ts.map +0 -1
  525. package/dist/types/components/form/Search/useSearch.d.ts +0 -10
  526. package/dist/types/components/form/Search/useSearch.d.ts.map +0 -1
  527. package/dist/types/components/form/Select/useSelect.d.ts +0 -10
  528. package/dist/types/components/form/Select/useSelect.d.ts.map +0 -1
  529. package/dist/types/components/form/Switch/useSwitch.d.ts +0 -10
  530. package/dist/types/components/form/Switch/useSwitch.d.ts.map +0 -1
  531. package/dist/types/components/form/Textfield/useTextfield.d.ts +0 -10
  532. package/dist/types/components/form/Textfield/useTextfield.d.ts.map +0 -1
  533. package/dist/types/types/Portal.d.ts +0 -9
  534. package/dist/types/types/Portal.d.ts.map +0 -1
  535. package/dist/types/utilities/AnimateHeight/AnimateHeight.d.ts +0 -9
  536. package/dist/types/utilities/AnimateHeight/AnimateHeight.d.ts.map +0 -1
  537. package/dist/types/utilities/AnimateHeight/index.d.ts +0 -3
  538. package/dist/types/utilities/AnimateHeight/index.d.ts.map +0 -1
  539. /package/dist/types/components/{Typography/Heading → Heading}/index.d.ts +0 -0
  540. /package/dist/types/components/{Typography/Label → Label}/index.d.ts +0 -0
  541. /package/dist/types/components/{Typography/Paragraph → Paragraph}/index.d.ts +0 -0
  542. /package/dist/types/components/{Typography/ValidationMessage → ValidationMessage}/index.d.ts +0 -0
package/README.md CHANGED
@@ -2,8 +2,7 @@
2
2
 
3
3
  React implementation of the Designsystemet components
4
4
 
5
- - Headless components.
6
- - Uses `@digdir/designsystemet-theme` and `@digdir/designsystemet-css` for styling.
5
+ - Uses `@digdir/designsystemet-theme` and `@digdir/designsystemet-css` for styling.
7
6
  - All components support `forwardRef`.
8
7
  - Most components extend and behave as native html-elements.
9
8
  - Most components support composition and `asChild` for overriding the underlying html-element.
@@ -8,7 +8,7 @@ var react = require('react');
8
8
  /**
9
9
  * Accordion component, contains `Accordion.Item` components.
10
10
  */
11
- const Accordion = react.forwardRef(function Accordion({ border = false, color = 'neutral', className, ...rest }, ref) {
11
+ const Accordion = react.forwardRef(function Accordion({ border = false, 'data-color': color = 'neutral', className, ...rest }, ref) {
12
12
  return (jsxRuntime.jsx("div", { className: cl('ds-accordion-group', className), "data-border": border || undefined, "data-color": color, ref: ref, ...rest }));
13
13
  });
14
14
 
@@ -3,7 +3,6 @@
3
3
 
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
5
  var react = require('react');
6
- var Paragraph = require('../Typography/Paragraph/Paragraph.js');
7
6
 
8
7
  /**
9
8
  * Accordion content component, contains the content of the accordion item.
@@ -11,7 +10,7 @@ var Paragraph = require('../Typography/Paragraph/Paragraph.js');
11
10
  * <AccordionContent>Content</AccordionContent>
12
11
  */
13
12
  const AccordionContent = react.forwardRef(function AccordionContent(rest, ref) {
14
- return (jsxRuntime.jsx(Paragraph.Paragraph, { asChild: true, size: 'sm', children: jsxRuntime.jsx("div", { ref: ref, ...rest }) }));
13
+ return jsxRuntime.jsx("div", { ref: ref, ...rest });
15
14
  });
16
15
 
17
16
  exports.AccordionContent = AccordionContent;
@@ -2,18 +2,16 @@
2
2
  'use strict';
3
3
 
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
- var cl = require('clsx/lite');
6
5
  var react = require('react');
7
- var Paragraph = require('../Typography/Paragraph/Paragraph.js');
8
6
 
9
7
  /**
10
- * Accordion header component, contains a button to toggle the content.
8
+ * Accordion heading component, contains a button to toggle the content.
11
9
  * @example
12
- * <AccordionHeader>Header</AccordionHeader>
10
+ * <AccordionHeading>Heading</AccordionHeading>
13
11
  */
14
12
  const AccordionHeading = react.forwardRef(function AccordionHeading({ className, ...rest }, ref) {
15
- return (jsxRuntime.jsx(Paragraph.Paragraph, { asChild: true, size: 'sm', children: jsxRuntime.jsx("u-summary", { class: cl('ds-focus ds-paragraph ds-paragraph--sm ds-line-height--md', // Very TMP fix awaiting CSS modules
16
- className), ref: ref, ...rest }) }));
13
+ /* Set `className` as `class` so react is happy */
14
+ return jsxRuntime.jsx("u-summary", { ref: ref, class: className, ...rest });
17
15
  });
18
16
 
19
17
  exports.AccordionHeading = AccordionHeading;
@@ -8,71 +8,35 @@ var react = require('react');
8
8
  require('@u-elements/u-details');
9
9
 
10
10
  /**
11
- * Accordion item component, contains `Accordion.Header` and `Accordion.Content` components.
11
+ * Accordion item component, contains `Accordion.Heading` and `Accordion.Content` components.
12
12
  * @example
13
13
  * <AccordionItem>
14
- * <AccordionHeader>Header</AccordionHeader>
14
+ * <AccordionHeading>Header</AccordionHeading>
15
15
  * <AccordionContent>Content</AccordionContent>
16
16
  * </AccordionItem>
17
17
  */
18
- const AccordionItem = react.forwardRef(function AccordionItem({ className, open, defaultOpen = false, onFound, ...rest }, ref) {
19
- const [internalOpen, setInternalOpen] = react.useState(open ?? defaultOpen);
20
- const initialOpen = react.useRef(internalOpen); // Allow rendering initial open state on server, but animate in browser
21
- const controlledOpen = react.useRef(internalOpen); // Using ref so we can access it inside useEffect without unbinding/binding event listeners
18
+ const AccordionItem = react.forwardRef(function AccordionItem({ className, open, defaultOpen = false, onToggle, ...rest }, ref) {
22
19
  const detailsRef = react.useRef(null);
20
+ const initialOpen = react.useRef(defaultOpen); // Allow rendering defaultOpen on server, but only render once on client
23
21
  const mergedRefs = react$1.useMergeRefs([detailsRef, ref]);
24
- controlledOpen.current = open ?? internalOpen; // Update controlledOpen on prop change
25
- // Control state with a useEffect to animate on prop change and prevent native <details> toggle
22
+ const onToggleRef = react.useRef(onToggle); // Using ref to enable access inside useEffect without re-binding event listeners
23
+ const openRef = react.useRef(open);
24
+ onToggleRef.current = onToggle;
25
+ openRef.current = open;
26
+ // Provide onToggle event and controlled state
26
27
  react.useEffect(() => {
27
28
  const details = detailsRef.current;
28
- const summary = details?.querySelector(':scope > :is(summary,u-summary)');
29
- const handleSummaryClick = (event) => {
30
- event?.preventDefault(); // Prevent native <details> toggle so we can animate
31
- setInternalOpen((open) => !open);
32
- };
33
- const handleToggle = () => {
34
- if (!details || details.open === controlledOpen.current)
29
+ const handleToggle = (event) => {
30
+ if (!details || details?.open === openRef.current)
35
31
  return;
36
- onFound?.();
37
- setInternalOpen(details?.open || false);
38
- window.requestAnimationFrame(() => {
39
- details.open = controlledOpen.current;
40
- }); // Let onFound run before correcting state
32
+ onToggleRef.current?.(event);
33
+ if (openRef.current !== undefined)
34
+ details.open = openRef.current; // Don't update DOM unless controlled state changes
41
35
  };
42
36
  details?.addEventListener('toggle', handleToggle, true);
43
- summary?.addEventListener('click', handleSummaryClick);
44
- return () => {
45
- details?.removeEventListener('toggle', handleToggle, true);
46
- summary?.removeEventListener('click', handleSummaryClick);
47
- };
37
+ return () => details?.removeEventListener('toggle', handleToggle, true);
48
38
  }, []);
49
- react.useEffect(() => {
50
- animateHeight(detailsRef.current, controlledOpen.current);
51
- }, [controlledOpen.current]);
52
- return (jsxRuntime.jsx("u-details", { class: cl('ds-accordion__item', className), open: initialOpen.current || undefined, ref: mergedRefs, ...rest }));
39
+ return (jsxRuntime.jsx("u-details", { class: cl('ds-accordion__item', className), open: (open ?? initialOpen.current) || undefined, ref: mergedRefs, ...rest }));
53
40
  });
54
- const animateHeight = (details, open) => {
55
- const content = details?.querySelector(':scope > :not(summary, u-summary)');
56
- const hasContent = content instanceof HTMLElement;
57
- const hasAnimate = details && 'animate' in details;
58
- const hasReducedMotion = window.matchMedia?.('(prefers-reduced-motion: reduce)').matches;
59
- details?.setAttribute('data-chevron-open', `${open}`); // Make flip on click
60
- if (hasReducedMotion || !hasAnimate || !hasContent) {
61
- if (details)
62
- details.open = open;
63
- }
64
- else if (details.open !== open) {
65
- details.open = true;
66
- const opened = `${content.scrollHeight}px`;
67
- content.style.overflow = 'clip'; // Clip content while animating
68
- content.animate({
69
- height: [open ? '0px' : opened, open ? opened : '0px'],
70
- paddingBlock: [open ? '0px' : '', open ? '' : '0px'],
71
- }, { duration: 400, easing: 'ease-in-out' }).onfinish = () => {
72
- content.style.removeProperty('overflow'); // Restore overlow
73
- details.open = open;
74
- };
75
- }
76
- };
77
41
 
78
42
  exports.AccordionItem = AccordionItem;
@@ -4,15 +4,14 @@
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
5
  var cl = require('clsx/lite');
6
6
  var react = require('react');
7
- var Paragraph = require('../Typography/Paragraph/Paragraph.js');
8
7
 
9
8
  /**
10
9
  * Alerts are used to inform users about important information, warnings, errors, or success.
11
10
  * @example
12
11
  * <Alert color='info'>Dette er en informasjonsmelding</Alert>
13
12
  */
14
- const Alert = react.forwardRef(function Alert({ color = 'info', size = 'md', className, ...rest }, ref) {
15
- return (jsxRuntime.jsx(Paragraph.Paragraph, { asChild: true, size: size, children: jsxRuntime.jsx("div", { className: cl('ds-alert', className), "data-color": color, "data-size": size, ref: ref, ...rest }) }));
13
+ const Alert = react.forwardRef(function Alert({ 'data-color': color = 'info', className, ...rest }, ref) {
14
+ return (jsxRuntime.jsx("div", { className: cl('ds-alert', className), "data-color": color, ref: ref, ...rest }));
16
15
  });
17
16
 
18
17
  exports.Alert = Alert;
@@ -6,17 +6,11 @@ var reactSlot = require('@radix-ui/react-slot');
6
6
  var cl = require('clsx/lite');
7
7
  var react = require('react');
8
8
 
9
- const fontSizeMap = {
10
- xs: 'ds-paragraph--xs',
11
- sm: 'ds-heading--2xs',
12
- md: 'ds-heading--sm',
13
- lg: 'ds-heading--md',
14
- };
15
9
  /**
16
10
  * Avatars are used to represent people or entities.
17
11
  *
18
12
  * @example
19
- * <Avatar aria-label="John Doe">JD</Avatar>
13
+ * <Avatar aria-label="John Doe" initials="JD" />
20
14
  *
21
15
  * @example
22
16
  * <Avatar aria-label="John Doe">
@@ -28,9 +22,10 @@ const fontSizeMap = {
28
22
  * <Icon />
29
23
  * </Avatar>
30
24
  */
31
- const Avatar = react.forwardRef(function Avatar({ 'aria-label': ariaLabel, color = 'accent', size = 'md', variant = 'circle', className, children, ...rest }, ref) {
32
- const Component = children && typeof children !== 'string' ? reactSlot.Slot : react.Fragment;
33
- return (jsxRuntime.jsx("span", { ref: ref, className: cl('ds-avatar', fontSizeMap[size], className), "data-variant": variant, "data-color": color, "data-size": size, role: 'img', "aria-label": ariaLabel, ...rest, children: jsxRuntime.jsx(Component, { ...(children ? { 'aria-hidden': true } : {}), children: children }) }));
25
+ const Avatar = react.forwardRef(function Avatar({ 'aria-label': ariaLabel, variant = 'circle', className, children, initials, ...rest }, ref) {
26
+ const useSlot = children && typeof children !== 'string';
27
+ const Component = useSlot ? reactSlot.Slot : react.Fragment;
28
+ return (jsxRuntime.jsx("span", { ref: ref, className: cl('ds-avatar', className), "data-variant": variant, "data-initials": initials, role: 'img', "aria-label": ariaLabel, ...rest, children: jsxRuntime.jsx(Component, { ...(useSlot ? { 'aria-hidden': true } : {}), children: children }) }));
34
29
  });
35
30
 
36
31
  exports.Avatar = Avatar;
@@ -4,30 +4,24 @@
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
5
  var cl = require('clsx/lite');
6
6
  var react = require('react');
7
- var Paragraph = require('../Typography/Paragraph/Paragraph.js');
8
7
 
9
- const paragraphSizeMap = {
10
- sm: 'xs',
11
- md: 'sm',
12
- lg: 'md',
13
- };
14
8
  /**
15
9
  * `Badge` is a non-interactive component for displaying status with or without numbers.
16
10
  *
17
11
  * @example without children
18
12
  * ```jsx
19
- * <Badge color='accent' size='md' count={5} />
13
+ * <Badge color='accent' count={5} />
20
14
  * ```
21
15
  *
22
16
  * @example with children
23
17
  * ```jsx
24
- * <Badge color='accent' size='md'>
18
+ * <Badge color='accent'>
25
19
  * <Icon />
26
20
  * </Badge>
27
21
  * ```
28
22
  */
29
- const Badge = react.forwardRef(function Badge({ className, color = 'accent', count, maxCount, overlap = 'rectangle', placement = 'top-right', size = 'md', ...rest }, ref) {
30
- return (jsxRuntime.jsx(Paragraph.Paragraph, { asChild: true, variant: 'short', size: paragraphSizeMap[size], children: jsxRuntime.jsx("span", { className: cl('ds-badge', className), "data-color": color, "data-count": count && maxCount && count > maxCount ? `${maxCount}+` : count, "data-overlap": rest.children ? overlap : null, "data-placement": rest.children ? placement : null, "data-size": size, ref: ref, ...rest }) }));
23
+ const Badge = react.forwardRef(function Badge({ className, count, maxCount, overlap = 'rectangle', placement = 'top-right', ...rest }, ref) {
24
+ return (jsxRuntime.jsx("span", { className: cl('ds-badge', className), "data-count": count && maxCount && count > maxCount ? `${maxCount}+` : count, "data-overlap": rest.children ? overlap : null, "data-placement": rest.children ? placement : null, ref: ref, ...rest }));
31
25
  });
32
26
 
33
27
  exports.Badge = Badge;
@@ -4,8 +4,7 @@
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
5
  var cl = require('clsx/lite');
6
6
  var react = require('react');
7
- var Paragraph = require('../Typography/Paragraph/Paragraph.js');
8
7
 
9
- const Breadcrumbs = react.forwardRef(({ 'aria-label': ariaLabel = 'Du er her:', className, size, ...rest }, ref) => (jsxRuntime.jsx(Paragraph.Paragraph, { asChild: true, size: size, children: jsxRuntime.jsx("nav", { "aria-label": ariaLabel, className: cl('ds-breadcrumbs', className), "data-size": size, ref: ref, ...rest }) })));
8
+ const Breadcrumbs = react.forwardRef(({ 'aria-label': ariaLabel = 'Du er her:', className, ...rest }, ref) => (jsxRuntime.jsx("nav", { "aria-label": ariaLabel, className: cl('ds-breadcrumbs', className), ref: ref, ...rest })));
10
9
 
11
10
  exports.Breadcrumbs = Breadcrumbs;
@@ -5,7 +5,6 @@ var jsxRuntime = require('react/jsx-runtime');
5
5
  var reactSlot = require('@radix-ui/react-slot');
6
6
  var cl = require('clsx/lite');
7
7
  var react = require('react');
8
- var Paragraph = require('../Typography/Paragraph/Paragraph.js');
9
8
  var Spinner = require('../loaders/Spinner/Spinner.js');
10
9
 
11
10
  /**
@@ -13,12 +12,13 @@ var Spinner = require('../loaders/Spinner/Spinner.js');
13
12
  * @example
14
13
  * <Button>Click me</Button>
15
14
  */
16
- const Button = react.forwardRef(function Button({ asChild, className, children, color = 'accent', icon = false, loading = false, size = 'md', variant = 'primary', ...rest }, ref) {
15
+ const Button = react.forwardRef(function Button({ asChild, className, children, icon = false, loading = false, variant = 'primary', ...rest }, ref) {
17
16
  const Component = asChild ? reactSlot.Slot : 'button';
18
- const spinnerColor = color === 'accent' ? color : 'neutral';
19
17
  // Fallbacks to undefined to prevent rendering attribute="false"
20
- return (jsxRuntime.jsx(Paragraph.Paragraph, { variant: 'short', size: size, asChild: true, children: jsxRuntime.jsxs(Component, { "aria-busy": Boolean(loading) || undefined, className: cl('ds-button', className), "data-color": color, "data-icon": icon || undefined, "data-size": size, "data-variant": variant, ref: ref, ...(asChild ? { asChild: true } : { type: 'button' }), ...rest, children: [loading === true ? (jsxRuntime.jsx(Spinner.Spinner, { "aria-hidden": 'true', color: spinnerColor, size: 'sm', title: '' })) : (loading // Allow custom loading spinner
21
- ), jsxRuntime.jsx(reactSlot.Slottable, { children: children })] }) }));
18
+ return (jsxRuntime.jsxs(Component, { "aria-busy": Boolean(loading) || undefined, className: cl('ds-button', className), "data-icon": icon || undefined, "data-variant": variant, ref: ref,
19
+ /* don't set type when we use `asChild` */
20
+ type: asChild ? undefined : 'button', ...rest, children: [loading === true ? (jsxRuntime.jsx(Spinner.Spinner, { "aria-hidden": 'true', "data-size": 'sm' })) : (loading // Allow custom loading spinner
21
+ ), jsxRuntime.jsx(reactSlot.Slottable, { children: children })] }));
22
22
  });
23
23
 
24
24
  exports.Button = Button;
@@ -2,6 +2,7 @@
2
2
  'use strict';
3
3
 
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
+ var react$1 = require('@floating-ui/react');
5
6
  var reactSlot = require('@radix-ui/react-slot');
6
7
  var cl = require('clsx/lite');
7
8
  var react = require('react');
@@ -10,15 +11,32 @@ var react = require('react');
10
11
  * Card component to present content in a structured way.
11
12
  * @example
12
13
  * <Card>
13
- * <Card.Header>Header</Card.Header>
14
- * <Card.Content>Content</Card.Content>
15
- * <Card.Footer>Footer</Card.Footer>
14
+ * <Card.Block>Header</Card.Block>
15
+ * <Card.Block>Content</Card.Block>
16
+ * <Card.Block>Footer</Card.Block>
16
17
  * </Card>
17
18
  */
18
- const Card = react.forwardRef(({ isLink = false, asChild = false, color = 'neutral', className, ...rest }, ref) => {
19
+ const Card = react.forwardRef(function Card({ asChild = false, 'data-color': color = 'neutral', className, ...rest }, ref) {
19
20
  const Component = asChild ? reactSlot.Slot : 'div';
20
- return (jsxRuntime.jsx(Component, { ref: ref, className: cl(`ds-card`, isLink && `ds-focus`, className), "data-color": color, "data-link": isLink ? '' : undefined, ...rest }));
21
+ const cardRef = react.useRef(null);
22
+ const mergedRefs = react$1.useMergeRefs([cardRef, ref]);
23
+ // Forward click on card to heading links for better accessibility
24
+ // https://adrianroselli.com/2020/02/block-links-cards-clickable-regions-etc.html
25
+ react.useEffect(() => {
26
+ const card = cardRef.current;
27
+ const handleClick = ({ ctrlKey, metaKey, target }) => {
28
+ const link = card?.querySelector(':is(h1,h2,h3,h4,h5,h6) a');
29
+ if (!link || link?.contains(target))
30
+ return; // Let links handle their own clicks
31
+ if (ctrlKey || metaKey)
32
+ window.open(link.href, '', 'noreferrer');
33
+ else
34
+ link.click(); // Using link.click instead of window.location.href as this will trigger the browser's handling of rel=, target=, etc.
35
+ };
36
+ card?.addEventListener('click', handleClick);
37
+ return () => card?.removeEventListener('click', handleClick);
38
+ }, []);
39
+ return (jsxRuntime.jsx(Component, { className: cl(`ds-card`, className), "data-color": color, ref: mergedRefs, ...rest }));
21
40
  });
22
- Card.displayName = 'Card';
23
41
 
24
42
  exports.Card = Card;
@@ -6,10 +6,9 @@ var reactSlot = require('@radix-ui/react-slot');
6
6
  var cl = require('clsx/lite');
7
7
  var react = require('react');
8
8
 
9
- const CardMedia = react.forwardRef(({ asChild, className, ...rest }, ref) => {
9
+ const CardBlock = react.forwardRef(function CardBlock({ asChild, className, ...rest }, ref) {
10
10
  const Component = asChild ? reactSlot.Slot : 'div';
11
- return (jsxRuntime.jsx(Component, { className: cl(`ds-card__media`, className), ref: ref, ...rest }));
11
+ return (jsxRuntime.jsx(Component, { className: cl(`ds-card__block`, className), ref: ref, ...rest }));
12
12
  });
13
- CardMedia.displayName = 'CardMedia';
14
13
 
15
- exports.CardMedia = CardMedia;
14
+ exports.CardBlock = CardBlock;
@@ -2,23 +2,12 @@
2
2
  'use strict';
3
3
 
4
4
  var Card$1 = require('./Card.js');
5
- var CardContent = require('./CardContent.js');
6
- var CardFooter = require('./CardFooter.js');
7
- var CardHeader = require('./CardHeader.js');
8
- var CardMedia = require('./CardMedia.js');
5
+ var CardBlock = require('./CardBlock.js');
9
6
 
10
- const Card = Card$1.Card;
11
- Card.Header = CardHeader.CardHeader;
12
- Card.Content = CardContent.CardContent;
13
- Card.Footer = CardFooter.CardFooter;
14
- Card.Media = CardMedia.CardMedia;
15
- Card.Header.displayName = 'Card.Header';
16
- Card.Content.displayName = 'Card.Content';
17
- Card.Footer.displayName = 'Card.Footer';
18
- Card.Media.displayName = 'Card.Media';
7
+ const Card = Object.assign(Card$1.Card, {
8
+ Block: CardBlock.CardBlock,
9
+ });
10
+ Card.Block.displayName = 'Card.Block';
19
11
 
20
- exports.CardContent = CardContent.CardContent;
21
- exports.CardFooter = CardFooter.CardFooter;
22
- exports.CardHeader = CardHeader.CardHeader;
23
- exports.CardMedia = CardMedia.CardMedia;
12
+ exports.CardBlock = CardBlock.CardBlock;
24
13
  exports.Card = Card;
@@ -0,0 +1,51 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var reactSlot = require('@radix-ui/react-slot');
6
+ var cl = require('clsx/lite');
7
+ var react = require('react');
8
+ var Input = require('../form/Input/Input.js');
9
+
10
+ /**
11
+ * Chip.Button used for interaction
12
+ * @example
13
+ * <Chip.Button>Click me</Chip.Button>
14
+ */
15
+ const ChipButton = react.forwardRef(function ChipButton({ asChild, className, ...rest }, ref) {
16
+ const Component = asChild ? reactSlot.Slot : 'button';
17
+ return (jsxRuntime.jsx(Component, { className: cl('ds-chip', className), type: asChild ? undefined : 'button', ref: ref, ...rest }));
18
+ });
19
+ /**
20
+ * Chip.Removable used for interaction
21
+ * @example
22
+ * <Chip.Removable>Click to remove me</Chip.Removable>
23
+ */
24
+ const ChipRemovable = react.forwardRef(function ChipRemovable(props, ref) {
25
+ return jsxRuntime.jsx(ChipButton, { "data-removable": true, ref: ref, ...props });
26
+ });
27
+ /**
28
+ * Chip.Checkbox used for multiselection
29
+ * @example
30
+ * <Chip.Checkbox name="language" value="nynorsk">Nynorsk</Chip.Checkbox>
31
+ * <Chip.Checkbox name="language" value="bokmål">Bokmål</Chip.Checkbox>
32
+ */
33
+ const ChipCheckbox = react.forwardRef(function ChipCheckbox({ asChild, children, className, 'data-size': size, 'data-color': color, ...rest }, ref) {
34
+ const inputType = rest.type ?? 'checkbox';
35
+ const Component = asChild ? reactSlot.Slot : 'label';
36
+ return (jsxRuntime.jsxs(Component, { className: cl('ds-chip', className), "data-size": size, "data-color": color, ref: ref, children: [jsxRuntime.jsx(Input.Input, { ...rest, type: inputType }), jsxRuntime.jsx(reactSlot.Slottable, { children: children })] }));
37
+ });
38
+ /**
39
+ * Chip.Radio used for single selection
40
+ * @example
41
+ * <Chip.Radio name="language" value="nynorsk">Nynorsk</Chip.Radio>
42
+ * <Chip.Radio name="language" value="bokmål">Bokmål</Chip.Radio>
43
+ */
44
+ const ChipRadio = react.forwardRef(function ChipRadio(props, ref) {
45
+ return jsxRuntime.jsx(ChipCheckbox, { ref, type: 'radio', ...props });
46
+ });
47
+
48
+ exports.ChipButton = ChipButton;
49
+ exports.ChipCheckbox = ChipCheckbox;
50
+ exports.ChipRadio = ChipRadio;
51
+ exports.ChipRemovable = ChipRemovable;
@@ -1,20 +1,21 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var Group = require('./Group/Group.js');
5
- var Removable = require('./Removable/Removable.js');
6
- var Toggle = require('./Toggle/Toggle.js');
4
+ var Chips = require('./Chips.js');
7
5
 
8
6
  const Chip = {
9
- Group: Group.Group,
10
- Removable: Removable.RemovableChip,
11
- Toggle: Toggle.ToggleChip,
7
+ Button: Chips.ChipButton,
8
+ Checkbox: Chips.ChipCheckbox,
9
+ Radio: Chips.ChipRadio,
10
+ Removable: Chips.ChipRemovable,
12
11
  };
13
- Chip.Group.displayName = 'Chip.Group';
12
+ Chip.Button.displayName = 'Chip.Button';
13
+ Chip.Checkbox.displayName = 'Chip.Checkbox';
14
+ Chip.Radio.displayName = 'Chip.Radio';
14
15
  Chip.Removable.displayName = 'Chip.Removable';
15
- Chip.Toggle.displayName = 'Chip.Toggle';
16
16
 
17
- exports.ChipGroup = Group.Group;
18
- exports.ChipRemovable = Removable.RemovableChip;
19
- exports.ChipToggle = Toggle.ToggleChip;
17
+ exports.ChipButton = Chips.ChipButton;
18
+ exports.ChipCheckbox = Chips.ChipCheckbox;
19
+ exports.ChipRadio = Chips.ChipRadio;
20
+ exports.ChipRemovable = Chips.ChipRemovable;
20
21
  exports.Chip = Chip;
@@ -6,18 +6,8 @@ var cl = require('clsx/lite');
6
6
  var react = require('react');
7
7
  var index = require('../Popover/index.js');
8
8
 
9
- const Dropdown = react.forwardRef(function DropddownMenuContent({ placement = 'bottom-end', className, ...rest }, ref) {
10
- const [size, setSize] = react.useState(rest.size || 'md');
11
- react.useEffect(() => {
12
- setSize(rest.size || 'md');
13
- }, [rest.size]);
14
- return (jsxRuntime.jsx(DropdownCtx.Provider, { value: {
15
- size,
16
- }, children: jsxRuntime.jsx(index.Popover, { ref: ref, placement: placement, size: size, className: cl('ds-dropdown', className), ...rest }) }));
17
- });
18
- const DropdownCtx = react.createContext({
19
- size: 'md',
9
+ const Dropdown = react.forwardRef(function DropdownContent({ placement = 'bottom-end', className, ...rest }, ref) {
10
+ return (jsxRuntime.jsx(index.Popover, { className: cl('ds-dropdown', className), placement: placement, ref: ref, ...rest }));
20
11
  });
21
12
 
22
13
  exports.Dropdown = Dropdown;
23
- exports.DropdownCtx = DropdownCtx;
@@ -0,0 +1,12 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ var react = require('react');
6
+ var Button = require('../Button/Button.js');
7
+
8
+ const DropdownButton = react.forwardRef(function DropdownButton({ className, ...rest }, ref) {
9
+ return jsxRuntime.jsx(Button.Button, { ref: ref, variant: 'tertiary', ...rest });
10
+ });
11
+
12
+ exports.DropdownButton = DropdownButton;
@@ -2,14 +2,11 @@
2
2
  'use strict';
3
3
 
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
- var cl = require('clsx/lite');
6
5
  var react = require('react');
7
- var Dropdown = require('./Dropdown.js');
8
- var Paragraph = require('../Typography/Paragraph/Paragraph.js');
6
+ var Heading = require('../Heading/Heading.js');
9
7
 
10
- const DropdownHeading = react.forwardRef(function DropdownHeading({ children, className, ...rest }, ref) {
11
- const { size } = react.useContext(Dropdown.DropdownCtx);
12
- return (jsxRuntime.jsx(Paragraph.Paragraph, { asChild: true, size: size, children: jsxRuntime.jsx("h2", { ref: ref, className: cl('ds-dropdown__heading', className), ...rest, children: children }) }));
8
+ const DropdownHeading = react.forwardRef(function DropdownHeading({ className, ...rest }, ref) {
9
+ return jsxRuntime.jsx(Heading.Heading, { ref: ref, ...rest });
13
10
  });
14
11
 
15
12
  exports.DropdownHeading = DropdownHeading;
@@ -3,12 +3,9 @@
3
3
 
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
5
  var react = require('react');
6
- var Button = require('../Button/Button.js');
7
- var Dropdown = require('./Dropdown.js');
8
6
 
9
- const DropdownItem = react.forwardRef(function DropdownItem({ className, style, ...rest }, ref) {
10
- const { size } = react.useContext(Dropdown.DropdownCtx);
11
- return (jsxRuntime.jsx("li", { className: className, style: style, children: jsxRuntime.jsx(Button.Button, { ref: ref, variant: 'tertiary', size: size, className: 'ds-dropdown__item', ...rest }) }));
7
+ const DropdownItem = react.forwardRef(function DropdownItem({ className, ...rest }, ref) {
8
+ return jsxRuntime.jsx("li", { ref: ref, ...rest });
12
9
  });
13
10
 
14
11
  exports.DropdownItem = DropdownItem;
@@ -2,11 +2,10 @@
2
2
  'use strict';
3
3
 
4
4
  var jsxRuntime = require('react/jsx-runtime');
5
- var cl = require('clsx/lite');
6
5
  var react = require('react');
7
6
 
8
7
  const DropdownList = react.forwardRef(function DropdownList({ className, ...rest }, ref) {
9
- return (jsxRuntime.jsx("ul", { ref: ref, className: cl('ds-dropdown__list', className), ...rest }));
8
+ return jsxRuntime.jsx("ul", { ref: ref, ...rest });
10
9
  });
11
10
 
12
11
  exports.DropdownList = DropdownList;
@@ -0,0 +1,26 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ var jsxRuntime = require('react/jsx-runtime');
5
+ require('../Popover/index.js');
6
+ var PopoverTriggerContext = require('../Popover/PopoverTriggerContext.js');
7
+
8
+ /**
9
+ * DropdownTriggerContext enables use of the `.Trigger` for the Dropdown component.
10
+ * @example
11
+ * <Dropdown.TriggerContext>
12
+ * <Dropdown.Trigger>Dropdown</Dropdown.Trigger>
13
+ * <Dropdown>
14
+ * <Dropdown.Heading>Heading</Dropdown.Heading>
15
+ * <Dropdown.List>
16
+ * <Dropdown.Item>Button 1</Dropdown.Item>
17
+ * </Dropdown.List>
18
+ * </Dropdown>
19
+ * </Dropdown.TriggerContext>
20
+ */
21
+ const DropdownTriggerContext = ({ children, }) => {
22
+ return jsxRuntime.jsx(PopoverTriggerContext.PopoverTriggerContext, { children: children });
23
+ };
24
+ DropdownTriggerContext.displayName = 'DropdownTriggerContext';
25
+
26
+ exports.DropdownTriggerContext = DropdownTriggerContext;
@@ -2,40 +2,46 @@
2
2
  'use strict';
3
3
 
4
4
  var Dropdown$1 = require('./Dropdown.js');
5
- var DropdownContext = require('./DropdownContext.js');
5
+ var DropdownButton = require('./DropdownButton.js');
6
6
  var DropdownHeading = require('./DropdownHeading.js');
7
7
  var DropdownItem = require('./DropdownItem.js');
8
8
  var DropdownList = require('./DropdownList.js');
9
9
  var DropdownTrigger = require('./DropdownTrigger.js');
10
+ var DropdownTriggerContext = require('./DropdownTriggerContext.js');
10
11
 
11
12
  /**
12
13
  * @example
13
- * <Dropdown.Context>
14
+ * <Dropdown.TriggerContext>
14
15
  * <Dropdown.Trigger>Dropdown</Dropdown.Trigger>
15
16
  * <Dropdown>
16
17
  * <Dropdown.Heading>Heading</Dropdown.Heading>
17
18
  * <Dropdown.List>
18
- * <Dropdown.Item>Button 1</Dropdown.Item>
19
+ * <Dropdown.Item>
20
+ * <Dropdown.Button>Button 1</Dropdown.Button>
21
+ * </Dropdown.Item>
19
22
  * </Dropdown.List>
20
23
  * </Dropdown>
21
- * </Dropdown.Context>
24
+ * </Dropdown.TriggerContext>
22
25
  */
23
26
  const Dropdown = Object.assign(Dropdown$1.Dropdown, {
24
- Context: DropdownContext.DropdownContext,
27
+ TriggerContext: DropdownTriggerContext.DropdownTriggerContext,
25
28
  Heading: DropdownHeading.DropdownHeading,
26
29
  List: DropdownList.DropdownList,
27
30
  Item: DropdownItem.DropdownItem,
31
+ Button: DropdownButton.DropdownButton,
28
32
  Trigger: DropdownTrigger.DropdownTrigger,
29
33
  });
30
- Dropdown.Context.displayName = 'Dropdown.Context';
34
+ Dropdown.TriggerContext.displayName = 'Dropdown.TriggerContext';
31
35
  Dropdown.List.displayName = 'Dropdown.List';
32
36
  Dropdown.Heading.displayName = 'Dropdown.Heading';
33
37
  Dropdown.Item.displayName = 'Dropdown.Item';
38
+ Dropdown.Button.displayName = 'Dropdown.Button';
34
39
  Dropdown.Trigger.displayName = 'Dropdown.Trigger';
35
40
 
36
- exports.DropdownContext = DropdownContext.DropdownContext;
41
+ exports.DropdownButton = DropdownButton.DropdownButton;
37
42
  exports.DropdownHeading = DropdownHeading.DropdownHeading;
38
43
  exports.DropdownItem = DropdownItem.DropdownItem;
39
44
  exports.DropdownList = DropdownList.DropdownList;
40
45
  exports.DropdownTrigger = DropdownTrigger.DropdownTrigger;
46
+ exports.DropdownTriggerContext = DropdownTriggerContext.DropdownTriggerContext;
41
47
  exports.Dropdown = Dropdown;