@dnb/eufemia 10.21.0 → 10.23.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 (1269) hide show
  1. package/CHANGELOG.md +69 -0
  2. package/cjs/components/accordion/Accordion.js +1 -1
  3. package/cjs/components/accordion/Accordion.js.map +1 -1
  4. package/cjs/components/accordion/AccordionContext.d.ts +1 -1
  5. package/cjs/components/accordion/AccordionGroup.js +1 -1
  6. package/cjs/components/accordion/AccordionGroup.js.map +1 -1
  7. package/cjs/components/anchor/Anchor.d.ts +2 -3
  8. package/cjs/components/anchor/Anchor.js +14 -23
  9. package/cjs/components/anchor/Anchor.js.map +1 -1
  10. package/cjs/components/anchor/style/anchor-mixins.scss +16 -10
  11. package/cjs/components/anchor/style/dnb-anchor.css +6 -12
  12. package/cjs/components/anchor/style/dnb-anchor.min.css +1 -1
  13. package/cjs/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +8 -16
  14. package/cjs/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  15. package/cjs/components/anchor/style/themes/dnb-anchor-theme-sbanken.css +126 -78
  16. package/cjs/components/anchor/style/themes/dnb-anchor-theme-sbanken.min.css +1 -1
  17. package/cjs/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +55 -52
  18. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.css +8 -16
  19. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  20. package/cjs/components/aria-live/useAriaLive.d.ts +2 -2
  21. package/cjs/components/breadcrumb/Breadcrumb.d.ts +2 -2
  22. package/cjs/components/breadcrumb/Breadcrumb.js +28 -19
  23. package/cjs/components/breadcrumb/Breadcrumb.js.map +1 -1
  24. package/cjs/components/breadcrumb/BreadcrumbItem.d.ts +6 -4
  25. package/cjs/components/breadcrumb/BreadcrumbItem.js +17 -9
  26. package/cjs/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  27. package/cjs/components/breadcrumb/style/dnb-breadcrumb.css +36 -6
  28. package/cjs/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  29. package/cjs/components/breadcrumb/style/dnb-breadcrumb.scss +42 -6
  30. package/cjs/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.css +9 -0
  31. package/cjs/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.min.css +1 -1
  32. package/cjs/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.scss +7 -0
  33. package/cjs/components/button/Button.js +2 -2
  34. package/cjs/components/button/Button.js.map +1 -1
  35. package/cjs/components/button/style/button--tertiary.scss +30 -75
  36. package/cjs/components/button/style/dnb-button.css +43 -49
  37. package/cjs/components/button/style/dnb-button.min.css +1 -1
  38. package/cjs/components/button/style/dnb-button.scss +46 -59
  39. package/cjs/components/button/style/themes/button-mixins.scss +26 -5
  40. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.css +29 -60
  41. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.min.css +12 -2
  42. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.css +67 -83
  43. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.min.css +16 -4
  44. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.scss +44 -30
  45. package/cjs/components/button/style/themes/dnb-button-theme-ui.css +29 -60
  46. package/cjs/components/button/style/themes/dnb-button-theme-ui.min.css +12 -2
  47. package/cjs/components/button/style/themes/dnb-button-theme-ui.scss +1 -1
  48. package/cjs/components/card/Card.d.ts +15 -2
  49. package/cjs/components/card/Card.js +19 -7
  50. package/cjs/components/card/Card.js.map +1 -1
  51. package/cjs/components/card/CardDocs.d.ts +2 -0
  52. package/cjs/components/card/CardDocs.js +65 -0
  53. package/cjs/components/card/CardDocs.js.map +1 -0
  54. package/cjs/components/card/style/dnb-card.css +35 -7
  55. package/cjs/components/card/style/dnb-card.min.css +1 -1
  56. package/cjs/components/card/style/dnb-card.scss +47 -6
  57. package/cjs/components/checkbox/style/dnb-checkbox.css +3 -0
  58. package/cjs/components/checkbox/style/dnb-checkbox.min.css +1 -1
  59. package/cjs/components/checkbox/style/dnb-checkbox.scss +7 -0
  60. package/cjs/components/date-picker/DatePicker.d.ts +2 -0
  61. package/cjs/components/date-picker/DatePicker.js +2 -1
  62. package/cjs/components/date-picker/DatePicker.js.map +1 -1
  63. package/cjs/components/date-picker/DatePickerInput.js +19 -3
  64. package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
  65. package/cjs/components/date-picker/DatePickerProvider.js +8 -3
  66. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  67. package/cjs/components/dropdown/style/dnb-dropdown.css +3 -0
  68. package/cjs/components/dropdown/style/dnb-dropdown.min.css +1 -1
  69. package/cjs/components/dropdown/style/dnb-dropdown.scss +4 -0
  70. package/cjs/components/form-label/FormLabel.js +1 -1
  71. package/cjs/components/form-label/FormLabel.js.map +1 -1
  72. package/cjs/components/form-label/style/dnb-form-label.css +7 -1
  73. package/cjs/components/form-label/style/dnb-form-label.min.css +1 -1
  74. package/cjs/components/form-label/style/dnb-form-label.scss +9 -2
  75. package/cjs/components/form-label/style/themes/dnb-form-label-theme-sbanken.css +0 -3
  76. package/cjs/components/form-label/style/themes/dnb-form-label-theme-sbanken.min.css +1 -1
  77. package/cjs/components/form-label/style/themes/dnb-form-label-theme-sbanken.scss +0 -8
  78. package/cjs/components/form-label/style/themes/dnb-form-label-theme-ui.css +0 -6
  79. package/cjs/components/form-label/style/themes/dnb-form-label-theme-ui.min.css +1 -1
  80. package/cjs/components/form-label/style/themes/dnb-form-label-theme-ui.scss +0 -8
  81. package/cjs/components/global-status/GlobalStatus.d.ts +1 -1
  82. package/cjs/components/global-status/GlobalStatusProvider.d.ts +1 -1
  83. package/cjs/components/heading/HeadingContext.d.ts +1 -1
  84. package/cjs/components/height-animation/HeightAnimationInstance.d.ts +5 -6
  85. package/cjs/components/height-animation/HeightAnimationInstance.js +12 -12
  86. package/cjs/components/height-animation/HeightAnimationInstance.js.map +1 -1
  87. package/cjs/components/height-animation/style/dnb-height-animation.css +2 -2
  88. package/cjs/components/height-animation/style/dnb-height-animation.min.css +1 -1
  89. package/cjs/components/height-animation/style/dnb-height-animation.scss +3 -2
  90. package/cjs/components/height-animation/useHeightAnimation.js +11 -10
  91. package/cjs/components/height-animation/useHeightAnimation.js.map +1 -1
  92. package/cjs/components/input/Input.d.ts +1 -1
  93. package/cjs/components/number-format/NumberUtils.d.ts +1 -1
  94. package/cjs/components/pagination/InfinityScroller.d.ts +1 -1
  95. package/cjs/components/progress-indicator/ProgressIndicator.js +5 -7
  96. package/cjs/components/progress-indicator/ProgressIndicator.js.map +1 -1
  97. package/cjs/components/progress-indicator/ProgressIndicatorCircular.js +1 -1
  98. package/cjs/components/progress-indicator/ProgressIndicatorCircular.js.map +1 -1
  99. package/cjs/components/progress-indicator/ProgressIndicatorLinear.js +4 -4
  100. package/cjs/components/progress-indicator/ProgressIndicatorLinear.js.map +1 -1
  101. package/cjs/components/progress-indicator/style/dnb-progress-indicator.css +5 -2
  102. package/cjs/components/progress-indicator/style/dnb-progress-indicator.min.css +1 -1
  103. package/cjs/components/progress-indicator/style/dnb-progress-indicator.scss +5 -2
  104. package/cjs/components/radio/style/dnb-radio.css +4 -0
  105. package/cjs/components/radio/style/dnb-radio.min.css +1 -1
  106. package/cjs/components/radio/style/dnb-radio.scss +9 -0
  107. package/cjs/components/section/style/themes/dnb-section-theme-ui.css +3 -6
  108. package/cjs/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  109. package/cjs/components/skeleton/SkeletonHelper.d.ts +6 -6
  110. package/cjs/components/skeleton/style/dnb-skeleton.css +1 -0
  111. package/cjs/components/skeleton/style/dnb-skeleton.min.css +1 -1
  112. package/cjs/components/skeleton/style/dnb-skeleton.scss +1 -0
  113. package/cjs/components/slider/SliderInstance.js +1 -0
  114. package/cjs/components/slider/SliderInstance.js.map +1 -1
  115. package/cjs/components/slider/SliderThumb.js +4 -2
  116. package/cjs/components/slider/SliderThumb.js.map +1 -1
  117. package/cjs/components/space/SpacingHelper.d.ts +5 -5
  118. package/cjs/components/step-indicator/StepIndicator.js +11 -5
  119. package/cjs/components/step-indicator/StepIndicator.js.map +1 -1
  120. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.css +1 -1
  121. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.min.css +1 -1
  122. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.scss +1 -1
  123. package/cjs/components/table/Table.js +2 -2
  124. package/cjs/components/table/Table.js.map +1 -1
  125. package/cjs/components/table/TableAccordion.js +40 -57
  126. package/cjs/components/table/TableAccordion.js.map +1 -1
  127. package/cjs/components/table/TableAccordionTd.d.ts +9 -0
  128. package/cjs/components/table/{TableAccordionContent.js → TableAccordionTd.js} +16 -54
  129. package/cjs/components/table/TableAccordionTd.js.map +1 -0
  130. package/cjs/components/table/TableAccordionTr.d.ts +13 -0
  131. package/cjs/components/table/TableAccordionTr.js +61 -0
  132. package/cjs/components/table/TableAccordionTr.js.map +1 -0
  133. package/cjs/components/table/TableContext.d.ts +2 -2
  134. package/cjs/components/table/TableContext.js +4 -3
  135. package/cjs/components/table/TableContext.js.map +1 -1
  136. package/cjs/components/table/TableScrollView.d.ts +5 -1
  137. package/cjs/components/table/TableScrollView.js +1 -0
  138. package/cjs/components/table/TableScrollView.js.map +1 -1
  139. package/cjs/components/table/TableTd.d.ts +2 -2
  140. package/cjs/components/table/TableTd.js +2 -2
  141. package/cjs/components/table/TableTd.js.map +1 -1
  142. package/cjs/components/table/TableTr.d.ts +7 -3
  143. package/cjs/components/table/TableTr.js +10 -5
  144. package/cjs/components/table/TableTr.js.map +1 -1
  145. package/cjs/components/table/style/dnb-table.css +92 -65
  146. package/cjs/components/table/style/dnb-table.min.css +1 -1
  147. package/cjs/components/table/style/dnb-table.scss +8 -2
  148. package/cjs/components/table/style/table-accordion.scss +62 -44
  149. package/cjs/components/table/style/table-header-buttons.scss +4 -1
  150. package/cjs/components/table/style/table-td.scss +1 -1
  151. package/cjs/components/table/style/themes/dnb-table-theme-sbanken.css +10 -0
  152. package/cjs/components/table/style/themes/dnb-table-theme-sbanken.min.css +3 -1
  153. package/cjs/components/table/style/themes/dnb-table-theme-sbanken.scss +14 -0
  154. package/cjs/components/table/useTableAnimationHandler.d.ts +20 -0
  155. package/cjs/components/table/useTableAnimationHandler.js +73 -0
  156. package/cjs/components/table/useTableAnimationHandler.js.map +1 -0
  157. package/cjs/components/tag/Tag.d.ts +11 -0
  158. package/cjs/components/tag/Tag.js +55 -40
  159. package/cjs/components/tag/Tag.js.map +1 -1
  160. package/cjs/components/tag/style/dnb-tag.css +50 -86
  161. package/cjs/components/tag/style/dnb-tag.min.css +1 -1
  162. package/cjs/components/tag/style/dnb-tag.scss +37 -45
  163. package/cjs/components/tag/style/themes/tag-mixins.scss +24 -6
  164. package/cjs/components/tooltip/Tooltip.js +1 -1
  165. package/cjs/components/tooltip/Tooltip.js.map +1 -1
  166. package/cjs/elements/Element.d.ts +3 -4
  167. package/cjs/elements/Element.js.map +1 -1
  168. package/cjs/elements/blockquote/style/themes/dnb-blockquote-theme-sbanken.scss +1 -0
  169. package/cjs/elements/code/style/themes/dnb-code-theme-sbanken.scss +5 -3
  170. package/cjs/extensions/forms/DataContext/At/At.js.map +1 -1
  171. package/cjs/extensions/forms/DataContext/Context.d.ts +31 -10
  172. package/cjs/extensions/forms/DataContext/Context.js +14 -3
  173. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  174. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +29 -17
  175. package/cjs/extensions/forms/DataContext/Provider/Provider.js +325 -82
  176. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  177. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.d.ts +3 -0
  178. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +93 -0
  179. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -0
  180. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +1 -1
  181. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  182. package/cjs/extensions/forms/Field/Date/Date.js +3 -3
  183. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  184. package/cjs/extensions/forms/Field/Expiry/Expiry.js +4 -4
  185. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  186. package/cjs/extensions/forms/Field/Number/Number.js +3 -3
  187. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  188. package/cjs/extensions/forms/Field/Password/Password.d.ts +1 -1
  189. package/cjs/extensions/forms/Field/Password/Password.js.map +1 -1
  190. package/cjs/extensions/forms/Field/Password/style/dnb-password.scss +1 -1
  191. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +4 -4
  192. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  193. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  194. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  195. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +3 -3
  196. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  197. package/cjs/extensions/forms/Field/Selection/Selection.js +5 -5
  198. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  199. package/cjs/extensions/forms/Field/String/String.js +3 -3
  200. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  201. package/cjs/extensions/forms/Field/String/StringDocs.js +9 -4
  202. package/cjs/extensions/forms/Field/String/StringDocs.js.map +1 -1
  203. package/cjs/extensions/forms/Field/Toggle/Toggle.js +7 -7
  204. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  205. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +3 -1
  206. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +41 -19
  207. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  208. package/cjs/extensions/forms/FieldBlock/FieldBlockContext.d.ts +3 -4
  209. package/cjs/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
  210. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +2 -2
  211. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  212. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +2 -0
  213. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +6 -0
  214. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  215. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -2
  216. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  217. package/cjs/extensions/forms/Form/Handler/Handler.js +50 -8
  218. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  219. package/cjs/extensions/forms/Form/Handler/HandlerDocs.d.ts +3 -0
  220. package/cjs/extensions/forms/Form/Handler/HandlerDocs.js +49 -0
  221. package/cjs/extensions/forms/Form/Handler/HandlerDocs.js.map +1 -0
  222. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.d.ts +6 -1
  223. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.js +19 -10
  224. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  225. package/cjs/extensions/forms/Form/SubmitButton/SubmitButtonDocs.d.ts +2 -0
  226. package/cjs/extensions/forms/Form/SubmitButton/SubmitButtonDocs.js +30 -0
  227. package/cjs/extensions/forms/Form/SubmitButton/SubmitButtonDocs.js.map +1 -0
  228. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.d.ts +14 -0
  229. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +81 -0
  230. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -0
  231. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.d.ts +2 -0
  232. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.js +25 -0
  233. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.js.map +1 -0
  234. package/cjs/extensions/forms/Form/SubmitIndicator/index.d.ts +2 -0
  235. package/cjs/extensions/forms/Form/SubmitIndicator/index.js +27 -0
  236. package/cjs/extensions/forms/Form/SubmitIndicator/index.js.map +1 -0
  237. package/cjs/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.css +99 -0
  238. package/cjs/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.min.css +1 -0
  239. package/cjs/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.scss +117 -0
  240. package/cjs/extensions/forms/Form/SubmitIndicator/style/index.d.ts +5 -0
  241. package/cjs/extensions/forms/Form/SubmitIndicator/style/index.js +4 -0
  242. package/cjs/extensions/forms/Form/SubmitIndicator/style/index.js.map +1 -0
  243. package/cjs/extensions/forms/Form/data-context/getData.d.ts +1 -1
  244. package/cjs/extensions/forms/Form/data-context/getData.js.map +1 -1
  245. package/cjs/extensions/forms/Form/data-context/useData.d.ts +4 -4
  246. package/cjs/extensions/forms/Form/data-context/useData.js +33 -29
  247. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  248. package/cjs/extensions/forms/Form/data-context/useError.d.ts +4 -2
  249. package/cjs/extensions/forms/Form/data-context/useError.js +7 -2
  250. package/cjs/extensions/forms/Form/data-context/useError.js.map +1 -1
  251. package/cjs/extensions/forms/Form/index.d.ts +1 -0
  252. package/cjs/extensions/forms/Form/index.js +7 -0
  253. package/cjs/extensions/forms/Form/index.js.map +1 -1
  254. package/cjs/extensions/forms/Iterate/Array/Array.js +1 -1
  255. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  256. package/cjs/extensions/forms/Iterate/ArrayPushButton/ArrayPushButton.js +1 -1
  257. package/cjs/extensions/forms/Iterate/ArrayPushButton/ArrayPushButton.js.map +1 -1
  258. package/cjs/extensions/forms/Iterate/ArrayRemoveElementButton/ArrayRemoveElementButton.js +1 -1
  259. package/cjs/extensions/forms/Iterate/ArrayRemoveElementButton/ArrayRemoveElementButton.js.map +1 -1
  260. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.d.ts +1 -3
  261. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js +4 -3
  262. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  263. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.d.ts +1 -3
  264. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +6 -2
  265. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  266. package/cjs/extensions/forms/StepsLayout/StepsLayout.d.ts +2 -2
  267. package/cjs/extensions/forms/StepsLayout/StepsLayout.js +54 -25
  268. package/cjs/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  269. package/cjs/extensions/forms/StepsLayout/StepsLayoutDocs.d.ts +3 -0
  270. package/cjs/extensions/forms/StepsLayout/StepsLayoutDocs.js +58 -0
  271. package/cjs/extensions/forms/StepsLayout/StepsLayoutDocs.js.map +1 -0
  272. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -1
  273. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  274. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +11 -1
  275. package/cjs/extensions/forms/Value/Boolean/Boolean.js +1 -1
  276. package/cjs/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  277. package/cjs/extensions/forms/Value/Number/Number.d.ts +2 -2
  278. package/cjs/extensions/forms/Value/Number/Number.js +5 -5
  279. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  280. package/cjs/extensions/forms/Value/String/String.js +1 -1
  281. package/cjs/extensions/forms/Value/String/String.js.map +1 -1
  282. package/cjs/extensions/forms/hooks/DataValueDocs.js +3 -3
  283. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  284. package/cjs/extensions/forms/hooks/index.d.ts +6 -3
  285. package/cjs/extensions/forms/hooks/index.js +4 -12
  286. package/cjs/extensions/forms/hooks/index.js.map +1 -1
  287. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +23 -0
  288. package/cjs/extensions/forms/hooks/useFieldProps.js +774 -0
  289. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -0
  290. package/cjs/extensions/forms/style/dnb-forms.css +113 -3
  291. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  292. package/cjs/extensions/forms/types.d.ts +69 -4
  293. package/cjs/extensions/forms/types.js +3 -2
  294. package/cjs/extensions/forms/types.js.map +1 -1
  295. package/cjs/extensions/forms/utils/ajv.d.ts +9 -7
  296. package/cjs/extensions/forms/utils/ajv.js +29 -16
  297. package/cjs/extensions/forms/utils/ajv.js.map +1 -1
  298. package/cjs/extensions/payment-card/utils/CardDesigns.d.ts +96 -96
  299. package/cjs/fragments/drawer-list/DrawerListHelpers.d.ts +52 -52
  300. package/cjs/fragments/scroll-view/ScrollView.d.ts +2 -2
  301. package/cjs/fragments/scroll-view/ScrollView.js +4 -1
  302. package/cjs/fragments/scroll-view/ScrollView.js.map +1 -1
  303. package/cjs/shared/Context.d.ts +20 -11
  304. package/cjs/shared/Context.js.map +1 -1
  305. package/cjs/shared/Eufemia.d.ts +2 -2
  306. package/cjs/shared/Eufemia.js +2 -2
  307. package/cjs/shared/Eufemia.js.map +1 -1
  308. package/cjs/shared/Provider.js.map +1 -1
  309. package/cjs/shared/Theme.d.ts +7 -1
  310. package/cjs/shared/Theme.js +20 -7
  311. package/cjs/shared/Theme.js.map +1 -1
  312. package/cjs/shared/defaults.d.ts +3 -3
  313. package/cjs/shared/defaults.js.map +1 -1
  314. package/cjs/shared/helpers/debounce.d.ts +28 -0
  315. package/cjs/shared/helpers/debounce.js +104 -0
  316. package/cjs/shared/helpers/debounce.js.map +1 -0
  317. package/cjs/shared/helpers/isAsync.d.ts +7 -0
  318. package/cjs/shared/helpers/isAsync.js +20 -0
  319. package/cjs/shared/helpers/isAsync.js.map +1 -0
  320. package/cjs/shared/helpers/runCssVersionMismatchWarning.d.ts +8 -0
  321. package/cjs/shared/helpers/runCssVersionMismatchWarning.js +31 -0
  322. package/cjs/shared/helpers/runCssVersionMismatchWarning.js.map +1 -0
  323. package/cjs/{extensions/forms/hooks → shared/helpers}/useId.js +1 -1
  324. package/cjs/shared/helpers/useId.js.map +1 -0
  325. package/cjs/shared/helpers/useMountEffect.js.map +1 -0
  326. package/cjs/shared/helpers/useMounted.d.ts +2 -0
  327. package/cjs/shared/helpers/useMounted.js +19 -0
  328. package/cjs/shared/helpers/useMounted.js.map +1 -0
  329. package/cjs/shared/helpers/useSharedState.d.ts +1 -0
  330. package/cjs/shared/helpers/useSharedState.js +64 -26
  331. package/cjs/shared/helpers/useSharedState.js.map +1 -1
  332. package/cjs/shared/helpers/useUnmountEffect.js.map +1 -0
  333. package/cjs/shared/helpers/useUpdateEffect.js.map +1 -0
  334. package/cjs/shared/helpers/withCamelCaseProps.d.ts +7 -0
  335. package/cjs/shared/helpers/withCamelCaseProps.js.map +1 -1
  336. package/cjs/shared/helpers.d.ts +1 -25
  337. package/cjs/shared/helpers.js +17 -37
  338. package/cjs/shared/helpers.js.map +1 -1
  339. package/cjs/shared/index.d.ts +10 -10
  340. package/cjs/shared/index.js +7 -1
  341. package/cjs/shared/index.js.map +1 -1
  342. package/cjs/shared/locales/en-GB.d.ts +1 -0
  343. package/cjs/shared/locales/en-GB.js +2 -1
  344. package/cjs/shared/locales/en-GB.js.map +1 -1
  345. package/cjs/shared/locales/en-US.d.ts +1 -0
  346. package/cjs/shared/locales/index.d.ts +4 -2
  347. package/cjs/shared/locales/index.js +2 -1
  348. package/cjs/shared/locales/index.js.map +1 -1
  349. package/cjs/shared/locales/nb-NO.d.ts +1 -0
  350. package/cjs/shared/locales/nb-NO.js +2 -1
  351. package/cjs/shared/locales/nb-NO.js.map +1 -1
  352. package/cjs/shared/types.d.ts +4 -1
  353. package/cjs/shared/types.js.map +1 -1
  354. package/cjs/shared/useLocale.d.ts +2 -0
  355. package/cjs/shared/useLocale.js +37 -0
  356. package/cjs/shared/useLocale.js.map +1 -0
  357. package/cjs/shared/useTheme.d.ts +1 -0
  358. package/cjs/style/core/scopes.scss +3 -0
  359. package/cjs/style/dnb-ui-basis.css +1 -0
  360. package/cjs/style/dnb-ui-basis.min.css +1 -1
  361. package/cjs/style/dnb-ui-body.css +1 -0
  362. package/cjs/style/dnb-ui-body.min.css +1 -1
  363. package/cjs/style/dnb-ui-components.css +400 -233
  364. package/cjs/style/dnb-ui-components.min.css +3 -3
  365. package/cjs/style/dnb-ui-core.css +1 -0
  366. package/cjs/style/dnb-ui-core.min.css +1 -1
  367. package/cjs/style/dnb-ui-extensions.css +113 -3
  368. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  369. package/cjs/style/dnb-ui-forms.css +113 -3
  370. package/cjs/style/dnb-ui-forms.min.css +1 -1
  371. package/cjs/style/dnb-ui-forms.scss +1 -0
  372. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +3 -6
  373. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  374. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +554 -325
  375. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +16 -6
  376. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +3 -6
  377. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  378. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +113 -3
  379. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  380. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +113 -3
  381. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  382. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +6 -2
  383. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  384. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +726 -401
  385. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +22 -8
  386. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +6 -2
  387. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  388. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +113 -3
  389. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  390. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +113 -3
  391. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  392. package/cjs/style/themes/theme-ui/prism/dnb-prism-theme.d.ts +3 -3
  393. package/cjs/style/themes/theme-ui/ui-theme-basis.css +3 -6
  394. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  395. package/cjs/style/themes/theme-ui/ui-theme-components.css +554 -325
  396. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +16 -6
  397. package/cjs/style/themes/theme-ui/ui-theme-elements.css +3 -6
  398. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  399. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +113 -3
  400. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  401. package/cjs/style/themes/theme-ui/ui-theme-forms.css +113 -3
  402. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  403. package/cjs/style/themes/theme-ui/ui-theme-tags.css +3 -6
  404. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  405. package/components/accordion/Accordion.js +1 -1
  406. package/components/accordion/Accordion.js.map +1 -1
  407. package/components/accordion/AccordionContext.d.ts +1 -1
  408. package/components/accordion/AccordionGroup.js +1 -1
  409. package/components/accordion/AccordionGroup.js.map +1 -1
  410. package/components/anchor/Anchor.d.ts +2 -3
  411. package/components/anchor/Anchor.js +14 -23
  412. package/components/anchor/Anchor.js.map +1 -1
  413. package/components/anchor/style/anchor-mixins.scss +16 -10
  414. package/components/anchor/style/dnb-anchor.css +6 -12
  415. package/components/anchor/style/dnb-anchor.min.css +1 -1
  416. package/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +8 -16
  417. package/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  418. package/components/anchor/style/themes/dnb-anchor-theme-sbanken.css +126 -78
  419. package/components/anchor/style/themes/dnb-anchor-theme-sbanken.min.css +1 -1
  420. package/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +55 -52
  421. package/components/anchor/style/themes/dnb-anchor-theme-ui.css +8 -16
  422. package/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  423. package/components/aria-live/useAriaLive.d.ts +2 -2
  424. package/components/breadcrumb/Breadcrumb.d.ts +2 -2
  425. package/components/breadcrumb/Breadcrumb.js +29 -20
  426. package/components/breadcrumb/Breadcrumb.js.map +1 -1
  427. package/components/breadcrumb/BreadcrumbItem.d.ts +6 -4
  428. package/components/breadcrumb/BreadcrumbItem.js +18 -10
  429. package/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  430. package/components/breadcrumb/style/dnb-breadcrumb.css +36 -6
  431. package/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  432. package/components/breadcrumb/style/dnb-breadcrumb.scss +42 -6
  433. package/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.css +9 -0
  434. package/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.min.css +1 -1
  435. package/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.scss +7 -0
  436. package/components/button/Button.js +2 -2
  437. package/components/button/Button.js.map +1 -1
  438. package/components/button/style/button--tertiary.scss +30 -75
  439. package/components/button/style/dnb-button.css +43 -49
  440. package/components/button/style/dnb-button.min.css +1 -1
  441. package/components/button/style/dnb-button.scss +46 -59
  442. package/components/button/style/themes/button-mixins.scss +26 -5
  443. package/components/button/style/themes/dnb-button-theme-eiendom.css +29 -60
  444. package/components/button/style/themes/dnb-button-theme-eiendom.min.css +12 -2
  445. package/components/button/style/themes/dnb-button-theme-sbanken.css +67 -83
  446. package/components/button/style/themes/dnb-button-theme-sbanken.min.css +16 -4
  447. package/components/button/style/themes/dnb-button-theme-sbanken.scss +44 -30
  448. package/components/button/style/themes/dnb-button-theme-ui.css +29 -60
  449. package/components/button/style/themes/dnb-button-theme-ui.min.css +12 -2
  450. package/components/button/style/themes/dnb-button-theme-ui.scss +1 -1
  451. package/components/card/Card.d.ts +15 -2
  452. package/components/card/Card.js +19 -7
  453. package/components/card/Card.js.map +1 -1
  454. package/components/card/CardDocs.d.ts +2 -0
  455. package/components/card/CardDocs.js +58 -0
  456. package/components/card/CardDocs.js.map +1 -0
  457. package/components/card/style/dnb-card.css +35 -7
  458. package/components/card/style/dnb-card.min.css +1 -1
  459. package/components/card/style/dnb-card.scss +47 -6
  460. package/components/checkbox/style/dnb-checkbox.css +3 -0
  461. package/components/checkbox/style/dnb-checkbox.min.css +1 -1
  462. package/components/checkbox/style/dnb-checkbox.scss +7 -0
  463. package/components/date-picker/DatePicker.d.ts +2 -0
  464. package/components/date-picker/DatePicker.js +2 -1
  465. package/components/date-picker/DatePicker.js.map +1 -1
  466. package/components/date-picker/DatePickerInput.js +19 -3
  467. package/components/date-picker/DatePickerInput.js.map +1 -1
  468. package/components/date-picker/DatePickerProvider.js +8 -3
  469. package/components/date-picker/DatePickerProvider.js.map +1 -1
  470. package/components/dropdown/style/dnb-dropdown.css +3 -0
  471. package/components/dropdown/style/dnb-dropdown.min.css +1 -1
  472. package/components/dropdown/style/dnb-dropdown.scss +4 -0
  473. package/components/form-label/FormLabel.js +1 -1
  474. package/components/form-label/FormLabel.js.map +1 -1
  475. package/components/form-label/style/dnb-form-label.css +7 -1
  476. package/components/form-label/style/dnb-form-label.min.css +1 -1
  477. package/components/form-label/style/dnb-form-label.scss +9 -2
  478. package/components/form-label/style/themes/dnb-form-label-theme-sbanken.css +0 -3
  479. package/components/form-label/style/themes/dnb-form-label-theme-sbanken.min.css +1 -1
  480. package/components/form-label/style/themes/dnb-form-label-theme-sbanken.scss +0 -8
  481. package/components/form-label/style/themes/dnb-form-label-theme-ui.css +0 -6
  482. package/components/form-label/style/themes/dnb-form-label-theme-ui.min.css +1 -1
  483. package/components/form-label/style/themes/dnb-form-label-theme-ui.scss +0 -8
  484. package/components/global-status/GlobalStatus.d.ts +1 -1
  485. package/components/global-status/GlobalStatusProvider.d.ts +1 -1
  486. package/components/heading/HeadingContext.d.ts +1 -1
  487. package/components/height-animation/HeightAnimationInstance.d.ts +5 -6
  488. package/components/height-animation/HeightAnimationInstance.js +12 -12
  489. package/components/height-animation/HeightAnimationInstance.js.map +1 -1
  490. package/components/height-animation/style/dnb-height-animation.css +2 -2
  491. package/components/height-animation/style/dnb-height-animation.min.css +1 -1
  492. package/components/height-animation/style/dnb-height-animation.scss +3 -2
  493. package/components/height-animation/useHeightAnimation.js +11 -10
  494. package/components/height-animation/useHeightAnimation.js.map +1 -1
  495. package/components/input/Input.d.ts +1 -1
  496. package/components/number-format/NumberUtils.d.ts +1 -1
  497. package/components/pagination/InfinityScroller.d.ts +1 -1
  498. package/components/progress-indicator/ProgressIndicator.js +5 -7
  499. package/components/progress-indicator/ProgressIndicator.js.map +1 -1
  500. package/components/progress-indicator/ProgressIndicatorCircular.js +1 -1
  501. package/components/progress-indicator/ProgressIndicatorCircular.js.map +1 -1
  502. package/components/progress-indicator/ProgressIndicatorLinear.js +4 -4
  503. package/components/progress-indicator/ProgressIndicatorLinear.js.map +1 -1
  504. package/components/progress-indicator/style/dnb-progress-indicator.css +5 -2
  505. package/components/progress-indicator/style/dnb-progress-indicator.min.css +1 -1
  506. package/components/progress-indicator/style/dnb-progress-indicator.scss +5 -2
  507. package/components/radio/style/dnb-radio.css +4 -0
  508. package/components/radio/style/dnb-radio.min.css +1 -1
  509. package/components/radio/style/dnb-radio.scss +9 -0
  510. package/components/section/style/themes/dnb-section-theme-ui.css +3 -6
  511. package/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  512. package/components/skeleton/SkeletonHelper.d.ts +6 -6
  513. package/components/skeleton/style/dnb-skeleton.css +1 -0
  514. package/components/skeleton/style/dnb-skeleton.min.css +1 -1
  515. package/components/skeleton/style/dnb-skeleton.scss +1 -0
  516. package/components/slider/SliderInstance.js +1 -0
  517. package/components/slider/SliderInstance.js.map +1 -1
  518. package/components/slider/SliderThumb.js +4 -2
  519. package/components/slider/SliderThumb.js.map +1 -1
  520. package/components/space/SpacingHelper.d.ts +5 -5
  521. package/components/step-indicator/StepIndicator.js +11 -6
  522. package/components/step-indicator/StepIndicator.js.map +1 -1
  523. package/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.css +1 -1
  524. package/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.min.css +1 -1
  525. package/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.scss +1 -1
  526. package/components/table/Table.js +1 -1
  527. package/components/table/Table.js.map +1 -1
  528. package/components/table/TableAccordion.js +38 -53
  529. package/components/table/TableAccordion.js.map +1 -1
  530. package/components/table/TableAccordionTd.d.ts +9 -0
  531. package/{es/components/table/TableAccordionContent.js → components/table/TableAccordionTd.js} +14 -48
  532. package/components/table/TableAccordionTd.js.map +1 -0
  533. package/components/table/TableAccordionTr.d.ts +13 -0
  534. package/components/table/TableAccordionTr.js +51 -0
  535. package/components/table/TableAccordionTr.js.map +1 -0
  536. package/components/table/TableContext.d.ts +2 -2
  537. package/components/table/TableContext.js +2 -2
  538. package/components/table/TableContext.js.map +1 -1
  539. package/components/table/TableScrollView.d.ts +5 -1
  540. package/components/table/TableScrollView.js +1 -0
  541. package/components/table/TableScrollView.js.map +1 -1
  542. package/components/table/TableTd.d.ts +2 -2
  543. package/components/table/TableTd.js +2 -2
  544. package/components/table/TableTd.js.map +1 -1
  545. package/components/table/TableTr.d.ts +7 -3
  546. package/components/table/TableTr.js +9 -4
  547. package/components/table/TableTr.js.map +1 -1
  548. package/components/table/style/dnb-table.css +92 -65
  549. package/components/table/style/dnb-table.min.css +1 -1
  550. package/components/table/style/dnb-table.scss +8 -2
  551. package/components/table/style/table-accordion.scss +62 -44
  552. package/components/table/style/table-header-buttons.scss +4 -1
  553. package/components/table/style/table-td.scss +1 -1
  554. package/components/table/style/themes/dnb-table-theme-sbanken.css +10 -0
  555. package/components/table/style/themes/dnb-table-theme-sbanken.min.css +3 -1
  556. package/components/table/style/themes/dnb-table-theme-sbanken.scss +14 -0
  557. package/components/table/useTableAnimationHandler.d.ts +20 -0
  558. package/components/table/useTableAnimationHandler.js +63 -0
  559. package/components/table/useTableAnimationHandler.js.map +1 -0
  560. package/components/tag/Tag.d.ts +11 -0
  561. package/components/tag/Tag.js +54 -39
  562. package/components/tag/Tag.js.map +1 -1
  563. package/components/tag/style/dnb-tag.css +50 -86
  564. package/components/tag/style/dnb-tag.min.css +1 -1
  565. package/components/tag/style/dnb-tag.scss +37 -45
  566. package/components/tag/style/themes/tag-mixins.scss +24 -6
  567. package/components/tooltip/Tooltip.js +1 -1
  568. package/components/tooltip/Tooltip.js.map +1 -1
  569. package/elements/Element.d.ts +3 -4
  570. package/elements/Element.js.map +1 -1
  571. package/elements/blockquote/style/themes/dnb-blockquote-theme-sbanken.scss +1 -0
  572. package/elements/code/style/themes/dnb-code-theme-sbanken.scss +5 -3
  573. package/es/components/accordion/Accordion.js +1 -1
  574. package/es/components/accordion/Accordion.js.map +1 -1
  575. package/es/components/accordion/AccordionContext.d.ts +1 -1
  576. package/es/components/accordion/AccordionGroup.js +1 -1
  577. package/es/components/accordion/AccordionGroup.js.map +1 -1
  578. package/es/components/anchor/Anchor.d.ts +2 -3
  579. package/es/components/anchor/Anchor.js +14 -23
  580. package/es/components/anchor/Anchor.js.map +1 -1
  581. package/es/components/anchor/style/anchor-mixins.scss +16 -10
  582. package/es/components/anchor/style/dnb-anchor.css +6 -12
  583. package/es/components/anchor/style/dnb-anchor.min.css +1 -1
  584. package/es/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +8 -16
  585. package/es/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  586. package/es/components/anchor/style/themes/dnb-anchor-theme-sbanken.css +126 -78
  587. package/es/components/anchor/style/themes/dnb-anchor-theme-sbanken.min.css +1 -1
  588. package/es/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +55 -52
  589. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.css +8 -16
  590. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  591. package/es/components/aria-live/useAriaLive.d.ts +2 -2
  592. package/es/components/breadcrumb/Breadcrumb.d.ts +2 -2
  593. package/es/components/breadcrumb/Breadcrumb.js +29 -20
  594. package/es/components/breadcrumb/Breadcrumb.js.map +1 -1
  595. package/es/components/breadcrumb/BreadcrumbItem.d.ts +6 -4
  596. package/es/components/breadcrumb/BreadcrumbItem.js +18 -10
  597. package/es/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  598. package/es/components/breadcrumb/style/dnb-breadcrumb.css +36 -6
  599. package/es/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  600. package/es/components/breadcrumb/style/dnb-breadcrumb.scss +42 -6
  601. package/es/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.css +9 -0
  602. package/es/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.min.css +1 -1
  603. package/es/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.scss +7 -0
  604. package/es/components/button/Button.js +2 -2
  605. package/es/components/button/Button.js.map +1 -1
  606. package/es/components/button/style/button--tertiary.scss +30 -75
  607. package/es/components/button/style/dnb-button.css +43 -49
  608. package/es/components/button/style/dnb-button.min.css +1 -1
  609. package/es/components/button/style/dnb-button.scss +46 -59
  610. package/es/components/button/style/themes/button-mixins.scss +26 -5
  611. package/es/components/button/style/themes/dnb-button-theme-eiendom.css +29 -60
  612. package/es/components/button/style/themes/dnb-button-theme-eiendom.min.css +12 -2
  613. package/es/components/button/style/themes/dnb-button-theme-sbanken.css +67 -83
  614. package/es/components/button/style/themes/dnb-button-theme-sbanken.min.css +16 -4
  615. package/es/components/button/style/themes/dnb-button-theme-sbanken.scss +44 -30
  616. package/es/components/button/style/themes/dnb-button-theme-ui.css +29 -60
  617. package/es/components/button/style/themes/dnb-button-theme-ui.min.css +12 -2
  618. package/es/components/button/style/themes/dnb-button-theme-ui.scss +1 -1
  619. package/es/components/card/Card.d.ts +15 -2
  620. package/es/components/card/Card.js +19 -7
  621. package/es/components/card/Card.js.map +1 -1
  622. package/es/components/card/CardDocs.d.ts +2 -0
  623. package/es/components/card/CardDocs.js +58 -0
  624. package/es/components/card/CardDocs.js.map +1 -0
  625. package/es/components/card/style/dnb-card.css +35 -7
  626. package/es/components/card/style/dnb-card.min.css +1 -1
  627. package/es/components/card/style/dnb-card.scss +47 -6
  628. package/es/components/checkbox/style/dnb-checkbox.css +3 -0
  629. package/es/components/checkbox/style/dnb-checkbox.min.css +1 -1
  630. package/es/components/checkbox/style/dnb-checkbox.scss +7 -0
  631. package/es/components/date-picker/DatePicker.d.ts +2 -0
  632. package/es/components/date-picker/DatePicker.js +2 -1
  633. package/es/components/date-picker/DatePicker.js.map +1 -1
  634. package/es/components/date-picker/DatePickerInput.js +19 -3
  635. package/es/components/date-picker/DatePickerInput.js.map +1 -1
  636. package/es/components/date-picker/DatePickerProvider.js +8 -3
  637. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  638. package/es/components/dropdown/style/dnb-dropdown.css +3 -0
  639. package/es/components/dropdown/style/dnb-dropdown.min.css +1 -1
  640. package/es/components/dropdown/style/dnb-dropdown.scss +4 -0
  641. package/es/components/form-label/FormLabel.js +1 -1
  642. package/es/components/form-label/FormLabel.js.map +1 -1
  643. package/es/components/form-label/style/dnb-form-label.css +7 -1
  644. package/es/components/form-label/style/dnb-form-label.min.css +1 -1
  645. package/es/components/form-label/style/dnb-form-label.scss +9 -2
  646. package/es/components/form-label/style/themes/dnb-form-label-theme-sbanken.css +0 -3
  647. package/es/components/form-label/style/themes/dnb-form-label-theme-sbanken.min.css +1 -1
  648. package/es/components/form-label/style/themes/dnb-form-label-theme-sbanken.scss +0 -8
  649. package/es/components/form-label/style/themes/dnb-form-label-theme-ui.css +0 -6
  650. package/es/components/form-label/style/themes/dnb-form-label-theme-ui.min.css +1 -1
  651. package/es/components/form-label/style/themes/dnb-form-label-theme-ui.scss +0 -8
  652. package/es/components/global-status/GlobalStatus.d.ts +1 -1
  653. package/es/components/global-status/GlobalStatusProvider.d.ts +1 -1
  654. package/es/components/heading/HeadingContext.d.ts +1 -1
  655. package/es/components/height-animation/HeightAnimationInstance.d.ts +5 -6
  656. package/es/components/height-animation/HeightAnimationInstance.js +12 -12
  657. package/es/components/height-animation/HeightAnimationInstance.js.map +1 -1
  658. package/es/components/height-animation/style/dnb-height-animation.css +2 -2
  659. package/es/components/height-animation/style/dnb-height-animation.min.css +1 -1
  660. package/es/components/height-animation/style/dnb-height-animation.scss +3 -2
  661. package/es/components/height-animation/useHeightAnimation.js +11 -10
  662. package/es/components/height-animation/useHeightAnimation.js.map +1 -1
  663. package/es/components/input/Input.d.ts +1 -1
  664. package/es/components/number-format/NumberUtils.d.ts +1 -1
  665. package/es/components/pagination/InfinityScroller.d.ts +1 -1
  666. package/es/components/progress-indicator/ProgressIndicator.js +5 -7
  667. package/es/components/progress-indicator/ProgressIndicator.js.map +1 -1
  668. package/es/components/progress-indicator/ProgressIndicatorCircular.js +1 -1
  669. package/es/components/progress-indicator/ProgressIndicatorCircular.js.map +1 -1
  670. package/es/components/progress-indicator/ProgressIndicatorLinear.js +4 -4
  671. package/es/components/progress-indicator/ProgressIndicatorLinear.js.map +1 -1
  672. package/es/components/progress-indicator/style/dnb-progress-indicator.css +5 -2
  673. package/es/components/progress-indicator/style/dnb-progress-indicator.min.css +1 -1
  674. package/es/components/progress-indicator/style/dnb-progress-indicator.scss +5 -2
  675. package/es/components/radio/style/dnb-radio.css +4 -0
  676. package/es/components/radio/style/dnb-radio.min.css +1 -1
  677. package/es/components/radio/style/dnb-radio.scss +9 -0
  678. package/es/components/section/style/themes/dnb-section-theme-ui.css +3 -6
  679. package/es/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  680. package/es/components/skeleton/SkeletonHelper.d.ts +6 -6
  681. package/es/components/skeleton/style/dnb-skeleton.css +1 -0
  682. package/es/components/skeleton/style/dnb-skeleton.min.css +1 -1
  683. package/es/components/skeleton/style/dnb-skeleton.scss +1 -0
  684. package/es/components/slider/SliderInstance.js +1 -0
  685. package/es/components/slider/SliderInstance.js.map +1 -1
  686. package/es/components/slider/SliderThumb.js +4 -2
  687. package/es/components/slider/SliderThumb.js.map +1 -1
  688. package/es/components/space/SpacingHelper.d.ts +5 -5
  689. package/es/components/step-indicator/StepIndicator.js +11 -6
  690. package/es/components/step-indicator/StepIndicator.js.map +1 -1
  691. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.css +1 -1
  692. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.min.css +1 -1
  693. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-ui.scss +1 -1
  694. package/es/components/table/Table.js +1 -1
  695. package/es/components/table/Table.js.map +1 -1
  696. package/es/components/table/TableAccordion.js +38 -53
  697. package/es/components/table/TableAccordion.js.map +1 -1
  698. package/es/components/table/TableAccordionTd.d.ts +9 -0
  699. package/{components/table/TableAccordionContent.js → es/components/table/TableAccordionTd.js} +14 -49
  700. package/es/components/table/TableAccordionTd.js.map +1 -0
  701. package/es/components/table/TableAccordionTr.d.ts +13 -0
  702. package/es/components/table/TableAccordionTr.js +51 -0
  703. package/es/components/table/TableAccordionTr.js.map +1 -0
  704. package/es/components/table/TableContext.d.ts +2 -2
  705. package/es/components/table/TableContext.js +2 -2
  706. package/es/components/table/TableContext.js.map +1 -1
  707. package/es/components/table/TableScrollView.d.ts +5 -1
  708. package/es/components/table/TableScrollView.js +1 -0
  709. package/es/components/table/TableScrollView.js.map +1 -1
  710. package/es/components/table/TableTd.d.ts +2 -2
  711. package/es/components/table/TableTd.js +2 -2
  712. package/es/components/table/TableTd.js.map +1 -1
  713. package/es/components/table/TableTr.d.ts +7 -3
  714. package/es/components/table/TableTr.js +9 -4
  715. package/es/components/table/TableTr.js.map +1 -1
  716. package/es/components/table/style/dnb-table.css +92 -65
  717. package/es/components/table/style/dnb-table.min.css +1 -1
  718. package/es/components/table/style/dnb-table.scss +8 -2
  719. package/es/components/table/style/table-accordion.scss +62 -44
  720. package/es/components/table/style/table-header-buttons.scss +4 -1
  721. package/es/components/table/style/table-td.scss +1 -1
  722. package/es/components/table/style/themes/dnb-table-theme-sbanken.css +10 -0
  723. package/es/components/table/style/themes/dnb-table-theme-sbanken.min.css +3 -1
  724. package/es/components/table/style/themes/dnb-table-theme-sbanken.scss +14 -0
  725. package/es/components/table/useTableAnimationHandler.d.ts +20 -0
  726. package/es/components/table/useTableAnimationHandler.js +62 -0
  727. package/es/components/table/useTableAnimationHandler.js.map +1 -0
  728. package/es/components/tag/Tag.d.ts +11 -0
  729. package/es/components/tag/Tag.js +54 -39
  730. package/es/components/tag/Tag.js.map +1 -1
  731. package/es/components/tag/style/dnb-tag.css +50 -86
  732. package/es/components/tag/style/dnb-tag.min.css +1 -1
  733. package/es/components/tag/style/dnb-tag.scss +37 -45
  734. package/es/components/tag/style/themes/tag-mixins.scss +24 -6
  735. package/es/components/tooltip/Tooltip.js +1 -1
  736. package/es/components/tooltip/Tooltip.js.map +1 -1
  737. package/es/elements/Element.d.ts +3 -4
  738. package/es/elements/Element.js.map +1 -1
  739. package/es/elements/blockquote/style/themes/dnb-blockquote-theme-sbanken.scss +1 -0
  740. package/es/elements/code/style/themes/dnb-code-theme-sbanken.scss +5 -3
  741. package/es/extensions/forms/DataContext/At/At.js.map +1 -1
  742. package/es/extensions/forms/DataContext/Context.d.ts +31 -10
  743. package/es/extensions/forms/DataContext/Context.js +14 -3
  744. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  745. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +29 -17
  746. package/es/extensions/forms/DataContext/Provider/Provider.js +322 -80
  747. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  748. package/es/extensions/forms/DataContext/Provider/ProviderDocs.d.ts +3 -0
  749. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +85 -0
  750. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -0
  751. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +2 -2
  752. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  753. package/es/extensions/forms/Field/Date/Date.js +4 -4
  754. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  755. package/es/extensions/forms/Field/Expiry/Expiry.js +5 -5
  756. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  757. package/es/extensions/forms/Field/Number/Number.js +4 -4
  758. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  759. package/es/extensions/forms/Field/Password/Password.d.ts +1 -1
  760. package/es/extensions/forms/Field/Password/Password.js.map +1 -1
  761. package/es/extensions/forms/Field/Password/style/dnb-password.scss +1 -1
  762. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +5 -5
  763. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  764. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  765. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  766. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  767. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  768. package/es/extensions/forms/Field/Selection/Selection.js +6 -6
  769. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  770. package/es/extensions/forms/Field/String/String.js +4 -4
  771. package/es/extensions/forms/Field/String/String.js.map +1 -1
  772. package/es/extensions/forms/Field/String/StringDocs.js +9 -4
  773. package/es/extensions/forms/Field/String/StringDocs.js.map +1 -1
  774. package/es/extensions/forms/Field/Toggle/Toggle.js +8 -8
  775. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  776. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +3 -1
  777. package/es/extensions/forms/FieldBlock/FieldBlock.js +41 -20
  778. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  779. package/es/extensions/forms/FieldBlock/FieldBlockContext.d.ts +3 -4
  780. package/es/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
  781. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +2 -2
  782. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  783. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +2 -0
  784. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +6 -0
  785. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  786. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -2
  787. package/es/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  788. package/es/extensions/forms/Form/Handler/Handler.js +45 -9
  789. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  790. package/es/extensions/forms/Form/Handler/HandlerDocs.d.ts +3 -0
  791. package/es/extensions/forms/Form/Handler/HandlerDocs.js +39 -0
  792. package/es/extensions/forms/Form/Handler/HandlerDocs.js.map +1 -0
  793. package/es/extensions/forms/Form/SubmitButton/SubmitButton.d.ts +6 -1
  794. package/es/extensions/forms/Form/SubmitButton/SubmitButton.js +21 -12
  795. package/es/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  796. package/es/extensions/forms/Form/SubmitButton/SubmitButtonDocs.d.ts +2 -0
  797. package/es/extensions/forms/Form/SubmitButton/SubmitButtonDocs.js +23 -0
  798. package/es/extensions/forms/Form/SubmitButton/SubmitButtonDocs.js.map +1 -0
  799. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.d.ts +14 -0
  800. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +69 -0
  801. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -0
  802. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.d.ts +2 -0
  803. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.js +18 -0
  804. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.js.map +1 -0
  805. package/es/extensions/forms/Form/SubmitIndicator/index.d.ts +2 -0
  806. package/es/extensions/forms/Form/SubmitIndicator/index.js +3 -0
  807. package/es/extensions/forms/Form/SubmitIndicator/index.js.map +1 -0
  808. package/es/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.css +99 -0
  809. package/es/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.min.css +1 -0
  810. package/es/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.scss +117 -0
  811. package/es/extensions/forms/Form/SubmitIndicator/style/index.d.ts +5 -0
  812. package/es/extensions/forms/Form/SubmitIndicator/style/index.js +1 -0
  813. package/es/extensions/forms/Form/SubmitIndicator/style/index.js.map +1 -0
  814. package/es/extensions/forms/Form/data-context/getData.d.ts +1 -1
  815. package/es/extensions/forms/Form/data-context/getData.js.map +1 -1
  816. package/es/extensions/forms/Form/data-context/useData.d.ts +4 -4
  817. package/es/extensions/forms/Form/data-context/useData.js +31 -29
  818. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  819. package/es/extensions/forms/Form/data-context/useError.d.ts +4 -2
  820. package/es/extensions/forms/Form/data-context/useError.js +6 -3
  821. package/es/extensions/forms/Form/data-context/useError.js.map +1 -1
  822. package/es/extensions/forms/Form/index.d.ts +1 -0
  823. package/es/extensions/forms/Form/index.js +1 -0
  824. package/es/extensions/forms/Form/index.js.map +1 -1
  825. package/es/extensions/forms/Iterate/Array/Array.js +2 -2
  826. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  827. package/es/extensions/forms/Iterate/ArrayPushButton/ArrayPushButton.js +2 -2
  828. package/es/extensions/forms/Iterate/ArrayPushButton/ArrayPushButton.js.map +1 -1
  829. package/es/extensions/forms/Iterate/ArrayRemoveElementButton/ArrayRemoveElementButton.js +2 -2
  830. package/es/extensions/forms/Iterate/ArrayRemoveElementButton/ArrayRemoveElementButton.js.map +1 -1
  831. package/es/extensions/forms/StepsLayout/NextButton/NextButton.d.ts +1 -3
  832. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js +4 -3
  833. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  834. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.d.ts +1 -3
  835. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +6 -2
  836. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  837. package/es/extensions/forms/StepsLayout/StepsLayout.d.ts +2 -2
  838. package/es/extensions/forms/StepsLayout/StepsLayout.js +55 -26
  839. package/es/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  840. package/es/extensions/forms/StepsLayout/StepsLayoutDocs.d.ts +3 -0
  841. package/es/extensions/forms/StepsLayout/StepsLayoutDocs.js +50 -0
  842. package/es/extensions/forms/StepsLayout/StepsLayoutDocs.js.map +1 -0
  843. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -1
  844. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  845. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +11 -1
  846. package/es/extensions/forms/Value/Boolean/Boolean.js +2 -2
  847. package/es/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  848. package/es/extensions/forms/Value/Number/Number.d.ts +2 -2
  849. package/es/extensions/forms/Value/Number/Number.js +5 -5
  850. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  851. package/es/extensions/forms/Value/String/String.js +2 -2
  852. package/es/extensions/forms/Value/String/String.js.map +1 -1
  853. package/es/extensions/forms/hooks/DataValueDocs.js +3 -3
  854. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  855. package/es/extensions/forms/hooks/index.d.ts +6 -3
  856. package/es/extensions/forms/hooks/index.js +2 -3
  857. package/es/extensions/forms/hooks/index.js.map +1 -1
  858. package/es/extensions/forms/hooks/useFieldProps.d.ts +23 -0
  859. package/es/extensions/forms/hooks/useFieldProps.js +749 -0
  860. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -0
  861. package/es/extensions/forms/style/dnb-forms.css +113 -3
  862. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  863. package/es/extensions/forms/types.d.ts +69 -4
  864. package/es/extensions/forms/types.js +3 -2
  865. package/es/extensions/forms/types.js.map +1 -1
  866. package/es/extensions/forms/utils/ajv.d.ts +9 -7
  867. package/es/extensions/forms/utils/ajv.js +29 -14
  868. package/es/extensions/forms/utils/ajv.js.map +1 -1
  869. package/es/extensions/payment-card/utils/CardDesigns.d.ts +96 -96
  870. package/es/fragments/drawer-list/DrawerListHelpers.d.ts +52 -52
  871. package/es/fragments/scroll-view/ScrollView.d.ts +2 -2
  872. package/es/fragments/scroll-view/ScrollView.js +4 -1
  873. package/es/fragments/scroll-view/ScrollView.js.map +1 -1
  874. package/es/shared/Context.d.ts +20 -11
  875. package/es/shared/Context.js.map +1 -1
  876. package/es/shared/Eufemia.d.ts +2 -2
  877. package/es/shared/Eufemia.js +2 -2
  878. package/es/shared/Eufemia.js.map +1 -1
  879. package/es/shared/Provider.js.map +1 -1
  880. package/es/shared/Theme.d.ts +7 -1
  881. package/es/shared/Theme.js +20 -7
  882. package/es/shared/Theme.js.map +1 -1
  883. package/es/shared/defaults.d.ts +3 -3
  884. package/es/shared/defaults.js.map +1 -1
  885. package/es/shared/helpers/debounce.d.ts +28 -0
  886. package/es/shared/helpers/debounce.js +88 -0
  887. package/es/shared/helpers/debounce.js.map +1 -0
  888. package/es/shared/helpers/isAsync.d.ts +7 -0
  889. package/es/shared/helpers/isAsync.js +14 -0
  890. package/es/shared/helpers/isAsync.js.map +1 -0
  891. package/es/shared/helpers/runCssVersionMismatchWarning.d.ts +8 -0
  892. package/es/shared/helpers/runCssVersionMismatchWarning.js +25 -0
  893. package/es/shared/helpers/runCssVersionMismatchWarning.js.map +1 -0
  894. package/es/{extensions/forms/hooks → shared/helpers}/useId.js +1 -1
  895. package/es/shared/helpers/useId.js.map +1 -0
  896. package/es/shared/helpers/useMountEffect.js.map +1 -0
  897. package/es/shared/helpers/useMounted.d.ts +2 -0
  898. package/es/shared/helpers/useMounted.js +14 -0
  899. package/es/shared/helpers/useMounted.js.map +1 -0
  900. package/es/shared/helpers/useSharedState.d.ts +1 -0
  901. package/es/shared/helpers/useSharedState.js +61 -26
  902. package/es/shared/helpers/useSharedState.js.map +1 -1
  903. package/es/shared/helpers/useUnmountEffect.js.map +1 -0
  904. package/es/shared/helpers/useUpdateEffect.js.map +1 -0
  905. package/es/shared/helpers/withCamelCaseProps.d.ts +7 -0
  906. package/es/shared/helpers/withCamelCaseProps.js.map +1 -1
  907. package/es/shared/helpers.d.ts +1 -25
  908. package/es/shared/helpers.js +3 -29
  909. package/es/shared/helpers.js.map +1 -1
  910. package/es/shared/index.d.ts +10 -10
  911. package/es/shared/index.js +9 -11
  912. package/es/shared/index.js.map +1 -1
  913. package/es/shared/locales/en-GB.d.ts +1 -0
  914. package/es/shared/locales/en-GB.js +2 -1
  915. package/es/shared/locales/en-GB.js.map +1 -1
  916. package/es/shared/locales/en-US.d.ts +1 -0
  917. package/es/shared/locales/index.d.ts +4 -2
  918. package/es/shared/locales/index.js +2 -1
  919. package/es/shared/locales/index.js.map +1 -1
  920. package/es/shared/locales/nb-NO.d.ts +1 -0
  921. package/es/shared/locales/nb-NO.js +2 -1
  922. package/es/shared/locales/nb-NO.js.map +1 -1
  923. package/es/shared/types.d.ts +4 -1
  924. package/es/shared/types.js.map +1 -1
  925. package/es/shared/useLocale.d.ts +2 -0
  926. package/es/shared/useLocale.js +29 -0
  927. package/es/shared/useLocale.js.map +1 -0
  928. package/es/shared/useTheme.d.ts +1 -0
  929. package/es/style/core/scopes.scss +3 -0
  930. package/es/style/dnb-ui-basis.css +1 -0
  931. package/es/style/dnb-ui-basis.min.css +1 -1
  932. package/es/style/dnb-ui-body.css +1 -0
  933. package/es/style/dnb-ui-body.min.css +1 -1
  934. package/es/style/dnb-ui-components.css +400 -233
  935. package/es/style/dnb-ui-components.min.css +3 -3
  936. package/es/style/dnb-ui-core.css +1 -0
  937. package/es/style/dnb-ui-core.min.css +1 -1
  938. package/es/style/dnb-ui-extensions.css +113 -3
  939. package/es/style/dnb-ui-extensions.min.css +1 -1
  940. package/es/style/dnb-ui-forms.css +113 -3
  941. package/es/style/dnb-ui-forms.min.css +1 -1
  942. package/es/style/dnb-ui-forms.scss +1 -0
  943. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +3 -6
  944. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  945. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +554 -325
  946. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +16 -6
  947. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +3 -6
  948. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  949. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +113 -3
  950. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  951. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +113 -3
  952. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  953. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +6 -2
  954. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  955. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +726 -401
  956. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +22 -8
  957. package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +6 -2
  958. package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  959. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +113 -3
  960. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  961. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +113 -3
  962. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  963. package/es/style/themes/theme-ui/prism/dnb-prism-theme.d.ts +3 -3
  964. package/es/style/themes/theme-ui/ui-theme-basis.css +3 -6
  965. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  966. package/es/style/themes/theme-ui/ui-theme-components.css +554 -325
  967. package/es/style/themes/theme-ui/ui-theme-components.min.css +16 -6
  968. package/es/style/themes/theme-ui/ui-theme-elements.css +3 -6
  969. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  970. package/es/style/themes/theme-ui/ui-theme-extensions.css +113 -3
  971. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  972. package/es/style/themes/theme-ui/ui-theme-forms.css +113 -3
  973. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  974. package/es/style/themes/theme-ui/ui-theme-tags.css +3 -6
  975. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  976. package/esm/dnb-ui-basis.min.mjs +1 -1
  977. package/esm/dnb-ui-components.min.mjs +1 -1
  978. package/esm/dnb-ui-elements.min.mjs +1 -1
  979. package/esm/dnb-ui-extensions.min.mjs +3 -3
  980. package/esm/dnb-ui-lib.min.mjs +1 -1
  981. package/extensions/forms/DataContext/At/At.js.map +1 -1
  982. package/extensions/forms/DataContext/Context.d.ts +31 -10
  983. package/extensions/forms/DataContext/Context.js +14 -3
  984. package/extensions/forms/DataContext/Context.js.map +1 -1
  985. package/extensions/forms/DataContext/Provider/Provider.d.ts +29 -17
  986. package/extensions/forms/DataContext/Provider/Provider.js +326 -83
  987. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  988. package/extensions/forms/DataContext/Provider/ProviderDocs.d.ts +3 -0
  989. package/extensions/forms/DataContext/Provider/ProviderDocs.js +85 -0
  990. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -0
  991. package/extensions/forms/Field/ArraySelection/ArraySelection.js +2 -2
  992. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  993. package/extensions/forms/Field/Date/Date.js +4 -4
  994. package/extensions/forms/Field/Date/Date.js.map +1 -1
  995. package/extensions/forms/Field/Expiry/Expiry.js +5 -5
  996. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  997. package/extensions/forms/Field/Number/Number.js +4 -4
  998. package/extensions/forms/Field/Number/Number.js.map +1 -1
  999. package/extensions/forms/Field/Password/Password.d.ts +1 -1
  1000. package/extensions/forms/Field/Password/Password.js.map +1 -1
  1001. package/extensions/forms/Field/Password/style/dnb-password.scss +1 -1
  1002. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +5 -5
  1003. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  1004. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  1005. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  1006. package/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  1007. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  1008. package/extensions/forms/Field/Selection/Selection.js +6 -6
  1009. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  1010. package/extensions/forms/Field/String/String.js +4 -4
  1011. package/extensions/forms/Field/String/String.js.map +1 -1
  1012. package/extensions/forms/Field/String/StringDocs.js +9 -4
  1013. package/extensions/forms/Field/String/StringDocs.js.map +1 -1
  1014. package/extensions/forms/Field/Toggle/Toggle.js +8 -8
  1015. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  1016. package/extensions/forms/FieldBlock/FieldBlock.d.ts +3 -1
  1017. package/extensions/forms/FieldBlock/FieldBlock.js +42 -20
  1018. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  1019. package/extensions/forms/FieldBlock/FieldBlockContext.d.ts +3 -4
  1020. package/extensions/forms/FieldBlock/FieldBlockContext.js.map +1 -1
  1021. package/extensions/forms/FieldBlock/style/dnb-field-block.css +2 -2
  1022. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  1023. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +2 -0
  1024. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +6 -0
  1025. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  1026. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -2
  1027. package/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  1028. package/extensions/forms/Form/Handler/Handler.js +49 -9
  1029. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  1030. package/extensions/forms/Form/Handler/HandlerDocs.d.ts +3 -0
  1031. package/extensions/forms/Form/Handler/HandlerDocs.js +39 -0
  1032. package/extensions/forms/Form/Handler/HandlerDocs.js.map +1 -0
  1033. package/extensions/forms/Form/SubmitButton/SubmitButton.d.ts +6 -1
  1034. package/extensions/forms/Form/SubmitButton/SubmitButton.js +21 -12
  1035. package/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  1036. package/extensions/forms/Form/SubmitButton/SubmitButtonDocs.d.ts +2 -0
  1037. package/extensions/forms/Form/SubmitButton/SubmitButtonDocs.js +23 -0
  1038. package/extensions/forms/Form/SubmitButton/SubmitButtonDocs.js.map +1 -0
  1039. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.d.ts +14 -0
  1040. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +69 -0
  1041. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -0
  1042. package/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.d.ts +2 -0
  1043. package/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.js +18 -0
  1044. package/extensions/forms/Form/SubmitIndicator/SubmitIndicatorDocs.js.map +1 -0
  1045. package/extensions/forms/Form/SubmitIndicator/index.d.ts +2 -0
  1046. package/extensions/forms/Form/SubmitIndicator/index.js +3 -0
  1047. package/extensions/forms/Form/SubmitIndicator/index.js.map +1 -0
  1048. package/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.css +99 -0
  1049. package/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.min.css +1 -0
  1050. package/extensions/forms/Form/SubmitIndicator/style/dnb-form-submit-indicator.scss +117 -0
  1051. package/extensions/forms/Form/SubmitIndicator/style/index.d.ts +5 -0
  1052. package/extensions/forms/Form/SubmitIndicator/style/index.js +1 -0
  1053. package/extensions/forms/Form/SubmitIndicator/style/index.js.map +1 -0
  1054. package/extensions/forms/Form/data-context/getData.d.ts +1 -1
  1055. package/extensions/forms/Form/data-context/getData.js.map +1 -1
  1056. package/extensions/forms/Form/data-context/useData.d.ts +4 -4
  1057. package/extensions/forms/Form/data-context/useData.js +33 -29
  1058. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  1059. package/extensions/forms/Form/data-context/useError.d.ts +4 -2
  1060. package/extensions/forms/Form/data-context/useError.js +7 -3
  1061. package/extensions/forms/Form/data-context/useError.js.map +1 -1
  1062. package/extensions/forms/Form/index.d.ts +1 -0
  1063. package/extensions/forms/Form/index.js +1 -0
  1064. package/extensions/forms/Form/index.js.map +1 -1
  1065. package/extensions/forms/Iterate/Array/Array.js +2 -2
  1066. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  1067. package/extensions/forms/Iterate/ArrayPushButton/ArrayPushButton.js +2 -2
  1068. package/extensions/forms/Iterate/ArrayPushButton/ArrayPushButton.js.map +1 -1
  1069. package/extensions/forms/Iterate/ArrayRemoveElementButton/ArrayRemoveElementButton.js +2 -2
  1070. package/extensions/forms/Iterate/ArrayRemoveElementButton/ArrayRemoveElementButton.js.map +1 -1
  1071. package/extensions/forms/StepsLayout/NextButton/NextButton.d.ts +1 -3
  1072. package/extensions/forms/StepsLayout/NextButton/NextButton.js +4 -3
  1073. package/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  1074. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.d.ts +1 -3
  1075. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +6 -2
  1076. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  1077. package/extensions/forms/StepsLayout/StepsLayout.d.ts +2 -2
  1078. package/extensions/forms/StepsLayout/StepsLayout.js +55 -26
  1079. package/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  1080. package/extensions/forms/StepsLayout/StepsLayoutDocs.d.ts +3 -0
  1081. package/extensions/forms/StepsLayout/StepsLayoutDocs.js +50 -0
  1082. package/extensions/forms/StepsLayout/StepsLayoutDocs.js.map +1 -0
  1083. package/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -1
  1084. package/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  1085. package/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +11 -1
  1086. package/extensions/forms/Value/Boolean/Boolean.js +2 -2
  1087. package/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  1088. package/extensions/forms/Value/Number/Number.d.ts +2 -2
  1089. package/extensions/forms/Value/Number/Number.js +5 -5
  1090. package/extensions/forms/Value/Number/Number.js.map +1 -1
  1091. package/extensions/forms/Value/String/String.js +2 -2
  1092. package/extensions/forms/Value/String/String.js.map +1 -1
  1093. package/extensions/forms/hooks/DataValueDocs.js +3 -3
  1094. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  1095. package/extensions/forms/hooks/index.d.ts +6 -3
  1096. package/extensions/forms/hooks/index.js +2 -3
  1097. package/extensions/forms/hooks/index.js.map +1 -1
  1098. package/extensions/forms/hooks/useFieldProps.d.ts +23 -0
  1099. package/extensions/forms/hooks/useFieldProps.js +764 -0
  1100. package/extensions/forms/hooks/useFieldProps.js.map +1 -0
  1101. package/extensions/forms/style/dnb-forms.css +113 -3
  1102. package/extensions/forms/style/dnb-forms.min.css +1 -1
  1103. package/extensions/forms/types.d.ts +69 -4
  1104. package/extensions/forms/types.js +3 -2
  1105. package/extensions/forms/types.js.map +1 -1
  1106. package/extensions/forms/utils/ajv.d.ts +9 -7
  1107. package/extensions/forms/utils/ajv.js +29 -14
  1108. package/extensions/forms/utils/ajv.js.map +1 -1
  1109. package/extensions/payment-card/utils/CardDesigns.d.ts +96 -96
  1110. package/fragments/drawer-list/DrawerListHelpers.d.ts +52 -52
  1111. package/fragments/scroll-view/ScrollView.d.ts +2 -2
  1112. package/fragments/scroll-view/ScrollView.js +4 -1
  1113. package/fragments/scroll-view/ScrollView.js.map +1 -1
  1114. package/package.json +1 -1
  1115. package/shared/Context.d.ts +20 -11
  1116. package/shared/Context.js.map +1 -1
  1117. package/shared/Eufemia.d.ts +2 -2
  1118. package/shared/Eufemia.js +2 -2
  1119. package/shared/Eufemia.js.map +1 -1
  1120. package/shared/Provider.js.map +1 -1
  1121. package/shared/Theme.d.ts +7 -1
  1122. package/shared/Theme.js +20 -7
  1123. package/shared/Theme.js.map +1 -1
  1124. package/shared/defaults.d.ts +3 -3
  1125. package/shared/defaults.js.map +1 -1
  1126. package/shared/helpers/debounce.d.ts +28 -0
  1127. package/shared/helpers/debounce.js +95 -0
  1128. package/shared/helpers/debounce.js.map +1 -0
  1129. package/shared/helpers/isAsync.d.ts +7 -0
  1130. package/shared/helpers/isAsync.js +14 -0
  1131. package/shared/helpers/isAsync.js.map +1 -0
  1132. package/shared/helpers/runCssVersionMismatchWarning.d.ts +8 -0
  1133. package/shared/helpers/runCssVersionMismatchWarning.js +25 -0
  1134. package/shared/helpers/runCssVersionMismatchWarning.js.map +1 -0
  1135. package/{extensions/forms/hooks → shared/helpers}/useId.js +1 -1
  1136. package/shared/helpers/useId.js.map +1 -0
  1137. package/shared/helpers/useMountEffect.js.map +1 -0
  1138. package/shared/helpers/useMounted.d.ts +2 -0
  1139. package/shared/helpers/useMounted.js +14 -0
  1140. package/shared/helpers/useMounted.js.map +1 -0
  1141. package/shared/helpers/useSharedState.d.ts +1 -0
  1142. package/shared/helpers/useSharedState.js +61 -26
  1143. package/shared/helpers/useSharedState.js.map +1 -1
  1144. package/shared/helpers/useUnmountEffect.js.map +1 -0
  1145. package/shared/helpers/useUpdateEffect.js.map +1 -0
  1146. package/shared/helpers/withCamelCaseProps.d.ts +7 -0
  1147. package/shared/helpers/withCamelCaseProps.js.map +1 -1
  1148. package/shared/helpers.d.ts +1 -25
  1149. package/shared/helpers.js +5 -36
  1150. package/shared/helpers.js.map +1 -1
  1151. package/shared/index.d.ts +10 -10
  1152. package/shared/index.js +9 -11
  1153. package/shared/index.js.map +1 -1
  1154. package/shared/locales/en-GB.d.ts +1 -0
  1155. package/shared/locales/en-GB.js +2 -1
  1156. package/shared/locales/en-GB.js.map +1 -1
  1157. package/shared/locales/en-US.d.ts +1 -0
  1158. package/shared/locales/index.d.ts +4 -2
  1159. package/shared/locales/index.js +2 -1
  1160. package/shared/locales/index.js.map +1 -1
  1161. package/shared/locales/nb-NO.d.ts +1 -0
  1162. package/shared/locales/nb-NO.js +2 -1
  1163. package/shared/locales/nb-NO.js.map +1 -1
  1164. package/shared/types.d.ts +4 -1
  1165. package/shared/types.js.map +1 -1
  1166. package/shared/useLocale.d.ts +2 -0
  1167. package/shared/useLocale.js +29 -0
  1168. package/shared/useLocale.js.map +1 -0
  1169. package/shared/useTheme.d.ts +1 -0
  1170. package/style/core/scopes.scss +3 -0
  1171. package/style/dnb-ui-basis.css +1 -0
  1172. package/style/dnb-ui-basis.min.css +1 -1
  1173. package/style/dnb-ui-body.css +1 -0
  1174. package/style/dnb-ui-body.min.css +1 -1
  1175. package/style/dnb-ui-components.css +400 -233
  1176. package/style/dnb-ui-components.min.css +3 -3
  1177. package/style/dnb-ui-core.css +1 -0
  1178. package/style/dnb-ui-core.min.css +1 -1
  1179. package/style/dnb-ui-extensions.css +113 -3
  1180. package/style/dnb-ui-extensions.min.css +1 -1
  1181. package/style/dnb-ui-forms.css +113 -3
  1182. package/style/dnb-ui-forms.min.css +1 -1
  1183. package/style/dnb-ui-forms.scss +1 -0
  1184. package/style/themes/theme-eiendom/eiendom-theme-basis.css +3 -6
  1185. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  1186. package/style/themes/theme-eiendom/eiendom-theme-components.css +554 -325
  1187. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +16 -6
  1188. package/style/themes/theme-eiendom/eiendom-theme-elements.css +3 -6
  1189. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  1190. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +113 -3
  1191. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  1192. package/style/themes/theme-eiendom/eiendom-theme-forms.css +113 -3
  1193. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  1194. package/style/themes/theme-sbanken/sbanken-theme-basis.css +6 -2
  1195. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  1196. package/style/themes/theme-sbanken/sbanken-theme-components.css +726 -401
  1197. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +22 -8
  1198. package/style/themes/theme-sbanken/sbanken-theme-elements.css +6 -2
  1199. package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  1200. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +113 -3
  1201. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  1202. package/style/themes/theme-sbanken/sbanken-theme-forms.css +113 -3
  1203. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  1204. package/style/themes/theme-ui/prism/dnb-prism-theme.d.ts +3 -3
  1205. package/style/themes/theme-ui/ui-theme-basis.css +3 -6
  1206. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  1207. package/style/themes/theme-ui/ui-theme-components.css +554 -325
  1208. package/style/themes/theme-ui/ui-theme-components.min.css +16 -6
  1209. package/style/themes/theme-ui/ui-theme-elements.css +3 -6
  1210. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  1211. package/style/themes/theme-ui/ui-theme-extensions.css +113 -3
  1212. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  1213. package/style/themes/theme-ui/ui-theme-forms.css +113 -3
  1214. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  1215. package/style/themes/theme-ui/ui-theme-tags.css +3 -6
  1216. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  1217. package/umd/dnb-ui-basis.min.js +1 -1
  1218. package/umd/dnb-ui-components.min.js +1 -1
  1219. package/umd/dnb-ui-elements.min.js +1 -1
  1220. package/umd/dnb-ui-extensions.min.js +3 -3
  1221. package/umd/dnb-ui-lib.min.js +1 -1
  1222. package/cjs/components/table/TableAccordionContent.d.ts +0 -18
  1223. package/cjs/components/table/TableAccordionContent.js.map +0 -1
  1224. package/cjs/extensions/forms/hooks/useDataValue.d.ts +0 -26
  1225. package/cjs/extensions/forms/hooks/useDataValue.js +0 -461
  1226. package/cjs/extensions/forms/hooks/useDataValue.js.map +0 -1
  1227. package/cjs/extensions/forms/hooks/useId.js.map +0 -1
  1228. package/cjs/extensions/forms/hooks/useMountEffect.js.map +0 -1
  1229. package/cjs/extensions/forms/hooks/useUnmountEffect.js.map +0 -1
  1230. package/cjs/extensions/forms/hooks/useUpdateEffect.js.map +0 -1
  1231. package/components/table/TableAccordionContent.d.ts +0 -18
  1232. package/components/table/TableAccordionContent.js.map +0 -1
  1233. package/es/components/table/TableAccordionContent.d.ts +0 -18
  1234. package/es/components/table/TableAccordionContent.js.map +0 -1
  1235. package/es/extensions/forms/hooks/useDataValue.d.ts +0 -26
  1236. package/es/extensions/forms/hooks/useDataValue.js +0 -443
  1237. package/es/extensions/forms/hooks/useDataValue.js.map +0 -1
  1238. package/es/extensions/forms/hooks/useId.js.map +0 -1
  1239. package/es/extensions/forms/hooks/useMountEffect.js.map +0 -1
  1240. package/es/extensions/forms/hooks/useUnmountEffect.js.map +0 -1
  1241. package/es/extensions/forms/hooks/useUpdateEffect.js.map +0 -1
  1242. package/extensions/forms/hooks/useDataValue.d.ts +0 -26
  1243. package/extensions/forms/hooks/useDataValue.js +0 -451
  1244. package/extensions/forms/hooks/useDataValue.js.map +0 -1
  1245. package/extensions/forms/hooks/useId.js.map +0 -1
  1246. package/extensions/forms/hooks/useMountEffect.js.map +0 -1
  1247. package/extensions/forms/hooks/useUnmountEffect.js.map +0 -1
  1248. package/extensions/forms/hooks/useUpdateEffect.js.map +0 -1
  1249. /package/cjs/{extensions/forms/hooks → shared/helpers}/useId.d.ts +0 -0
  1250. /package/cjs/{extensions/forms/hooks → shared/helpers}/useMountEffect.d.ts +0 -0
  1251. /package/cjs/{extensions/forms/hooks → shared/helpers}/useMountEffect.js +0 -0
  1252. /package/cjs/{extensions/forms/hooks → shared/helpers}/useUnmountEffect.d.ts +0 -0
  1253. /package/cjs/{extensions/forms/hooks → shared/helpers}/useUnmountEffect.js +0 -0
  1254. /package/cjs/{extensions/forms/hooks → shared/helpers}/useUpdateEffect.d.ts +0 -0
  1255. /package/cjs/{extensions/forms/hooks → shared/helpers}/useUpdateEffect.js +0 -0
  1256. /package/es/{extensions/forms/hooks → shared/helpers}/useId.d.ts +0 -0
  1257. /package/es/{extensions/forms/hooks → shared/helpers}/useMountEffect.d.ts +0 -0
  1258. /package/es/{extensions/forms/hooks → shared/helpers}/useMountEffect.js +0 -0
  1259. /package/es/{extensions/forms/hooks → shared/helpers}/useUnmountEffect.d.ts +0 -0
  1260. /package/es/{extensions/forms/hooks → shared/helpers}/useUnmountEffect.js +0 -0
  1261. /package/es/{extensions/forms/hooks → shared/helpers}/useUpdateEffect.d.ts +0 -0
  1262. /package/es/{extensions/forms/hooks → shared/helpers}/useUpdateEffect.js +0 -0
  1263. /package/{extensions/forms/hooks → shared/helpers}/useId.d.ts +0 -0
  1264. /package/{extensions/forms/hooks → shared/helpers}/useMountEffect.d.ts +0 -0
  1265. /package/{extensions/forms/hooks → shared/helpers}/useMountEffect.js +0 -0
  1266. /package/{extensions/forms/hooks → shared/helpers}/useUnmountEffect.d.ts +0 -0
  1267. /package/{extensions/forms/hooks → shared/helpers}/useUnmountEffect.js +0 -0
  1268. /package/{extensions/forms/hooks → shared/helpers}/useUpdateEffect.d.ts +0 -0
  1269. /package/{extensions/forms/hooks → shared/helpers}/useUpdateEffect.js +0 -0
@@ -10,6 +10,8 @@
10
10
  padding: 0;
11
11
  display: flex;
12
12
  flex-direction: column;
13
+ /* stylelint-disable no-descending-specificity, no-duplicate-selectors */
14
+ /* stylelint-enable */
13
15
  }
14
16
  .dnb-breadcrumb__bar.dnb-section {
15
17
  display: flex;
@@ -21,17 +23,41 @@
21
23
  list-style: none;
22
24
  flex-flow: row wrap;
23
25
  align-items: center;
24
- gap: 1.5rem;
26
+ row-gap: 1rem;
27
+ -moz-column-gap: 0.5rem;
28
+ column-gap: 0.5rem;
25
29
  }
26
- .dnb-breadcrumb__item__span {
30
+ .dnb-breadcrumb__item {
27
31
  display: flex;
28
32
  align-items: center;
29
- line-height: normal;
30
33
  padding: 0.5rem 0;
31
34
  }
35
+ .dnb-breadcrumb__item__span {
36
+ display: flex;
37
+ align-items: center;
38
+ line-height: var(--line-height-basis);
39
+ }
32
40
  .dnb-breadcrumb__item__span__icon {
33
41
  margin-right: 0.5rem;
34
42
  }
43
+ .dnb-breadcrumb__item .dnb-anchor {
44
+ line-height: 1rem;
45
+ padding: 0.25rem 0;
46
+ position: relative;
47
+ }
48
+ .dnb-breadcrumb__item .dnb-anchor::after {
49
+ content: "";
50
+ position: absolute;
51
+ inset: 0;
52
+ transform: scale(1.25, 2);
53
+ border: 0.5rem solid transparent;
54
+ }
55
+ .dnb-breadcrumb__item:first-child .dnb-anchor {
56
+ border-left: none;
57
+ }
58
+ .dnb-breadcrumb__item:first-child .dnb-anchor .dnb-icon {
59
+ margin-right: 0.5rem;
60
+ }
35
61
  .dnb-breadcrumb__multiple {
36
62
  display: flex;
37
63
  flex-direction: column;
@@ -44,13 +70,16 @@
44
70
  .dnb-breadcrumb__multiple.dnb-height-animation--parallax .dnb-breadcrumb__item {
45
71
  transform: translateX(0);
46
72
  }
73
+ html[data-visual-test] .dnb-breadcrumb__multiple .dnb-breadcrumb__item {
74
+ transition: none;
75
+ }
47
76
  @media screen and (max-width: 60em) {
48
- .dnb-breadcrumb__bar .dnb-breadcrumb__multiple {
77
+ .dnb-breadcrumb--variant-responsive .dnb-breadcrumb__bar .dnb-breadcrumb__multiple {
49
78
  display: none;
50
79
  }
51
80
  }
52
81
  @media screen and (min-width: 60em) {
53
- .dnb-breadcrumb--variant-multiple .dnb-breadcrumb__toggle {
82
+ .dnb-breadcrumb--variant-responsive .dnb-breadcrumb__toggle {
54
83
  display: none;
55
84
  }
56
85
  }
@@ -61,7 +90,8 @@
61
90
  .dnb-breadcrumb__collapse .dnb-breadcrumb__list.dnb-section {
62
91
  flex-direction: column;
63
92
  align-items: flex-start;
93
+ row-gap: 0;
64
94
  margin: 0.5rem 0;
65
95
  margin-left: 1.5rem;
66
- gap: 0;
96
+ padding: 0;
67
97
  }
@@ -1 +1 @@
1
- .dnb-breadcrumb{display:flex;flex-direction:column;margin:0;padding:0}.dnb-breadcrumb__bar.dnb-section{display:flex}.dnb-breadcrumb__list.dnb-section{align-items:center;display:flex;flex-flow:row wrap;gap:1.5rem;list-style:none;margin:0;padding:0}.dnb-breadcrumb__item__span{align-items:center;display:flex;line-height:normal;padding:.5rem 0}.dnb-breadcrumb__item__span__icon{margin-right:.5rem}.dnb-breadcrumb__multiple{display:flex;flex-direction:column;transition:height .4s var(--easing-default)}.dnb-breadcrumb__multiple .dnb-breadcrumb__item{transform:translateX(-1rem);transition:transform .4s var(--easing-default) calc(var(--delay)*50ms)}.dnb-breadcrumb__multiple.dnb-height-animation--parallax .dnb-breadcrumb__item{transform:translateX(0)}@media screen and (max-width:60em){.dnb-breadcrumb__bar .dnb-breadcrumb__multiple{display:none}}@media screen and (min-width:60em){.dnb-breadcrumb--variant-multiple .dnb-breadcrumb__toggle{display:none}}.dnb-breadcrumb__collapse{display:flex;flex-direction:column}.dnb-breadcrumb__collapse .dnb-breadcrumb__list.dnb-section{align-items:flex-start;flex-direction:column;gap:0;margin:.5rem 0 .5rem 1.5rem}
1
+ .dnb-breadcrumb{display:flex;flex-direction:column;margin:0;padding:0}.dnb-breadcrumb__bar.dnb-section{display:flex}.dnb-breadcrumb__list.dnb-section{align-items:center;-moz-column-gap:.5rem;column-gap:.5rem;display:flex;flex-flow:row wrap;list-style:none;margin:0;padding:0;row-gap:1rem}.dnb-breadcrumb__item{align-items:center;display:flex;padding:.5rem 0}.dnb-breadcrumb__item__span{align-items:center;display:flex;line-height:var(--line-height-basis)}.dnb-breadcrumb__item__span__icon{margin-right:.5rem}.dnb-breadcrumb__item .dnb-anchor{line-height:1rem;padding:.25rem 0;position:relative}.dnb-breadcrumb__item .dnb-anchor:after{border:.5rem solid transparent;content:"";inset:0;position:absolute;transform:scale(1.25,2)}.dnb-breadcrumb__item:first-child .dnb-anchor{border-left:none}.dnb-breadcrumb__item:first-child .dnb-anchor .dnb-icon{margin-right:.5rem}.dnb-breadcrumb__multiple{display:flex;flex-direction:column;transition:height .4s var(--easing-default)}.dnb-breadcrumb__multiple .dnb-breadcrumb__item{transform:translateX(-1rem);transition:transform .4s var(--easing-default) calc(var(--delay)*50ms)}.dnb-breadcrumb__multiple.dnb-height-animation--parallax .dnb-breadcrumb__item{transform:translateX(0)}html[data-visual-test] .dnb-breadcrumb__multiple .dnb-breadcrumb__item{transition:none}@media screen and (max-width:60em){.dnb-breadcrumb--variant-responsive .dnb-breadcrumb__bar .dnb-breadcrumb__multiple{display:none}}@media screen and (min-width:60em){.dnb-breadcrumb--variant-responsive .dnb-breadcrumb__toggle{display:none}}.dnb-breadcrumb__collapse{display:flex;flex-direction:column}.dnb-breadcrumb__collapse .dnb-breadcrumb__list.dnb-section{align-items:flex-start;flex-direction:column;margin:.5rem 0 .5rem 1.5rem;padding:0;row-gap:0}
@@ -25,21 +25,48 @@
25
25
 
26
26
  flex-flow: row wrap;
27
27
  align-items: center;
28
- gap: 1.5rem;
28
+ row-gap: 1rem; // For when breaking into new lines (Anchor variant)
29
+ column-gap: 0.5rem;
29
30
  }
30
31
 
31
32
  &__item {
33
+ display: flex;
34
+ align-items: center;
35
+ padding: 0.5rem 0;
36
+
32
37
  &__span {
33
38
  display: flex;
34
39
  align-items: center;
35
- line-height: normal;
36
- padding: 0.5rem 0;
40
+ line-height: var(--line-height-basis);
37
41
 
38
42
  // To match the other tertiary buttons
39
43
  &__icon {
40
44
  margin-right: 0.5rem;
41
45
  }
42
46
  }
47
+
48
+ .dnb-anchor {
49
+ line-height: 1rem;
50
+ padding: 0.25rem 0;
51
+
52
+ // To make the click area bigger
53
+ position: relative;
54
+ &::after {
55
+ content: '';
56
+ position: absolute;
57
+ inset: 0;
58
+ transform: scale(1.25, 2);
59
+ border: 0.5rem solid transparent;
60
+ }
61
+ }
62
+
63
+ // Home icon spacing
64
+ &:first-child .dnb-anchor {
65
+ border-left: none;
66
+ .dnb-icon {
67
+ margin-right: 0.5rem;
68
+ }
69
+ }
43
70
  }
44
71
 
45
72
  &__multiple {
@@ -59,13 +86,21 @@
59
86
  transform: translateX(0);
60
87
  }
61
88
 
62
- &__bar &__multiple {
89
+ /* stylelint-disable no-descending-specificity, no-duplicate-selectors */
90
+ &__multiple &__item {
91
+ html[data-visual-test] & {
92
+ transition: none;
93
+ }
94
+ }
95
+ /* stylelint-enable */
96
+
97
+ &--variant-responsive &__bar &__multiple {
63
98
  @include allBelow(medium) {
64
99
  display: none;
65
100
  }
66
101
  }
67
102
 
68
- &--variant-multiple &__toggle {
103
+ &--variant-responsive &__toggle {
69
104
  @include allAbove(medium) {
70
105
  display: none;
71
106
  }
@@ -79,9 +114,10 @@
79
114
  &__collapse &__list.dnb-section {
80
115
  flex-direction: column;
81
116
  align-items: flex-start;
117
+ row-gap: 0;
82
118
 
83
119
  margin: 0.5rem 0;
84
120
  margin-left: 1.5rem;
85
- gap: 0;
121
+ padding: 0;
86
122
  }
87
123
  }
@@ -9,6 +9,12 @@
9
9
  font-weight: var(--font-weight-medium);
10
10
  color: var(--sb-color-text);
11
11
  }
12
+ .dnb-breadcrumb__item {
13
+ padding: 0;
14
+ }
15
+ .dnb-breadcrumb__item__span {
16
+ padding: 0.5rem 0;
17
+ }
12
18
  .dnb-breadcrumb__item__span__icon {
13
19
  color: var(--sb-color-violet);
14
20
  }
@@ -20,4 +26,7 @@
20
26
  }
21
27
  .dnb-breadcrumb__item:not(:last-of-type) .dnb-button.dnb-button--has-text .dnb-button__text {
22
28
  color: var(--sb-color-text);
29
+ }
30
+ .dnb-breadcrumb__list.dnb-section {
31
+ row-gap: 0;
23
32
  }
@@ -1 +1 @@
1
- .dnb-breadcrumb .dnb-button__text{color:var(--sb-color-text);font-weight:var(--font-weight-medium)}.dnb-breadcrumb__item__span__icon{color:var(--sb-color-violet)}.dnb-breadcrumb__item__span .dnb-p{color:var(--sb-color-gray-dark-3)}.dnb-breadcrumb__item:not(:last-of-type) .dnb-button.dnb-button--has-text{font-weight:var(--font-weight-medium)}.dnb-breadcrumb__item:not(:last-of-type) .dnb-button.dnb-button--has-text .dnb-button__text{color:var(--sb-color-text)}
1
+ .dnb-breadcrumb .dnb-button__text{color:var(--sb-color-text);font-weight:var(--font-weight-medium)}.dnb-breadcrumb__item{padding:0}.dnb-breadcrumb__item__span{padding:.5rem 0}.dnb-breadcrumb__item__span__icon{color:var(--sb-color-violet)}.dnb-breadcrumb__item__span .dnb-p{color:var(--sb-color-gray-dark-3)}.dnb-breadcrumb__item:not(:last-of-type) .dnb-button.dnb-button--has-text{font-weight:var(--font-weight-medium)}.dnb-breadcrumb__item:not(:last-of-type) .dnb-button.dnb-button--has-text .dnb-button__text{color:var(--sb-color-text)}.dnb-breadcrumb__list.dnb-section{row-gap:0}
@@ -13,7 +13,9 @@
13
13
  }
14
14
  }
15
15
  &__item {
16
+ padding: 0;
16
17
  &__span {
18
+ padding: 0.5rem 0;
17
19
  &__icon {
18
20
  color: var(--sb-color-violet);
19
21
  }
@@ -30,4 +32,9 @@
30
32
  }
31
33
  }
32
34
  }
35
+
36
+ // For when breaking into new lines
37
+ &__list.dnb-section {
38
+ row-gap: 0;
39
+ }
33
40
  }
@@ -54,7 +54,7 @@ export default class Button extends React.PureComponent {
54
54
  }
55
55
  }
56
56
  render() {
57
- var _this$context, _this$context2, _this$context3;
57
+ var _this$context, _this$context2, _this$context3, _this$context4, _this$context4$theme;
58
58
  const props = extendPropsWithContextInClassComponent(this.props, Button.defaultProps, {
59
59
  skeleton: (_this$context = this.context) === null || _this$context === void 0 ? void 0 : _this$context.skeleton
60
60
  }, pickFormElementProps((_this$context2 = this.context) === null || _this$context2 === void 0 ? void 0 : _this$context2.FormRow), pickFormElementProps((_this$context3 = this.context) === null || _this$context3 === void 0 ? void 0 : _this$context3.formElement), this.context.Button);
@@ -128,7 +128,7 @@ export default class Button extends React.PureComponent {
128
128
  icon = launch;
129
129
  }
130
130
  }
131
- const classes = classnames(`dnb-button dnb-button--${usedVariant || 'primary'}`, (text || content || custom_content) && 'dnb-button--has-text', createSkeletonClass(variant === 'tertiary' ? 'font' : 'shape', skeleton, this.context), createSpacingClasses(props), class_name, className, (props.href || props.to) && '', icon && `dnb-button--icon-position-${icon_position} dnb-button--has-icon` + (iconSize ? ` dnb-button--icon-size-${iconSize}` : ""), usedSize && usedSize !== 'default' && `dnb-button--size-${usedSize}`, isTrue(stretch) && 'dnb-button--stretch', wrap && 'dnb-button--wrap', status && `dnb-button__status--${status_state}`, Element === Anchor && 'dnb-anchor--no-style');
131
+ const classes = classnames(`dnb-button dnb-button--${usedVariant || 'primary'}`, (text || content || custom_content) && 'dnb-button--has-text', createSkeletonClass(variant === 'tertiary' ? 'font' : 'shape', skeleton, this.context), createSpacingClasses(props), class_name, className, (props.href || props.to) && '', icon && `dnb-button--icon-position-${icon_position} dnb-button--has-icon` + (iconSize ? ` dnb-button--icon-size-${iconSize}` : ""), usedSize && usedSize !== 'default' && `dnb-button--size-${usedSize}`, ((_this$context4 = this.context) === null || _this$context4 === void 0 ? void 0 : (_this$context4$theme = _this$context4.theme) === null || _this$context4$theme === void 0 ? void 0 : _this$context4$theme.darkBackground) && `dnb-button--on-dark-background`, isTrue(stretch) && 'dnb-button--stretch', wrap && 'dnb-button--wrap', status && `dnb-button__status--${status_state}`, Element === Anchor && 'dnb-anchor--no-style');
132
132
  const params = _objectSpread({
133
133
  className: classes,
134
134
  title,
@@ -1 +1 @@
1
- {"version":3,"file":"Button.js","names":["React","PropTypes","classnames","Context","warn","makeUniqueId","isTrue","extendPropsWithContextInClassComponent","validateDOMAttributes","processChildren","getStatusState","dispatchCustomElementEvent","spacingPropTypes","createSpacingClasses","skeletonDOMAttributes","createSkeletonClass","pickFormElementProps","IconPrimary","FormStatus","Anchor","pickIcon","opensNewTab","launch","Tooltip","buttonVariantPropType","variant","oneOf","Button","PureComponent","getContent","props","constructor","_defineProperty","event","afterContent","isValidElement","setState","_id","id","status","tooltip","_ref","createRef","state","componentDidMount","innerRef","current","inner_ref","render","_this$context","_this$context2","_this$context3","defaultProps","skeleton","context","FormRow","formElement","class","class_name","className","size","title","custom_content","status_state","status_props","status_no_animation","globalStatus","disabled","text","_text","icon","_icon","icon_position","icon_size","wrap","bounding","stretch","element","attributes","_objectWithoutProperties","_excluded","showStatus","usedVariant","usedSize","iconSize","content","isIconOnly","Boolean","Element","href","to","omitClass","target","classes","params","_objectSpread","on_click","onClick","onClickHandler","type","undefined","createElement","Fragment","_extends","ref","Content","show","label","text_id","no_animation","targetElement","process","env","NODE_ENV","propTypes","oneOfType","string","node","func","number","bool","object","shape","message","rel","children","_span","key","_span2","_span3","array","_formElement","_supportsSpacingProps"],"sources":["../../../../src/components/button/Button.js"],"sourcesContent":["/**\n * Web Button Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport Context from '../../shared/Context'\nimport {\n warn,\n makeUniqueId,\n isTrue,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n processChildren,\n getStatusState,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\nimport {\n skeletonDOMAttributes,\n createSkeletonClass,\n} from '../skeleton/SkeletonHelper'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\nimport IconPrimary from '../icon-primary/IconPrimary'\nimport FormStatus from '../form-status/FormStatus'\nimport Anchor, { pickIcon, opensNewTab } from '../anchor/Anchor'\nimport { launch } from '../../icons'\nimport Tooltip from '../tooltip/Tooltip'\n\nexport const buttonVariantPropType = {\n variant: PropTypes.oneOf([\n 'primary',\n 'secondary',\n 'tertiary',\n 'signal',\n\n /**\n * For internal use only (as of now)\n */\n 'unstyled',\n ]),\n}\n\n/**\n * The button component should be used as the call-to-action in a form, or as a user interaction mechanism. Generally speaking, a button should not be used when a link would do the trick. Exceptions are made at times when it is used as a navigation element in the action-nav element.\n */\nexport default class Button extends React.PureComponent {\n static contextType = Context\n\n static getContent(props) {\n return processChildren(props)\n }\n\n constructor(props) {\n super(props)\n\n this._id =\n props.id || ((props.status || props.tooltip) && makeUniqueId()) // cause we need an id anyway\n this._ref = React.createRef()\n\n this.state = { afterContent: null }\n }\n\n componentDidMount() {\n if (this.props.innerRef) {\n typeof this.props.innerRef === 'function'\n ? this.props.innerRef(this._ref.current)\n : (this.props.innerRef.current = this._ref.current)\n }\n if (this.props.inner_ref) {\n typeof this.props.innerRef === 'function'\n ? this.props.inner_ref(this._ref.current)\n : (this.props.inner_ref.current = this._ref.current)\n }\n }\n\n onClickHandler = (event) => {\n const afterContent = dispatchCustomElementEvent(this, 'on_click', {\n event,\n })\n if (afterContent && React.isValidElement(afterContent)) {\n this.setState({\n afterContent,\n })\n }\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n Button.defaultProps,\n { skeleton: this.context?.skeleton },\n // Deprecated – can be removed in v11\n pickFormElementProps(this.context?.FormRow),\n pickFormElementProps(this.context?.formElement),\n this.context.Button\n )\n\n const {\n class: class_name,\n className,\n variant,\n size,\n title,\n custom_content,\n tooltip,\n status,\n status_state,\n status_props,\n status_no_animation,\n globalStatus,\n id, // eslint-disable-line\n disabled,\n text: _text, // eslint-disable-line\n icon: _icon, // eslint-disable-line\n icon_position,\n icon_size,\n wrap,\n bounding, // eslint-disable-line\n stretch,\n skeleton,\n element,\n inner_ref, // eslint-disable-line\n innerRef, // eslint-disable-line\n ...attributes\n } = props\n\n const showStatus = getStatusState(status)\n\n let { text, icon } = props\n let usedVariant = variant\n let usedSize = size\n let iconSize = icon_size\n const content = Button.getContent(this.props)\n\n if (\n variant === 'tertiary' &&\n (text || content) &&\n !icon &&\n icon !== false\n ) {\n warn(\n `Icon required: A Tertiary Button requires an icon to be WCAG compliant in most cases, because variant tertiary has no underline.\n(Override this warning using icon={false}, or consider using one of the other variants)`\n )\n }\n\n // if only has Icon, then resize it and define it as secondary\n const isIconOnly = Boolean(!text && !content && icon)\n if (isIconOnly) {\n if (!usedVariant) {\n usedVariant = 'secondary'\n }\n if (!iconSize && (usedSize === 'default' || usedSize === 'large')) {\n iconSize = 'medium'\n }\n if (!usedSize) {\n usedSize = 'medium'\n }\n } else if (content) {\n if (!usedVariant) {\n usedVariant = 'primary'\n }\n if (!usedSize) {\n usedSize = 'default'\n }\n }\n if (!iconSize && variant === 'tertiary' && icon_position === 'top') {\n iconSize = 'medium'\n }\n\n const Element = element\n ? element\n : props.href || props.to\n ? Anchor\n : 'button'\n if (Element === Anchor) {\n attributes.omitClass = true\n if (opensNewTab(props.target, props.href) && !icon) {\n icon = launch\n }\n }\n\n const classes = classnames(\n 'dnb-button',\n `dnb-button--${usedVariant || 'primary'}`,\n usedSize && usedSize !== 'default' && `dnb-button--size-${usedSize}`,\n icon && `dnb-button--icon-position-${icon_position}`,\n isTrue(stretch) && 'dnb-button--stretch',\n icon && iconSize && `dnb-button--icon-size-${iconSize}`,\n (text || content || custom_content) && 'dnb-button--has-text',\n icon && 'dnb-button--has-icon',\n wrap && 'dnb-button--wrap',\n status && `dnb-button__status--${status_state}`,\n createSkeletonClass(\n variant === 'tertiary' ? 'font' : 'shape',\n skeleton,\n this.context\n ),\n createSpacingClasses(props),\n class_name,\n className,\n props.href || props.to ? '' : null, // dnb-anchor--no-underline dnb-anchor--no-hover\n Element === Anchor && 'dnb-anchor--no-style'\n )\n\n const params = {\n className: classes,\n title,\n id: this._id,\n disabled: isTrue(disabled),\n ...attributes,\n }\n\n if (this.props.on_click || this.props.onClick) {\n params.onClick = this.onClickHandler\n }\n\n if (Element !== Anchor && !params.type) {\n params.type = params.type === '' ? undefined : 'button'\n }\n\n skeletonDOMAttributes(params, skeleton, this.context)\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n return (\n <>\n <Element ref={this._ref} {...params}>\n <Content\n {...this.props}\n icon={icon}\n icon_size={iconSize}\n content={text || content}\n custom_content={custom_content}\n isIconOnly={isIconOnly}\n skeleton={isTrue(skeleton)}\n />\n </Element>\n\n {this.state.afterContent}\n\n <FormStatus\n show={showStatus}\n id={this._id + '-form-status'}\n globalStatus={globalStatus}\n label={text}\n text={status}\n state={status_state}\n text_id={this._id + '-status'} // used for \"aria-describedby\"\n no_animation={status_no_animation}\n skeleton={skeleton}\n {...status_props}\n />\n\n {tooltip && this._ref && (\n <Tooltip\n id={this._id + '-tooltip'}\n targetElement={this._ref}\n tooltip={tooltip}\n />\n )}\n </>\n )\n }\n}\n\nButton.propTypes = {\n text: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n type: PropTypes.string,\n title: PropTypes.node,\n variant: buttonVariantPropType.variant,\n size: PropTypes.oneOf(['default', 'small', 'medium', 'large']),\n icon: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.node,\n PropTypes.func,\n ]),\n icon_position: PropTypes.oneOf(['left', 'right', 'top']),\n icon_size: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n tooltip: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n status: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n PropTypes.func,\n PropTypes.node,\n ]),\n status_state: PropTypes.string,\n status_props: PropTypes.object,\n status_no_animation: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n globalStatus: PropTypes.shape({\n id: PropTypes.string,\n message: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n }),\n id: PropTypes.string,\n class: PropTypes.string,\n href: PropTypes.string,\n target: PropTypes.string,\n rel: PropTypes.string,\n to: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n PropTypes.func,\n ]),\n custom_content: PropTypes.node,\n wrap: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n bounding: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n stretch: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n inner_ref: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n className: PropTypes.string,\n innerRef: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n children: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n element: PropTypes.oneOfType([\n PropTypes.func,\n PropTypes.object,\n PropTypes.node,\n ]),\n\n ...spacingPropTypes,\n\n on_click: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n}\n\nButton.defaultProps = {\n type: null, // set the type because of the anchor/href situation – can be made more smart in future\n text: null,\n variant: null,\n size: null,\n title: null,\n icon: null,\n icon_position: 'right',\n icon_size: null,\n href: null,\n target: null,\n rel: null,\n to: null,\n id: null,\n class: null,\n custom_content: null,\n wrap: null,\n bounding: null,\n stretch: null,\n skeleton: null,\n disabled: null,\n tooltip: null,\n status: null,\n status_state: 'error',\n status_props: null,\n status_no_animation: null,\n globalStatus: null,\n inner_ref: null,\n\n className: null,\n innerRef: null,\n children: null,\n element: null,\n\n on_click: null,\n}\n\nfunction Content({\n title,\n content,\n custom_content,\n icon,\n icon_size,\n bounding,\n skeleton,\n isIconOnly,\n}) {\n return (\n <>\n {isTrue(bounding) && (\n <span key=\"button-bounding\" className=\"dnb-button__bounding\" />\n )}\n\n {custom_content && (\n <React.Fragment key=\"button-custom-content\">\n {custom_content}\n </React.Fragment>\n )}\n\n {content && (\n <>\n <span\n key=\"button-alignment\"\n className=\"dnb-button__alignment\"\n aria-hidden\n >\n &zwnj;\n </span>\n <span\n key=\"button-text\"\n className=\"dnb-button__text dnb-skeleton--show-font\"\n >\n {content}\n </span>\n </>\n )}\n\n {\n // on empty text, use a zero-width non-joiner\n // so the icon button gets vertical aligned\n // we need the dnb-button__text for alignment\n !content && icon && (\n <span\n key=\"button-alignment\"\n className=\"dnb-button__alignment\"\n aria-hidden\n >\n &zwnj;\n </span>\n )\n }\n\n {icon &&\n (pickIcon(icon) || (\n <IconPrimary\n key=\"button-icon\"\n className=\"dnb-button__icon\"\n icon={icon}\n size={icon_size}\n aria-hidden={isIconOnly && !title ? null : true}\n skeleton={skeleton}\n />\n ))}\n </>\n )\n}\n\nContent.propTypes = {\n title: PropTypes.node,\n custom_content: PropTypes.node,\n content: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.array,\n PropTypes.node,\n ]),\n icon: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.node,\n PropTypes.func,\n ]),\n icon_size: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n bounding: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.bool,\n isIconOnly: PropTypes.bool,\n}\n\nContent.defaultProps = {\n custom_content: null,\n title: null,\n content: null,\n icon: null,\n icon_size: 'default',\n bounding: null,\n skeleton: null,\n isIconOnly: null,\n}\n\nButton._formElement = true\nButton._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"Button.js","names":["React","PropTypes","classnames","Context","warn","makeUniqueId","isTrue","extendPropsWithContextInClassComponent","validateDOMAttributes","processChildren","getStatusState","dispatchCustomElementEvent","spacingPropTypes","createSpacingClasses","skeletonDOMAttributes","createSkeletonClass","pickFormElementProps","IconPrimary","FormStatus","Anchor","pickIcon","opensNewTab","launch","Tooltip","buttonVariantPropType","variant","oneOf","Button","PureComponent","getContent","props","constructor","_defineProperty","event","afterContent","isValidElement","setState","_id","id","status","tooltip","_ref","createRef","state","componentDidMount","innerRef","current","inner_ref","render","_this$context","_this$context2","_this$context3","_this$context4","_this$context4$theme","defaultProps","skeleton","context","FormRow","formElement","class","class_name","className","size","title","custom_content","status_state","status_props","status_no_animation","globalStatus","disabled","text","_text","icon","_icon","icon_position","icon_size","wrap","bounding","stretch","element","attributes","_objectWithoutProperties","_excluded","showStatus","usedVariant","usedSize","iconSize","content","isIconOnly","Boolean","Element","href","to","omitClass","target","classes","theme","darkBackground","params","_objectSpread","on_click","onClick","onClickHandler","type","undefined","createElement","Fragment","_extends","ref","Content","show","label","text_id","no_animation","targetElement","process","env","NODE_ENV","propTypes","oneOfType","string","node","func","number","bool","object","shape","message","rel","children","_span","key","_span2","_span3","array","_formElement","_supportsSpacingProps"],"sources":["../../../../src/components/button/Button.js"],"sourcesContent":["/**\n * Web Button Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport Context from '../../shared/Context'\nimport {\n warn,\n makeUniqueId,\n isTrue,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n processChildren,\n getStatusState,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\nimport {\n skeletonDOMAttributes,\n createSkeletonClass,\n} from '../skeleton/SkeletonHelper'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\nimport IconPrimary from '../icon-primary/IconPrimary'\nimport FormStatus from '../form-status/FormStatus'\nimport Anchor, { pickIcon, opensNewTab } from '../anchor/Anchor'\nimport { launch } from '../../icons'\nimport Tooltip from '../tooltip/Tooltip'\n\nexport const buttonVariantPropType = {\n variant: PropTypes.oneOf([\n 'primary',\n 'secondary',\n 'tertiary',\n 'signal',\n\n /**\n * For internal use only (as of now)\n */\n 'unstyled',\n ]),\n}\n\n/**\n * The button component should be used as the call-to-action in a form, or as a user interaction mechanism. Generally speaking, a button should not be used when a link would do the trick. Exceptions are made at times when it is used as a navigation element in the action-nav element.\n */\nexport default class Button extends React.PureComponent {\n static contextType = Context\n\n static getContent(props) {\n return processChildren(props)\n }\n\n constructor(props) {\n super(props)\n\n this._id =\n props.id || ((props.status || props.tooltip) && makeUniqueId()) // cause we need an id anyway\n this._ref = React.createRef()\n\n this.state = { afterContent: null }\n }\n\n componentDidMount() {\n if (this.props.innerRef) {\n typeof this.props.innerRef === 'function'\n ? this.props.innerRef(this._ref.current)\n : (this.props.innerRef.current = this._ref.current)\n }\n if (this.props.inner_ref) {\n typeof this.props.innerRef === 'function'\n ? this.props.inner_ref(this._ref.current)\n : (this.props.inner_ref.current = this._ref.current)\n }\n }\n\n onClickHandler = (event) => {\n const afterContent = dispatchCustomElementEvent(this, 'on_click', {\n event,\n })\n if (afterContent && React.isValidElement(afterContent)) {\n this.setState({\n afterContent,\n })\n }\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n Button.defaultProps,\n { skeleton: this.context?.skeleton },\n // Deprecated – can be removed in v11\n pickFormElementProps(this.context?.FormRow),\n pickFormElementProps(this.context?.formElement),\n this.context.Button\n )\n\n const {\n class: class_name,\n className,\n variant,\n size,\n title,\n custom_content,\n tooltip,\n status,\n status_state,\n status_props,\n status_no_animation,\n globalStatus,\n id, // eslint-disable-line\n disabled,\n text: _text, // eslint-disable-line\n icon: _icon, // eslint-disable-line\n icon_position,\n icon_size,\n wrap,\n bounding, // eslint-disable-line\n stretch,\n skeleton,\n element,\n inner_ref, // eslint-disable-line\n innerRef, // eslint-disable-line\n ...attributes\n } = props\n\n const showStatus = getStatusState(status)\n\n let { text, icon } = props\n let usedVariant = variant\n let usedSize = size\n let iconSize = icon_size\n const content = Button.getContent(this.props)\n\n if (\n variant === 'tertiary' &&\n (text || content) &&\n !icon &&\n icon !== false\n ) {\n warn(\n `Icon required: A Tertiary Button requires an icon to be WCAG compliant in most cases, because variant tertiary has no underline.\n(Override this warning using icon={false}, or consider using one of the other variants)`\n )\n }\n\n // if only has Icon, then resize it and define it as secondary\n const isIconOnly = Boolean(!text && !content && icon)\n if (isIconOnly) {\n if (!usedVariant) {\n usedVariant = 'secondary'\n }\n if (!iconSize && (usedSize === 'default' || usedSize === 'large')) {\n iconSize = 'medium'\n }\n if (!usedSize) {\n usedSize = 'medium'\n }\n } else if (content) {\n if (!usedVariant) {\n usedVariant = 'primary'\n }\n if (!usedSize) {\n usedSize = 'default'\n }\n }\n if (!iconSize && variant === 'tertiary' && icon_position === 'top') {\n iconSize = 'medium'\n }\n\n const Element = element\n ? element\n : props.href || props.to\n ? Anchor\n : 'button'\n if (Element === Anchor) {\n attributes.omitClass = true\n if (opensNewTab(props.target, props.href) && !icon) {\n icon = launch\n }\n }\n\n const classes = classnames(\n 'dnb-button',\n `dnb-button--${usedVariant || 'primary'}`,\n usedSize && usedSize !== 'default' && `dnb-button--size-${usedSize}`,\n this.context?.theme?.darkBackground &&\n `dnb-button--on-dark-background`,\n icon && `dnb-button--icon-position-${icon_position}`,\n isTrue(stretch) && 'dnb-button--stretch',\n icon && iconSize && `dnb-button--icon-size-${iconSize}`,\n (text || content || custom_content) && 'dnb-button--has-text',\n icon && 'dnb-button--has-icon',\n wrap && 'dnb-button--wrap',\n status && `dnb-button__status--${status_state}`,\n createSkeletonClass(\n variant === 'tertiary' ? 'font' : 'shape',\n skeleton,\n this.context\n ),\n createSpacingClasses(props),\n class_name,\n className,\n props.href || props.to ? '' : null, // dnb-anchor--no-underline dnb-anchor--no-hover\n Element === Anchor && 'dnb-anchor--no-style'\n )\n\n const params = {\n className: classes,\n title,\n id: this._id,\n disabled: isTrue(disabled),\n ...attributes,\n }\n\n if (this.props.on_click || this.props.onClick) {\n params.onClick = this.onClickHandler\n }\n\n if (Element !== Anchor && !params.type) {\n params.type = params.type === '' ? undefined : 'button'\n }\n\n skeletonDOMAttributes(params, skeleton, this.context)\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n return (\n <>\n <Element ref={this._ref} {...params}>\n <Content\n {...this.props}\n icon={icon}\n icon_size={iconSize}\n content={text || content}\n custom_content={custom_content}\n isIconOnly={isIconOnly}\n skeleton={isTrue(skeleton)}\n />\n </Element>\n\n {this.state.afterContent}\n\n <FormStatus\n show={showStatus}\n id={this._id + '-form-status'}\n globalStatus={globalStatus}\n label={text}\n text={status}\n state={status_state}\n text_id={this._id + '-status'} // used for \"aria-describedby\"\n no_animation={status_no_animation}\n skeleton={skeleton}\n {...status_props}\n />\n\n {tooltip && this._ref && (\n <Tooltip\n id={this._id + '-tooltip'}\n targetElement={this._ref}\n tooltip={tooltip}\n />\n )}\n </>\n )\n }\n}\n\nButton.propTypes = {\n text: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n type: PropTypes.string,\n title: PropTypes.node,\n variant: buttonVariantPropType.variant,\n size: PropTypes.oneOf(['default', 'small', 'medium', 'large']),\n icon: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.node,\n PropTypes.func,\n ]),\n icon_position: PropTypes.oneOf(['left', 'right', 'top']),\n icon_size: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n tooltip: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n status: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n PropTypes.func,\n PropTypes.node,\n ]),\n status_state: PropTypes.string,\n status_props: PropTypes.object,\n status_no_animation: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n globalStatus: PropTypes.shape({\n id: PropTypes.string,\n message: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n }),\n id: PropTypes.string,\n class: PropTypes.string,\n href: PropTypes.string,\n target: PropTypes.string,\n rel: PropTypes.string,\n to: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n PropTypes.func,\n ]),\n custom_content: PropTypes.node,\n wrap: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n bounding: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n stretch: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n inner_ref: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n\n className: PropTypes.string,\n innerRef: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n children: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n element: PropTypes.oneOfType([\n PropTypes.func,\n PropTypes.object,\n PropTypes.node,\n ]),\n\n ...spacingPropTypes,\n\n on_click: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n}\n\nButton.defaultProps = {\n type: null, // set the type because of the anchor/href situation – can be made more smart in future\n text: null,\n variant: null,\n size: null,\n title: null,\n icon: null,\n icon_position: 'right',\n icon_size: null,\n href: null,\n target: null,\n rel: null,\n to: null,\n id: null,\n class: null,\n custom_content: null,\n wrap: null,\n bounding: null,\n stretch: null,\n skeleton: null,\n disabled: null,\n tooltip: null,\n status: null,\n status_state: 'error',\n status_props: null,\n status_no_animation: null,\n globalStatus: null,\n inner_ref: null,\n\n className: null,\n innerRef: null,\n children: null,\n element: null,\n\n on_click: null,\n}\n\nfunction Content({\n title,\n content,\n custom_content,\n icon,\n icon_size,\n bounding,\n skeleton,\n isIconOnly,\n}) {\n return (\n <>\n {isTrue(bounding) && (\n <span key=\"button-bounding\" className=\"dnb-button__bounding\" />\n )}\n\n {custom_content && (\n <React.Fragment key=\"button-custom-content\">\n {custom_content}\n </React.Fragment>\n )}\n\n {content && (\n <>\n <span\n key=\"button-alignment\"\n className=\"dnb-button__alignment\"\n aria-hidden\n >\n &zwnj;\n </span>\n <span\n key=\"button-text\"\n className=\"dnb-button__text dnb-skeleton--show-font\"\n >\n {content}\n </span>\n </>\n )}\n\n {\n // on empty text, use a zero-width non-joiner\n // so the icon button gets vertical aligned\n // we need the dnb-button__text for alignment\n !content && icon && (\n <span\n key=\"button-alignment\"\n className=\"dnb-button__alignment\"\n aria-hidden\n >\n &zwnj;\n </span>\n )\n }\n\n {icon &&\n (pickIcon(icon) || (\n <IconPrimary\n key=\"button-icon\"\n className=\"dnb-button__icon\"\n icon={icon}\n size={icon_size}\n aria-hidden={isIconOnly && !title ? null : true}\n skeleton={skeleton}\n />\n ))}\n </>\n )\n}\n\nContent.propTypes = {\n title: PropTypes.node,\n custom_content: PropTypes.node,\n content: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.array,\n PropTypes.node,\n ]),\n icon: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.node,\n PropTypes.func,\n ]),\n icon_size: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n bounding: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.bool,\n isIconOnly: PropTypes.bool,\n}\n\nContent.defaultProps = {\n custom_content: null,\n title: null,\n content: null,\n icon: null,\n icon_size: 'default',\n bounding: null,\n skeleton: null,\n isIconOnly: null,\n}\n\nButton._formElement = true\nButton._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -6,8 +6,16 @@
6
6
  --button-tertiary-focus-left: -0.5rem;
7
7
  --button-tertiary-focus-right: -0.5rem;
8
8
  --button-tertiary-focus-overflow--icon-top: -0.5rem;
9
+ --button-tertiary-underline-left: var(
10
+ --button-tertiary-underline-overflow
11
+ );
12
+ --button-tertiary-underline-right: var(
13
+ --button-tertiary-underline-overflow
14
+ );
9
15
  --button-tertiary-underline-overflow: 0;
10
- --button-tertiary-underline-overflow--icon: -0.5rem;
16
+ --button-tertiary-underline-overflow--icon: calc(
17
+ (var(--button-icon-gutter) + var(--button-icon-size)) * -1
18
+ );
11
19
  // create underline (::after)
12
20
  .dnb-button__text {
13
21
  position: relative; // because of the underline
@@ -19,8 +27,8 @@
19
27
  [data-visual-test-wrapper] & {
20
28
  transition: none;
21
29
  }
22
- left: var(--button-tertiary-underline-overflow);
23
- right: var(--button-tertiary-underline-overflow);
30
+ left: var(--button-tertiary-underline-left);
31
+ right: var(--button-tertiary-underline-right);
24
32
  }
25
33
  }
26
34
 
@@ -62,28 +70,14 @@
62
70
  }
63
71
 
64
72
  &.dnb-button--has-text {
65
- padding-left: 0;
66
- padding-right: 0;
73
+ --button-padding-left: 0;
74
+ --button-padding-right: 0;
75
+ --button-icon-margin-top: calc(
76
+ (var(--button-height) - var(--button-icon-size)) / 2
77
+ );
67
78
 
68
79
  .dnb-button__icon {
69
80
  align-self: flex-start; // needed to vertically center icon
70
-
71
- margin-top: calc(var(--button-height) / 2 - 0.5rem);
72
- &.dnb-icon--medium {
73
- margin-top: calc(var(--button-height) / 2 - 0.75rem);
74
- }
75
- &.dnb-icon--large {
76
- margin-top: calc(var(--button-height) / 2 - 1rem);
77
- }
78
- }
79
- &.dnb-button--size-large .dnb-button__icon {
80
- margin-top: calc(var(--button-height--large) / 2 - 0.5rem);
81
- }
82
- &.dnb-button--size-medium .dnb-button__icon {
83
- margin-top: calc(var(--button-height--medium) / 2 - 0.5rem);
84
- }
85
- &.dnb-button--size-small .dnb-button__icon {
86
- margin-top: calc(var(--button-height--small) / 2 - 0.5rem);
87
81
  }
88
82
  }
89
83
 
@@ -99,10 +93,8 @@
99
93
  vertical-align: middle;
100
94
 
101
95
  &.dnb-button--has-text {
102
- padding: 0;
103
-
96
+ --button-icon-margin-top: 0.5rem;
104
97
  .dnb-button__icon {
105
- margin-top: 0.5rem;
106
98
  align-self: center;
107
99
  }
108
100
  }
@@ -126,61 +118,24 @@
126
118
 
127
119
  &.dnb-button--has-icon {
128
120
  &.dnb-button--has-text {
121
+ &.dnb-button--icon-size-medium,
122
+ &.dnb-button--icon-size-large {
123
+ --button-tertiary-underline-overflow--icon: var(
124
+ --button-tertiary-underline-overflow
125
+ );
126
+ }
127
+
129
128
  &.dnb-button--icon-position-left {
130
129
  --button-tertiary-focus-right: -1rem;
131
- .dnb-button__text {
132
- padding-left: 1rem;
133
-
134
- // underline
135
- &::after {
136
- left: var(--button-tertiary-underline-overflow--icon);
137
- }
138
- }
139
- .dnb-button__icon {
140
- margin-right: -0.5rem;
141
- margin-left: 0;
142
- }
143
- &.dnb-button--icon-size-medium,
144
- &.dnb-button--icon-size-large {
145
- .dnb-button__text {
146
- padding-left: 0;
147
- margin-left: 1rem;
148
-
149
- // underline
150
- &::after {
151
- left: 0;
152
- }
153
- }
154
- }
130
+ --button-tertiary-underline-left: var(
131
+ --button-tertiary-underline-overflow--icon
132
+ );
155
133
  }
156
134
  &.dnb-button--icon-position-right {
157
135
  --button-tertiary-focus-left: -1rem;
158
- /* stylelint-disable */
159
- .dnb-button__text {
160
- padding-right: 1rem;
161
-
162
- // underline
163
- &::after {
164
- right: var(--button-tertiary-underline-overflow--icon);
165
- }
166
- }
167
- .dnb-button__icon {
168
- margin-left: -0.5rem;
169
- margin-right: 0;
170
- }
171
- /* stylelint-enable */
172
- &.dnb-button--icon-size-medium,
173
- &.dnb-button--icon-size-large {
174
- .dnb-button__text {
175
- padding-right: 0;
176
- margin-right: 1rem;
177
-
178
- // underlinex
179
- &::after {
180
- right: 0;
181
- }
182
- }
183
- }
136
+ --button-tertiary-underline-right: var(
137
+ --button-tertiary-underline-overflow--icon
138
+ );
184
139
  }
185
140
  }
186
141