@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
@@ -0,0 +1,24 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import '../Popover/index.js';
4
+ import { PopoverTriggerContext } from '../Popover/PopoverTriggerContext.js';
5
+
6
+ /**
7
+ * DropdownTriggerContext enables use of the `.Trigger` for the Dropdown component.
8
+ * @example
9
+ * <Dropdown.TriggerContext>
10
+ * <Dropdown.Trigger>Dropdown</Dropdown.Trigger>
11
+ * <Dropdown>
12
+ * <Dropdown.Heading>Heading</Dropdown.Heading>
13
+ * <Dropdown.List>
14
+ * <Dropdown.Item>Button 1</Dropdown.Item>
15
+ * </Dropdown.List>
16
+ * </Dropdown>
17
+ * </Dropdown.TriggerContext>
18
+ */
19
+ const DropdownTriggerContext = ({ children, }) => {
20
+ return jsx(PopoverTriggerContext, { children: children });
21
+ };
22
+ DropdownTriggerContext.displayName = 'DropdownTriggerContext';
23
+
24
+ export { DropdownTriggerContext };
@@ -1,34 +1,39 @@
1
1
  'use client';
2
2
  import { Dropdown as Dropdown$1 } from './Dropdown.js';
3
- import { DropdownContext } from './DropdownContext.js';
3
+ import { DropdownButton } from './DropdownButton.js';
4
4
  import { DropdownHeading } from './DropdownHeading.js';
5
5
  import { DropdownItem } from './DropdownItem.js';
6
6
  import { DropdownList } from './DropdownList.js';
7
7
  import { DropdownTrigger } from './DropdownTrigger.js';
8
+ import { DropdownTriggerContext } from './DropdownTriggerContext.js';
8
9
 
9
10
  /**
10
11
  * @example
11
- * <Dropdown.Context>
12
+ * <Dropdown.TriggerContext>
12
13
  * <Dropdown.Trigger>Dropdown</Dropdown.Trigger>
13
14
  * <Dropdown>
14
15
  * <Dropdown.Heading>Heading</Dropdown.Heading>
15
16
  * <Dropdown.List>
16
- * <Dropdown.Item>Button 1</Dropdown.Item>
17
+ * <Dropdown.Item>
18
+ * <Dropdown.Button>Button 1</Dropdown.Button>
19
+ * </Dropdown.Item>
17
20
  * </Dropdown.List>
18
21
  * </Dropdown>
19
- * </Dropdown.Context>
22
+ * </Dropdown.TriggerContext>
20
23
  */
21
24
  const Dropdown = Object.assign(Dropdown$1, {
22
- Context: DropdownContext,
25
+ TriggerContext: DropdownTriggerContext,
23
26
  Heading: DropdownHeading,
24
27
  List: DropdownList,
25
28
  Item: DropdownItem,
29
+ Button: DropdownButton,
26
30
  Trigger: DropdownTrigger,
27
31
  });
28
- Dropdown.Context.displayName = 'Dropdown.Context';
32
+ Dropdown.TriggerContext.displayName = 'Dropdown.TriggerContext';
29
33
  Dropdown.List.displayName = 'Dropdown.List';
30
34
  Dropdown.Heading.displayName = 'Dropdown.Heading';
31
35
  Dropdown.Item.displayName = 'Dropdown.Item';
36
+ Dropdown.Button.displayName = 'Dropdown.Button';
32
37
  Dropdown.Trigger.displayName = 'Dropdown.Trigger';
33
38
 
34
- export { Dropdown, DropdownContext, DropdownHeading, DropdownItem, DropdownList, DropdownTrigger };
39
+ export { Dropdown, DropdownButton, DropdownHeading, DropdownItem, DropdownList, DropdownTrigger, DropdownTriggerContext };
@@ -4,14 +4,13 @@ import cl from 'clsx/lite';
4
4
  import { createContext, forwardRef, useId, useState } from 'react';
5
5
 
6
6
  const ErrorSummaryContext = createContext({
7
- size: 'md',
8
7
  headingId: 'heading',
9
8
  setHeadingId: () => { },
10
9
  });
11
- const ErrorSummary = forwardRef(function ErrorSummary({ className, size = 'md', role = 'alert', 'aria-live': ariaLive = 'polite', 'aria-relevant': ariaRelevant = 'all', ...rest }, ref) {
10
+ const ErrorSummary = forwardRef(function ErrorSummary({ className, role = 'alert', 'aria-live': ariaLive = 'polite', 'aria-relevant': ariaRelevant = 'all', ...rest }, ref) {
12
11
  const randomId = useId();
13
12
  const [headingId, setHeadingId] = useState(randomId);
14
- return (jsx(ErrorSummaryContext.Provider, { value: { size, headingId, setHeadingId }, children: jsx("div", { "aria-labelledby": headingId, "aria-live": ariaLive, "aria-relevant": ariaRelevant, className: cl('ds-error-summary', className), ref: ref, role: role, ...rest }) }));
13
+ return (jsx(ErrorSummaryContext.Provider, { value: { headingId, setHeadingId }, children: jsx("div", { "aria-labelledby": headingId, "aria-live": ariaLive, "aria-relevant": ariaRelevant, className: cl('ds-error-summary', className), ref: ref, role: role, ...rest }) }));
15
14
  });
16
15
 
17
16
  export { ErrorSummary, ErrorSummaryContext };
@@ -2,20 +2,15 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { forwardRef, useContext, useEffect } from 'react';
4
4
  import { ErrorSummaryContext } from './ErrorSummary.js';
5
- import { Heading } from '../Typography/Heading/Heading.js';
5
+ import { Heading } from '../Heading/Heading.js';
6
6
 
7
- const HEADING_SIZE_MAP = {
8
- sm: '2xs',
9
- md: 'xs',
10
- lg: 'sm',
11
- };
12
7
  const ErrorSummaryHeading = forwardRef(function ErrorSummaryHeading({ className, id, ...rest }, ref) {
13
- const { size, headingId, setHeadingId } = useContext(ErrorSummaryContext);
8
+ const { headingId, setHeadingId } = useContext(ErrorSummaryContext);
14
9
  useEffect(() => {
15
10
  if (id && headingId !== id)
16
11
  setHeadingId(id);
17
12
  }, [headingId, id, setHeadingId]);
18
- return (jsx(Heading, { id: headingId, size: HEADING_SIZE_MAP[size ?? 'md'], spacing: true, ref: ref, ...rest }));
13
+ return jsx(Heading, { id: headingId, ref: ref, ...rest });
19
14
  });
20
15
 
21
16
  export { ErrorSummaryHeading };
@@ -1,12 +1,10 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
- import { forwardRef, useContext } from 'react';
3
+ import { forwardRef } from 'react';
4
4
  import { List } from '../List/index.js';
5
- import { ErrorSummaryContext } from './ErrorSummary.js';
6
5
 
7
6
  const ErrorSummaryList = forwardRef(function ErrorSummaryList({ ...rest }, ref) {
8
- const { size } = useContext(ErrorSummaryContext);
9
- return jsx(List.Unordered, { size: size, ...rest, ref: ref });
7
+ return jsx(List.Unordered, { ...rest, ref: ref });
10
8
  });
11
9
 
12
10
  export { ErrorSummaryList };
@@ -0,0 +1,18 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { Slot } from '@radix-ui/react-slot';
4
+ import cl from 'clsx/lite';
5
+ import { forwardRef } from 'react';
6
+
7
+ /**
8
+ * Use `Heading` to render h1-6 elements with heading text styles.
9
+ *
10
+ * @example
11
+ * <Heading data-size='lg' level={2}>Heading</Heading>
12
+ */
13
+ const Heading = forwardRef(function Heading({ level = 2, className, asChild, ...rest }, ref) {
14
+ const Component = asChild ? Slot : `h${level}`;
15
+ return (jsx(Component, { className: cl(`ds-heading`, className), ref: ref, ...rest }));
16
+ });
17
+
18
+ export { Heading };
@@ -4,8 +4,8 @@ import cl from 'clsx/lite';
4
4
  import { forwardRef } from 'react';
5
5
  import { Popover } from '../Popover/index.js';
6
6
 
7
- const HelpText = forwardRef(function HelpText({ placement = 'right', size = 'md', className, children, ...rest }, ref) {
8
- return (jsxs(Popover.Context, { children: [jsx(Popover.Trigger, { className: cl('ds-helptext', className), ref: ref, size: size, variant: 'tertiary', ...rest }), jsx(Popover, { placement: placement, size: size, variant: 'info', children: children })] }));
7
+ const HelpText = forwardRef(function HelpText({ placement = 'right', className, children, ...rest }, ref) {
8
+ return (jsxs(Popover.TriggerContext, { children: [jsx(Popover.Trigger, { className: cl('ds-helptext', className), ref: ref, variant: 'tertiary', ...rest }), jsx(Popover, { placement: placement, "data-color": 'info', children: children })] }));
9
9
  });
10
10
 
11
11
  export { HelpText };
@@ -8,12 +8,11 @@ import { forwardRef } from 'react';
8
8
  * Use `Label` for labels.
9
9
  *
10
10
  * @example
11
- * <Label size='lg'>Label</Label>
11
+ * <Label data-size='lg'>Label</Label>
12
12
  */
13
- const Label = forwardRef(({ className, spacing, size = 'md', weight = 'medium', asChild, ...rest }, ref) => {
13
+ const Label = forwardRef(function Label({ className, weight = 'medium', asChild, ...rest }, ref) {
14
14
  const Component = asChild ? Slot : 'label';
15
- return (jsx(Component, { ref: ref, className: cl('ds-label', `ds-label--${size}`, spacing && 'ds-label--spacing', weight && `ds-font-weight--${weight}`, className), ...rest }));
15
+ return (jsx(Component, { ref: ref, className: cl('ds-label', className), "data-weight": weight, ...rest }));
16
16
  });
17
- Label.displayName = 'Label';
18
17
 
19
18
  export { Label };
@@ -4,9 +4,9 @@ import { Slot } from '@radix-ui/react-slot';
4
4
  import cl from 'clsx/lite';
5
5
  import { forwardRef } from 'react';
6
6
 
7
- const Link = forwardRef(({ asChild, className, color = 'accent', ...rest }, ref) => {
7
+ const Link = forwardRef(({ asChild, className, ...rest }, ref) => {
8
8
  const Component = asChild ? Slot : 'a';
9
- return (jsx(Component, { className: cl('ds-link', className), "data-color": color, ref: ref, ...rest }));
9
+ return (jsx(Component, { className: cl('ds-link', className), ref: ref, ...rest }));
10
10
  });
11
11
  Link.displayName = 'Link';
12
12
 
@@ -3,11 +3,10 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { Slot } from '@radix-ui/react-slot';
4
4
  import cl from 'clsx/lite';
5
5
  import { forwardRef } from 'react';
6
- import { Paragraph } from '../Typography/Paragraph/Paragraph.js';
7
6
 
8
- const render = (tagName, { asChild, className, size = 'md', ...rest }, ref) => {
7
+ const render = (tagName, { asChild, className, ...rest }, ref) => {
9
8
  const Component = asChild ? Slot : tagName;
10
- return (jsx(Paragraph, { size: size, asChild: true, children: jsx(Component, { className: cl(`ds-list`, className), "data-size": size, ref: ref, ...rest }) }));
9
+ return jsx(Component, { className: cl(`ds-list`, className), ref: ref, ...rest });
11
10
  };
12
11
  const ListUnordered = forwardRef(function ListUnordered(props, ref) {
13
12
  return render('ul', props, ref);
@@ -0,0 +1,49 @@
1
+ 'use client';
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
3
+ import { useMergeRefs } from '@floating-ui/react';
4
+ import { Slot } from '@radix-ui/react-slot';
5
+ import cl from 'clsx/lite';
6
+ import { forwardRef, useContext, useRef, useEffect } from 'react';
7
+ import { Context } from './ModalTriggerContext.js';
8
+ import { Button } from '../Button/Button.js';
9
+
10
+ const Modal = forwardRef(function Modal({ asChild, children, className, closeButton = 'Lukk dialogvindu', onClose, open, backdropClose = false, ...rest }, ref) {
11
+ const contextRef = useContext(Context);
12
+ const modalRef = useRef(null); // This local ref is used to make sure the modal works without a ModalTriggerContext
13
+ const Component = asChild ? Slot : 'dialog';
14
+ const mergedRefs = useMergeRefs([contextRef, ref, modalRef]);
15
+ useEffect(() => modalRef.current?.[open ? 'showModal' : 'close'](), [open]); // Toggle open based on prop
16
+ useEffect(() => {
17
+ const modal = modalRef.current;
18
+ const handleBackdropClick = ({ clientY: y, clientX: x, target, }) => {
19
+ if (window.getSelection()?.toString())
20
+ return; // Fix bug where if you select text spanning two divs it thinks you clicked outside
21
+ if (modal && target === modal && backdropClose) {
22
+ const { top, left, right, bottom } = modal.getBoundingClientRect();
23
+ const isInDialog = top <= y && y <= bottom && left <= x && x <= right;
24
+ if (!isInDialog)
25
+ modal?.close(); // Both <dialog> and ::backdrop is considered same event.target
26
+ }
27
+ };
28
+ const handleAutoFocus = () => {
29
+ const autofocus = modal?.querySelector('[autofocus]');
30
+ if (document.activeElement !== autofocus)
31
+ autofocus?.focus();
32
+ };
33
+ modal?.addEventListener('animationend', handleAutoFocus);
34
+ modal?.addEventListener('click', handleBackdropClick);
35
+ return () => {
36
+ modal?.removeEventListener('animationend', handleAutoFocus);
37
+ modal?.removeEventListener('click', handleBackdropClick);
38
+ };
39
+ }, [backdropClose]);
40
+ /* handle closing */
41
+ useEffect(() => {
42
+ const handleClose = (event) => onClose?.(event);
43
+ modalRef.current?.addEventListener('close', handleClose);
44
+ return () => modalRef.current?.removeEventListener('close', handleClose);
45
+ }, [onClose]);
46
+ return (jsxs(Component, { className: cl('ds-modal', className), ref: mergedRefs, ...rest, children: [closeButton !== false && (jsx("form", { method: 'dialog', children: jsx(Button, { "aria-label": closeButton, autoFocus: true, color: 'neutral', icon: true, name: 'close', type: 'submit', variant: 'tertiary' }) })), children] }));
47
+ });
48
+
49
+ export { Modal };
@@ -0,0 +1,12 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { Slot } from '@radix-ui/react-slot';
4
+ import cl from 'clsx/lite';
5
+ import { forwardRef } from 'react';
6
+
7
+ const ModalBlock = forwardRef(function ModalBlock({ asChild, className, ...rest }, ref) {
8
+ const Component = asChild ? Slot : 'div';
9
+ return (jsx(Component, { className: cl('ds-modal__block', className), ref: ref, ...rest }));
10
+ });
11
+
12
+ export { ModalBlock };
@@ -3,13 +3,12 @@ import { jsx } from 'react/jsx-runtime';
3
3
  import { Slot } from '@radix-ui/react-slot';
4
4
  import { forwardRef, useContext } from 'react';
5
5
  import { Button } from '../Button/Button.js';
6
- import { ModalContext } from './ModalRoot.js';
6
+ import { Context } from './ModalTriggerContext.js';
7
7
 
8
- const ModalTrigger = forwardRef(({ asChild, ...rest }, ref) => {
9
- const { modalRef, open } = useContext(ModalContext);
8
+ const ModalTrigger = forwardRef(function ModalTrigger({ asChild, ...rest }, ref) {
9
+ const contextRef = useContext(Context);
10
10
  const Component = asChild ? Slot : Button;
11
- return (jsx(Component, { ref: ref, onClick: () => modalRef?.current?.showModal(), "aria-expanded": open, "aria-haspopup": 'dialog', ...rest }));
11
+ return (jsx(Component, { "aria-haspopup": 'dialog', onClick: () => contextRef?.current?.showModal(), ref: ref, ...rest }));
12
12
  });
13
- ModalTrigger.displayName = 'ModalTrigger';
14
13
 
15
14
  export { ModalTrigger };
@@ -0,0 +1,14 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { createContext, useRef } from 'react';
4
+
5
+ const Context = createContext({
6
+ current: null,
7
+ });
8
+ const ModalTriggerContext = ({ children }) => {
9
+ const contextRef = useRef(null);
10
+ return jsx(Context.Provider, { value: contextRef, children: children });
11
+ };
12
+ ModalTriggerContext.displayName = 'ModalTriggerContext';
13
+
14
+ export { Context, ModalTriggerContext };
@@ -1,23 +1,16 @@
1
1
  'use client';
2
- import { ModalContent } from './ModaContent.js';
3
- import { ModalDialog } from './ModalDialog.js';
4
- import { ModalFooter } from './ModalFooter.js';
5
- import { ModalHeader } from './ModalHeader.js';
6
- import { ModalRoot } from './ModalRoot.js';
2
+ import { Modal as Modal$1 } from './Modal.js';
3
+ import { ModalBlock } from './ModalBlock.js';
7
4
  import { ModalTrigger } from './ModalTrigger.js';
5
+ import { ModalTriggerContext } from './ModalTriggerContext.js';
8
6
 
9
- const Modal = {};
10
- Modal.Root = ModalRoot;
11
- Modal.Content = ModalContent;
12
- Modal.Footer = ModalFooter;
13
- Modal.Header = ModalHeader;
14
- Modal.Trigger = ModalTrigger;
15
- Modal.Dialog = ModalDialog;
16
- Modal.Root.displayName = 'Modal.Root';
17
- Modal.Dialog.displayName = 'Modal.Dialog';
18
- Modal.Footer.displayName = 'Modal.Footer';
19
- Modal.Header.displayName = 'Modal.Header';
20
- Modal.Content.displayName = 'Modal.Content';
7
+ const Modal = Object.assign(Modal$1, {
8
+ Block: ModalBlock,
9
+ TriggerContext: ModalTriggerContext,
10
+ Trigger: ModalTrigger,
11
+ });
12
+ Modal.Block.displayName = 'Modal.Block';
13
+ Modal.TriggerContext.displayName = 'Modal.TriggerContext';
21
14
  Modal.Trigger.displayName = 'Modal.Trigger';
22
15
 
23
- export { Modal, ModalContent, ModalDialog, ModalFooter, ModalHeader, ModalRoot, ModalTrigger };
16
+ export { Modal, ModalBlock, ModalTrigger, ModalTriggerContext };
@@ -1,21 +1,12 @@
1
1
  'use client';
2
- import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { Slot } from '@radix-ui/react-slot';
4
+ import cl from 'clsx/lite';
3
5
  import { forwardRef } from 'react';
4
- import { PaginationButton } from './PaginationButton.js';
5
- import { PaginationEllipsis } from './PaginationEllipsis.js';
6
- import { PaginationItem } from './PaginationItem.js';
7
- import { PaginationList } from './PaginationList.js';
8
- import { PaginationPrevious, PaginationNext } from './PaginationNextPrev.js';
9
- import { PaginationRoot } from './PaginationRoot.js';
10
- import { usePagination } from './usePagination.js';
11
6
 
12
- const Pagination = forwardRef(function Pagination({ nextLabel = '', previousLabel = '', compact = false, hideLabels = false, currentPage = 1, totalPages, size = 'md', onChange, itemLabel = (num) => `Side ${num}`, ...rest }, ref) {
13
- const { pages, showNextPage, showPreviousPage } = usePagination({
14
- compact,
15
- currentPage,
16
- totalPages,
17
- });
18
- return (jsx(PaginationRoot, { "aria-label": 'Pagination', compact: compact, ref: ref, size: size, ...rest, children: jsxs(PaginationList, { children: [jsx(PaginationItem, { children: jsx(PaginationPrevious, { "aria-label": previousLabel, disabled: !showPreviousPage, onClick: () => onChange(currentPage - 1), children: !hideLabels && previousLabel }) }), pages.map((page, i) => (jsx(PaginationItem, { children: page === 'ellipsis' ? (jsx(PaginationEllipsis, {})) : (jsx(PaginationButton, { "aria-current": currentPage === page, "aria-label": itemLabel(page), isActive: currentPage === page, onClick: () => onChange(page), children: page })) }, `${page}${i}`))), jsx(PaginationItem, { children: jsx(PaginationNext, { "aria-label": nextLabel, disabled: !showNextPage, onClick: () => onChange(currentPage + 1), children: !hideLabels && nextLabel }) })] }) }));
7
+ const Pagination = forwardRef(function Pagination({ 'aria-label': ariaLabel = 'Sidenavigering', asChild, className, ...rest }, ref) {
8
+ const Component = asChild ? Slot : 'nav';
9
+ return (jsx(Component, { "aria-label": ariaLabel, className: cl('ds-pagination', className), ref: ref, ...rest }));
19
10
  });
20
11
 
21
12
  export { Pagination };
@@ -1,12 +1,10 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
- import { forwardRef, useContext } from 'react';
3
+ import { forwardRef } from 'react';
4
4
  import { Button } from '../Button/Button.js';
5
- import { PaginationContext } from './PaginationRoot.js';
6
5
 
7
- const PaginationButton = forwardRef(function PaginationButton({ isActive, ...rest }, ref) {
8
- const { size } = useContext(PaginationContext);
9
- return (jsx(Button, { "aria-current": isActive, ref: ref, size: size, variant: isActive ? 'primary' : 'tertiary', ...rest }));
6
+ const PaginationButton = forwardRef(function PaginationButton(rest, ref) {
7
+ return jsx(Button, { ref: ref, ...rest });
10
8
  });
11
9
 
12
10
  export { PaginationButton };
@@ -1,14 +1,11 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { Slot } from '@radix-ui/react-slot';
4
- import cl from 'clsx/lite';
5
- import { forwardRef, useContext } from 'react';
6
- import { PaginationContext } from './PaginationRoot.js';
4
+ import { forwardRef } from 'react';
7
5
 
8
6
  const PaginationItem = forwardRef(function PaginationItem({ asChild, className, ...rest }, ref) {
9
7
  const Component = asChild ? Slot : 'li';
10
- const { size, compact } = useContext(PaginationContext);
11
- return (jsx(Component, { ref: ref, className: cl('ds-pagination__item', `ds-pagination--${size}`, compact && 'ds-pagination--compact', className), ...rest }));
8
+ return jsx(Component, { ref: ref, ...rest });
12
9
  });
13
10
 
14
11
  export { PaginationItem };
@@ -1,14 +1,11 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { Slot } from '@radix-ui/react-slot';
4
- import cl from 'clsx/lite';
5
- import { forwardRef, useContext } from 'react';
6
- import { PaginationContext } from './PaginationRoot.js';
4
+ import { forwardRef } from 'react';
7
5
 
8
- const PaginationList = forwardRef(function PaginationList({ asChild, className, ...rest }, ref) {
9
- const { size } = useContext(PaginationContext);
6
+ const PaginationList = forwardRef(function PaginationList({ asChild, ...rest }, ref) {
10
7
  const Component = asChild ? Slot : 'ul';
11
- return (jsx(Component, { className: cl('ds-pagination', className), "data-size": size, ref: ref, ...rest }));
8
+ return jsx(Component, { ref: ref, ...rest });
12
9
  });
13
10
 
14
11
  export { PaginationList };
@@ -1,26 +1,16 @@
1
1
  'use client';
2
2
  import { Pagination as Pagination$1 } from './Pagination.js';
3
3
  import { PaginationButton } from './PaginationButton.js';
4
- import { PaginationEllipsis } from './PaginationEllipsis.js';
5
4
  import { PaginationItem } from './PaginationItem.js';
6
5
  import { PaginationList } from './PaginationList.js';
7
- import { PaginationPrevious, PaginationNext } from './PaginationNextPrev.js';
8
- import { PaginationRoot } from './PaginationRoot.js';
9
6
 
10
- const Pagination = Pagination$1;
11
- Pagination.Root = PaginationRoot;
12
- Pagination.List = PaginationList;
13
- Pagination.Item = PaginationItem;
14
- Pagination.Button = PaginationButton;
15
- Pagination.Ellipsis = PaginationEllipsis;
16
- Pagination.Previous = PaginationPrevious;
17
- Pagination.Next = PaginationNext;
18
- Pagination.Root.displayName = 'Pagination.Root';
7
+ const Pagination = Object.assign(Pagination$1, {
8
+ List: PaginationList,
9
+ Item: PaginationItem,
10
+ Button: PaginationButton,
11
+ });
19
12
  Pagination.List.displayName = 'Pagination.List';
20
13
  Pagination.Item.displayName = 'Pagination.Item';
21
14
  Pagination.Button.displayName = 'Pagination.Button';
22
- Pagination.Ellipsis.displayName = 'Pagination.Ellipsis';
23
- Pagination.Previous.displayName = 'Pagination.Previous';
24
- Pagination.Next.displayName = 'Pagination.Next';
25
15
 
26
- export { Pagination, PaginationButton, PaginationEllipsis, PaginationItem, PaginationList, PaginationNext, PaginationPrevious, PaginationRoot };
16
+ export { Pagination, PaginationButton, PaginationItem, PaginationList };
@@ -1,63 +1,58 @@
1
1
  'use client';
2
- import { useState, useEffect } from 'react';
2
+ import { useMemo } from 'react';
3
3
 
4
- const getSteps = ({ compact, currentPage, totalPages, }) => {
5
- /** Number of always visible pages at the start and end. */
6
- const boundaryCount = 1;
7
- /** Number of always visible pages before and after the current page. */
8
- const siblingCount = compact ? 0 : 1;
9
- const range = (start, end) => Array.from({ length: end - start + 1 }, (_, i) => start + i);
10
- if (totalPages <= (boundaryCount + siblingCount) * 2 + 3)
11
- return range(1, totalPages);
12
- const startPages = range(1, boundaryCount);
13
- const endPages = range(totalPages - boundaryCount + 1, totalPages);
14
- const siblingsStart = Math.max(Math.min(currentPage - siblingCount, totalPages - boundaryCount - siblingCount * 2 - 1), boundaryCount + 2);
15
- const siblingsEnd = siblingsStart + siblingCount * 2;
16
- return [
17
- ...startPages,
18
- siblingsStart - (startPages[startPages.length - 1] ?? 0) === 2
19
- ? siblingsStart - 1
20
- : 'ellipsis',
21
- ...range(siblingsStart, siblingsEnd),
22
- (endPages[0] ?? totalPages + 1) - siblingsEnd === 2
23
- ? siblingsEnd + 1
24
- : 'ellipsis',
25
- ...endPages,
26
- ];
4
+ const getSteps = (now, max, show) => {
5
+ const offset = (show - 1) / 2;
6
+ const start = Math.min(Math.max(now - Math.floor(offset), 1), max - show + 1);
7
+ const end = Math.min(Math.max(now + Math.ceil(offset), show), max);
8
+ const pages = Array.from({ length: end + 1 - start }, (_, i) => i + start);
9
+ if (show > 4 && start > 1)
10
+ pages.splice(0, 2, 1, 0);
11
+ if (show > 3 && end < max)
12
+ pages.splice(-2, 2, 0, max);
13
+ return pages;
27
14
  };
28
15
  /** Hook to help manage pagination state */
29
- const usePagination = ({ totalPages, currentPage: currentPageProps = 1, compact, }) => {
30
- const [currentPage, setCurrentPage] = useState(currentPageProps);
31
- useEffect(() => {
32
- setCurrentPage(currentPageProps);
33
- }, [currentPageProps]);
34
- const pages = getSteps({ currentPage, totalPages, compact });
35
- const showNextPage = currentPage < totalPages;
36
- const showPreviousPage = currentPage !== 1;
37
- const nextPage = () => {
38
- setCurrentPage(currentPage + 1 <= totalPages ? currentPage + 1 : totalPages);
39
- };
40
- const previousPage = () => {
41
- setCurrentPage(currentPage - 1 > 0 ? currentPage - 1 : 1);
16
+ const usePagination = ({ currentPage = 1, setCurrentPage, onChange, totalPages, showPages = 7, }) => useMemo(() => {
17
+ const hasNext = currentPage < totalPages;
18
+ const hasPrev = currentPage !== 1;
19
+ const handleClick = (page) => (event) => {
20
+ if (page < 1 || page > totalPages)
21
+ return event.preventDefault(); // Prevent out of bounds navigation
22
+ onChange?.(event, page);
23
+ if (!event.defaultPrevented)
24
+ setCurrentPage?.(page); // Allow stopping change by calling event.preventDefault() in onChange
42
25
  };
43
26
  return {
44
27
  /** Number of steps */
45
- pages,
46
- /** Current active page */
47
- currentPage,
48
- /** Set active page */
49
- setCurrentPage,
50
- /** Decrements active page by 1 */
51
- previousPage,
52
- /** Increments active page by 1 */
53
- nextPage,
54
- /** Total amount of pages */
55
- totalPages,
56
- /** Indication if next page action should be shown or not */
57
- showNextPage,
28
+ pages: getSteps(currentPage, totalPages, showPages).map((page, index) => ({
29
+ page: page || '',
30
+ itemKey: page ? `page-${page}` : `ellipsis-${index}`, // React key utility
31
+ buttonProps: {
32
+ 'aria-current': page === currentPage ? 'page' : undefined,
33
+ 'aria-hidden': !page || undefined, // Hide ellipsis from screen reader
34
+ onClick: handleClick(page),
35
+ tabIndex: page ? undefined : -1, // Hide ellipsis keyboard
36
+ variant: page === currentPage ? 'primary' : 'tertiary',
37
+ },
38
+ })),
39
+ /** Properties to spread on Pagination.Button used for previous naviagation */
40
+ prevButtonProps: {
41
+ 'aria-disabled': !hasPrev, // Using aria-disabled to support all HTML elements because of potential asChild
42
+ onClick: handleClick(currentPage - 1),
43
+ variant: 'tertiary',
44
+ },
45
+ /** Properties to spread on Pagination.Button used for next naviagation */
46
+ nextButtonProps: {
47
+ 'aria-disabled': !hasNext, // Using aria-disabled to support all HTML elements because of potential asChild
48
+ onClick: handleClick(currentPage + 1),
49
+ variant: 'tertiary',
50
+ },
58
51
  /** Indication if previous page action should be shown or not */
59
- showPreviousPage,
52
+ hasPrev,
53
+ /** Indication if next page action should be shown or not */
54
+ hasNext,
60
55
  };
61
- };
56
+ }, [currentPage, totalPages, showPages]);
62
57
 
63
58
  export { usePagination };
@@ -0,0 +1,18 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { Slot } from '@radix-ui/react-slot';
4
+ import cl from 'clsx/lite';
5
+ import { forwardRef } from 'react';
6
+
7
+ /**
8
+ * Use `Paragraph` to display text with paragraph text styles.
9
+ *
10
+ * @example
11
+ * <Paragraph data-size='lg'>Paragraph</Paragraph>
12
+ */
13
+ const Paragraph = forwardRef(function Paragraph({ className, asChild, variant = 'default', ...rest }, ref) {
14
+ const Component = asChild ? Slot : 'p';
15
+ return (jsx(Component, { ref: ref, className: cl(`ds-paragraph`, className), "data-variant": variant, ...rest }));
16
+ });
17
+
18
+ export { Paragraph };