@dnb/eufemia 10.32.0 → 10.34.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 (938) hide show
  1. package/CHANGELOG.md +51 -0
  2. package/cjs/components/autocomplete/style/dnb-autocomplete.css +0 -1
  3. package/cjs/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  4. package/cjs/components/autocomplete/style/dnb-autocomplete.scss +0 -2
  5. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +41 -0
  6. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.min.css +1 -0
  7. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +65 -0
  8. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +3 -0
  9. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
  10. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +6 -0
  11. package/cjs/components/breadcrumb/Breadcrumb.d.ts +4 -4
  12. package/cjs/components/breadcrumb/Breadcrumb.js +5 -3
  13. package/cjs/components/breadcrumb/Breadcrumb.js.map +1 -1
  14. package/cjs/components/card/Card.js +1 -0
  15. package/cjs/components/card/Card.js.map +1 -1
  16. package/cjs/components/card/style/dnb-card.css +3 -0
  17. package/cjs/components/card/style/dnb-card.min.css +1 -1
  18. package/cjs/components/card/style/dnb-card.scss +4 -0
  19. package/cjs/components/checkbox/Checkbox.js +1 -1
  20. package/cjs/components/checkbox/Checkbox.js.map +1 -1
  21. package/cjs/components/checkbox/style/dnb-checkbox.css +9 -3
  22. package/cjs/components/checkbox/style/dnb-checkbox.min.css +1 -1
  23. package/cjs/components/checkbox/style/dnb-checkbox.scss +11 -3
  24. package/cjs/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.css +5 -3
  25. package/cjs/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.min.css +2 -2
  26. package/cjs/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.scss +5 -3
  27. package/cjs/components/flex/Container.js +4 -4
  28. package/cjs/components/flex/Container.js.map +1 -1
  29. package/cjs/components/form-row/FormRow.js +1 -1
  30. package/cjs/components/form-row/FormRow.js.map +1 -1
  31. package/cjs/components/form-set/FormSet.js +1 -1
  32. package/cjs/components/form-set/FormSet.js.map +1 -1
  33. package/cjs/components/form-status/FormStatus.d.ts +0 -1
  34. package/cjs/components/form-status/FormStatus.js +85 -67
  35. package/cjs/components/form-status/FormStatus.js.map +1 -1
  36. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +2 -2
  37. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -1
  38. package/cjs/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +2 -2
  39. package/cjs/components/global-status/GlobalStatus.js +2 -4
  40. package/cjs/components/global-status/GlobalStatus.js.map +1 -1
  41. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +1 -1
  42. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -1
  43. package/cjs/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +1 -1
  44. package/cjs/components/grid/Container.d.ts +2 -2
  45. package/cjs/components/grid/Container.js.map +1 -1
  46. package/cjs/components/grid/ContainerDocs.d.ts +2 -0
  47. package/cjs/components/grid/ContainerDocs.js +30 -0
  48. package/cjs/components/grid/ContainerDocs.js.map +1 -0
  49. package/cjs/components/grid/style/dnb-grid.css +6 -0
  50. package/cjs/components/grid/style/dnb-grid.min.css +1 -1
  51. package/cjs/components/grid/style/grid-container.scss +6 -0
  52. package/cjs/components/number-format/NumberFormat.js +1 -1
  53. package/cjs/components/number-format/NumberFormat.js.map +1 -1
  54. package/cjs/components/radio/style/dnb-radio.css +19 -7
  55. package/cjs/components/radio/style/dnb-radio.min.css +1 -1
  56. package/cjs/components/radio/style/dnb-radio.scss +21 -7
  57. package/cjs/components/radio/style/themes/dnb-radio-theme-sbanken.css +6 -0
  58. package/cjs/components/radio/style/themes/dnb-radio-theme-sbanken.min.css +1 -1
  59. package/cjs/components/radio/style/themes/dnb-radio-theme-sbanken.scss +6 -0
  60. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.css +1 -1
  61. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -1
  62. package/cjs/components/section/style/themes/dnb-section-theme-sbanken.scss +1 -1
  63. package/cjs/components/slider/SliderDocs.d.ts +3 -0
  64. package/cjs/components/slider/SliderDocs.js +158 -0
  65. package/cjs/components/slider/SliderDocs.js.map +1 -0
  66. package/cjs/components/step-indicator/StepIndicator.js +1 -10
  67. package/cjs/components/step-indicator/StepIndicator.js.map +1 -1
  68. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +1 -1
  69. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -1
  70. package/cjs/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +1 -1
  71. package/cjs/components/table/TableContainer.d.ts +1 -0
  72. package/cjs/components/table/TableContainer.js +1 -0
  73. package/cjs/components/table/TableContainer.js.map +1 -1
  74. package/cjs/components/table/style/dnb-table.css +3 -0
  75. package/cjs/components/table/style/dnb-table.min.css +1 -1
  76. package/cjs/components/table/style/table-container.scss +5 -0
  77. package/cjs/extensions/forms/DataContext/Context.d.ts +8 -5
  78. package/cjs/extensions/forms/DataContext/Context.js +0 -1
  79. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  80. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  81. package/cjs/extensions/forms/DataContext/Provider/Provider.js +30 -3
  82. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  83. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +7 -2
  84. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  85. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  86. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  87. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  88. package/cjs/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  89. package/cjs/extensions/forms/Field/Composition/Composition.js.map +1 -1
  90. package/cjs/extensions/forms/Field/Composition/CompositionDocs.d.ts +2 -0
  91. package/cjs/extensions/forms/Field/Composition/CompositionDocs.js +23 -0
  92. package/cjs/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -0
  93. package/cjs/extensions/forms/Field/Number/Number.d.ts +1 -0
  94. package/cjs/extensions/forms/Field/Number/Number.js +18 -15
  95. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  96. package/cjs/extensions/forms/Field/Number/NumberDocs.js +6 -1
  97. package/cjs/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  98. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  99. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  100. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  101. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  102. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  103. package/cjs/extensions/forms/Field/Selection/Selection.js +5 -6
  104. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  105. package/cjs/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  106. package/cjs/extensions/forms/Field/Slider/Slider.js +115 -0
  107. package/cjs/extensions/forms/Field/Slider/Slider.js.map +1 -0
  108. package/cjs/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  109. package/cjs/extensions/forms/Field/Slider/SliderDocs.js +34 -0
  110. package/cjs/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  111. package/cjs/extensions/forms/Field/Slider/index.d.ts +2 -0
  112. package/cjs/extensions/forms/Field/Slider/index.js +27 -0
  113. package/cjs/extensions/forms/Field/Slider/index.js.map +1 -0
  114. package/cjs/extensions/forms/Field/String/String.js +2 -2
  115. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  116. package/cjs/extensions/forms/Field/Toggle/Toggle.js +7 -7
  117. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  118. package/cjs/extensions/forms/Field/index.d.ts +1 -0
  119. package/cjs/extensions/forms/Field/index.js +7 -0
  120. package/cjs/extensions/forms/Field/index.js.map +1 -1
  121. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +4 -1
  122. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +15 -3
  123. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  124. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  125. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  126. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -1
  127. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  128. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -2
  129. package/cjs/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  130. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js +47 -24
  131. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  132. package/cjs/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  133. package/cjs/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  134. package/cjs/extensions/forms/Form/MainHeading/MainHeading.js +1 -0
  135. package/cjs/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  136. package/cjs/extensions/forms/Form/Section/Section.d.ts +36 -0
  137. package/cjs/extensions/forms/Form/Section/Section.js +79 -0
  138. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -0
  139. package/cjs/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  140. package/cjs/extensions/forms/Form/Section/SectionContext.js +12 -0
  141. package/cjs/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  142. package/cjs/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  143. package/cjs/extensions/forms/Form/Section/SectionDocs.js +53 -0
  144. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  145. package/cjs/extensions/forms/Form/Section/index.d.ts +2 -0
  146. package/cjs/extensions/forms/Form/Section/index.js +27 -0
  147. package/cjs/extensions/forms/Form/Section/index.js.map +1 -0
  148. package/cjs/extensions/forms/Form/SubHeading/SubHeading.js +1 -0
  149. package/cjs/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  150. package/cjs/extensions/forms/Form/Visibility/Visibility.js +15 -9
  151. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  152. package/cjs/extensions/forms/Form/data-context/useData.js +6 -2
  153. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  154. package/cjs/extensions/forms/Form/index.d.ts +1 -1
  155. package/cjs/extensions/forms/Form/index.js +7 -5
  156. package/cjs/extensions/forms/Form/index.js.map +1 -1
  157. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +2 -2
  158. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  159. package/cjs/extensions/forms/Iterate/Array/Array.js +37 -1
  160. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  161. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +15 -0
  162. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  163. package/cjs/extensions/forms/Iterate/Array/types.d.ts +9 -3
  164. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  165. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -2
  166. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  167. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  168. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  169. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  170. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  171. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -2
  172. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  173. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.css +1 -1
  174. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  175. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.scss +1 -0
  176. package/cjs/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  177. package/cjs/extensions/forms/Tools/GenerateSchema.js +143 -0
  178. package/cjs/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  179. package/cjs/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  180. package/cjs/extensions/forms/Tools/ListAllProps.js +73 -0
  181. package/cjs/extensions/forms/Tools/ListAllProps.js.map +1 -0
  182. package/{es/extensions/forms/Form → cjs/extensions/forms}/Tools/index.d.ts +1 -0
  183. package/cjs/extensions/forms/{Form/Tools → Tools}/index.js +7 -0
  184. package/cjs/extensions/forms/Tools/index.js.map +1 -0
  185. package/cjs/extensions/forms/Value/Boolean/Boolean.d.ts +5 -1
  186. package/cjs/extensions/forms/Value/Boolean/Boolean.js +5 -3
  187. package/cjs/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  188. package/cjs/extensions/forms/Value/Boolean/BooleanDocs.d.ts +2 -0
  189. package/cjs/extensions/forms/Value/Boolean/BooleanDocs.js +20 -0
  190. package/cjs/extensions/forms/Value/Boolean/BooleanDocs.js.map +1 -0
  191. package/cjs/extensions/forms/Value/Number/Number.d.ts +5 -1
  192. package/cjs/extensions/forms/Value/Number/Number.js +18 -5
  193. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  194. package/cjs/extensions/forms/Value/Number/NumberDocs.d.ts +2 -0
  195. package/cjs/extensions/forms/Value/Number/NumberDocs.js +20 -0
  196. package/cjs/extensions/forms/Value/Number/NumberDocs.js.map +1 -0
  197. package/cjs/extensions/forms/Value/ValueDocs.js +6 -1
  198. package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
  199. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +15 -1
  200. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  201. package/cjs/extensions/forms/Wizard/Buttons/Buttons.js +2 -1
  202. package/cjs/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  203. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +90 -42
  204. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  205. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  206. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  207. package/cjs/extensions/forms/Wizard/EditButton/EditButton.js +7 -2
  208. package/cjs/extensions/forms/Wizard/EditButton/EditButton.js.map +1 -1
  209. package/cjs/extensions/forms/Wizard/Step/Step.d.ts +4 -0
  210. package/cjs/extensions/forms/Wizard/Step/Step.js +7 -4
  211. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  212. package/cjs/extensions/forms/Wizard/Step/StepDocs.js +5 -0
  213. package/cjs/extensions/forms/Wizard/Step/StepDocs.js.map +1 -1
  214. package/cjs/extensions/forms/Wizard/hooks/useStep.js +17 -1
  215. package/cjs/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  216. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.css +1 -1
  217. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  218. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
  219. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +13 -0
  220. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +164 -0
  221. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -0
  222. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.d.ts +2 -0
  223. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +25 -0
  224. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -0
  225. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +77 -0
  226. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +84 -0
  227. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -0
  228. package/cjs/extensions/forms/blocks/ChildrenWithAge/index.d.ts +2 -0
  229. package/cjs/extensions/forms/blocks/ChildrenWithAge/index.js +27 -0
  230. package/cjs/extensions/forms/blocks/ChildrenWithAge/index.js.map +1 -0
  231. package/cjs/extensions/forms/blocks/index.d.ts +1 -0
  232. package/cjs/extensions/forms/blocks/index.js +14 -0
  233. package/cjs/extensions/forms/blocks/index.js.map +1 -0
  234. package/cjs/extensions/forms/constants/locales/en-GB.js +2 -2
  235. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  236. package/cjs/extensions/forms/hooks/DataValueDocs.js +10 -10
  237. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  238. package/cjs/extensions/forms/hooks/index.d.ts +2 -5
  239. package/cjs/extensions/forms/hooks/index.js +12 -4
  240. package/cjs/extensions/forms/hooks/index.js.map +1 -1
  241. package/cjs/extensions/forms/hooks/useDataValue.d.ts +9 -0
  242. package/cjs/extensions/forms/hooks/useDataValue.js +39 -0
  243. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -0
  244. package/cjs/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  245. package/cjs/extensions/forms/hooks/useExternalValue.js +47 -0
  246. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -0
  247. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  248. package/cjs/extensions/forms/hooks/useFieldProps.js +67 -83
  249. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  250. package/cjs/extensions/forms/hooks/usePath.d.ts +14 -0
  251. package/cjs/extensions/forms/hooks/usePath.js +72 -0
  252. package/cjs/extensions/forms/hooks/usePath.js.map +1 -0
  253. package/cjs/extensions/forms/hooks/useValueProps.js +19 -5
  254. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  255. package/cjs/extensions/forms/index.d.ts +2 -0
  256. package/cjs/extensions/forms/index.js +4 -1
  257. package/cjs/extensions/forms/index.js.map +1 -1
  258. package/cjs/extensions/forms/style/dnb-forms.css +5 -3
  259. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  260. package/cjs/extensions/forms/types.d.ts +16 -7
  261. package/cjs/extensions/forms/types.js.map +1 -1
  262. package/cjs/fragments/drawer-list/DrawerListHelpers.js +3 -2
  263. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  264. package/cjs/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +12 -1
  265. package/cjs/shared/Context.d.ts +4 -4
  266. package/cjs/shared/Context.js +8 -8
  267. package/cjs/shared/Context.js.map +1 -1
  268. package/cjs/shared/Eufemia.d.ts +1 -1
  269. package/cjs/shared/Eufemia.js +2 -2
  270. package/cjs/shared/Eufemia.js.map +1 -1
  271. package/cjs/shared/component-helper.d.ts +3 -1
  272. package/cjs/shared/component-helper.js +39 -10
  273. package/cjs/shared/component-helper.js.map +1 -1
  274. package/cjs/style/core/scopes.scss +1 -1
  275. package/cjs/style/dnb-ui-basis.css +1 -1
  276. package/cjs/style/dnb-ui-basis.min.css +1 -1
  277. package/cjs/style/dnb-ui-body.css +1 -1
  278. package/cjs/style/dnb-ui-body.min.css +1 -1
  279. package/cjs/style/dnb-ui-components.css +45 -14
  280. package/cjs/style/dnb-ui-components.min.css +3 -3
  281. package/cjs/style/dnb-ui-core.css +1 -1
  282. package/cjs/style/dnb-ui-core.min.css +1 -1
  283. package/cjs/style/dnb-ui-extensions.css +5 -3
  284. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  285. package/cjs/style/dnb-ui-forms.css +5 -3
  286. package/cjs/style/dnb-ui-forms.min.css +1 -1
  287. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +53 -17
  288. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  289. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +5 -3
  290. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  291. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +5 -3
  292. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  293. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +118 -76
  294. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -8
  295. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  296. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +5 -3
  297. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  298. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +5 -3
  299. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  300. package/cjs/style/themes/theme-ui/ui-theme-components.css +53 -17
  301. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  302. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +5 -3
  303. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  304. package/cjs/style/themes/theme-ui/ui-theme-forms.css +5 -3
  305. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  306. package/components/autocomplete/style/dnb-autocomplete.css +0 -1
  307. package/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  308. package/components/autocomplete/style/dnb-autocomplete.scss +0 -2
  309. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +41 -0
  310. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.min.css +1 -0
  311. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +65 -0
  312. package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +3 -0
  313. package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
  314. package/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +6 -0
  315. package/components/breadcrumb/Breadcrumb.d.ts +4 -4
  316. package/components/breadcrumb/Breadcrumb.js +6 -4
  317. package/components/breadcrumb/Breadcrumb.js.map +1 -1
  318. package/components/card/Card.js +1 -0
  319. package/components/card/Card.js.map +1 -1
  320. package/components/card/style/dnb-card.css +3 -0
  321. package/components/card/style/dnb-card.min.css +1 -1
  322. package/components/card/style/dnb-card.scss +4 -0
  323. package/components/checkbox/Checkbox.js +1 -1
  324. package/components/checkbox/Checkbox.js.map +1 -1
  325. package/components/checkbox/style/dnb-checkbox.css +9 -3
  326. package/components/checkbox/style/dnb-checkbox.min.css +1 -1
  327. package/components/checkbox/style/dnb-checkbox.scss +11 -3
  328. package/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.css +5 -3
  329. package/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.min.css +2 -2
  330. package/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.scss +5 -3
  331. package/components/flex/Container.js +4 -4
  332. package/components/flex/Container.js.map +1 -1
  333. package/components/form-row/FormRow.js +2 -2
  334. package/components/form-row/FormRow.js.map +1 -1
  335. package/components/form-set/FormSet.js +2 -2
  336. package/components/form-set/FormSet.js.map +1 -1
  337. package/components/form-status/FormStatus.d.ts +0 -1
  338. package/components/form-status/FormStatus.js +84 -66
  339. package/components/form-status/FormStatus.js.map +1 -1
  340. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +2 -2
  341. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -1
  342. package/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +2 -2
  343. package/components/global-status/GlobalStatus.js +2 -4
  344. package/components/global-status/GlobalStatus.js.map +1 -1
  345. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +1 -1
  346. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -1
  347. package/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +1 -1
  348. package/components/grid/Container.d.ts +2 -2
  349. package/components/grid/Container.js.map +1 -1
  350. package/components/grid/ContainerDocs.d.ts +2 -0
  351. package/components/grid/ContainerDocs.js +23 -0
  352. package/components/grid/ContainerDocs.js.map +1 -0
  353. package/components/grid/style/dnb-grid.css +6 -0
  354. package/components/grid/style/dnb-grid.min.css +1 -1
  355. package/components/grid/style/grid-container.scss +6 -0
  356. package/components/number-format/NumberFormat.js +2 -2
  357. package/components/number-format/NumberFormat.js.map +1 -1
  358. package/components/radio/style/dnb-radio.css +19 -7
  359. package/components/radio/style/dnb-radio.min.css +1 -1
  360. package/components/radio/style/dnb-radio.scss +21 -7
  361. package/components/radio/style/themes/dnb-radio-theme-sbanken.css +6 -0
  362. package/components/radio/style/themes/dnb-radio-theme-sbanken.min.css +1 -1
  363. package/components/radio/style/themes/dnb-radio-theme-sbanken.scss +6 -0
  364. package/components/section/style/themes/dnb-section-theme-sbanken.css +1 -1
  365. package/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -1
  366. package/components/section/style/themes/dnb-section-theme-sbanken.scss +1 -1
  367. package/components/slider/SliderDocs.d.ts +3 -0
  368. package/components/slider/SliderDocs.js +150 -0
  369. package/components/slider/SliderDocs.js.map +1 -0
  370. package/components/step-indicator/StepIndicator.js +1 -9
  371. package/components/step-indicator/StepIndicator.js.map +1 -1
  372. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +1 -1
  373. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -1
  374. package/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +1 -1
  375. package/components/table/TableContainer.d.ts +1 -0
  376. package/components/table/TableContainer.js +1 -0
  377. package/components/table/TableContainer.js.map +1 -1
  378. package/components/table/style/dnb-table.css +3 -0
  379. package/components/table/style/dnb-table.min.css +1 -1
  380. package/components/table/style/table-container.scss +5 -0
  381. package/es/components/autocomplete/style/dnb-autocomplete.css +0 -1
  382. package/es/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  383. package/es/components/autocomplete/style/dnb-autocomplete.scss +0 -2
  384. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +41 -0
  385. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.min.css +1 -0
  386. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +65 -0
  387. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.css +3 -0
  388. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.min.css +1 -1
  389. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-ui.scss +6 -0
  390. package/es/components/breadcrumb/Breadcrumb.d.ts +4 -4
  391. package/es/components/breadcrumb/Breadcrumb.js +6 -4
  392. package/es/components/breadcrumb/Breadcrumb.js.map +1 -1
  393. package/es/components/card/Card.js +1 -0
  394. package/es/components/card/Card.js.map +1 -1
  395. package/es/components/card/style/dnb-card.css +3 -0
  396. package/es/components/card/style/dnb-card.min.css +1 -1
  397. package/es/components/card/style/dnb-card.scss +4 -0
  398. package/es/components/checkbox/Checkbox.js +1 -1
  399. package/es/components/checkbox/Checkbox.js.map +1 -1
  400. package/es/components/checkbox/style/dnb-checkbox.css +9 -3
  401. package/es/components/checkbox/style/dnb-checkbox.min.css +1 -1
  402. package/es/components/checkbox/style/dnb-checkbox.scss +11 -3
  403. package/es/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.css +5 -3
  404. package/es/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.min.css +2 -2
  405. package/es/components/checkbox/style/themes/dnb-checkbox-theme-sbanken.scss +5 -3
  406. package/es/components/flex/Container.js +4 -4
  407. package/es/components/flex/Container.js.map +1 -1
  408. package/es/components/form-row/FormRow.js +2 -2
  409. package/es/components/form-row/FormRow.js.map +1 -1
  410. package/es/components/form-set/FormSet.js +2 -2
  411. package/es/components/form-set/FormSet.js.map +1 -1
  412. package/es/components/form-status/FormStatus.d.ts +0 -1
  413. package/es/components/form-status/FormStatus.js +84 -66
  414. package/es/components/form-status/FormStatus.js.map +1 -1
  415. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.css +2 -2
  416. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.min.css +1 -1
  417. package/es/components/form-status/style/themes/dnb-form-status-theme-sbanken.scss +2 -2
  418. package/es/components/global-status/GlobalStatus.js +2 -4
  419. package/es/components/global-status/GlobalStatus.js.map +1 -1
  420. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.css +1 -1
  421. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.min.css +1 -1
  422. package/es/components/global-status/style/themes/dnb-global-status-theme-sbanken.scss +1 -1
  423. package/es/components/grid/Container.d.ts +2 -2
  424. package/es/components/grid/Container.js.map +1 -1
  425. package/es/components/grid/ContainerDocs.d.ts +2 -0
  426. package/es/components/grid/ContainerDocs.js +23 -0
  427. package/es/components/grid/ContainerDocs.js.map +1 -0
  428. package/es/components/grid/style/dnb-grid.css +6 -0
  429. package/es/components/grid/style/dnb-grid.min.css +1 -1
  430. package/es/components/grid/style/grid-container.scss +6 -0
  431. package/es/components/number-format/NumberFormat.js +2 -2
  432. package/es/components/number-format/NumberFormat.js.map +1 -1
  433. package/es/components/radio/style/dnb-radio.css +19 -7
  434. package/es/components/radio/style/dnb-radio.min.css +1 -1
  435. package/es/components/radio/style/dnb-radio.scss +21 -7
  436. package/es/components/radio/style/themes/dnb-radio-theme-sbanken.css +6 -0
  437. package/es/components/radio/style/themes/dnb-radio-theme-sbanken.min.css +1 -1
  438. package/es/components/radio/style/themes/dnb-radio-theme-sbanken.scss +6 -0
  439. package/es/components/section/style/themes/dnb-section-theme-sbanken.css +1 -1
  440. package/es/components/section/style/themes/dnb-section-theme-sbanken.min.css +1 -1
  441. package/es/components/section/style/themes/dnb-section-theme-sbanken.scss +1 -1
  442. package/es/components/slider/SliderDocs.d.ts +3 -0
  443. package/es/components/slider/SliderDocs.js +150 -0
  444. package/es/components/slider/SliderDocs.js.map +1 -0
  445. package/es/components/step-indicator/StepIndicator.js +1 -9
  446. package/es/components/step-indicator/StepIndicator.js.map +1 -1
  447. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.css +1 -1
  448. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.min.css +1 -1
  449. package/es/components/step-indicator/style/themes/dnb-step-indicator-theme-sbanken.scss +1 -1
  450. package/es/components/table/TableContainer.d.ts +1 -0
  451. package/es/components/table/TableContainer.js +1 -0
  452. package/es/components/table/TableContainer.js.map +1 -1
  453. package/es/components/table/style/dnb-table.css +3 -0
  454. package/es/components/table/style/dnb-table.min.css +1 -1
  455. package/es/components/table/style/table-container.scss +5 -0
  456. package/es/extensions/forms/DataContext/Context.d.ts +8 -5
  457. package/es/extensions/forms/DataContext/Context.js +0 -1
  458. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  459. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  460. package/es/extensions/forms/DataContext/Provider/Provider.js +33 -6
  461. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  462. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +7 -2
  463. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  464. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  465. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  466. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  467. package/es/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  468. package/es/extensions/forms/Field/Composition/Composition.js.map +1 -1
  469. package/es/extensions/forms/Field/Composition/CompositionDocs.d.ts +2 -0
  470. package/es/extensions/forms/Field/Composition/CompositionDocs.js +14 -0
  471. package/es/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -0
  472. package/es/extensions/forms/Field/Number/Number.d.ts +1 -0
  473. package/es/extensions/forms/Field/Number/Number.js +18 -15
  474. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  475. package/es/extensions/forms/Field/Number/NumberDocs.js +6 -1
  476. package/es/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  477. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  478. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  479. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  480. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  481. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  482. package/es/extensions/forms/Field/Selection/Selection.js +5 -6
  483. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  484. package/es/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  485. package/es/extensions/forms/Field/Slider/Slider.js +103 -0
  486. package/es/extensions/forms/Field/Slider/Slider.js.map +1 -0
  487. package/es/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  488. package/es/extensions/forms/Field/Slider/SliderDocs.js +26 -0
  489. package/es/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  490. package/es/extensions/forms/Field/Slider/index.d.ts +2 -0
  491. package/es/extensions/forms/Field/Slider/index.js +3 -0
  492. package/es/extensions/forms/Field/Slider/index.js.map +1 -0
  493. package/es/extensions/forms/Field/String/String.js +2 -2
  494. package/es/extensions/forms/Field/String/String.js.map +1 -1
  495. package/es/extensions/forms/Field/Toggle/Toggle.js +7 -7
  496. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  497. package/es/extensions/forms/Field/index.d.ts +1 -0
  498. package/es/extensions/forms/Field/index.js +1 -0
  499. package/es/extensions/forms/Field/index.js.map +1 -1
  500. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +4 -1
  501. package/es/extensions/forms/FieldBlock/FieldBlock.js +15 -3
  502. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  503. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  504. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  505. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -1
  506. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  507. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -2
  508. package/es/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  509. package/es/extensions/forms/Form/FieldProps/FieldProps.js +46 -25
  510. package/es/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  511. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  512. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  513. package/es/extensions/forms/Form/MainHeading/MainHeading.js +1 -0
  514. package/es/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  515. package/es/extensions/forms/Form/Section/Section.d.ts +36 -0
  516. package/es/extensions/forms/Form/Section/Section.js +63 -0
  517. package/es/extensions/forms/Form/Section/Section.js.map +1 -0
  518. package/es/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  519. package/es/extensions/forms/Form/Section/SectionContext.js +4 -0
  520. package/es/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  521. package/es/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  522. package/es/extensions/forms/Form/Section/SectionDocs.js +45 -0
  523. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  524. package/es/extensions/forms/Form/Section/index.d.ts +2 -0
  525. package/es/extensions/forms/Form/Section/index.js +3 -0
  526. package/es/extensions/forms/Form/Section/index.js.map +1 -0
  527. package/es/extensions/forms/Form/SubHeading/SubHeading.js +1 -0
  528. package/es/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  529. package/es/extensions/forms/Form/Visibility/Visibility.js +16 -10
  530. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  531. package/es/extensions/forms/Form/data-context/useData.js +6 -2
  532. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  533. package/es/extensions/forms/Form/index.d.ts +1 -1
  534. package/es/extensions/forms/Form/index.js +1 -1
  535. package/es/extensions/forms/Form/index.js.map +1 -1
  536. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +2 -2
  537. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  538. package/es/extensions/forms/Iterate/Array/Array.js +37 -1
  539. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  540. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +15 -0
  541. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  542. package/es/extensions/forms/Iterate/Array/types.d.ts +9 -3
  543. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  544. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -2
  545. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  546. package/es/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  547. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  548. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  549. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  550. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -2
  551. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  552. package/es/extensions/forms/Iterate/style/dnb-form-iterate.css +1 -1
  553. package/es/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  554. package/es/extensions/forms/Iterate/style/dnb-form-iterate.scss +1 -0
  555. package/es/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  556. package/es/extensions/forms/Tools/GenerateSchema.js +130 -0
  557. package/es/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  558. package/es/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  559. package/es/extensions/forms/Tools/ListAllProps.js +65 -0
  560. package/es/extensions/forms/Tools/ListAllProps.js.map +1 -0
  561. package/{extensions/forms/Form → es/extensions/forms}/Tools/index.d.ts +1 -0
  562. package/es/extensions/forms/Tools/index.js +3 -0
  563. package/es/extensions/forms/Tools/index.js.map +1 -0
  564. package/es/extensions/forms/Value/Boolean/Boolean.d.ts +5 -1
  565. package/es/extensions/forms/Value/Boolean/Boolean.js +5 -3
  566. package/es/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  567. package/es/extensions/forms/Value/Boolean/BooleanDocs.d.ts +2 -0
  568. package/es/extensions/forms/Value/Boolean/BooleanDocs.js +13 -0
  569. package/es/extensions/forms/Value/Boolean/BooleanDocs.js.map +1 -0
  570. package/es/extensions/forms/Value/Number/Number.d.ts +5 -1
  571. package/es/extensions/forms/Value/Number/Number.js +18 -5
  572. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  573. package/es/extensions/forms/Value/Number/NumberDocs.d.ts +2 -0
  574. package/es/extensions/forms/Value/Number/NumberDocs.js +13 -0
  575. package/es/extensions/forms/Value/Number/NumberDocs.js.map +1 -0
  576. package/es/extensions/forms/Value/ValueDocs.js +6 -1
  577. package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
  578. package/es/extensions/forms/ValueBlock/ValueBlock.js +16 -2
  579. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  580. package/es/extensions/forms/Wizard/Buttons/Buttons.js +2 -1
  581. package/es/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  582. package/es/extensions/forms/Wizard/Container/WizardContainer.js +83 -36
  583. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  584. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  585. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  586. package/es/extensions/forms/Wizard/EditButton/EditButton.js +7 -2
  587. package/es/extensions/forms/Wizard/EditButton/EditButton.js.map +1 -1
  588. package/es/extensions/forms/Wizard/Step/Step.d.ts +4 -0
  589. package/es/extensions/forms/Wizard/Step/Step.js +7 -4
  590. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  591. package/es/extensions/forms/Wizard/Step/StepDocs.js +5 -0
  592. package/es/extensions/forms/Wizard/Step/StepDocs.js.map +1 -1
  593. package/es/extensions/forms/Wizard/hooks/useStep.js +17 -1
  594. package/es/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  595. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.css +1 -1
  596. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  597. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
  598. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +13 -0
  599. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +151 -0
  600. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -0
  601. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.d.ts +2 -0
  602. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +18 -0
  603. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -0
  604. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +77 -0
  605. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +77 -0
  606. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -0
  607. package/es/extensions/forms/blocks/ChildrenWithAge/index.d.ts +2 -0
  608. package/es/extensions/forms/blocks/ChildrenWithAge/index.js +3 -0
  609. package/es/extensions/forms/blocks/ChildrenWithAge/index.js.map +1 -0
  610. package/es/extensions/forms/blocks/index.d.ts +1 -0
  611. package/es/extensions/forms/blocks/index.js +1 -0
  612. package/es/extensions/forms/blocks/index.js.map +1 -0
  613. package/es/extensions/forms/constants/locales/en-GB.js +2 -2
  614. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  615. package/es/extensions/forms/hooks/DataValueDocs.js +10 -10
  616. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  617. package/es/extensions/forms/hooks/index.d.ts +2 -5
  618. package/es/extensions/forms/hooks/index.js +2 -1
  619. package/es/extensions/forms/hooks/index.js.map +1 -1
  620. package/es/extensions/forms/hooks/useDataValue.d.ts +9 -0
  621. package/es/extensions/forms/hooks/useDataValue.js +32 -0
  622. package/es/extensions/forms/hooks/useDataValue.js.map +1 -0
  623. package/es/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  624. package/es/extensions/forms/hooks/useExternalValue.js +41 -0
  625. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -0
  626. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  627. package/es/extensions/forms/hooks/useFieldProps.js +67 -82
  628. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  629. package/es/extensions/forms/hooks/usePath.d.ts +14 -0
  630. package/es/extensions/forms/hooks/usePath.js +64 -0
  631. package/es/extensions/forms/hooks/usePath.js.map +1 -0
  632. package/es/extensions/forms/hooks/useValueProps.js +19 -6
  633. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  634. package/es/extensions/forms/index.d.ts +2 -0
  635. package/es/extensions/forms/index.js +1 -0
  636. package/es/extensions/forms/index.js.map +1 -1
  637. package/es/extensions/forms/style/dnb-forms.css +5 -3
  638. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  639. package/es/extensions/forms/types.d.ts +16 -7
  640. package/es/extensions/forms/types.js.map +1 -1
  641. package/es/fragments/drawer-list/DrawerListHelpers.js +3 -2
  642. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  643. package/es/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +12 -1
  644. package/es/shared/Context.d.ts +4 -4
  645. package/es/shared/Context.js +9 -9
  646. package/es/shared/Context.js.map +1 -1
  647. package/es/shared/Eufemia.d.ts +1 -1
  648. package/es/shared/Eufemia.js +2 -2
  649. package/es/shared/Eufemia.js.map +1 -1
  650. package/es/shared/component-helper.d.ts +3 -1
  651. package/es/shared/component-helper.js +25 -2
  652. package/es/shared/component-helper.js.map +1 -1
  653. package/es/style/core/scopes.scss +1 -1
  654. package/es/style/dnb-ui-basis.css +1 -1
  655. package/es/style/dnb-ui-basis.min.css +1 -1
  656. package/es/style/dnb-ui-body.css +1 -1
  657. package/es/style/dnb-ui-body.min.css +1 -1
  658. package/es/style/dnb-ui-components.css +45 -14
  659. package/es/style/dnb-ui-components.min.css +3 -3
  660. package/es/style/dnb-ui-core.css +1 -1
  661. package/es/style/dnb-ui-core.min.css +1 -1
  662. package/es/style/dnb-ui-extensions.css +5 -3
  663. package/es/style/dnb-ui-extensions.min.css +1 -1
  664. package/es/style/dnb-ui-forms.css +5 -3
  665. package/es/style/dnb-ui-forms.min.css +1 -1
  666. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +53 -17
  667. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  668. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +5 -3
  669. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  670. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +5 -3
  671. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  672. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +118 -76
  673. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -8
  674. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  675. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +5 -3
  676. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  677. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +5 -3
  678. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  679. package/es/style/themes/theme-ui/ui-theme-components.css +53 -17
  680. package/es/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  681. package/es/style/themes/theme-ui/ui-theme-extensions.css +5 -3
  682. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  683. package/es/style/themes/theme-ui/ui-theme-forms.css +5 -3
  684. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  685. package/esm/dnb-ui-basis.min.mjs +1 -1
  686. package/esm/dnb-ui-components.min.mjs +1 -1
  687. package/esm/dnb-ui-elements.min.mjs +1 -1
  688. package/esm/dnb-ui-extensions.min.mjs +5 -5
  689. package/esm/dnb-ui-lib.min.mjs +1 -1
  690. package/extensions/forms/DataContext/Context.d.ts +8 -5
  691. package/extensions/forms/DataContext/Context.js +0 -1
  692. package/extensions/forms/DataContext/Context.js.map +1 -1
  693. package/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  694. package/extensions/forms/DataContext/Provider/Provider.js +33 -6
  695. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  696. package/extensions/forms/DataContext/Provider/ProviderDocs.js +7 -2
  697. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  698. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +1 -1
  699. package/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -3
  700. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  701. package/extensions/forms/Field/Composition/Composition.d.ts +2 -2
  702. package/extensions/forms/Field/Composition/Composition.js.map +1 -1
  703. package/extensions/forms/Field/Composition/CompositionDocs.d.ts +2 -0
  704. package/extensions/forms/Field/Composition/CompositionDocs.js +14 -0
  705. package/extensions/forms/Field/Composition/CompositionDocs.js.map +1 -0
  706. package/extensions/forms/Field/Number/Number.d.ts +1 -0
  707. package/extensions/forms/Field/Number/Number.js +18 -15
  708. package/extensions/forms/Field/Number/Number.js.map +1 -1
  709. package/extensions/forms/Field/Number/NumberDocs.js +6 -1
  710. package/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  711. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  712. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +2 -2
  713. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  714. package/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -4
  715. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  716. package/extensions/forms/Field/Selection/Selection.js +5 -6
  717. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  718. package/extensions/forms/Field/Slider/Slider.d.ts +34 -0
  719. package/extensions/forms/Field/Slider/Slider.js +104 -0
  720. package/extensions/forms/Field/Slider/Slider.js.map +1 -0
  721. package/extensions/forms/Field/Slider/SliderDocs.d.ts +3 -0
  722. package/extensions/forms/Field/Slider/SliderDocs.js +26 -0
  723. package/extensions/forms/Field/Slider/SliderDocs.js.map +1 -0
  724. package/extensions/forms/Field/Slider/index.d.ts +2 -0
  725. package/extensions/forms/Field/Slider/index.js +3 -0
  726. package/extensions/forms/Field/Slider/index.js.map +1 -0
  727. package/extensions/forms/Field/String/String.js +2 -2
  728. package/extensions/forms/Field/String/String.js.map +1 -1
  729. package/extensions/forms/Field/Toggle/Toggle.js +7 -7
  730. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  731. package/extensions/forms/Field/index.d.ts +1 -0
  732. package/extensions/forms/Field/index.js +1 -0
  733. package/extensions/forms/Field/index.js.map +1 -1
  734. package/extensions/forms/FieldBlock/FieldBlock.d.ts +4 -1
  735. package/extensions/forms/FieldBlock/FieldBlock.js +15 -3
  736. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  737. package/extensions/forms/FieldBlock/FieldBlockDocs.js +5 -0
  738. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  739. package/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -1
  740. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  741. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +5 -2
  742. package/extensions/forms/Form/FieldProps/FieldProps.d.ts +19 -5
  743. package/extensions/forms/Form/FieldProps/FieldProps.js +46 -25
  744. package/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  745. package/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts +1 -0
  746. package/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +1 -1
  747. package/extensions/forms/Form/MainHeading/MainHeading.js +1 -0
  748. package/extensions/forms/Form/MainHeading/MainHeading.js.map +1 -1
  749. package/extensions/forms/Form/Section/Section.d.ts +36 -0
  750. package/extensions/forms/Form/Section/Section.js +68 -0
  751. package/extensions/forms/Form/Section/Section.js.map +1 -0
  752. package/extensions/forms/Form/Section/SectionContext.d.ts +11 -0
  753. package/extensions/forms/Form/Section/SectionContext.js +4 -0
  754. package/extensions/forms/Form/Section/SectionContext.js.map +1 -0
  755. package/extensions/forms/Form/Section/SectionDocs.d.ts +3 -0
  756. package/extensions/forms/Form/Section/SectionDocs.js +45 -0
  757. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -0
  758. package/extensions/forms/Form/Section/index.d.ts +2 -0
  759. package/extensions/forms/Form/Section/index.js +3 -0
  760. package/extensions/forms/Form/Section/index.js.map +1 -0
  761. package/extensions/forms/Form/SubHeading/SubHeading.js +1 -0
  762. package/extensions/forms/Form/SubHeading/SubHeading.js.map +1 -1
  763. package/extensions/forms/Form/Visibility/Visibility.js +16 -10
  764. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  765. package/extensions/forms/Form/data-context/useData.js +6 -2
  766. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  767. package/extensions/forms/Form/index.d.ts +1 -1
  768. package/extensions/forms/Form/index.js +1 -2
  769. package/extensions/forms/Form/index.js.map +1 -1
  770. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +2 -2
  771. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  772. package/extensions/forms/Iterate/Array/Array.js +37 -1
  773. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  774. package/extensions/forms/Iterate/Array/ArrayDocs.js +15 -0
  775. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  776. package/extensions/forms/Iterate/Array/types.d.ts +9 -3
  777. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  778. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +2 -2
  779. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  780. package/extensions/forms/Iterate/PushButton/PushButton.js +1 -1
  781. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  782. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  783. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  784. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +2 -2
  785. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  786. package/extensions/forms/Iterate/style/dnb-form-iterate.css +1 -1
  787. package/extensions/forms/Iterate/style/dnb-form-iterate.min.css +1 -1
  788. package/extensions/forms/Iterate/style/dnb-form-iterate.scss +1 -0
  789. package/extensions/forms/Tools/GenerateSchema.d.ts +19 -0
  790. package/extensions/forms/Tools/GenerateSchema.js +133 -0
  791. package/extensions/forms/Tools/GenerateSchema.js.map +1 -0
  792. package/extensions/forms/Tools/ListAllProps.d.ts +15 -0
  793. package/extensions/forms/Tools/ListAllProps.js +67 -0
  794. package/extensions/forms/Tools/ListAllProps.js.map +1 -0
  795. package/{cjs/extensions/forms/Form → extensions/forms}/Tools/index.d.ts +1 -0
  796. package/extensions/forms/Tools/index.js +3 -0
  797. package/extensions/forms/Tools/index.js.map +1 -0
  798. package/extensions/forms/Value/Boolean/Boolean.d.ts +5 -1
  799. package/extensions/forms/Value/Boolean/Boolean.js +5 -3
  800. package/extensions/forms/Value/Boolean/Boolean.js.map +1 -1
  801. package/extensions/forms/Value/Boolean/BooleanDocs.d.ts +2 -0
  802. package/extensions/forms/Value/Boolean/BooleanDocs.js +13 -0
  803. package/extensions/forms/Value/Boolean/BooleanDocs.js.map +1 -0
  804. package/extensions/forms/Value/Number/Number.d.ts +5 -1
  805. package/extensions/forms/Value/Number/Number.js +18 -5
  806. package/extensions/forms/Value/Number/Number.js.map +1 -1
  807. package/extensions/forms/Value/Number/NumberDocs.d.ts +2 -0
  808. package/extensions/forms/Value/Number/NumberDocs.js +13 -0
  809. package/extensions/forms/Value/Number/NumberDocs.js.map +1 -0
  810. package/extensions/forms/Value/ValueDocs.js +6 -1
  811. package/extensions/forms/Value/ValueDocs.js.map +1 -1
  812. package/extensions/forms/ValueBlock/ValueBlock.js +16 -2
  813. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  814. package/extensions/forms/Wizard/Buttons/Buttons.js +2 -1
  815. package/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  816. package/extensions/forms/Wizard/Container/WizardContainer.js +91 -43
  817. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  818. package/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  819. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  820. package/extensions/forms/Wizard/EditButton/EditButton.js +7 -2
  821. package/extensions/forms/Wizard/EditButton/EditButton.js.map +1 -1
  822. package/extensions/forms/Wizard/Step/Step.d.ts +4 -0
  823. package/extensions/forms/Wizard/Step/Step.js +7 -4
  824. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  825. package/extensions/forms/Wizard/Step/StepDocs.js +5 -0
  826. package/extensions/forms/Wizard/Step/StepDocs.js.map +1 -1
  827. package/extensions/forms/Wizard/hooks/useStep.js +17 -1
  828. package/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  829. package/extensions/forms/Wizard/style/dnb-wizard-layout.css +1 -1
  830. package/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  831. package/extensions/forms/Wizard/style/dnb-wizard-layout.scss +1 -1
  832. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +13 -0
  833. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +156 -0
  834. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -0
  835. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.d.ts +2 -0
  836. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +18 -0
  837. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -0
  838. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +77 -0
  839. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +77 -0
  840. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -0
  841. package/extensions/forms/blocks/ChildrenWithAge/index.d.ts +2 -0
  842. package/extensions/forms/blocks/ChildrenWithAge/index.js +3 -0
  843. package/extensions/forms/blocks/ChildrenWithAge/index.js.map +1 -0
  844. package/extensions/forms/blocks/index.d.ts +1 -0
  845. package/extensions/forms/blocks/index.js +1 -0
  846. package/extensions/forms/blocks/index.js.map +1 -0
  847. package/extensions/forms/constants/locales/en-GB.js +2 -2
  848. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  849. package/extensions/forms/hooks/DataValueDocs.js +10 -10
  850. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  851. package/extensions/forms/hooks/index.d.ts +2 -5
  852. package/extensions/forms/hooks/index.js +2 -1
  853. package/extensions/forms/hooks/index.js.map +1 -1
  854. package/extensions/forms/hooks/useDataValue.d.ts +9 -0
  855. package/extensions/forms/hooks/useDataValue.js +33 -0
  856. package/extensions/forms/hooks/useDataValue.js.map +1 -0
  857. package/extensions/forms/hooks/useExternalValue.d.ts +12 -0
  858. package/extensions/forms/hooks/useExternalValue.js +41 -0
  859. package/extensions/forms/hooks/useExternalValue.js.map +1 -0
  860. package/extensions/forms/hooks/useFieldProps.d.ts +1 -10
  861. package/extensions/forms/hooks/useFieldProps.js +67 -82
  862. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  863. package/extensions/forms/hooks/usePath.d.ts +14 -0
  864. package/extensions/forms/hooks/usePath.js +66 -0
  865. package/extensions/forms/hooks/usePath.js.map +1 -0
  866. package/extensions/forms/hooks/useValueProps.js +19 -6
  867. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  868. package/extensions/forms/index.d.ts +2 -0
  869. package/extensions/forms/index.js +2 -0
  870. package/extensions/forms/index.js.map +1 -1
  871. package/extensions/forms/style/dnb-forms.css +5 -3
  872. package/extensions/forms/style/dnb-forms.min.css +1 -1
  873. package/extensions/forms/types.d.ts +16 -7
  874. package/extensions/forms/types.js.map +1 -1
  875. package/fragments/drawer-list/DrawerListHelpers.js +3 -2
  876. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  877. package/fragments/drawer-list/style/themes/dnb-drawer-list-theme-sbanken.scss +12 -1
  878. package/package.json +2 -2
  879. package/shared/Context.d.ts +4 -4
  880. package/shared/Context.js +9 -9
  881. package/shared/Context.js.map +1 -1
  882. package/shared/Eufemia.d.ts +1 -1
  883. package/shared/Eufemia.js +2 -2
  884. package/shared/Eufemia.js.map +1 -1
  885. package/shared/component-helper.d.ts +3 -1
  886. package/shared/component-helper.js +35 -8
  887. package/shared/component-helper.js.map +1 -1
  888. package/style/core/scopes.scss +1 -1
  889. package/style/dnb-ui-basis.css +1 -1
  890. package/style/dnb-ui-basis.min.css +1 -1
  891. package/style/dnb-ui-body.css +1 -1
  892. package/style/dnb-ui-body.min.css +1 -1
  893. package/style/dnb-ui-components.css +45 -14
  894. package/style/dnb-ui-components.min.css +3 -3
  895. package/style/dnb-ui-core.css +1 -1
  896. package/style/dnb-ui-core.min.css +1 -1
  897. package/style/dnb-ui-extensions.css +5 -3
  898. package/style/dnb-ui-extensions.min.css +1 -1
  899. package/style/dnb-ui-forms.css +5 -3
  900. package/style/dnb-ui-forms.min.css +1 -1
  901. package/style/themes/theme-eiendom/eiendom-theme-components.css +53 -17
  902. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +4 -4
  903. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +5 -3
  904. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  905. package/style/themes/theme-eiendom/eiendom-theme-forms.css +5 -3
  906. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  907. package/style/themes/theme-sbanken/sbanken-theme-components.css +118 -76
  908. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -8
  909. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -1
  910. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +5 -3
  911. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  912. package/style/themes/theme-sbanken/sbanken-theme-forms.css +5 -3
  913. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  914. package/style/themes/theme-ui/ui-theme-components.css +53 -17
  915. package/style/themes/theme-ui/ui-theme-components.min.css +4 -4
  916. package/style/themes/theme-ui/ui-theme-extensions.css +5 -3
  917. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  918. package/style/themes/theme-ui/ui-theme-forms.css +5 -3
  919. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  920. package/umd/dnb-ui-basis.min.js +1 -1
  921. package/umd/dnb-ui-components.min.js +1 -1
  922. package/umd/dnb-ui-elements.min.js +1 -1
  923. package/umd/dnb-ui-extensions.min.js +5 -5
  924. package/umd/dnb-ui-lib.min.js +1 -1
  925. package/cjs/extensions/forms/Form/Tools/GenerateSchema.d.ts +0 -8
  926. package/cjs/extensions/forms/Form/Tools/GenerateSchema.js +0 -100
  927. package/cjs/extensions/forms/Form/Tools/GenerateSchema.js.map +0 -1
  928. package/cjs/extensions/forms/Form/Tools/index.js.map +0 -1
  929. package/es/extensions/forms/Form/Tools/GenerateSchema.d.ts +0 -8
  930. package/es/extensions/forms/Form/Tools/GenerateSchema.js +0 -89
  931. package/es/extensions/forms/Form/Tools/GenerateSchema.js.map +0 -1
  932. package/es/extensions/forms/Form/Tools/index.js +0 -1
  933. package/es/extensions/forms/Form/Tools/index.js.map +0 -1
  934. package/extensions/forms/Form/Tools/GenerateSchema.d.ts +0 -8
  935. package/extensions/forms/Form/Tools/GenerateSchema.js +0 -90
  936. package/extensions/forms/Form/Tools/GenerateSchema.js.map +0 -1
  937. package/extensions/forms/Form/Tools/index.js +0 -1
  938. package/extensions/forms/Form/Tools/index.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"Container.js","names":["React","useCallback","classnames","Space","Hr","useMedia","getSpaceValue","isHeadingElement","renderWithSpacing","propNames","pickFlexContainerProps","props","defaults","arguments","length","undefined","skip","_objectSpread","Object","fromEntries","entries","filter","_ref","key","includes","FlexContainer","_ref2","className","style","children","element","direction","wrap","sizeCount","rowGap","justify","align","alignSelf","divider","gap","spacing","spacingProp","breakpoints","queries","rest","_objectWithoutProperties","_excluded","childrenArray","wrapChildren","hasHeading","some","child","i","previousChild","hasSizeProp","_child$props","size","mediaKey","disabled","content","map","_previousChild$type","isFirst","isLast","isHeading","start","end","endSpacing","startSpacing","_getSpaceValue","_ref3","_getSpaceValue2","spaceAboveLine","createElement","Fragment","top","space","_ref4","_ref5","_getSpaceValue3","isValidElement","type","n","getRowGapClass","cn","_extends","Children","toArray","cloneElement","_supportsSpacingProps"],"sources":["../../../../src/components/flex/Container.tsx"],"sourcesContent":["import React, { useCallback } from 'react'\nimport classnames from 'classnames'\nimport Space, { SpaceProps } from '../space/Space'\nimport { Hr } from '../../elements'\nimport useMedia from '../../shared/useMedia'\nimport {\n getSpaceValue,\n isHeadingElement,\n renderWithSpacing,\n} from './utils'\n\nimport type { MediaQueryBreakpoints } from '../../shared/MediaQueryUtils'\nimport type { SpaceType } from '../space/types'\nimport type { UseMediaQueries } from '../../shared/useMedia'\nimport type { End, Start } from './types'\n\ntype Gap =\n | false\n | 'xx-small'\n | 'x-small'\n | 'small'\n | 'medium'\n | 'large'\n | 'x-large'\n | 'xx-large'\n\nexport type BasicProps = {\n direction?: 'horizontal' | 'vertical'\n wrap?: boolean\n rowGap?: 'small' | 'medium' | 'large' | boolean\n sizeCount?: number\n justify?:\n | 'flex-start'\n | 'flex-end'\n | 'center'\n | 'space-between'\n | 'space-around'\n | 'space-evenly'\n align?: 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'baseline'\n /** For when used as a flex item in an outer container in addition to being a container: */\n alignSelf?: 'flex-start' | 'flex-end' | 'center' | 'baseline' | 'stretch'\n /** When \"line-framed\" is used, a line will be shown between items and above the first and below the last item */\n divider?: 'space' | 'line' | 'line-framed'\n /** Spacing between items inside */\n gap?: Gap\n /** @deprecated Use `gap` instead */\n spacing?: Gap\n breakpoints?: MediaQueryBreakpoints\n queries?: UseMediaQueries\n}\n\nexport type Props = BasicProps &\n SpaceProps &\n Omit<\n React.HTMLAttributes<HTMLDivElement>,\n 'ref' | 'wrap' | 'value' | 'label' | 'title' | 'placeholder'\n >\n\nconst propNames: Array<keyof Props> = [\n 'direction',\n 'wrap',\n 'justify',\n 'align',\n 'divider',\n 'spacing',\n 'gap',\n]\n\nexport function pickFlexContainerProps<T extends Props>(\n props: T,\n defaults: Partial<Props> = {},\n skip: Array<keyof Props> = []\n): Omit<Props, 'children'> {\n return {\n ...defaults,\n ...Object.fromEntries(\n Object.entries(props ?? {}).filter(\n ([key]) =>\n propNames.includes(key as keyof Props) &&\n !skip.includes(key as keyof Props)\n )\n ),\n }\n}\n\nfunction FlexContainer(props: Props) {\n const {\n className,\n style,\n children,\n element = 'div',\n direction = 'horizontal',\n wrap = true,\n sizeCount = 12,\n rowGap,\n justify = 'flex-start',\n align = 'flex-start',\n alignSelf,\n divider = 'space',\n gap,\n spacing: spacingProp,\n breakpoints,\n queries,\n ...rest\n } = props\n\n const spacing = spacingProp ?? gap ?? 'small'\n\n const childrenArray = wrapChildren(props, children)\n const hasHeading = childrenArray.some((child, i) => {\n const previousChild = childrenArray?.[i - 1]\n return (\n isHeadingElement(child) || (i > 0 && isHeadingElement(previousChild))\n )\n })\n const hasSizeProp =\n !hasHeading &&\n direction === 'horizontal' &&\n childrenArray.some((child) => child['props']?.size)\n\n const { key: mediaKey } = useMedia({\n disabled: !hasSizeProp,\n breakpoints,\n queries,\n })\n\n const content = childrenArray.map((child, i) => {\n // Set spacing on child components by props (instead of CSS) to be able to dynamically override by props on each child. The default\n // is the spacing-props that controls space between children. Then override with props sent to the children, including both top\n // and bottom when th\n const isFirst = i === 0\n const isLast = i >= childrenArray.length - 1\n const previousChild = childrenArray?.[i - 1]\n const isHeading = hasHeading && isHeadingElement(previousChild)\n\n // Always set spacing between elements in the vertical layout on the top props, and 0 on bottom, to avoid\n // having to divide spacing between both with smaller values.\n const start: Start = direction === 'horizontal' ? 'left' : 'top'\n const end: End = direction === 'horizontal' ? 'right' : 'bottom'\n // const start: Start | End = direction === 'horizontal' ? 'right' : 'top'\n // const end: Start | End = direction === 'horizontal' ? 'left' : 'bottom'\n const endSpacing = 0\n let startSpacing = null\n\n if (\n // No line above heading\n !isHeading &&\n ((divider === 'line' && !isFirst) || divider === 'line-framed')\n ) {\n const spaceAboveLine = getSpaceValue(end, previousChild) ?? spacing\n startSpacing = (getSpaceValue(start, child) ??\n gap ??\n spacing) as SpaceType\n\n return (\n <React.Fragment key={`element-${i}`}>\n <Hr\n top={!isFirst ? spaceAboveLine : 0}\n space={0}\n className=\"dnb-flex-container__hr\"\n />\n\n {renderWithSpacing(child, {\n space: { [start]: startSpacing, [end]: endSpacing },\n })}\n\n {divider === 'line-framed' && isLast && (\n <Hr\n top={spaceAboveLine}\n space={0}\n className=\"dnb-flex-container__hr\"\n />\n )}\n </React.Fragment>\n )\n }\n\n // No space above first element.\n if (isFirst && direction !== 'horizontal') {\n startSpacing = 0\n } else {\n // Since top space of current and bottom space of previous component is the same\n startSpacing =\n getSpaceValue(start, child) ??\n getSpaceValue(end, previousChild) ??\n gap ??\n spacing\n }\n\n if (\n React.isValidElement(previousChild) &&\n previousChild?.type?.['_supportsSpacingProps'] === false\n ) {\n startSpacing = 0\n }\n\n const space =\n direction === 'horizontal'\n ? { [start]: endSpacing, [end]: startSpacing }\n : { [start]: startSpacing, [end]: endSpacing }\n\n return renderWithSpacing(child, {\n key: child?.['key'] || `element-${i}`,\n space,\n })\n })\n\n const n = 'dnb-flex-container'\n const getRowGapClass = useCallback(() => {\n if (rowGap === false) {\n return `${n}--row-gap-off`\n }\n\n if (\n rowGap === true ||\n (!rowGap && wrap && direction === 'horizontal')\n ) {\n return `${n}--row-gap-small`\n }\n\n if (hasSizeProp && spacing) {\n return `${n}--row-gap-${spacing}`\n }\n\n if (rowGap) {\n return `${n}--row-gap-${rowGap}`\n }\n }, [direction, hasSizeProp, rowGap, spacing, wrap])\n\n const cn = classnames(\n 'dnb-flex-container',\n direction && `${n}--direction-${direction}`,\n justify && `${n}--justify-${justify}`,\n align && `${n}--align-${align}`,\n alignSelf && `${n}--align-self-${alignSelf}`,\n spacing && `${n}--spacing-${spacing}`,\n wrap && `${n}--wrap`,\n getRowGapClass(),\n hasSizeProp && `${n}--has-size`,\n divider && `${n}--divider-${divider}`,\n className\n )\n\n return (\n <Space\n element={element}\n className={cn}\n data-media-key={mediaKey}\n style={\n hasSizeProp\n ? ({ '--sizeCount': sizeCount, ...style } as React.CSSProperties)\n : style\n }\n {...rest}\n >\n {content}\n </Space>\n )\n}\n\nfunction wrapChildren(props: Props, children: React.ReactNode) {\n return React.Children.toArray(children).map((child) => {\n if (\n React.isValidElement(child) &&\n child.type['_supportsSpacingProps'] === 'children'\n ) {\n return React.cloneElement(\n child,\n child.props,\n <FlexContainer {...props}>{child.props.children}</FlexContainer>\n )\n }\n\n return child\n })\n}\n\nFlexContainer._supportsSpacingProps = true\n\nexport default FlexContainer\n"],"mappings":"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"}
1
+ {"version":3,"file":"Container.js","names":["React","useCallback","classnames","Space","Hr","useMedia","getSpaceValue","isHeadingElement","renderWithSpacing","propNames","pickFlexContainerProps","props","defaults","arguments","length","undefined","skip","_objectSpread","Object","fromEntries","entries","filter","_ref","key","includes","FlexContainer","_ref2","className","style","children","element","direction","wrap","sizeCount","rowGap","justify","align","alignSelf","divider","gap","spacing","spacingProp","breakpoints","queries","rest","_objectWithoutProperties","_excluded","childrenArray","wrapChildren","hasHeading","some","child","i","previousChild","hasSizeProp","_child$props","size","mediaKey","disabled","content","map","_previousChild$type","isFirst","isLast","isHeading","start","end","endSpacing","startSpacing","_getSpaceValue","_getSpaceValue2","spaceAboveLine","createElement","Fragment","top","space","_ref3","_getSpaceValue3","isValidElement","type","n","getRowGapClass","cn","_extends","Children","toArray","cloneElement","_supportsSpacingProps"],"sources":["../../../../src/components/flex/Container.tsx"],"sourcesContent":["import React, { useCallback } from 'react'\nimport classnames from 'classnames'\nimport Space, { SpaceProps } from '../space/Space'\nimport { Hr } from '../../elements'\nimport useMedia from '../../shared/useMedia'\nimport {\n getSpaceValue,\n isHeadingElement,\n renderWithSpacing,\n} from './utils'\n\nimport type { MediaQueryBreakpoints } from '../../shared/MediaQueryUtils'\nimport type { SpaceType } from '../space/types'\nimport type { UseMediaQueries } from '../../shared/useMedia'\nimport type { End, Start } from './types'\n\ntype Gap =\n | false\n | 'xx-small'\n | 'x-small'\n | 'small'\n | 'medium'\n | 'large'\n | 'x-large'\n | 'xx-large'\n\nexport type BasicProps = {\n direction?: 'horizontal' | 'vertical'\n wrap?: boolean\n rowGap?: 'small' | 'medium' | 'large' | boolean\n sizeCount?: number\n justify?:\n | 'flex-start'\n | 'flex-end'\n | 'center'\n | 'space-between'\n | 'space-around'\n | 'space-evenly'\n align?: 'flex-start' | 'flex-end' | 'center' | 'stretch' | 'baseline'\n /** For when used as a flex item in an outer container in addition to being a container: */\n alignSelf?: 'flex-start' | 'flex-end' | 'center' | 'baseline' | 'stretch'\n /** When \"line-framed\" is used, a line will be shown between items and above the first and below the last item */\n divider?: 'space' | 'line' | 'line-framed'\n /** Spacing between items inside */\n gap?: Gap\n /** @deprecated Use `gap` instead */\n spacing?: Gap\n breakpoints?: MediaQueryBreakpoints\n queries?: UseMediaQueries\n}\n\nexport type Props = BasicProps &\n SpaceProps &\n Omit<\n React.HTMLAttributes<HTMLDivElement>,\n 'ref' | 'wrap' | 'value' | 'label' | 'title' | 'placeholder'\n >\n\nconst propNames: Array<keyof Props> = [\n 'direction',\n 'wrap',\n 'justify',\n 'align',\n 'divider',\n 'spacing',\n 'gap',\n]\n\nexport function pickFlexContainerProps<T extends Props>(\n props: T,\n defaults: Partial<Props> = {},\n skip: Array<keyof Props> = []\n): Omit<Props, 'children'> {\n return {\n ...defaults,\n ...Object.fromEntries(\n Object.entries(props ?? {}).filter(\n ([key]) =>\n propNames.includes(key as keyof Props) &&\n !skip.includes(key as keyof Props)\n )\n ),\n }\n}\n\nfunction FlexContainer(props: Props) {\n const {\n className,\n style,\n children,\n element = 'div',\n direction = 'horizontal',\n wrap = true,\n sizeCount = 12,\n rowGap,\n justify = 'flex-start',\n align = 'flex-start',\n alignSelf,\n divider = 'space',\n gap,\n spacing: spacingProp,\n breakpoints,\n queries,\n ...rest\n } = props\n\n const spacing = spacingProp ?? gap ?? 'small'\n\n const childrenArray = wrapChildren(props, children)\n const hasHeading = childrenArray.some((child, i) => {\n const previousChild = childrenArray?.[i - 1]\n return (\n isHeadingElement(child) || (i > 0 && isHeadingElement(previousChild))\n )\n })\n const hasSizeProp =\n !hasHeading &&\n direction === 'horizontal' &&\n childrenArray.some((child) => child['props']?.size)\n\n const { key: mediaKey } = useMedia({\n disabled: !hasSizeProp,\n breakpoints,\n queries,\n })\n\n const content = childrenArray.map((child, i) => {\n // Set spacing on child components by props (instead of CSS) to be able to dynamically override by props on each child. The default\n // is the spacing-props that controls space between children. Then override with props sent to the children, including both top\n // and bottom when th\n const isFirst = i === 0\n const isLast = i >= childrenArray.length - 1\n const previousChild = childrenArray?.[i - 1]\n const isHeading = hasHeading && isHeadingElement(previousChild)\n\n // Always set spacing between elements in the vertical layout on the top props, and 0 on bottom, to avoid\n // having to divide spacing between both with smaller values.\n const start: Start = direction === 'horizontal' ? 'left' : 'top'\n const end: End = direction === 'horizontal' ? 'right' : 'bottom'\n // const start: Start | End = direction === 'horizontal' ? 'right' : 'top'\n // const end: Start | End = direction === 'horizontal' ? 'left' : 'bottom'\n const endSpacing = 0\n let startSpacing = null\n\n if (\n // No line above heading\n !isHeading &&\n ((divider === 'line' && !isFirst) || divider === 'line-framed')\n ) {\n const spaceAboveLine = getSpaceValue(end, previousChild) ?? spacing\n startSpacing = (getSpaceValue(start, child) ?? spacing) as SpaceType\n\n return (\n <React.Fragment key={`element-${i}`}>\n <Hr\n top={!isFirst ? spaceAboveLine : 0}\n space={0}\n className=\"dnb-flex-container__hr\"\n />\n\n {renderWithSpacing(child, {\n space: { [start]: startSpacing, [end]: endSpacing },\n })}\n\n {divider === 'line-framed' && isLast && (\n <Hr\n top={spaceAboveLine}\n space={0}\n className=\"dnb-flex-container__hr\"\n />\n )}\n </React.Fragment>\n )\n }\n\n // No space above first element.\n if (isFirst && direction !== 'horizontal') {\n startSpacing = 0\n } else {\n // Since top space of current and bottom space of previous component is the same\n startSpacing =\n getSpaceValue(start, child) ??\n getSpaceValue(end, previousChild) ??\n spacing\n }\n\n if (\n React.isValidElement(previousChild) &&\n previousChild?.type?.['_supportsSpacingProps'] === false\n ) {\n startSpacing = 0\n }\n\n const space =\n direction === 'horizontal'\n ? { [start]: endSpacing, [end]: startSpacing }\n : { [start]: startSpacing, [end]: endSpacing }\n\n return renderWithSpacing(child, {\n key: child?.['key'] || `element-${i}`,\n space,\n })\n })\n\n const n = 'dnb-flex-container'\n const getRowGapClass = useCallback(() => {\n if (rowGap === false) {\n return `${n}--row-gap-off`\n }\n\n if (\n rowGap === true ||\n (!rowGap && wrap && direction === 'horizontal')\n ) {\n return `${n}--row-gap-small`\n }\n\n if (hasSizeProp && spacing) {\n return `${n}--row-gap-${spacing}`\n }\n\n if (rowGap) {\n return `${n}--row-gap-${rowGap}`\n }\n }, [direction, hasSizeProp, rowGap, spacing, wrap])\n\n const cn = classnames(\n 'dnb-flex-container',\n direction && `${n}--direction-${direction}`,\n justify && `${n}--justify-${justify}`,\n align && `${n}--align-${align}`,\n alignSelf && `${n}--align-self-${alignSelf}`,\n spacing && `${n}--spacing-${spacing}`,\n wrap && `${n}--wrap`,\n getRowGapClass(),\n hasSizeProp && `${n}--has-size`,\n divider && `${n}--divider-${divider}`,\n className\n )\n\n return (\n <Space\n element={element}\n className={cn}\n data-media-key={mediaKey}\n style={\n hasSizeProp\n ? ({ '--sizeCount': sizeCount, ...style } as React.CSSProperties)\n : style\n }\n {...rest}\n >\n {content}\n </Space>\n )\n}\n\nfunction wrapChildren(props: Props, children: React.ReactNode) {\n return React.Children.toArray(children).map((child) => {\n if (\n React.isValidElement(child) &&\n child.type['_supportsSpacingProps'] === 'children'\n ) {\n return React.cloneElement(\n child,\n child.props,\n <FlexContainer {...props}>{child.props.children}</FlexContainer>\n )\n }\n\n return child\n })\n}\n\nFlexContainer._supportsSpacingProps = true\n\nexport default FlexContainer\n"],"mappings":"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"}
@@ -11,7 +11,7 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
11
11
  import React from 'react';
12
12
  import PropTypes from 'prop-types';
13
13
  import classnames from 'classnames';
14
- import { extend, extendPropsWithContextInClassComponent, isTrue, makeUniqueId, validateDOMAttributes } from '../../shared/component-helper';
14
+ import { extendGracefully, extendPropsWithContextInClassComponent, isTrue, makeUniqueId, validateDOMAttributes } from '../../shared/component-helper';
15
15
  import AlignmentHelper from '../../shared/AlignmentHelper';
16
16
  import Context from '../../shared/Context';
17
17
  import FormLabel from '../form-label/FormLabel';
@@ -157,7 +157,7 @@ export default class FormRow extends React.PureComponent {
157
157
  disabled,
158
158
  skeleton
159
159
  };
160
- const providerContext = extend(this.context, {
160
+ const providerContext = extendGracefully(this.context, {
161
161
  locale: locale ? locale : this.context.locale,
162
162
  formElement,
163
163
  FormRow: formElement
@@ -1 +1 @@
1
- {"version":3,"file":"FormRow.js","names":["React","PropTypes","classnames","extend","extendPropsWithContextInClassComponent","isTrue","makeUniqueId","validateDOMAttributes","AlignmentHelper","Context","FormLabel","Section","spacingPropTypes","createSpacingClasses","formRowPropTypes","_objectSpread","id","string","label","oneOfType","func","node","label_direction","oneOf","label_sr_only","bool","label_id","label_class","no_label","no_fieldset","locale","wrap","direction","vertical","centered","section_style","section_spacing","globalStatus","shape","message","responsive","disabled","skeleton","class","skipContentWrapperIfNested","className","children","formRowDefaultProps","FormRow","PureComponent","getContent","props","Array","isArray","reduce","pV","cV","type","name","push","constructor","_id","render","_this$context","_this$context2","_this$context3","_this$context3$FormRo","_this$context4","_this$context4$formEl","defaultProps","context","formElement","_className","_label","attributes","_objectWithoutProperties","_excluded","isNested","itsMeAgain","nestedLabel","hasLabel","length","params","useId","isIsUsed","providerContext","useFieldset","createElement","Provider","value","Fieldset","_extends","style_type","spacing","element","_AlignmentHelper","for_id","text","sr_only","_span","_defineProperty","process","env","NODE_ENV","propTypes","_ref","_excluded2","_supportsSpacingProps"],"sources":["../../../../src/components/form-row/FormRow.js"],"sourcesContent":["/**\n * Web FormRow Component\n *\n * This is a legacy component.\n * For refferencing while developing new features, please use a Functional component.\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport {\n extend,\n extendPropsWithContextInClassComponent,\n isTrue,\n makeUniqueId,\n validateDOMAttributes,\n} from '../../shared/component-helper'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\n\nimport Context from '../../shared/Context'\nimport FormLabel from '../form-label/FormLabel'\nimport Section from '../section/Section'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\n\nexport const formRowPropTypes = {\n id: PropTypes.string,\n label: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n label_direction: PropTypes.oneOf(['vertical', 'horizontal']),\n label_sr_only: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n label_id: PropTypes.string,\n label_class: PropTypes.string,\n no_label: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n no_fieldset: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n locale: PropTypes.string,\n wrap: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n direction: PropTypes.oneOf(['vertical', 'horizontal']),\n vertical: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n centered: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n section_style: PropTypes.string,\n section_spacing: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n globalStatus: PropTypes.shape({\n id: PropTypes.string,\n message: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n }),\n responsive: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n class: PropTypes.string,\n\n skipContentWrapperIfNested: PropTypes.bool,\n\n ...spacingPropTypes,\n\n className: PropTypes.string,\n children: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n}\n\nexport const formRowDefaultProps = {\n id: null,\n label: null,\n label_direction: null,\n label_sr_only: null,\n label_id: null,\n label_class: null,\n no_label: false,\n no_fieldset: null,\n locale: null,\n wrap: null,\n direction: null,\n vertical: null,\n centered: null,\n section_style: null,\n section_spacing: null,\n globalStatus: null,\n responsive: null,\n disabled: null,\n skeleton: null,\n class: null,\n\n skipContentWrapperIfNested: false,\n className: null,\n children: null,\n}\n\nexport default class FormRow extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n ...formRowPropTypes,\n }\n\n static defaultProps = {\n ...formRowDefaultProps,\n }\n\n static getContent(props) {\n let label = null\n let children =\n typeof props.children === 'function'\n ? props.children(props)\n : props.children\n\n if (Array.isArray(props.children)) {\n children = children.reduce((pV, cV) => {\n if (cV && cV.type && cV.type.name === 'FormLabel') {\n label = cV.props.children\n } else {\n pV.push(cV)\n }\n return pV\n }, [])\n }\n\n return { label, children }\n }\n\n constructor(props) {\n super(props)\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n\n // We may consider to use this later to check if we are inside FormSet\n // this.isInsideFormSet =\n // context.FormRow && context.FormRow.isInsideFormSet\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n FormRow.defaultProps,\n this.context?.FormRow, // nested FormRow\n this.context?.formElement // nested formElement\n )\n\n const {\n label_direction,\n label_sr_only,\n label_id,\n label_class,\n no_fieldset,\n no_label,\n locale,\n direction,\n vertical,\n centered,\n section_style,\n section_spacing,\n globalStatus,\n responsive,\n disabled,\n skeleton,\n wrap,\n className,\n class: _className,\n skipContentWrapperIfNested,\n\n id: _id, // eslint-disable-line\n label: _label, // eslint-disable-line\n\n ...attributes\n } = props\n\n let { label } = props\n\n const isNested =\n this.context?.FormRow?.itsMeAgain ||\n this.context?.formElement?.itsMeAgain\n\n // in case we have a label already, we split this out and use this one instead\n const { label: nestedLabel, children } = FormRow.getContent(this.props)\n if (!label && nestedLabel) {\n label = nestedLabel\n }\n const hasLabel =\n (typeof label === 'string' && label.length > 0) || label\n ? true\n : false\n\n const id = this._id\n const params = {\n className: classnames(\n 'dnb-form-row',\n (isTrue(vertical) || direction) &&\n `dnb-form-row--${isTrue(vertical) ? 'vertical' : direction}`,\n (isTrue(vertical) || label_direction) &&\n `dnb-form-row--${\n isTrue(vertical) ? 'vertical' : label_direction\n }-label`, // <-- has label\n centered && 'dnb-form-row--centered',\n isNested && 'dnb-form-row--nested',\n createSpacingClasses(props),\n className,\n _className\n ),\n ...attributes,\n }\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n const formElement = {\n useId: () => {\n if (this.isIsUsed) {\n // make a new ID, as we used one\n return makeUniqueId() // cause we need an id anyway\n }\n this.isIsUsed = true\n return id\n },\n itsMeAgain: true,\n hasLabel,\n globalStatus,\n direction,\n vertical,\n label_direction: isTrue(vertical) ? 'vertical' : label_direction,\n responsive,\n disabled,\n skeleton,\n }\n\n const providerContext = extend(this.context, {\n locale: locale ? locale : this.context.locale,\n formElement,\n FormRow: formElement,\n })\n\n const useFieldset = !isTrue(no_fieldset) && hasLabel\n\n return (\n <Context.Provider value={providerContext}>\n <Fieldset useFieldset={useFieldset}>\n <Section\n style_type={section_style || 'transparent'}\n spacing={section_spacing}\n element=\"div\"\n {...params}\n >\n <AlignmentHelper />\n\n {label && (\n <FormLabel\n className={classnames('dnb-form-row__label', label_class)}\n id={label_id ? label_id : id + '-label'}\n for_id={useFieldset ? null : id} // we don't use for_id, because we don't have a single element to target to\n text={label}\n element={useFieldset ? 'legend' : 'label'}\n label_direction={label_direction}\n sr_only={label_sr_only}\n disabled={disabled}\n skeleton={skeleton}\n />\n )}\n\n {isTrue(no_label) && (\n <span\n className=\"dnb-form-label dnb-form-row__label-dummy\"\n aria-hidden\n />\n )}\n\n {isNested && skipContentWrapperIfNested ? (\n children\n ) : (\n <div\n className={classnames(\n 'dnb-form-row__content',\n isTrue(wrap) && 'dnb-form-row__content--wrap',\n label && !isTrue(vertical) && direction !== 'vertical',\n responsive && 'dnb-responsive-component'\n )}\n >\n {children}\n </div>\n )}\n </Section>\n </Fieldset>\n </Context.Provider>\n )\n }\n}\n\nconst Fieldset = ({\n useFieldset,\n children,\n className = null,\n ...props\n}) => {\n if (useFieldset) {\n return (\n <fieldset\n className={classnames('dnb-form-row__fieldset', className)}\n {...props}\n >\n {children}\n </fieldset>\n )\n }\n return (\n <div\n className={classnames('dnb-form-row__fieldset', className)}\n {...props}\n >\n {children}\n </div>\n )\n}\n\n// docs (or use ptd): https://github.com/facebook/prop-types#usage\nFieldset.propTypes = {\n children: PropTypes.node,\n useFieldset: PropTypes.bool,\n className: PropTypes.string,\n}\nFieldset.defaultProps = {\n children: null,\n useFieldset: false,\n className: null,\n}\n\nFormRow._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"FormRow.js","names":["React","PropTypes","classnames","extendGracefully","extendPropsWithContextInClassComponent","isTrue","makeUniqueId","validateDOMAttributes","AlignmentHelper","Context","FormLabel","Section","spacingPropTypes","createSpacingClasses","formRowPropTypes","_objectSpread","id","string","label","oneOfType","func","node","label_direction","oneOf","label_sr_only","bool","label_id","label_class","no_label","no_fieldset","locale","wrap","direction","vertical","centered","section_style","section_spacing","globalStatus","shape","message","responsive","disabled","skeleton","class","skipContentWrapperIfNested","className","children","formRowDefaultProps","FormRow","PureComponent","getContent","props","Array","isArray","reduce","pV","cV","type","name","push","constructor","_id","render","_this$context","_this$context2","_this$context3","_this$context3$FormRo","_this$context4","_this$context4$formEl","defaultProps","context","formElement","_className","_label","attributes","_objectWithoutProperties","_excluded","isNested","itsMeAgain","nestedLabel","hasLabel","length","params","useId","isIsUsed","providerContext","useFieldset","createElement","Provider","value","Fieldset","_extends","style_type","spacing","element","_AlignmentHelper","for_id","text","sr_only","_span","_defineProperty","process","env","NODE_ENV","propTypes","_ref","_excluded2","_supportsSpacingProps"],"sources":["../../../../src/components/form-row/FormRow.js"],"sourcesContent":["/**\n * Web FormRow Component\n *\n * This is a legacy component.\n * For refferencing while developing new features, please use a Functional component.\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport {\n extendGracefully,\n extendPropsWithContextInClassComponent,\n isTrue,\n makeUniqueId,\n validateDOMAttributes,\n} from '../../shared/component-helper'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\n\nimport Context from '../../shared/Context'\nimport FormLabel from '../form-label/FormLabel'\nimport Section from '../section/Section'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\n\nexport const formRowPropTypes = {\n id: PropTypes.string,\n label: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n label_direction: PropTypes.oneOf(['vertical', 'horizontal']),\n label_sr_only: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n label_id: PropTypes.string,\n label_class: PropTypes.string,\n no_label: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n no_fieldset: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n locale: PropTypes.string,\n wrap: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n direction: PropTypes.oneOf(['vertical', 'horizontal']),\n vertical: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n centered: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n section_style: PropTypes.string,\n section_spacing: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n globalStatus: PropTypes.shape({\n id: PropTypes.string,\n message: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n }),\n responsive: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n class: PropTypes.string,\n\n skipContentWrapperIfNested: PropTypes.bool,\n\n ...spacingPropTypes,\n\n className: PropTypes.string,\n children: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n}\n\nexport const formRowDefaultProps = {\n id: null,\n label: null,\n label_direction: null,\n label_sr_only: null,\n label_id: null,\n label_class: null,\n no_label: false,\n no_fieldset: null,\n locale: null,\n wrap: null,\n direction: null,\n vertical: null,\n centered: null,\n section_style: null,\n section_spacing: null,\n globalStatus: null,\n responsive: null,\n disabled: null,\n skeleton: null,\n class: null,\n\n skipContentWrapperIfNested: false,\n className: null,\n children: null,\n}\n\nexport default class FormRow extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n ...formRowPropTypes,\n }\n\n static defaultProps = {\n ...formRowDefaultProps,\n }\n\n static getContent(props) {\n let label = null\n let children =\n typeof props.children === 'function'\n ? props.children(props)\n : props.children\n\n if (Array.isArray(props.children)) {\n children = children.reduce((pV, cV) => {\n if (cV && cV.type && cV.type.name === 'FormLabel') {\n label = cV.props.children\n } else {\n pV.push(cV)\n }\n return pV\n }, [])\n }\n\n return { label, children }\n }\n\n constructor(props) {\n super(props)\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n\n // We may consider to use this later to check if we are inside FormSet\n // this.isInsideFormSet =\n // context.FormRow && context.FormRow.isInsideFormSet\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n FormRow.defaultProps,\n this.context?.FormRow, // nested FormRow\n this.context?.formElement // nested formElement\n )\n\n const {\n label_direction,\n label_sr_only,\n label_id,\n label_class,\n no_fieldset,\n no_label,\n locale,\n direction,\n vertical,\n centered,\n section_style,\n section_spacing,\n globalStatus,\n responsive,\n disabled,\n skeleton,\n wrap,\n className,\n class: _className,\n skipContentWrapperIfNested,\n\n id: _id, // eslint-disable-line\n label: _label, // eslint-disable-line\n\n ...attributes\n } = props\n\n let { label } = props\n\n const isNested =\n this.context?.FormRow?.itsMeAgain ||\n this.context?.formElement?.itsMeAgain\n\n // in case we have a label already, we split this out and use this one instead\n const { label: nestedLabel, children } = FormRow.getContent(this.props)\n if (!label && nestedLabel) {\n label = nestedLabel\n }\n const hasLabel =\n (typeof label === 'string' && label.length > 0) || label\n ? true\n : false\n\n const id = this._id\n const params = {\n className: classnames(\n 'dnb-form-row',\n (isTrue(vertical) || direction) &&\n `dnb-form-row--${isTrue(vertical) ? 'vertical' : direction}`,\n (isTrue(vertical) || label_direction) &&\n `dnb-form-row--${\n isTrue(vertical) ? 'vertical' : label_direction\n }-label`, // <-- has label\n centered && 'dnb-form-row--centered',\n isNested && 'dnb-form-row--nested',\n createSpacingClasses(props),\n className,\n _className\n ),\n ...attributes,\n }\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n const formElement = {\n useId: () => {\n if (this.isIsUsed) {\n // make a new ID, as we used one\n return makeUniqueId() // cause we need an id anyway\n }\n this.isIsUsed = true\n return id\n },\n itsMeAgain: true,\n hasLabel,\n globalStatus,\n direction,\n vertical,\n label_direction: isTrue(vertical) ? 'vertical' : label_direction,\n responsive,\n disabled,\n skeleton,\n }\n\n const providerContext = extendGracefully(this.context, {\n locale: locale ? locale : this.context.locale,\n formElement,\n FormRow: formElement,\n })\n\n const useFieldset = !isTrue(no_fieldset) && hasLabel\n\n return (\n <Context.Provider value={providerContext}>\n <Fieldset useFieldset={useFieldset}>\n <Section\n style_type={section_style || 'transparent'}\n spacing={section_spacing}\n element=\"div\"\n {...params}\n >\n <AlignmentHelper />\n\n {label && (\n <FormLabel\n className={classnames('dnb-form-row__label', label_class)}\n id={label_id ? label_id : id + '-label'}\n for_id={useFieldset ? null : id} // we don't use for_id, because we don't have a single element to target to\n text={label}\n element={useFieldset ? 'legend' : 'label'}\n label_direction={label_direction}\n sr_only={label_sr_only}\n disabled={disabled}\n skeleton={skeleton}\n />\n )}\n\n {isTrue(no_label) && (\n <span\n className=\"dnb-form-label dnb-form-row__label-dummy\"\n aria-hidden\n />\n )}\n\n {isNested && skipContentWrapperIfNested ? (\n children\n ) : (\n <div\n className={classnames(\n 'dnb-form-row__content',\n isTrue(wrap) && 'dnb-form-row__content--wrap',\n label && !isTrue(vertical) && direction !== 'vertical',\n responsive && 'dnb-responsive-component'\n )}\n >\n {children}\n </div>\n )}\n </Section>\n </Fieldset>\n </Context.Provider>\n )\n }\n}\n\nconst Fieldset = ({\n useFieldset,\n children,\n className = null,\n ...props\n}) => {\n if (useFieldset) {\n return (\n <fieldset\n className={classnames('dnb-form-row__fieldset', className)}\n {...props}\n >\n {children}\n </fieldset>\n )\n }\n return (\n <div\n className={classnames('dnb-form-row__fieldset', className)}\n {...props}\n >\n {children}\n </div>\n )\n}\n\n// docs (or use ptd): https://github.com/facebook/prop-types#usage\nFieldset.propTypes = {\n children: PropTypes.node,\n useFieldset: PropTypes.bool,\n className: PropTypes.string,\n}\nFieldset.defaultProps = {\n children: null,\n useFieldset: false,\n className: null,\n}\n\nFormRow._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -8,7 +8,7 @@ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { va
8
8
  import React from 'react';
9
9
  import PropTypes from 'prop-types';
10
10
  import classnames from 'classnames';
11
- import { isTrue, makeUniqueId, extend, extendPropsWithContextInClassComponent, validateDOMAttributes, processChildren, dispatchCustomElementEvent } from '../../shared/component-helper';
11
+ import { isTrue, makeUniqueId, extendGracefully, extendPropsWithContextInClassComponent, validateDOMAttributes, processChildren, dispatchCustomElementEvent } from '../../shared/component-helper';
12
12
  import { createSpacingClasses } from '../space/SpacingHelper';
13
13
  import Context from '../../shared/Context';
14
14
  import { formRowDefaultProps, formRowPropTypes } from '../form-row/FormRow';
@@ -65,7 +65,7 @@ export default class FormSet extends React.PureComponent {
65
65
  }
66
66
  validateDOMAttributes(this.props, params);
67
67
  const content = FormSet.getContent(this.props);
68
- const providerContext = extend(this.context, {
68
+ const providerContext = extendGracefully(this.context, {
69
69
  locale: locale ? locale : this.context.locale,
70
70
  FormRow: allowedProps
71
71
  });
@@ -1 +1 @@
1
- {"version":3,"file":"FormSet.js","names":["React","PropTypes","classnames","isTrue","makeUniqueId","extend","extendPropsWithContextInClassComponent","validateDOMAttributes","processChildren","dispatchCustomElementEvent","createSpacingClasses","Context","formRowDefaultProps","formRowPropTypes","FormSet","PureComponent","getContent","props","constructor","_defineProperty","event","prevent_submit","preventDefault","_id","id","render","defaultProps","context","element","locale","no_form","className","class","_className","rest","_objectWithoutProperties","_excluded","allowedProps","Object","entries","reduce","acc","_ref","k","v","attributes","_ref2","params","_objectSpread","onSubmit","onSubmitHandler","content","providerContext","FormRow","Element","createElement","Provider","value","disabled","skeleton","on_submit","process","env","NODE_ENV","propTypes","string","oneOfType","bool","func","_supportsSpacingProps"],"sources":["../../../../src/components/form-set/FormSet.js"],"sourcesContent":["/**\n * Web FormSet Component\n *\n * This is a legacy component.\n * For refferencing while developing new features, please use a Functional component.\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport {\n isTrue,\n makeUniqueId,\n extend,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n processChildren,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport Context from '../../shared/Context'\nimport { formRowDefaultProps, formRowPropTypes } from '../form-row/FormRow'\n\nexport default class FormSet extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n element: PropTypes.string,\n no_form: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n prevent_submit: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n\n ...formRowPropTypes,\n\n on_submit: PropTypes.func,\n }\n\n static defaultProps = {\n element: 'form',\n no_form: false,\n disabled: null,\n skeleton: null,\n prevent_submit: false,\n\n on_submit: null,\n }\n\n static getContent(props) {\n return processChildren(props)\n }\n\n constructor(props) {\n super(props)\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n }\n\n onSubmitHandler = (event) => {\n const { prevent_submit } = this.props\n if (isTrue(prevent_submit)) {\n event.preventDefault()\n }\n dispatchCustomElementEvent(this, 'on_submit', { event })\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n FormSet.defaultProps,\n this.context.FormSet\n )\n\n const {\n element,\n locale,\n no_form,\n prevent_submit, // eslint-disable-line\n id, // eslint-disable-line\n className,\n class: _className,\n\n ...rest\n } = props\n\n const allowedProps = Object.entries(rest).reduce((acc, [k, v]) => {\n if (\n typeof formRowDefaultProps[k] !== 'undefined' &&\n k !== 'id' &&\n k !== 'children' &&\n k !== 'label'\n ) {\n acc[k] = v\n }\n return acc\n }, {})\n const attributes = Object.entries(rest).reduce((acc, [k, v]) => {\n if (typeof allowedProps[k] === 'undefined' && k !== 'children') {\n acc[k] = v\n }\n return acc\n }, {})\n\n const params = {\n className: classnames(\n 'dnb-form-set',\n createSpacingClasses(this.props),\n className,\n _className\n ),\n ...attributes,\n }\n\n if (!isTrue(no_form)) {\n params.onSubmit = this.onSubmitHandler\n }\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n const content = FormSet.getContent(this.props)\n\n const providerContext = extend(this.context, {\n locale: locale ? locale : this.context.locale,\n FormRow: allowedProps,\n // isInsideFormSet: true // We may consider to use this later to check if we are inside FormSet\n })\n\n const Element = isTrue(no_form) ? 'div' : element\n\n return (\n <Context.Provider value={providerContext}>\n <Element {...params}>{content}</Element>\n </Context.Provider>\n )\n }\n}\n\nFormSet._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"FormSet.js","names":["React","PropTypes","classnames","isTrue","makeUniqueId","extendGracefully","extendPropsWithContextInClassComponent","validateDOMAttributes","processChildren","dispatchCustomElementEvent","createSpacingClasses","Context","formRowDefaultProps","formRowPropTypes","FormSet","PureComponent","getContent","props","constructor","_defineProperty","event","prevent_submit","preventDefault","_id","id","render","defaultProps","context","element","locale","no_form","className","class","_className","rest","_objectWithoutProperties","_excluded","allowedProps","Object","entries","reduce","acc","_ref","k","v","attributes","_ref2","params","_objectSpread","onSubmit","onSubmitHandler","content","providerContext","FormRow","Element","createElement","Provider","value","disabled","skeleton","on_submit","process","env","NODE_ENV","propTypes","string","oneOfType","bool","func","_supportsSpacingProps"],"sources":["../../../../src/components/form-set/FormSet.js"],"sourcesContent":["/**\n * Web FormSet Component\n *\n * This is a legacy component.\n * For refferencing while developing new features, please use a Functional component.\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport {\n isTrue,\n makeUniqueId,\n extendGracefully,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n processChildren,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport Context from '../../shared/Context'\nimport { formRowDefaultProps, formRowPropTypes } from '../form-row/FormRow'\n\nexport default class FormSet extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n element: PropTypes.string,\n no_form: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n prevent_submit: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n\n ...formRowPropTypes,\n\n on_submit: PropTypes.func,\n }\n\n static defaultProps = {\n element: 'form',\n no_form: false,\n disabled: null,\n skeleton: null,\n prevent_submit: false,\n\n on_submit: null,\n }\n\n static getContent(props) {\n return processChildren(props)\n }\n\n constructor(props) {\n super(props)\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n }\n\n onSubmitHandler = (event) => {\n const { prevent_submit } = this.props\n if (isTrue(prevent_submit)) {\n event.preventDefault()\n }\n dispatchCustomElementEvent(this, 'on_submit', { event })\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n FormSet.defaultProps,\n this.context.FormSet\n )\n\n const {\n element,\n locale,\n no_form,\n prevent_submit, // eslint-disable-line\n id, // eslint-disable-line\n className,\n class: _className,\n\n ...rest\n } = props\n\n const allowedProps = Object.entries(rest).reduce((acc, [k, v]) => {\n if (\n typeof formRowDefaultProps[k] !== 'undefined' &&\n k !== 'id' &&\n k !== 'children' &&\n k !== 'label'\n ) {\n acc[k] = v\n }\n return acc\n }, {})\n const attributes = Object.entries(rest).reduce((acc, [k, v]) => {\n if (typeof allowedProps[k] === 'undefined' && k !== 'children') {\n acc[k] = v\n }\n return acc\n }, {})\n\n const params = {\n className: classnames(\n 'dnb-form-set',\n createSpacingClasses(this.props),\n className,\n _className\n ),\n ...attributes,\n }\n\n if (!isTrue(no_form)) {\n params.onSubmit = this.onSubmitHandler\n }\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n const content = FormSet.getContent(this.props)\n\n const providerContext = extendGracefully(this.context, {\n locale: locale ? locale : this.context.locale,\n FormRow: allowedProps,\n // isInsideFormSet: true // We may consider to use this later to check if we are inside FormSet\n })\n\n const Element = isTrue(no_form) ? 'div' : element\n\n return (\n <Context.Provider value={providerContext}>\n <Element {...params}>{content}</Element>\n </Context.Provider>\n )\n }\n}\n\nFormSet._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -121,7 +121,6 @@ export interface InfoIconProps {
121
121
  * The `title` attribute in the status.
122
122
  */
123
123
  title?: string;
124
- theme?: string;
125
124
  }
126
125
  export declare const InfoIcon: React.FC<InfoIconProps>;
127
126
  export interface MarketingIconProps {
@@ -3,14 +3,13 @@
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
5
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
6
- var _path, _path2, _path3, _path4, _path5, _path6, _circle, _path7, _path8;
7
6
  const _excluded = ["title", "state", "size", "variant", "className", "stretch", "shellSpace", "class", "text_id", "show", "no_animation", "label", "status_id", "globalStatus", "id", "text", "icon", "icon_size", "skeleton", "children", "role"];
8
7
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
9
8
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
10
9
  import React from 'react';
11
10
  import PropTypes from 'prop-types';
12
11
  import classnames from 'classnames';
13
- import Context from '../../shared/Context';
12
+ import { useTheme, Context } from '../../shared';
14
13
  import { isTrue, makeUniqueId, validateDOMAttributes, processChildren, extendPropsWithContextInClassComponent } from '../../shared/component-helper';
15
14
  import HeightAnimation from '../height-animation/HeightAnimation';
16
15
  import { spacingPropTypes, createSpacingClasses } from '../space/SpacingHelper';
@@ -18,6 +17,12 @@ import Icon from '../icon/Icon';
18
17
  import GlobalStatusProvider from '../global-status/GlobalStatusProvider';
19
18
  import { skeletonDOMAttributes, createSkeletonClass } from '../skeleton/SkeletonHelper';
20
19
  import { pickFormElementProps } from '../../shared/helpers/filterValidProps';
20
+ import ui from '../../style/themes/theme-ui/properties';
21
+ import sbanken from '../../style/themes/theme-sbanken/properties';
22
+ const properties = {
23
+ ui,
24
+ sbanken
25
+ };
21
26
  export default class FormStatus extends React.PureComponent {
22
27
  static getContent(props) {
23
28
  if (props.text) {
@@ -43,8 +48,7 @@ export default class FormStatus extends React.PureComponent {
43
48
  let {
44
49
  state,
45
50
  icon,
46
- icon_size,
47
- theme
51
+ icon_size
48
52
  } = _ref;
49
53
  if (typeof icon !== 'string') {
50
54
  return icon;
@@ -68,8 +72,7 @@ export default class FormStatus extends React.PureComponent {
68
72
  return React.createElement(Icon, {
69
73
  icon: React.createElement(IconToLoad, {
70
74
  title: null,
71
- state: state,
72
- theme: theme
75
+ state: state
73
76
  }),
74
77
  size: icon_size,
75
78
  inherit_color: false
@@ -216,7 +219,6 @@ export default class FormStatus extends React.PureComponent {
216
219
  return isTrue(props.show) && FormStatus.getContent(props) ? true : false;
217
220
  }
218
221
  render() {
219
- var _this$context, _this$context$theme;
220
222
  const props = this.getProps();
221
223
  const {
222
224
  title,
@@ -246,8 +248,7 @@ export default class FormStatus extends React.PureComponent {
246
248
  const iconToRender = FormStatus.getIcon({
247
249
  state,
248
250
  icon,
249
- icon_size,
250
- theme: (_this$context = this.context) === null || _this$context === void 0 ? void 0 : (_this$context$theme = _this$context.theme) === null || _this$context$theme === void 0 ? void 0 : _this$context$theme.name
251
+ icon_size
251
252
  });
252
253
  const contentToRender = FormStatus.getContent(this.props);
253
254
  const hasStringContent = typeof contentToRender === 'string' && contentToRender.length > 0;
@@ -341,48 +342,60 @@ process.env.NODE_ENV !== "production" ? FormStatus.propTypes = _objectSpread(_ob
341
342
  className: PropTypes.string,
342
343
  children: PropTypes.oneOfType([PropTypes.string, PropTypes.func, PropTypes.node])
343
344
  }) : void 0;
344
- export const ErrorIcon = props => React.createElement("svg", _extends({
345
- width: "24",
346
- height: "24",
347
- viewBox: "0 0 24 24",
348
- fill: "none"
349
- }, props), props && props.title && React.createElement("title", null, props.title), _path || (_path = React.createElement("path", {
350
- d: "M23.625 17.864A3.547 3.547 0 0120.45 23H3.548a3.546 3.546 0 01-3.172-5.136l8.45-14.902a3.548 3.548 0 016.347 0l8.452 14.902z",
351
- fill: "#DC2A2A"
352
- })), _path2 || (_path2 = React.createElement("path", {
353
- d: "M12 16.286a1.286 1.286 0 100 2.572 1.286 1.286 0 000-2.572z",
354
- fill: "#fff"
355
- })), _path3 || (_path3 = React.createElement("path", {
356
- d: "M12 13.818v-5",
357
- stroke: "#fff",
358
- strokeWidth: "1.5",
359
- strokeLinecap: "round",
360
- strokeLinejoin: "round"
361
- })));
345
+ export const ErrorIcon = props => {
346
+ var _useTheme;
347
+ const isSbankenTheme = ((_useTheme = useTheme()) === null || _useTheme === void 0 ? void 0 : _useTheme.name) === 'sbanken';
348
+ const fill = isSbankenTheme ? properties.sbanken['--sb-color-magenta'] : properties.ui['--color-fire-red'];
349
+ const line = isSbankenTheme ? properties.sbanken['--sb-color-magenta-light-2'] : properties.ui['--color-white'];
350
+ return React.createElement("svg", _extends({
351
+ width: "24",
352
+ height: "24",
353
+ viewBox: "0 0 24 24",
354
+ fill: "none"
355
+ }, props), props && props.title && React.createElement("title", null, props.title), React.createElement("path", {
356
+ d: "M23.625 17.864A3.547 3.547 0 0120.45 23H3.548a3.546 3.546 0 01-3.172-5.136l8.45-14.902a3.548 3.548 0 016.347 0l8.452 14.902z",
357
+ fill: fill
358
+ }), React.createElement("path", {
359
+ d: "M12 16.286a1.286 1.286 0 100 2.572 1.286 1.286 0 000-2.572z",
360
+ fill: line
361
+ }), React.createElement("path", {
362
+ d: "M12 13.818v-5",
363
+ stroke: line,
364
+ strokeWidth: "1.5",
365
+ strokeLinecap: "round",
366
+ strokeLinejoin: "round"
367
+ }));
368
+ };
362
369
  process.env.NODE_ENV !== "production" ? ErrorIcon.propTypes = {
363
370
  title: PropTypes.string
364
371
  } : void 0;
365
372
  ErrorIcon.defaultProps = {
366
373
  title: 'error'
367
374
  };
368
- export const WarnIcon = props => React.createElement("svg", _extends({
369
- width: "24",
370
- height: "24",
371
- viewBox: "0 0 24 24",
372
- fill: "none"
373
- }, props), props && props.title && React.createElement("title", null, props.title), _path4 || (_path4 = React.createElement("path", {
374
- d: "M23.625 17.864A3.547 3.547 0 0120.45 23H3.548a3.546 3.546 0 01-3.172-5.136l8.45-14.902a3.548 3.548 0 016.347 0l8.452 14.902z",
375
- fill: "#FDBB31"
376
- })), _path5 || (_path5 = React.createElement("path", {
377
- d: "M12 16.286a1.286 1.286 0 100 2.572 1.286 1.286 0 000-2.572z",
378
- fill: "#333"
379
- })), _path6 || (_path6 = React.createElement("path", {
380
- d: "M12 13.818v-5",
381
- stroke: "#333",
382
- strokeWidth: "1.5",
383
- strokeLinecap: "round",
384
- strokeLinejoin: "round"
385
- })));
375
+ export const WarnIcon = props => {
376
+ var _useTheme2;
377
+ const isSbankenTheme = ((_useTheme2 = useTheme()) === null || _useTheme2 === void 0 ? void 0 : _useTheme2.name) === 'sbanken';
378
+ const fill = isSbankenTheme ? properties.sbanken['--sb-color-yellow-dark'] : properties.ui['--color-accent-yellow'];
379
+ const line = isSbankenTheme ? properties.sbanken['--sb-color-black'] : properties.ui['--color-black-80'];
380
+ return React.createElement("svg", _extends({
381
+ width: "24",
382
+ height: "24",
383
+ viewBox: "0 0 24 24",
384
+ fill: "none"
385
+ }, props), props && props.title && React.createElement("title", null, props.title), React.createElement("path", {
386
+ d: "M23.625 17.864A3.547 3.547 0 0120.45 23H3.548a3.546 3.546 0 01-3.172-5.136l8.45-14.902a3.548 3.548 0 016.347 0l8.452 14.902z",
387
+ fill: fill
388
+ }), React.createElement("path", {
389
+ d: "M12 16.286a1.286 1.286 0 100 2.572 1.286 1.286 0 000-2.572z",
390
+ fill: line
391
+ }), React.createElement("path", {
392
+ d: "M12 13.818v-5",
393
+ stroke: line,
394
+ strokeWidth: "1.5",
395
+ strokeLinecap: "round",
396
+ strokeLinejoin: "round"
397
+ }));
398
+ };
386
399
  process.env.NODE_ENV !== "production" ? WarnIcon.propTypes = {
387
400
  title: PropTypes.string
388
401
  } : void 0;
@@ -390,11 +403,13 @@ WarnIcon.defaultProps = {
390
403
  title: 'error'
391
404
  };
392
405
  export const InfoIcon = props => {
393
- const isSbankenTheme = props && (props === null || props === void 0 ? void 0 : props.theme) === 'sbanken';
394
- let fill = isSbankenTheme ? '#000' : '#007272';
406
+ var _useTheme3;
407
+ const isSbankenTheme = ((_useTheme3 = useTheme()) === null || _useTheme3 === void 0 ? void 0 : _useTheme3.name) === 'sbanken';
408
+ let fill = isSbankenTheme ? properties.sbanken['--sb-color-violet-light'] : properties.ui['--color-sea-green'];
395
409
  if (props && (props === null || props === void 0 ? void 0 : props.state) === 'success') {
396
- fill = isSbankenTheme ? '#02A56A' : '#28B482';
410
+ fill = isSbankenTheme ? properties.sbanken['--sb-color-green-dark-3'] : properties.ui['--color-summer-green'];
397
411
  }
412
+ const line = isSbankenTheme ? properties.sbanken['--sb-color-green-light-2'] : properties.ui['--color-white'];
398
413
  return React.createElement("svg", _extends({
399
414
  width: "24",
400
415
  height: "24",
@@ -405,39 +420,42 @@ export const InfoIcon = props => {
405
420
  clipRule: "evenodd",
406
421
  d: "M11.268 0a11.25 11.25 0 105.566 21.017l6.112 2.91a.75.75 0 001-1l-2.911-6.112A11.234 11.234 0 0011.268 0z",
407
422
  fill: fill
408
- }), _circle || (_circle = React.createElement("circle", {
423
+ }), React.createElement("circle", {
409
424
  cx: "11",
410
425
  cy: "6.5",
411
426
  r: ".5",
412
427
  fill: "#fff",
413
- stroke: "#fff"
414
- })), _path7 || (_path7 = React.createElement("path", {
428
+ stroke: line
429
+ }), React.createElement("path", {
415
430
  d: "M13.75 16H13a1.5 1.5 0 01-1.5-1.5v-3.75a.75.75 0 00-.75-.75H10",
416
- stroke: "#fff",
431
+ stroke: line,
417
432
  strokeWidth: "1.5",
418
433
  strokeLinecap: "round",
419
434
  strokeLinejoin: "round"
420
- })));
435
+ }));
421
436
  };
422
437
  process.env.NODE_ENV !== "production" ? InfoIcon.propTypes = {
423
438
  title: PropTypes.string,
424
- state: PropTypes.string,
425
- theme: PropTypes.string
439
+ state: PropTypes.string
426
440
  } : void 0;
427
441
  InfoIcon.defaultProps = {
428
442
  title: 'info',
429
- state: 'info',
430
- theme: 'ui'
443
+ state: 'info'
444
+ };
445
+ export const MarketingIcon = props => {
446
+ var _useTheme4;
447
+ const isSbankenTheme = ((_useTheme4 = useTheme()) === null || _useTheme4 === void 0 ? void 0 : _useTheme4.name) === 'sbanken';
448
+ const fill = isSbankenTheme ? properties.sbanken['--sb-color-violet-light'] : properties.ui['--color-black-80'];
449
+ return React.createElement("svg", _extends({
450
+ width: "24",
451
+ height: "24",
452
+ fill: "none",
453
+ xmlns: "http://www.w3.org/2000/svg"
454
+ }, props), props && props.title && React.createElement("title", null, props.title), React.createElement("path", {
455
+ d: "M6 15.25H4.5c-2.042 0-3.75-1.707-3.75-3.75S2.458 7.75 4.5 7.75H6v7.5ZM7.5 15.25c4.801 0 8.846 1.897 12.75 4.5V3.25c-3.904 2.603-7.949 4.5-12.75 4.5v7.5ZM23.25 10a.75.75 0 0 0-1.5 0h1.5Zm-1.5 3a.75.75 0 0 0 1.5 0h-1.5ZM8.483 21.043a.75.75 0 1 0 1.034-1.086l-1.034 1.086ZM21.75 10v3h1.5v-3h-1.5ZM6 15.25a8.058 8.058 0 0 0 2.483 5.793l1.034-1.086A6.559 6.559 0 0 1 7.5 15.25H6Z",
456
+ fill: fill
457
+ }));
431
458
  };
432
- export const MarketingIcon = props => React.createElement("svg", _extends({
433
- width: "24",
434
- height: "24",
435
- fill: "none",
436
- xmlns: "http://www.w3.org/2000/svg"
437
- }, props), props && props.title && React.createElement("title", null, props.title), _path8 || (_path8 = React.createElement("path", {
438
- d: "M6 15.25H4.5c-2.042 0-3.75-1.707-3.75-3.75S2.458 7.75 4.5 7.75H6v7.5ZM7.5 15.25c4.801 0 8.846 1.897 12.75 4.5V3.25c-3.904 2.603-7.949 4.5-12.75 4.5v7.5ZM23.25 10a.75.75 0 0 0-1.5 0h1.5Zm-1.5 3a.75.75 0 0 0 1.5 0h-1.5ZM8.483 21.043a.75.75 0 1 0 1.034-1.086l-1.034 1.086ZM21.75 10v3h1.5v-3h-1.5ZM6 15.25a8.058 8.058 0 0 0 2.483 5.793l1.034-1.086A6.559 6.559 0 0 1 7.5 15.25H6Z",
439
- fill: "#333"
440
- })));
441
459
  process.env.NODE_ENV !== "production" ? MarketingIcon.propTypes = {
442
460
  title: PropTypes.string
443
461
  } : void 0;