@dnb/eufemia 10.18.0 → 10.20.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1199) hide show
  1. package/CHANGELOG.md +67 -0
  2. package/cjs/components/AriaLive.d.ts +12 -0
  3. package/cjs/components/AriaLive.js +24 -0
  4. package/cjs/components/AriaLive.js.map +1 -0
  5. package/cjs/components/accordion/AccordionContent.d.ts +1 -1
  6. package/cjs/components/accordion/AccordionContent.js.map +1 -1
  7. package/cjs/components/accordion/style/dnb-accordion.css +0 -3
  8. package/cjs/components/accordion/style/dnb-accordion.min.css +1 -1
  9. package/cjs/components/accordion/style/dnb-accordion.scss +0 -5
  10. package/cjs/components/aria-live/AriaLive.d.ts +6 -0
  11. package/cjs/components/aria-live/AriaLive.js +23 -0
  12. package/cjs/components/aria-live/AriaLive.js.map +1 -0
  13. package/cjs/components/aria-live/index.d.ts +7 -0
  14. package/cjs/components/aria-live/index.js +24 -0
  15. package/cjs/components/aria-live/index.js.map +1 -0
  16. package/cjs/components/aria-live/types.d.ts +44 -0
  17. package/cjs/components/aria-live/types.js +1 -0
  18. package/cjs/components/aria-live/types.js.map +1 -0
  19. package/cjs/components/aria-live/useAriaLive.d.ts +273 -0
  20. package/cjs/components/aria-live/useAriaLive.js +84 -0
  21. package/cjs/components/aria-live/useAriaLive.js.map +1 -0
  22. package/cjs/components/autocomplete/Autocomplete.d.ts +0 -1
  23. package/cjs/components/autocomplete/Autocomplete.js +24 -46
  24. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  25. package/cjs/components/breadcrumb/Breadcrumb.js +24 -21
  26. package/cjs/components/breadcrumb/Breadcrumb.js.map +1 -1
  27. package/cjs/components/breadcrumb/BreadcrumbItem.js +16 -7
  28. package/cjs/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  29. package/cjs/components/breadcrumb/BreadcrumbMultiple.js +1 -1
  30. package/cjs/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  31. package/cjs/components/breadcrumb/style/dnb-breadcrumb.css +13 -3
  32. package/cjs/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  33. package/cjs/components/breadcrumb/style/dnb-breadcrumb.scss +15 -3
  34. package/cjs/components/card/Card.d.ts +6 -4
  35. package/cjs/components/card/Card.js +11 -15
  36. package/cjs/components/card/Card.js.map +1 -1
  37. package/cjs/components/card/style/dnb-card.css +29 -0
  38. package/cjs/components/card/style/dnb-card.min.css +1 -1
  39. package/cjs/components/card/style/dnb-card.scss +41 -0
  40. package/cjs/components/card/style/themes/dnb-card-theme-ui.css +1 -19
  41. package/cjs/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  42. package/cjs/components/card/style/themes/dnb-card-theme-ui.scss +1 -27
  43. package/cjs/components/date-picker/DatePicker.d.ts +3 -0
  44. package/cjs/components/date-picker/DatePickerProvider.js +9 -5
  45. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  46. package/cjs/components/flex/Container.d.ts +4 -2
  47. package/cjs/components/flex/Container.js +28 -9
  48. package/cjs/components/flex/Container.js.map +1 -1
  49. package/cjs/components/flex/Item.js +8 -13
  50. package/cjs/components/flex/Item.js.map +1 -1
  51. package/cjs/components/flex/style/dnb-flex.css +6 -3
  52. package/cjs/components/flex/style/dnb-flex.min.css +1 -1
  53. package/cjs/components/flex/style/flex-container.scss +6 -7
  54. package/cjs/components/flex/utils.d.ts +35 -7
  55. package/cjs/components/flex/utils.js +65 -33
  56. package/cjs/components/flex/utils.js.map +1 -1
  57. package/cjs/components/form-status/FormStatus.d.ts +5 -1
  58. package/cjs/components/form-status/FormStatus.js +38 -44
  59. package/cjs/components/form-status/FormStatus.js.map +1 -1
  60. package/cjs/components/form-status/style/dnb-form-status.css +0 -18
  61. package/cjs/components/form-status/style/dnb-form-status.min.css +1 -1
  62. package/cjs/components/form-status/style/dnb-form-status.scss +0 -45
  63. package/cjs/components/global-status/GlobalStatus.js +52 -138
  64. package/cjs/components/global-status/GlobalStatus.js.map +1 -1
  65. package/cjs/components/global-status/style/dnb-global-status.css +6 -16
  66. package/cjs/components/global-status/style/dnb-global-status.min.css +1 -1
  67. package/cjs/components/global-status/style/dnb-global-status.scss +11 -23
  68. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.css +0 -3
  69. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  70. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.scss +0 -10
  71. package/cjs/components/height-animation/HeightAnimation.d.ts +12 -4
  72. package/cjs/components/height-animation/HeightAnimation.js +31 -14
  73. package/cjs/components/height-animation/HeightAnimation.js.map +1 -1
  74. package/cjs/components/height-animation/HeightAnimationInstance.d.ts +35 -18
  75. package/cjs/components/height-animation/HeightAnimationInstance.js +186 -158
  76. package/cjs/components/height-animation/HeightAnimationInstance.js.map +1 -1
  77. package/cjs/components/height-animation/style/dnb-height-animation.css +16 -2
  78. package/cjs/components/height-animation/style/dnb-height-animation.min.css +1 -1
  79. package/cjs/components/height-animation/style/dnb-height-animation.scss +18 -2
  80. package/cjs/components/height-animation/useHeightAnimation.d.ts +6 -1
  81. package/cjs/components/height-animation/useHeightAnimation.js +125 -92
  82. package/cjs/components/height-animation/useHeightAnimation.js.map +1 -1
  83. package/cjs/components/index.d.ts +2 -1
  84. package/cjs/components/index.js +7 -0
  85. package/cjs/components/index.js.map +1 -1
  86. package/cjs/components/input/Input.js +0 -3
  87. package/cjs/components/input/Input.js.map +1 -1
  88. package/cjs/components/input-masked/MultiInputMask.d.ts +1 -1
  89. package/cjs/components/input-masked/MultiInputMask.js +52 -41
  90. package/cjs/components/input-masked/MultiInputMask.js.map +1 -1
  91. package/cjs/components/lib.d.ts +3 -1
  92. package/cjs/components/lib.js +8 -0
  93. package/cjs/components/lib.js.map +1 -1
  94. package/cjs/components/number-format/NumberFormat.d.ts +7 -12
  95. package/cjs/components/number-format/NumberUtils.d.ts +8 -2
  96. package/cjs/components/number-format/useNumberFormat.d.ts +1 -1
  97. package/cjs/components/section/Section.d.ts +6 -3
  98. package/cjs/components/section/Section.js.map +1 -1
  99. package/cjs/components/section/style/dnb-section.css +1 -0
  100. package/cjs/components/section/style/dnb-section.min.css +1 -1
  101. package/cjs/components/section/style/dnb-section.scss +1 -0
  102. package/cjs/components/space/SpacingUtils.js +5 -1
  103. package/cjs/components/space/SpacingUtils.js.map +1 -1
  104. package/cjs/components/step-indicator/StepIndicatorItem.js +3 -21
  105. package/cjs/components/step-indicator/StepIndicatorItem.js.map +1 -1
  106. package/cjs/components/step-indicator/StepIndicatorTriggerButton.js +2 -16
  107. package/cjs/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  108. package/cjs/components/step-indicator/style/dnb-step-indicator.css +0 -5
  109. package/cjs/components/step-indicator/style/dnb-step-indicator.min.css +1 -1
  110. package/cjs/components/step-indicator/style/dnb-step-indicator.scss +0 -7
  111. package/cjs/components/table/TableAccordion.js +1 -1
  112. package/cjs/components/table/TableAccordion.js.map +1 -1
  113. package/cjs/components/table/TableAccordionContent.js +51 -23
  114. package/cjs/components/table/TableAccordionContent.js.map +1 -1
  115. package/cjs/components/table/style/dnb-table.css +6 -3
  116. package/cjs/components/table/style/dnb-table.min.css +1 -1
  117. package/cjs/components/table/style/table-accordion.scss +6 -3
  118. package/cjs/components/tabs/Tabs.js +2 -1
  119. package/cjs/components/tabs/Tabs.js.map +1 -1
  120. package/cjs/components/tabs/TabsContentWrapper.d.ts +1 -0
  121. package/cjs/components/tabs/TabsContentWrapper.js +8 -6
  122. package/cjs/components/tabs/TabsContentWrapper.js.map +1 -1
  123. package/cjs/components/textarea/Textarea.d.ts +5 -0
  124. package/cjs/components/textarea/Textarea.js +16 -3
  125. package/cjs/components/textarea/Textarea.js.map +1 -1
  126. package/cjs/components/textarea/style/dnb-textarea.css +10 -3
  127. package/cjs/components/textarea/style/dnb-textarea.min.css +1 -1
  128. package/cjs/components/textarea/style/dnb-textarea.scss +13 -3
  129. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.css +15 -2
  130. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  131. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.scss +15 -2
  132. package/cjs/components/upload/Upload.js +15 -18
  133. package/cjs/components/upload/Upload.js.map +1 -1
  134. package/cjs/components/upload/UploadFileInput.js +3 -1
  135. package/cjs/components/upload/UploadFileInput.js.map +1 -1
  136. package/cjs/components/upload/UploadFileList.js +1 -1
  137. package/cjs/components/upload/UploadFileList.js.map +1 -1
  138. package/cjs/components/upload/UploadStatus.js +6 -2
  139. package/cjs/components/upload/UploadStatus.js.map +1 -1
  140. package/cjs/components/upload/useUpload.js +5 -6
  141. package/cjs/components/upload/useUpload.js.map +1 -1
  142. package/cjs/elements/lib.d.ts +6 -0
  143. package/cjs/elements/typography/H1.d.ts +1 -0
  144. package/cjs/elements/typography/H1.js +1 -1
  145. package/cjs/elements/typography/H1.js.map +1 -1
  146. package/cjs/elements/typography/H2.d.ts +1 -0
  147. package/cjs/elements/typography/H2.js +1 -1
  148. package/cjs/elements/typography/H2.js.map +1 -1
  149. package/cjs/elements/typography/H3.d.ts +1 -0
  150. package/cjs/elements/typography/H3.js +1 -1
  151. package/cjs/elements/typography/H3.js.map +1 -1
  152. package/cjs/elements/typography/H4.d.ts +1 -0
  153. package/cjs/elements/typography/H4.js +1 -1
  154. package/cjs/elements/typography/H4.js.map +1 -1
  155. package/cjs/elements/typography/H5.d.ts +1 -0
  156. package/cjs/elements/typography/H5.js +1 -1
  157. package/cjs/elements/typography/H5.js.map +1 -1
  158. package/cjs/elements/typography/H6.d.ts +1 -0
  159. package/cjs/elements/typography/H6.js +1 -1
  160. package/cjs/elements/typography/H6.js.map +1 -1
  161. package/cjs/extensions/forms/DataContext/Context.d.ts +18 -5
  162. package/cjs/extensions/forms/DataContext/Context.js +9 -0
  163. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  164. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +57 -19
  165. package/cjs/extensions/forms/DataContext/Provider/Provider.js +128 -48
  166. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  167. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -1
  168. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  169. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  170. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +5 -4
  171. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  172. package/cjs/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  173. package/cjs/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  174. package/cjs/extensions/forms/Field/Currency/Currency.d.ts +2 -2
  175. package/cjs/extensions/forms/Field/Currency/Currency.js.map +1 -1
  176. package/cjs/extensions/forms/Field/Date/Date.js +8 -4
  177. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  178. package/cjs/extensions/forms/Field/Email/Email.d.ts +2 -2
  179. package/cjs/extensions/forms/Field/Email/Email.js +5 -4
  180. package/cjs/extensions/forms/Field/Email/Email.js.map +1 -1
  181. package/cjs/extensions/forms/Field/Expiry/Expiry.js +18 -16
  182. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  183. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  184. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +5 -4
  185. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  186. package/cjs/extensions/forms/Field/Number/Number.d.ts +2 -4
  187. package/cjs/extensions/forms/Field/Number/Number.js +28 -27
  188. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  189. package/cjs/extensions/forms/Field/Number/style/dnb-number.css +0 -6
  190. package/cjs/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  191. package/cjs/extensions/forms/Field/Number/style/dnb-number.scss +0 -1
  192. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +4 -0
  193. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +1 -1
  194. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +7 -0
  195. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +4 -0
  196. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +1 -1
  197. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +9 -0
  198. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +2 -2
  199. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +5 -4
  200. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  201. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  202. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +15 -7
  203. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  204. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  205. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  206. package/cjs/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.css +9 -0
  207. package/cjs/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.min.css +1 -1
  208. package/cjs/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.scss +7 -0
  209. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +9 -5
  210. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  211. package/cjs/extensions/forms/Field/Selection/Selection.js +12 -7
  212. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  213. package/cjs/extensions/forms/Field/String/String.d.ts +4 -2
  214. package/cjs/extensions/forms/Field/String/String.js +17 -9
  215. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  216. package/cjs/extensions/forms/Field/Toggle/Toggle.js +20 -13
  217. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  218. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +2 -2
  219. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +11 -8
  220. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  221. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +22 -5
  222. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  223. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +29 -1
  224. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.css +4 -0
  225. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.min.css +1 -0
  226. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.scss +6 -0
  227. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +4 -0
  228. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -0
  229. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +6 -0
  230. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  231. package/cjs/extensions/forms/Form/Handler/Handler.js +7 -1
  232. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  233. package/cjs/extensions/forms/Form/Visibility/Visibility.d.ts +6 -1
  234. package/cjs/extensions/forms/Form/Visibility/Visibility.js +54 -39
  235. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  236. package/cjs/extensions/forms/Form/data-context/getData.d.ts +8 -0
  237. package/cjs/extensions/forms/Form/data-context/getData.js +21 -0
  238. package/cjs/extensions/forms/Form/data-context/getData.js.map +1 -0
  239. package/cjs/extensions/forms/Form/data-context/setData.d.ts +2 -0
  240. package/cjs/extensions/forms/Form/data-context/setData.js +12 -0
  241. package/cjs/extensions/forms/Form/data-context/setData.js.map +1 -0
  242. package/cjs/extensions/forms/Form/data-context/useData.d.ts +22 -0
  243. package/cjs/extensions/forms/Form/data-context/useData.js +65 -0
  244. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -0
  245. package/cjs/extensions/forms/Form/data-context/useError.d.ts +5 -0
  246. package/cjs/extensions/forms/Form/data-context/useError.js +18 -0
  247. package/cjs/extensions/forms/Form/data-context/useError.js.map +1 -0
  248. package/cjs/extensions/forms/Form/index.d.ts +4 -1
  249. package/cjs/extensions/forms/Form/index.js +22 -1
  250. package/cjs/extensions/forms/Form/index.js.map +1 -1
  251. package/cjs/extensions/forms/Iterate/Array/Array.d.ts +2 -2
  252. package/cjs/extensions/forms/Iterate/Array/Array.js +3 -1
  253. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  254. package/cjs/extensions/forms/StepsLayout/StepsLayout.d.ts +3 -0
  255. package/cjs/extensions/forms/StepsLayout/StepsLayout.js +30 -21
  256. package/cjs/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  257. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -0
  258. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  259. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +7 -0
  260. package/cjs/extensions/forms/Value/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  261. package/cjs/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js.map +1 -1
  262. package/cjs/extensions/forms/Value/Currency/Currency.d.ts +2 -2
  263. package/cjs/extensions/forms/Value/Currency/Currency.js +2 -3
  264. package/cjs/extensions/forms/Value/Currency/Currency.js.map +1 -1
  265. package/cjs/extensions/forms/Value/Date/Date.d.ts +2 -2
  266. package/cjs/extensions/forms/Value/Date/Date.js.map +1 -1
  267. package/cjs/extensions/forms/Value/Email/Email.d.ts +2 -2
  268. package/cjs/extensions/forms/Value/Email/Email.js.map +1 -1
  269. package/cjs/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  270. package/cjs/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  271. package/cjs/extensions/forms/Value/Number/Number.d.ts +6 -10
  272. package/cjs/extensions/forms/Value/Number/Number.js +25 -27
  273. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  274. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.d.ts +2 -2
  275. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.js +6 -4
  276. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  277. package/cjs/extensions/forms/hooks/index.d.ts +1 -0
  278. package/cjs/extensions/forms/hooks/index.js +7 -0
  279. package/cjs/extensions/forms/hooks/index.js.map +1 -1
  280. package/cjs/extensions/forms/hooks/useDataValue.d.ts +10 -1
  281. package/cjs/extensions/forms/hooks/useDataValue.js +87 -28
  282. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  283. package/cjs/extensions/forms/hooks/useErrorMessage.d.ts +10 -0
  284. package/cjs/extensions/forms/hooks/useErrorMessage.js +23 -0
  285. package/cjs/extensions/forms/hooks/useErrorMessage.js.map +1 -0
  286. package/cjs/extensions/forms/index.d.ts +1 -0
  287. package/cjs/extensions/forms/index.js +9 -1
  288. package/cjs/extensions/forms/index.js.map +1 -1
  289. package/cjs/extensions/forms/style/dnb-forms.css +37 -11
  290. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  291. package/cjs/extensions/forms/types.d.ts +26 -9
  292. package/cjs/extensions/forms/types.js.map +1 -1
  293. package/cjs/extensions/forms/utils/ajv.d.ts +47 -6
  294. package/cjs/extensions/forms/utils/ajv.js +29 -13
  295. package/cjs/extensions/forms/utils/ajv.js.map +1 -1
  296. package/cjs/extensions/forms/utils/index.d.ts +0 -1
  297. package/cjs/extensions/forms/utils/index.js +0 -12
  298. package/cjs/extensions/forms/utils/index.js.map +1 -1
  299. package/cjs/fragments/TextCounter.d.ts +12 -0
  300. package/cjs/fragments/TextCounter.js +24 -0
  301. package/cjs/fragments/TextCounter.js.map +1 -0
  302. package/cjs/fragments/drawer-list/DrawerListHelpers.js +1 -0
  303. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  304. package/cjs/fragments/index.d.ts +2 -1
  305. package/cjs/fragments/index.js +7 -0
  306. package/cjs/fragments/index.js.map +1 -1
  307. package/cjs/fragments/lib.d.ts +3 -1
  308. package/cjs/fragments/lib.js +9 -1
  309. package/cjs/fragments/lib.js.map +1 -1
  310. package/cjs/fragments/text-counter/TextCounter.d.ts +8 -0
  311. package/cjs/fragments/text-counter/TextCounter.js +61 -0
  312. package/cjs/fragments/text-counter/TextCounter.js.map +1 -0
  313. package/cjs/fragments/text-counter/index.d.ts +5 -0
  314. package/cjs/fragments/text-counter/index.js +17 -0
  315. package/cjs/fragments/text-counter/index.js.map +1 -0
  316. package/cjs/fragments/text-counter/style/dnb-text-counter.scss +15 -0
  317. package/cjs/fragments/text-counter/style/index.d.ts +1 -0
  318. package/cjs/fragments/text-counter/style/index.js +4 -0
  319. package/cjs/fragments/text-counter/style/index.js.map +1 -0
  320. package/cjs/fragments/text-counter/style/themes/dnb-text-counter-theme-sbanken.scss +8 -0
  321. package/cjs/fragments/text-counter/style/themes/dnb-text-counter-theme-ui.scss +8 -0
  322. package/cjs/fragments/text-counter/style/themes/ui.d.ts +1 -0
  323. package/cjs/fragments/text-counter/style/themes/ui.js +4 -0
  324. package/cjs/fragments/text-counter/style/themes/ui.js.map +1 -0
  325. package/cjs/fragments/text-counter/style.d.ts +5 -0
  326. package/cjs/fragments/text-counter/style.js +4 -0
  327. package/cjs/fragments/text-counter/style.js.map +1 -0
  328. package/cjs/index.d.ts +2 -1
  329. package/cjs/index.js +7 -0
  330. package/cjs/index.js.map +1 -1
  331. package/cjs/shared/Eufemia.d.ts +1 -1
  332. package/cjs/shared/Eufemia.js +2 -2
  333. package/cjs/shared/Eufemia.js.map +1 -1
  334. package/cjs/shared/component-helper.js +0 -3
  335. package/cjs/shared/component-helper.js.map +1 -1
  336. package/cjs/shared/helpers/useSharedState.d.ts +33 -10
  337. package/cjs/shared/helpers/useSharedState.js +78 -40
  338. package/cjs/shared/helpers/useSharedState.js.map +1 -1
  339. package/cjs/shared/locales/en-GB.d.ts +7 -0
  340. package/cjs/shared/locales/en-GB.js +9 -2
  341. package/cjs/shared/locales/en-GB.js.map +1 -1
  342. package/cjs/shared/locales/en-US.d.ts +7 -0
  343. package/cjs/shared/locales/index.d.ts +14 -0
  344. package/cjs/shared/locales/nb-NO.d.ts +7 -0
  345. package/cjs/shared/locales/nb-NO.js +7 -0
  346. package/cjs/shared/locales/nb-NO.js.map +1 -1
  347. package/cjs/style/core/utilities.scss +1 -1
  348. package/cjs/style/dnb-ui-components.css +134 -67
  349. package/cjs/style/dnb-ui-components.min.css +3 -3
  350. package/cjs/style/dnb-ui-extensions.css +37 -11
  351. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  352. package/cjs/style/dnb-ui-forms.css +37 -11
  353. package/cjs/style/dnb-ui-forms.min.css +1 -1
  354. package/cjs/style/dnb-ui-fragments.css +10 -0
  355. package/cjs/style/dnb-ui-fragments.min.css +1 -1
  356. package/cjs/style/dnb-ui-fragments.scss +1 -0
  357. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +203 -102
  358. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  359. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  360. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +46 -11
  361. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  362. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  363. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +46 -11
  364. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  365. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  366. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +188 -97
  367. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  368. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  369. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +46 -11
  370. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  371. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  372. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +46 -11
  373. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  374. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  375. package/cjs/style/themes/theme-ui/ui-theme-components.css +203 -102
  376. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  377. package/cjs/style/themes/theme-ui/ui-theme-components.scss +1 -0
  378. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +46 -11
  379. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  380. package/cjs/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  381. package/cjs/style/themes/theme-ui/ui-theme-forms.css +46 -11
  382. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  383. package/cjs/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  384. package/components/AriaLive.d.ts +12 -0
  385. package/components/AriaLive.js +4 -0
  386. package/components/AriaLive.js.map +1 -0
  387. package/components/accordion/AccordionContent.d.ts +1 -1
  388. package/components/accordion/AccordionContent.js.map +1 -1
  389. package/components/accordion/style/dnb-accordion.css +0 -3
  390. package/components/accordion/style/dnb-accordion.min.css +1 -1
  391. package/components/accordion/style/dnb-accordion.scss +0 -5
  392. package/components/aria-live/AriaLive.d.ts +6 -0
  393. package/components/aria-live/AriaLive.js +15 -0
  394. package/components/aria-live/AriaLive.js.map +1 -0
  395. package/components/aria-live/index.d.ts +7 -0
  396. package/components/aria-live/index.js +4 -0
  397. package/components/aria-live/index.js.map +1 -0
  398. package/components/aria-live/types.d.ts +44 -0
  399. package/components/aria-live/types.js +1 -0
  400. package/components/aria-live/types.js.map +1 -0
  401. package/components/aria-live/useAriaLive.d.ts +273 -0
  402. package/components/aria-live/useAriaLive.js +75 -0
  403. package/components/aria-live/useAriaLive.js.map +1 -0
  404. package/components/autocomplete/Autocomplete.d.ts +0 -1
  405. package/components/autocomplete/Autocomplete.js +24 -46
  406. package/components/autocomplete/Autocomplete.js.map +1 -1
  407. package/components/breadcrumb/Breadcrumb.js +25 -22
  408. package/components/breadcrumb/Breadcrumb.js.map +1 -1
  409. package/components/breadcrumb/BreadcrumbItem.js +16 -7
  410. package/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  411. package/components/breadcrumb/BreadcrumbMultiple.js +1 -1
  412. package/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  413. package/components/breadcrumb/style/dnb-breadcrumb.css +13 -3
  414. package/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  415. package/components/breadcrumb/style/dnb-breadcrumb.scss +15 -3
  416. package/components/card/Card.d.ts +6 -4
  417. package/components/card/Card.js +11 -15
  418. package/components/card/Card.js.map +1 -1
  419. package/components/card/style/dnb-card.css +29 -0
  420. package/components/card/style/dnb-card.min.css +1 -1
  421. package/components/card/style/dnb-card.scss +41 -0
  422. package/components/card/style/themes/dnb-card-theme-ui.css +1 -19
  423. package/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  424. package/components/card/style/themes/dnb-card-theme-ui.scss +1 -27
  425. package/components/date-picker/DatePicker.d.ts +3 -0
  426. package/components/date-picker/DatePickerProvider.js +9 -5
  427. package/components/date-picker/DatePickerProvider.js.map +1 -1
  428. package/components/flex/Container.d.ts +4 -2
  429. package/components/flex/Container.js +26 -9
  430. package/components/flex/Container.js.map +1 -1
  431. package/components/flex/Item.js +8 -11
  432. package/components/flex/Item.js.map +1 -1
  433. package/components/flex/style/dnb-flex.css +6 -3
  434. package/components/flex/style/dnb-flex.min.css +1 -1
  435. package/components/flex/style/flex-container.scss +6 -7
  436. package/components/flex/utils.d.ts +35 -7
  437. package/components/flex/utils.js +56 -24
  438. package/components/flex/utils.js.map +1 -1
  439. package/components/form-status/FormStatus.d.ts +5 -1
  440. package/components/form-status/FormStatus.js +38 -44
  441. package/components/form-status/FormStatus.js.map +1 -1
  442. package/components/form-status/style/dnb-form-status.css +0 -18
  443. package/components/form-status/style/dnb-form-status.min.css +1 -1
  444. package/components/form-status/style/dnb-form-status.scss +0 -45
  445. package/components/global-status/GlobalStatus.js +53 -139
  446. package/components/global-status/GlobalStatus.js.map +1 -1
  447. package/components/global-status/style/dnb-global-status.css +6 -16
  448. package/components/global-status/style/dnb-global-status.min.css +1 -1
  449. package/components/global-status/style/dnb-global-status.scss +11 -23
  450. package/components/global-status/style/themes/dnb-global-status-theme-ui.css +0 -3
  451. package/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  452. package/components/global-status/style/themes/dnb-global-status-theme-ui.scss +0 -10
  453. package/components/height-animation/HeightAnimation.d.ts +12 -4
  454. package/components/height-animation/HeightAnimation.js +27 -14
  455. package/components/height-animation/HeightAnimation.js.map +1 -1
  456. package/components/height-animation/HeightAnimationInstance.d.ts +35 -18
  457. package/components/height-animation/HeightAnimationInstance.js +186 -158
  458. package/components/height-animation/HeightAnimationInstance.js.map +1 -1
  459. package/components/height-animation/style/dnb-height-animation.css +16 -2
  460. package/components/height-animation/style/dnb-height-animation.min.css +1 -1
  461. package/components/height-animation/style/dnb-height-animation.scss +18 -2
  462. package/components/height-animation/useHeightAnimation.d.ts +6 -1
  463. package/components/height-animation/useHeightAnimation.js +124 -92
  464. package/components/height-animation/useHeightAnimation.js.map +1 -1
  465. package/components/index.d.ts +2 -1
  466. package/components/index.js +2 -1
  467. package/components/index.js.map +1 -1
  468. package/components/input/Input.js +0 -3
  469. package/components/input/Input.js.map +1 -1
  470. package/components/input-masked/MultiInputMask.d.ts +1 -1
  471. package/components/input-masked/MultiInputMask.js +52 -41
  472. package/components/input-masked/MultiInputMask.js.map +1 -1
  473. package/components/lib.d.ts +3 -1
  474. package/components/lib.js +3 -1
  475. package/components/lib.js.map +1 -1
  476. package/components/number-format/NumberFormat.d.ts +7 -12
  477. package/components/number-format/NumberUtils.d.ts +8 -2
  478. package/components/number-format/useNumberFormat.d.ts +1 -1
  479. package/components/section/Section.d.ts +6 -3
  480. package/components/section/Section.js.map +1 -1
  481. package/components/section/style/dnb-section.css +1 -0
  482. package/components/section/style/dnb-section.min.css +1 -1
  483. package/components/section/style/dnb-section.scss +1 -0
  484. package/components/space/SpacingUtils.js +5 -1
  485. package/components/space/SpacingUtils.js.map +1 -1
  486. package/components/step-indicator/StepIndicatorItem.js +4 -22
  487. package/components/step-indicator/StepIndicatorItem.js.map +1 -1
  488. package/components/step-indicator/StepIndicatorTriggerButton.js +3 -17
  489. package/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  490. package/components/step-indicator/style/dnb-step-indicator.css +0 -5
  491. package/components/step-indicator/style/dnb-step-indicator.min.css +1 -1
  492. package/components/step-indicator/style/dnb-step-indicator.scss +0 -7
  493. package/components/table/TableAccordion.js +1 -1
  494. package/components/table/TableAccordion.js.map +1 -1
  495. package/components/table/TableAccordionContent.js +48 -23
  496. package/components/table/TableAccordionContent.js.map +1 -1
  497. package/components/table/style/dnb-table.css +6 -3
  498. package/components/table/style/dnb-table.min.css +1 -1
  499. package/components/table/style/table-accordion.scss +6 -3
  500. package/components/tabs/Tabs.js +2 -1
  501. package/components/tabs/Tabs.js.map +1 -1
  502. package/components/tabs/TabsContentWrapper.d.ts +1 -0
  503. package/components/tabs/TabsContentWrapper.js +8 -6
  504. package/components/tabs/TabsContentWrapper.js.map +1 -1
  505. package/components/textarea/Textarea.d.ts +5 -0
  506. package/components/textarea/Textarea.js +16 -3
  507. package/components/textarea/Textarea.js.map +1 -1
  508. package/components/textarea/style/dnb-textarea.css +10 -3
  509. package/components/textarea/style/dnb-textarea.min.css +1 -1
  510. package/components/textarea/style/dnb-textarea.scss +13 -3
  511. package/components/textarea/style/themes/dnb-textarea-theme-ui.css +15 -2
  512. package/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  513. package/components/textarea/style/themes/dnb-textarea-theme-ui.scss +15 -2
  514. package/components/upload/Upload.js +13 -18
  515. package/components/upload/Upload.js.map +1 -1
  516. package/components/upload/UploadFileInput.js +3 -1
  517. package/components/upload/UploadFileInput.js.map +1 -1
  518. package/components/upload/UploadFileList.js +1 -1
  519. package/components/upload/UploadFileList.js.map +1 -1
  520. package/components/upload/UploadStatus.js +6 -2
  521. package/components/upload/UploadStatus.js.map +1 -1
  522. package/components/upload/useUpload.js +5 -7
  523. package/components/upload/useUpload.js.map +1 -1
  524. package/elements/lib.d.ts +6 -0
  525. package/elements/typography/H1.d.ts +1 -0
  526. package/elements/typography/H1.js +1 -1
  527. package/elements/typography/H1.js.map +1 -1
  528. package/elements/typography/H2.d.ts +1 -0
  529. package/elements/typography/H2.js +1 -1
  530. package/elements/typography/H2.js.map +1 -1
  531. package/elements/typography/H3.d.ts +1 -0
  532. package/elements/typography/H3.js +1 -1
  533. package/elements/typography/H3.js.map +1 -1
  534. package/elements/typography/H4.d.ts +1 -0
  535. package/elements/typography/H4.js +1 -1
  536. package/elements/typography/H4.js.map +1 -1
  537. package/elements/typography/H5.d.ts +1 -0
  538. package/elements/typography/H5.js +1 -1
  539. package/elements/typography/H5.js.map +1 -1
  540. package/elements/typography/H6.d.ts +1 -0
  541. package/elements/typography/H6.js +1 -1
  542. package/elements/typography/H6.js.map +1 -1
  543. package/es/components/AriaLive.d.ts +12 -0
  544. package/es/components/AriaLive.js +4 -0
  545. package/es/components/AriaLive.js.map +1 -0
  546. package/es/components/accordion/AccordionContent.d.ts +1 -1
  547. package/es/components/accordion/AccordionContent.js.map +1 -1
  548. package/es/components/accordion/style/dnb-accordion.css +0 -3
  549. package/es/components/accordion/style/dnb-accordion.min.css +1 -1
  550. package/es/components/accordion/style/dnb-accordion.scss +0 -5
  551. package/es/components/aria-live/AriaLive.d.ts +6 -0
  552. package/es/components/aria-live/AriaLive.js +15 -0
  553. package/es/components/aria-live/AriaLive.js.map +1 -0
  554. package/es/components/aria-live/index.d.ts +7 -0
  555. package/es/components/aria-live/index.js +4 -0
  556. package/es/components/aria-live/index.js.map +1 -0
  557. package/es/components/aria-live/types.d.ts +44 -0
  558. package/es/components/aria-live/types.js +1 -0
  559. package/es/components/aria-live/types.js.map +1 -0
  560. package/es/components/aria-live/useAriaLive.d.ts +273 -0
  561. package/es/components/aria-live/useAriaLive.js +75 -0
  562. package/es/components/aria-live/useAriaLive.js.map +1 -0
  563. package/es/components/autocomplete/Autocomplete.d.ts +0 -1
  564. package/es/components/autocomplete/Autocomplete.js +24 -46
  565. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  566. package/es/components/breadcrumb/Breadcrumb.js +25 -22
  567. package/es/components/breadcrumb/Breadcrumb.js.map +1 -1
  568. package/es/components/breadcrumb/BreadcrumbItem.js +16 -7
  569. package/es/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  570. package/es/components/breadcrumb/BreadcrumbMultiple.js +1 -1
  571. package/es/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  572. package/es/components/breadcrumb/style/dnb-breadcrumb.css +13 -3
  573. package/es/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  574. package/es/components/breadcrumb/style/dnb-breadcrumb.scss +15 -3
  575. package/es/components/card/Card.d.ts +6 -4
  576. package/es/components/card/Card.js +11 -15
  577. package/es/components/card/Card.js.map +1 -1
  578. package/es/components/card/style/dnb-card.css +29 -0
  579. package/es/components/card/style/dnb-card.min.css +1 -1
  580. package/es/components/card/style/dnb-card.scss +41 -0
  581. package/es/components/card/style/themes/dnb-card-theme-ui.css +1 -19
  582. package/es/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  583. package/es/components/card/style/themes/dnb-card-theme-ui.scss +1 -27
  584. package/es/components/date-picker/DatePicker.d.ts +3 -0
  585. package/es/components/date-picker/DatePickerProvider.js +9 -5
  586. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  587. package/es/components/flex/Container.d.ts +4 -2
  588. package/es/components/flex/Container.js +26 -9
  589. package/es/components/flex/Container.js.map +1 -1
  590. package/es/components/flex/Item.js +8 -11
  591. package/es/components/flex/Item.js.map +1 -1
  592. package/es/components/flex/style/dnb-flex.css +6 -3
  593. package/es/components/flex/style/dnb-flex.min.css +1 -1
  594. package/es/components/flex/style/flex-container.scss +6 -7
  595. package/es/components/flex/utils.d.ts +35 -7
  596. package/es/components/flex/utils.js +55 -24
  597. package/es/components/flex/utils.js.map +1 -1
  598. package/es/components/form-status/FormStatus.d.ts +5 -1
  599. package/es/components/form-status/FormStatus.js +38 -44
  600. package/es/components/form-status/FormStatus.js.map +1 -1
  601. package/es/components/form-status/style/dnb-form-status.css +0 -18
  602. package/es/components/form-status/style/dnb-form-status.min.css +1 -1
  603. package/es/components/form-status/style/dnb-form-status.scss +0 -45
  604. package/es/components/global-status/GlobalStatus.js +51 -133
  605. package/es/components/global-status/GlobalStatus.js.map +1 -1
  606. package/es/components/global-status/style/dnb-global-status.css +6 -16
  607. package/es/components/global-status/style/dnb-global-status.min.css +1 -1
  608. package/es/components/global-status/style/dnb-global-status.scss +11 -23
  609. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.css +0 -3
  610. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  611. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.scss +0 -10
  612. package/es/components/height-animation/HeightAnimation.d.ts +12 -4
  613. package/es/components/height-animation/HeightAnimation.js +27 -14
  614. package/es/components/height-animation/HeightAnimation.js.map +1 -1
  615. package/es/components/height-animation/HeightAnimationInstance.d.ts +35 -18
  616. package/es/components/height-animation/HeightAnimationInstance.js +188 -155
  617. package/es/components/height-animation/HeightAnimationInstance.js.map +1 -1
  618. package/es/components/height-animation/style/dnb-height-animation.css +16 -2
  619. package/es/components/height-animation/style/dnb-height-animation.min.css +1 -1
  620. package/es/components/height-animation/style/dnb-height-animation.scss +18 -2
  621. package/es/components/height-animation/useHeightAnimation.d.ts +6 -1
  622. package/es/components/height-animation/useHeightAnimation.js +124 -92
  623. package/es/components/height-animation/useHeightAnimation.js.map +1 -1
  624. package/es/components/index.d.ts +2 -1
  625. package/es/components/index.js +2 -1
  626. package/es/components/index.js.map +1 -1
  627. package/es/components/input/Input.js +0 -3
  628. package/es/components/input/Input.js.map +1 -1
  629. package/es/components/input-masked/MultiInputMask.d.ts +1 -1
  630. package/es/components/input-masked/MultiInputMask.js +50 -39
  631. package/es/components/input-masked/MultiInputMask.js.map +1 -1
  632. package/es/components/lib.d.ts +3 -1
  633. package/es/components/lib.js +3 -1
  634. package/es/components/lib.js.map +1 -1
  635. package/es/components/number-format/NumberFormat.d.ts +7 -12
  636. package/es/components/number-format/NumberUtils.d.ts +8 -2
  637. package/es/components/number-format/useNumberFormat.d.ts +1 -1
  638. package/es/components/section/Section.d.ts +6 -3
  639. package/es/components/section/Section.js.map +1 -1
  640. package/es/components/section/style/dnb-section.css +1 -0
  641. package/es/components/section/style/dnb-section.min.css +1 -1
  642. package/es/components/section/style/dnb-section.scss +1 -0
  643. package/es/components/space/SpacingUtils.js +5 -1
  644. package/es/components/space/SpacingUtils.js.map +1 -1
  645. package/es/components/step-indicator/StepIndicatorItem.js +4 -22
  646. package/es/components/step-indicator/StepIndicatorItem.js.map +1 -1
  647. package/es/components/step-indicator/StepIndicatorTriggerButton.js +3 -17
  648. package/es/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  649. package/es/components/step-indicator/style/dnb-step-indicator.css +0 -5
  650. package/es/components/step-indicator/style/dnb-step-indicator.min.css +1 -1
  651. package/es/components/step-indicator/style/dnb-step-indicator.scss +0 -7
  652. package/es/components/table/TableAccordion.js +1 -1
  653. package/es/components/table/TableAccordion.js.map +1 -1
  654. package/es/components/table/TableAccordionContent.js +47 -23
  655. package/es/components/table/TableAccordionContent.js.map +1 -1
  656. package/es/components/table/style/dnb-table.css +6 -3
  657. package/es/components/table/style/dnb-table.min.css +1 -1
  658. package/es/components/table/style/table-accordion.scss +6 -3
  659. package/es/components/tabs/Tabs.js +2 -1
  660. package/es/components/tabs/Tabs.js.map +1 -1
  661. package/es/components/tabs/TabsContentWrapper.d.ts +1 -0
  662. package/es/components/tabs/TabsContentWrapper.js +8 -6
  663. package/es/components/tabs/TabsContentWrapper.js.map +1 -1
  664. package/es/components/textarea/Textarea.d.ts +5 -0
  665. package/es/components/textarea/Textarea.js +16 -3
  666. package/es/components/textarea/Textarea.js.map +1 -1
  667. package/es/components/textarea/style/dnb-textarea.css +10 -3
  668. package/es/components/textarea/style/dnb-textarea.min.css +1 -1
  669. package/es/components/textarea/style/dnb-textarea.scss +13 -3
  670. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.css +15 -2
  671. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  672. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.scss +15 -2
  673. package/es/components/upload/Upload.js +13 -18
  674. package/es/components/upload/Upload.js.map +1 -1
  675. package/es/components/upload/UploadFileInput.js +3 -1
  676. package/es/components/upload/UploadFileInput.js.map +1 -1
  677. package/es/components/upload/UploadFileList.js +1 -1
  678. package/es/components/upload/UploadFileList.js.map +1 -1
  679. package/es/components/upload/UploadStatus.js +6 -2
  680. package/es/components/upload/UploadStatus.js.map +1 -1
  681. package/es/components/upload/useUpload.js +5 -7
  682. package/es/components/upload/useUpload.js.map +1 -1
  683. package/es/elements/lib.d.ts +6 -0
  684. package/es/elements/typography/H1.d.ts +1 -0
  685. package/es/elements/typography/H1.js +1 -1
  686. package/es/elements/typography/H1.js.map +1 -1
  687. package/es/elements/typography/H2.d.ts +1 -0
  688. package/es/elements/typography/H2.js +1 -1
  689. package/es/elements/typography/H2.js.map +1 -1
  690. package/es/elements/typography/H3.d.ts +1 -0
  691. package/es/elements/typography/H3.js +1 -1
  692. package/es/elements/typography/H3.js.map +1 -1
  693. package/es/elements/typography/H4.d.ts +1 -0
  694. package/es/elements/typography/H4.js +1 -1
  695. package/es/elements/typography/H4.js.map +1 -1
  696. package/es/elements/typography/H5.d.ts +1 -0
  697. package/es/elements/typography/H5.js +1 -1
  698. package/es/elements/typography/H5.js.map +1 -1
  699. package/es/elements/typography/H6.d.ts +1 -0
  700. package/es/elements/typography/H6.js +1 -1
  701. package/es/elements/typography/H6.js.map +1 -1
  702. package/es/extensions/forms/DataContext/Context.d.ts +18 -5
  703. package/es/extensions/forms/DataContext/Context.js +9 -0
  704. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  705. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +57 -19
  706. package/es/extensions/forms/DataContext/Provider/Provider.js +127 -49
  707. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  708. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +5 -3
  709. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  710. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  711. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +6 -5
  712. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  713. package/es/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  714. package/es/extensions/forms/Field/Boolean/Boolean.js +2 -2
  715. package/es/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  716. package/es/extensions/forms/Field/Currency/Currency.d.ts +2 -2
  717. package/es/extensions/forms/Field/Currency/Currency.js +2 -2
  718. package/es/extensions/forms/Field/Currency/Currency.js.map +1 -1
  719. package/es/extensions/forms/Field/Date/Date.js +8 -4
  720. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  721. package/es/extensions/forms/Field/Email/Email.d.ts +2 -2
  722. package/es/extensions/forms/Field/Email/Email.js +7 -6
  723. package/es/extensions/forms/Field/Email/Email.js.map +1 -1
  724. package/es/extensions/forms/Field/Expiry/Expiry.js +19 -17
  725. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  726. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  727. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +6 -5
  728. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  729. package/es/extensions/forms/Field/Number/Number.d.ts +2 -4
  730. package/es/extensions/forms/Field/Number/Number.js +28 -27
  731. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  732. package/es/extensions/forms/Field/Number/style/dnb-number.css +0 -6
  733. package/es/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  734. package/es/extensions/forms/Field/Number/style/dnb-number.scss +0 -1
  735. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +4 -0
  736. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +1 -1
  737. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +7 -0
  738. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +4 -0
  739. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +1 -1
  740. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +9 -0
  741. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +2 -2
  742. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +6 -5
  743. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  744. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  745. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +17 -9
  746. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  747. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  748. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -3
  749. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  750. package/es/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.css +9 -0
  751. package/es/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.min.css +1 -1
  752. package/es/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.scss +7 -0
  753. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +9 -5
  754. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  755. package/es/extensions/forms/Field/Selection/Selection.js +15 -10
  756. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  757. package/es/extensions/forms/Field/String/String.d.ts +4 -2
  758. package/es/extensions/forms/Field/String/String.js +17 -9
  759. package/es/extensions/forms/Field/String/String.js.map +1 -1
  760. package/es/extensions/forms/Field/Toggle/Toggle.js +20 -13
  761. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  762. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +2 -2
  763. package/es/extensions/forms/FieldBlock/FieldBlock.js +11 -8
  764. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  765. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +22 -5
  766. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  767. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +29 -1
  768. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.css +4 -0
  769. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.min.css +1 -0
  770. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.scss +6 -0
  771. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +4 -0
  772. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -0
  773. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +6 -0
  774. package/es/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  775. package/es/extensions/forms/Form/Handler/Handler.js +7 -1
  776. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  777. package/es/extensions/forms/Form/Visibility/Visibility.d.ts +6 -1
  778. package/es/extensions/forms/Form/Visibility/Visibility.js +55 -40
  779. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  780. package/es/extensions/forms/Form/data-context/getData.d.ts +8 -0
  781. package/es/extensions/forms/Form/data-context/getData.js +15 -0
  782. package/es/extensions/forms/Form/data-context/getData.js.map +1 -0
  783. package/es/extensions/forms/Form/data-context/setData.d.ts +2 -0
  784. package/es/extensions/forms/Form/data-context/setData.js +6 -0
  785. package/es/extensions/forms/Form/data-context/setData.js.map +1 -0
  786. package/es/extensions/forms/Form/data-context/useData.d.ts +22 -0
  787. package/es/extensions/forms/Form/data-context/useData.js +58 -0
  788. package/es/extensions/forms/Form/data-context/useData.js.map +1 -0
  789. package/es/extensions/forms/Form/data-context/useError.d.ts +5 -0
  790. package/es/extensions/forms/Form/data-context/useError.js +13 -0
  791. package/es/extensions/forms/Form/data-context/useError.js.map +1 -0
  792. package/es/extensions/forms/Form/index.d.ts +4 -1
  793. package/es/extensions/forms/Form/index.js +4 -1
  794. package/es/extensions/forms/Form/index.js.map +1 -1
  795. package/es/extensions/forms/Iterate/Array/Array.d.ts +2 -2
  796. package/es/extensions/forms/Iterate/Array/Array.js +3 -1
  797. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  798. package/es/extensions/forms/StepsLayout/StepsLayout.d.ts +3 -0
  799. package/es/extensions/forms/StepsLayout/StepsLayout.js +31 -22
  800. package/es/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  801. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -0
  802. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  803. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +7 -0
  804. package/es/extensions/forms/Value/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  805. package/es/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js +2 -2
  806. package/es/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js.map +1 -1
  807. package/es/extensions/forms/Value/Currency/Currency.d.ts +2 -2
  808. package/es/extensions/forms/Value/Currency/Currency.js +4 -5
  809. package/es/extensions/forms/Value/Currency/Currency.js.map +1 -1
  810. package/es/extensions/forms/Value/Date/Date.d.ts +2 -2
  811. package/es/extensions/forms/Value/Date/Date.js +2 -2
  812. package/es/extensions/forms/Value/Date/Date.js.map +1 -1
  813. package/es/extensions/forms/Value/Email/Email.d.ts +2 -2
  814. package/es/extensions/forms/Value/Email/Email.js +2 -2
  815. package/es/extensions/forms/Value/Email/Email.js.map +1 -1
  816. package/es/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  817. package/es/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js +2 -2
  818. package/es/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  819. package/es/extensions/forms/Value/Number/Number.d.ts +6 -10
  820. package/es/extensions/forms/Value/Number/Number.js +22 -27
  821. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  822. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.d.ts +2 -2
  823. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.js +8 -6
  824. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  825. package/es/extensions/forms/hooks/index.d.ts +1 -0
  826. package/es/extensions/forms/hooks/index.js +1 -0
  827. package/es/extensions/forms/hooks/index.js.map +1 -1
  828. package/es/extensions/forms/hooks/useDataValue.d.ts +10 -1
  829. package/es/extensions/forms/hooks/useDataValue.js +81 -24
  830. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  831. package/es/extensions/forms/hooks/useErrorMessage.d.ts +10 -0
  832. package/es/extensions/forms/hooks/useErrorMessage.js +15 -0
  833. package/es/extensions/forms/hooks/useErrorMessage.js.map +1 -0
  834. package/es/extensions/forms/index.d.ts +1 -0
  835. package/es/extensions/forms/index.js +1 -0
  836. package/es/extensions/forms/index.js.map +1 -1
  837. package/es/extensions/forms/style/dnb-forms.css +37 -11
  838. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  839. package/es/extensions/forms/types.d.ts +26 -9
  840. package/es/extensions/forms/types.js.map +1 -1
  841. package/es/extensions/forms/utils/ajv.d.ts +47 -6
  842. package/es/extensions/forms/utils/ajv.js +23 -15
  843. package/es/extensions/forms/utils/ajv.js.map +1 -1
  844. package/es/extensions/forms/utils/index.d.ts +0 -1
  845. package/es/extensions/forms/utils/index.js +0 -1
  846. package/es/extensions/forms/utils/index.js.map +1 -1
  847. package/es/fragments/TextCounter.d.ts +12 -0
  848. package/es/fragments/TextCounter.js +4 -0
  849. package/es/fragments/TextCounter.js.map +1 -0
  850. package/es/fragments/drawer-list/DrawerListHelpers.js +1 -0
  851. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  852. package/es/fragments/index.d.ts +2 -1
  853. package/es/fragments/index.js +2 -1
  854. package/es/fragments/index.js.map +1 -1
  855. package/es/fragments/lib.d.ts +3 -1
  856. package/es/fragments/lib.js +4 -2
  857. package/es/fragments/lib.js.map +1 -1
  858. package/es/fragments/text-counter/TextCounter.d.ts +8 -0
  859. package/es/fragments/text-counter/TextCounter.js +52 -0
  860. package/es/fragments/text-counter/TextCounter.js.map +1 -0
  861. package/es/fragments/text-counter/index.d.ts +5 -0
  862. package/es/fragments/text-counter/index.js +1 -0
  863. package/es/fragments/text-counter/index.js.map +1 -0
  864. package/es/fragments/text-counter/style/dnb-text-counter.scss +15 -0
  865. package/es/fragments/text-counter/style/index.d.ts +1 -0
  866. package/es/fragments/text-counter/style/index.js +1 -0
  867. package/es/fragments/text-counter/style/index.js.map +1 -0
  868. package/es/fragments/text-counter/style/themes/dnb-text-counter-theme-sbanken.scss +8 -0
  869. package/es/fragments/text-counter/style/themes/dnb-text-counter-theme-ui.scss +8 -0
  870. package/es/fragments/text-counter/style/themes/ui.d.ts +1 -0
  871. package/es/fragments/text-counter/style/themes/ui.js +1 -0
  872. package/es/fragments/text-counter/style/themes/ui.js.map +1 -0
  873. package/es/fragments/text-counter/style.d.ts +5 -0
  874. package/es/fragments/text-counter/style.js +1 -0
  875. package/es/fragments/text-counter/style.js.map +1 -0
  876. package/es/index.d.ts +2 -1
  877. package/es/index.js +2 -1
  878. package/es/index.js.map +1 -1
  879. package/es/shared/Eufemia.d.ts +1 -1
  880. package/es/shared/Eufemia.js +2 -2
  881. package/es/shared/Eufemia.js.map +1 -1
  882. package/es/shared/component-helper.js +0 -3
  883. package/es/shared/component-helper.js.map +1 -1
  884. package/es/shared/helpers/useSharedState.d.ts +33 -10
  885. package/es/shared/helpers/useSharedState.js +76 -40
  886. package/es/shared/helpers/useSharedState.js.map +1 -1
  887. package/es/shared/locales/en-GB.d.ts +7 -0
  888. package/es/shared/locales/en-GB.js +9 -2
  889. package/es/shared/locales/en-GB.js.map +1 -1
  890. package/es/shared/locales/en-US.d.ts +7 -0
  891. package/es/shared/locales/index.d.ts +14 -0
  892. package/es/shared/locales/nb-NO.d.ts +7 -0
  893. package/es/shared/locales/nb-NO.js +7 -0
  894. package/es/shared/locales/nb-NO.js.map +1 -1
  895. package/es/style/core/utilities.scss +1 -1
  896. package/es/style/dnb-ui-components.css +134 -67
  897. package/es/style/dnb-ui-components.min.css +3 -3
  898. package/es/style/dnb-ui-extensions.css +37 -11
  899. package/es/style/dnb-ui-extensions.min.css +1 -1
  900. package/es/style/dnb-ui-forms.css +37 -11
  901. package/es/style/dnb-ui-forms.min.css +1 -1
  902. package/es/style/dnb-ui-fragments.css +10 -0
  903. package/es/style/dnb-ui-fragments.min.css +1 -1
  904. package/es/style/dnb-ui-fragments.scss +1 -0
  905. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +203 -102
  906. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  907. package/es/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  908. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +46 -11
  909. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  910. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  911. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +46 -11
  912. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  913. package/es/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  914. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +188 -97
  915. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  916. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  917. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +46 -11
  918. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  919. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  920. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +46 -11
  921. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  922. package/es/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  923. package/es/style/themes/theme-ui/ui-theme-components.css +203 -102
  924. package/es/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  925. package/es/style/themes/theme-ui/ui-theme-components.scss +1 -0
  926. package/es/style/themes/theme-ui/ui-theme-extensions.css +46 -11
  927. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  928. package/es/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  929. package/es/style/themes/theme-ui/ui-theme-forms.css +46 -11
  930. package/es/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  931. package/es/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  932. package/esm/dnb-ui-basis.min.mjs +1 -1
  933. package/esm/dnb-ui-components.min.mjs +1 -1
  934. package/esm/dnb-ui-elements.min.mjs +1 -1
  935. package/esm/dnb-ui-extensions.min.mjs +3 -3
  936. package/esm/dnb-ui-lib.min.mjs +1 -1
  937. package/extensions/forms/DataContext/Context.d.ts +18 -5
  938. package/extensions/forms/DataContext/Context.js +9 -0
  939. package/extensions/forms/DataContext/Context.js.map +1 -1
  940. package/extensions/forms/DataContext/Provider/Provider.d.ts +57 -19
  941. package/extensions/forms/DataContext/Provider/Provider.js +129 -49
  942. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  943. package/extensions/forms/Field/ArraySelection/ArraySelection.js +5 -3
  944. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  945. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  946. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +6 -5
  947. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  948. package/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  949. package/extensions/forms/Field/Boolean/Boolean.js +2 -2
  950. package/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  951. package/extensions/forms/Field/Currency/Currency.d.ts +2 -2
  952. package/extensions/forms/Field/Currency/Currency.js +2 -2
  953. package/extensions/forms/Field/Currency/Currency.js.map +1 -1
  954. package/extensions/forms/Field/Date/Date.js +8 -4
  955. package/extensions/forms/Field/Date/Date.js.map +1 -1
  956. package/extensions/forms/Field/Email/Email.d.ts +2 -2
  957. package/extensions/forms/Field/Email/Email.js +7 -6
  958. package/extensions/forms/Field/Email/Email.js.map +1 -1
  959. package/extensions/forms/Field/Expiry/Expiry.js +19 -17
  960. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  961. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  962. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +6 -5
  963. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  964. package/extensions/forms/Field/Number/Number.d.ts +2 -4
  965. package/extensions/forms/Field/Number/Number.js +28 -27
  966. package/extensions/forms/Field/Number/Number.js.map +1 -1
  967. package/extensions/forms/Field/Number/style/dnb-number.css +0 -6
  968. package/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  969. package/extensions/forms/Field/Number/style/dnb-number.scss +0 -1
  970. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +4 -0
  971. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +1 -1
  972. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +7 -0
  973. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +4 -0
  974. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +1 -1
  975. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +9 -0
  976. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +2 -2
  977. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +6 -5
  978. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  979. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  980. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +17 -9
  981. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  982. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  983. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -3
  984. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  985. package/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.css +9 -0
  986. package/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.min.css +1 -1
  987. package/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.scss +7 -0
  988. package/extensions/forms/Field/SelectCountry/SelectCountry.js +9 -5
  989. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  990. package/extensions/forms/Field/Selection/Selection.js +15 -10
  991. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  992. package/extensions/forms/Field/String/String.d.ts +4 -2
  993. package/extensions/forms/Field/String/String.js +17 -9
  994. package/extensions/forms/Field/String/String.js.map +1 -1
  995. package/extensions/forms/Field/Toggle/Toggle.js +20 -13
  996. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  997. package/extensions/forms/FieldBlock/FieldBlock.d.ts +2 -2
  998. package/extensions/forms/FieldBlock/FieldBlock.js +11 -8
  999. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  1000. package/extensions/forms/FieldBlock/style/dnb-field-block.css +22 -5
  1001. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  1002. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +29 -1
  1003. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.css +4 -0
  1004. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.min.css +1 -0
  1005. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.scss +6 -0
  1006. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +4 -0
  1007. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -0
  1008. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +6 -0
  1009. package/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  1010. package/extensions/forms/Form/Handler/Handler.js +7 -1
  1011. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  1012. package/extensions/forms/Form/Visibility/Visibility.d.ts +6 -1
  1013. package/extensions/forms/Form/Visibility/Visibility.js +53 -39
  1014. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  1015. package/extensions/forms/Form/data-context/getData.d.ts +8 -0
  1016. package/extensions/forms/Form/data-context/getData.js +15 -0
  1017. package/extensions/forms/Form/data-context/getData.js.map +1 -0
  1018. package/extensions/forms/Form/data-context/setData.d.ts +2 -0
  1019. package/extensions/forms/Form/data-context/setData.js +6 -0
  1020. package/extensions/forms/Form/data-context/setData.js.map +1 -0
  1021. package/extensions/forms/Form/data-context/useData.d.ts +22 -0
  1022. package/extensions/forms/Form/data-context/useData.js +59 -0
  1023. package/extensions/forms/Form/data-context/useData.js.map +1 -0
  1024. package/extensions/forms/Form/data-context/useError.d.ts +5 -0
  1025. package/extensions/forms/Form/data-context/useError.js +13 -0
  1026. package/extensions/forms/Form/data-context/useError.js.map +1 -0
  1027. package/extensions/forms/Form/index.d.ts +4 -1
  1028. package/extensions/forms/Form/index.js +4 -1
  1029. package/extensions/forms/Form/index.js.map +1 -1
  1030. package/extensions/forms/Iterate/Array/Array.d.ts +2 -2
  1031. package/extensions/forms/Iterate/Array/Array.js +3 -1
  1032. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  1033. package/extensions/forms/StepsLayout/StepsLayout.d.ts +3 -0
  1034. package/extensions/forms/StepsLayout/StepsLayout.js +31 -22
  1035. package/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  1036. package/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -0
  1037. package/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  1038. package/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +7 -0
  1039. package/extensions/forms/Value/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  1040. package/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js +2 -2
  1041. package/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js.map +1 -1
  1042. package/extensions/forms/Value/Currency/Currency.d.ts +2 -2
  1043. package/extensions/forms/Value/Currency/Currency.js +4 -5
  1044. package/extensions/forms/Value/Currency/Currency.js.map +1 -1
  1045. package/extensions/forms/Value/Date/Date.d.ts +2 -2
  1046. package/extensions/forms/Value/Date/Date.js +2 -2
  1047. package/extensions/forms/Value/Date/Date.js.map +1 -1
  1048. package/extensions/forms/Value/Email/Email.d.ts +2 -2
  1049. package/extensions/forms/Value/Email/Email.js +2 -2
  1050. package/extensions/forms/Value/Email/Email.js.map +1 -1
  1051. package/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  1052. package/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js +2 -2
  1053. package/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  1054. package/extensions/forms/Value/Number/Number.d.ts +6 -10
  1055. package/extensions/forms/Value/Number/Number.js +22 -27
  1056. package/extensions/forms/Value/Number/Number.js.map +1 -1
  1057. package/extensions/forms/Value/PhoneNumber/PhoneNumber.d.ts +2 -2
  1058. package/extensions/forms/Value/PhoneNumber/PhoneNumber.js +8 -6
  1059. package/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  1060. package/extensions/forms/hooks/index.d.ts +1 -0
  1061. package/extensions/forms/hooks/index.js +1 -0
  1062. package/extensions/forms/hooks/index.js.map +1 -1
  1063. package/extensions/forms/hooks/useDataValue.d.ts +10 -1
  1064. package/extensions/forms/hooks/useDataValue.js +85 -26
  1065. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  1066. package/extensions/forms/hooks/useErrorMessage.d.ts +10 -0
  1067. package/extensions/forms/hooks/useErrorMessage.js +15 -0
  1068. package/extensions/forms/hooks/useErrorMessage.js.map +1 -0
  1069. package/extensions/forms/index.d.ts +1 -0
  1070. package/extensions/forms/index.js +1 -0
  1071. package/extensions/forms/index.js.map +1 -1
  1072. package/extensions/forms/style/dnb-forms.css +37 -11
  1073. package/extensions/forms/style/dnb-forms.min.css +1 -1
  1074. package/extensions/forms/types.d.ts +26 -9
  1075. package/extensions/forms/types.js.map +1 -1
  1076. package/extensions/forms/utils/ajv.d.ts +47 -6
  1077. package/extensions/forms/utils/ajv.js +23 -15
  1078. package/extensions/forms/utils/ajv.js.map +1 -1
  1079. package/extensions/forms/utils/index.d.ts +0 -1
  1080. package/extensions/forms/utils/index.js +0 -1
  1081. package/extensions/forms/utils/index.js.map +1 -1
  1082. package/fragments/TextCounter.d.ts +12 -0
  1083. package/fragments/TextCounter.js +4 -0
  1084. package/fragments/TextCounter.js.map +1 -0
  1085. package/fragments/drawer-list/DrawerListHelpers.js +1 -0
  1086. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  1087. package/fragments/index.d.ts +2 -1
  1088. package/fragments/index.js +2 -1
  1089. package/fragments/index.js.map +1 -1
  1090. package/fragments/lib.d.ts +3 -1
  1091. package/fragments/lib.js +4 -2
  1092. package/fragments/lib.js.map +1 -1
  1093. package/fragments/text-counter/TextCounter.d.ts +8 -0
  1094. package/fragments/text-counter/TextCounter.js +52 -0
  1095. package/fragments/text-counter/TextCounter.js.map +1 -0
  1096. package/fragments/text-counter/index.d.ts +5 -0
  1097. package/fragments/text-counter/index.js +1 -0
  1098. package/fragments/text-counter/index.js.map +1 -0
  1099. package/fragments/text-counter/style/dnb-text-counter.scss +15 -0
  1100. package/fragments/text-counter/style/index.d.ts +1 -0
  1101. package/fragments/text-counter/style/index.js +1 -0
  1102. package/fragments/text-counter/style/index.js.map +1 -0
  1103. package/fragments/text-counter/style/themes/dnb-text-counter-theme-sbanken.scss +8 -0
  1104. package/fragments/text-counter/style/themes/dnb-text-counter-theme-ui.scss +8 -0
  1105. package/fragments/text-counter/style/themes/ui.d.ts +1 -0
  1106. package/fragments/text-counter/style/themes/ui.js +1 -0
  1107. package/fragments/text-counter/style/themes/ui.js.map +1 -0
  1108. package/fragments/text-counter/style.d.ts +5 -0
  1109. package/fragments/text-counter/style.js +1 -0
  1110. package/fragments/text-counter/style.js.map +1 -0
  1111. package/index.d.ts +2 -1
  1112. package/index.js +2 -1
  1113. package/index.js.map +1 -1
  1114. package/package.json +1 -1
  1115. package/shared/Eufemia.d.ts +1 -1
  1116. package/shared/Eufemia.js +2 -2
  1117. package/shared/Eufemia.js.map +1 -1
  1118. package/shared/component-helper.js +0 -3
  1119. package/shared/component-helper.js.map +1 -1
  1120. package/shared/helpers/useSharedState.d.ts +33 -10
  1121. package/shared/helpers/useSharedState.js +78 -40
  1122. package/shared/helpers/useSharedState.js.map +1 -1
  1123. package/shared/locales/en-GB.d.ts +7 -0
  1124. package/shared/locales/en-GB.js +9 -2
  1125. package/shared/locales/en-GB.js.map +1 -1
  1126. package/shared/locales/en-US.d.ts +7 -0
  1127. package/shared/locales/index.d.ts +14 -0
  1128. package/shared/locales/nb-NO.d.ts +7 -0
  1129. package/shared/locales/nb-NO.js +7 -0
  1130. package/shared/locales/nb-NO.js.map +1 -1
  1131. package/style/core/utilities.scss +1 -1
  1132. package/style/dnb-ui-components.css +134 -67
  1133. package/style/dnb-ui-components.min.css +3 -3
  1134. package/style/dnb-ui-extensions.css +37 -11
  1135. package/style/dnb-ui-extensions.min.css +1 -1
  1136. package/style/dnb-ui-forms.css +37 -11
  1137. package/style/dnb-ui-forms.min.css +1 -1
  1138. package/style/dnb-ui-fragments.css +10 -0
  1139. package/style/dnb-ui-fragments.min.css +1 -1
  1140. package/style/dnb-ui-fragments.scss +1 -0
  1141. package/style/themes/theme-eiendom/eiendom-theme-components.css +203 -102
  1142. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  1143. package/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  1144. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +46 -11
  1145. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  1146. package/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  1147. package/style/themes/theme-eiendom/eiendom-theme-forms.css +46 -11
  1148. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  1149. package/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  1150. package/style/themes/theme-sbanken/sbanken-theme-components.css +188 -97
  1151. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  1152. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  1153. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +46 -11
  1154. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  1155. package/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  1156. package/style/themes/theme-sbanken/sbanken-theme-forms.css +46 -11
  1157. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  1158. package/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  1159. package/style/themes/theme-ui/ui-theme-components.css +203 -102
  1160. package/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  1161. package/style/themes/theme-ui/ui-theme-components.scss +1 -0
  1162. package/style/themes/theme-ui/ui-theme-extensions.css +46 -11
  1163. package/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  1164. package/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  1165. package/style/themes/theme-ui/ui-theme-forms.css +46 -11
  1166. package/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  1167. package/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  1168. package/umd/dnb-ui-basis.min.js +1 -1
  1169. package/umd/dnb-ui-components.min.js +1 -1
  1170. package/umd/dnb-ui-elements.min.js +1 -1
  1171. package/umd/dnb-ui-extensions.min.js +3 -3
  1172. package/umd/dnb-ui-lib.min.js +1 -1
  1173. package/cjs/components/global-status/AnimationHelper.d.ts +0 -12
  1174. package/cjs/components/global-status/AnimationHelper.js +0 -109
  1175. package/cjs/components/global-status/AnimationHelper.js.map +0 -1
  1176. package/cjs/extensions/forms/Form/hooks/useData.d.ts +0 -10
  1177. package/cjs/extensions/forms/Form/hooks/useData.js +0 -36
  1178. package/cjs/extensions/forms/Form/hooks/useData.js.map +0 -1
  1179. package/cjs/extensions/forms/utils/numbers.d.ts +0 -17
  1180. package/cjs/extensions/forms/utils/numbers.js +0 -42
  1181. package/cjs/extensions/forms/utils/numbers.js.map +0 -1
  1182. package/components/global-status/AnimationHelper.d.ts +0 -12
  1183. package/components/global-status/AnimationHelper.js +0 -100
  1184. package/components/global-status/AnimationHelper.js.map +0 -1
  1185. package/es/components/global-status/AnimationHelper.d.ts +0 -12
  1186. package/es/components/global-status/AnimationHelper.js +0 -100
  1187. package/es/components/global-status/AnimationHelper.js.map +0 -1
  1188. package/es/extensions/forms/Form/hooks/useData.d.ts +0 -10
  1189. package/es/extensions/forms/Form/hooks/useData.js +0 -29
  1190. package/es/extensions/forms/Form/hooks/useData.js.map +0 -1
  1191. package/es/extensions/forms/utils/numbers.d.ts +0 -17
  1192. package/es/extensions/forms/utils/numbers.js +0 -35
  1193. package/es/extensions/forms/utils/numbers.js.map +0 -1
  1194. package/extensions/forms/Form/hooks/useData.d.ts +0 -10
  1195. package/extensions/forms/Form/hooks/useData.js +0 -30
  1196. package/extensions/forms/Form/hooks/useData.js.map +0 -1
  1197. package/extensions/forms/utils/numbers.d.ts +0 -17
  1198. package/extensions/forms/utils/numbers.js +0 -35
  1199. package/extensions/forms/utils/numbers.js.map +0 -1
@@ -23,9 +23,7 @@ export type NumberFormatTooltip =
23
23
  export type NumberFormatChildren =
24
24
  | React.ReactNode
25
25
  | ((...args: any[]) => any);
26
- export interface NumberFormatProps
27
- extends React.HTMLProps<HTMLElement>,
28
- SpacingProps {
26
+ export type NumberFormatProps = {
29
27
  id?: string;
30
28
  /**
31
29
  * <em>(required)</em> a number.
@@ -137,17 +135,14 @@ export interface NumberFormatProps
137
135
  * If set to `true`, an overlaying skeleton with animation will be shown.
138
136
  */
139
137
  skeleton?: SkeletonShow;
140
- class?: string;
141
- className?: string;
142
- /**
143
- * <em>(required)</em> a number.
144
- */
145
- children?: NumberFormatChildren;
146
- }
138
+ };
139
+ export type NumberFormatAllProps = NumberFormatProps &
140
+ Omit<React.HTMLProps<HTMLElement>, 'prefix'> &
141
+ SpacingProps;
147
142
  export default class NumberFormat extends React.Component<
148
- NumberFormatProps,
143
+ NumberFormatAllProps,
149
144
  any
150
145
  > {
151
- static defaultProps: NumberFormatProps;
146
+ static defaultProps: NumberFormatAllProps;
152
147
  render(): JSX.Element;
153
148
  }
@@ -30,6 +30,7 @@ export interface formatReturnValue {
30
30
  }
31
31
  export type formatValue = string | number;
32
32
  export type formatReturnType = formatReturnValue | formatValue;
33
+
33
34
  export interface formatOptionParams {
34
35
  /** can be "auto" */
35
36
  locale?: Locale;
@@ -80,10 +81,15 @@ export interface formatOptionParams {
80
81
  /** If an object should be returned, including the "aria" property */
81
82
  returnAria?: boolean;
82
83
  }
83
- export const format: (
84
+
85
+ export function format(
86
+ value: formatValue,
87
+ options: formatOptionParams & { returnAria: true }
88
+ ): formatReturnValue;
89
+ export function format(
84
90
  value: formatValue,
85
91
  options?: formatOptionParams
86
- ) => formatReturnType;
92
+ ): formatValue;
87
93
 
88
94
  type cleanNumberOptions = {
89
95
  decimalSeparator?: string;
@@ -1,3 +1,3 @@
1
1
  import type { formatOptionParams, formatValue } from './NumberUtils';
2
- declare function useNumberFormat(value: formatValue, options?: formatOptionParams): import("./NumberUtils").formatReturnType;
2
+ declare function useNumberFormat(value: formatValue, options?: formatOptionParams): formatValue;
3
3
  export default useNumberFormat;
@@ -69,13 +69,16 @@ export type SectionProps = {
69
69
  */
70
70
  innerRef?: React.RefObject<HTMLElement>;
71
71
  /**
72
- * @deprecated in v11 use "innerSpace" prop instead */
72
+ * @deprecated in v11 use "innerSpace" prop instead
73
+ */
73
74
  spacing?: SectionSpacing | ResponsiveProp<SectionSpacing>;
74
75
  /**
75
- * @deprecated in v11 use "background" prop instead */
76
+ * @deprecated in v11 use "background" prop instead
77
+ */
76
78
  style_type?: SectionStyleTypes | string;
77
79
  /**
78
- * @deprecated in v11 use "innerRef" prop instead */
80
+ * @deprecated in v11 use "innerRef" prop instead
81
+ */
79
82
  inner_ref?: React.RefObject<HTMLElement>;
80
83
  };
81
84
  export type SectionAllProps = SectionProps & SpacingProps & Omit<React.HTMLProps<HTMLElement>, 'ref'>;
@@ -1 +1 @@
1
- {"version":3,"file":"Section.js","names":["React","classnames","Context","isTrue","extendPropsWithContext","Space","defaultProps","element","Section","localProps","createElement","SectionParams","context","useContext","props","variant","breakout","roundedCorner","textColor","backgroundColor","dropShadow","outline","innerRef","className","children","spacing","style_type","inner_ref","attributes","_objectWithoutProperties","_excluded","internalRef","useRef","elementRef","Object","freeze","_objectSpread","style","computeStyle","value","getColor","String","test","undefined","property","name","valueCallback","media","small","medium","large","result","size","_media","_media2","_name","_supportsSpacingProps"],"sources":["../../../../src/components/section/Section.tsx"],"sourcesContent":["/**\n * Web Section Component\n *\n */\n\nimport React from 'react'\nimport classnames from 'classnames'\nimport Context from '../../shared/Context'\nimport {\n isTrue,\n extendPropsWithContext,\n} from '../../shared/component-helper'\nimport type {\n DynamicElement,\n ResponsiveProp,\n SpacingProps,\n} from '../../shared/types'\nimport Space from '../space/Space'\n\nexport type SectionVariants = 'error' | 'info' | 'warning' | 'success'\n\nexport type SectionStyleTypes =\n | 'divider'\n | 'white'\n | 'transparent'\n\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'lavender'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'pistachio'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'emerald-green'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'sea-green'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'fire-red'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'fire-red-8'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'sand-yellow'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'black-3'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'mint-green'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'mint-green-12'\n\nexport type SectionSpacing =\n | boolean\n | 'x-small'\n | 'small'\n | 'medium'\n | 'large'\n | 'x-large'\n | 'xx-large'\n\nexport type TextColor = string\nexport type OutlineColor = string | boolean\nexport type BackgroundColor = string\nexport type DropShadow = boolean\n\nexport type SectionProps = {\n /**\n * Defines the semantic purpose and subsequently the style of the visual helper. Will take precedence over the style_type prop\n */\n variant?: SectionVariants | string\n\n /**\n * Define if the background color should break-out to a fullscreen view. Defaults to `true`.\n */\n breakout?: boolean | ResponsiveProp<boolean>\n\n /**\n * Define if the section should have rounded corners. Defaults to `false`.\n */\n roundedCorner?: boolean | ResponsiveProp<boolean>\n\n /**\n * Define a custom border color. Use a Eufemia color.\n */\n outline?: OutlineColor | ResponsiveProp<OutlineColor>\n\n /**\n * Define a custom text color to compliment the backgroundColor. Use a Eufemia color.\n */\n textColor?: TextColor | ResponsiveProp<TextColor>\n\n /**\n * Define a custom background color, instead of a variant. Use a Eufemia color.\n */\n backgroundColor?: BackgroundColor | ResponsiveProp<BackgroundColor>\n\n /**\n * Define a custom drop-shadow.\n */\n dropShadow?: DropShadow | ResponsiveProp<DropShadow>\n\n /**\n * Define what HTML element should be used. Defaults to `<section>`.\n */\n element?: DynamicElement\n\n /**\n * Define a React.Ref.\n */\n innerRef?: React.RefObject<HTMLElement>\n\n /**\n * @deprecated in v11 use \"innerSpace\" prop instead */\n spacing?: SectionSpacing | ResponsiveProp<SectionSpacing>\n /**\n * @deprecated in v11 use \"background\" prop instead */\n style_type?: SectionStyleTypes | string\n /**\n * @deprecated in v11 use \"innerRef\" prop instead */\n inner_ref?: React.RefObject<HTMLElement>\n}\n\nexport type SectionAllProps = SectionProps &\n SpacingProps &\n Omit<React.HTMLProps<HTMLElement>, 'ref'>\n\ntype SectionReturnParams = Record<string, unknown> & {\n className: string\n innerRef: React.RefObject<HTMLElement>\n children: React.ReactNode\n style: React.CSSProperties\n}\n\nconst defaultProps = {\n element: 'section',\n}\n\nexport default function Section(localProps: SectionAllProps) {\n return <Space {...SectionParams(localProps)} />\n}\n\nexport function SectionParams(\n localProps: SectionAllProps\n): SectionReturnParams {\n const context = React.useContext(Context)\n\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContext(\n localProps,\n defaultProps,\n context.Section\n )\n\n const {\n variant,\n breakout = true,\n roundedCorner,\n textColor,\n backgroundColor,\n dropShadow,\n outline,\n innerRef,\n\n className,\n children,\n\n spacing,\n style_type,\n inner_ref,\n\n ...attributes\n } = props\n\n const internalRef = React.useRef<HTMLElement>()\n const elementRef = innerRef || inner_ref || internalRef\n\n return Object.freeze({\n ...attributes,\n className: classnames(\n 'dnb-section',\n `dnb-section--${variant ? variant : style_type || 'default'}`,\n spacing &&\n `dnb-section--spacing-${isTrue(spacing) ? 'large' : spacing}`,\n className\n ),\n style: {\n ...computeStyle(\n breakout,\n 'breakout',\n (value) => `var(--breakout--${value ? 'on' : 'off'})`\n ),\n ...computeStyle(\n roundedCorner,\n 'rounded-corner',\n (value) => value && 'var(--rounded-corner--value)'\n ),\n ...computeStyle(textColor, 'text-color', (value) => getColor(value)),\n ...computeStyle(backgroundColor, 'background-color', (value) =>\n getColor(value)\n ),\n ...computeStyle(\n dropShadow,\n 'drop-shadow',\n (value) => value && 'var(--shadow-default)'\n ),\n ...computeStyle(outline, 'outline-color', (value) =>\n String(value) === 'true'\n ? 'var(--outline-color--value)'\n : getColor(value)\n ),\n ...attributes?.style,\n } as React.CSSProperties,\n innerRef: elementRef,\n children,\n })\n}\n\nfunction getColor(value: string) {\n return value\n ? !/#|var/.test(value)\n ? `var(--color-${value})`\n : value\n : undefined\n}\n\nfunction computeStyle(\n property: ResponsiveProp<unknown> | boolean | string,\n name: string,\n valueCallback: (value: string) => string | undefined\n) {\n let media = property as ResponsiveProp<unknown>\n\n if (media !== null && typeof media !== 'object') {\n media = {\n small: property,\n medium: property,\n large: property,\n } as ResponsiveProp<unknown>\n }\n\n const result = {}\n\n for (const size in media as ResponsiveProp<unknown>) {\n if (typeof media?.[size] !== 'undefined') {\n const value = valueCallback(media?.[size])\n if (typeof value === 'string') {\n result[`--${name}--${size}`] = value\n }\n }\n }\n\n return result\n}\n\nSection._name = 'Section'\nSection._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"Section.js","names":["React","classnames","Context","isTrue","extendPropsWithContext","Space","defaultProps","element","Section","localProps","createElement","SectionParams","context","useContext","props","variant","breakout","roundedCorner","textColor","backgroundColor","dropShadow","outline","innerRef","className","children","spacing","style_type","inner_ref","attributes","_objectWithoutProperties","_excluded","internalRef","useRef","elementRef","Object","freeze","_objectSpread","style","computeStyle","value","getColor","String","test","undefined","property","name","valueCallback","media","small","medium","large","result","size","_media","_media2","_name","_supportsSpacingProps"],"sources":["../../../../src/components/section/Section.tsx"],"sourcesContent":["/**\n * Web Section Component\n *\n */\n\nimport React from 'react'\nimport classnames from 'classnames'\nimport Context from '../../shared/Context'\nimport {\n isTrue,\n extendPropsWithContext,\n} from '../../shared/component-helper'\nimport type {\n DynamicElement,\n ResponsiveProp,\n SpacingProps,\n} from '../../shared/types'\nimport Space from '../space/Space'\n\nexport type SectionVariants = 'error' | 'info' | 'warning' | 'success'\n\nexport type SectionStyleTypes =\n | 'divider'\n | 'white'\n | 'transparent'\n\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'lavender'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'pistachio'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'emerald-green'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'sea-green'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'fire-red'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'fire-red-8'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'sand-yellow'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'black-3'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'mint-green'\n /** @deprecated in v11 use \"variant\" or \"backgroundColor\" prop instead */\n | 'mint-green-12'\n\nexport type SectionSpacing =\n | boolean\n | 'x-small'\n | 'small'\n | 'medium'\n | 'large'\n | 'x-large'\n | 'xx-large'\n\nexport type TextColor = string\nexport type OutlineColor = string | boolean\nexport type BackgroundColor = string\nexport type DropShadow = boolean\n\nexport type SectionProps = {\n /**\n * Defines the semantic purpose and subsequently the style of the visual helper. Will take precedence over the style_type prop\n */\n variant?: SectionVariants | string\n\n /**\n * Define if the background color should break-out to a fullscreen view. Defaults to `true`.\n */\n breakout?: boolean | ResponsiveProp<boolean>\n\n /**\n * Define if the section should have rounded corners. Defaults to `false`.\n */\n roundedCorner?: boolean | ResponsiveProp<boolean>\n\n /**\n * Define a custom border color. Use a Eufemia color.\n */\n outline?: OutlineColor | ResponsiveProp<OutlineColor>\n\n /**\n * Define a custom text color to compliment the backgroundColor. Use a Eufemia color.\n */\n textColor?: TextColor | ResponsiveProp<TextColor>\n\n /**\n * Define a custom background color, instead of a variant. Use a Eufemia color.\n */\n backgroundColor?: BackgroundColor | ResponsiveProp<BackgroundColor>\n\n /**\n * Define a custom drop-shadow.\n */\n dropShadow?: DropShadow | ResponsiveProp<DropShadow>\n\n /**\n * Define what HTML element should be used. Defaults to `<section>`.\n */\n element?: DynamicElement\n\n /**\n * Define a React.Ref.\n */\n innerRef?: React.RefObject<HTMLElement>\n\n /**\n * @deprecated in v11 use \"innerSpace\" prop instead\n */\n spacing?: SectionSpacing | ResponsiveProp<SectionSpacing>\n /**\n * @deprecated in v11 use \"background\" prop instead\n */\n style_type?: SectionStyleTypes | string\n /**\n * @deprecated in v11 use \"innerRef\" prop instead\n */\n inner_ref?: React.RefObject<HTMLElement>\n}\n\nexport type SectionAllProps = SectionProps &\n SpacingProps &\n Omit<React.HTMLProps<HTMLElement>, 'ref'>\n\ntype SectionReturnParams = Record<string, unknown> & {\n className: string\n innerRef: React.RefObject<HTMLElement>\n children: React.ReactNode\n style: React.CSSProperties\n}\n\nconst defaultProps = {\n element: 'section',\n}\n\nexport default function Section(localProps: SectionAllProps) {\n return <Space {...SectionParams(localProps)} />\n}\n\nexport function SectionParams(\n localProps: SectionAllProps\n): SectionReturnParams {\n const context = React.useContext(Context)\n\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContext(\n localProps,\n defaultProps,\n context.Section\n )\n\n const {\n variant,\n breakout = true,\n roundedCorner,\n textColor,\n backgroundColor,\n dropShadow,\n outline,\n innerRef,\n\n className,\n children,\n\n spacing,\n style_type,\n inner_ref,\n\n ...attributes\n } = props\n\n const internalRef = React.useRef<HTMLElement>()\n const elementRef = innerRef || inner_ref || internalRef\n\n return Object.freeze({\n ...attributes,\n className: classnames(\n 'dnb-section',\n `dnb-section--${variant ? variant : style_type || 'default'}`,\n spacing &&\n `dnb-section--spacing-${isTrue(spacing) ? 'large' : spacing}`,\n className\n ),\n style: {\n ...computeStyle(\n breakout,\n 'breakout',\n (value) => `var(--breakout--${value ? 'on' : 'off'})`\n ),\n ...computeStyle(\n roundedCorner,\n 'rounded-corner',\n (value) => value && 'var(--rounded-corner--value)'\n ),\n ...computeStyle(textColor, 'text-color', (value) => getColor(value)),\n ...computeStyle(backgroundColor, 'background-color', (value) =>\n getColor(value)\n ),\n ...computeStyle(\n dropShadow,\n 'drop-shadow',\n (value) => value && 'var(--shadow-default)'\n ),\n ...computeStyle(outline, 'outline-color', (value) =>\n String(value) === 'true'\n ? 'var(--outline-color--value)'\n : getColor(value)\n ),\n ...attributes?.style,\n } as React.CSSProperties,\n innerRef: elementRef,\n children,\n })\n}\n\nfunction getColor(value: string) {\n return value\n ? !/#|var/.test(value)\n ? `var(--color-${value})`\n : value\n : undefined\n}\n\nfunction computeStyle(\n property: ResponsiveProp<unknown> | boolean | string,\n name: string,\n valueCallback: (value: string) => string | undefined\n) {\n let media = property as ResponsiveProp<unknown>\n\n if (media !== null && typeof media !== 'object') {\n media = {\n small: property,\n medium: property,\n large: property,\n } as ResponsiveProp<unknown>\n }\n\n const result = {}\n\n for (const size in media as ResponsiveProp<unknown>) {\n if (typeof media?.[size] !== 'undefined') {\n const value = valueCallback(media?.[size])\n if (typeof value === 'string') {\n result[`--${name}--${size}`] = value\n }\n }\n }\n\n return result\n}\n\nSection._name = 'Section'\nSection._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -18,6 +18,7 @@
18
18
  --left: -100vw;
19
19
  --width: 100vw;
20
20
  --height: 100%;
21
+ --color-transparent: transparent;
21
22
  color: var(--text-color, black);
22
23
  border-radius: var(--rounded-corner, 0);
23
24
  }
@@ -1,4 +1,4 @@
1
- .dnb-section{--breakout--on:visible;--breakout--off:hidden;--rounded-corner--value:0.5rem;--outline:0 0 0 var(--outline-width,1px) var(--outline-color,transparent);--outline-none:0 0 0 0 transparent;--top:0;--left:-100vw;--width:100vw;--height:100%;border-radius:var(--rounded-corner,0);color:var(--text-color,#000);display:flow-root;position:relative}.dnb-section[style*="--background-color"]{background-color:var(--background-color,#fff)}.dnb-section:before{border-radius:var(--rounded-corner,0);box-shadow:var(--drop-shadow,var(--outline-none)),var(--outline,var(--outline-none));content:"";inset:0;position:absolute;z-index:-1}.dnb-section:after{--box-shadow:99vw 0 0 0 currentcolor,198vw 0 0 0 currentcolor,297vw 0 0 0 currentcolor,396vw 0 0 0 currentcolor;background-color:currentcolor;box-shadow:var(--box-shadow);color:var(--background-color,currentcolor);content:"";height:var(--height);left:var(--left);position:absolute;top:var(--top);visibility:var(--breakout,hidden);width:var(--width);z-index:-15}.dnb-section:not([style*="--breakout"]){--breakout:var(--breakout--on)}@media screen and (max-width:60em){.dnb-section{--breakout:var(--breakout--small,var(--breakout--fallback));--background-color--value:var(--background-color--small);--text-color--value:var(--text-color--small);--outline-color:var(--outline-color--small);--drop-shadow:var(--drop-shadow--small);--rounded-corner:var(
1
+ .dnb-section{--breakout--on:visible;--breakout--off:hidden;--rounded-corner--value:0.5rem;--outline:0 0 0 var(--outline-width,1px) var(--outline-color,transparent);--outline-none:0 0 0 0 transparent;--top:0;--left:-100vw;--width:100vw;--height:100%;--color-transparent:transparent;border-radius:var(--rounded-corner,0);color:var(--text-color,#000);display:flow-root;position:relative}.dnb-section[style*="--background-color"]{background-color:var(--background-color,#fff)}.dnb-section:before{border-radius:var(--rounded-corner,0);box-shadow:var(--drop-shadow,var(--outline-none)),var(--outline,var(--outline-none));content:"";inset:0;position:absolute;z-index:-1}.dnb-section:after{--box-shadow:99vw 0 0 0 currentcolor,198vw 0 0 0 currentcolor,297vw 0 0 0 currentcolor,396vw 0 0 0 currentcolor;background-color:currentcolor;box-shadow:var(--box-shadow);color:var(--background-color,currentcolor);content:"";height:var(--height);left:var(--left);position:absolute;top:var(--top);visibility:var(--breakout,hidden);width:var(--width);z-index:-15}.dnb-section:not([style*="--breakout"]){--breakout:var(--breakout--on)}@media screen and (max-width:60em){.dnb-section{--breakout:var(--breakout--small,var(--breakout--fallback));--background-color--value:var(--background-color--small);--text-color--value:var(--text-color--small);--outline-color:var(--outline-color--small);--drop-shadow:var(--drop-shadow--small);--rounded-corner:var(
2
2
  --rounded-corner--small,var(--rounded-corner--fallback)
3
3
  )}}@media screen and (max-width:59.9375em) and (min-width:40.0625em){.dnb-section{--breakout:var(--breakout--medium,var(--breakout--fallback));--background-color--value:var(--background-color--medium);--text-color--value:var(--text-color--medium);--outline-color:var(--outline-color--medium);--drop-shadow:var(--drop-shadow--medium);--rounded-corner:var(
4
4
  --rounded-corner--medium,var(--rounded-corner--fallback)
@@ -22,6 +22,7 @@
22
22
  --left: -100vw;
23
23
  --width: 100vw;
24
24
  --height: 100%;
25
+ --color-transparent: transparent;
25
26
 
26
27
  color: var(--text-color, black);
27
28
  border-radius: var(--rounded-corner, 0);
@@ -95,7 +95,11 @@ export const createSpacingClasses = (props, Element = null) => {
95
95
  const p = Object.isFrozen(props) ? _objectSpread({}, props) : props;
96
96
  if (typeof p.space !== 'undefined') {
97
97
  if (typeof p.space === 'string' || typeof p.space === 'number' || typeof p.space === 'boolean' && p.space) {
98
- p.top = p.right = p.bottom = p.left = p.space;
98
+ var _p$left, _p$bottom, _p$right, _p$top;
99
+ p.left = (_p$left = p.left) !== null && _p$left !== void 0 ? _p$left : p.space;
100
+ p.bottom = (_p$bottom = p.bottom) !== null && _p$bottom !== void 0 ? _p$bottom : p.space;
101
+ p.right = (_p$right = p.right) !== null && _p$right !== void 0 ? _p$right : p.space;
102
+ p.top = (_p$top = p.top) !== null && _p$top !== void 0 ? _p$top : p.space;
99
103
  }
100
104
  if (typeof p.space === 'object') {
101
105
  for (const i in p.space) {
@@ -1 +1 @@
1
- {"version":3,"file":"SpacingUtils.js","names":["warn","spacingDefaultProps","space","innerSpace","top","right","bottom","left","spacePatterns","small","medium","large","globalThis","CALC_CACHE","calc","types","hash","join","result","forEach","rawTypes","createTypeModifiers","type","push","length","createSpacingProperties","props","computeProperties","hasMediaSize","media","keys","Object","includes","hasSize","size","_space","value","transformToAll","key","isValidSpaceProp","cur","name","String","typeModifiers","sum","sumTypes","createSpacingClasses","Element","p","isFrozen","_objectSpread","i","entries","reduce","acc","direction","nearestTypes","findNearestTypes","map","isInline","translateSpace","test","replace","splitTypes","split","clean","t","filter","r","firstLetter","parseFloat","num","foundType","findType","found","findTypeAll","listOfSpacePatterns","find","k","v","multiply","res","near","reverse","nearNum","nearType","leftOver","foundMoreTypes","index","indexOf","propName","removeSpaceProps","restProps","_objectWithoutProperties","_excluded","elementName"],"sources":["../../../../src/components/space/SpacingUtils.ts"],"sourcesContent":["/**\n * Space helper\n *\n */\n\nimport { warn } from '../../shared/component-helper'\n\nimport type {\n SpaceType,\n SpacingUnknownProps,\n SpacingProps,\n SpaceTypesPositiveValuesType,\n SpaceTypesPositiveRemValuesType,\n SpaceStringTypes,\n SpaceTypeMedia,\n SpaceTypeAll,\n SpacingElementProps,\n} from './types'\n\ntype SpaceNumber = number\n\nexport const spacingDefaultProps: SpacingProps = {\n space: null,\n innerSpace: null,\n top: null,\n right: null,\n bottom: null,\n left: null,\n}\n// IMPORTANT: Keep the shorthand after the long type names\nexport const spacePatterns: Record<\n SpaceTypesPositiveValuesType,\n SpaceTypesPositiveRemValuesType\n> = {\n 'xx-small': 0.25,\n 'x-small': 0.5,\n small: 1,\n medium: 1.5,\n large: 2,\n 'x-large': 3,\n 'xx-large': 3.5,\n 'xx-large-x2': 7,\n}\n\n/**\n * Helper function to generate a calc(var(--spacing-large) + var(--spacing-small))\n *\n * @param types 'small', '16px', '1rem'\n * @returns e.g. calc(var(--spacing-large) + var(--spacing-small))\n */\nglobalThis.CALC_CACHE = {}\nexport const calc = (...types: Array<SpaceType>) => {\n const hash = types.join('|')\n if (globalThis.CALC_CACHE[hash]) {\n return globalThis.CALC_CACHE[hash]\n }\n\n const result: Array<string> = []\n\n types.forEach((rawTypes) => {\n createTypeModifiers(rawTypes as SpaceType).forEach((type) => {\n result.push(`var(--spacing-${type})`)\n })\n })\n\n return result.length\n ? (globalThis.CALC_CACHE[hash] = `calc(${result.join(' + ')})`)\n : null\n}\n\n/**\n * Creates a valid space CSS style out from given space types\n *\n * @param props\n * @returns { '--space-b-l': '2rem', '--space-t-l': '1rem' }\n */\nexport const createSpacingProperties = (\n props: SpacingProps\n): React.CSSProperties => {\n if (props?.innerSpace) {\n return computeProperties(props.innerSpace)\n }\n\n return {}\n}\n\nfunction hasMediaSize(media: SpaceTypeMedia) {\n const keys = Object.keys(media)\n return (\n keys.includes('small') ||\n keys.includes('medium') ||\n keys.includes('large')\n )\n}\n\nfunction hasSize(space: SpacingElementProps) {\n const keys = Object.keys(space)\n return (\n keys.includes('top') ||\n keys.includes('right') ||\n keys.includes('bottom') ||\n keys.includes('left')\n )\n}\n\nfunction computeProperties(space: SpaceTypeAll | SpaceTypeMedia) {\n if (!hasMediaSize(space as SpaceTypeMedia)) {\n space = {\n small: space,\n medium: space,\n large: space,\n } as SpaceTypeMedia\n }\n\n const result = {}\n\n for (const size in space as SpaceTypeMedia) {\n const value = space?.[size] as SpaceType | SpacingElementProps\n const props = transformToAll(value)\n\n for (const key in props as SpaceTypeMedia) {\n if (isValidSpaceProp(key)) {\n const cur = props[key]\n const name = `--space-${key[0]}-${size[0]}`\n\n if (String(cur) === '0' || String(cur) === 'false') {\n result[name] = '0'\n } else if (cur) {\n const typeModifiers = createTypeModifiers(cur as SpaceType)\n const sum = sumTypes(typeModifiers)\n result[name] = `${sum}rem`\n }\n }\n }\n }\n\n return result as React.CSSProperties\n}\n\nfunction transformToAll(value: SpaceType | SpacingElementProps) {\n let result = value\n\n if (!hasSize(value as SpacingElementProps)) {\n result = {\n top: value,\n right: value,\n bottom: value,\n left: value,\n } as SpacingElementProps\n }\n\n return result as SpacingElementProps\n}\n\n/**\n * Creates a valid space CSS class out from given space types\n *\n * @param props\n * @param Element to check if it should be handled as inline\n * @returns \"dnb-space__large dnb-space__small\"\n */\nexport const createSpacingClasses = (\n props:\n | SpacingProps\n /**\n * To support typical not defined props form components\n */\n | SpacingUnknownProps,\n Element = null\n) => {\n const p = Object.isFrozen(props) ? { ...props } : props\n\n if (typeof p.space !== 'undefined') {\n if (\n typeof p.space === 'string' ||\n typeof p.space === 'number' ||\n (typeof p.space === 'boolean' && p.space)\n ) {\n p.top = p.right = p.bottom = p.left = p.space\n }\n if (typeof p.space === 'object') {\n for (const i in p.space) {\n if (!p[i] && isValidSpaceProp(i)) {\n p[i] = p.space[i]\n }\n }\n }\n delete p.space\n }\n\n return Object.entries(p).reduce((acc, [direction, cur]) => {\n if (isValidSpaceProp(direction) && direction !== 'innerSpace') {\n if (String(cur) === '0' || String(cur) === 'false') {\n acc.push(`dnb-space__${direction}--zero`)\n } else if (cur) {\n const typeModifiers = createTypeModifiers(cur as SpaceType)\n\n // get the total sum\n const sum = sumTypes(typeModifiers)\n if (sum > 10) {\n warn(\n `Spacing of more than 10rem is not supported! You used ${sum} / (${typeModifiers.join(\n ','\n )})`\n )\n } else {\n // auto combine classes\n const nearestTypes = findNearestTypes(sum, true)\n\n acc = [\n ...acc,\n ...nearestTypes.map(\n (type) => `dnb-space__${direction}--${type}`\n ),\n ]\n }\n }\n } else if (direction === 'no_collapse') {\n acc.push('dnb-space--no-collapse')\n if (Element && isInline(Element)) {\n acc.push('dnb-space--inline')\n }\n }\n\n return acc\n }, [])\n}\n\n// @internal splits types by given string\nexport const translateSpace = (type: SpaceType) => {\n if (/-x2$/.test(String(type))) {\n return spacePatterns[String(type).replace(/-x2$/, '')] * 2\n }\n return spacePatterns[String(type)] || 0\n}\n\n// @internal Splits a string of: \"large x-small\" into an array of the same\nexport const splitTypes = (types: SpaceType | Array<SpaceType>) => {\n if (typeof types === 'string') {\n const test = (types as SpaceStringTypes).split(/ /g)\n return clean(test as Array<SpaceStringTypes>)\n } else if (typeof types === 'boolean') {\n return ['small' as SpaceTypesPositiveValuesType]\n } else if (typeof types === 'number') {\n return [types]\n }\n\n return clean(types) || null\n\n function clean(t: Array<SpaceType> | Array<SpaceStringTypes>) {\n return t?.filter((r) => r && String(r).length > 0)\n }\n}\n\n// @internal Sums e.g. \"large\" + \"x-small\" to be = 2.5rem\nexport const sumTypes = (types: SpaceType | Array<SpaceType>) =>\n splitTypes(types)\n .map((type) => translateSpace(type))\n .reduce((acc, cur) => {\n if (cur > 0) {\n acc += cur\n } else if (cur < 0) {\n acc -= cur\n }\n return acc\n }, 0)\n\n// @internal Returns an array with modifiers e.g. [\"large\", \"x-small\"]\nexport const createTypeModifiers = (\n types: SpaceType\n): Array<SpaceType> => {\n return (splitTypes(types) || []).reduce((acc, type) => {\n if (type) {\n const firstLetter = String(type)[0]\n if (parseFloat(firstLetter) > -1) {\n // can be \"2rem\" or \"32px\" - but we want only a number\n let num = parseFloat(String(type))\n\n // check if we got pixels\n if (num >= 8 && /[0-9]px/.test(String(type))) {\n num = num / 16\n }\n\n // check if the type exists in our extensions\n const foundType = findType(num)\n\n // get the type\n if (foundType) {\n type = foundType\n } else {\n findNearestTypes(num).forEach((type) => {\n if (type) {\n acc.push(type)\n }\n })\n }\n }\n\n if (!(parseFloat(String(type)) > 0)) {\n acc.push(type)\n }\n }\n return acc\n }, [])\n}\n\n// @internal Finds from \"2.0\" the equivalent type \"large\"\nexport const findType = (num: SpaceNumber): SpaceType => {\n const found = findTypeAll(num)\n\n // get the type\n if (found) {\n return found[0]\n }\n\n return null\n}\n\n// @internal Finds from \"2.0\" the equivalent type \"large\" and returns all results\nexport const findTypeAll = (\n num: SpaceNumber\n): Array<\n SpaceTypesPositiveValuesType | SpaceTypesPositiveRemValuesType\n> => {\n const listOfSpacePatterns = Object.entries(spacePatterns) as [\n SpaceTypesPositiveValuesType,\n SpaceTypesPositiveRemValuesType,\n ][]\n const found =\n listOfSpacePatterns.find(([k, v]) => k && v === num) || null\n return found\n}\n\n// @internal Finds from e.g. a value of \"2.5rem\" the nearest type = [\"large\", \"x-small\"]\nexport const findNearestTypes = (num: SpaceNumber, multiply = false) => {\n let res = []\n\n const near = Object.entries(spacePatterns)\n .reverse()\n .filter((k) => (multiply ? true : !k[0].includes('-x'))) // e.g. -x2\n .find(([k, v]) => k && num >= v)\n const nearNum = (near && near[1]) || num\n const types = findTypeAll(nearNum)\n\n if (types) {\n const nearType = types[0]\n res.push(nearType)\n const leftOver = num - parseFloat(String(types[1]))\n const foundMoreTypes = findNearestTypes(leftOver, multiply)\n\n // if the value already exists, then replace it with an x2\n foundMoreTypes.forEach((type) => {\n const index = res.indexOf(type)\n if (index !== -1) {\n res[index] = multiply ? `${type}-x2` : type\n }\n })\n\n res = [...res, ...foundMoreTypes]\n }\n\n return res\n}\n\n// @internal Checks if a space prop is a valid string like \"top\"\nexport const isValidSpaceProp = (propName: string) =>\n propName &&\n ['top', 'right', 'bottom', 'left', 'space', 'innerSpace'].includes(\n propName\n )\n\nexport const removeSpaceProps = <Props extends SpacingProps>(\n props: Props\n): Omit<Props, keyof SpacingProps> => {\n const { space, innerSpace, top, bottom, left, right, ...restProps } =\n props\n return restProps\n}\n\nexport const isInline = (elementName: string) => {\n switch (elementName) {\n case 'h1':\n case 'h2':\n case 'h3':\n case 'h4':\n case 'h5':\n case 'h6':\n case 'p':\n return true\n }\n\n return false\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"SpacingUtils.js","names":["warn","spacingDefaultProps","space","innerSpace","top","right","bottom","left","spacePatterns","small","medium","large","globalThis","CALC_CACHE","calc","types","hash","join","result","forEach","rawTypes","createTypeModifiers","type","push","length","createSpacingProperties","props","computeProperties","hasMediaSize","media","keys","Object","includes","hasSize","size","_space","value","transformToAll","key","isValidSpaceProp","cur","name","String","typeModifiers","sum","sumTypes","createSpacingClasses","Element","p","isFrozen","_objectSpread","_p$left","_p$bottom","_p$right","_p$top","i","entries","reduce","acc","direction","nearestTypes","findNearestTypes","map","isInline","translateSpace","test","replace","splitTypes","split","clean","t","filter","r","firstLetter","parseFloat","num","foundType","findType","found","findTypeAll","listOfSpacePatterns","find","k","v","multiply","res","near","reverse","nearNum","nearType","leftOver","foundMoreTypes","index","indexOf","propName","removeSpaceProps","restProps","_objectWithoutProperties","_excluded","elementName"],"sources":["../../../../src/components/space/SpacingUtils.ts"],"sourcesContent":["/**\n * Space helper\n *\n */\n\nimport { warn } from '../../shared/component-helper'\n\nimport type {\n SpaceType,\n SpacingUnknownProps,\n SpacingProps,\n SpaceTypesPositiveValuesType,\n SpaceTypesPositiveRemValuesType,\n SpaceStringTypes,\n SpaceTypeMedia,\n SpaceTypeAll,\n SpacingElementProps,\n} from './types'\n\ntype SpaceNumber = number\n\nexport const spacingDefaultProps: SpacingProps = {\n space: null,\n innerSpace: null,\n top: null,\n right: null,\n bottom: null,\n left: null,\n}\n// IMPORTANT: Keep the shorthand after the long type names\nexport const spacePatterns: Record<\n SpaceTypesPositiveValuesType,\n SpaceTypesPositiveRemValuesType\n> = {\n 'xx-small': 0.25,\n 'x-small': 0.5,\n small: 1,\n medium: 1.5,\n large: 2,\n 'x-large': 3,\n 'xx-large': 3.5,\n 'xx-large-x2': 7,\n}\n\n/**\n * Helper function to generate a calc(var(--spacing-large) + var(--spacing-small))\n *\n * @param types 'small', '16px', '1rem'\n * @returns e.g. calc(var(--spacing-large) + var(--spacing-small))\n */\nglobalThis.CALC_CACHE = {}\nexport const calc = (...types: Array<SpaceType>) => {\n const hash = types.join('|')\n if (globalThis.CALC_CACHE[hash]) {\n return globalThis.CALC_CACHE[hash]\n }\n\n const result: Array<string> = []\n\n types.forEach((rawTypes) => {\n createTypeModifiers(rawTypes as SpaceType).forEach((type) => {\n result.push(`var(--spacing-${type})`)\n })\n })\n\n return result.length\n ? (globalThis.CALC_CACHE[hash] = `calc(${result.join(' + ')})`)\n : null\n}\n\n/**\n * Creates a valid space CSS style out from given space types\n *\n * @param props\n * @returns { '--space-b-l': '2rem', '--space-t-l': '1rem' }\n */\nexport const createSpacingProperties = (\n props: SpacingProps\n): React.CSSProperties => {\n if (props?.innerSpace) {\n return computeProperties(props.innerSpace)\n }\n\n return {}\n}\n\nfunction hasMediaSize(media: SpaceTypeMedia) {\n const keys = Object.keys(media)\n return (\n keys.includes('small') ||\n keys.includes('medium') ||\n keys.includes('large')\n )\n}\n\nfunction hasSize(space: SpacingElementProps) {\n const keys = Object.keys(space)\n return (\n keys.includes('top') ||\n keys.includes('right') ||\n keys.includes('bottom') ||\n keys.includes('left')\n )\n}\n\nfunction computeProperties(space: SpaceTypeAll | SpaceTypeMedia) {\n if (!hasMediaSize(space as SpaceTypeMedia)) {\n space = {\n small: space,\n medium: space,\n large: space,\n } as SpaceTypeMedia\n }\n\n const result = {}\n\n for (const size in space as SpaceTypeMedia) {\n const value = space?.[size] as SpaceType | SpacingElementProps\n const props = transformToAll(value)\n\n for (const key in props as SpaceTypeMedia) {\n if (isValidSpaceProp(key)) {\n const cur = props[key]\n const name = `--space-${key[0]}-${size[0]}`\n\n if (String(cur) === '0' || String(cur) === 'false') {\n result[name] = '0'\n } else if (cur) {\n const typeModifiers = createTypeModifiers(cur as SpaceType)\n const sum = sumTypes(typeModifiers)\n result[name] = `${sum}rem`\n }\n }\n }\n }\n\n return result as React.CSSProperties\n}\n\nfunction transformToAll(value: SpaceType | SpacingElementProps) {\n let result = value\n\n if (!hasSize(value as SpacingElementProps)) {\n result = {\n top: value,\n right: value,\n bottom: value,\n left: value,\n } as SpacingElementProps\n }\n\n return result as SpacingElementProps\n}\n\n/**\n * Creates a valid space CSS class out from given space types\n *\n * @param props\n * @param Element to check if it should be handled as inline\n * @returns \"dnb-space__large dnb-space__small\"\n */\nexport const createSpacingClasses = (\n props:\n | SpacingProps\n /**\n * To support typical not defined props form components\n */\n | SpacingUnknownProps,\n Element = null\n) => {\n const p = Object.isFrozen(props) ? { ...props } : props\n\n if (typeof p.space !== 'undefined') {\n if (\n typeof p.space === 'string' ||\n typeof p.space === 'number' ||\n (typeof p.space === 'boolean' && p.space)\n ) {\n p.left = p.left ?? p.space\n p.bottom = p.bottom ?? p.space\n p.right = p.right ?? p.space\n p.top = p.top ?? p.space\n }\n if (typeof p.space === 'object') {\n for (const i in p.space) {\n if (!p[i] && isValidSpaceProp(i)) {\n p[i] = p.space[i]\n }\n }\n }\n delete p.space\n }\n\n return Object.entries(p).reduce((acc, [direction, cur]) => {\n if (isValidSpaceProp(direction) && direction !== 'innerSpace') {\n if (String(cur) === '0' || String(cur) === 'false') {\n acc.push(`dnb-space__${direction}--zero`)\n } else if (cur) {\n const typeModifiers = createTypeModifiers(cur as SpaceType)\n\n // get the total sum\n const sum = sumTypes(typeModifiers)\n if (sum > 10) {\n warn(\n `Spacing of more than 10rem is not supported! You used ${sum} / (${typeModifiers.join(\n ','\n )})`\n )\n } else {\n // auto combine classes\n const nearestTypes = findNearestTypes(sum, true)\n\n acc = [\n ...acc,\n ...nearestTypes.map(\n (type) => `dnb-space__${direction}--${type}`\n ),\n ]\n }\n }\n } else if (direction === 'no_collapse') {\n acc.push('dnb-space--no-collapse')\n if (Element && isInline(Element)) {\n acc.push('dnb-space--inline')\n }\n }\n\n return acc\n }, [])\n}\n\n// @internal splits types by given string\nexport const translateSpace = (type: SpaceType) => {\n if (/-x2$/.test(String(type))) {\n return spacePatterns[String(type).replace(/-x2$/, '')] * 2\n }\n return spacePatterns[String(type)] || 0\n}\n\n// @internal Splits a string of: \"large x-small\" into an array of the same\nexport const splitTypes = (types: SpaceType | Array<SpaceType>) => {\n if (typeof types === 'string') {\n const test = (types as SpaceStringTypes).split(/ /g)\n return clean(test as Array<SpaceStringTypes>)\n } else if (typeof types === 'boolean') {\n return ['small' as SpaceTypesPositiveValuesType]\n } else if (typeof types === 'number') {\n return [types]\n }\n\n return clean(types) || null\n\n function clean(t: Array<SpaceType> | Array<SpaceStringTypes>) {\n return t?.filter((r) => r && String(r).length > 0)\n }\n}\n\n// @internal Sums e.g. \"large\" + \"x-small\" to be = 2.5rem\nexport const sumTypes = (types: SpaceType | Array<SpaceType>) =>\n splitTypes(types)\n .map((type) => translateSpace(type))\n .reduce((acc, cur) => {\n if (cur > 0) {\n acc += cur\n } else if (cur < 0) {\n acc -= cur\n }\n return acc\n }, 0)\n\n// @internal Returns an array with modifiers e.g. [\"large\", \"x-small\"]\nexport const createTypeModifiers = (\n types: SpaceType\n): Array<SpaceType> => {\n return (splitTypes(types) || []).reduce((acc, type) => {\n if (type) {\n const firstLetter = String(type)[0]\n if (parseFloat(firstLetter) > -1) {\n // can be \"2rem\" or \"32px\" - but we want only a number\n let num = parseFloat(String(type))\n\n // check if we got pixels\n if (num >= 8 && /[0-9]px/.test(String(type))) {\n num = num / 16\n }\n\n // check if the type exists in our extensions\n const foundType = findType(num)\n\n // get the type\n if (foundType) {\n type = foundType\n } else {\n findNearestTypes(num).forEach((type) => {\n if (type) {\n acc.push(type)\n }\n })\n }\n }\n\n if (!(parseFloat(String(type)) > 0)) {\n acc.push(type)\n }\n }\n return acc\n }, [])\n}\n\n// @internal Finds from \"2.0\" the equivalent type \"large\"\nexport const findType = (num: SpaceNumber): SpaceType => {\n const found = findTypeAll(num)\n\n // get the type\n if (found) {\n return found[0]\n }\n\n return null\n}\n\n// @internal Finds from \"2.0\" the equivalent type \"large\" and returns all results\nexport const findTypeAll = (\n num: SpaceNumber\n): Array<\n SpaceTypesPositiveValuesType | SpaceTypesPositiveRemValuesType\n> => {\n const listOfSpacePatterns = Object.entries(spacePatterns) as [\n SpaceTypesPositiveValuesType,\n SpaceTypesPositiveRemValuesType,\n ][]\n const found =\n listOfSpacePatterns.find(([k, v]) => k && v === num) || null\n return found\n}\n\n// @internal Finds from e.g. a value of \"2.5rem\" the nearest type = [\"large\", \"x-small\"]\nexport const findNearestTypes = (num: SpaceNumber, multiply = false) => {\n let res = []\n\n const near = Object.entries(spacePatterns)\n .reverse()\n .filter((k) => (multiply ? true : !k[0].includes('-x'))) // e.g. -x2\n .find(([k, v]) => k && num >= v)\n const nearNum = (near && near[1]) || num\n const types = findTypeAll(nearNum)\n\n if (types) {\n const nearType = types[0]\n res.push(nearType)\n const leftOver = num - parseFloat(String(types[1]))\n const foundMoreTypes = findNearestTypes(leftOver, multiply)\n\n // if the value already exists, then replace it with an x2\n foundMoreTypes.forEach((type) => {\n const index = res.indexOf(type)\n if (index !== -1) {\n res[index] = multiply ? `${type}-x2` : type\n }\n })\n\n res = [...res, ...foundMoreTypes]\n }\n\n return res\n}\n\n// @internal Checks if a space prop is a valid string like \"top\"\nexport const isValidSpaceProp = (propName: string) =>\n propName &&\n ['top', 'right', 'bottom', 'left', 'space', 'innerSpace'].includes(\n propName\n )\n\nexport const removeSpaceProps = <Props extends SpacingProps>(\n props: Props\n): Omit<Props, keyof SpacingProps> => {\n const { space, innerSpace, top, bottom, left, right, ...restProps } =\n props\n return restProps\n}\n\nexport const isInline = (elementName: string) => {\n switch (elementName) {\n case 'h1':\n case 'h2':\n case 'h3':\n case 'h4':\n case 'h5':\n case 'h6':\n case 'p':\n return true\n }\n\n return false\n}\n"],"mappings":"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"}
@@ -8,10 +8,10 @@ const _excluded = ["status_state", "inactive", "disabled"],
8
8
  _excluded3 = ["children", "className", "status", "status_state", "inner_ref"];
9
9
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
10
10
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
11
- import React, { useContext, useEffect, useLayoutEffect, useRef, useState } from 'react';
11
+ import React, { useContext, useEffect, useRef, useState } from 'react';
12
12
  import classnames from 'classnames';
13
13
  import { makeUniqueId, dispatchCustomElementEvent } from '../../shared/component-helper';
14
- import HeightAnimationInstance from '../height-animation/HeightAnimationInstance';
14
+ import HeightAnimation from '../height-animation/HeightAnimation';
15
15
  import Button from '../button/Button';
16
16
  import Icon from '../icon/Icon';
17
17
  import { WarnIcon, InfoIcon, ErrorIcon } from '../form-status/FormStatus';
@@ -31,35 +31,17 @@ function StepIndicatorItem(_ref) {
31
31
  }, restOfProps);
32
32
  const context = useContext(StepIndicatorContext);
33
33
  const [previousStep, setPreviousStep] = useState(context.activeStep);
34
- const heightAnim = useRef(new HeightAnimationInstance({
35
- animate: (context === null || context === void 0 ? void 0 : context.no_animation) !== undefined ? context.no_animation : false
36
- })).current;
37
34
  const ref = useRef(null);
38
35
  const thisReference = {
39
36
  context,
40
37
  props,
41
38
  onClickHandler
42
39
  };
43
- useEffect(() => {
44
- heightAnim.setElement(ref.current);
45
- return () => {
46
- heightAnim.remove();
47
- };
48
- }, []);
49
40
  useEffect(() => {
50
41
  if (previousStep !== context.activeStep) {
51
42
  setPreviousStep(context.activeStep);
52
43
  }
53
- }, [context.activeStep]);
54
- useLayoutEffect(() => {
55
- const height = heightAnim.getHeight();
56
- if (previousStep !== context.activeStep && (props.currentItemNum === previousStep || props.currentItemNum === context.activeStep)) {
57
- const toHeight = heightAnim.getUnknownHeight();
58
- if (height !== toHeight) {
59
- heightAnim.adjustTo(height, toHeight);
60
- }
61
- }
62
- }, [previousStep, context.activeStep, heightAnim, props.currentItemNum]);
44
+ }, [context.activeStep, previousStep]);
63
45
  function onClickHandler({
64
46
  event,
65
47
  item,
@@ -204,7 +186,7 @@ export function StepItemButton(_ref2) {
204
186
  icon_size: "medium",
205
187
  icon_position: "right",
206
188
  inner_ref: inner_ref
207
- }, props), children);
189
+ }, props), React.createElement(HeightAnimation, null, children));
208
190
  }
209
191
  export function StepItemWrapper({
210
192
  children,
@@ -1 +1 @@
1
- {"version":3,"file":"StepIndicatorItem.js","names":["React","useContext","useEffect","useLayoutEffect","useRef","useState","classnames","makeUniqueId","dispatchCustomElementEvent","HeightAnimationInstance","Button","Icon","WarnIcon","InfoIcon","ErrorIcon","StepIndicatorContext","stepIndicatorDefaultProps","StepIndicatorItem","_ref","status_state","status_state_default","inactive","inactive_default","disabled","disabled_default","restOfProps","_objectWithoutProperties","_excluded","props","_objectSpread","context","previousStep","setPreviousStep","activeStep","heightAnim","animate","no_animation","undefined","current","ref","thisReference","onClickHandler","setElement","remove","height","getHeight","currentItemNum","toHeight","getUnknownHeight","adjustTo","event","item","params","current_step","currentStep","onClickItem","onClickGlobal","setActiveStep","onChangeState","mode","filterAttributes","countSteps","listOfReachedSteps","hide_numbers","on_item_render","sidebar_id","step_title","title","is_current","status","on_render","on_click","attributes","_excluded2","Object","keys","forEach","key","includes","hasPassedAndIsCurrent","isNavigatable","isInactive","isVisited","id","ariaLabel","replace","String","isCurrent","element","createElement","StepItemWrapper","number","callbackProps","StepItem","itemParams","buttonParams","icon","onClick","type","_extends","className","StepItemButton","inner_ref","_ref2","children","_excluded3","icons","info","error","warn","size","inherit_color","wrap","stretch","variant","icon_size","icon_position"],"sources":["../../../../src/components/step-indicator/StepIndicatorItem.tsx"],"sourcesContent":["/**\n * Web StepIndicator Component\n *\n */\n\nimport React, {\n HTMLProps,\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n useState,\n} from 'react'\n\nimport classnames from 'classnames'\nimport {\n makeUniqueId,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport HeightAnimationInstance from '../height-animation/HeightAnimationInstance'\nimport Button, { ButtonProps } from '../button/Button'\nimport Icon, { IconIcon } from '../icon/Icon'\nimport { WarnIcon, InfoIcon, ErrorIcon } from '../form-status/FormStatus'\nimport StepIndicatorContext from './StepIndicatorContext'\nimport { stepIndicatorDefaultProps } from './StepIndicatorProps'\nimport {\n StepIndicatorMouseEvent,\n StepIndicatorRenderCallback,\n} from './StepIndicator'\n\nexport type StepIndicatorStatusState = 'warn' | 'info' | 'error'\nexport type StepIndicatorItemProps = Omit<\n React.HTMLProps<HTMLElement>,\n 'title' | 'data'\n> & {\n title: string | React.ReactNode\n /**\n * If set to true, this item step will be set as the current current selected step. This can be used instead of `current_step` on the component itself.\n */\n is_current?: boolean\n /**\n * If set to true, this item step will be handled as an inactive step and will not be clickable.\n * Defaults to `false`\n */\n inactive?: boolean\n /**\n * If set to true, this item step will be visible as an disabled button and will not be clickable.\n * Defaults to false.\n */\n disabled?: boolean\n /**\n * Is used to set the status text.\n */\n status?: string | React.ReactNode\n /**\n * Used to set the status state to be either `info`, `error` or `warn`.\n * Defaults to `warn`.\n */\n status_state?: StepIndicatorStatusState\n /**\n * Callback function to manipulate or wrap the step item. Has to return a React Node. You receive an object `{ StepItem, element, attributes, props, context }`.\n */\n on_render?: ({\n StepItem,\n element,\n attributes,\n props,\n context,\n }: StepIndicatorRenderCallback) => React.ReactNode\n /**\n * Will be called once the user clicks on the current or another step. Will be emitted on every click. Returns an object `{ event, item, current_step }`.\n */\n on_click?: ({\n event,\n item,\n current_step,\n currentStep,\n }: StepIndicatorMouseEvent) => void\n currentItemNum: number\n}\n\nfunction StepIndicatorItem({\n status_state: status_state_default = 'warn',\n inactive: inactive_default = false,\n disabled: disabled_default = false,\n ...restOfProps\n}: StepIndicatorItemProps) {\n const props: StepIndicatorItemProps = {\n status_state: status_state_default,\n inactive: inactive_default,\n disabled: disabled_default,\n ...restOfProps,\n }\n\n const context = useContext(StepIndicatorContext)\n\n const [previousStep, setPreviousStep] = useState<number>(\n context.activeStep\n )\n\n const heightAnim = useRef(\n new HeightAnimationInstance({\n animate:\n context?.no_animation !== undefined ? context.no_animation : false,\n })\n ).current\n\n const ref = useRef(null)\n\n const thisReference = {\n context,\n props,\n onClickHandler,\n }\n\n // Mount and Dismount\n useEffect(() => {\n heightAnim.setElement(ref.current)\n\n return () => {\n heightAnim.remove()\n }\n }, [])\n\n // Effect used to keep track of previous activeStep from context\n useEffect(() => {\n if (previousStep !== context.activeStep) {\n setPreviousStep(context.activeStep)\n }\n }, [context.activeStep])\n\n useLayoutEffect(() => {\n const height = heightAnim.getHeight()\n\n if (\n previousStep !== context.activeStep &&\n (props.currentItemNum === previousStep ||\n props.currentItemNum === context.activeStep)\n ) {\n const toHeight = heightAnim.getUnknownHeight()\n if (height !== toHeight) {\n heightAnim.adjustTo(height, toHeight)\n }\n }\n }, [previousStep, context.activeStep, heightAnim, props.currentItemNum])\n\n function onClickHandler({ event, item, currentItemNum }) {\n const params = {\n event,\n item,\n current_step: currentItemNum,\n currentStep: currentItemNum,\n }\n\n const onClickItem = dispatchCustomElementEvent(\n thisReference,\n 'on_click',\n params\n )\n\n const onClickGlobal = dispatchCustomElementEvent(\n context,\n 'on_click',\n params\n )\n\n if (onClickItem === false || onClickGlobal === false) {\n return // stop here\n }\n\n if (context.activeStep !== currentItemNum) {\n context.setActiveStep(currentItemNum)\n if (typeof context.onChangeState === 'function') {\n context.onChangeState()\n }\n\n dispatchCustomElementEvent(context, 'on_change', params)\n }\n }\n\n const {\n mode,\n filterAttributes,\n activeStep,\n countSteps,\n listOfReachedSteps,\n hide_numbers,\n on_item_render,\n sidebar_id,\n step_title,\n } = context\n\n const {\n currentItemNum,\n\n title,\n is_current,\n inactive,\n disabled,\n status,\n status_state,\n\n on_render,\n on_click, // eslint-disable-line\n\n ...attributes\n } = props\n\n Object.keys(attributes).forEach((key) => {\n if (filterAttributes.includes(key)) {\n delete attributes[key]\n }\n })\n\n const hasPassedAndIsCurrent =\n mode === 'loose' ||\n currentItemNum <= activeStep ||\n listOfReachedSteps.includes(currentItemNum)\n\n const isNavigatable = mode === 'strict' || mode === 'loose'\n\n let isInactive =\n inactive || (mode === 'strict' && !hasPassedAndIsCurrent)\n\n const isVisited = currentItemNum < activeStep\n\n const id = `${sidebar_id || makeUniqueId()}-${currentItemNum}`\n const ariaLabel = step_title\n ?.replace('%step', String(currentItemNum + 1))\n .replace('%count', String(countSteps))\n\n const isCurrent = currentItemNum === activeStep\n\n let element = (\n <StepItemWrapper\n number={currentItemNum + 1}\n hide_numbers={hide_numbers}\n status={status}\n >\n {title}\n </StepItemWrapper>\n ) as React.ReactNode\n\n const callbackProps = {\n StepItem: StepItemWrapper,\n element,\n attributes,\n props,\n context,\n }\n\n if (typeof on_render === 'function') {\n element = on_render(callbackProps)\n } else if (typeof on_item_render === 'function') {\n element = on_item_render(callbackProps)\n }\n\n const itemParams = {} as HTMLProps<HTMLLIElement>\n const buttonParams = {\n icon: 'check',\n status,\n status_state,\n 'aria-describedby': id,\n } as StepItemButtonProps\n\n if (isCurrent) {\n itemParams['aria-current'] = 'step'\n }\n\n if (disabled) {\n buttonParams.disabled = true\n }\n\n if (isNavigatable && !isInactive) {\n buttonParams.onClick = ({ event }: never) =>\n onClickHandler({\n event,\n item: props,\n currentItemNum,\n })\n }\n\n if (!buttonParams.onClick) {\n buttonParams.element = 'span'\n buttonParams.type = ''\n buttonParams.on_click = undefined\n isInactive = true\n }\n\n return (\n <li\n {...itemParams}\n className={classnames(\n 'dnb-step-indicator__item',\n isCurrent && 'dnb-step-indicator__item--current',\n isInactive && 'dnb-step-indicator__item--inactive',\n isVisited && 'dnb-step-indicator__item--visited',\n itemParams.className\n )}\n >\n <StepItemButton {...buttonParams} inner_ref={ref}>\n {element}\n </StepItemButton>\n <span id={id} aria-hidden className=\"dnb-sr-only\">\n {ariaLabel}\n </span>\n </li>\n )\n}\n\nexport type StepItemButtonProps = Omit<ButtonProps, 'status_state'> & {\n status_state?: StepIndicatorStatusState\n}\n\nexport function StepItemButton({\n children,\n className,\n status,\n status_state,\n inner_ref,\n ...props\n}: StepItemButtonProps) {\n const icons: Record<StepIndicatorStatusState, IconIcon> = {\n info: InfoIcon,\n error: ErrorIcon,\n warn: WarnIcon,\n }\n\n if (status) {\n props.icon = (\n <Icon\n icon={icons[status_state] || icons.warn}\n className=\"dnb-button__icon\"\n size=\"medium\"\n inherit_color={false}\n />\n )\n }\n\n return (\n <Button\n className={classnames(\n className,\n status && 'dnb-step-indicator__button__status',\n status && `dnb-step-indicator__button__status--${status_state}`\n )}\n wrap\n stretch\n variant=\"secondary\"\n icon_size=\"medium\"\n icon_position=\"right\"\n inner_ref={inner_ref}\n {...props}\n >\n {children}\n </Button>\n )\n}\n\nexport type StepItemWrapperProps = React.HTMLProps<HTMLElement> & {\n children?: React.ReactNode\n number?: number\n /**\n * Define whether to show automatically counted numbers or not. Defaults to `false`.\n */\n hide_numbers?: boolean\n status?: string | React.ReactNode\n}\n\nexport function StepItemWrapper({\n children,\n number,\n hide_numbers = stepIndicatorDefaultProps.hide_numbers,\n status,\n}: StepItemWrapperProps) {\n return (\n <span className=\"dnb-step-indicator__item-content\">\n {!hide_numbers && (\n <span\n aria-hidden // because we provide the hidden aria-describedby\n className=\"dnb-step-indicator__item-content__number\"\n >\n {number}.\n </span>\n )}\n <span className=\"dnb-step-indicator__item-content__wrapper\">\n <span className=\"dnb-step-indicator__item-content__text\">\n {children}\n </span>\n {status && (\n <span className=\"dnb-step-indicator__item-content__status\">\n {status}\n </span>\n )}\n </span>\n </span>\n )\n}\n\nexport default StepIndicatorItem\n"],"mappings":"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"}
1
+ {"version":3,"file":"StepIndicatorItem.js","names":["React","useContext","useEffect","useRef","useState","classnames","makeUniqueId","dispatchCustomElementEvent","HeightAnimation","Button","Icon","WarnIcon","InfoIcon","ErrorIcon","StepIndicatorContext","stepIndicatorDefaultProps","StepIndicatorItem","_ref","status_state","status_state_default","inactive","inactive_default","disabled","disabled_default","restOfProps","_objectWithoutProperties","_excluded","props","_objectSpread","context","previousStep","setPreviousStep","activeStep","ref","thisReference","onClickHandler","event","item","currentItemNum","params","current_step","currentStep","onClickItem","onClickGlobal","setActiveStep","onChangeState","mode","filterAttributes","countSteps","listOfReachedSteps","hide_numbers","on_item_render","sidebar_id","step_title","title","is_current","status","on_render","on_click","attributes","_excluded2","Object","keys","forEach","key","includes","hasPassedAndIsCurrent","isNavigatable","isInactive","isVisited","id","ariaLabel","replace","String","isCurrent","element","createElement","StepItemWrapper","number","callbackProps","StepItem","itemParams","buttonParams","icon","onClick","type","undefined","_extends","className","StepItemButton","inner_ref","_ref2","children","_excluded3","icons","info","error","warn","size","inherit_color","wrap","stretch","variant","icon_size","icon_position"],"sources":["../../../../src/components/step-indicator/StepIndicatorItem.tsx"],"sourcesContent":["/**\n * Web StepIndicator Component\n *\n */\n\nimport React, {\n HTMLProps,\n useContext,\n useEffect,\n useRef,\n useState,\n} from 'react'\n\nimport classnames from 'classnames'\nimport {\n makeUniqueId,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport HeightAnimation from '../height-animation/HeightAnimation'\nimport Button, { ButtonProps } from '../button/Button'\nimport Icon, { IconIcon } from '../icon/Icon'\nimport { WarnIcon, InfoIcon, ErrorIcon } from '../form-status/FormStatus'\nimport StepIndicatorContext from './StepIndicatorContext'\nimport { stepIndicatorDefaultProps } from './StepIndicatorProps'\nimport {\n StepIndicatorMouseEvent,\n StepIndicatorRenderCallback,\n} from './StepIndicator'\n\nexport type StepIndicatorStatusState = 'warn' | 'info' | 'error'\nexport type StepIndicatorItemProps = Omit<\n React.HTMLProps<HTMLElement>,\n 'title' | 'data'\n> & {\n title: string | React.ReactNode\n /**\n * If set to true, this item step will be set as the current current selected step. This can be used instead of `current_step` on the component itself.\n */\n is_current?: boolean\n /**\n * If set to true, this item step will be handled as an inactive step and will not be clickable.\n * Defaults to `false`\n */\n inactive?: boolean\n /**\n * If set to true, this item step will be visible as an disabled button and will not be clickable.\n * Defaults to false.\n */\n disabled?: boolean\n /**\n * Is used to set the status text.\n */\n status?: string | React.ReactNode\n /**\n * Used to set the status state to be either `info`, `error` or `warn`.\n * Defaults to `warn`.\n */\n status_state?: StepIndicatorStatusState\n /**\n * Callback function to manipulate or wrap the step item. Has to return a React Node. You receive an object `{ StepItem, element, attributes, props, context }`.\n */\n on_render?: ({\n StepItem,\n element,\n attributes,\n props,\n context,\n }: StepIndicatorRenderCallback) => React.ReactNode\n /**\n * Will be called once the user clicks on the current or another step. Will be emitted on every click. Returns an object `{ event, item, current_step }`.\n */\n on_click?: ({\n event,\n item,\n current_step,\n currentStep,\n }: StepIndicatorMouseEvent) => void\n currentItemNum: number\n}\n\nfunction StepIndicatorItem({\n status_state: status_state_default = 'warn',\n inactive: inactive_default = false,\n disabled: disabled_default = false,\n ...restOfProps\n}: StepIndicatorItemProps) {\n const props: StepIndicatorItemProps = {\n status_state: status_state_default,\n inactive: inactive_default,\n disabled: disabled_default,\n ...restOfProps,\n }\n\n const context = useContext(StepIndicatorContext)\n\n const [previousStep, setPreviousStep] = useState<number>(\n context.activeStep\n )\n\n const ref = useRef(null)\n\n const thisReference = {\n context,\n props,\n onClickHandler,\n }\n\n // Effect used to keep track of previous activeStep from context\n useEffect(() => {\n if (previousStep !== context.activeStep) {\n setPreviousStep(context.activeStep)\n }\n }, [context.activeStep, previousStep])\n\n function onClickHandler({ event, item, currentItemNum }) {\n const params = {\n event,\n item,\n current_step: currentItemNum,\n currentStep: currentItemNum,\n }\n\n const onClickItem = dispatchCustomElementEvent(\n thisReference,\n 'on_click',\n params\n )\n\n const onClickGlobal = dispatchCustomElementEvent(\n context,\n 'on_click',\n params\n )\n\n if (onClickItem === false || onClickGlobal === false) {\n return // stop here\n }\n\n if (context.activeStep !== currentItemNum) {\n context.setActiveStep(currentItemNum)\n if (typeof context.onChangeState === 'function') {\n context.onChangeState()\n }\n\n dispatchCustomElementEvent(context, 'on_change', params)\n }\n }\n\n const {\n mode,\n filterAttributes,\n activeStep,\n countSteps,\n listOfReachedSteps,\n hide_numbers,\n on_item_render,\n sidebar_id,\n step_title,\n } = context\n\n const {\n currentItemNum,\n\n title,\n is_current, // eslint-disable-line\n inactive,\n disabled,\n status,\n status_state,\n\n on_render,\n on_click, // eslint-disable-line\n\n ...attributes\n } = props\n\n Object.keys(attributes).forEach((key) => {\n if (filterAttributes.includes(key)) {\n delete attributes[key]\n }\n })\n\n const hasPassedAndIsCurrent =\n mode === 'loose' ||\n currentItemNum <= activeStep ||\n listOfReachedSteps.includes(currentItemNum)\n\n const isNavigatable = mode === 'strict' || mode === 'loose'\n\n let isInactive =\n inactive || (mode === 'strict' && !hasPassedAndIsCurrent)\n\n const isVisited = currentItemNum < activeStep\n\n const id = `${sidebar_id || makeUniqueId()}-${currentItemNum}`\n const ariaLabel = step_title\n ?.replace('%step', String(currentItemNum + 1))\n .replace('%count', String(countSteps))\n\n const isCurrent = currentItemNum === activeStep\n\n let element = (\n <StepItemWrapper\n number={currentItemNum + 1}\n hide_numbers={hide_numbers}\n status={status}\n >\n {title}\n </StepItemWrapper>\n ) as React.ReactNode\n\n const callbackProps = {\n StepItem: StepItemWrapper,\n element,\n attributes,\n props,\n context,\n }\n\n if (typeof on_render === 'function') {\n element = on_render(callbackProps)\n } else if (typeof on_item_render === 'function') {\n element = on_item_render(callbackProps)\n }\n\n const itemParams = {} as HTMLProps<HTMLLIElement>\n const buttonParams = {\n icon: 'check',\n status,\n status_state,\n 'aria-describedby': id,\n } as StepItemButtonProps\n\n if (isCurrent) {\n itemParams['aria-current'] = 'step'\n }\n\n if (disabled) {\n buttonParams.disabled = true\n }\n\n if (isNavigatable && !isInactive) {\n buttonParams.onClick = ({ event }: never) =>\n onClickHandler({\n event,\n item: props,\n currentItemNum,\n })\n }\n\n if (!buttonParams.onClick) {\n buttonParams.element = 'span'\n buttonParams.type = ''\n buttonParams.on_click = undefined\n isInactive = true\n }\n\n return (\n <li\n {...itemParams}\n className={classnames(\n 'dnb-step-indicator__item',\n isCurrent && 'dnb-step-indicator__item--current',\n isInactive && 'dnb-step-indicator__item--inactive',\n isVisited && 'dnb-step-indicator__item--visited',\n itemParams.className\n )}\n >\n <StepItemButton {...buttonParams} inner_ref={ref}>\n {element}\n </StepItemButton>\n <span id={id} aria-hidden className=\"dnb-sr-only\">\n {ariaLabel}\n </span>\n </li>\n )\n}\n\nexport type StepItemButtonProps = Omit<ButtonProps, 'status_state'> & {\n status_state?: StepIndicatorStatusState\n}\n\nexport function StepItemButton({\n children,\n className,\n status,\n status_state,\n inner_ref,\n ...props\n}: StepItemButtonProps) {\n const icons: Record<StepIndicatorStatusState, IconIcon> = {\n info: InfoIcon,\n error: ErrorIcon,\n warn: WarnIcon,\n }\n\n if (status) {\n props.icon = (\n <Icon\n icon={icons[status_state] || icons.warn}\n className=\"dnb-button__icon\"\n size=\"medium\"\n inherit_color={false}\n />\n )\n }\n\n return (\n <Button\n className={classnames(\n className,\n status && 'dnb-step-indicator__button__status',\n status && `dnb-step-indicator__button__status--${status_state}`\n )}\n wrap\n stretch\n variant=\"secondary\"\n icon_size=\"medium\"\n icon_position=\"right\"\n inner_ref={inner_ref}\n {...props}\n >\n <HeightAnimation>{children}</HeightAnimation>\n </Button>\n )\n}\n\nexport type StepItemWrapperProps = React.HTMLProps<HTMLElement> & {\n children?: React.ReactNode\n number?: number\n /**\n * Define whether to show automatically counted numbers or not. Defaults to `false`.\n */\n hide_numbers?: boolean\n status?: string | React.ReactNode\n}\n\nexport function StepItemWrapper({\n children,\n number,\n hide_numbers = stepIndicatorDefaultProps.hide_numbers,\n status,\n}: StepItemWrapperProps) {\n return (\n <span className=\"dnb-step-indicator__item-content\">\n {!hide_numbers && (\n <span\n aria-hidden // because we provide the hidden aria-describedby\n className=\"dnb-step-indicator__item-content__number\"\n >\n {number}.\n </span>\n )}\n <span className=\"dnb-step-indicator__item-content__wrapper\">\n <span className=\"dnb-step-indicator__item-content__text\">\n {children}\n </span>\n {status && (\n <span className=\"dnb-step-indicator__item-content__status\">\n {status}\n </span>\n )}\n </span>\n </span>\n )\n}\n\nexport default StepIndicatorItem\n"],"mappings":"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"}
@@ -7,11 +7,11 @@ const _excluded = ["data"];
7
7
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
8
8
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
9
9
  import classnames from 'classnames';
10
- import React, { useContext, useEffect, useLayoutEffect, useRef } from 'react';
10
+ import React, { useContext, useRef } from 'react';
11
11
  import Button from '../button/Button';
12
12
  import chevron_icon from '../../icons/chevron_right_medium';
13
13
  import { validateDOMAttributes, combineDescribedBy } from '../../shared/component-helper';
14
- import HeightAnimationInstance from '../height-animation/HeightAnimationInstance';
14
+ import HeightAnimation from '../height-animation/HeightAnimation';
15
15
  import { createSpacingClasses } from '../space/SpacingHelper';
16
16
  import FormLabel from '../form-label/FormLabel';
17
17
  import StepIndicatorContext from './StepIndicatorContext';
@@ -20,20 +20,6 @@ import { skeletonDOMAttributes, createSkeletonClass } from '../skeleton/Skeleton
20
20
  function StepIndicatorTriggerButton(props) {
21
21
  const context = useContext(StepIndicatorContext);
22
22
  const buttonRef = useRef((props === null || props === void 0 ? void 0 : props.inner_ref) || null);
23
- const heightAnim = useRef(new HeightAnimationInstance({
24
- animate: !(context !== null && context !== void 0 && context.no_animation)
25
- })).current;
26
- useEffect(() => {
27
- heightAnim.setElement(buttonRef.current);
28
- return () => {
29
- heightAnim.remove();
30
- };
31
- }, []);
32
- useLayoutEffect(() => {
33
- const height = heightAnim.getHeight();
34
- const toHeight = heightAnim.getUnknownHeight();
35
- heightAnim.adjustTo(height, toHeight);
36
- }, [context.activeStep, heightAnim]);
37
23
  const item = context.data[context.activeStep || 0];
38
24
  const label = context.stepsLabel;
39
25
  const {
@@ -74,7 +60,7 @@ function StepIndicatorTriggerButton(props) {
74
60
  }), React.createElement(StepItemWrapper, {
75
61
  number: (context.activeStep || 0) + 1,
76
62
  hide_numbers: context.hide_numbers
77
- }, (typeof item === 'string' ? item : item && item.title) || '')));
63
+ }, React.createElement(HeightAnimation, null, (typeof item === 'string' ? item : item && item.title) || ''))));
78
64
  }
79
65
  export default StepIndicatorTriggerButton;
80
66
  //# sourceMappingURL=StepIndicatorTriggerButton.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"StepIndicatorTriggerButton.js","names":["classnames","React","useContext","useEffect","useLayoutEffect","useRef","Button","chevron_icon","validateDOMAttributes","combineDescribedBy","HeightAnimationInstance","createSpacingClasses","FormLabel","StepIndicatorContext","StepItemWrapper","skeletonDOMAttributes","createSkeletonClass","StepIndicatorTriggerButton","props","context","buttonRef","inner_ref","heightAnim","animate","no_animation","current","setElement","remove","height","getHeight","toHeight","getUnknownHeight","adjustTo","activeStep","item","data","label","stepsLabel","contextWithoutData","_objectWithoutProperties","_excluded","triggerParams","_objectSpread","className","skeleton","buttonParams","sidebar_id","Object","keys","forEach","key","filterAttributes","includes","createElement","id","overview_title","for_id","_extends","wrap","stretch","variant","icon","icon_size","icon_position","number","hide_numbers","title"],"sources":["../../../../src/components/step-indicator/StepIndicatorTriggerButton.tsx"],"sourcesContent":["/**\n * Web StepIndicator Component\n *\n */\n\nimport classnames from 'classnames'\nimport React, {\n useContext,\n useEffect,\n useLayoutEffect,\n useRef,\n} from 'react'\nimport Button, { ButtonProps } from '../button/Button'\nimport chevron_icon from '../../icons/chevron_right_medium'\nimport {\n validateDOMAttributes,\n combineDescribedBy,\n} from '../../shared/component-helper'\nimport HeightAnimationInstance from '../height-animation/HeightAnimationInstance'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport FormLabel from '../form-label/FormLabel'\nimport StepIndicatorContext from './StepIndicatorContext'\nimport { StepItemWrapper } from './StepIndicatorItem'\nimport {\n skeletonDOMAttributes,\n createSkeletonClass,\n} from '../skeleton/SkeletonHelper'\n\nexport type StepIndicatorTriggerButtonProps = ButtonProps & {\n /**\n * <em>(required)</em> a unique string-based ID in order to bind together the main component and the sidebar (`<StepIndicator.Sidebar />`). Both have to get the same ID.\n */\n sidebar_id?: string\n className?: string\n inner_ref?: React.RefObject<HTMLElement>\n}\nfunction StepIndicatorTriggerButton(\n props: StepIndicatorTriggerButtonProps\n) {\n const context = useContext(StepIndicatorContext)\n\n const buttonRef = useRef(props?.inner_ref || null)\n\n const heightAnim = useRef(\n new HeightAnimationInstance({\n animate: !context?.no_animation,\n })\n ).current\n\n useEffect(() => {\n heightAnim.setElement(buttonRef.current)\n\n return () => {\n heightAnim.remove()\n }\n }, [])\n\n // Adjust height\n useLayoutEffect(() => {\n const height = heightAnim.getHeight()\n const toHeight = heightAnim.getUnknownHeight()\n\n heightAnim.adjustTo(height, toHeight)\n }, [context.activeStep, heightAnim])\n\n const item = context.data[context.activeStep || 0]\n const label = context.stepsLabel\n\n const { data, ...contextWithoutData } = context\n\n const triggerParams = {\n ...contextWithoutData,\n className: classnames(\n 'dnb-step-indicator__trigger',\n createSkeletonClass('font', context.skeleton),\n createSpacingClasses(context)\n ),\n 'aria-live': 'polite',\n } as React.HTMLProps<HTMLElement>\n\n const buttonParams = {\n ...props,\n className: classnames(\n 'dnb-step-indicator__trigger__button',\n props.className\n ),\n }\n\n buttonParams['aria-describedby'] = combineDescribedBy(\n buttonParams,\n context.sidebar_id + '-overview'\n )\n\n Object.keys(triggerParams).forEach((key) => {\n if (context.filterAttributes.includes(key)) {\n delete triggerParams[key]\n }\n })\n\n skeletonDOMAttributes(triggerParams, context.skeleton)\n\n // also used for code markup simulation\n validateDOMAttributes(context, triggerParams)\n\n return (\n <div {...(triggerParams as React.HTMLProps<HTMLDivElement>)}>\n <span className=\"dnb-sr-only\" id={context.sidebar_id + '-overview'}>\n {context.overview_title}\n </span>\n <FormLabel\n aria-describedby={context.sidebar_id}\n for_id={context.sidebar_id}\n className=\"dnb-step-indicator__label\"\n >\n {label}\n </FormLabel>\n <Button\n {...buttonParams}\n id={context.sidebar_id}\n wrap\n stretch\n variant=\"secondary\"\n icon={chevron_icon}\n icon_size=\"medium\"\n icon_position=\"right\"\n inner_ref={buttonRef}\n >\n <StepItemWrapper\n number={(context.activeStep || 0) + 1}\n hide_numbers={context.hide_numbers}\n >\n {(typeof item === 'string' ? item : item && item.title) || ''}\n </StepItemWrapper>\n </Button>\n </div>\n )\n}\n\nexport default StepIndicatorTriggerButton\n"],"mappings":"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"}
1
+ {"version":3,"file":"StepIndicatorTriggerButton.js","names":["classnames","React","useContext","useRef","Button","chevron_icon","validateDOMAttributes","combineDescribedBy","HeightAnimation","createSpacingClasses","FormLabel","StepIndicatorContext","StepItemWrapper","skeletonDOMAttributes","createSkeletonClass","StepIndicatorTriggerButton","props","context","buttonRef","inner_ref","item","data","activeStep","label","stepsLabel","contextWithoutData","_objectWithoutProperties","_excluded","triggerParams","_objectSpread","className","skeleton","buttonParams","sidebar_id","Object","keys","forEach","key","filterAttributes","includes","createElement","id","overview_title","for_id","_extends","wrap","stretch","variant","icon","icon_size","icon_position","number","hide_numbers","title"],"sources":["../../../../src/components/step-indicator/StepIndicatorTriggerButton.tsx"],"sourcesContent":["/**\n * Web StepIndicator Component\n *\n */\n\nimport classnames from 'classnames'\nimport React, { useContext, useRef } from 'react'\nimport Button, { ButtonProps } from '../button/Button'\nimport chevron_icon from '../../icons/chevron_right_medium'\nimport {\n validateDOMAttributes,\n combineDescribedBy,\n} from '../../shared/component-helper'\nimport HeightAnimation from '../height-animation/HeightAnimation'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport FormLabel from '../form-label/FormLabel'\nimport StepIndicatorContext from './StepIndicatorContext'\nimport { StepItemWrapper } from './StepIndicatorItem'\nimport {\n skeletonDOMAttributes,\n createSkeletonClass,\n} from '../skeleton/SkeletonHelper'\n\nexport type StepIndicatorTriggerButtonProps = ButtonProps & {\n /**\n * <em>(required)</em> a unique string-based ID in order to bind together the main component and the sidebar (`<StepIndicator.Sidebar />`). Both have to get the same ID.\n */\n sidebar_id?: string\n className?: string\n inner_ref?: React.RefObject<HTMLElement>\n}\nfunction StepIndicatorTriggerButton(\n props: StepIndicatorTriggerButtonProps\n) {\n const context = useContext(StepIndicatorContext)\n\n const buttonRef = useRef(props?.inner_ref || null)\n\n const item = context.data[context.activeStep || 0]\n const label = context.stepsLabel\n\n const { data, ...contextWithoutData } = context\n\n const triggerParams = {\n ...contextWithoutData,\n className: classnames(\n 'dnb-step-indicator__trigger',\n createSkeletonClass('font', context.skeleton),\n createSpacingClasses(context)\n ),\n 'aria-live': 'polite',\n } as React.HTMLProps<HTMLElement>\n\n const buttonParams = {\n ...props,\n className: classnames(\n 'dnb-step-indicator__trigger__button',\n props.className\n ),\n }\n\n buttonParams['aria-describedby'] = combineDescribedBy(\n buttonParams,\n context.sidebar_id + '-overview'\n )\n\n Object.keys(triggerParams).forEach((key) => {\n if (context.filterAttributes.includes(key)) {\n delete triggerParams[key]\n }\n })\n\n skeletonDOMAttributes(triggerParams, context.skeleton)\n\n // also used for code markup simulation\n validateDOMAttributes(context, triggerParams)\n\n return (\n <div {...(triggerParams as React.HTMLProps<HTMLDivElement>)}>\n <span className=\"dnb-sr-only\" id={context.sidebar_id + '-overview'}>\n {context.overview_title}\n </span>\n <FormLabel\n aria-describedby={context.sidebar_id}\n for_id={context.sidebar_id}\n className=\"dnb-step-indicator__label\"\n >\n {label}\n </FormLabel>\n <Button\n {...buttonParams}\n id={context.sidebar_id}\n wrap\n stretch\n variant=\"secondary\"\n icon={chevron_icon}\n icon_size=\"medium\"\n icon_position=\"right\"\n inner_ref={buttonRef}\n >\n <StepItemWrapper\n number={(context.activeStep || 0) + 1}\n hide_numbers={context.hide_numbers}\n >\n <HeightAnimation>\n {(typeof item === 'string' ? item : item && item.title) || ''}\n </HeightAnimation>\n </StepItemWrapper>\n </Button>\n </div>\n )\n}\n\nexport default StepIndicatorTriggerButton\n"],"mappings":"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"}
@@ -38,8 +38,6 @@
38
38
  overflow: hidden;
39
39
  justify-content: space-between;
40
40
  border-radius: 0.25rem;
41
- will-change: height;
42
- transition: height 400ms var(--easing-default);
43
41
  }
44
42
  .dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button .dnb-button__text, .dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button .dnb-button__text {
45
43
  text-align: left;
@@ -50,9 +48,6 @@
50
48
  .dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button .dnb-button__alignment, .dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button .dnb-button__alignment {
51
49
  order: 2;
52
50
  }
53
- html[data-visual-test] .dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button, html[data-visual-test] .dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button {
54
- transition-duration: 1ms !important;
55
- }
56
51
  .dnb-step-indicator-wrapper .dnb-step-indicator__trigger button.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button {
57
52
  margin-top: 0.5rem;
58
53
  }
@@ -1 +1 @@
1
- @media screen and (min-width:50.1em){.dnb-step-indicator__sidebar{margin-right:var(--spacing-x-large);max-width:20rem}.dnb-step-indicator__sidebar .dnb-step-indicator__item{min-width:320px}}@media screen and (max-width:50.1em){.dnb-step-indicator__sidebar--ssr-skeleton{height:5.5rem;overflow:hidden;visibility:hidden;width:0}}.dnb-step-indicator-wrapper .dnb-step-indicator__list{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}.dnb-step-indicator-wrapper .dnb-step-indicator__trigger{display:flex;flex-direction:column}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button{border-radius:.25rem;justify-content:space-between;overflow:hidden;transition:height .4s var(--easing-default);will-change:height}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button .dnb-button__text,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button .dnb-button__text{text-align:left}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button.dnb-button--has-icon .dnb-button__text,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button.dnb-button--has-icon .dnb-button__text{margin-right:1rem}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button .dnb-button__alignment,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button .dnb-button__alignment{order:2}html[data-visual-test] .dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button,html[data-visual-test] .dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button{transition-duration:1ms!important}.dnb-step-indicator-wrapper .dnb-step-indicator__trigger button.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button{margin-top:.5rem}.dnb-step-indicator-wrapper .dnb-step-indicator__item{margin-bottom:1rem}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button__icon{opacity:1;transition:opacity 1.4s ease-in-out}html[data-visual-test] .dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button__icon{transition-duration:1ms!important}.dnb-step-indicator-wrapper .dnb-step-indicator__item:not(.dnb-step-indicator__item--visited) .dnb-button:not(.dnb-step-indicator__button__status) .dnb-button__icon{opacity:0}.dnb-step-indicator-wrapper .dnb-step-indicator__item-content{display:flex;flex-wrap:nowrap;padding:.5rem 0}.dnb-step-indicator-wrapper .dnb-step-indicator__item-content__number{padding-right:.5rem;white-space:nowrap}.dnb-step-indicator-wrapper .dnb-step-indicator__item-content__wrapper{display:flex;flex-direction:column}.dnb-step-indicator-wrapper .dnb-step-indicator__button__status .dnb-step-indicator__item-content__status{color:var(--color-black-80);font-size:var(--font-size-x-small)}
1
+ @media screen and (min-width:50.1em){.dnb-step-indicator__sidebar{margin-right:var(--spacing-x-large);max-width:20rem}.dnb-step-indicator__sidebar .dnb-step-indicator__item{min-width:320px}}@media screen and (max-width:50.1em){.dnb-step-indicator__sidebar--ssr-skeleton{height:5.5rem;overflow:hidden;visibility:hidden;width:0}}.dnb-step-indicator-wrapper .dnb-step-indicator__list{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}.dnb-step-indicator-wrapper .dnb-step-indicator__trigger{display:flex;flex-direction:column}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button{border-radius:.25rem;justify-content:space-between;overflow:hidden}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button .dnb-button__text,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button .dnb-button__text{text-align:left}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button.dnb-button--has-icon .dnb-button__text,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button.dnb-button--has-icon .dnb-button__text{margin-right:1rem}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button .dnb-button__alignment,.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button .dnb-button__alignment{order:2}.dnb-step-indicator-wrapper .dnb-step-indicator__trigger button.dnb-step-indicator-wrapper .dnb-step-indicator__trigger__button{margin-top:.5rem}.dnb-step-indicator-wrapper .dnb-step-indicator__item{margin-bottom:1rem}.dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button__icon{opacity:1;transition:opacity 1.4s ease-in-out}html[data-visual-test] .dnb-step-indicator-wrapper .dnb-step-indicator__item .dnb-button__icon{transition-duration:1ms!important}.dnb-step-indicator-wrapper .dnb-step-indicator__item:not(.dnb-step-indicator__item--visited) .dnb-button:not(.dnb-step-indicator__button__status) .dnb-button__icon{opacity:0}.dnb-step-indicator-wrapper .dnb-step-indicator__item-content{display:flex;flex-wrap:nowrap;padding:.5rem 0}.dnb-step-indicator-wrapper .dnb-step-indicator__item-content__number{padding-right:.5rem;white-space:nowrap}.dnb-step-indicator-wrapper .dnb-step-indicator__item-content__wrapper{display:flex;flex-direction:column}.dnb-step-indicator-wrapper .dnb-step-indicator__button__status .dnb-step-indicator__item-content__status{color:var(--color-black-80);font-size:var(--font-size-x-small)}
@@ -62,13 +62,6 @@
62
62
 
63
63
  justify-content: space-between;
64
64
  border-radius: 0.25rem;
65
-
66
- will-change: height;
67
- transition: height 400ms var(--easing-default);
68
-
69
- html[data-visual-test] & {
70
- transition-duration: 1ms !important;
71
- }
72
65
  }
73
66
  &__trigger button#{&}__trigger__button {
74
67
  margin-top: 0.5rem;
@@ -118,7 +118,7 @@ export function useTableAccordion({
118
118
  }
119
119
  function toggleOpenTr(event) {
120
120
  const target = event.target;
121
- if (document.activeElement !== target && target.tagName !== 'INPUT' && !hasSelectedText()) {
121
+ if (document.activeElement !== target && target.tagName !== 'INPUT' && target.tagName !== 'LABEL' && !hasSelectedText()) {
122
122
  setOpen(!trIsOpen);
123
123
  setHadClick(true);
124
124
  onClick === null || onClick === void 0 ? void 0 : onClick(event);