@dnb/eufemia 10.6.0 → 10.8.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 (1125) hide show
  1. package/CHANGELOG.md +55 -0
  2. package/cjs/components/accordion/Accordion.d.ts +1 -1
  3. package/cjs/components/accordion/AccordionHeader.d.ts +4 -4
  4. package/cjs/components/accordion/AccordionHeader.js +18 -5
  5. package/cjs/components/accordion/AccordionHeader.js.map +1 -1
  6. package/cjs/components/accordion/style/dnb-accordion.css +22 -17
  7. package/cjs/components/accordion/style/dnb-accordion.min.css +1 -1
  8. package/cjs/components/accordion/style/dnb-accordion.scss +40 -18
  9. package/cjs/components/accordion/style/themes/dnb-accordion-theme-sbanken.css +124 -0
  10. package/cjs/components/accordion/style/themes/dnb-accordion-theme-sbanken.min.css +1 -0
  11. package/cjs/components/accordion/style/themes/dnb-accordion-theme-sbanken.scss +125 -0
  12. package/cjs/components/anchor/Anchor.js +1 -1
  13. package/cjs/components/anchor/Anchor.js.map +1 -1
  14. package/cjs/components/anchor/style/anchor-mixins.scss +9 -3
  15. package/cjs/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +3 -1
  16. package/cjs/components/autocomplete/Autocomplete.d.ts +1 -1
  17. package/cjs/components/autocomplete/Autocomplete.js +4 -2
  18. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  19. package/cjs/components/avatar/style/index.d.ts +1 -1
  20. package/cjs/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -1
  21. package/cjs/components/breadcrumb/Breadcrumb.js +2 -2
  22. package/cjs/components/breadcrumb/Breadcrumb.js.map +1 -1
  23. package/cjs/components/breadcrumb/BreadcrumbItem.js +23 -1
  24. package/cjs/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  25. package/cjs/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.css +23 -0
  26. package/cjs/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.min.css +1 -0
  27. package/cjs/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.scss +33 -0
  28. package/cjs/components/button/style/dnb-button--tertiary.css +53 -37
  29. package/cjs/components/button/style/dnb-button--tertiary.min.css +5 -1
  30. package/cjs/components/button/style/dnb-button--tertiary.scss +28 -34
  31. package/cjs/components/button/style/themes/button-mixins.scss +5 -3
  32. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.css +53 -37
  33. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.min.css +5 -1
  34. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.css +155 -136
  35. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.min.css +12 -2
  36. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.scss +81 -115
  37. package/cjs/components/button/style/themes/dnb-button-theme-ui.css +53 -37
  38. package/cjs/components/button/style/themes/dnb-button-theme-ui.min.css +5 -1
  39. package/cjs/components/button/style/themes/dnb-button-theme-ui.scss +3 -1
  40. package/cjs/components/checkbox/Checkbox.d.ts +4 -0
  41. package/cjs/components/checkbox/Checkbox.js +6 -4
  42. package/cjs/components/checkbox/Checkbox.js.map +1 -1
  43. package/cjs/components/checkbox/style/themes/dnb-checkbox-theme-ui.scss +3 -1
  44. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +6 -2
  45. package/cjs/components/drawer/Drawer.d.ts +1 -1
  46. package/cjs/components/drawer/Drawer.js +3 -1
  47. package/cjs/components/drawer/Drawer.js.map +1 -1
  48. package/cjs/components/form-label/style/dnb-form-label.css +0 -1
  49. package/cjs/components/form-label/style/dnb-form-label.min.css +1 -1
  50. package/cjs/components/form-label/style/dnb-form-label.scss +0 -1
  51. package/cjs/components/form-label/style/themes/dnb-form-label-theme-sbanken.css +10 -0
  52. package/cjs/components/form-label/style/themes/dnb-form-label-theme-sbanken.min.css +1 -0
  53. package/cjs/components/form-label/style/themes/dnb-form-label-theme-sbanken.scss +16 -0
  54. package/cjs/components/form-label/style/themes/dnb-form-label-theme-ui.css +3 -0
  55. package/cjs/components/form-label/style/themes/dnb-form-label-theme-ui.min.css +1 -1
  56. package/cjs/components/form-label/style/themes/dnb-form-label-theme-ui.scss +6 -2
  57. package/cjs/components/form-row/style/themes/dnb-form-row-theme-sbanken.css +4 -0
  58. package/cjs/components/form-row/style/themes/dnb-form-row-theme-sbanken.min.css +0 -0
  59. package/cjs/components/form-row/style/themes/dnb-form-row-theme-sbanken.scss +4 -0
  60. package/cjs/components/form-status/FormStatus.d.ts +2 -0
  61. package/cjs/components/form-status/FormStatus.js +70 -53
  62. package/cjs/components/form-status/FormStatus.js.map +1 -1
  63. package/cjs/components/form-status/style/dnb-form-status.scss +4 -2
  64. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +37 -0
  65. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -0
  66. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +35 -0
  67. package/cjs/components/global-status/GlobalStatus.d.ts +1 -1
  68. package/cjs/components/global-status/GlobalStatus.js +17 -7
  69. package/cjs/components/global-status/GlobalStatus.js.map +1 -1
  70. package/cjs/components/global-status/style/dnb-global-status.scss +2 -1
  71. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +22 -0
  72. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -0
  73. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +28 -0
  74. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.css +6 -3
  75. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  76. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.scss +13 -6
  77. package/cjs/components/heading/Heading.d.ts +8 -8
  78. package/cjs/components/heading/Heading.js +8 -16
  79. package/cjs/components/heading/Heading.js.map +1 -1
  80. package/cjs/components/heading/HeadingHelpers.d.ts +5 -1
  81. package/cjs/components/heading/HeadingHelpers.js +42 -1
  82. package/cjs/components/heading/HeadingHelpers.js.map +1 -1
  83. package/cjs/components/info-card/index.js.map +1 -1
  84. package/cjs/components/info-card/style.js.map +1 -1
  85. package/cjs/components/input/style/themes/dnb-input-theme-sbanken.css +20 -20
  86. package/cjs/components/input/style/themes/dnb-input-theme-sbanken.min.css +1 -1
  87. package/cjs/components/input/style/themes/dnb-input-theme-sbanken.scss +15 -23
  88. package/cjs/components/input/style/themes/dnb-input-theme-ui.css +1 -1
  89. package/cjs/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  90. package/cjs/components/input/style/themes/dnb-input-theme-ui.scss +9 -3
  91. package/cjs/components/input-masked/InputMaskedUtils.js +1 -1
  92. package/cjs/components/input-masked/InputMaskedUtils.js.map +1 -1
  93. package/cjs/components/modal/Modal.js.map +1 -1
  94. package/cjs/components/modal/parts/ModalHeaderBar.js +0 -4
  95. package/cjs/components/modal/parts/ModalHeaderBar.js.map +1 -1
  96. package/cjs/components/pagination/Pagination.js.map +1 -1
  97. package/cjs/components/pagination/style/dnb-pagination.css +20 -0
  98. package/cjs/components/pagination/style/dnb-pagination.min.css +1 -1
  99. package/cjs/components/pagination/style/dnb-pagination.scss +24 -0
  100. package/cjs/components/pagination/style/themes/dnb-pagination-theme-sbanken.css +26 -0
  101. package/cjs/components/pagination/style/themes/dnb-pagination-theme-sbanken.min.css +1 -0
  102. package/cjs/components/pagination/style/themes/dnb-pagination-theme-sbanken.scss +35 -0
  103. package/cjs/components/pagination/style/themes/dnb-pagination-theme-ui.css +0 -24
  104. package/cjs/components/pagination/style/themes/dnb-pagination-theme-ui.min.css +1 -1
  105. package/cjs/components/pagination/style/themes/dnb-pagination-theme-ui.scss +0 -30
  106. package/cjs/components/radio/Radio.d.ts +4 -0
  107. package/cjs/components/radio/Radio.js +6 -4
  108. package/cjs/components/radio/Radio.js.map +1 -1
  109. package/cjs/components/radio/style/themes/dnb-radio-theme-ui.scss +15 -5
  110. package/cjs/components/section/Section.d.ts +26 -1
  111. package/cjs/components/section/Section.js +3 -2
  112. package/cjs/components/section/Section.js.map +1 -1
  113. package/cjs/components/section/style/dnb-section.css +1 -1
  114. package/cjs/components/section/style/dnb-section.scss +8 -3
  115. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.css +39 -0
  116. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -0
  117. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.scss +56 -0
  118. package/cjs/components/section/style/themes/dnb-section-theme-ui.css +28 -13
  119. package/cjs/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  120. package/cjs/components/section/style/themes/dnb-section-theme-ui.scss +37 -14
  121. package/cjs/components/skeleton/style/dnb-skeleton.scss +8 -5
  122. package/cjs/components/slider/style/dnb-slider.scss +4 -2
  123. package/cjs/components/space/SpacingUtils.js.map +1 -1
  124. package/cjs/components/step-indicator/StepIndicator.d.ts +89 -75
  125. package/cjs/components/step-indicator/StepIndicator.js +31 -26
  126. package/cjs/components/step-indicator/StepIndicator.js.map +1 -1
  127. package/cjs/components/step-indicator/StepIndicatorContext.d.ts +45 -15
  128. package/cjs/components/step-indicator/StepIndicatorContext.js +102 -121
  129. package/cjs/components/step-indicator/StepIndicatorContext.js.map +1 -1
  130. package/cjs/components/step-indicator/StepIndicatorItem.d.ts +59 -61
  131. package/cjs/components/step-indicator/StepIndicatorItem.js +183 -231
  132. package/cjs/components/step-indicator/StepIndicatorItem.js.map +1 -1
  133. package/cjs/components/step-indicator/StepIndicatorList.d.ts +6 -8
  134. package/cjs/components/step-indicator/StepIndicatorList.js +45 -50
  135. package/cjs/components/step-indicator/StepIndicatorList.js.map +1 -1
  136. package/cjs/components/step-indicator/StepIndicatorModal.d.ts +6 -14
  137. package/cjs/components/step-indicator/StepIndicatorModal.js +41 -53
  138. package/cjs/components/step-indicator/StepIndicatorModal.js.map +1 -1
  139. package/cjs/components/step-indicator/StepIndicatorProps.d.ts +2 -55
  140. package/cjs/components/step-indicator/StepIndicatorProps.js +4 -50
  141. package/cjs/components/step-indicator/StepIndicatorProps.js.map +1 -1
  142. package/cjs/components/step-indicator/StepIndicatorSidebar.d.ts +27 -21
  143. package/cjs/components/step-indicator/StepIndicatorSidebar.js +41 -51
  144. package/cjs/components/step-indicator/StepIndicatorSidebar.js.map +1 -1
  145. package/cjs/components/step-indicator/StepIndicatorTriggerButton.d.ts +16 -17
  146. package/cjs/components/step-indicator/StepIndicatorTriggerButton.js +65 -78
  147. package/cjs/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  148. package/cjs/components/switch/Switch.d.ts +4 -0
  149. package/cjs/components/switch/Switch.js +6 -4
  150. package/cjs/components/switch/Switch.js.map +1 -1
  151. package/cjs/components/switch/style/themes/dnb-switch-theme-ui.scss +3 -1
  152. package/cjs/components/table/TableContainer.js.map +1 -1
  153. package/cjs/components/table/style/table-accordion.scss +18 -6
  154. package/cjs/components/table/style/table-header-buttons.scss +3 -1
  155. package/cjs/components/table/style/table-tr.scss +6 -2
  156. package/cjs/components/table/style/themes/dnb-table-theme-sbanken.css +56 -7
  157. package/cjs/components/table/style/themes/dnb-table-theme-sbanken.min.css +1 -1
  158. package/cjs/components/table/style/themes/dnb-table-theme-sbanken.scss +21 -5
  159. package/cjs/components/table/style/themes/dnb-table-theme-ui.scss +3 -1
  160. package/cjs/components/timeline/TimelineItem.d.ts +3 -2
  161. package/cjs/components/timeline/TimelineItem.js +96 -62
  162. package/cjs/components/timeline/TimelineItem.js.map +1 -1
  163. package/cjs/components/timeline/style/themes/dnb-timeline-theme-ui.css +3 -2
  164. package/cjs/components/timeline/style/themes/dnb-timeline-theme-ui.min.css +3 -1
  165. package/cjs/components/timeline/style/themes/dnb-timeline-theme-ui.scss +3 -2
  166. package/cjs/components/toggle-button/style/themes/dnb-toggle-button-theme-ui.scss +3 -1
  167. package/cjs/elements/lib.d.ts +1 -1
  168. package/cjs/elements/typography/H.d.ts +5 -3
  169. package/cjs/elements/typography/H.js +7 -3
  170. package/cjs/elements/typography/H.js.map +1 -1
  171. package/cjs/elements/typography/H1.js +2 -2
  172. package/cjs/elements/typography/H1.js.map +1 -1
  173. package/cjs/elements/typography/H2.js +2 -2
  174. package/cjs/elements/typography/H2.js.map +1 -1
  175. package/cjs/elements/typography/H3.js +2 -2
  176. package/cjs/elements/typography/H3.js.map +1 -1
  177. package/cjs/elements/typography/H4.js +2 -2
  178. package/cjs/elements/typography/H4.js.map +1 -1
  179. package/cjs/elements/typography/H5.js +2 -2
  180. package/cjs/elements/typography/H5.js.map +1 -1
  181. package/cjs/elements/typography/H6.js +2 -2
  182. package/cjs/elements/typography/H6.js.map +1 -1
  183. package/cjs/elements/typography/style/dnb-typography.scss +3 -0
  184. package/cjs/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +12 -2
  185. package/cjs/elements/typography/style/typography-mixins.scss +5 -0
  186. package/cjs/extensions/forms/DataContext/Provider.js +9 -9
  187. package/cjs/extensions/forms/DataContext/Provider.js.map +1 -1
  188. package/cjs/extensions/forms/DataContext/index.js.map +1 -1
  189. package/cjs/extensions/forms/Field/ArraySelection.d.ts +2 -1
  190. package/cjs/extensions/forms/Field/ArraySelection.js +52 -32
  191. package/cjs/extensions/forms/Field/ArraySelection.js.map +1 -1
  192. package/cjs/extensions/forms/Field/CountryCode.d.ts +10 -0
  193. package/cjs/extensions/forms/Field/CountryCode.js +78 -0
  194. package/cjs/extensions/forms/Field/CountryCode.js.map +1 -0
  195. package/cjs/extensions/forms/Field/Currency.d.ts +2 -2
  196. package/cjs/extensions/forms/Field/Currency.js +6 -38
  197. package/cjs/extensions/forms/Field/Currency.js.map +1 -1
  198. package/cjs/extensions/forms/Field/Date.d.ts +2 -2
  199. package/cjs/extensions/forms/Field/Date.js +10 -6
  200. package/cjs/extensions/forms/Field/Date.js.map +1 -1
  201. package/cjs/extensions/forms/Field/Number.d.ts +7 -3
  202. package/cjs/extensions/forms/Field/Number.js +48 -22
  203. package/cjs/extensions/forms/Field/Number.js.map +1 -1
  204. package/cjs/extensions/forms/Field/PhoneNumber.d.ts +7 -2
  205. package/cjs/extensions/forms/Field/PhoneNumber.js +43 -42
  206. package/cjs/extensions/forms/Field/PhoneNumber.js.map +1 -1
  207. package/cjs/extensions/forms/Field/PostalCodeAndCity.d.ts +1 -1
  208. package/cjs/extensions/forms/Field/PostalCodeAndCity.js +1 -1
  209. package/cjs/extensions/forms/Field/PostalCodeAndCity.js.map +1 -1
  210. package/cjs/extensions/forms/Field/Selection.d.ts +6 -4
  211. package/cjs/extensions/forms/Field/Selection.js +88 -37
  212. package/cjs/extensions/forms/Field/Selection.js.map +1 -1
  213. package/cjs/extensions/forms/Field/String.d.ts +3 -3
  214. package/cjs/extensions/forms/Field/String.js +32 -17
  215. package/cjs/extensions/forms/Field/String.js.map +1 -1
  216. package/cjs/extensions/forms/Field/Toggle.js +11 -9
  217. package/cjs/extensions/forms/Field/Toggle.js.map +1 -1
  218. package/cjs/extensions/forms/Field/fields.scss +2 -2
  219. package/cjs/extensions/forms/Field/hooks/useField.d.ts +6 -8
  220. package/cjs/extensions/forms/Field/hooks/useField.js +34 -33
  221. package/cjs/extensions/forms/Field/hooks/useField.js.map +1 -1
  222. package/cjs/extensions/forms/Field/index.d.ts +2 -0
  223. package/cjs/extensions/forms/Field/index.js +3 -1
  224. package/cjs/extensions/forms/Field/index.js.map +1 -1
  225. package/cjs/extensions/forms/Field/style/dnb-array-selection.css +13 -0
  226. package/cjs/extensions/forms/Field/style/dnb-array-selection.min.css +1 -0
  227. package/cjs/extensions/forms/Field/style/dnb-array-selection.scss +15 -0
  228. package/cjs/extensions/forms/Field/style/dnb-country-code.css +12 -0
  229. package/cjs/extensions/forms/Field/style/dnb-country-code.min.css +1 -0
  230. package/cjs/extensions/forms/Field/style/dnb-country-code.scss +19 -0
  231. package/cjs/extensions/forms/Field/style/dnb-phone-number.css +6 -7
  232. package/cjs/extensions/forms/Field/style/dnb-phone-number.min.css +1 -1
  233. package/cjs/extensions/forms/Field/style/dnb-phone-number.scss +7 -8
  234. package/cjs/extensions/forms/Field/style/dnb-postal-code-and-city.css +5 -2
  235. package/cjs/extensions/forms/Field/style/dnb-postal-code-and-city.min.css +1 -1
  236. package/cjs/extensions/forms/Field/style/dnb-postal-code-and-city.scss +5 -1
  237. package/cjs/extensions/forms/Field/style/dnb-selection.css +5 -2
  238. package/cjs/extensions/forms/Field/style/dnb-selection.min.css +1 -1
  239. package/cjs/extensions/forms/Field/style/dnb-selection.scss +7 -1
  240. package/cjs/extensions/forms/Field/style/index.d.ts +2 -1
  241. package/cjs/extensions/forms/Field/style/index.js +2 -1
  242. package/cjs/extensions/forms/Field/style/index.js.map +1 -1
  243. package/cjs/extensions/forms/Field/style/index.scss +2 -2
  244. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -0
  245. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +19 -9
  246. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  247. package/cjs/extensions/forms/FieldBlock/index.js.map +1 -1
  248. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +39 -1
  249. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  250. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +60 -1
  251. package/cjs/extensions/forms/FieldGroup/index.js.map +1 -1
  252. package/cjs/extensions/forms/Layout/Card.js +2 -2
  253. package/cjs/extensions/forms/Layout/Card.js.map +1 -1
  254. package/cjs/extensions/forms/Layout/FlexContainer.d.ts +1 -0
  255. package/cjs/extensions/forms/Layout/FlexContainer.js +5 -3
  256. package/cjs/extensions/forms/Layout/FlexContainer.js.map +1 -1
  257. package/cjs/extensions/forms/Layout/FlexItem.d.ts +1 -0
  258. package/cjs/extensions/forms/Layout/FlexItem.js +2 -1
  259. package/cjs/extensions/forms/Layout/FlexItem.js.map +1 -1
  260. package/cjs/extensions/forms/Layout/SubHeading.js +2 -1
  261. package/cjs/extensions/forms/Layout/SubHeading.js.map +1 -1
  262. package/cjs/extensions/forms/Layout/style/dnb-card.css +3 -3
  263. package/cjs/extensions/forms/Layout/style/dnb-card.min.css +1 -1
  264. package/cjs/extensions/forms/Layout/style/dnb-card.scss +6 -4
  265. package/cjs/extensions/forms/Layout/style/dnb-flex-container.css +9 -0
  266. package/cjs/extensions/forms/Layout/style/dnb-flex-container.min.css +1 -1
  267. package/cjs/extensions/forms/Layout/style/dnb-flex-container.scss +14 -0
  268. package/cjs/extensions/forms/Layout/style/dnb-flex-item.css +9 -0
  269. package/cjs/extensions/forms/Layout/style/dnb-flex-item.min.css +1 -1
  270. package/cjs/extensions/forms/Layout/style/dnb-flex-item.scss +14 -0
  271. package/cjs/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  272. package/cjs/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  273. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.css +11 -5
  274. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  275. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +10 -3
  276. package/cjs/extensions/forms/ValueBlock/index.js.map +1 -1
  277. package/cjs/extensions/forms/field-types.d.ts +7 -1
  278. package/cjs/extensions/forms/field-types.js.map +1 -1
  279. package/cjs/extensions/forms/style/dnb-forms.css +112 -42
  280. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  281. package/cjs/extensions/forms/style/index.d.ts +1 -0
  282. package/cjs/extensions/forms/style/index.js +4 -0
  283. package/cjs/extensions/forms/style/index.js.map +1 -0
  284. package/cjs/extensions/forms/utils/TestElement/style/dnb-test-element.css +2 -2
  285. package/cjs/extensions/forms/utils/TestElement/style/dnb-test-element.min.css +1 -1
  286. package/cjs/extensions/forms/utils/TestElement/style/dnb-test-element.scss +2 -2
  287. package/cjs/extensions/forms/utils/useWasChanged.d.ts +5 -0
  288. package/cjs/extensions/forms/utils/useWasChanged.js +62 -0
  289. package/cjs/extensions/forms/utils/useWasChanged.js.map +1 -0
  290. package/cjs/extensions/forms/variables.scss +3 -0
  291. package/cjs/extensions/lib.d.ts +1 -0
  292. package/cjs/extensions/payment-card/PaymentCard.d.ts +6 -2
  293. package/cjs/extensions/payment-card/PaymentCard.js +13 -2
  294. package/cjs/extensions/payment-card/PaymentCard.js.map +1 -1
  295. package/cjs/extensions/payment-card/icons/CardIn.d.ts +2 -0
  296. package/cjs/extensions/payment-card/icons/CardIn.js +26 -0
  297. package/cjs/extensions/payment-card/icons/CardIn.js.map +1 -0
  298. package/cjs/extensions/payment-card/icons/index.js +4 -1
  299. package/cjs/extensions/payment-card/icons/index.js.map +1 -1
  300. package/cjs/extensions/payment-card/style/dnb-payment-card.css +3 -2
  301. package/cjs/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
  302. package/cjs/extensions/payment-card/style/dnb-payment-card.scss +2 -2
  303. package/cjs/extensions/payment-card/utils/backgrounds/ung.js +1 -1
  304. package/cjs/extensions/payment-card/utils/backgrounds/ung.js.map +1 -1
  305. package/cjs/extensions/payment-card/utils/backgrounds/youth.js +1 -1
  306. package/cjs/extensions/payment-card/utils/backgrounds/youth.js.map +1 -1
  307. package/cjs/fragments/drawer-list/DrawerList.js +1 -1
  308. package/cjs/fragments/drawer-list/DrawerList.js.map +1 -1
  309. package/cjs/fragments/drawer-list/DrawerListPortal.js +2 -2
  310. package/cjs/fragments/drawer-list/DrawerListPortal.js.map +1 -1
  311. package/cjs/fragments/drawer-list/style/dnb-drawer-list.scss +3 -1
  312. package/cjs/shared/Context.d.ts +2 -0
  313. package/cjs/shared/Context.js.map +1 -1
  314. package/cjs/shared/Eufemia.d.ts +1 -1
  315. package/cjs/shared/Eufemia.js +2 -2
  316. package/cjs/shared/Eufemia.js.map +1 -1
  317. package/cjs/shared/helpers/withCamelCaseProps.js.map +1 -1
  318. package/cjs/shared/helpers/withSnakeCaseProps.js.map +1 -1
  319. package/cjs/shared/libs/Shortcuts.js.map +1 -1
  320. package/cjs/shared/locales/en-GB.d.ts +2 -0
  321. package/cjs/shared/locales/en-GB.js +3 -1
  322. package/cjs/shared/locales/en-GB.js.map +1 -1
  323. package/cjs/shared/locales/en-US.d.ts +2 -0
  324. package/cjs/shared/locales/index.d.ts +4 -0
  325. package/cjs/shared/locales/nb-NO.d.ts +2 -0
  326. package/cjs/shared/locales/nb-NO.js +3 -1
  327. package/cjs/shared/locales/nb-NO.js.map +1 -1
  328. package/cjs/style/core/reset.scss +13 -3
  329. package/cjs/style/core/utilities.scss +3 -1
  330. package/cjs/style/dnb-ui-components.css +42 -19
  331. package/cjs/style/dnb-ui-components.min.css +1 -1
  332. package/cjs/style/dnb-ui-elements.css +6 -0
  333. package/cjs/style/dnb-ui-elements.min.css +1 -1
  334. package/cjs/style/dnb-ui-extensions.css +115 -44
  335. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  336. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +6 -0
  337. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  338. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +189 -135
  339. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -1
  340. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +115 -44
  341. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  342. package/cjs/style/themes/theme-sbanken/customisations.scss +0 -8
  343. package/cjs/style/themes/theme-sbanken/properties.js +6 -6
  344. package/cjs/style/themes/theme-sbanken/properties.js.map +1 -1
  345. package/cjs/style/themes/theme-sbanken/properties.scss +6 -6
  346. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +27 -26
  347. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  348. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +574 -615
  349. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +14 -2
  350. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +8 -7
  351. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +21 -2
  352. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  353. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +115 -44
  354. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  355. package/cjs/style/themes/theme-ui/fonts.scss +8 -4
  356. package/cjs/style/themes/theme-ui/ui-theme-basis.css +6 -0
  357. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  358. package/cjs/style/themes/theme-ui/ui-theme-components.css +136 -98
  359. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +7 -1
  360. package/cjs/style/themes/theme-ui/ui-theme-elements.css +6 -0
  361. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  362. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +115 -44
  363. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  364. package/cjs/style/themes/theme-ui/ui-theme-tags.css +3 -0
  365. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  366. package/cjs/style/themes/theme-ui/ui-theme-tags.scss +9 -4
  367. package/components/accordion/Accordion.d.ts +1 -1
  368. package/components/accordion/AccordionHeader.d.ts +4 -4
  369. package/components/accordion/AccordionHeader.js +18 -5
  370. package/components/accordion/AccordionHeader.js.map +1 -1
  371. package/components/accordion/style/dnb-accordion.css +22 -17
  372. package/components/accordion/style/dnb-accordion.min.css +1 -1
  373. package/components/accordion/style/dnb-accordion.scss +40 -18
  374. package/components/accordion/style/themes/dnb-accordion-theme-sbanken.css +124 -0
  375. package/components/accordion/style/themes/dnb-accordion-theme-sbanken.min.css +1 -0
  376. package/components/accordion/style/themes/dnb-accordion-theme-sbanken.scss +125 -0
  377. package/components/anchor/Anchor.js +1 -1
  378. package/components/anchor/Anchor.js.map +1 -1
  379. package/components/anchor/style/anchor-mixins.scss +9 -3
  380. package/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +3 -1
  381. package/components/autocomplete/Autocomplete.d.ts +1 -1
  382. package/components/autocomplete/Autocomplete.js +4 -2
  383. package/components/autocomplete/Autocomplete.js.map +1 -1
  384. package/components/avatar/style/index.d.ts +1 -1
  385. package/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -1
  386. package/components/breadcrumb/Breadcrumb.js +2 -2
  387. package/components/breadcrumb/Breadcrumb.js.map +1 -1
  388. package/components/breadcrumb/BreadcrumbItem.js +23 -1
  389. package/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  390. package/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.css +23 -0
  391. package/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.min.css +1 -0
  392. package/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.scss +33 -0
  393. package/components/button/style/dnb-button--tertiary.css +53 -37
  394. package/components/button/style/dnb-button--tertiary.min.css +5 -1
  395. package/components/button/style/dnb-button--tertiary.scss +28 -34
  396. package/components/button/style/themes/button-mixins.scss +5 -3
  397. package/components/button/style/themes/dnb-button-theme-eiendom.css +53 -37
  398. package/components/button/style/themes/dnb-button-theme-eiendom.min.css +5 -1
  399. package/components/button/style/themes/dnb-button-theme-sbanken.css +155 -136
  400. package/components/button/style/themes/dnb-button-theme-sbanken.min.css +12 -2
  401. package/components/button/style/themes/dnb-button-theme-sbanken.scss +81 -115
  402. package/components/button/style/themes/dnb-button-theme-ui.css +53 -37
  403. package/components/button/style/themes/dnb-button-theme-ui.min.css +5 -1
  404. package/components/button/style/themes/dnb-button-theme-ui.scss +3 -1
  405. package/components/checkbox/Checkbox.d.ts +4 -0
  406. package/components/checkbox/Checkbox.js +6 -4
  407. package/components/checkbox/Checkbox.js.map +1 -1
  408. package/components/checkbox/style/themes/dnb-checkbox-theme-ui.scss +3 -1
  409. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +6 -2
  410. package/components/drawer/Drawer.d.ts +1 -1
  411. package/components/drawer/Drawer.js +3 -1
  412. package/components/drawer/Drawer.js.map +1 -1
  413. package/components/form-label/style/dnb-form-label.css +0 -1
  414. package/components/form-label/style/dnb-form-label.min.css +1 -1
  415. package/components/form-label/style/dnb-form-label.scss +0 -1
  416. package/components/form-label/style/themes/dnb-form-label-theme-sbanken.css +10 -0
  417. package/components/form-label/style/themes/dnb-form-label-theme-sbanken.min.css +1 -0
  418. package/components/form-label/style/themes/dnb-form-label-theme-sbanken.scss +16 -0
  419. package/components/form-label/style/themes/dnb-form-label-theme-ui.css +3 -0
  420. package/components/form-label/style/themes/dnb-form-label-theme-ui.min.css +1 -1
  421. package/components/form-label/style/themes/dnb-form-label-theme-ui.scss +6 -2
  422. package/components/form-row/style/themes/dnb-form-row-theme-sbanken.css +4 -0
  423. package/components/form-row/style/themes/dnb-form-row-theme-sbanken.min.css +0 -0
  424. package/components/form-row/style/themes/dnb-form-row-theme-sbanken.scss +4 -0
  425. package/components/form-status/FormStatus.d.ts +2 -0
  426. package/components/form-status/FormStatus.js +70 -53
  427. package/components/form-status/FormStatus.js.map +1 -1
  428. package/components/form-status/style/dnb-form-status.scss +4 -2
  429. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +37 -0
  430. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -0
  431. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +35 -0
  432. package/components/global-status/GlobalStatus.d.ts +1 -1
  433. package/components/global-status/GlobalStatus.js +18 -8
  434. package/components/global-status/GlobalStatus.js.map +1 -1
  435. package/components/global-status/style/dnb-global-status.scss +2 -1
  436. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +22 -0
  437. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -0
  438. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +28 -0
  439. package/components/global-status/style/themes/dnb-global-status-theme-ui.css +6 -3
  440. package/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  441. package/components/global-status/style/themes/dnb-global-status-theme-ui.scss +13 -6
  442. package/components/heading/Heading.d.ts +8 -8
  443. package/components/heading/Heading.js +9 -15
  444. package/components/heading/Heading.js.map +1 -1
  445. package/components/heading/HeadingHelpers.d.ts +5 -1
  446. package/components/heading/HeadingHelpers.js +39 -0
  447. package/components/heading/HeadingHelpers.js.map +1 -1
  448. package/components/info-card/index.js.map +1 -1
  449. package/components/info-card/style.js.map +1 -1
  450. package/components/input/style/themes/dnb-input-theme-sbanken.css +20 -20
  451. package/components/input/style/themes/dnb-input-theme-sbanken.min.css +1 -1
  452. package/components/input/style/themes/dnb-input-theme-sbanken.scss +15 -23
  453. package/components/input/style/themes/dnb-input-theme-ui.css +1 -1
  454. package/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  455. package/components/input/style/themes/dnb-input-theme-ui.scss +9 -3
  456. package/components/input-masked/InputMaskedUtils.js +1 -1
  457. package/components/input-masked/InputMaskedUtils.js.map +1 -1
  458. package/components/modal/Modal.js.map +1 -1
  459. package/components/modal/parts/ModalHeaderBar.js +0 -4
  460. package/components/modal/parts/ModalHeaderBar.js.map +1 -1
  461. package/components/pagination/Pagination.js.map +1 -1
  462. package/components/pagination/style/dnb-pagination.css +20 -0
  463. package/components/pagination/style/dnb-pagination.min.css +1 -1
  464. package/components/pagination/style/dnb-pagination.scss +24 -0
  465. package/components/pagination/style/themes/dnb-pagination-theme-sbanken.css +26 -0
  466. package/components/pagination/style/themes/dnb-pagination-theme-sbanken.min.css +1 -0
  467. package/components/pagination/style/themes/dnb-pagination-theme-sbanken.scss +35 -0
  468. package/components/pagination/style/themes/dnb-pagination-theme-ui.css +0 -24
  469. package/components/pagination/style/themes/dnb-pagination-theme-ui.min.css +1 -1
  470. package/components/pagination/style/themes/dnb-pagination-theme-ui.scss +0 -30
  471. package/components/radio/Radio.d.ts +4 -0
  472. package/components/radio/Radio.js +6 -4
  473. package/components/radio/Radio.js.map +1 -1
  474. package/components/radio/style/themes/dnb-radio-theme-ui.scss +15 -5
  475. package/components/section/Section.d.ts +26 -1
  476. package/components/section/Section.js +3 -2
  477. package/components/section/Section.js.map +1 -1
  478. package/components/section/style/dnb-section.css +1 -1
  479. package/components/section/style/dnb-section.scss +8 -3
  480. package/components/section/style/themes/dnb-section-theme-sbanken.css +39 -0
  481. package/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -0
  482. package/components/section/style/themes/dnb-section-theme-sbanken.scss +56 -0
  483. package/components/section/style/themes/dnb-section-theme-ui.css +28 -13
  484. package/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  485. package/components/section/style/themes/dnb-section-theme-ui.scss +37 -14
  486. package/components/skeleton/style/dnb-skeleton.scss +8 -5
  487. package/components/slider/style/dnb-slider.scss +4 -2
  488. package/components/space/SpacingUtils.js.map +1 -1
  489. package/components/step-indicator/StepIndicator.d.ts +89 -75
  490. package/components/step-indicator/StepIndicator.js +29 -25
  491. package/components/step-indicator/StepIndicator.js.map +1 -1
  492. package/components/step-indicator/StepIndicatorContext.d.ts +45 -15
  493. package/components/step-indicator/StepIndicatorContext.js +98 -120
  494. package/components/step-indicator/StepIndicatorContext.js.map +1 -1
  495. package/components/step-indicator/StepIndicatorItem.d.ts +59 -61
  496. package/components/step-indicator/StepIndicatorItem.js +177 -227
  497. package/components/step-indicator/StepIndicatorItem.js.map +1 -1
  498. package/components/step-indicator/StepIndicatorList.d.ts +6 -8
  499. package/components/step-indicator/StepIndicatorList.js +43 -48
  500. package/components/step-indicator/StepIndicatorList.js.map +1 -1
  501. package/components/step-indicator/StepIndicatorModal.d.ts +6 -14
  502. package/components/step-indicator/StepIndicatorModal.js +38 -50
  503. package/components/step-indicator/StepIndicatorModal.js.map +1 -1
  504. package/components/step-indicator/StepIndicatorProps.d.ts +2 -55
  505. package/components/step-indicator/StepIndicatorProps.js +3 -45
  506. package/components/step-indicator/StepIndicatorProps.js.map +1 -1
  507. package/components/step-indicator/StepIndicatorSidebar.d.ts +27 -21
  508. package/components/step-indicator/StepIndicatorSidebar.js +39 -52
  509. package/components/step-indicator/StepIndicatorSidebar.js.map +1 -1
  510. package/components/step-indicator/StepIndicatorTriggerButton.d.ts +16 -17
  511. package/components/step-indicator/StepIndicatorTriggerButton.js +62 -78
  512. package/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  513. package/components/switch/Switch.d.ts +4 -0
  514. package/components/switch/Switch.js +6 -4
  515. package/components/switch/Switch.js.map +1 -1
  516. package/components/switch/style/themes/dnb-switch-theme-ui.scss +3 -1
  517. package/components/table/TableContainer.js.map +1 -1
  518. package/components/table/style/table-accordion.scss +18 -6
  519. package/components/table/style/table-header-buttons.scss +3 -1
  520. package/components/table/style/table-tr.scss +6 -2
  521. package/components/table/style/themes/dnb-table-theme-sbanken.css +56 -7
  522. package/components/table/style/themes/dnb-table-theme-sbanken.min.css +1 -1
  523. package/components/table/style/themes/dnb-table-theme-sbanken.scss +21 -5
  524. package/components/table/style/themes/dnb-table-theme-ui.scss +3 -1
  525. package/components/timeline/TimelineItem.d.ts +3 -2
  526. package/components/timeline/TimelineItem.js +95 -61
  527. package/components/timeline/TimelineItem.js.map +1 -1
  528. package/components/timeline/style/themes/dnb-timeline-theme-ui.css +3 -2
  529. package/components/timeline/style/themes/dnb-timeline-theme-ui.min.css +3 -1
  530. package/components/timeline/style/themes/dnb-timeline-theme-ui.scss +3 -2
  531. package/components/toggle-button/style/themes/dnb-toggle-button-theme-ui.scss +3 -1
  532. package/elements/lib.d.ts +1 -1
  533. package/elements/typography/H.d.ts +5 -3
  534. package/elements/typography/H.js +8 -4
  535. package/elements/typography/H.js.map +1 -1
  536. package/elements/typography/H1.js +2 -2
  537. package/elements/typography/H1.js.map +1 -1
  538. package/elements/typography/H2.js +2 -2
  539. package/elements/typography/H2.js.map +1 -1
  540. package/elements/typography/H3.js +2 -2
  541. package/elements/typography/H3.js.map +1 -1
  542. package/elements/typography/H4.js +2 -2
  543. package/elements/typography/H4.js.map +1 -1
  544. package/elements/typography/H5.js +2 -2
  545. package/elements/typography/H5.js.map +1 -1
  546. package/elements/typography/H6.js +2 -2
  547. package/elements/typography/H6.js.map +1 -1
  548. package/elements/typography/style/dnb-typography.scss +3 -0
  549. package/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +12 -2
  550. package/elements/typography/style/typography-mixins.scss +5 -0
  551. package/es/components/accordion/Accordion.d.ts +1 -1
  552. package/es/components/accordion/AccordionHeader.d.ts +4 -4
  553. package/es/components/accordion/AccordionHeader.js +18 -5
  554. package/es/components/accordion/AccordionHeader.js.map +1 -1
  555. package/es/components/accordion/style/dnb-accordion.css +22 -17
  556. package/es/components/accordion/style/dnb-accordion.min.css +1 -1
  557. package/es/components/accordion/style/dnb-accordion.scss +40 -18
  558. package/es/components/accordion/style/themes/dnb-accordion-theme-sbanken.css +124 -0
  559. package/es/components/accordion/style/themes/dnb-accordion-theme-sbanken.min.css +1 -0
  560. package/es/components/accordion/style/themes/dnb-accordion-theme-sbanken.scss +125 -0
  561. package/es/components/anchor/Anchor.js +1 -1
  562. package/es/components/anchor/Anchor.js.map +1 -1
  563. package/es/components/anchor/style/anchor-mixins.scss +9 -3
  564. package/es/components/anchor/style/themes/dnb-anchor-theme-sbanken.scss +3 -1
  565. package/es/components/autocomplete/Autocomplete.d.ts +1 -1
  566. package/es/components/autocomplete/Autocomplete.js +4 -2
  567. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  568. package/es/components/avatar/style/index.d.ts +1 -1
  569. package/es/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -1
  570. package/es/components/breadcrumb/Breadcrumb.js +2 -2
  571. package/es/components/breadcrumb/Breadcrumb.js.map +1 -1
  572. package/es/components/breadcrumb/BreadcrumbItem.js +23 -1
  573. package/es/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  574. package/es/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.css +23 -0
  575. package/es/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.min.css +1 -0
  576. package/es/components/breadcrumb/style/themes/dnb-breadcrumb-theme-sbanken.scss +33 -0
  577. package/es/components/button/style/dnb-button--tertiary.css +53 -37
  578. package/es/components/button/style/dnb-button--tertiary.min.css +5 -1
  579. package/es/components/button/style/dnb-button--tertiary.scss +28 -34
  580. package/es/components/button/style/themes/button-mixins.scss +5 -3
  581. package/es/components/button/style/themes/dnb-button-theme-eiendom.css +53 -37
  582. package/es/components/button/style/themes/dnb-button-theme-eiendom.min.css +5 -1
  583. package/es/components/button/style/themes/dnb-button-theme-sbanken.css +155 -136
  584. package/es/components/button/style/themes/dnb-button-theme-sbanken.min.css +12 -2
  585. package/es/components/button/style/themes/dnb-button-theme-sbanken.scss +81 -115
  586. package/es/components/button/style/themes/dnb-button-theme-ui.css +53 -37
  587. package/es/components/button/style/themes/dnb-button-theme-ui.min.css +5 -1
  588. package/es/components/button/style/themes/dnb-button-theme-ui.scss +3 -1
  589. package/es/components/checkbox/Checkbox.d.ts +4 -0
  590. package/es/components/checkbox/Checkbox.js +6 -4
  591. package/es/components/checkbox/Checkbox.js.map +1 -1
  592. package/es/components/checkbox/style/themes/dnb-checkbox-theme-ui.scss +3 -1
  593. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +6 -2
  594. package/es/components/drawer/Drawer.d.ts +1 -1
  595. package/es/components/drawer/Drawer.js +3 -1
  596. package/es/components/drawer/Drawer.js.map +1 -1
  597. package/es/components/form-label/style/dnb-form-label.css +0 -1
  598. package/es/components/form-label/style/dnb-form-label.min.css +1 -1
  599. package/es/components/form-label/style/dnb-form-label.scss +0 -1
  600. package/es/components/form-label/style/themes/dnb-form-label-theme-sbanken.css +10 -0
  601. package/es/components/form-label/style/themes/dnb-form-label-theme-sbanken.min.css +1 -0
  602. package/es/components/form-label/style/themes/dnb-form-label-theme-sbanken.scss +16 -0
  603. package/es/components/form-label/style/themes/dnb-form-label-theme-ui.css +3 -0
  604. package/es/components/form-label/style/themes/dnb-form-label-theme-ui.min.css +1 -1
  605. package/es/components/form-label/style/themes/dnb-form-label-theme-ui.scss +6 -2
  606. package/es/components/form-row/style/themes/dnb-form-row-theme-sbanken.css +4 -0
  607. package/es/components/form-row/style/themes/dnb-form-row-theme-sbanken.min.css +0 -0
  608. package/es/components/form-row/style/themes/dnb-form-row-theme-sbanken.scss +4 -0
  609. package/es/components/form-status/FormStatus.d.ts +2 -0
  610. package/es/components/form-status/FormStatus.js +70 -53
  611. package/es/components/form-status/FormStatus.js.map +1 -1
  612. package/es/components/form-status/style/dnb-form-status.scss +4 -2
  613. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +37 -0
  614. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -0
  615. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +35 -0
  616. package/es/components/global-status/GlobalStatus.d.ts +1 -1
  617. package/es/components/global-status/GlobalStatus.js +18 -8
  618. package/es/components/global-status/GlobalStatus.js.map +1 -1
  619. package/es/components/global-status/style/dnb-global-status.scss +2 -1
  620. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +22 -0
  621. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -0
  622. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +28 -0
  623. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.css +6 -3
  624. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  625. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.scss +13 -6
  626. package/es/components/heading/Heading.d.ts +8 -8
  627. package/es/components/heading/Heading.js +9 -15
  628. package/es/components/heading/Heading.js.map +1 -1
  629. package/es/components/heading/HeadingHelpers.d.ts +5 -1
  630. package/es/components/heading/HeadingHelpers.js +39 -0
  631. package/es/components/heading/HeadingHelpers.js.map +1 -1
  632. package/es/components/info-card/index.js.map +1 -1
  633. package/es/components/info-card/style.js.map +1 -1
  634. package/es/components/input/style/themes/dnb-input-theme-sbanken.css +20 -20
  635. package/es/components/input/style/themes/dnb-input-theme-sbanken.min.css +1 -1
  636. package/es/components/input/style/themes/dnb-input-theme-sbanken.scss +15 -23
  637. package/es/components/input/style/themes/dnb-input-theme-ui.css +1 -1
  638. package/es/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  639. package/es/components/input/style/themes/dnb-input-theme-ui.scss +9 -3
  640. package/es/components/input-masked/InputMaskedUtils.js +1 -1
  641. package/es/components/input-masked/InputMaskedUtils.js.map +1 -1
  642. package/es/components/modal/Modal.js.map +1 -1
  643. package/es/components/modal/parts/ModalHeaderBar.js +0 -4
  644. package/es/components/modal/parts/ModalHeaderBar.js.map +1 -1
  645. package/es/components/pagination/Pagination.js.map +1 -1
  646. package/es/components/pagination/style/dnb-pagination.css +20 -0
  647. package/es/components/pagination/style/dnb-pagination.min.css +1 -1
  648. package/es/components/pagination/style/dnb-pagination.scss +24 -0
  649. package/es/components/pagination/style/themes/dnb-pagination-theme-sbanken.css +26 -0
  650. package/es/components/pagination/style/themes/dnb-pagination-theme-sbanken.min.css +1 -0
  651. package/es/components/pagination/style/themes/dnb-pagination-theme-sbanken.scss +35 -0
  652. package/es/components/pagination/style/themes/dnb-pagination-theme-ui.css +0 -24
  653. package/es/components/pagination/style/themes/dnb-pagination-theme-ui.min.css +1 -1
  654. package/es/components/pagination/style/themes/dnb-pagination-theme-ui.scss +0 -30
  655. package/es/components/radio/Radio.d.ts +4 -0
  656. package/es/components/radio/Radio.js +6 -4
  657. package/es/components/radio/Radio.js.map +1 -1
  658. package/es/components/radio/style/themes/dnb-radio-theme-ui.scss +15 -5
  659. package/es/components/section/Section.d.ts +26 -1
  660. package/es/components/section/Section.js +3 -2
  661. package/es/components/section/Section.js.map +1 -1
  662. package/es/components/section/style/dnb-section.css +1 -1
  663. package/es/components/section/style/dnb-section.scss +8 -3
  664. package/es/components/section/style/themes/dnb-section-theme-sbanken.css +39 -0
  665. package/es/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -0
  666. package/es/components/section/style/themes/dnb-section-theme-sbanken.scss +56 -0
  667. package/es/components/section/style/themes/dnb-section-theme-ui.css +28 -13
  668. package/es/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  669. package/es/components/section/style/themes/dnb-section-theme-ui.scss +37 -14
  670. package/es/components/skeleton/style/dnb-skeleton.scss +8 -5
  671. package/es/components/slider/style/dnb-slider.scss +4 -2
  672. package/es/components/space/SpacingUtils.js.map +1 -1
  673. package/es/components/step-indicator/StepIndicator.d.ts +89 -75
  674. package/es/components/step-indicator/StepIndicator.js +29 -25
  675. package/es/components/step-indicator/StepIndicator.js.map +1 -1
  676. package/es/components/step-indicator/StepIndicatorContext.d.ts +45 -15
  677. package/es/components/step-indicator/StepIndicatorContext.js +94 -114
  678. package/es/components/step-indicator/StepIndicatorContext.js.map +1 -1
  679. package/es/components/step-indicator/StepIndicatorItem.d.ts +59 -61
  680. package/es/components/step-indicator/StepIndicatorItem.js +173 -223
  681. package/es/components/step-indicator/StepIndicatorItem.js.map +1 -1
  682. package/es/components/step-indicator/StepIndicatorList.d.ts +6 -8
  683. package/es/components/step-indicator/StepIndicatorList.js +43 -48
  684. package/es/components/step-indicator/StepIndicatorList.js.map +1 -1
  685. package/es/components/step-indicator/StepIndicatorModal.d.ts +6 -14
  686. package/es/components/step-indicator/StepIndicatorModal.js +38 -48
  687. package/es/components/step-indicator/StepIndicatorModal.js.map +1 -1
  688. package/es/components/step-indicator/StepIndicatorProps.d.ts +2 -55
  689. package/es/components/step-indicator/StepIndicatorProps.js +3 -45
  690. package/es/components/step-indicator/StepIndicatorProps.js.map +1 -1
  691. package/es/components/step-indicator/StepIndicatorSidebar.d.ts +27 -21
  692. package/es/components/step-indicator/StepIndicatorSidebar.js +39 -52
  693. package/es/components/step-indicator/StepIndicatorSidebar.js.map +1 -1
  694. package/es/components/step-indicator/StepIndicatorTriggerButton.d.ts +16 -17
  695. package/es/components/step-indicator/StepIndicatorTriggerButton.js +62 -78
  696. package/es/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  697. package/es/components/switch/Switch.d.ts +4 -0
  698. package/es/components/switch/Switch.js +6 -4
  699. package/es/components/switch/Switch.js.map +1 -1
  700. package/es/components/switch/style/themes/dnb-switch-theme-ui.scss +3 -1
  701. package/es/components/table/TableContainer.js.map +1 -1
  702. package/es/components/table/style/table-accordion.scss +18 -6
  703. package/es/components/table/style/table-header-buttons.scss +3 -1
  704. package/es/components/table/style/table-tr.scss +6 -2
  705. package/es/components/table/style/themes/dnb-table-theme-sbanken.css +56 -7
  706. package/es/components/table/style/themes/dnb-table-theme-sbanken.min.css +1 -1
  707. package/es/components/table/style/themes/dnb-table-theme-sbanken.scss +21 -5
  708. package/es/components/table/style/themes/dnb-table-theme-ui.scss +3 -1
  709. package/es/components/timeline/TimelineItem.d.ts +3 -2
  710. package/es/components/timeline/TimelineItem.js +89 -58
  711. package/es/components/timeline/TimelineItem.js.map +1 -1
  712. package/es/components/timeline/style/themes/dnb-timeline-theme-ui.css +3 -2
  713. package/es/components/timeline/style/themes/dnb-timeline-theme-ui.min.css +3 -1
  714. package/es/components/timeline/style/themes/dnb-timeline-theme-ui.scss +3 -2
  715. package/es/components/toggle-button/style/themes/dnb-toggle-button-theme-ui.scss +3 -1
  716. package/es/elements/lib.d.ts +1 -1
  717. package/es/elements/typography/H.d.ts +5 -3
  718. package/es/elements/typography/H.js +8 -4
  719. package/es/elements/typography/H.js.map +1 -1
  720. package/es/elements/typography/H1.js +2 -2
  721. package/es/elements/typography/H1.js.map +1 -1
  722. package/es/elements/typography/H2.js +2 -2
  723. package/es/elements/typography/H2.js.map +1 -1
  724. package/es/elements/typography/H3.js +2 -2
  725. package/es/elements/typography/H3.js.map +1 -1
  726. package/es/elements/typography/H4.js +2 -2
  727. package/es/elements/typography/H4.js.map +1 -1
  728. package/es/elements/typography/H5.js +2 -2
  729. package/es/elements/typography/H5.js.map +1 -1
  730. package/es/elements/typography/H6.js +2 -2
  731. package/es/elements/typography/H6.js.map +1 -1
  732. package/es/elements/typography/style/dnb-typography.scss +3 -0
  733. package/es/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +12 -2
  734. package/es/elements/typography/style/typography-mixins.scss +5 -0
  735. package/es/extensions/forms/DataContext/Provider.js +9 -9
  736. package/es/extensions/forms/DataContext/Provider.js.map +1 -1
  737. package/es/extensions/forms/DataContext/index.js.map +1 -1
  738. package/es/extensions/forms/Field/ArraySelection.d.ts +2 -1
  739. package/es/extensions/forms/Field/ArraySelection.js +49 -33
  740. package/es/extensions/forms/Field/ArraySelection.js.map +1 -1
  741. package/es/extensions/forms/Field/CountryCode.d.ts +10 -0
  742. package/es/extensions/forms/Field/CountryCode.js +67 -0
  743. package/es/extensions/forms/Field/CountryCode.js.map +1 -0
  744. package/es/extensions/forms/Field/Currency.d.ts +2 -2
  745. package/es/extensions/forms/Field/Currency.js +6 -37
  746. package/es/extensions/forms/Field/Currency.js.map +1 -1
  747. package/es/extensions/forms/Field/Date.d.ts +2 -2
  748. package/es/extensions/forms/Field/Date.js +11 -7
  749. package/es/extensions/forms/Field/Date.js.map +1 -1
  750. package/es/extensions/forms/Field/Number.d.ts +7 -3
  751. package/es/extensions/forms/Field/Number.js +47 -23
  752. package/es/extensions/forms/Field/Number.js.map +1 -1
  753. package/es/extensions/forms/Field/PhoneNumber.d.ts +7 -2
  754. package/es/extensions/forms/Field/PhoneNumber.js +44 -41
  755. package/es/extensions/forms/Field/PhoneNumber.js.map +1 -1
  756. package/es/extensions/forms/Field/PostalCodeAndCity.d.ts +1 -1
  757. package/es/extensions/forms/Field/PostalCodeAndCity.js +1 -1
  758. package/es/extensions/forms/Field/PostalCodeAndCity.js.map +1 -1
  759. package/es/extensions/forms/Field/Selection.d.ts +6 -4
  760. package/es/extensions/forms/Field/Selection.js +86 -38
  761. package/es/extensions/forms/Field/Selection.js.map +1 -1
  762. package/es/extensions/forms/Field/String.d.ts +3 -3
  763. package/es/extensions/forms/Field/String.js +33 -18
  764. package/es/extensions/forms/Field/String.js.map +1 -1
  765. package/es/extensions/forms/Field/Toggle.js +11 -9
  766. package/es/extensions/forms/Field/Toggle.js.map +1 -1
  767. package/es/extensions/forms/Field/fields.scss +2 -2
  768. package/es/extensions/forms/Field/hooks/useField.d.ts +6 -8
  769. package/es/extensions/forms/Field/hooks/useField.js +34 -31
  770. package/es/extensions/forms/Field/hooks/useField.js.map +1 -1
  771. package/es/extensions/forms/Field/index.d.ts +2 -0
  772. package/es/extensions/forms/Field/index.js +3 -1
  773. package/es/extensions/forms/Field/index.js.map +1 -1
  774. package/es/extensions/forms/Field/style/dnb-array-selection.css +13 -0
  775. package/es/extensions/forms/Field/style/dnb-array-selection.min.css +1 -0
  776. package/es/extensions/forms/Field/style/dnb-array-selection.scss +15 -0
  777. package/es/extensions/forms/Field/style/dnb-country-code.css +12 -0
  778. package/es/extensions/forms/Field/style/dnb-country-code.min.css +1 -0
  779. package/es/extensions/forms/Field/style/dnb-country-code.scss +19 -0
  780. package/es/extensions/forms/Field/style/dnb-phone-number.css +6 -7
  781. package/es/extensions/forms/Field/style/dnb-phone-number.min.css +1 -1
  782. package/es/extensions/forms/Field/style/dnb-phone-number.scss +7 -8
  783. package/es/extensions/forms/Field/style/dnb-postal-code-and-city.css +5 -2
  784. package/es/extensions/forms/Field/style/dnb-postal-code-and-city.min.css +1 -1
  785. package/es/extensions/forms/Field/style/dnb-postal-code-and-city.scss +5 -1
  786. package/es/extensions/forms/Field/style/dnb-selection.css +5 -2
  787. package/es/extensions/forms/Field/style/dnb-selection.min.css +1 -1
  788. package/es/extensions/forms/Field/style/dnb-selection.scss +7 -1
  789. package/es/extensions/forms/Field/style/index.d.ts +2 -1
  790. package/es/extensions/forms/Field/style/index.js +2 -1
  791. package/es/extensions/forms/Field/style/index.js.map +1 -1
  792. package/es/extensions/forms/Field/style/index.scss +2 -2
  793. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -0
  794. package/es/extensions/forms/FieldBlock/FieldBlock.js +19 -9
  795. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  796. package/es/extensions/forms/FieldBlock/index.js.map +1 -1
  797. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +39 -1
  798. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  799. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +60 -1
  800. package/es/extensions/forms/FieldGroup/index.js.map +1 -1
  801. package/es/extensions/forms/Layout/Card.js +2 -2
  802. package/es/extensions/forms/Layout/Card.js.map +1 -1
  803. package/es/extensions/forms/Layout/FlexContainer.d.ts +1 -0
  804. package/es/extensions/forms/Layout/FlexContainer.js +5 -3
  805. package/es/extensions/forms/Layout/FlexContainer.js.map +1 -1
  806. package/es/extensions/forms/Layout/FlexItem.d.ts +1 -0
  807. package/es/extensions/forms/Layout/FlexItem.js +2 -1
  808. package/es/extensions/forms/Layout/FlexItem.js.map +1 -1
  809. package/es/extensions/forms/Layout/SubHeading.js +2 -1
  810. package/es/extensions/forms/Layout/SubHeading.js.map +1 -1
  811. package/es/extensions/forms/Layout/style/dnb-card.css +3 -3
  812. package/es/extensions/forms/Layout/style/dnb-card.min.css +1 -1
  813. package/es/extensions/forms/Layout/style/dnb-card.scss +6 -4
  814. package/es/extensions/forms/Layout/style/dnb-flex-container.css +9 -0
  815. package/es/extensions/forms/Layout/style/dnb-flex-container.min.css +1 -1
  816. package/es/extensions/forms/Layout/style/dnb-flex-container.scss +14 -0
  817. package/es/extensions/forms/Layout/style/dnb-flex-item.css +9 -0
  818. package/es/extensions/forms/Layout/style/dnb-flex-item.min.css +1 -1
  819. package/es/extensions/forms/Layout/style/dnb-flex-item.scss +14 -0
  820. package/es/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  821. package/es/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  822. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.css +11 -5
  823. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  824. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +10 -3
  825. package/es/extensions/forms/ValueBlock/index.js.map +1 -1
  826. package/es/extensions/forms/field-types.d.ts +7 -1
  827. package/es/extensions/forms/field-types.js.map +1 -1
  828. package/es/extensions/forms/style/dnb-forms.css +112 -42
  829. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  830. package/es/extensions/forms/style/index.d.ts +1 -0
  831. package/es/extensions/forms/style/index.js +1 -0
  832. package/es/extensions/forms/style/index.js.map +1 -0
  833. package/es/extensions/forms/utils/TestElement/style/dnb-test-element.css +2 -2
  834. package/es/extensions/forms/utils/TestElement/style/dnb-test-element.min.css +1 -1
  835. package/es/extensions/forms/utils/TestElement/style/dnb-test-element.scss +2 -2
  836. package/es/extensions/forms/utils/useWasChanged.d.ts +5 -0
  837. package/es/extensions/forms/utils/useWasChanged.js +51 -0
  838. package/es/extensions/forms/utils/useWasChanged.js.map +1 -0
  839. package/es/extensions/forms/variables.scss +3 -0
  840. package/es/extensions/lib.d.ts +1 -0
  841. package/es/extensions/payment-card/PaymentCard.d.ts +6 -2
  842. package/es/extensions/payment-card/PaymentCard.js +13 -2
  843. package/es/extensions/payment-card/PaymentCard.js.map +1 -1
  844. package/es/extensions/payment-card/icons/CardIn.d.ts +2 -0
  845. package/es/extensions/payment-card/icons/CardIn.js +18 -0
  846. package/es/extensions/payment-card/icons/CardIn.js.map +1 -0
  847. package/es/extensions/payment-card/icons/index.js +4 -1
  848. package/es/extensions/payment-card/icons/index.js.map +1 -1
  849. package/es/extensions/payment-card/style/dnb-payment-card.css +3 -2
  850. package/es/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
  851. package/es/extensions/payment-card/style/dnb-payment-card.scss +2 -2
  852. package/es/extensions/payment-card/utils/backgrounds/ung.js +1 -1
  853. package/es/extensions/payment-card/utils/backgrounds/ung.js.map +1 -1
  854. package/es/extensions/payment-card/utils/backgrounds/youth.js +1 -1
  855. package/es/extensions/payment-card/utils/backgrounds/youth.js.map +1 -1
  856. package/es/fragments/drawer-list/DrawerList.js +1 -1
  857. package/es/fragments/drawer-list/DrawerList.js.map +1 -1
  858. package/es/fragments/drawer-list/DrawerListPortal.js +2 -2
  859. package/es/fragments/drawer-list/DrawerListPortal.js.map +1 -1
  860. package/es/fragments/drawer-list/style/dnb-drawer-list.scss +3 -1
  861. package/es/shared/Context.d.ts +2 -0
  862. package/es/shared/Context.js.map +1 -1
  863. package/es/shared/Eufemia.d.ts +1 -1
  864. package/es/shared/Eufemia.js +2 -2
  865. package/es/shared/Eufemia.js.map +1 -1
  866. package/es/shared/helpers/withCamelCaseProps.js.map +1 -1
  867. package/es/shared/helpers/withSnakeCaseProps.js.map +1 -1
  868. package/es/shared/libs/Shortcuts.js.map +1 -1
  869. package/es/shared/locales/en-GB.d.ts +2 -0
  870. package/es/shared/locales/en-GB.js +3 -1
  871. package/es/shared/locales/en-GB.js.map +1 -1
  872. package/es/shared/locales/en-US.d.ts +2 -0
  873. package/es/shared/locales/index.d.ts +4 -0
  874. package/es/shared/locales/nb-NO.d.ts +2 -0
  875. package/es/shared/locales/nb-NO.js +3 -1
  876. package/es/shared/locales/nb-NO.js.map +1 -1
  877. package/es/style/core/reset.scss +13 -3
  878. package/es/style/core/utilities.scss +3 -1
  879. package/es/style/dnb-ui-components.css +42 -19
  880. package/es/style/dnb-ui-components.min.css +1 -1
  881. package/es/style/dnb-ui-elements.css +6 -0
  882. package/es/style/dnb-ui-elements.min.css +1 -1
  883. package/es/style/dnb-ui-extensions.css +115 -44
  884. package/es/style/dnb-ui-extensions.min.css +1 -1
  885. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +6 -0
  886. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  887. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +189 -135
  888. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -1
  889. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +115 -44
  890. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  891. package/es/style/themes/theme-sbanken/customisations.scss +0 -8
  892. package/es/style/themes/theme-sbanken/properties.js +6 -6
  893. package/es/style/themes/theme-sbanken/properties.js.map +1 -1
  894. package/es/style/themes/theme-sbanken/properties.scss +6 -6
  895. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +27 -26
  896. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  897. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +574 -615
  898. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +14 -2
  899. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +8 -7
  900. package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +21 -2
  901. package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  902. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +115 -44
  903. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  904. package/es/style/themes/theme-ui/fonts.scss +8 -4
  905. package/es/style/themes/theme-ui/ui-theme-basis.css +6 -0
  906. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  907. package/es/style/themes/theme-ui/ui-theme-components.css +136 -98
  908. package/es/style/themes/theme-ui/ui-theme-components.min.css +7 -1
  909. package/es/style/themes/theme-ui/ui-theme-elements.css +6 -0
  910. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  911. package/es/style/themes/theme-ui/ui-theme-extensions.css +115 -44
  912. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  913. package/es/style/themes/theme-ui/ui-theme-tags.css +3 -0
  914. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  915. package/es/style/themes/theme-ui/ui-theme-tags.scss +9 -4
  916. package/esm/dnb-ui-basis.min.mjs +1 -1
  917. package/esm/dnb-ui-components.min.mjs +1 -1
  918. package/esm/dnb-ui-elements.min.mjs +1 -1
  919. package/esm/dnb-ui-extensions.min.mjs +6 -6
  920. package/esm/dnb-ui-lib.min.mjs +1 -1
  921. package/extensions/forms/DataContext/Provider.js +9 -9
  922. package/extensions/forms/DataContext/Provider.js.map +1 -1
  923. package/extensions/forms/DataContext/index.js.map +1 -1
  924. package/extensions/forms/Field/ArraySelection.d.ts +2 -1
  925. package/extensions/forms/Field/ArraySelection.js +49 -33
  926. package/extensions/forms/Field/ArraySelection.js.map +1 -1
  927. package/extensions/forms/Field/CountryCode.d.ts +10 -0
  928. package/extensions/forms/Field/CountryCode.js +68 -0
  929. package/extensions/forms/Field/CountryCode.js.map +1 -0
  930. package/extensions/forms/Field/Currency.d.ts +2 -2
  931. package/extensions/forms/Field/Currency.js +6 -38
  932. package/extensions/forms/Field/Currency.js.map +1 -1
  933. package/extensions/forms/Field/Date.d.ts +2 -2
  934. package/extensions/forms/Field/Date.js +11 -7
  935. package/extensions/forms/Field/Date.js.map +1 -1
  936. package/extensions/forms/Field/Number.d.ts +7 -3
  937. package/extensions/forms/Field/Number.js +47 -23
  938. package/extensions/forms/Field/Number.js.map +1 -1
  939. package/extensions/forms/Field/PhoneNumber.d.ts +7 -2
  940. package/extensions/forms/Field/PhoneNumber.js +44 -43
  941. package/extensions/forms/Field/PhoneNumber.js.map +1 -1
  942. package/extensions/forms/Field/PostalCodeAndCity.d.ts +1 -1
  943. package/extensions/forms/Field/PostalCodeAndCity.js +1 -1
  944. package/extensions/forms/Field/PostalCodeAndCity.js.map +1 -1
  945. package/extensions/forms/Field/Selection.d.ts +6 -4
  946. package/extensions/forms/Field/Selection.js +88 -39
  947. package/extensions/forms/Field/Selection.js.map +1 -1
  948. package/extensions/forms/Field/String.d.ts +3 -3
  949. package/extensions/forms/Field/String.js +33 -18
  950. package/extensions/forms/Field/String.js.map +1 -1
  951. package/extensions/forms/Field/Toggle.js +11 -9
  952. package/extensions/forms/Field/Toggle.js.map +1 -1
  953. package/extensions/forms/Field/fields.scss +2 -2
  954. package/extensions/forms/Field/hooks/useField.d.ts +6 -8
  955. package/extensions/forms/Field/hooks/useField.js +34 -33
  956. package/extensions/forms/Field/hooks/useField.js.map +1 -1
  957. package/extensions/forms/Field/index.d.ts +2 -0
  958. package/extensions/forms/Field/index.js +3 -1
  959. package/extensions/forms/Field/index.js.map +1 -1
  960. package/extensions/forms/Field/style/dnb-array-selection.css +13 -0
  961. package/extensions/forms/Field/style/dnb-array-selection.min.css +1 -0
  962. package/extensions/forms/Field/style/dnb-array-selection.scss +15 -0
  963. package/extensions/forms/Field/style/dnb-country-code.css +12 -0
  964. package/extensions/forms/Field/style/dnb-country-code.min.css +1 -0
  965. package/extensions/forms/Field/style/dnb-country-code.scss +19 -0
  966. package/extensions/forms/Field/style/dnb-phone-number.css +6 -7
  967. package/extensions/forms/Field/style/dnb-phone-number.min.css +1 -1
  968. package/extensions/forms/Field/style/dnb-phone-number.scss +7 -8
  969. package/extensions/forms/Field/style/dnb-postal-code-and-city.css +5 -2
  970. package/extensions/forms/Field/style/dnb-postal-code-and-city.min.css +1 -1
  971. package/extensions/forms/Field/style/dnb-postal-code-and-city.scss +5 -1
  972. package/extensions/forms/Field/style/dnb-selection.css +5 -2
  973. package/extensions/forms/Field/style/dnb-selection.min.css +1 -1
  974. package/extensions/forms/Field/style/dnb-selection.scss +7 -1
  975. package/extensions/forms/Field/style/index.d.ts +2 -1
  976. package/extensions/forms/Field/style/index.js +2 -1
  977. package/extensions/forms/Field/style/index.js.map +1 -1
  978. package/extensions/forms/Field/style/index.scss +2 -2
  979. package/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -0
  980. package/extensions/forms/FieldBlock/FieldBlock.js +19 -9
  981. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  982. package/extensions/forms/FieldBlock/index.js.map +1 -1
  983. package/extensions/forms/FieldBlock/style/dnb-field-block.css +39 -1
  984. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  985. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +60 -1
  986. package/extensions/forms/FieldGroup/index.js.map +1 -1
  987. package/extensions/forms/Layout/Card.js +2 -2
  988. package/extensions/forms/Layout/Card.js.map +1 -1
  989. package/extensions/forms/Layout/FlexContainer.d.ts +1 -0
  990. package/extensions/forms/Layout/FlexContainer.js +5 -3
  991. package/extensions/forms/Layout/FlexContainer.js.map +1 -1
  992. package/extensions/forms/Layout/FlexItem.d.ts +1 -0
  993. package/extensions/forms/Layout/FlexItem.js +2 -1
  994. package/extensions/forms/Layout/FlexItem.js.map +1 -1
  995. package/extensions/forms/Layout/SubHeading.js +2 -1
  996. package/extensions/forms/Layout/SubHeading.js.map +1 -1
  997. package/extensions/forms/Layout/style/dnb-card.css +3 -3
  998. package/extensions/forms/Layout/style/dnb-card.min.css +1 -1
  999. package/extensions/forms/Layout/style/dnb-card.scss +6 -4
  1000. package/extensions/forms/Layout/style/dnb-flex-container.css +9 -0
  1001. package/extensions/forms/Layout/style/dnb-flex-container.min.css +1 -1
  1002. package/extensions/forms/Layout/style/dnb-flex-container.scss +14 -0
  1003. package/extensions/forms/Layout/style/dnb-flex-item.css +9 -0
  1004. package/extensions/forms/Layout/style/dnb-flex-item.min.css +1 -1
  1005. package/extensions/forms/Layout/style/dnb-flex-item.scss +14 -0
  1006. package/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  1007. package/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  1008. package/extensions/forms/StepsLayout/style/dnb-steps-layout.css +11 -5
  1009. package/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  1010. package/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +10 -3
  1011. package/extensions/forms/ValueBlock/index.js.map +1 -1
  1012. package/extensions/forms/field-types.d.ts +7 -1
  1013. package/extensions/forms/field-types.js.map +1 -1
  1014. package/extensions/forms/style/dnb-forms.css +112 -42
  1015. package/extensions/forms/style/dnb-forms.min.css +1 -1
  1016. package/extensions/forms/style/index.d.ts +1 -0
  1017. package/extensions/forms/style/index.js +1 -0
  1018. package/extensions/forms/style/index.js.map +1 -0
  1019. package/extensions/forms/utils/TestElement/style/dnb-test-element.css +2 -2
  1020. package/extensions/forms/utils/TestElement/style/dnb-test-element.min.css +1 -1
  1021. package/extensions/forms/utils/TestElement/style/dnb-test-element.scss +2 -2
  1022. package/extensions/forms/utils/useWasChanged.d.ts +5 -0
  1023. package/extensions/forms/utils/useWasChanged.js +56 -0
  1024. package/extensions/forms/utils/useWasChanged.js.map +1 -0
  1025. package/extensions/forms/variables.scss +3 -0
  1026. package/extensions/lib.d.ts +1 -0
  1027. package/extensions/payment-card/PaymentCard.d.ts +6 -2
  1028. package/extensions/payment-card/PaymentCard.js +13 -2
  1029. package/extensions/payment-card/PaymentCard.js.map +1 -1
  1030. package/extensions/payment-card/icons/CardIn.d.ts +2 -0
  1031. package/extensions/payment-card/icons/CardIn.js +18 -0
  1032. package/extensions/payment-card/icons/CardIn.js.map +1 -0
  1033. package/extensions/payment-card/icons/index.js +4 -1
  1034. package/extensions/payment-card/icons/index.js.map +1 -1
  1035. package/extensions/payment-card/style/dnb-payment-card.css +3 -2
  1036. package/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
  1037. package/extensions/payment-card/style/dnb-payment-card.scss +2 -2
  1038. package/extensions/payment-card/utils/backgrounds/ung.js +1 -1
  1039. package/extensions/payment-card/utils/backgrounds/ung.js.map +1 -1
  1040. package/extensions/payment-card/utils/backgrounds/youth.js +1 -1
  1041. package/extensions/payment-card/utils/backgrounds/youth.js.map +1 -1
  1042. package/fragments/drawer-list/DrawerList.js +1 -1
  1043. package/fragments/drawer-list/DrawerList.js.map +1 -1
  1044. package/fragments/drawer-list/DrawerListPortal.js +2 -2
  1045. package/fragments/drawer-list/DrawerListPortal.js.map +1 -1
  1046. package/fragments/drawer-list/style/dnb-drawer-list.scss +3 -1
  1047. package/package.json +1 -1
  1048. package/shared/Context.d.ts +2 -0
  1049. package/shared/Context.js.map +1 -1
  1050. package/shared/Eufemia.d.ts +1 -1
  1051. package/shared/Eufemia.js +2 -2
  1052. package/shared/Eufemia.js.map +1 -1
  1053. package/shared/helpers/withCamelCaseProps.js.map +1 -1
  1054. package/shared/helpers/withSnakeCaseProps.js.map +1 -1
  1055. package/shared/libs/Shortcuts.js.map +1 -1
  1056. package/shared/locales/en-GB.d.ts +2 -0
  1057. package/shared/locales/en-GB.js +3 -1
  1058. package/shared/locales/en-GB.js.map +1 -1
  1059. package/shared/locales/en-US.d.ts +2 -0
  1060. package/shared/locales/index.d.ts +4 -0
  1061. package/shared/locales/nb-NO.d.ts +2 -0
  1062. package/shared/locales/nb-NO.js +3 -1
  1063. package/shared/locales/nb-NO.js.map +1 -1
  1064. package/style/core/reset.scss +13 -3
  1065. package/style/core/utilities.scss +3 -1
  1066. package/style/dnb-ui-components.css +42 -19
  1067. package/style/dnb-ui-components.min.css +1 -1
  1068. package/style/dnb-ui-elements.css +6 -0
  1069. package/style/dnb-ui-elements.min.css +1 -1
  1070. package/style/dnb-ui-extensions.css +115 -44
  1071. package/style/dnb-ui-extensions.min.css +1 -1
  1072. package/style/themes/theme-eiendom/eiendom-theme-basis.css +6 -0
  1073. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  1074. package/style/themes/theme-eiendom/eiendom-theme-components.css +189 -135
  1075. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -1
  1076. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +115 -44
  1077. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  1078. package/style/themes/theme-sbanken/customisations.scss +0 -8
  1079. package/style/themes/theme-sbanken/properties.js +6 -6
  1080. package/style/themes/theme-sbanken/properties.js.map +1 -1
  1081. package/style/themes/theme-sbanken/properties.scss +6 -6
  1082. package/style/themes/theme-sbanken/sbanken-theme-basis.css +27 -26
  1083. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  1084. package/style/themes/theme-sbanken/sbanken-theme-components.css +574 -615
  1085. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +14 -2
  1086. package/style/themes/theme-sbanken/sbanken-theme-components.scss +8 -7
  1087. package/style/themes/theme-sbanken/sbanken-theme-elements.css +21 -2
  1088. package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  1089. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +115 -44
  1090. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  1091. package/style/themes/theme-ui/fonts.scss +8 -4
  1092. package/style/themes/theme-ui/ui-theme-basis.css +6 -0
  1093. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  1094. package/style/themes/theme-ui/ui-theme-components.css +136 -98
  1095. package/style/themes/theme-ui/ui-theme-components.min.css +7 -1
  1096. package/style/themes/theme-ui/ui-theme-elements.css +6 -0
  1097. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  1098. package/style/themes/theme-ui/ui-theme-extensions.css +115 -44
  1099. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  1100. package/style/themes/theme-ui/ui-theme-tags.css +3 -0
  1101. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  1102. package/style/themes/theme-ui/ui-theme-tags.scss +9 -4
  1103. package/umd/dnb-ui-basis.min.js +1 -1
  1104. package/umd/dnb-ui-components.min.js +1 -1
  1105. package/umd/dnb-ui-elements.min.js +1 -1
  1106. package/umd/dnb-ui-extensions.min.js +6 -6
  1107. package/umd/dnb-ui-lib.min.js +1 -1
  1108. package/cjs/extensions/forms/Field/style/dnb-number.css +0 -11
  1109. package/cjs/extensions/forms/Field/style/dnb-number.min.css +0 -1
  1110. package/cjs/extensions/forms/Field/style/dnb-number.scss +0 -19
  1111. package/cjs/extensions/forms/Field/style/dnb-string.css +0 -11
  1112. package/cjs/extensions/forms/Field/style/dnb-string.min.css +0 -1
  1113. package/cjs/extensions/forms/Field/style/dnb-string.scss +0 -19
  1114. package/es/extensions/forms/Field/style/dnb-number.css +0 -11
  1115. package/es/extensions/forms/Field/style/dnb-number.min.css +0 -1
  1116. package/es/extensions/forms/Field/style/dnb-number.scss +0 -19
  1117. package/es/extensions/forms/Field/style/dnb-string.css +0 -11
  1118. package/es/extensions/forms/Field/style/dnb-string.min.css +0 -1
  1119. package/es/extensions/forms/Field/style/dnb-string.scss +0 -19
  1120. package/extensions/forms/Field/style/dnb-number.css +0 -11
  1121. package/extensions/forms/Field/style/dnb-number.min.css +0 -1
  1122. package/extensions/forms/Field/style/dnb-number.scss +0 -19
  1123. package/extensions/forms/Field/style/dnb-string.css +0 -11
  1124. package/extensions/forms/Field/style/dnb-string.min.css +0 -1
  1125. package/extensions/forms/Field/style/dnb-string.scss +0 -19
@@ -69,9 +69,15 @@
69
69
 
70
70
  &__status--error &__submit-button {
71
71
  html:not([data-whatintent='touch'])
72
- &__button.dnb-button--secondary:not(&__button--has-text, [disabled]):hover,
72
+ &__button.dnb-button--secondary:not(
73
+ &__button--has-text,
74
+ [disabled]
75
+ ):hover,
73
76
  html:not([data-whatintent='touch'])
74
- &__button.dnb-button--secondary:not(&__button--has-text, [disabled]):focus {
77
+ &__button.dnb-button--secondary:not(
78
+ &__button--has-text,
79
+ [disabled]
80
+ ):focus {
75
81
  &,
76
82
  &::after {
77
83
  background-color: var(--color-fire-red);
@@ -101,7 +107,7 @@
101
107
  display: none;
102
108
  }
103
109
 
104
- &--keep-placeholder &[data-input-state='focus'] &__placeholder {
110
+ &--keep-placeholder[data-input-state='focus'] &__placeholder {
105
111
  display: block;
106
112
  color: var(--color-black-20);
107
113
  }
@@ -27,7 +27,7 @@ export const correctNumberValue = _ref3 => {
27
27
  locale,
28
28
  maskParams
29
29
  } = _ref3;
30
- let value = String(props.value);
30
+ let value = props.value === null ? null : String(props.value);
31
31
  if (isNaN(parseFloat(value))) {
32
32
  return value;
33
33
  }
@@ -1 +1 @@
1
- {"version":3,"file":"InputMaskedUtils.js","names":["format","getDecimalSeparator","getThousandsSeparator","warn","IS_ANDROID","IS_IOS","safeSetSelection","enableLocaleSupportWhen","enableNumberMaskWhen","invisibleSpace","isRequestingLocaleSupport","props","Object","entries","some","_ref","k","v","includes","isRequestingNumberMask","_ref2","correctNumberValue","_ref3","localValue","locale","maskParams","value","String","isNaN","parseFloat","decimalPos","indexOf","integerLimit","limit","integers","split","isNegative","length","decimals","slice","shouldHaveDecimals","allowDecimal","decimalLimit","number_format","options","_objectSpread","decimalSymbol","replace","localNumberValue","numberValue","endsWithDecimal","endsWith","endsWithZeroAndDecimal","startsWith","test","correctCaretPosition","element","correction","suffix","prefix","start","selectionStart","end","selectionEnd","suffixStart","suffixEnd","pos","undefined","placeholderChar","prefixStart","prefixEnd","char","mask","chars","l","i","RegExp","n","_mask$test","call","e","window","requestAnimationFrame","handlePercentMask","_ref4","_String","_String$match","percent","match","handleCurrencyMask","_ref5","mask_options","currency_mask","showMask","fix","currency","handleNumberMask","_ref6","number_mask","getInputModeFromMask","allowNegative","instanceOf","handleThousandsSeparator","handleDecimalSeparator","fromJSON","str","fallback","arguments","JSON","parse"],"sources":["../../../../src/components/input-masked/InputMaskedUtils.js"],"sourcesContent":["/**\n * Web InputMasked Component\n *\n */\n\nimport {\n format,\n getDecimalSeparator,\n getThousandsSeparator,\n} from '../number-format/NumberUtils'\nimport { warn } from '../../shared/component-helper'\nimport { IS_ANDROID, IS_IOS } from '../../shared/helpers'\nimport { safeSetSelection } from './text-mask/createTextMaskInputElement'\n\nconst enableLocaleSupportWhen = ['as_number', 'as_percent', 'as_currency']\nconst enableNumberMaskWhen = [\n 'as_number',\n 'as_percent',\n 'as_currency',\n 'number_mask',\n 'currency_mask',\n]\n\nexport const invisibleSpace = '\\u200B'\n\n/**\n * Will return true if a prop needs Locale support\n *\n * @param {object} props object with given component props\n * @returns boolean\n */\nexport const isRequestingLocaleSupport = (props) => {\n return Object.entries(props).some(\n ([k, v]) => v && enableLocaleSupportWhen.includes(k)\n )\n}\n\n/**\n * Will return true if a prop will enable the internal NumberMask\n *\n * @param {object} props object with given component props\n * @returns boolean\n */\nexport const isRequestingNumberMask = (props) => {\n return Object.entries(props).some(\n ([k, v]) => v && enableNumberMaskWhen.includes(k)\n )\n}\n\n/**\n * Probably the most complex part of this component\n * It will modify a given value based on certain criteria's\n *\n * @param {object} param0 object with properties\n * @property {string} localValue optional – if given, it will uses its ending to determine of what to return\n * @property {number|string} value component property value\n * @property {object} context Eufemia Context\n * @property {string} locale Eufemia locale (either from component or context)\n * @property {object} maskParams predefined mask parameters\n * @returns string Value\n */\nexport const correctNumberValue = ({\n localValue = null,\n props,\n locale,\n maskParams,\n}) => {\n let value = String(props.value)\n\n if (isNaN(parseFloat(value))) {\n return value\n }\n\n const decimalPos = value.indexOf('.')\n\n if (\n maskParams.integerLimit &&\n typeof maskParams.integerLimit === 'number'\n ) {\n const limit = maskParams.integerLimit\n const integers = value.split('.')[0]\n const isNegative = parseFloat(integers) < 0\n if (integers.length - (isNegative ? 1 : 0) > limit) {\n const decimals = decimalPos > 0 ? value.slice(decimalPos) : ''\n value = integers.slice(0, limit + (isNegative ? 1 : 0)) + decimals\n }\n }\n\n const shouldHaveDecimals =\n maskParams.allowDecimal ||\n (maskParams.decimalLimit > 0 && maskParams.allowDecimal !== false)\n\n if (!shouldHaveDecimals) {\n if (decimalPos > -1) {\n value = value.slice(0, decimalPos)\n }\n }\n\n /**\n * This only runs IF \"number_format\" is set – we do not use it else\n */\n if (props.number_format) {\n const options = {\n locale,\n decimals: 0,\n ...props.number_format,\n }\n if (shouldHaveDecimals) {\n options.decimals = maskParams.decimalLimit\n }\n value = format(value, options)\n }\n\n const decimalSymbol = maskParams.decimalSymbol\n value = value.replace('.', decimalSymbol)\n\n if (localValue !== null) {\n const localNumberValue = localValue.replace(/[^\\d,.-]/g, '')\n const numberValue = value.replace(/[^\\d,.-]/g, '')\n\n const endsWithDecimal = localNumberValue.endsWith(decimalSymbol)\n const endsWithZeroAndDecimal = localNumberValue.endsWith(\n `${decimalSymbol}0`\n )\n\n if (endsWithDecimal) {\n value = `${value}${decimalSymbol}`\n } else if (\n endsWithZeroAndDecimal &&\n !numberValue.endsWith(`${decimalSymbol}0`)\n ) {\n /**\n * When the users has 20,02, then hits \"backspace\",\n * the returned {numberValue} in the onChange event would then be \"20\",\n * but we want it to be 20,0\n */\n value = `${value}${decimalSymbol}0`\n }\n\n /**\n * If the user removes a leading digit and we have left a leading zero.\n *\n * The users enters these steps:\n * Step 1. 1012\n * Step 2. 012 -> user removes 1, now use \"localValue\"\n * Step 3. 2012\n *\n * If a dev listens on_change and sends the number value back in,\n * for this, we also ensure that \"numberValue\" and \"localNumberValue\" is the same.\n */\n if (\n localNumberValue !== '0' &&\n localNumberValue.startsWith('0') &&\n parseFloat(numberValue.replace(decimalSymbol, '.')) ===\n parseFloat(localNumberValue.replace(decimalSymbol, '.'))\n ) {\n value = localValue\n }\n\n /**\n * While typing;\n * If the local value is - or -0 we use it.\n * Also, because of invisible whitespace we remove everything else\n */\n if (/^(-|-0)$/.test(localValue.replace(/[^\\d-0]/g, ''))) {\n value = localValue\n } else if (localNumberValue === '' && numberValue === '0') {\n value = ''\n }\n }\n\n return value\n}\n\n/**\n * This is a helper for setting the cursor position,\n * when it is on a not allowed position\n *\n * @param {Element} element Input Element\n * @param {Object} maskParams Mask parameters, containing eventually suffix or prefix\n */\nexport const correctCaretPosition = (element, maskParams, props) => {\n const correction = () => {\n try {\n const suffix = maskParams?.suffix\n const prefix = maskParams?.prefix\n\n const start = element.selectionStart\n const end = element.selectionEnd\n\n if (start !== end) {\n return // stop here\n }\n\n if (suffix || prefix) {\n const suffixStart = element.value.indexOf(suffix)\n const suffixEnd = suffixStart + suffix?.length\n let pos = undefined\n\n if (start >= suffixStart && start <= suffixEnd) {\n pos = suffixStart\n\n // If there is a placeholder,\n // and the user clicks after the suffix\n // we want the position to be \"before\" the placeholderChar\n if (\n maskParams.placeholderChar !== invisibleSpace &&\n element.value.length - 1 === String(suffix + prefix).length\n ) {\n pos = pos - 1\n }\n } else {\n const prefixStart = element.value.indexOf(prefix)\n const prefixEnd = prefixStart + prefix?.length || 0\n\n if (start >= prefixStart && start <= prefixEnd) {\n pos = prefixEnd\n }\n }\n\n const char = element.value.slice(pos - 1, pos)\n if (char === invisibleSpace) {\n pos = suffixStart - 1\n }\n\n if (!isNaN(parseFloat(pos))) {\n safeSetSelection(element, pos)\n }\n } else if (props?.mask && element.value.length === end) {\n const chars = element.value.split('')\n\n for (let l = chars.length, i = l - 1; i >= 0; i--) {\n const char = chars[i]\n const mask = props.mask[i]\n if (\n char &&\n char !== invisibleSpace &&\n mask instanceof RegExp &&\n mask.test(char)\n ) {\n for (let n = i + 1; n < l; n++) {\n const mask = props.mask[n]\n if (mask?.test?.(mask) === false) {\n safeSetSelection(element, n)\n break\n }\n }\n\n break\n }\n }\n }\n } catch (e) {\n warn(e)\n }\n }\n\n if (typeof window !== 'undefined') {\n window.requestAnimationFrame(correction)\n }\n}\n\n/**\n * Manipulate needed mask for handle: percent\n *\n * @param {object} param0 object with properties\n * @property {object} props Component property\n * @property {string} locale Eufemia locale (either from component or context)\n * @property {object} maskParams predefined mask parameters\n * @returns object maskParams\n */\nexport const handlePercentMask = ({ props, locale, maskParams }) => {\n const value = format(props.value, { locale, percent: true })\n maskParams.suffix = String(value)?.match(/((\\s|)%)$/g, '$1')?.[0] || ' %'\n\n return maskParams\n}\n\n/**\n * Return needed mask for handle: currency\n *\n * @param {object} param0 object with properties\n * @property {object} context Eufemia context\n * @property {object} mask_options Component property for change the mask parameters\n * @property {object} currency_mask Component property for change the currency parameters\n * @returns object maskParams\n */\nexport const handleCurrencyMask = ({ mask_options, currency_mask }) => {\n const maskParams = {\n showMask: true,\n placeholderChar: null,\n allowDecimal: true,\n decimalLimit: 2,\n decimalSymbol: ',',\n ...mask_options,\n ...currency_mask,\n }\n\n const fix =\n typeof currency_mask === 'string'\n ? currency_mask\n : typeof maskParams.currency === 'string'\n ? maskParams.currency\n : 'kr'\n\n maskParams.suffix = ` ${fix}`\n\n return maskParams\n}\n\n/**\n * Return needed mask for handle: number\n *\n * @param {object} param0 object with properties\n * @property {object} context Eufemia context\n * @property {object} mask_options Component property for change the mask parameters\n * @property {object} number_mask Component property for change the number parameters\n * @returns object maskParams\n */\nexport const handleNumberMask = ({ mask_options, number_mask }) => {\n const maskParams = {\n decimalSymbol: ',',\n ...mask_options,\n ...number_mask,\n }\n\n if (typeof maskParams.allowDecimal === 'undefined') {\n maskParams.allowDecimal = maskParams.decimalLimit > 0\n }\n\n return maskParams\n}\n\n/**\n * Returns the type of what inputMode should be used\n *\n * @param {function} mask mask function\n * @returns undefined|decimal|numeric\n */\nexport function getInputModeFromMask(mask) {\n const maskParams = mask?.maskParams\n\n // because of the missing minus key, we still have to use text on Android and iOS\n if ((IS_ANDROID || IS_IOS) && maskParams?.allowNegative !== false) {\n return undefined\n }\n\n if (maskParams && mask?.instanceOf === 'createNumberMask') {\n return maskParams.allowDecimal && maskParams.decimalLimit !== 0\n ? 'decimal'\n : 'numeric'\n }\n return undefined\n}\n\n/**\n * Returns the thousands separator character\n *\n * @param {string} locale Component or context locale\n * @returns string\n */\nexport function handleThousandsSeparator(locale) {\n return getThousandsSeparator(locale).replace(' ', ' ') // replace non-breaking space with a regular space\n}\n\n/**\n * Returns the decimal separator character\n *\n * @param {string} locale Component or context locale\n * @returns string\n */\nexport function handleDecimalSeparator(locale) {\n let decimalSymbol = getDecimalSeparator(locale)\n\n return decimalSymbol\n}\n\n/**\n * Will take a JSON and return it parsed\n *\n * @param {string} str\n * @param {*} fallback optional fallback\n * @returns parsed json\n */\nexport function fromJSON(str, fallback = null) {\n if (typeof str === 'string' && str[0] === '{') {\n return JSON.parse(str)\n }\n\n return str || fallback\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"InputMaskedUtils.js","names":["format","getDecimalSeparator","getThousandsSeparator","warn","IS_ANDROID","IS_IOS","safeSetSelection","enableLocaleSupportWhen","enableNumberMaskWhen","invisibleSpace","isRequestingLocaleSupport","props","Object","entries","some","_ref","k","v","includes","isRequestingNumberMask","_ref2","correctNumberValue","_ref3","localValue","locale","maskParams","value","String","isNaN","parseFloat","decimalPos","indexOf","integerLimit","limit","integers","split","isNegative","length","decimals","slice","shouldHaveDecimals","allowDecimal","decimalLimit","number_format","options","_objectSpread","decimalSymbol","replace","localNumberValue","numberValue","endsWithDecimal","endsWith","endsWithZeroAndDecimal","startsWith","test","correctCaretPosition","element","correction","suffix","prefix","start","selectionStart","end","selectionEnd","suffixStart","suffixEnd","pos","undefined","placeholderChar","prefixStart","prefixEnd","char","mask","chars","l","i","RegExp","n","_mask$test","call","e","window","requestAnimationFrame","handlePercentMask","_ref4","_String","_String$match","percent","match","handleCurrencyMask","_ref5","mask_options","currency_mask","showMask","fix","currency","handleNumberMask","_ref6","number_mask","getInputModeFromMask","allowNegative","instanceOf","handleThousandsSeparator","handleDecimalSeparator","fromJSON","str","fallback","arguments","JSON","parse"],"sources":["../../../../src/components/input-masked/InputMaskedUtils.js"],"sourcesContent":["/**\n * Web InputMasked Component\n *\n */\n\nimport {\n format,\n getDecimalSeparator,\n getThousandsSeparator,\n} from '../number-format/NumberUtils'\nimport { warn } from '../../shared/component-helper'\nimport { IS_ANDROID, IS_IOS } from '../../shared/helpers'\nimport { safeSetSelection } from './text-mask/createTextMaskInputElement'\n\nconst enableLocaleSupportWhen = ['as_number', 'as_percent', 'as_currency']\nconst enableNumberMaskWhen = [\n 'as_number',\n 'as_percent',\n 'as_currency',\n 'number_mask',\n 'currency_mask',\n]\n\nexport const invisibleSpace = '\\u200B'\n\n/**\n * Will return true if a prop needs Locale support\n *\n * @param {object} props object with given component props\n * @returns boolean\n */\nexport const isRequestingLocaleSupport = (props) => {\n return Object.entries(props).some(\n ([k, v]) => v && enableLocaleSupportWhen.includes(k)\n )\n}\n\n/**\n * Will return true if a prop will enable the internal NumberMask\n *\n * @param {object} props object with given component props\n * @returns boolean\n */\nexport const isRequestingNumberMask = (props) => {\n return Object.entries(props).some(\n ([k, v]) => v && enableNumberMaskWhen.includes(k)\n )\n}\n\n/**\n * Probably the most complex part of this component\n * It will modify a given value based on certain criteria's\n *\n * @param {object} param0 object with properties\n * @property {string} localValue optional – if given, it will uses its ending to determine of what to return\n * @property {number|string} value component property value\n * @property {object} context Eufemia Context\n * @property {string} locale Eufemia locale (either from component or context)\n * @property {object} maskParams predefined mask parameters\n * @returns string Value\n */\nexport const correctNumberValue = ({\n localValue = null,\n props,\n locale,\n maskParams,\n}) => {\n let value = props.value === null ? null : String(props.value)\n\n if (isNaN(parseFloat(value))) {\n return value\n }\n\n const decimalPos = value.indexOf('.')\n\n if (\n maskParams.integerLimit &&\n typeof maskParams.integerLimit === 'number'\n ) {\n const limit = maskParams.integerLimit\n const integers = value.split('.')[0]\n const isNegative = parseFloat(integers) < 0\n if (integers.length - (isNegative ? 1 : 0) > limit) {\n const decimals = decimalPos > 0 ? value.slice(decimalPos) : ''\n value = integers.slice(0, limit + (isNegative ? 1 : 0)) + decimals\n }\n }\n\n const shouldHaveDecimals =\n maskParams.allowDecimal ||\n (maskParams.decimalLimit > 0 && maskParams.allowDecimal !== false)\n\n if (!shouldHaveDecimals) {\n if (decimalPos > -1) {\n value = value.slice(0, decimalPos)\n }\n }\n\n /**\n * This only runs IF \"number_format\" is set – we do not use it else\n */\n if (props.number_format) {\n const options = {\n locale,\n decimals: 0,\n ...props.number_format,\n }\n if (shouldHaveDecimals) {\n options.decimals = maskParams.decimalLimit\n }\n value = format(value, options)\n }\n\n const decimalSymbol = maskParams.decimalSymbol\n value = value.replace('.', decimalSymbol)\n\n if (localValue !== null) {\n const localNumberValue = localValue.replace(/[^\\d,.-]/g, '')\n const numberValue = value.replace(/[^\\d,.-]/g, '')\n\n const endsWithDecimal = localNumberValue.endsWith(decimalSymbol)\n const endsWithZeroAndDecimal = localNumberValue.endsWith(\n `${decimalSymbol}0`\n )\n\n if (endsWithDecimal) {\n value = `${value}${decimalSymbol}`\n } else if (\n endsWithZeroAndDecimal &&\n !numberValue.endsWith(`${decimalSymbol}0`)\n ) {\n /**\n * When the users has 20,02, then hits \"backspace\",\n * the returned {numberValue} in the onChange event would then be \"20\",\n * but we want it to be 20,0\n */\n value = `${value}${decimalSymbol}0`\n }\n\n /**\n * If the user removes a leading digit and we have left a leading zero.\n *\n * The users enters these steps:\n * Step 1. 1012\n * Step 2. 012 -> user removes 1, now use \"localValue\"\n * Step 3. 2012\n *\n * If a dev listens on_change and sends the number value back in,\n * for this, we also ensure that \"numberValue\" and \"localNumberValue\" is the same.\n */\n if (\n localNumberValue !== '0' &&\n localNumberValue.startsWith('0') &&\n parseFloat(numberValue.replace(decimalSymbol, '.')) ===\n parseFloat(localNumberValue.replace(decimalSymbol, '.'))\n ) {\n value = localValue\n }\n\n /**\n * While typing;\n * If the local value is - or -0 we use it.\n * Also, because of invisible whitespace we remove everything else\n */\n if (/^(-|-0)$/.test(localValue.replace(/[^\\d-0]/g, ''))) {\n value = localValue\n } else if (localNumberValue === '' && numberValue === '0') {\n value = ''\n }\n }\n\n return value\n}\n\n/**\n * This is a helper for setting the cursor position,\n * when it is on a not allowed position\n *\n * @param {Element} element Input Element\n * @param {Object} maskParams Mask parameters, containing eventually suffix or prefix\n */\nexport const correctCaretPosition = (element, maskParams, props) => {\n const correction = () => {\n try {\n const suffix = maskParams?.suffix\n const prefix = maskParams?.prefix\n\n const start = element.selectionStart\n const end = element.selectionEnd\n\n if (start !== end) {\n return // stop here\n }\n\n if (suffix || prefix) {\n const suffixStart = element.value.indexOf(suffix)\n const suffixEnd = suffixStart + suffix?.length\n let pos = undefined\n\n if (start >= suffixStart && start <= suffixEnd) {\n pos = suffixStart\n\n // If there is a placeholder,\n // and the user clicks after the suffix\n // we want the position to be \"before\" the placeholderChar\n if (\n maskParams.placeholderChar !== invisibleSpace &&\n element.value.length - 1 === String(suffix + prefix).length\n ) {\n pos = pos - 1\n }\n } else {\n const prefixStart = element.value.indexOf(prefix)\n const prefixEnd = prefixStart + prefix?.length || 0\n\n if (start >= prefixStart && start <= prefixEnd) {\n pos = prefixEnd\n }\n }\n\n const char = element.value.slice(pos - 1, pos)\n if (char === invisibleSpace) {\n pos = suffixStart - 1\n }\n\n if (!isNaN(parseFloat(pos))) {\n safeSetSelection(element, pos)\n }\n } else if (props?.mask && element.value.length === end) {\n const chars = element.value.split('')\n\n for (let l = chars.length, i = l - 1; i >= 0; i--) {\n const char = chars[i]\n const mask = props.mask[i]\n if (\n char &&\n char !== invisibleSpace &&\n mask instanceof RegExp &&\n mask.test(char)\n ) {\n for (let n = i + 1; n < l; n++) {\n const mask = props.mask[n]\n if (mask?.test?.(mask) === false) {\n safeSetSelection(element, n)\n break\n }\n }\n\n break\n }\n }\n }\n } catch (e) {\n warn(e)\n }\n }\n\n if (typeof window !== 'undefined') {\n window.requestAnimationFrame(correction)\n }\n}\n\n/**\n * Manipulate needed mask for handle: percent\n *\n * @param {object} param0 object with properties\n * @property {object} props Component property\n * @property {string} locale Eufemia locale (either from component or context)\n * @property {object} maskParams predefined mask parameters\n * @returns object maskParams\n */\nexport const handlePercentMask = ({ props, locale, maskParams }) => {\n const value = format(props.value, { locale, percent: true })\n maskParams.suffix = String(value)?.match(/((\\s|)%)$/g, '$1')?.[0] || ' %'\n\n return maskParams\n}\n\n/**\n * Return needed mask for handle: currency\n *\n * @param {object} param0 object with properties\n * @property {object} context Eufemia context\n * @property {object} mask_options Component property for change the mask parameters\n * @property {object} currency_mask Component property for change the currency parameters\n * @returns object maskParams\n */\nexport const handleCurrencyMask = ({ mask_options, currency_mask }) => {\n const maskParams = {\n showMask: true,\n placeholderChar: null,\n allowDecimal: true,\n decimalLimit: 2,\n decimalSymbol: ',',\n ...mask_options,\n ...currency_mask,\n }\n\n const fix =\n typeof currency_mask === 'string'\n ? currency_mask\n : typeof maskParams.currency === 'string'\n ? maskParams.currency\n : 'kr'\n\n maskParams.suffix = ` ${fix}`\n\n return maskParams\n}\n\n/**\n * Return needed mask for handle: number\n *\n * @param {object} param0 object with properties\n * @property {object} context Eufemia context\n * @property {object} mask_options Component property for change the mask parameters\n * @property {object} number_mask Component property for change the number parameters\n * @returns object maskParams\n */\nexport const handleNumberMask = ({ mask_options, number_mask }) => {\n const maskParams = {\n decimalSymbol: ',',\n ...mask_options,\n ...number_mask,\n }\n\n if (typeof maskParams.allowDecimal === 'undefined') {\n maskParams.allowDecimal = maskParams.decimalLimit > 0\n }\n\n return maskParams\n}\n\n/**\n * Returns the type of what inputMode should be used\n *\n * @param {function} mask mask function\n * @returns undefined|decimal|numeric\n */\nexport function getInputModeFromMask(mask) {\n const maskParams = mask?.maskParams\n\n // because of the missing minus key, we still have to use text on Android and iOS\n if ((IS_ANDROID || IS_IOS) && maskParams?.allowNegative !== false) {\n return undefined\n }\n\n if (maskParams && mask?.instanceOf === 'createNumberMask') {\n return maskParams.allowDecimal && maskParams.decimalLimit !== 0\n ? 'decimal'\n : 'numeric'\n }\n return undefined\n}\n\n/**\n * Returns the thousands separator character\n *\n * @param {string} locale Component or context locale\n * @returns string\n */\nexport function handleThousandsSeparator(locale) {\n return getThousandsSeparator(locale).replace(' ', ' ') // replace non-breaking space with a regular space\n}\n\n/**\n * Returns the decimal separator character\n *\n * @param {string} locale Component or context locale\n * @returns string\n */\nexport function handleDecimalSeparator(locale) {\n let decimalSymbol = getDecimalSeparator(locale)\n\n return decimalSymbol\n}\n\n/**\n * Will take a JSON and return it parsed\n *\n * @param {string} str\n * @param {*} fallback optional fallback\n * @returns parsed json\n */\nexport function fromJSON(str, fallback = null) {\n if (typeof str === 'string' && str[0] === '{') {\n return JSON.parse(str)\n }\n\n return str || fallback\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"Modal.js","names":["React","classnames","SuffixContext","Context","warn","isTrue","makeUniqueId","extendPropsWithContextInClassComponent","processChildren","dispatchCustomElementEvent","createSpacingClasses","HelpButtonInstance","getListOfModalRoots","getModalRoot","ModalInner","ModalHeader","ModalHeaderBar","CloseButton","ModalRoot","classWithCamelCaseProps","ANIMATION_DURATION","Modal","PureComponent","getContent","props","modal_content","getDerivedStateFromProps","state","open_state","_open_state","hide","no_animation","modalActive","constructor","_this","this","_defineProperty","event","arguments","length","undefined","showModal","preventDefault","toggleNow","animation_duration","timeoutDuration","parseFloat","isInTransition","doItNow","setState","handleSideEffects","_closeTimeout","setTimeout","waitBeforeOpen","open_delay","delay","_openTimeout","clearTimeout","open_modal","fn","_onUnmount","push","close_modal","toggleOpenClose","setActiveState","_id","_this$_triggerRef","focus","elem","setAttribute","preventScroll","Promise","resolve","removeAttribute","String","_triggerRef","current","activeElement","HTMLElement","then","e","removeActiveState","ifIsLatest","triggeredBy","prevent_close","id","close","list","last","createRef","componentDidMount","openBasedOnStateUpdate","componentWillUnmount","forEach","componentDidUpdate","prevProps","document","documentElement","modalId","render","defaultProps","context","getTranslation","root_id","content_id","disabled","labelled_by","focus_selector","header_content","bar_content","bypass_invalidation_selectors","omit_trigger_button","trigger","trigger_attributes","rest","_objectWithoutProperties","_excluded","children","Object","freeze","_objectSpread","suffixProps","triggerAttributes","hidden","variant","icon_position","fallbackTitle","title","translation","HelpButton","TriggerButton","text","createElement","Fragment","_extends","onClick","innerRef","className","class","Consumer","spacing","dialog_title","close_title","hide_close_button","close_button_attributes","prevent_core_style","no_animation_on_mobile","fullscreen","min_width","max_width","align_content","container_placement","direct_dom_return","on_open","on_close","on_close_prevent","overlay_class","content_class","OriginalComponent"],"sources":["../../../../src/components/modal/Modal.tsx"],"sourcesContent":["/**\n * Web Modal Component\n *\n */\n\nimport React from 'react'\nimport classnames from 'classnames'\nimport { SuffixContext } from '../../shared/helpers/Suffix'\nimport Context, { ContextProps } from '../../shared/Context'\nimport {\n warn,\n isTrue,\n makeUniqueId,\n extendPropsWithContextInClassComponent,\n processChildren,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport HelpButtonInstance from '../help-button/HelpButtonInstance'\nimport { getListOfModalRoots, getModalRoot } from './helpers'\nimport ModalInner from './parts/ModalInner'\nimport { ModalProps } from './types'\n\nimport ModalHeader from './parts/ModalHeader'\nimport ModalHeaderBar from './parts/ModalHeaderBar'\nimport { ScrollViewAllProps } from '../../fragments/scroll-view/ScrollView'\nimport CloseButton from './parts/CloseButton'\nimport ModalRoot from './ModalRoot'\nimport type { SpacingProps } from '../../shared/types'\nimport {\n classWithCamelCaseProps,\n ToCamelCasePartial,\n} from '../../shared/helpers/withCamelCaseProps'\nimport type { ButtonProps } from '../button/Button'\n\nexport const ANIMATION_DURATION = 300\n\ninterface ModalState {\n hide: boolean\n modalActive: boolean\n}\n\nexport type ModalPropTypes = ModalProps &\n SpacingProps &\n Omit<ScrollViewAllProps, 'children'>\n\nclass Modal extends React.PureComponent<\n ModalPropTypes & ToCamelCasePartial<ModalPropTypes>,\n ModalState\n> {\n static contextType = Context\n\n context!: ContextProps\n\n static Bar = ModalHeaderBar\n static Header = ModalHeader\n static Content = ModalInner\n\n static getContent(props) {\n if (typeof props.modal_content === 'string') {\n return props.modal_content\n } else if (typeof props.modal_content === 'function') {\n return props.modal_content(props)\n }\n return processChildren(props)\n }\n\n _id: string\n _triggerRef: React.RefObject<any>\n _onUnmount: Array<() => void>\n _openTimeout: NodeJS.Timeout\n _closeTimeout: NodeJS.Timeout\n _sideEffectsTimeout: NodeJS.Timeout\n _tryToOpenTimeout: NodeJS.Timeout\n activeElement: Element\n isInTransition: boolean\n\n state = {\n hide: false,\n modalActive: false,\n }\n\n static defaultProps = {\n id: null,\n focus_selector: null,\n labelled_by: null,\n title: null,\n disabled: null,\n spacing: true,\n open_delay: null,\n content_id: null,\n dialog_title: 'Vindu',\n close_title: 'Lukk', // Close Modal Window\n hide_close_button: false,\n close_button_attributes: null,\n prevent_close: false,\n prevent_core_style: false,\n animation_duration: ANIMATION_DURATION,\n no_animation: false,\n no_animation_on_mobile: false,\n fullscreen: 'auto',\n min_width: null,\n max_width: null,\n align_content: 'left',\n container_placement: null,\n open_state: null,\n direct_dom_return: false,\n class: null,\n root_id: 'root',\n omit_trigger_button: false,\n\n className: null,\n children: null,\n\n on_open: null,\n on_close: null,\n on_close_prevent: null,\n open_modal: null,\n close_modal: null,\n\n trigger: null,\n trigger_attributes: null,\n\n overlay_class: null,\n content_class: null,\n\n modal_content: null,\n header_content: null,\n bar_content: null,\n }\n\n static getDerivedStateFromProps(props, state) {\n if (props.open_state !== state._open_state) {\n switch (props.open_state) {\n case 'opened':\n case true:\n state.hide = false\n if (isTrue(props.no_animation)) {\n state.modalActive = true\n }\n break\n case 'closed':\n case false:\n state.hide = true\n if (isTrue(props.no_animation)) {\n state.modalActive = false\n }\n break\n }\n }\n state._open_state = props.open_state\n\n return state\n }\n\n constructor(props) {\n super(props)\n this._id = props.id || makeUniqueId('modal-')\n\n this._triggerRef = React.createRef()\n\n this._onUnmount = []\n }\n\n componentDidMount() {\n this.openBasedOnStateUpdate()\n }\n\n componentWillUnmount() {\n clearTimeout(this._openTimeout)\n clearTimeout(this._closeTimeout)\n\n this.removeActiveState()\n\n this._onUnmount.forEach((fn) => {\n if (typeof fn === 'function') {\n fn()\n }\n })\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps !== this.props) {\n this.openBasedOnStateUpdate()\n }\n }\n\n openBasedOnStateUpdate() {\n const { hide } = this.state\n const { open_state } = this.props\n\n if (!this.activeElement && typeof document !== 'undefined') {\n this.activeElement = document.activeElement\n }\n\n if (!hide && (open_state === 'opened' || open_state === true)) {\n this.toggleOpenClose(null, true)\n } else if (hide && (open_state === 'closed' || open_state === false)) {\n this.toggleOpenClose(null, false)\n }\n }\n\n toggleOpenClose = (event = null, showModal = null) => {\n if (event && event.preventDefault) {\n event.preventDefault()\n }\n\n const toggleNow = () => {\n const {\n animation_duration = ANIMATION_DURATION,\n no_animation = false,\n } = this.props\n const timeoutDuration =\n typeof animation_duration === 'string'\n ? parseFloat(animation_duration)\n : animation_duration\n\n const modalActive =\n typeof showModal === 'boolean'\n ? showModal\n : !this.state.modalActive\n\n this.isInTransition = true\n\n const doItNow = () => {\n this.setState(\n {\n hide: false,\n modalActive,\n },\n () => {\n this.isInTransition = false\n this.handleSideEffects()\n }\n )\n }\n\n if (modalActive === false && !isTrue(no_animation)) {\n this.setState({\n hide: true,\n })\n\n this._closeTimeout = setTimeout(doItNow, timeoutDuration) // delay because of the animation\n } else {\n doItNow()\n }\n }\n\n const waitBeforeOpen = () => {\n const { open_delay, no_animation } = this.props\n const delay =\n typeof open_delay === 'string'\n ? parseFloat(open_delay)\n : open_delay\n if (delay > 0 && !isTrue(no_animation)) {\n this._openTimeout = setTimeout(toggleNow, delay) // custom delay\n } else {\n toggleNow()\n }\n }\n\n clearTimeout(this._closeTimeout)\n clearTimeout(this._openTimeout)\n\n const { open_modal } = this.props\n if (typeof open_modal === 'function') {\n const fn = open_modal(waitBeforeOpen, this)\n if (fn) {\n this._onUnmount.push(fn)\n }\n } else {\n waitBeforeOpen()\n }\n }\n\n handleSideEffects = () => {\n const { modalActive } = this.state\n const { close_modal, open_state, animation_duration } = this.props\n\n if (modalActive) {\n if (typeof close_modal === 'function') {\n const fn = close_modal(() => {\n this.toggleOpenClose(null, false)\n }, this)\n if (fn) {\n this._onUnmount.push(fn)\n }\n }\n\n this.setActiveState(this._id)\n } else if (modalActive === false) {\n const focus = (elem: HTMLElement) => {\n // So we can omit showing a Tooltip on the trigger button\n elem.setAttribute('data-autofocus', 'true')\n\n elem.focus({ preventScroll: true })\n\n return new Promise<void>((resolve) => {\n setTimeout(() => {\n elem?.removeAttribute('data-autofocus')\n resolve()\n }, parseFloat(String(animation_duration)) / 3)\n })\n }\n\n if (this._triggerRef?.current) {\n focus(this._triggerRef.current)\n }\n\n // because the open_state was set to opened, we force\n if (\n (open_state === 'opened' || open_state === true) &&\n this.activeElement instanceof HTMLElement\n ) {\n try {\n focus(this.activeElement).then(() => {\n this.activeElement = null\n })\n } catch (e) {\n //\n }\n }\n\n this.removeActiveState()\n }\n }\n\n open = (e: Event) => {\n this.toggleOpenClose(e, true)\n }\n\n close = (\n event: Event,\n { ifIsLatest, triggeredBy = null } = { ifIsLatest: true }\n ) => {\n const { prevent_close = false } = this.props\n\n if (isTrue(prevent_close)) {\n const id = this._id\n dispatchCustomElementEvent(this, 'on_close_prevent', {\n id,\n event,\n triggeredBy,\n close: (e) => {\n this.toggleOpenClose(e, false)\n },\n })\n } else {\n if (ifIsLatest) {\n const list = getListOfModalRoots()\n if (list.length > 1) {\n const last = getModalRoot(-1)\n if (last !== this) {\n return // stop here\n }\n }\n }\n\n this.toggleOpenClose(event, false)\n }\n }\n\n removeActiveState() {\n const last = getModalRoot(-1)\n\n // If this instance is not the last one,\n // make the current one to as the active one\n if (last?._id && last._id !== this._id) {\n return this.setActiveState(last._id)\n }\n\n try {\n document.documentElement.removeAttribute('data-dnb-modal-active')\n } catch (e) {\n warn('Modal: Error on remove \"data-dnb-modal-active\"', e)\n }\n }\n\n /**\n * Prevent scrolling on the background\n * But checks if this instance was the last one or not\n *\n * @param {string} modalId Will remove the attribute if false is given\n */\n setActiveState(modalId: string) {\n if (!modalId) {\n warn('Modal: A valid modalId is required')\n }\n // prevent scrolling on the background\n if (typeof document !== 'undefined') {\n try {\n document.documentElement.setAttribute(\n 'data-dnb-modal-active',\n modalId\n )\n } catch (e) {\n warn('Modal: Error on set \"data-dnb-modal-active\"', e)\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 Modal.defaultProps,\n this.context.getTranslation(this.props).Modal,\n this.context.Modal\n )\n\n const {\n root_id = 'root',\n content_id = null,\n disabled = null,\n labelled_by = null,\n focus_selector = null,\n header_content = null,\n bar_content = null,\n bypass_invalidation_selectors = null,\n\n id, // eslint-disable-line\n open_state, // eslint-disable-line\n open_delay, // eslint-disable-line\n\n omit_trigger_button = false,\n trigger = null,\n trigger_attributes = null,\n ...rest\n } = props\n\n const { hide, modalActive } = this.state\n const modal_content = Modal.getContent(\n typeof this.props.children === 'function'\n ? Object.freeze({ ...this.props, close: this.close })\n : this.props\n )\n\n const render = (suffixProps) => {\n const triggerAttributes = {\n hidden: false,\n variant: 'secondary',\n icon_position: 'left',\n ...trigger_attributes,\n } as ButtonProps\n\n if (isTrue(disabled)) {\n triggerAttributes.disabled = true\n }\n\n if (triggerAttributes.id) {\n this._id = triggerAttributes.id\n }\n\n let fallbackTitle: string\n if (triggerAttributes.title) {\n fallbackTitle = triggerAttributes.title\n }\n // in case the modal is used in suffix and no title is given\n // suffixProps.label is also available, so we could use that too\n else if (suffixProps) {\n fallbackTitle = this.context.translation.HelpButton.title\n }\n\n const TriggerButton = trigger\n ? (trigger as React.FC)\n : HelpButtonInstance\n\n const title = (\n !triggerAttributes.text ? rest.title || fallbackTitle : null\n ) as string\n\n return (\n <>\n {TriggerButton && !isTrue(omit_trigger_button) && (\n <TriggerButton\n {...triggerAttributes}\n id={this._id}\n title={title}\n onClick={this.toggleOpenClose}\n innerRef={this._triggerRef}\n className={classnames(\n 'dnb-modal__trigger',\n createSpacingClasses(props),\n triggerAttributes.class,\n triggerAttributes.className\n )}\n />\n )}\n\n {modalActive && modal_content && (\n <ModalRoot\n {...rest}\n id={this._id}\n root_id={root_id}\n content_id={content_id || `dnb-modal-${this._id}`}\n labelled_by={labelled_by}\n focus_selector={focus_selector}\n modal_content={modal_content}\n header_content={header_content}\n bar_content={bar_content}\n bypass_invalidation_selectors={bypass_invalidation_selectors}\n close={this.close}\n hide={hide}\n title={rest.title || fallbackTitle}\n />\n )}\n </>\n )\n }\n\n return <SuffixContext.Consumer>{render}</SuffixContext.Consumer>\n }\n}\n\nexport { CloseButton, Modal as OriginalComponent }\n\nexport default classWithCamelCaseProps(Modal)\n"],"mappings":"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"}
1
+ {"version":3,"file":"Modal.js","names":["React","classnames","SuffixContext","Context","warn","isTrue","makeUniqueId","extendPropsWithContextInClassComponent","processChildren","dispatchCustomElementEvent","createSpacingClasses","HelpButtonInstance","getListOfModalRoots","getModalRoot","ModalInner","ModalHeader","ModalHeaderBar","CloseButton","ModalRoot","classWithCamelCaseProps","ANIMATION_DURATION","Modal","PureComponent","getContent","props","modal_content","getDerivedStateFromProps","state","open_state","_open_state","hide","no_animation","modalActive","constructor","_this","this","_defineProperty","event","arguments","length","undefined","showModal","preventDefault","toggleNow","animation_duration","timeoutDuration","parseFloat","isInTransition","doItNow","setState","handleSideEffects","_closeTimeout","setTimeout","waitBeforeOpen","open_delay","delay","_openTimeout","clearTimeout","open_modal","fn","_onUnmount","push","close_modal","toggleOpenClose","setActiveState","_id","_this$_triggerRef","focus","elem","setAttribute","preventScroll","Promise","resolve","removeAttribute","String","_triggerRef","current","activeElement","HTMLElement","then","e","removeActiveState","ifIsLatest","triggeredBy","prevent_close","id","close","list","last","createRef","componentDidMount","openBasedOnStateUpdate","componentWillUnmount","forEach","componentDidUpdate","prevProps","document","documentElement","modalId","render","defaultProps","context","getTranslation","root_id","content_id","disabled","labelled_by","focus_selector","header_content","bar_content","bypass_invalidation_selectors","omit_trigger_button","trigger","trigger_attributes","rest","_objectWithoutProperties","_excluded","children","Object","freeze","_objectSpread","suffixProps","triggerAttributes","hidden","variant","icon_position","fallbackTitle","title","translation","HelpButton","TriggerButton","text","createElement","Fragment","_extends","onClick","innerRef","className","class","Consumer","spacing","dialog_title","close_title","hide_close_button","close_button_attributes","prevent_core_style","no_animation_on_mobile","fullscreen","min_width","max_width","align_content","container_placement","direct_dom_return","on_open","on_close","on_close_prevent","overlay_class","content_class","OriginalComponent"],"sources":["../../../../src/components/modal/Modal.tsx"],"sourcesContent":["/**\n * Web Modal Component\n *\n */\n\nimport React from 'react'\nimport classnames from 'classnames'\nimport { SuffixContext } from '../../shared/helpers/Suffix'\nimport Context, { ContextProps } from '../../shared/Context'\nimport {\n warn,\n isTrue,\n makeUniqueId,\n extendPropsWithContextInClassComponent,\n processChildren,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport HelpButtonInstance from '../help-button/HelpButtonInstance'\nimport { getListOfModalRoots, getModalRoot } from './helpers'\nimport ModalInner from './parts/ModalInner'\nimport { ModalProps } from './types'\n\nimport ModalHeader from './parts/ModalHeader'\nimport ModalHeaderBar from './parts/ModalHeaderBar'\nimport { ScrollViewAllProps } from '../../fragments/scroll-view/ScrollView'\nimport CloseButton from './parts/CloseButton'\nimport ModalRoot from './ModalRoot'\nimport type { SpacingProps } from '../../shared/types'\nimport {\n classWithCamelCaseProps,\n ToCamelCasePartial,\n} from '../../shared/helpers/withCamelCaseProps'\nimport type { ButtonProps } from '../button/Button'\n\nexport const ANIMATION_DURATION = 300\n\ninterface ModalState {\n hide: boolean\n modalActive: boolean\n}\n\nexport type ModalPropTypes = ModalProps &\n SpacingProps &\n Omit<ScrollViewAllProps, 'children'>\n\nclass Modal extends React.PureComponent<\n ModalPropTypes & ToCamelCasePartial<ModalPropTypes>,\n ModalState\n> {\n static contextType = Context\n\n context!: ContextProps\n\n static Bar = ModalHeaderBar\n static Header = ModalHeader\n static Content = ModalInner\n\n static getContent(props) {\n if (typeof props.modal_content === 'string') {\n return props.modal_content\n } else if (typeof props.modal_content === 'function') {\n return props.modal_content(props)\n }\n return processChildren(props)\n }\n\n _id: string\n _triggerRef: React.RefObject<any>\n _onUnmount: Array<() => void>\n _openTimeout: NodeJS.Timeout\n _closeTimeout: NodeJS.Timeout\n _sideEffectsTimeout: NodeJS.Timeout\n _tryToOpenTimeout: NodeJS.Timeout\n activeElement: Element\n isInTransition: boolean\n\n state = {\n hide: false,\n modalActive: false,\n }\n\n static defaultProps = {\n id: null,\n focus_selector: null,\n labelled_by: null,\n title: null,\n disabled: null,\n spacing: true,\n open_delay: null,\n content_id: null,\n dialog_title: 'Vindu',\n close_title: 'Lukk', // Close Modal Window\n hide_close_button: false,\n close_button_attributes: null,\n prevent_close: false,\n prevent_core_style: false,\n animation_duration: ANIMATION_DURATION,\n no_animation: false,\n no_animation_on_mobile: false,\n fullscreen: 'auto',\n min_width: null,\n max_width: null,\n align_content: 'left',\n container_placement: null,\n open_state: null,\n direct_dom_return: false,\n class: null,\n root_id: 'root',\n omit_trigger_button: false,\n\n className: null,\n children: null,\n\n on_open: null,\n on_close: null,\n on_close_prevent: null,\n open_modal: null,\n close_modal: null,\n\n trigger: null,\n trigger_attributes: null,\n\n overlay_class: null,\n content_class: null,\n\n modal_content: null,\n header_content: null,\n bar_content: null,\n }\n\n static getDerivedStateFromProps(props, state) {\n if (props.open_state !== state._open_state) {\n switch (props.open_state) {\n case 'opened':\n case true:\n state.hide = false\n if (isTrue(props.no_animation)) {\n state.modalActive = true\n }\n break\n case 'closed':\n case false:\n state.hide = true\n if (isTrue(props.no_animation)) {\n state.modalActive = false\n }\n break\n }\n }\n state._open_state = props.open_state\n\n return state\n }\n\n constructor(props) {\n super(props)\n this._id = props.id || makeUniqueId('modal-')\n\n this._triggerRef = React.createRef()\n\n this._onUnmount = []\n }\n\n componentDidMount() {\n this.openBasedOnStateUpdate()\n }\n\n componentWillUnmount() {\n clearTimeout(this._openTimeout)\n clearTimeout(this._closeTimeout)\n\n this.removeActiveState()\n\n this._onUnmount.forEach((fn) => {\n if (typeof fn === 'function') {\n fn()\n }\n })\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps !== this.props) {\n this.openBasedOnStateUpdate()\n }\n }\n\n openBasedOnStateUpdate() {\n const { hide } = this.state\n const { open_state } = this.props\n\n if (!this.activeElement && typeof document !== 'undefined') {\n this.activeElement = document.activeElement\n }\n\n if (!hide && (open_state === 'opened' || open_state === true)) {\n this.toggleOpenClose(null, true)\n } else if (hide && (open_state === 'closed' || open_state === false)) {\n this.toggleOpenClose(null, false)\n }\n }\n\n toggleOpenClose = (event = null, showModal = null) => {\n if (event && event.preventDefault) {\n event.preventDefault()\n }\n\n const toggleNow = () => {\n const {\n animation_duration = ANIMATION_DURATION,\n no_animation = false,\n } = this.props\n const timeoutDuration =\n typeof animation_duration === 'string'\n ? parseFloat(animation_duration)\n : animation_duration\n\n const modalActive =\n typeof showModal === 'boolean'\n ? showModal\n : !this.state.modalActive\n\n this.isInTransition = true\n\n const doItNow = () => {\n this.setState(\n {\n hide: false,\n modalActive,\n },\n () => {\n this.isInTransition = false\n this.handleSideEffects()\n }\n )\n }\n\n if (modalActive === false && !isTrue(no_animation)) {\n this.setState({\n hide: true,\n })\n\n this._closeTimeout = setTimeout(doItNow, timeoutDuration) // delay because of the animation\n } else {\n doItNow()\n }\n }\n\n const waitBeforeOpen = () => {\n const { open_delay, no_animation } = this.props\n const delay =\n typeof open_delay === 'string'\n ? parseFloat(open_delay)\n : open_delay\n if (delay > 0 && !isTrue(no_animation)) {\n this._openTimeout = setTimeout(toggleNow, delay) // custom delay\n } else {\n toggleNow()\n }\n }\n\n clearTimeout(this._closeTimeout)\n clearTimeout(this._openTimeout)\n\n const { open_modal } = this.props\n if (typeof open_modal === 'function') {\n const fn = open_modal(waitBeforeOpen, this)\n if (fn) {\n this._onUnmount.push(fn)\n }\n } else {\n waitBeforeOpen()\n }\n }\n\n handleSideEffects = () => {\n const { modalActive } = this.state\n const { close_modal, open_state, animation_duration } = this.props\n\n if (modalActive) {\n if (typeof close_modal === 'function') {\n const fn = close_modal(() => {\n this.toggleOpenClose(null, false)\n }, this)\n if (fn) {\n this._onUnmount.push(fn)\n }\n }\n\n this.setActiveState(this._id)\n } else if (modalActive === false) {\n const focus = (elem: HTMLElement) => {\n // So we can omit showing a Tooltip on the trigger button\n elem.setAttribute('data-autofocus', 'true')\n\n elem.focus({ preventScroll: true })\n\n return new Promise<void>((resolve) => {\n setTimeout(\n () => {\n elem?.removeAttribute('data-autofocus')\n resolve()\n },\n parseFloat(String(animation_duration)) / 3\n )\n })\n }\n\n if (this._triggerRef?.current) {\n focus(this._triggerRef.current)\n }\n\n // because the open_state was set to opened, we force\n if (\n (open_state === 'opened' || open_state === true) &&\n this.activeElement instanceof HTMLElement\n ) {\n try {\n focus(this.activeElement).then(() => {\n this.activeElement = null\n })\n } catch (e) {\n //\n }\n }\n\n this.removeActiveState()\n }\n }\n\n open = (e: Event) => {\n this.toggleOpenClose(e, true)\n }\n\n close = (\n event: Event,\n { ifIsLatest, triggeredBy = null } = { ifIsLatest: true }\n ) => {\n const { prevent_close = false } = this.props\n\n if (isTrue(prevent_close)) {\n const id = this._id\n dispatchCustomElementEvent(this, 'on_close_prevent', {\n id,\n event,\n triggeredBy,\n close: (e) => {\n this.toggleOpenClose(e, false)\n },\n })\n } else {\n if (ifIsLatest) {\n const list = getListOfModalRoots()\n if (list.length > 1) {\n const last = getModalRoot(-1)\n if (last !== this) {\n return // stop here\n }\n }\n }\n\n this.toggleOpenClose(event, false)\n }\n }\n\n removeActiveState() {\n const last = getModalRoot(-1)\n\n // If this instance is not the last one,\n // make the current one to as the active one\n if (last?._id && last._id !== this._id) {\n return this.setActiveState(last._id)\n }\n\n try {\n document.documentElement.removeAttribute('data-dnb-modal-active')\n } catch (e) {\n warn('Modal: Error on remove \"data-dnb-modal-active\"', e)\n }\n }\n\n /**\n * Prevent scrolling on the background\n * But checks if this instance was the last one or not\n *\n * @param {string} modalId Will remove the attribute if false is given\n */\n setActiveState(modalId: string) {\n if (!modalId) {\n warn('Modal: A valid modalId is required')\n }\n // prevent scrolling on the background\n if (typeof document !== 'undefined') {\n try {\n document.documentElement.setAttribute(\n 'data-dnb-modal-active',\n modalId\n )\n } catch (e) {\n warn('Modal: Error on set \"data-dnb-modal-active\"', e)\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 Modal.defaultProps,\n this.context.getTranslation(this.props).Modal,\n this.context.Modal\n )\n\n const {\n root_id = 'root',\n content_id = null,\n disabled = null,\n labelled_by = null,\n focus_selector = null,\n header_content = null,\n bar_content = null,\n bypass_invalidation_selectors = null,\n\n id, // eslint-disable-line\n open_state, // eslint-disable-line\n open_delay, // eslint-disable-line\n\n omit_trigger_button = false,\n trigger = null,\n trigger_attributes = null,\n ...rest\n } = props\n\n const { hide, modalActive } = this.state\n const modal_content = Modal.getContent(\n typeof this.props.children === 'function'\n ? Object.freeze({ ...this.props, close: this.close })\n : this.props\n )\n\n const render = (suffixProps) => {\n const triggerAttributes = {\n hidden: false,\n variant: 'secondary',\n icon_position: 'left',\n ...trigger_attributes,\n } as ButtonProps\n\n if (isTrue(disabled)) {\n triggerAttributes.disabled = true\n }\n\n if (triggerAttributes.id) {\n this._id = triggerAttributes.id\n }\n\n let fallbackTitle: string\n if (triggerAttributes.title) {\n fallbackTitle = triggerAttributes.title\n }\n // in case the modal is used in suffix and no title is given\n // suffixProps.label is also available, so we could use that too\n else if (suffixProps) {\n fallbackTitle = this.context.translation.HelpButton.title\n }\n\n const TriggerButton = trigger\n ? (trigger as React.FC)\n : HelpButtonInstance\n\n const title = (\n !triggerAttributes.text ? rest.title || fallbackTitle : null\n ) as string\n\n return (\n <>\n {TriggerButton && !isTrue(omit_trigger_button) && (\n <TriggerButton\n {...triggerAttributes}\n id={this._id}\n title={title}\n onClick={this.toggleOpenClose}\n innerRef={this._triggerRef}\n className={classnames(\n 'dnb-modal__trigger',\n createSpacingClasses(props),\n triggerAttributes.class,\n triggerAttributes.className\n )}\n />\n )}\n\n {modalActive && modal_content && (\n <ModalRoot\n {...rest}\n id={this._id}\n root_id={root_id}\n content_id={content_id || `dnb-modal-${this._id}`}\n labelled_by={labelled_by}\n focus_selector={focus_selector}\n modal_content={modal_content}\n header_content={header_content}\n bar_content={bar_content}\n bypass_invalidation_selectors={bypass_invalidation_selectors}\n close={this.close}\n hide={hide}\n title={rest.title || fallbackTitle}\n />\n )}\n </>\n )\n }\n\n return <SuffixContext.Consumer>{render}</SuffixContext.Consumer>\n }\n}\n\nexport { CloseButton, Modal as OriginalComponent }\n\nexport default classWithCamelCaseProps(Modal)\n"],"mappings":"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"}
@@ -51,15 +51,11 @@ export default class ModalHeaderBar extends React.PureComponent {
51
51
  showShadow
52
52
  } = this.state;
53
53
  const {
54
- title,
55
54
  hide_close_button = false,
56
55
  close_button_attributes,
57
56
  onCloseClickHandler,
58
57
  close_title
59
58
  } = this.context;
60
- if (!title && isTrue(hide_close_button) && !this._ref.current) {
61
- return null;
62
- }
63
59
  return React.createElement(Section, _extends({
64
60
  style_type: "white",
65
61
  className: classnames('dnb-modal__header__bar', className, showShadow && shadow_class),
@@ -1 +1 @@
1
- {"version":3,"file":"ModalHeaderBar.js","names":["React","classnames","isTrue","Section","ModalContext","CloseButton","ModalHeaderBar","PureComponent","constructor","props","_defineProperty","showShadow","_ref","createRef","componentDidMount","window","IntersectionObserver","current","marginTop","clientHeight","intersectionObserver","entries","entry","setState","isIntersecting","rootMargin","threshold","observe","componentWillUnmount","_this$intersectionObs","disconnect","render","_this$props","className","children","ref","shadow_class","_objectWithoutProperties","_excluded","state","title","hide_close_button","close_button_attributes","onCloseClickHandler","close_title","context","createElement","_extends","style_type","inner_ref","on_click"],"sources":["../../../../../src/components/modal/parts/ModalHeaderBar.tsx"],"sourcesContent":["/**\n * Web Modal Component\n *\n */\n\nimport React from 'react'\nimport classnames from 'classnames'\nimport { isTrue } from '../../../shared/component-helper'\nimport Section from '../../section/Section'\nimport ModalContext from '../ModalContext'\nimport CloseButton from './CloseButton'\nimport { SectionProps } from '../../Section'\nimport { ReactChildType } from '../types'\n\nexport interface ModalHeaderBarProps\n extends Omit<SectionProps, 'children'> {\n /**\n * The content which will appear when triggering the modal/drawer.\n */\n children?: ReactChildType\n\n /**\n * Give the inner content wrapper a class name (maps to `dnb-modal__content__inner`).\n */\n className?: string\n\n shadow_class?: string\n}\n\ninterface ModalHeaderBarState {\n showShadow: boolean\n}\n\nexport default class ModalHeaderBar extends React.PureComponent<\n ModalHeaderBarProps & Omit<React.HTMLProps<HTMLElement>, 'children'>,\n ModalHeaderBarState\n> {\n static contextType = ModalContext\n\n context!: React.ContextType<typeof ModalContext>\n\n _ref: React.RefObject<any>\n intersectionObserver: IntersectionObserver\n\n constructor(props) {\n super(props)\n this._ref = React.createRef()\n }\n\n state = { showShadow: false }\n\n componentDidMount() {\n if (\n typeof window !== 'undefined' &&\n typeof IntersectionObserver !== 'undefined' &&\n this._ref.current\n ) {\n const marginTop = -this._ref.current.clientHeight\n this.intersectionObserver = new IntersectionObserver(\n (entries) => {\n const [entry] = entries\n this.setState({\n showShadow: !entry.isIntersecting,\n })\n },\n {\n rootMargin: `${marginTop}px 0px 0px 0px`,\n threshold: 0.001,\n }\n )\n\n this.intersectionObserver.observe(this._ref.current)\n }\n }\n\n componentWillUnmount() {\n this.intersectionObserver?.disconnect()\n }\n\n render() {\n const {\n className = null,\n children = null,\n ref, //eslint-disable-line\n shadow_class = null,\n ...props\n } = this.props\n const { showShadow } = this.state\n const {\n title,\n hide_close_button = false,\n close_button_attributes,\n onCloseClickHandler,\n close_title,\n } = this.context\n\n if (!title && isTrue(hide_close_button) && !this._ref.current) {\n return null\n }\n\n return (\n <Section\n style_type=\"white\"\n className={classnames(\n 'dnb-modal__header__bar',\n showShadow && shadow_class,\n className\n )}\n inner_ref={this._ref}\n {...props}\n >\n <div className=\"dnb-modal__header__bar__inner\">\n {children as React.ReactNode}\n </div>\n\n {!isTrue(hide_close_button) && (\n <div className=\"dnb-modal__header__bar__close\">\n <CloseButton\n on_click={onCloseClickHandler}\n close_title={close_title}\n {...close_button_attributes}\n />\n </div>\n )}\n </Section>\n )\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"ModalHeaderBar.js","names":["React","classnames","isTrue","Section","ModalContext","CloseButton","ModalHeaderBar","PureComponent","constructor","props","_defineProperty","showShadow","_ref","createRef","componentDidMount","window","IntersectionObserver","current","marginTop","clientHeight","intersectionObserver","entries","entry","setState","isIntersecting","rootMargin","threshold","observe","componentWillUnmount","_this$intersectionObs","disconnect","render","_this$props","className","children","ref","shadow_class","_objectWithoutProperties","_excluded","state","hide_close_button","close_button_attributes","onCloseClickHandler","close_title","context","createElement","_extends","style_type","inner_ref","on_click"],"sources":["../../../../../src/components/modal/parts/ModalHeaderBar.tsx"],"sourcesContent":["/**\n * Web Modal Component\n *\n */\n\nimport React from 'react'\nimport classnames from 'classnames'\nimport { isTrue } from '../../../shared/component-helper'\nimport Section from '../../section/Section'\nimport ModalContext from '../ModalContext'\nimport CloseButton from './CloseButton'\nimport { SectionProps } from '../../Section'\nimport { ReactChildType } from '../types'\n\nexport interface ModalHeaderBarProps\n extends Omit<SectionProps, 'children'> {\n /**\n * The content which will appear when triggering the modal/drawer.\n */\n children?: ReactChildType\n\n /**\n * Give the inner content wrapper a class name (maps to `dnb-modal__content__inner`).\n */\n className?: string\n\n shadow_class?: string\n}\n\ninterface ModalHeaderBarState {\n showShadow: boolean\n}\n\nexport default class ModalHeaderBar extends React.PureComponent<\n ModalHeaderBarProps & Omit<React.HTMLProps<HTMLElement>, 'children'>,\n ModalHeaderBarState\n> {\n static contextType = ModalContext\n\n context!: React.ContextType<typeof ModalContext>\n\n _ref: React.RefObject<any>\n intersectionObserver: IntersectionObserver\n\n constructor(props) {\n super(props)\n this._ref = React.createRef()\n }\n\n state = { showShadow: false }\n\n componentDidMount() {\n if (\n typeof window !== 'undefined' &&\n typeof IntersectionObserver !== 'undefined' &&\n this._ref.current\n ) {\n const marginTop = -this._ref.current.clientHeight\n this.intersectionObserver = new IntersectionObserver(\n (entries) => {\n const [entry] = entries\n this.setState({\n showShadow: !entry.isIntersecting,\n })\n },\n {\n rootMargin: `${marginTop}px 0px 0px 0px`,\n threshold: 0.001,\n }\n )\n\n this.intersectionObserver.observe(this._ref.current)\n }\n }\n\n componentWillUnmount() {\n this.intersectionObserver?.disconnect()\n }\n\n render() {\n const {\n className = null,\n children = null,\n ref, //eslint-disable-line\n shadow_class = null,\n ...props\n } = this.props\n const { showShadow } = this.state\n const {\n hide_close_button = false,\n close_button_attributes,\n onCloseClickHandler,\n close_title,\n } = this.context\n\n return (\n <Section\n style_type=\"white\"\n className={classnames(\n 'dnb-modal__header__bar',\n showShadow && shadow_class,\n className\n )}\n inner_ref={this._ref}\n {...props}\n >\n <div className=\"dnb-modal__header__bar__inner\">\n {children as React.ReactNode}\n </div>\n\n {!isTrue(hide_close_button) && (\n <div className=\"dnb-modal__header__bar__close\">\n <CloseButton\n on_click={onCloseClickHandler}\n close_title={close_title}\n {...close_button_attributes}\n />\n </div>\n )}\n </Section>\n )\n }\n}\n"],"mappings":";;;;AAKA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,QAAQ,kCAAkC;AACzD,OAAOC,OAAO,MAAM,uBAAuB;AAC3C,OAAOC,YAAY,MAAM,iBAAiB;AAC1C,OAAOC,WAAW,MAAM,eAAe;AAuBvC,eAAe,MAAMC,cAAc,SAASN,KAAK,CAACO,aAAa,CAG7D;EAQAC,WAAWA,CAACC,KAAK,EAAE;IACjB,KAAK,CAACA,KAAK,CAAC;IAAAC,eAAA;IAAAA,eAAA;IAAAA,eAAA;IAAAA,eAAA,gBAIN;MAAEC,UAAU,EAAE;IAAM,CAAC;IAH3B,IAAI,CAACC,IAAI,GAAGZ,KAAK,CAACa,SAAS,CAAC,CAAC;EAC/B;EAIAC,iBAAiBA,CAAA,EAAG;IAClB,IACE,OAAOC,MAAM,KAAK,WAAW,IAC7B,OAAOC,oBAAoB,KAAK,WAAW,IAC3C,IAAI,CAACJ,IAAI,CAACK,OAAO,EACjB;MACA,MAAMC,SAAS,GAAG,CAAC,IAAI,CAACN,IAAI,CAACK,OAAO,CAACE,YAAY;MACjD,IAAI,CAACC,oBAAoB,GAAG,IAAIJ,oBAAoB,CACjDK,OAAO,IAAK;QACX,MAAM,CAACC,KAAK,CAAC,GAAGD,OAAO;QACvB,IAAI,CAACE,QAAQ,CAAC;UACZZ,UAAU,EAAE,CAACW,KAAK,CAACE;QACrB,CAAC,CAAC;MACJ,CAAC,EACD;QACEC,UAAU,EAAG,GAAEP,SAAU,gBAAe;QACxCQ,SAAS,EAAE;MACb,CACF,CAAC;MAED,IAAI,CAACN,oBAAoB,CAACO,OAAO,CAAC,IAAI,CAACf,IAAI,CAACK,OAAO,CAAC;IACtD;EACF;EAEAW,oBAAoBA,CAAA,EAAG;IAAA,IAAAC,qBAAA;IACrB,CAAAA,qBAAA,OAAI,CAACT,oBAAoB,cAAAS,qBAAA,uBAAzBA,qBAAA,CAA2BC,UAAU,CAAC,CAAC;EACzC;EAEAC,MAAMA,CAAA,EAAG;IACP,MAAAC,WAAA,GAMI,IAAI,CAACvB,KAAK;MANR;QACJwB,SAAS,GAAG,IAAI;QAChBC,QAAQ,GAAG,IAAI;QACfC,GAAG;QACHC,YAAY,GAAG;MAEjB,CAAC,GAAAJ,WAAA;MADIvB,KAAK,GAAA4B,wBAAA,CAAAL,WAAA,EAAAM,SAAA;IAEV,MAAM;MAAE3B;IAAW,CAAC,GAAG,IAAI,CAAC4B,KAAK;IACjC,MAAM;MACJC,iBAAiB,GAAG,KAAK;MACzBC,uBAAuB;MACvBC,mBAAmB;MACnBC;IACF,CAAC,GAAG,IAAI,CAACC,OAAO;IAEhB,OACE5C,KAAA,CAAA6C,aAAA,CAAC1C,OAAO,EAAA2C,QAAA;MACNC,UAAU,EAAC,OAAO;MAClBd,SAAS,EAAEhC,UAAU,CACnB,wBAAwB,EAExBgC,SAAS,EADTtB,UAAU,IAAIyB,YAEhB,CAAE;MACFY,SAAS,EAAE,IAAI,CAACpC;IAAK,GACjBH,KAAK,GAETT,KAAA,CAAA6C,aAAA;MAAKZ,SAAS,EAAC;IAA+B,GAC3CC,QACE,CAAC,EAEL,CAAChC,MAAM,CAACsC,iBAAiB,CAAC,IACzBxC,KAAA,CAAA6C,aAAA;MAAKZ,SAAS,EAAC;IAA+B,GAC5CjC,KAAA,CAAA6C,aAAA,CAACxC,WAAW,EAAAyC,QAAA;MACVG,QAAQ,EAAEP,mBAAoB;MAC9BC,WAAW,EAAEA;IAAY,GACrBF,uBAAuB,CAC5B,CACE,CAEA,CAAC;EAEd;AACF;AAAC/B,eAAA,CAzFoBJ,cAAc,iBAIZF,YAAY"}
@@ -1 +1 @@
1
- {"version":3,"file":"Pagination.js","names":["React","PropTypes","classnames","PaginationContext","PaginationProvider","validateDOMAttributes","extendPropsWithContextInClassComponent","spacingPropTypes","createSpacingClasses","PaginationIndicator","InfinityScroller","PaginationBar","paginationPropTypes","process","env","NODE_ENV","_objectSpread","startup_page","oneOfType","string","number","current_page","page_count","startup_count","parallel_load_count","place_maker_before_content","bool","min_wait_time","disabled","skeleton","mode","oneOf","use_load_button","items","array","hide_progress_indicator","set_content_handler","func","reset_content_handler","reset_pagination_handler","end_infinity_handler","page_element","object","node","fallback_element","marker_element","indicator_element","align","button_title","prev_title","next_title","more_pages","is_loading_text","load_button_text","class","className","children","on_change","on_startup","on_load","on_end","paginationDefaultProps","undefined","Pagination","PureComponent","render","createElement","_extends","tagName","internalContent","props","PaginationInstance","_defineProperty","propTypes","constructor","_contentRef","createRef","context","getTranslation","_className","_disabled","_skeleton","_tagName","_page_count","_current_page","_startup_page","_mode","_hide_progress_indicator","_use_load_button","currentPage","_currentPage","attributes","_objectWithoutProperties","_excluded","pagination","_items$find","mainParams","content","find","_ref","pageNumber","contentRef","length","PaginationContent","ref","_InfinityScroller","InfinityMarker","_this$props","_excluded2","useMarkerOnly","forwardRef","_ref2","_excluded3","tabIndex","isRequired","Bar","Content","PaginationWrapper","InfinityMarkerWrapper","createPagination","initProps","arguments","store","rerender","_setContent","_resetContent","_resetInfinity","_endInfinity","setContent","current","resetContent","resetInfinity","endInfinity","args","fn"],"sources":["../../../../src/components/pagination/Pagination.js"],"sourcesContent":["/**\n * Web Pagination Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport PaginationContext from './PaginationContext'\nimport PaginationProvider from './PaginationProvider'\nimport {\n validateDOMAttributes,\n extendPropsWithContextInClassComponent,\n} from '../../shared/component-helper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\n\nimport { PaginationIndicator } from './PaginationHelpers'\nimport InfinityScroller from './PaginationInfinity'\nimport PaginationBar from './PaginationBar'\n\n\nconst paginationPropTypes = {\n startup_page: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n current_page: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n page_count: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n startup_count: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n parallel_load_count: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number,\n ]),\n place_maker_before_content: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n min_wait_time: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n mode: PropTypes.oneOf(['pagination', 'infinity']),\n use_load_button: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n items: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),\n hide_progress_indicator: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n set_content_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n reset_content_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n reset_pagination_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n end_infinity_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n page_element: PropTypes.oneOfType([\n PropTypes.object,\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n fallback_element: PropTypes.oneOfType([\n PropTypes.object,\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n marker_element: PropTypes.oneOfType([\n PropTypes.object,\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n indicator_element: PropTypes.oneOfType([\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n align: PropTypes.string,\n button_title: PropTypes.string,\n prev_title: PropTypes.string,\n next_title: PropTypes.string,\n more_pages: PropTypes.string,\n is_loading_text: PropTypes.string,\n load_button_text: PropTypes.string,\n\n ...spacingPropTypes,\n\n class: PropTypes.string,\n className: PropTypes.string,\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),\n\n on_change: PropTypes.func,\n on_startup: PropTypes.func,\n on_load: PropTypes.func,\n on_end: PropTypes.func,\n}\n\nconst paginationDefaultProps = {\n startup_page: null,\n current_page: null,\n page_count: null,\n mode: 'pagination',\n use_load_button: false,\n items: null,\n hide_progress_indicator: false,\n set_content_handler: null,\n reset_content_handler: null,\n page_element: undefined,\n fallback_element: undefined,\n marker_element: undefined,\n indicator_element: undefined,\n align: 'left',\n button_title: null,\n prev_title: null,\n next_title: null,\n more_pages: null,\n is_loading_text: null,\n load_button_text: null,\n startup_count: 1,\n parallel_load_count: 1,\n place_maker_before_content: false,\n min_wait_time: 400,\n disabled: null,\n skeleton: null,\n\n class: null,\n className: null,\n children: null,\n\n on_change: null,\n on_startup: null,\n on_load: null,\n on_end: null,\n}\n\nexport default class Pagination extends React.PureComponent {\n static propTypes = { ...paginationPropTypes }\n static defaultProps = paginationDefaultProps\n\n render() {\n return (\n <PaginationProvider\n tagName=\"dnb-pagination\"\n internalContent={this.props.children}\n {...this.props}\n >\n <PaginationInstance {...this.props} />\n </PaginationProvider>\n )\n }\n}\n\nclass PaginationInstance extends React.PureComponent {\n static propTypes = { ...paginationPropTypes }\n static defaultProps = paginationDefaultProps\n static contextType = PaginationContext\n\n constructor(props) {\n super(props)\n this._contentRef = React.createRef()\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n paginationDefaultProps,\n this.context.getTranslation(this.props).Pagination,\n this.context.Pagination\n )\n\n const {\n align,\n children,\n className,\n class: _className,\n\n disabled: _disabled, // eslint-disable-line\n skeleton: _skeleton, // eslint-disable-line\n tagName: _tagName, // eslint-disable-line\n page_count: _page_count, // eslint-disable-line\n current_page: _current_page, // eslint-disable-line\n startup_page: _startup_page, // eslint-disable-line\n mode: _mode, // eslint-disable-line\n hide_progress_indicator: _hide_progress_indicator, // eslint-disable-line\n use_load_button: _use_load_button, // eslint-disable-line\n currentPage: _currentPage, // eslint-disable-line\n\n ...attributes\n } = props\n\n // our props\n const { currentPage, items, fallback_element, indicator_element } =\n this.context.pagination\n\n // Pagination mode\n if (this.context.pagination.mode === 'pagination') {\n const mainParams = {\n className: classnames(\n 'dnb-pagination',\n align && `dnb-pagination--${align}`,\n createSpacingClasses(props),\n className,\n _className\n ),\n ...attributes,\n }\n\n validateDOMAttributes(props, mainParams)\n\n const content = items.find(\n ({ pageNumber }) => pageNumber === currentPage\n )?.content\n\n return (\n <div {...mainParams}>\n <PaginationBar contentRef={this._contentRef}>\n {children}\n </PaginationBar>\n {items.length > 0 && (\n <PaginationContent ref={this._contentRef}>\n {content || (\n <PaginationIndicator\n indicator_element={indicator_element || fallback_element}\n />\n )}\n </PaginationContent>\n )}\n </div>\n )\n }\n\n // InfinityScroller mode\n return <InfinityScroller />\n }\n}\n\nexport class InfinityMarker extends React.PureComponent {\n static propTypes = { ...paginationPropTypes }\n static defaultProps = paginationDefaultProps\n\n render() {\n const { children, ...props } = this.props\n return (\n <PaginationProvider\n useMarkerOnly\n tagName=\"dnb-infinity-marker\"\n {...props}\n >\n <InfinityScroller {...props}>{children}</InfinityScroller>\n </PaginationProvider>\n )\n }\n}\n\nconst PaginationContent = React.forwardRef(\n ({ children, ...props }, ref) => {\n return (\n <div\n className=\"dnb-pagination__content dnb-no-focus\"\n tabIndex=\"-1\"\n {...props}\n ref={ref}\n >\n {children}\n </div>\n )\n }\n)\nPaginationContent.propTypes = {\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func])\n .isRequired,\n}\n\n// NB: This is not ready yet\nPagination.Bar = PaginationBar\nPagination.Content = PaginationContent\n\nconst PaginationWrapper = Pagination\nconst InfinityMarkerWrapper = InfinityMarker\n\nexport const Bar = (props) => (\n <Pagination fallback_element={() => null} {...props} />\n)\n\nexport const createPagination = (initProps = {}) => {\n const store = React.createRef({})\n const rerender = React.createRef(null)\n const _setContent = React.createRef(null)\n const _resetContent = React.createRef(null)\n const _resetInfinity = React.createRef(null)\n const _endInfinity = React.createRef(null)\n\n const setContent = (pageNumber, content) => {\n if (pageNumber > 0) {\n store.current = { ...store.current, ...{ pageNumber, content } }\n rerender.current && rerender.current(store)\n }\n }\n const resetContent = () => {\n _resetContent.current && _resetContent.current()\n }\n const resetInfinity = () => {\n _resetInfinity.current && _resetInfinity.current()\n }\n const endInfinity = () => {\n _endInfinity.current && _endInfinity.current()\n }\n\n const args = (props) => ({\n ...{ ...initProps, ...props },\n store,\n rerender,\n set_content_handler: (fn) => (_setContent.current = fn),\n reset_content_handler: (fn) => (_resetContent.current = fn),\n reset_pagination_handler: (fn) => (_resetInfinity.current = fn),\n end_infinity_handler: (fn) => (_endInfinity.current = fn),\n })\n\n const Pagination = (props) => (\n <PaginationWrapper tagName=\"dnb-pagination\" {...args(props)} />\n )\n\n const InfinityMarker = (props) => (\n <InfinityMarkerWrapper\n tagName={InfinityMarkerWrapper?.tagName}\n {...args(props)}\n />\n )\n\n return {\n Pagination,\n InfinityMarker,\n setContent,\n resetContent,\n resetInfinity,\n endInfinity,\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"Pagination.js","names":["React","PropTypes","classnames","PaginationContext","PaginationProvider","validateDOMAttributes","extendPropsWithContextInClassComponent","spacingPropTypes","createSpacingClasses","PaginationIndicator","InfinityScroller","PaginationBar","paginationPropTypes","process","env","NODE_ENV","_objectSpread","startup_page","oneOfType","string","number","current_page","page_count","startup_count","parallel_load_count","place_maker_before_content","bool","min_wait_time","disabled","skeleton","mode","oneOf","use_load_button","items","array","hide_progress_indicator","set_content_handler","func","reset_content_handler","reset_pagination_handler","end_infinity_handler","page_element","object","node","fallback_element","marker_element","indicator_element","align","button_title","prev_title","next_title","more_pages","is_loading_text","load_button_text","class","className","children","on_change","on_startup","on_load","on_end","paginationDefaultProps","undefined","Pagination","PureComponent","render","createElement","_extends","tagName","internalContent","props","PaginationInstance","_defineProperty","propTypes","constructor","_contentRef","createRef","context","getTranslation","_className","_disabled","_skeleton","_tagName","_page_count","_current_page","_startup_page","_mode","_hide_progress_indicator","_use_load_button","currentPage","_currentPage","attributes","_objectWithoutProperties","_excluded","pagination","_items$find","mainParams","content","find","_ref","pageNumber","contentRef","length","PaginationContent","ref","_InfinityScroller","InfinityMarker","_this$props","_excluded2","useMarkerOnly","forwardRef","_ref2","_excluded3","tabIndex","isRequired","Bar","Content","PaginationWrapper","InfinityMarkerWrapper","createPagination","initProps","arguments","store","rerender","_setContent","_resetContent","_resetInfinity","_endInfinity","setContent","current","resetContent","resetInfinity","endInfinity","args","fn"],"sources":["../../../../src/components/pagination/Pagination.js"],"sourcesContent":["/**\n * Web Pagination Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport PaginationContext from './PaginationContext'\nimport PaginationProvider from './PaginationProvider'\nimport {\n validateDOMAttributes,\n extendPropsWithContextInClassComponent,\n} from '../../shared/component-helper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\n\nimport { PaginationIndicator } from './PaginationHelpers'\nimport InfinityScroller from './PaginationInfinity'\nimport PaginationBar from './PaginationBar'\n\nconst paginationPropTypes = {\n startup_page: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n current_page: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n page_count: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n startup_count: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n parallel_load_count: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number,\n ]),\n place_maker_before_content: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n min_wait_time: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n mode: PropTypes.oneOf(['pagination', 'infinity']),\n use_load_button: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n items: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),\n hide_progress_indicator: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n set_content_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n reset_content_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n reset_pagination_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n end_infinity_handler: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n ]),\n page_element: PropTypes.oneOfType([\n PropTypes.object,\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n fallback_element: PropTypes.oneOfType([\n PropTypes.object,\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n marker_element: PropTypes.oneOfType([\n PropTypes.object,\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n indicator_element: PropTypes.oneOfType([\n PropTypes.node,\n PropTypes.func,\n PropTypes.string,\n ]),\n align: PropTypes.string,\n button_title: PropTypes.string,\n prev_title: PropTypes.string,\n next_title: PropTypes.string,\n more_pages: PropTypes.string,\n is_loading_text: PropTypes.string,\n load_button_text: PropTypes.string,\n\n ...spacingPropTypes,\n\n class: PropTypes.string,\n className: PropTypes.string,\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),\n\n on_change: PropTypes.func,\n on_startup: PropTypes.func,\n on_load: PropTypes.func,\n on_end: PropTypes.func,\n}\n\nconst paginationDefaultProps = {\n startup_page: null,\n current_page: null,\n page_count: null,\n mode: 'pagination',\n use_load_button: false,\n items: null,\n hide_progress_indicator: false,\n set_content_handler: null,\n reset_content_handler: null,\n page_element: undefined,\n fallback_element: undefined,\n marker_element: undefined,\n indicator_element: undefined,\n align: 'left',\n button_title: null,\n prev_title: null,\n next_title: null,\n more_pages: null,\n is_loading_text: null,\n load_button_text: null,\n startup_count: 1,\n parallel_load_count: 1,\n place_maker_before_content: false,\n min_wait_time: 400,\n disabled: null,\n skeleton: null,\n\n class: null,\n className: null,\n children: null,\n\n on_change: null,\n on_startup: null,\n on_load: null,\n on_end: null,\n}\n\nexport default class Pagination extends React.PureComponent {\n static propTypes = { ...paginationPropTypes }\n static defaultProps = paginationDefaultProps\n\n render() {\n return (\n <PaginationProvider\n tagName=\"dnb-pagination\"\n internalContent={this.props.children}\n {...this.props}\n >\n <PaginationInstance {...this.props} />\n </PaginationProvider>\n )\n }\n}\n\nclass PaginationInstance extends React.PureComponent {\n static propTypes = { ...paginationPropTypes }\n static defaultProps = paginationDefaultProps\n static contextType = PaginationContext\n\n constructor(props) {\n super(props)\n this._contentRef = React.createRef()\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n paginationDefaultProps,\n this.context.getTranslation(this.props).Pagination,\n this.context.Pagination\n )\n\n const {\n align,\n children,\n className,\n class: _className,\n\n disabled: _disabled, // eslint-disable-line\n skeleton: _skeleton, // eslint-disable-line\n tagName: _tagName, // eslint-disable-line\n page_count: _page_count, // eslint-disable-line\n current_page: _current_page, // eslint-disable-line\n startup_page: _startup_page, // eslint-disable-line\n mode: _mode, // eslint-disable-line\n hide_progress_indicator: _hide_progress_indicator, // eslint-disable-line\n use_load_button: _use_load_button, // eslint-disable-line\n currentPage: _currentPage, // eslint-disable-line\n\n ...attributes\n } = props\n\n // our props\n const { currentPage, items, fallback_element, indicator_element } =\n this.context.pagination\n\n // Pagination mode\n if (this.context.pagination.mode === 'pagination') {\n const mainParams = {\n className: classnames(\n 'dnb-pagination',\n align && `dnb-pagination--${align}`,\n createSpacingClasses(props),\n className,\n _className\n ),\n ...attributes,\n }\n\n validateDOMAttributes(props, mainParams)\n\n const content = items.find(\n ({ pageNumber }) => pageNumber === currentPage\n )?.content\n\n return (\n <div {...mainParams}>\n <PaginationBar contentRef={this._contentRef}>\n {children}\n </PaginationBar>\n {items.length > 0 && (\n <PaginationContent ref={this._contentRef}>\n {content || (\n <PaginationIndicator\n indicator_element={indicator_element || fallback_element}\n />\n )}\n </PaginationContent>\n )}\n </div>\n )\n }\n\n // InfinityScroller mode\n return <InfinityScroller />\n }\n}\n\nexport class InfinityMarker extends React.PureComponent {\n static propTypes = { ...paginationPropTypes }\n static defaultProps = paginationDefaultProps\n\n render() {\n const { children, ...props } = this.props\n return (\n <PaginationProvider\n useMarkerOnly\n tagName=\"dnb-infinity-marker\"\n {...props}\n >\n <InfinityScroller {...props}>{children}</InfinityScroller>\n </PaginationProvider>\n )\n }\n}\n\nconst PaginationContent = React.forwardRef(\n ({ children, ...props }, ref) => {\n return (\n <div\n className=\"dnb-pagination__content dnb-no-focus\"\n tabIndex=\"-1\"\n {...props}\n ref={ref}\n >\n {children}\n </div>\n )\n }\n)\nPaginationContent.propTypes = {\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func])\n .isRequired,\n}\n\n// NB: This is not ready yet\nPagination.Bar = PaginationBar\nPagination.Content = PaginationContent\n\nconst PaginationWrapper = Pagination\nconst InfinityMarkerWrapper = InfinityMarker\n\nexport const Bar = (props) => (\n <Pagination fallback_element={() => null} {...props} />\n)\n\nexport const createPagination = (initProps = {}) => {\n const store = React.createRef({})\n const rerender = React.createRef(null)\n const _setContent = React.createRef(null)\n const _resetContent = React.createRef(null)\n const _resetInfinity = React.createRef(null)\n const _endInfinity = React.createRef(null)\n\n const setContent = (pageNumber, content) => {\n if (pageNumber > 0) {\n store.current = { ...store.current, ...{ pageNumber, content } }\n rerender.current && rerender.current(store)\n }\n }\n const resetContent = () => {\n _resetContent.current && _resetContent.current()\n }\n const resetInfinity = () => {\n _resetInfinity.current && _resetInfinity.current()\n }\n const endInfinity = () => {\n _endInfinity.current && _endInfinity.current()\n }\n\n const args = (props) => ({\n ...{ ...initProps, ...props },\n store,\n rerender,\n set_content_handler: (fn) => (_setContent.current = fn),\n reset_content_handler: (fn) => (_resetContent.current = fn),\n reset_pagination_handler: (fn) => (_resetInfinity.current = fn),\n end_infinity_handler: (fn) => (_endInfinity.current = fn),\n })\n\n const Pagination = (props) => (\n <PaginationWrapper tagName=\"dnb-pagination\" {...args(props)} />\n )\n\n const InfinityMarker = (props) => (\n <InfinityMarkerWrapper\n tagName={InfinityMarkerWrapper?.tagName}\n {...args(props)}\n />\n )\n\n return {\n Pagination,\n InfinityMarker,\n setContent,\n resetContent,\n resetInfinity,\n endInfinity,\n }\n}\n"],"mappings":"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"}
@@ -14,6 +14,13 @@
14
14
  flex-wrap: wrap;
15
15
  align-items: center;
16
16
  }
17
+ .dnb-pagination__page, .dnb-pagination__loadbar {
18
+ min-height: 6rem;
19
+ }
20
+ .dnb-pagination__bar {
21
+ margin-top: 1rem;
22
+ margin-bottom: 1rem;
23
+ }
17
24
  .dnb-pagination--left .dnb-pagination__bar {
18
25
  justify-content: flex-start;
19
26
  }
@@ -59,12 +66,14 @@
59
66
  display: flex;
60
67
  flex-direction: column;
61
68
  justify-content: center;
69
+ min-height: inherit;
62
70
  }
63
71
  .dnb-pagination__indicator__inner {
64
72
  display: flex;
65
73
  flex-direction: column;
66
74
  align-items: center;
67
75
  justify-content: center;
76
+ animation: show-page 300ms ease-out forwards;
68
77
  }
69
78
  .dnb-pagination__dots {
70
79
  align-self: flex-end;
@@ -88,4 +97,15 @@
88
97
  }
89
98
  .dnb-pagination__bar__skip .dnb-button:first-of-type {
90
99
  margin-right: 1.5rem;
100
+ }
101
+
102
+ @keyframes show-page {
103
+ from {
104
+ transform: translate3d(0, -8px, 0);
105
+ opacity: 0.1;
106
+ }
107
+ to {
108
+ transform: translate3d(0, 0, 0);
109
+ opacity: 1;
110
+ }
91
111
  }
@@ -1 +1 @@
1
- .dnb-pagination{display:flex;flex-direction:column-reverse}.dnb-pagination__bar,.dnb-pagination__bar__inner,.dnb-pagination__loadbar{align-items:center;display:flex;flex-wrap:wrap}.dnb-pagination--left .dnb-pagination__bar{justify-content:flex-start}.dnb-pagination--center .dnb-pagination__bar{justify-content:center}@media screen and (max-width:40em){.dnb-pagination--center .dnb-pagination__bar{justify-content:flex-start}}.dnb-pagination--right .dnb-pagination__bar{justify-content:flex-end}.dnb-pagination__bar__wrapper{display:flex;flex-flow:column-reverse wrap}.dnb-pagination--center .dnb-pagination__bar__wrapper{align-items:center}.dnb-pagination--right .dnb-pagination__bar__wrapper{align-items:flex-end}.dnb-pagination__bar__inner{grid-gap:.5rem;gap:.5rem}.dnb-pagination__button{max-width:3.5rem}.dnb-pagination__button--large-number{max-width:unset}.dnb-pagination__loadbar{align-items:center;cursor:default;display:flex;justify-content:center}.dnb-pagination__indicator{cursor:default;display:flex;flex-direction:column;justify-content:center}.dnb-pagination__indicator__inner{align-items:center;display:flex;flex-direction:column;justify-content:center}.dnb-pagination__dots{align-self:flex-end}.dnb-pagination__marker{height:1px;margin:-1px 0 0 -1px;overflow:hidden;pointer-events:none;position:relative;width:1px}.dnb-pagination__marker td,.dnb-pagination__marker__inner{height:1px;opacity:0;padding:0!important;width:1px}.dnb-pagination__bar__skip{margin-top:.5rem}.dnb-pagination__bar__skip .dnb-button:first-of-type{margin-right:1.5rem}
1
+ .dnb-pagination{display:flex;flex-direction:column-reverse}.dnb-pagination__bar,.dnb-pagination__bar__inner,.dnb-pagination__loadbar{align-items:center;display:flex;flex-wrap:wrap}.dnb-pagination__loadbar,.dnb-pagination__page{min-height:6rem}.dnb-pagination__bar{margin-bottom:1rem;margin-top:1rem}.dnb-pagination--left .dnb-pagination__bar{justify-content:flex-start}.dnb-pagination--center .dnb-pagination__bar{justify-content:center}@media screen and (max-width:40em){.dnb-pagination--center .dnb-pagination__bar{justify-content:flex-start}}.dnb-pagination--right .dnb-pagination__bar{justify-content:flex-end}.dnb-pagination__bar__wrapper{display:flex;flex-flow:column-reverse wrap}.dnb-pagination--center .dnb-pagination__bar__wrapper{align-items:center}.dnb-pagination--right .dnb-pagination__bar__wrapper{align-items:flex-end}.dnb-pagination__bar__inner{grid-gap:.5rem;gap:.5rem}.dnb-pagination__button{max-width:3.5rem}.dnb-pagination__button--large-number{max-width:unset}.dnb-pagination__loadbar{align-items:center;cursor:default;display:flex;justify-content:center}.dnb-pagination__indicator{cursor:default;display:flex;flex-direction:column;justify-content:center;min-height:inherit}.dnb-pagination__indicator__inner{align-items:center;animation:show-page .3s ease-out forwards;display:flex;flex-direction:column;justify-content:center}.dnb-pagination__dots{align-self:flex-end}.dnb-pagination__marker{height:1px;margin:-1px 0 0 -1px;overflow:hidden;pointer-events:none;position:relative;width:1px}.dnb-pagination__marker td,.dnb-pagination__marker__inner{height:1px;opacity:0;padding:0!important;width:1px}.dnb-pagination__bar__skip{margin-top:.5rem}.dnb-pagination__bar__skip .dnb-button:first-of-type{margin-right:1.5rem}@keyframes show-page{0%{opacity:.1;transform:translate3d(0,-8px,0)}to{opacity:1;transform:translateZ(0)}}
@@ -17,6 +17,16 @@
17
17
  align-items: center;
18
18
  }
19
19
 
20
+ &__page,
21
+ &__loadbar {
22
+ min-height: 6rem;
23
+ }
24
+
25
+ &__bar {
26
+ margin-top: 1rem;
27
+ margin-bottom: 1rem;
28
+ }
29
+
20
30
  &--left &__bar {
21
31
  justify-content: flex-start;
22
32
  }
@@ -70,12 +80,14 @@
70
80
  display: flex;
71
81
  flex-direction: column;
72
82
  justify-content: center;
83
+ min-height: inherit;
73
84
 
74
85
  &__inner {
75
86
  display: flex;
76
87
  flex-direction: column;
77
88
  align-items: center;
78
89
  justify-content: center;
90
+ animation: show-page 300ms ease-out forwards;
79
91
  }
80
92
  }
81
93
 
@@ -112,3 +124,15 @@
112
124
  margin-right: 1.5rem;
113
125
  }
114
126
  }
127
+
128
+ @keyframes show-page {
129
+ from {
130
+ transform: translate3d(0, -8px, 0);
131
+ opacity: 0.1;
132
+ }
133
+
134
+ to {
135
+ transform: translate3d(0, 0, 0);
136
+ opacity: 1;
137
+ }
138
+ }
@@ -0,0 +1,26 @@
1
+ /*
2
+ * Pagination theme
3
+ *
4
+ */
5
+ /*
6
+ * Utilities
7
+ */
8
+ .dnb-pagination__bar__skip .dnb-button--tertiary:not([disabled]) .dnb-button__text {
9
+ color: var(--sb-color-text);
10
+ }
11
+ .dnb-core-style .dnb-pagination__button.dnb-button, .dnb-pagination__button.dnb-button {
12
+ --button-primary-color: var(--sb-color-white);
13
+ --button-primary-color--active: var(--sb-color-white);
14
+ --button-primary-background: var(--sb-color-violet);
15
+ --button-primary-background--hover: var(--sb-color-violet-light-4);
16
+ --button-primary-background--active: var(--sb-color-violet);
17
+ --button-primary-border--hover: var(--sb-color-violet);
18
+ --button-secondary-background--hover: var(--sb-color-white);
19
+ --button-secondary-border--default: var(--sb-color-gray);
20
+ --button-secondary-border--hover: var(--sb-color-violet);
21
+ --button-secondary-border--active: var(--sb-color-gray);
22
+ }
23
+
24
+ .dnb-pagination__dots {
25
+ color: var(--sb-color-text);
26
+ }
@@ -0,0 +1 @@
1
+ .dnb-pagination__bar__skip .dnb-button--tertiary:not([disabled]) .dnb-button__text{color:var(--sb-color-text)}.dnb-core-style .dnb-pagination__button.dnb-button,.dnb-pagination__button.dnb-button{--button-primary-color:var(--sb-color-white);--button-primary-color--active:var(--sb-color-white);--button-primary-background:var(--sb-color-violet);--button-primary-background--hover:var(--sb-color-violet-light-4);--button-primary-background--active:var(--sb-color-violet);--button-primary-border--hover:var(--sb-color-violet);--button-secondary-background--hover:var(--sb-color-white);--button-secondary-border--default:var(--sb-color-gray);--button-secondary-border--hover:var(--sb-color-violet);--button-secondary-border--active:var(--sb-color-gray)}.dnb-pagination__dots{color:var(--sb-color-text)}
@@ -0,0 +1,35 @@
1
+ /*
2
+ * Pagination theme
3
+ *
4
+ */
5
+
6
+ @import '../../../../style/core/utilities.scss';
7
+
8
+ .dnb-pagination {
9
+ &__bar__skip {
10
+ // button tertiary
11
+ .dnb-button--tertiary:not([disabled]) .dnb-button__text {
12
+ color: var(--sb-color-text);
13
+ }
14
+ }
15
+ // active/checked - like toggle-button
16
+ @at-root .dnb-core-style &__button.dnb-button,
17
+ &__button.dnb-button {
18
+ // button primary
19
+ --button-primary-color: var(--sb-color-white);
20
+ --button-primary-color--active: var(--sb-color-white);
21
+ --button-primary-background: var(--sb-color-violet);
22
+ --button-primary-background--hover: var(--sb-color-violet-light-4);
23
+ --button-primary-background--active: var(--sb-color-violet);
24
+ --button-primary-border--hover: var(--sb-color-violet);
25
+ // button secondary
26
+ --button-secondary-background--hover: var(--sb-color-white);
27
+ --button-secondary-border--default: var(--sb-color-gray);
28
+ --button-secondary-border--hover: var(--sb-color-violet);
29
+ --button-secondary-border--active: var(--sb-color-gray);
30
+ }
31
+
32
+ &__dots {
33
+ color: var(--sb-color-text);
34
+ }
35
+ }