@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
@@ -28,7 +28,7 @@ function ArraySelection(props) {
28
28
  handleChange,
29
29
  children
30
30
  } = useFieldProps(props);
31
- const fieldBlockProps = _objectSpread({
31
+ const fieldSectionProps = _objectSpread({
32
32
  forId: id,
33
33
  className: classnames(`dnb-forms-field-array-selection dnb-forms-field-array-selection--layout-${layout} dnb-forms-field-array-selection--options-layout-${optionsLayout}`, className),
34
34
  contentClassName: 'dnb-forms-field-array-selection__options',
@@ -53,7 +53,7 @@ function ArraySelection(props) {
53
53
  }), [children, value, emptyValue, handleChange]);
54
54
  switch (variant) {
55
55
  case 'button':
56
- return React.createElement(FieldBlock, fieldBlockProps, React.createElement(ToggleButtonGroupContext.Provider, {
56
+ return React.createElement(FieldBlock, fieldSectionProps, React.createElement(ToggleButtonGroupContext.Provider, {
57
57
  value: {
58
58
  status: hasError ? 'error' : undefined,
59
59
  disabled
@@ -65,7 +65,7 @@ function ArraySelection(props) {
65
65
  on_change: option.handleSelect
66
66
  }))));
67
67
  case 'checkbox':
68
- return React.createElement(FieldBlock, fieldBlockProps, options.map((option, i) => React.createElement(Checkbox, {
68
+ return React.createElement(FieldBlock, fieldSectionProps, options.map((option, i) => React.createElement(Checkbox, {
69
69
  key: `option-${i}-${option.value}`,
70
70
  className: "dnb-forms-field-array-selection__checkbox",
71
71
  label: option.title,
@@ -1 +1 @@
1
- {"version":3,"file":"ArraySelection.js","names":["React","useMemo","Checkbox","ToggleButton","classnames","OptionField","FieldBlock","useFieldProps","pickSpacingProps","ToggleButtonGroupContext","ArraySelection","props","id","className","variant","layout","optionsLayout","label","labelDescription","value","error","hasError","info","warning","disabled","emptyValue","handleChange","children","fieldBlockProps","_objectSpread","forId","contentClassName","options","Children","toArray","filter","child","isValidElement","type","map","option","_option$props$title","title","handleSelect","selected","newValue","includes","length","createElement","Provider","status","undefined","i","key","text","checked","on_change","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/ArraySelection/ArraySelection.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport { Checkbox, ToggleButton } from '../../../../components'\nimport classnames from 'classnames'\nimport OptionField from '../Option'\nimport FieldBlock from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport { FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport ToggleButtonGroupContext from '../../../../components/toggle-button/ToggleButtonGroupContext'\n\ninterface IOption {\n title: string\n value: number | string\n handleSelect: () => void\n}\n\nexport type Props = FieldProps<Array<string | number>> & {\n children?: React.ReactNode\n variant?: 'checkbox' | 'button'\n optionsLayout?: 'horizontal' | 'vertical'\n}\n\nfunction ArraySelection(props: Props) {\n const {\n id,\n className,\n variant = 'checkbox',\n layout = 'vertical',\n optionsLayout = 'vertical',\n label,\n labelDescription,\n value,\n error,\n hasError,\n info,\n warning,\n disabled,\n emptyValue,\n handleChange,\n children,\n } = useFieldProps(props)\n\n const fieldBlockProps = {\n forId: id,\n className: classnames(\n 'dnb-forms-field-array-selection',\n `dnb-forms-field-array-selection--layout-${layout}`,\n `dnb-forms-field-array-selection--options-layout-${optionsLayout}`,\n className\n ),\n contentClassName: 'dnb-forms-field-array-selection__options',\n info,\n warning,\n error,\n layout,\n label,\n labelDescription,\n ...pickSpacingProps(props),\n }\n\n const options: IOption[] = useMemo(\n () =>\n React.Children.toArray(children)\n .filter(\n (child) =>\n React.isValidElement(child) && child.type === OptionField\n )\n .map((option: React.ReactElement) => ({\n title: option.props.title ?? option.props.children,\n value: option.props.value,\n handleSelect: () => {\n const selected = option.props.value\n\n const newValue = value?.includes(selected)\n ? value.filter((value) => value !== selected)\n : [...(value ?? []), selected]\n\n handleChange?.(newValue.length === 0 ? emptyValue : newValue)\n },\n })),\n [children, value, emptyValue, handleChange]\n )\n\n switch (variant) {\n case 'button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButtonGroupContext.Provider\n value={{\n status: hasError ? 'error' : undefined,\n disabled,\n }}\n >\n {options.map((option, i) => (\n <ToggleButton\n key={`option-${i}-${option.value}`}\n text={option.title}\n checked={value?.includes(option.value)}\n on_change={option.handleSelect}\n />\n ))}\n </ToggleButtonGroupContext.Provider>\n </FieldBlock>\n )\n case 'checkbox':\n return (\n <FieldBlock {...fieldBlockProps}>\n {options.map((option, i) => (\n <Checkbox\n key={`option-${i}-${option.value}`}\n className=\"dnb-forms-field-array-selection__checkbox\"\n label={option.title}\n checked={value?.includes(option.value)}\n disabled={disabled}\n on_change={option.handleSelect}\n status={hasError ? 'error' : undefined}\n />\n ))}\n </FieldBlock>\n )\n }\n}\n\nArraySelection._supportsSpacingProps = true\nexport default ArraySelection\n"],"mappings":"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"}
1
+ {"version":3,"file":"ArraySelection.js","names":["React","useMemo","Checkbox","ToggleButton","classnames","OptionField","FieldBlock","useFieldProps","pickSpacingProps","ToggleButtonGroupContext","ArraySelection","props","id","className","variant","layout","optionsLayout","label","labelDescription","value","error","hasError","info","warning","disabled","emptyValue","handleChange","children","fieldSectionProps","_objectSpread","forId","contentClassName","options","Children","toArray","filter","child","isValidElement","type","map","option","_option$props$title","title","handleSelect","selected","newValue","includes","length","createElement","Provider","status","undefined","i","key","text","checked","on_change","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/ArraySelection/ArraySelection.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport { Checkbox, ToggleButton } from '../../../../components'\nimport classnames from 'classnames'\nimport OptionField from '../Option'\nimport FieldBlock from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport { FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport ToggleButtonGroupContext from '../../../../components/toggle-button/ToggleButtonGroupContext'\n\ninterface IOption {\n title: string\n value: number | string\n handleSelect: () => void\n}\n\nexport type Props = FieldProps<Array<string | number> | undefined> & {\n children?: React.ReactNode\n variant?: 'checkbox' | 'button'\n optionsLayout?: 'horizontal' | 'vertical'\n}\n\nfunction ArraySelection(props: Props) {\n const {\n id,\n className,\n variant = 'checkbox',\n layout = 'vertical',\n optionsLayout = 'vertical',\n label,\n labelDescription,\n value,\n error,\n hasError,\n info,\n warning,\n disabled,\n emptyValue,\n handleChange,\n children,\n } = useFieldProps(props)\n\n const fieldSectionProps = {\n forId: id,\n className: classnames(\n 'dnb-forms-field-array-selection',\n `dnb-forms-field-array-selection--layout-${layout}`,\n `dnb-forms-field-array-selection--options-layout-${optionsLayout}`,\n className\n ),\n contentClassName: 'dnb-forms-field-array-selection__options',\n info,\n warning,\n error,\n layout,\n label,\n labelDescription,\n ...pickSpacingProps(props),\n }\n\n const options: IOption[] = useMemo(\n () =>\n React.Children.toArray(children)\n .filter(\n (child) =>\n React.isValidElement(child) && child.type === OptionField\n )\n .map((option: React.ReactElement) => ({\n title: option.props.title ?? option.props.children,\n value: option.props.value,\n handleSelect: () => {\n const selected = option.props.value\n\n const newValue = value?.includes(selected)\n ? value.filter((value) => value !== selected)\n : [...(value ?? []), selected]\n\n handleChange?.(newValue.length === 0 ? emptyValue : newValue)\n },\n })),\n [children, value, emptyValue, handleChange]\n )\n\n switch (variant) {\n case 'button':\n return (\n <FieldBlock {...fieldSectionProps}>\n <ToggleButtonGroupContext.Provider\n value={{\n status: hasError ? 'error' : undefined,\n disabled,\n }}\n >\n {options.map((option, i) => (\n <ToggleButton\n key={`option-${i}-${option.value}`}\n text={option.title}\n checked={value?.includes(option.value)}\n on_change={option.handleSelect}\n />\n ))}\n </ToggleButtonGroupContext.Provider>\n </FieldBlock>\n )\n case 'checkbox':\n return (\n <FieldBlock {...fieldSectionProps}>\n {options.map((option, i) => (\n <Checkbox\n key={`option-${i}-${option.value}`}\n className=\"dnb-forms-field-array-selection__checkbox\"\n label={option.title}\n checked={value?.includes(option.value)}\n disabled={disabled}\n on_change={option.handleSelect}\n status={hasError ? 'error' : undefined}\n />\n ))}\n </FieldBlock>\n )\n }\n}\n\nArraySelection._supportsSpacingProps = true\nexport default ArraySelection\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { Props as FieldBlockProps } from '../../FieldBlock';
2
- declare function CompositionField(props: FieldBlockProps): import("react/jsx-runtime").JSX.Element;
1
+ import { Props as FieldSectionProps } from '../../FieldBlock';
2
+ declare function CompositionField(props: FieldSectionProps): import("react/jsx-runtime").JSX.Element;
3
3
  declare namespace CompositionField {
4
4
  var _supportsSpacingProps: boolean;
5
5
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Composition.js","names":["React","FieldBlock","CompositionField","props","createElement","_extends","composition","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Composition/Composition.tsx"],"sourcesContent":["import React from 'react'\nimport FieldBlock, { Props as FieldBlockProps } from '../../FieldBlock'\n\nfunction CompositionField(props: FieldBlockProps) {\n return <FieldBlock {...props} composition />\n}\n\nCompositionField._supportsSpacingProps = true\nexport default CompositionField\n"],"mappings":";AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAoC,kBAAkB;AAEvE,SAASC,gBAAgBA,CAACC,KAAsB,EAAE;EAChD,OAAOH,KAAA,CAAAI,aAAA,CAACH,UAAU,EAAAI,QAAA,KAAKF,KAAK;IAAEG,WAAW;EAAA,EAAE,CAAC;AAC9C;AAEAJ,gBAAgB,CAACK,qBAAqB,GAAG,IAAI;AAC7C,eAAeL,gBAAgB"}
1
+ {"version":3,"file":"Composition.js","names":["React","FieldBlock","CompositionField","props","createElement","_extends","composition","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Composition/Composition.tsx"],"sourcesContent":["import React from 'react'\nimport FieldBlock, { Props as FieldSectionProps } from '../../FieldBlock'\n\nfunction CompositionField(props: FieldSectionProps) {\n return <FieldBlock {...props} composition />\n}\n\nCompositionField._supportsSpacingProps = true\nexport default CompositionField\n"],"mappings":";AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAsC,kBAAkB;AAEzE,SAASC,gBAAgBA,CAACC,KAAwB,EAAE;EAClD,OAAOH,KAAA,CAAAI,aAAA,CAACH,UAAU,EAAAI,QAAA,KAAKF,KAAK;IAAEG,WAAW;EAAA,EAAE,CAAC;AAC9C;AAEAJ,gBAAgB,CAACK,qBAAqB,GAAG,IAAI;AAC7C,eAAeL,gBAAgB"}
@@ -0,0 +1,2 @@
1
+ import { PropertiesTableProps } from '../../../../shared/types';
2
+ export declare const CompositionProperties: PropertiesTableProps;
@@ -0,0 +1,14 @@
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ 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; }
3
+ 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; }
4
+ import { fieldBlockProperties } from '../../FieldBlock/FieldBlockDocs';
5
+ export const CompositionProperties = _objectSpread(_objectSpread({}, fieldBlockProperties), {}, {
6
+ align: {
7
+ doc: '`center` or `bottom` for aligning the contents vertically. Defaults to `bottom`.',
8
+ type: ['string', 'false'],
9
+ status: 'optional'
10
+ },
11
+ asFieldset: undefined,
12
+ composition: undefined
13
+ });
14
+ //# sourceMappingURL=CompositionDocs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CompositionDocs.js","names":["fieldBlockProperties","CompositionProperties","_objectSpread","align","doc","type","status","asFieldset","undefined","composition"],"sources":["../../../../../../src/extensions/forms/Field/Composition/CompositionDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { fieldBlockProperties } from '../../FieldBlock/FieldBlockDocs'\n\nexport const CompositionProperties: PropertiesTableProps = {\n ...fieldBlockProperties,\n align: {\n doc: '`center` or `bottom` for aligning the contents vertically. Defaults to `bottom`.',\n type: ['string', 'false'],\n status: 'optional',\n },\n asFieldset: undefined,\n composition: undefined,\n}\n"],"mappings":";;;AACA,SAASA,oBAAoB,QAAQ,iCAAiC;AAEtE,OAAO,MAAMC,qBAA2C,GAAAC,aAAA,CAAAA,aAAA,KACnDF,oBAAoB;EACvBG,KAAK,EAAE;IACLC,GAAG,EAAE,kFAAkF;IACvFC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDC,UAAU,EAAEC,SAAS;EACrBC,WAAW,EAAED;AAAS,EACvB"}
@@ -17,6 +17,7 @@ export type Props = FieldHelpProps & FieldProps<number, undefined, ErrorMessages
17
17
  percent?: InputMaskedProps['as_percent'];
18
18
  mask?: InputMaskedProps['mask'];
19
19
  step?: number;
20
+ startWith?: number;
20
21
  decimalLimit?: number;
21
22
  prefix?: string;
22
23
  suffix?: string;
@@ -52,7 +52,7 @@ function NumberComponent(props) {
52
52
  }, [props.schema, props.minimum, props.maximum, props.exclusiveMinimum, props.exclusiveMaximum, props.multipleOf]);
53
53
  const toInput = useCallback(external => {
54
54
  if (external === undefined) {
55
- return '';
55
+ return null;
56
56
  }
57
57
  return external;
58
58
  }, []);
@@ -120,6 +120,7 @@ function NumberComponent(props) {
120
120
  label,
121
121
  labelDescription,
122
122
  value,
123
+ startWith = null,
123
124
  minimum = Number.MIN_SAFE_INTEGER,
124
125
  maximum = Number.MAX_SAFE_INTEGER,
125
126
  disabled,
@@ -147,10 +148,10 @@ function NumberComponent(props) {
147
148
  let numberValue = null;
148
149
  switch (key) {
149
150
  case 'ArrowUp':
150
- numberValue = clamp(value + step, minimum, maximum);
151
+ numberValue = clamp((value !== null && value !== void 0 ? value : startWith) + step, minimum, maximum);
151
152
  break;
152
153
  case 'ArrowDown':
153
- numberValue = clamp(value - step, minimum, maximum);
154
+ numberValue = clamp((value !== null && value !== void 0 ? value : startWith) - step, minimum, maximum);
154
155
  break;
155
156
  }
156
157
  if (numberValue !== null) {
@@ -160,7 +161,7 @@ function NumberComponent(props) {
160
161
  numberValue
161
162
  });
162
163
  }
163
- }, [handleChange, maximum, minimum, showStepControls, step, value]);
164
+ }, [handleChange, maximum, minimum, showStepControls, startWith, step, value]);
164
165
  const fieldBlockProps = _objectSpread({
165
166
  className: classnames("dnb-forms-field-number dnb-input__border--tokens", className),
166
167
  contentClassName: classnames('dnb-forms-field-number__contents', showStepControls && 'dnb-forms-field-number__contents--has-controls', hasError && 'dnb-input__status--error', disabled && 'dnb-input--disabled'),
@@ -172,9 +173,14 @@ function NumberComponent(props) {
172
173
  warning,
173
174
  error,
174
175
  disabled,
175
- width: width === 'stretch' || fieldBlockContext !== null && fieldBlockContext !== void 0 && fieldBlockContext.composition ? width : undefined,
176
+ width: (width === 'stretch' || fieldBlockContext !== null && fieldBlockContext !== void 0 && fieldBlockContext.composition) && !showStepControls ? width : undefined,
176
177
  contentWidth: width !== false ? width : undefined
177
178
  }, pickSpacingProps(props));
179
+ const increaseClickHandler = useCallback(() => {
180
+ handleChange({
181
+ numberValue: clamp((value !== null && value !== void 0 ? value : startWith) + step, minimum, maximum)
182
+ });
183
+ }, [handleChange, maximum, minimum, startWith, step, value]);
178
184
  const increaseProps = showStepControls && {
179
185
  'aria-hidden': true,
180
186
  className: 'dnb-button--control-after',
@@ -183,23 +189,20 @@ function NumberComponent(props) {
183
189
  size: size || 'small',
184
190
  tabIndex: -1,
185
191
  disabled: disabled || value >= maximum,
186
- onClick: () => {
187
- handleChange({
188
- numberValue: clamp(value + step, minimum, maximum)
189
- });
190
- },
192
+ onClick: increaseClickHandler,
191
193
  title: sharedContext === null || sharedContext === void 0 ? void 0 : (_sharedContext$transl = sharedContext.translation.Slider.addTitle) === null || _sharedContext$transl === void 0 ? void 0 : _sharedContext$transl.replace('%s', String(value + step))
192
194
  };
195
+ const decreaseClickHandler = useCallback(() => {
196
+ handleChange({
197
+ numberValue: clamp((value !== null && value !== void 0 ? value : startWith) - step, minimum, maximum)
198
+ });
199
+ }, [handleChange, maximum, minimum, startWith, step, value]);
193
200
  const decreaseProps = showStepControls && _objectSpread(_objectSpread({}, increaseProps), {}, {
194
201
  className: 'dnb-button--control-before',
195
202
  icon: 'subtract',
196
203
  size: size || 'small',
197
204
  disabled: disabled || value <= minimum,
198
- onClick: () => {
199
- handleChange({
200
- numberValue: clamp(value - step, minimum, maximum)
201
- });
202
- },
205
+ onClick: decreaseClickHandler,
203
206
  title: sharedContext === null || sharedContext === void 0 ? void 0 : (_sharedContext$transl2 = sharedContext.translation.Slider.subtractTitle) === null || _sharedContext$transl2 === void 0 ? void 0 : _sharedContext$transl2.replace('%s', String(value - step))
204
207
  });
205
208
  const ariaParams = showStepControls && {
@@ -1 +1 @@
1
- {"version":3,"file":"Number.js","names":["React","useContext","useMemo","useCallback","InputMasked","HelpButton","Button","SharedContext","FieldBlockContext","classnames","FieldBlock","useFieldProps","pickSpacingProps","clamp","useErrorMessage","useTranslation","NumberComponent","props","_props$width","_sharedContext$transl","_sharedContext$transl2","fieldBlockContext","sharedContext","translations","currency","currencyDisplay","percent","mask","step","decimalLimit","prefix","suffix","showStepControls","errorMessages","path","required","Field","errorRequired","minimum","NumberField","errorMinimum","maximum","errorMaximum","exclusiveMinimum","errorExclusiveMinimum","exclusiveMaximum","errorExclusiveMaximum","multipleOf","errorMultipleOf","schema","_props$schema","type","toInput","external","undefined","fromInput","_ref","value","numberValue","emptyValue","transformValue","currentValue","Number","MAX_SAFE_INTEGER","MIN_SAFE_INTEGER","maskProps","mask_options","as_currency","currency_mask","as_percent","as_number","number_mask","_objectSpread","preparedProps","valueType","width","composition","id","name","className","inputClassName","autoComplete","layout","placeholder","label","labelDescription","disabled","htmlAttributes","info","warning","error","hasError","help","size","align","handleFocus","handleBlur","handleChange","onKeyDownHandler","_ref2","key","event","persist","preventDefault","fieldBlockProps","contentClassName","forId","contentWidth","increaseProps","variant","icon","tabIndex","onClick","title","translation","Slider","addTitle","replace","String","decreaseProps","subtractTitle","ariaParams","role","inputProps","onKeyDown","onFocus","onBlur","onChange","status","stretch","Boolean","createElement","content","_extends","asFieldset","left","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Number/Number.tsx"],"sourcesContent":["import React, { useContext, useMemo, useCallback } from 'react'\nimport { InputMasked, HelpButton, Button } from '../../../../components'\nimport { InputMaskedProps } from '../../../../components/InputMasked'\nimport type { InputAlign, InputSize } from '../../../../components/Input'\nimport SharedContext from '../../../../shared/Context'\nimport FieldBlockContext from '../../FieldBlock/FieldBlockContext'\nimport classnames from 'classnames'\nimport FieldBlock from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport {\n FieldProps,\n FieldHelpProps,\n AllJSONSchemaVersions,\n CustomErrorMessages,\n FieldBlockWidth,\n} from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport { ButtonProps, ButtonSize } from '../../../../components/Button'\nimport { clamp } from '../../../../components/slider/SliderHelpers'\nimport useErrorMessage from '../../hooks/useErrorMessage'\nimport useTranslation from '../../hooks/useTranslation'\n\ninterface ErrorMessages extends CustomErrorMessages {\n required?: string\n schema?: string\n minimum?: string\n maximum?: string\n exclusiveMinimum?: string\n exclusiveMaximum?: string\n multipleOf?: string\n}\n\nexport type Props = FieldHelpProps &\n FieldProps<number, undefined, ErrorMessages> & {\n inputClassName?: string\n currency?: InputMaskedProps['as_currency']\n currencyDisplay?: 'code' | 'symbol' | 'narrowSymbol' | 'name'\n percent?: InputMaskedProps['as_percent']\n mask?: InputMaskedProps['mask']\n step?: number\n // Formatting\n decimalLimit?: number\n prefix?: string\n suffix?: string\n // Validation\n minimum?: number // aka greater than or equal to\n maximum?: number // aka less than or equal to\n exclusiveMinimum?: number // aka greater than\n exclusiveMaximum?: number // aka less than\n multipleOf?: number\n // Styling\n size?: InputSize\n width?: FieldBlockWidth\n align?: InputAlign\n showStepControls?: boolean\n }\n\nfunction NumberComponent(props: Props) {\n const fieldBlockContext = useContext(FieldBlockContext)\n const sharedContext = useContext(SharedContext)\n const translations = useTranslation()\n\n const {\n currency,\n currencyDisplay,\n percent,\n mask,\n step = 1,\n decimalLimit = 12,\n prefix,\n suffix,\n showStepControls,\n } = props\n\n const errorMessages = useErrorMessage(props.path, props.errorMessages, {\n required: translations.Field.errorRequired,\n minimum: translations.NumberField.errorMinimum,\n maximum: translations.NumberField.errorMaximum,\n exclusiveMinimum: translations.NumberField.errorExclusiveMinimum,\n exclusiveMaximum: translations.NumberField.errorExclusiveMaximum,\n multipleOf: translations.NumberField.errorMultipleOf,\n })\n\n const schema = useMemo<AllJSONSchemaVersions>(\n () =>\n props.schema ?? {\n type: 'number',\n minimum: props.minimum,\n maximum: props.maximum,\n exclusiveMinimum: props.exclusiveMinimum,\n exclusiveMaximum: props.exclusiveMaximum,\n multipleOf: props.multipleOf,\n },\n [\n props.schema,\n props.minimum,\n props.maximum,\n props.exclusiveMinimum,\n props.exclusiveMaximum,\n props.multipleOf,\n ]\n )\n\n const toInput = useCallback((external: number | undefined) => {\n if (external === undefined) {\n return ''\n }\n return external\n }, [])\n const fromInput = useCallback(\n ({ value, numberValue }: { value: string; numberValue: number }) => {\n if (value === '') {\n return props.emptyValue\n }\n return numberValue\n },\n [props.emptyValue]\n )\n const transformValue = useCallback(\n (value: number, currentValue: number) => {\n if (\n value > Number.MAX_SAFE_INTEGER ||\n value < Number.MIN_SAFE_INTEGER\n ) {\n return currentValue\n }\n\n return value\n },\n []\n )\n\n const maskProps: Partial<InputMaskedProps> = useMemo(() => {\n const mask_options = { prefix, suffix, decimalLimit }\n\n if (currency) {\n return {\n as_currency: currency,\n mask_options,\n currency_mask: {\n currencyDisplay,\n },\n }\n }\n\n if (percent) {\n return {\n as_percent: percent,\n mask_options,\n }\n }\n\n // Custom mask based on props\n return {\n as_number: true,\n mask,\n number_mask: {\n ...mask_options,\n },\n }\n }, [\n currency,\n currencyDisplay,\n decimalLimit,\n mask,\n percent,\n prefix,\n suffix,\n ])\n\n const preparedProps: Props = {\n valueType: 'number',\n ...props,\n errorMessages,\n schema,\n toInput,\n fromInput,\n transformValue,\n width:\n props.width ??\n (fieldBlockContext?.composition ? 'stretch' : 'medium'),\n }\n\n const {\n id,\n name,\n className,\n inputClassName,\n autoComplete,\n layout,\n placeholder,\n label,\n labelDescription,\n value,\n minimum = Number.MIN_SAFE_INTEGER,\n maximum = Number.MAX_SAFE_INTEGER,\n disabled,\n htmlAttributes,\n info,\n warning,\n error,\n hasError,\n help,\n size,\n width,\n align,\n handleFocus,\n handleBlur,\n handleChange,\n } = useFieldProps(preparedProps)\n\n const onKeyDownHandler = useCallback(\n ({ key, event }) => {\n if (!showStepControls) {\n return\n }\n\n let numberValue = null\n\n switch (key) {\n case 'ArrowUp':\n numberValue = clamp((value as number) + step, minimum, maximum)\n break\n case 'ArrowDown':\n numberValue = clamp((value as number) - step, minimum, maximum)\n break\n }\n\n if (numberValue !== null) {\n event.persist()\n event.preventDefault()\n handleChange({ numberValue })\n }\n },\n [handleChange, maximum, minimum, showStepControls, step, value]\n )\n\n const fieldBlockProps = {\n className: classnames(\n 'dnb-forms-field-number',\n 'dnb-input__border--tokens', // Used by \"dnb-input__border\"\n className\n ),\n contentClassName: classnames(\n 'dnb-forms-field-number__contents',\n showStepControls && 'dnb-forms-field-number__contents--has-controls',\n hasError && 'dnb-input__status--error', // Also used by \"dnb-input__border\"\n disabled && 'dnb-input--disabled' // Also used by \"dnb-input__border\"\n ),\n forId: id,\n layout,\n label,\n labelDescription,\n info,\n warning,\n error,\n disabled,\n width:\n width === 'stretch' || fieldBlockContext?.composition\n ? width\n : undefined,\n contentWidth: width !== false ? width : undefined,\n ...pickSpacingProps(props),\n }\n\n const increaseProps: ButtonProps = showStepControls && {\n 'aria-hidden': true,\n className: 'dnb-button--control-after',\n variant: 'secondary',\n icon: 'add',\n size: (size || 'small') as ButtonSize,\n tabIndex: -1,\n disabled: disabled || value >= maximum,\n onClick: () => {\n handleChange({\n numberValue: clamp((value as number) + step, minimum, maximum),\n })\n },\n title: sharedContext?.translation.Slider.addTitle?.replace(\n '%s',\n String(value + step)\n ),\n }\n\n const decreaseProps: ButtonProps = showStepControls && {\n ...increaseProps,\n className: 'dnb-button--control-before',\n icon: 'subtract',\n size: (size || 'small') as ButtonSize,\n disabled: disabled || value <= minimum,\n onClick: () => {\n handleChange({\n numberValue: clamp((value as number) - step, minimum, maximum),\n })\n },\n title: sharedContext?.translation.Slider.subtractTitle?.replace(\n '%s',\n String(value - step)\n ),\n }\n\n const ariaParams = showStepControls && {\n role: 'spinbutton',\n 'aria-valuemin': String(minimum),\n 'aria-valuemax': String(maximum),\n 'aria-valuenow': String(value), // without it, VO will read an invalid value\n 'aria-valuetext': String(value), // without it, VO will read %\n }\n\n const inputProps = {\n id,\n name,\n autoComplete,\n className: classnames(\n 'dnb-forms-field-number__input',\n `dnb-input--${size}`,\n inputClassName\n ),\n step: showStepControls ? step : undefined,\n placeholder,\n value,\n align: showStepControls ? 'center' : align,\n ...maskProps,\n onKeyDown: onKeyDownHandler,\n onFocus: handleFocus,\n onBlur: handleBlur,\n onChange: handleChange,\n disabled,\n ...htmlAttributes,\n status: hasError ? 'error' : undefined,\n stretch: Boolean(\n width !== undefined || fieldBlockContext?.composition\n ),\n suffix:\n help && !showStepControls ? (\n <HelpButton title={help.title}>{help.content}</HelpButton>\n ) : undefined,\n ...ariaParams,\n }\n\n if (showStepControls) {\n return (\n <FieldBlock {...fieldBlockProps} asFieldset={false}>\n <span className=\"dnb-input__border dnb-input__border--root\">\n {<Button {...decreaseProps} />}\n <InputMasked {...inputProps} />\n {<Button {...increaseProps} />}\n </span>\n {help && (\n <HelpButton left=\"x-small\" title={help.title}>\n {help.content}\n </HelpButton>\n )}\n </FieldBlock>\n )\n }\n\n return (\n <FieldBlock {...fieldBlockProps} asFieldset={false}>\n <InputMasked {...inputProps} />\n </FieldBlock>\n )\n}\n\nNumberComponent._supportsSpacingProps = true\nexport default NumberComponent\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,EAAEC,WAAW,QAAQ,OAAO;AAC/D,SAASC,WAAW,EAAEC,UAAU,EAAEC,MAAM,QAAQ,wBAAwB;AAGxE,OAAOC,aAAa,MAAM,4BAA4B;AACtD,OAAOC,iBAAiB,MAAM,oCAAoC;AAClE,OAAOC,UAAU,MAAM,YAAY;AACnC,OAAOC,UAAU,MAAM,kBAAkB;AACzC,SAASC,aAAa,QAAQ,aAAa;AAQ3C,SAASC,gBAAgB,QAAQ,mCAAmC;AAEpE,SAASC,KAAK,QAAQ,6CAA6C;AACnE,OAAOC,eAAe,MAAM,6BAA6B;AACzD,OAAOC,cAAc,MAAM,4BAA4B;AAqCvD,SAASC,eAAeA,CAACC,KAAY,EAAE;EAAA,IAAAC,YAAA,EAAAC,qBAAA,EAAAC,sBAAA;EACrC,MAAMC,iBAAiB,GAAGpB,UAAU,CAACO,iBAAiB,CAAC;EACvD,MAAMc,aAAa,GAAGrB,UAAU,CAACM,aAAa,CAAC;EAC/C,MAAMgB,YAAY,GAAGR,cAAc,CAAC,CAAC;EAErC,MAAM;IACJS,QAAQ;IACRC,eAAe;IACfC,OAAO;IACPC,IAAI;IACJC,IAAI,GAAG,CAAC;IACRC,YAAY,GAAG,EAAE;IACjBC,MAAM;IACNC,MAAM;IACNC;EACF,CAAC,GAAGf,KAAK;EAET,MAAMgB,aAAa,GAAGnB,eAAe,CAACG,KAAK,CAACiB,IAAI,EAAEjB,KAAK,CAACgB,aAAa,EAAE;IACrEE,QAAQ,EAAEZ,YAAY,CAACa,KAAK,CAACC,aAAa;IAC1CC,OAAO,EAAEf,YAAY,CAACgB,WAAW,CAACC,YAAY;IAC9CC,OAAO,EAAElB,YAAY,CAACgB,WAAW,CAACG,YAAY;IAC9CC,gBAAgB,EAAEpB,YAAY,CAACgB,WAAW,CAACK,qBAAqB;IAChEC,gBAAgB,EAAEtB,YAAY,CAACgB,WAAW,CAACO,qBAAqB;IAChEC,UAAU,EAAExB,YAAY,CAACgB,WAAW,CAACS;EACvC,CAAC,CAAC;EAEF,MAAMC,MAAM,GAAG/C,OAAO,CACpB;IAAA,IAAAgD,aAAA;IAAA,QAAAA,aAAA,GACEjC,KAAK,CAACgC,MAAM,cAAAC,aAAA,cAAAA,aAAA,GAAI;MACdC,IAAI,EAAE,QAAQ;MACdb,OAAO,EAAErB,KAAK,CAACqB,OAAO;MACtBG,OAAO,EAAExB,KAAK,CAACwB,OAAO;MACtBE,gBAAgB,EAAE1B,KAAK,CAAC0B,gBAAgB;MACxCE,gBAAgB,EAAE5B,KAAK,CAAC4B,gBAAgB;MACxCE,UAAU,EAAE9B,KAAK,CAAC8B;IACpB,CAAC;EAAA,GACH,CACE9B,KAAK,CAACgC,MAAM,EACZhC,KAAK,CAACqB,OAAO,EACbrB,KAAK,CAACwB,OAAO,EACbxB,KAAK,CAAC0B,gBAAgB,EACtB1B,KAAK,CAAC4B,gBAAgB,EACtB5B,KAAK,CAAC8B,UAAU,CAEpB,CAAC;EAED,MAAMK,OAAO,GAAGjD,WAAW,CAAEkD,QAA4B,IAAK;IAC5D,IAAIA,QAAQ,KAAKC,SAAS,EAAE;MAC1B,OAAO,EAAE;IACX;IACA,OAAOD,QAAQ;EACjB,CAAC,EAAE,EAAE,CAAC;EACN,MAAME,SAAS,GAAGpD,WAAW,CAC3BqD,IAAA,IAAoE;IAAA,IAAnE;MAAEC,KAAK;MAAEC;IAAoD,CAAC,GAAAF,IAAA;IAC7D,IAAIC,KAAK,KAAK,EAAE,EAAE;MAChB,OAAOxC,KAAK,CAAC0C,UAAU;IACzB;IACA,OAAOD,WAAW;EACpB,CAAC,EACD,CAACzC,KAAK,CAAC0C,UAAU,CACnB,CAAC;EACD,MAAMC,cAAc,GAAGzD,WAAW,CAChC,CAACsD,KAAa,EAAEI,YAAoB,KAAK;IACvC,IACEJ,KAAK,GAAGK,MAAM,CAACC,gBAAgB,IAC/BN,KAAK,GAAGK,MAAM,CAACE,gBAAgB,EAC/B;MACA,OAAOH,YAAY;IACrB;IAEA,OAAOJ,KAAK;EACd,CAAC,EACD,EACF,CAAC;EAED,MAAMQ,SAAoC,GAAG/D,OAAO,CAAC,MAAM;IACzD,MAAMgE,YAAY,GAAG;MAAEpC,MAAM;MAAEC,MAAM;MAAEF;IAAa,CAAC;IAErD,IAAIL,QAAQ,EAAE;MACZ,OAAO;QACL2C,WAAW,EAAE3C,QAAQ;QACrB0C,YAAY;QACZE,aAAa,EAAE;UACb3C;QACF;MACF,CAAC;IACH;IAEA,IAAIC,OAAO,EAAE;MACX,OAAO;QACL2C,UAAU,EAAE3C,OAAO;QACnBwC;MACF,CAAC;IACH;IAGA,OAAO;MACLI,SAAS,EAAE,IAAI;MACf3C,IAAI;MACJ4C,WAAW,EAAAC,aAAA,KACNN,YAAY;IAEnB,CAAC;EACH,CAAC,EAAE,CACD1C,QAAQ,EACRC,eAAe,EACfI,YAAY,EACZF,IAAI,EACJD,OAAO,EACPI,MAAM,EACNC,MAAM,CACP,CAAC;EAEF,MAAM0C,aAAoB,GAAAD,aAAA,CAAAA,aAAA;IACxBE,SAAS,EAAE;EAAQ,GAChBzD,KAAK;IACRgB,aAAa;IACbgB,MAAM;IACNG,OAAO;IACPG,SAAS;IACTK,cAAc;IACde,KAAK,GAAAzD,YAAA,GACHD,KAAK,CAAC0D,KAAK,cAAAzD,YAAA,cAAAA,YAAA,GACVG,iBAAiB,aAAjBA,iBAAiB,eAAjBA,iBAAiB,CAAEuD,WAAW,GAAG,SAAS,GAAG;EAAS,EAC1D;EAED,MAAM;IACJC,EAAE;IACFC,IAAI;IACJC,SAAS;IACTC,cAAc;IACdC,YAAY;IACZC,MAAM;IACNC,WAAW;IACXC,KAAK;IACLC,gBAAgB;IAChB5B,KAAK;IACLnB,OAAO,GAAGwB,MAAM,CAACE,gBAAgB;IACjCvB,OAAO,GAAGqB,MAAM,CAACC,gBAAgB;IACjCuB,QAAQ;IACRC,cAAc;IACdC,IAAI;IACJC,OAAO;IACPC,KAAK;IACLC,QAAQ;IACRC,IAAI;IACJC,IAAI;IACJlB,KAAK;IACLmB,KAAK;IACLC,WAAW;IACXC,UAAU;IACVC;EACF,CAAC,GAAGtF,aAAa,CAAC8D,aAAa,CAAC;EAEhC,MAAMyB,gBAAgB,GAAG/F,WAAW,CAClCgG,KAAA,IAAoB;IAAA,IAAnB;MAAEC,GAAG;MAAEC;IAAM,CAAC,GAAAF,KAAA;IACb,IAAI,CAACnE,gBAAgB,EAAE;MACrB;IACF;IAEA,IAAI0B,WAAW,GAAG,IAAI;IAEtB,QAAQ0C,GAAG;MACT,KAAK,SAAS;QACZ1C,WAAW,GAAG7C,KAAK,CAAE4C,KAAK,GAAc7B,IAAI,EAAEU,OAAO,EAAEG,OAAO,CAAC;QAC/D;MACF,KAAK,WAAW;QACdiB,WAAW,GAAG7C,KAAK,CAAE4C,KAAK,GAAc7B,IAAI,EAAEU,OAAO,EAAEG,OAAO,CAAC;QAC/D;IACJ;IAEA,IAAIiB,WAAW,KAAK,IAAI,EAAE;MACxB2C,KAAK,CAACC,OAAO,CAAC,CAAC;MACfD,KAAK,CAACE,cAAc,CAAC,CAAC;MACtBN,YAAY,CAAC;QAAEvC;MAAY,CAAC,CAAC;IAC/B;EACF,CAAC,EACD,CAACuC,YAAY,EAAExD,OAAO,EAAEH,OAAO,EAAEN,gBAAgB,EAAEJ,IAAI,EAAE6B,KAAK,CAChE,CAAC;EAED,MAAM+C,eAAe,GAAAhC,aAAA;IACnBO,SAAS,EAAEtE,UAAU,qDAGnBsE,SACF,CAAC;IACD0B,gBAAgB,EAAEhG,UAAU,CAC1B,kCAAkC,EAClCuB,gBAAgB,IAAI,gDAAgD,EACpE2D,QAAQ,IAAI,0BAA0B,EACtCL,QAAQ,IAAI,qBACd,CAAC;IACDoB,KAAK,EAAE7B,EAAE;IACTK,MAAM;IACNE,KAAK;IACLC,gBAAgB;IAChBG,IAAI;IACJC,OAAO;IACPC,KAAK;IACLJ,QAAQ;IACRX,KAAK,EACHA,KAAK,KAAK,SAAS,IAAItD,iBAAiB,aAAjBA,iBAAiB,eAAjBA,iBAAiB,CAAEuD,WAAW,GACjDD,KAAK,GACLrB,SAAS;IACfqD,YAAY,EAAEhC,KAAK,KAAK,KAAK,GAAGA,KAAK,GAAGrB;EAAS,GAC9C1C,gBAAgB,CAACK,KAAK,CAAC,CAC3B;EAED,MAAM2F,aAA0B,GAAG5E,gBAAgB,IAAI;IACrD,aAAa,EAAE,IAAI;IACnB+C,SAAS,EAAE,2BAA2B;IACtC8B,OAAO,EAAE,WAAW;IACpBC,IAAI,EAAE,KAAK;IACXjB,IAAI,EAAGA,IAAI,IAAI,OAAsB;IACrCkB,QAAQ,EAAE,CAAC,CAAC;IACZzB,QAAQ,EAAEA,QAAQ,IAAI7B,KAAK,IAAIhB,OAAO;IACtCuE,OAAO,EAAEA,CAAA,KAAM;MACbf,YAAY,CAAC;QACXvC,WAAW,EAAE7C,KAAK,CAAE4C,KAAK,GAAc7B,IAAI,EAAEU,OAAO,EAAEG,OAAO;MAC/D,CAAC,CAAC;IACJ,CAAC;IACDwE,KAAK,EAAE3F,aAAa,aAAbA,aAAa,wBAAAH,qBAAA,GAAbG,aAAa,CAAE4F,WAAW,CAACC,MAAM,CAACC,QAAQ,cAAAjG,qBAAA,uBAA1CA,qBAAA,CAA4CkG,OAAO,CACxD,IAAI,EACJC,MAAM,CAAC7D,KAAK,GAAG7B,IAAI,CACrB;EACF,CAAC;EAED,MAAM2F,aAA0B,GAAGvF,gBAAgB,IAAAwC,aAAA,CAAAA,aAAA,KAC9CoC,aAAa;IAChB7B,SAAS,EAAE,4BAA4B;IACvC+B,IAAI,EAAE,UAAU;IAChBjB,IAAI,EAAGA,IAAI,IAAI,OAAsB;IACrCP,QAAQ,EAAEA,QAAQ,IAAI7B,KAAK,IAAInB,OAAO;IACtC0E,OAAO,EAAEA,CAAA,KAAM;MACbf,YAAY,CAAC;QACXvC,WAAW,EAAE7C,KAAK,CAAE4C,KAAK,GAAc7B,IAAI,EAAEU,OAAO,EAAEG,OAAO;MAC/D,CAAC,CAAC;IACJ,CAAC;IACDwE,KAAK,EAAE3F,aAAa,aAAbA,aAAa,wBAAAF,sBAAA,GAAbE,aAAa,CAAE4F,WAAW,CAACC,MAAM,CAACK,aAAa,cAAApG,sBAAA,uBAA/CA,sBAAA,CAAiDiG,OAAO,CAC7D,IAAI,EACJC,MAAM,CAAC7D,KAAK,GAAG7B,IAAI,CACrB;EAAC,EACF;EAED,MAAM6F,UAAU,GAAGzF,gBAAgB,IAAI;IACrC0F,IAAI,EAAE,YAAY;IAClB,eAAe,EAAEJ,MAAM,CAAChF,OAAO,CAAC;IAChC,eAAe,EAAEgF,MAAM,CAAC7E,OAAO,CAAC;IAChC,eAAe,EAAE6E,MAAM,CAAC7D,KAAK,CAAC;IAC9B,gBAAgB,EAAE6D,MAAM,CAAC7D,KAAK;EAChC,CAAC;EAED,MAAMkE,UAAU,GAAAnD,aAAA,CAAAA,aAAA,CAAAA,aAAA;IACdK,EAAE;IACFC,IAAI;IACJG,YAAY;IACZF,SAAS,EAAEtE,UAAU,6CAELoF,IAAK,IACnBb,cACF,CAAC;IACDpD,IAAI,EAAEI,gBAAgB,GAAGJ,IAAI,GAAG0B,SAAS;IACzC6B,WAAW;IACX1B,KAAK;IACLqC,KAAK,EAAE9D,gBAAgB,GAAG,QAAQ,GAAG8D;EAAK,GACvC7B,SAAS;IACZ2D,SAAS,EAAE1B,gBAAgB;IAC3B2B,OAAO,EAAE9B,WAAW;IACpB+B,MAAM,EAAE9B,UAAU;IAClB+B,QAAQ,EAAE9B,YAAY;IACtBX;EAAQ,GACLC,cAAc;IACjByC,MAAM,EAAErC,QAAQ,GAAG,OAAO,GAAGrC,SAAS;IACtC2E,OAAO,EAAEC,OAAO,CACdvD,KAAK,KAAKrB,SAAS,KAAIjC,iBAAiB,aAAjBA,iBAAiB,uBAAjBA,iBAAiB,CAAEuD,WAAW,CACvD,CAAC;IACD7C,MAAM,EACJ6D,IAAI,IAAI,CAAC5D,gBAAgB,GACvBhC,KAAA,CAAAmI,aAAA,CAAC9H,UAAU;MAAC4G,KAAK,EAAErB,IAAI,CAACqB;IAAM,GAAErB,IAAI,CAACwC,OAAoB,CAAC,GACxD9E;EAAS,GACZmE,UAAU,CACd;EAED,IAAIzF,gBAAgB,EAAE;IACpB,OACEhC,KAAA,CAAAmI,aAAA,CAACzH,UAAU,EAAA2H,QAAA,KAAK7B,eAAe;MAAE8B,UAAU,EAAE;IAAM,IACjDtI,KAAA,CAAAmI,aAAA;MAAMpD,SAAS,EAAC;IAA2C,GACxD/E,KAAA,CAAAmI,aAAA,CAAC7H,MAAM,EAAKiH,aAAgB,CAAC,EAC9BvH,KAAA,CAAAmI,aAAA,CAAC/H,WAAW,EAAKuH,UAAa,CAAC,EAC9B3H,KAAA,CAAAmI,aAAA,CAAC7H,MAAM,EAAKsG,aAAgB,CACzB,CAAC,EACNhB,IAAI,IACH5F,KAAA,CAAAmI,aAAA,CAAC9H,UAAU;MAACkI,IAAI,EAAC,SAAS;MAACtB,KAAK,EAAErB,IAAI,CAACqB;IAAM,GAC1CrB,IAAI,CAACwC,OACI,CAEJ,CAAC;EAEjB;EAEA,OACEpI,KAAA,CAAAmI,aAAA,CAACzH,UAAU,EAAA2H,QAAA,KAAK7B,eAAe;IAAE8B,UAAU,EAAE;EAAM,IACjDtI,KAAA,CAAAmI,aAAA,CAAC/H,WAAW,EAAKuH,UAAa,CACpB,CAAC;AAEjB;AAEA3G,eAAe,CAACwH,qBAAqB,GAAG,IAAI;AAC5C,eAAexH,eAAe"}
1
+ {"version":3,"file":"Number.js","names":["React","useContext","useMemo","useCallback","InputMasked","HelpButton","Button","SharedContext","FieldBlockContext","classnames","FieldBlock","useFieldProps","pickSpacingProps","clamp","useErrorMessage","useTranslation","NumberComponent","props","_props$width","_sharedContext$transl","_sharedContext$transl2","fieldBlockContext","sharedContext","translations","currency","currencyDisplay","percent","mask","step","decimalLimit","prefix","suffix","showStepControls","errorMessages","path","required","Field","errorRequired","minimum","NumberField","errorMinimum","maximum","errorMaximum","exclusiveMinimum","errorExclusiveMinimum","exclusiveMaximum","errorExclusiveMaximum","multipleOf","errorMultipleOf","schema","_props$schema","type","toInput","external","undefined","fromInput","_ref","value","numberValue","emptyValue","transformValue","currentValue","Number","MAX_SAFE_INTEGER","MIN_SAFE_INTEGER","maskProps","mask_options","as_currency","currency_mask","as_percent","as_number","number_mask","_objectSpread","preparedProps","valueType","width","composition","id","name","className","inputClassName","autoComplete","layout","placeholder","label","labelDescription","startWith","disabled","htmlAttributes","info","warning","error","hasError","help","size","align","handleFocus","handleBlur","handleChange","onKeyDownHandler","_ref2","key","event","persist","preventDefault","fieldBlockProps","contentClassName","forId","contentWidth","increaseClickHandler","increaseProps","variant","icon","tabIndex","onClick","title","translation","Slider","addTitle","replace","String","decreaseClickHandler","decreaseProps","subtractTitle","ariaParams","role","inputProps","onKeyDown","onFocus","onBlur","onChange","status","stretch","Boolean","createElement","content","_extends","asFieldset","left","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Number/Number.tsx"],"sourcesContent":["import React, { useContext, useMemo, useCallback } from 'react'\nimport { InputMasked, HelpButton, Button } from '../../../../components'\nimport { InputMaskedProps } from '../../../../components/InputMasked'\nimport type { InputAlign, InputSize } from '../../../../components/Input'\nimport SharedContext from '../../../../shared/Context'\nimport FieldBlockContext from '../../FieldBlock/FieldBlockContext'\nimport classnames from 'classnames'\nimport FieldBlock from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport {\n FieldProps,\n FieldHelpProps,\n AllJSONSchemaVersions,\n CustomErrorMessages,\n FieldBlockWidth,\n} from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport { ButtonProps, ButtonSize } from '../../../../components/Button'\nimport { clamp } from '../../../../components/slider/SliderHelpers'\nimport useErrorMessage from '../../hooks/useErrorMessage'\nimport useTranslation from '../../hooks/useTranslation'\n\ninterface ErrorMessages extends CustomErrorMessages {\n required?: string\n schema?: string\n minimum?: string\n maximum?: string\n exclusiveMinimum?: string\n exclusiveMaximum?: string\n multipleOf?: string\n}\n\nexport type Props = FieldHelpProps &\n FieldProps<number, undefined, ErrorMessages> & {\n inputClassName?: string\n currency?: InputMaskedProps['as_currency']\n currencyDisplay?: 'code' | 'symbol' | 'narrowSymbol' | 'name'\n percent?: InputMaskedProps['as_percent']\n mask?: InputMaskedProps['mask']\n step?: number\n startWith?: number\n // Formatting\n decimalLimit?: number\n prefix?: string\n suffix?: string\n // Validation\n minimum?: number // aka greater than or equal to\n maximum?: number // aka less than or equal to\n exclusiveMinimum?: number // aka greater than\n exclusiveMaximum?: number // aka less than\n multipleOf?: number\n // Styling\n size?: InputSize\n width?: FieldBlockWidth\n align?: InputAlign\n showStepControls?: boolean\n }\n\nfunction NumberComponent(props: Props) {\n const fieldBlockContext = useContext(FieldBlockContext)\n const sharedContext = useContext(SharedContext)\n const translations = useTranslation()\n\n const {\n currency,\n currencyDisplay,\n percent,\n mask,\n step = 1,\n decimalLimit = 12,\n prefix,\n suffix,\n showStepControls,\n } = props\n\n const errorMessages = useErrorMessage(props.path, props.errorMessages, {\n required: translations.Field.errorRequired,\n minimum: translations.NumberField.errorMinimum,\n maximum: translations.NumberField.errorMaximum,\n exclusiveMinimum: translations.NumberField.errorExclusiveMinimum,\n exclusiveMaximum: translations.NumberField.errorExclusiveMaximum,\n multipleOf: translations.NumberField.errorMultipleOf,\n })\n\n const schema = useMemo<AllJSONSchemaVersions>(\n () =>\n props.schema ?? {\n type: 'number',\n minimum: props.minimum,\n maximum: props.maximum,\n exclusiveMinimum: props.exclusiveMinimum,\n exclusiveMaximum: props.exclusiveMaximum,\n multipleOf: props.multipleOf,\n },\n [\n props.schema,\n props.minimum,\n props.maximum,\n props.exclusiveMinimum,\n props.exclusiveMaximum,\n props.multipleOf,\n ]\n )\n\n const toInput = useCallback((external: number | undefined) => {\n if (external === undefined) {\n return null\n }\n return external\n }, [])\n const fromInput = useCallback(\n ({ value, numberValue }: { value: string; numberValue: number }) => {\n if (value === '') {\n return props.emptyValue\n }\n return numberValue\n },\n [props.emptyValue]\n )\n const transformValue = useCallback(\n (value: number, currentValue: number) => {\n if (\n value > Number.MAX_SAFE_INTEGER ||\n value < Number.MIN_SAFE_INTEGER\n ) {\n return currentValue\n }\n\n return value\n },\n []\n )\n\n const maskProps: Partial<InputMaskedProps> = useMemo(() => {\n const mask_options = { prefix, suffix, decimalLimit }\n\n if (currency) {\n return {\n as_currency: currency,\n mask_options,\n currency_mask: {\n currencyDisplay,\n },\n }\n }\n\n if (percent) {\n return {\n as_percent: percent,\n mask_options,\n }\n }\n\n // Custom mask based on props\n return {\n as_number: true,\n mask,\n number_mask: {\n ...mask_options,\n },\n }\n }, [\n currency,\n currencyDisplay,\n decimalLimit,\n mask,\n percent,\n prefix,\n suffix,\n ])\n\n const preparedProps: Props = {\n valueType: 'number',\n ...props,\n errorMessages,\n schema,\n toInput,\n fromInput,\n transformValue,\n width:\n props.width ??\n (fieldBlockContext?.composition ? 'stretch' : 'medium'),\n }\n\n const {\n id,\n name,\n className,\n inputClassName,\n autoComplete,\n layout,\n placeholder,\n label,\n labelDescription,\n value,\n startWith = null,\n minimum = Number.MIN_SAFE_INTEGER,\n maximum = Number.MAX_SAFE_INTEGER,\n disabled,\n htmlAttributes,\n info,\n warning,\n error,\n hasError,\n help,\n size,\n width,\n align,\n handleFocus,\n handleBlur,\n handleChange,\n } = useFieldProps(preparedProps)\n\n const onKeyDownHandler = useCallback(\n ({ key, event }) => {\n if (!showStepControls) {\n return\n }\n\n let numberValue = null\n\n switch (key) {\n case 'ArrowUp':\n numberValue = clamp(\n (value ?? startWith) + step,\n minimum,\n maximum\n )\n break\n case 'ArrowDown':\n numberValue = clamp(\n (value ?? startWith) - step,\n minimum,\n maximum\n )\n break\n }\n\n if (numberValue !== null) {\n event.persist()\n event.preventDefault()\n handleChange({ numberValue })\n }\n },\n [\n handleChange,\n maximum,\n minimum,\n showStepControls,\n startWith,\n step,\n value,\n ]\n )\n\n const fieldBlockProps = {\n className: classnames(\n 'dnb-forms-field-number',\n 'dnb-input__border--tokens', // Used by \"dnb-input__border\"\n className\n ),\n contentClassName: classnames(\n 'dnb-forms-field-number__contents',\n showStepControls && 'dnb-forms-field-number__contents--has-controls',\n hasError && 'dnb-input__status--error', // Also used by \"dnb-input__border\"\n disabled && 'dnb-input--disabled' // Also used by \"dnb-input__border\"\n ),\n forId: id,\n layout,\n label,\n labelDescription,\n info,\n warning,\n error,\n disabled,\n width:\n (width === 'stretch' || fieldBlockContext?.composition) &&\n !showStepControls\n ? width\n : undefined,\n contentWidth: width !== false ? width : undefined,\n ...pickSpacingProps(props),\n }\n\n const increaseClickHandler = useCallback(() => {\n handleChange({\n numberValue: clamp((value ?? startWith) + step, minimum, maximum),\n })\n }, [handleChange, maximum, minimum, startWith, step, value])\n\n const increaseProps: ButtonProps = showStepControls && {\n 'aria-hidden': true,\n className: 'dnb-button--control-after',\n variant: 'secondary',\n icon: 'add',\n size: (size || 'small') as ButtonSize,\n tabIndex: -1,\n disabled: disabled || value >= maximum,\n onClick: increaseClickHandler,\n title: sharedContext?.translation.Slider.addTitle?.replace(\n '%s',\n String(value + step)\n ),\n }\n\n const decreaseClickHandler = useCallback(() => {\n handleChange({\n numberValue: clamp((value ?? startWith) - step, minimum, maximum),\n })\n }, [handleChange, maximum, minimum, startWith, step, value])\n\n const decreaseProps: ButtonProps = showStepControls && {\n ...increaseProps,\n className: 'dnb-button--control-before',\n icon: 'subtract',\n size: (size || 'small') as ButtonSize,\n disabled: disabled || value <= minimum,\n onClick: decreaseClickHandler,\n title: sharedContext?.translation.Slider.subtractTitle?.replace(\n '%s',\n String(value - step)\n ),\n }\n\n const ariaParams = showStepControls && {\n role: 'spinbutton',\n 'aria-valuemin': String(minimum),\n 'aria-valuemax': String(maximum),\n 'aria-valuenow': String(value), // without it, VO will read an invalid value\n 'aria-valuetext': String(value), // without it, VO will read %\n }\n\n const inputProps = {\n id,\n name,\n autoComplete,\n className: classnames(\n 'dnb-forms-field-number__input',\n `dnb-input--${size}`,\n inputClassName\n ),\n step: showStepControls ? step : undefined,\n placeholder,\n value,\n align: showStepControls ? 'center' : align,\n ...maskProps,\n onKeyDown: onKeyDownHandler,\n onFocus: handleFocus,\n onBlur: handleBlur,\n onChange: handleChange,\n disabled,\n ...htmlAttributes,\n status: hasError ? 'error' : undefined,\n stretch: Boolean(\n width !== undefined || fieldBlockContext?.composition\n ),\n suffix:\n help && !showStepControls ? (\n <HelpButton title={help.title}>{help.content}</HelpButton>\n ) : undefined,\n ...ariaParams,\n }\n\n if (showStepControls) {\n return (\n <FieldBlock {...fieldBlockProps} asFieldset={false}>\n <span className=\"dnb-input__border dnb-input__border--root\">\n {<Button {...decreaseProps} />}\n <InputMasked {...inputProps} />\n {<Button {...increaseProps} />}\n </span>\n {help && (\n <HelpButton left=\"x-small\" title={help.title}>\n {help.content}\n </HelpButton>\n )}\n </FieldBlock>\n )\n }\n\n return (\n <FieldBlock {...fieldBlockProps} asFieldset={false}>\n <InputMasked {...inputProps} />\n </FieldBlock>\n )\n}\n\nNumberComponent._supportsSpacingProps = true\nexport default NumberComponent\n"],"mappings":"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"}
@@ -72,7 +72,12 @@ export const numberProperties = {
72
72
  status: 'optional'
73
73
  },
74
74
  step: {
75
- doc: 'Determines step granularity when in/decreasing value input through step controls buttons or arrow keys.',
75
+ doc: 'Determines step granularity when in/decreasing value input through step controls buttons or arrow keys. Defaults to 1.',
76
+ type: 'number',
77
+ status: 'optional'
78
+ },
79
+ startWith: {
80
+ doc: 'When no `value` or `defaultValue` is given, start with a given value when in/decreasing value input through step controls buttons or arrow keys. Defaults to `null`.',
76
81
  type: 'number',
77
82
  status: 'optional'
78
83
  },
@@ -1 +1 @@
1
- {"version":3,"file":"NumberDocs.js","names":["inputProperties","numberProperties","decimalLimit","doc","type","status","percent","currency","minimum","maximum","exclusiveMinimum","exclusiveMaximum","multipleOf","width","size","align","help","autoComplete","prefix","suffix","step","showStepControls"],"sources":["../../../../../../src/extensions/forms/Field/Number/NumberDocs.ts"],"sourcesContent":["import { inputProperties } from '../../../../components/input/InputDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const numberProperties: PropertiesTableProps = {\n decimalLimit: {\n doc: 'Max number of decimals. Values with more decimals will be rounded. Defaults to `12`.',\n type: 'number',\n status: 'optional',\n },\n percent: {\n doc: 'Format a number as percentage.',\n type: 'boolean',\n status: 'optional',\n },\n currency: {\n doc: 'Currency code (ISO 4217) or `true` to use the default `NOK`. Uses two decimals by default.',\n type: ['boolean', 'string'],\n status: 'optional',\n },\n minimum: {\n doc: 'Validation for inclusive minimum number value (greater than or equal). Defaults to `Number.MIN_SAFE_INTEGER`.',\n type: 'number',\n status: 'optional',\n },\n maximum: {\n doc: 'Validation for inclusive maximum number value (less than or equal). Defaults to `Number.MAX_SAFE_INTEGER`.',\n type: 'number',\n status: 'optional',\n },\n exclusiveMinimum: {\n doc: 'Validation for exclusive minimum number value (greater than).',\n type: 'number',\n status: 'optional',\n },\n exclusiveMaximum: {\n doc: 'Validation for exclusive maximum number value (less than).',\n type: 'number',\n status: 'optional',\n },\n multipleOf: {\n doc: 'Validation that requires the number to be a multiple of given value.',\n type: 'number',\n status: 'optional',\n },\n width: {\n doc: '`false` for no width (use browser default), `small`, `medium` or `large` for predefined standard widths, `stretch` for fill available width.',\n type: ['string', 'false'],\n status: 'optional',\n },\n size: inputProperties.size,\n align: {\n doc: 'Lateral alignment of contents of input field, one of `left` (default), `center`, or `right`.',\n type: 'string',\n status: 'optional',\n },\n help: {\n doc: 'Provide a help button. Object consisting of `title` and `content`.',\n type: 'object',\n status: 'optional',\n },\n autoComplete: {\n doc: 'For HTML `autocomplete` attributes.',\n type: ['on', 'string'],\n status: 'optional',\n },\n prefix: {\n doc: 'Text added before the value input.',\n type: 'string',\n status: 'optional',\n },\n suffix: {\n doc: 'Text added after the value input.',\n type: 'string',\n status: 'optional',\n },\n step: {\n doc: 'Determines step granularity when in/decreasing value input through step controls buttons or arrow keys.',\n type: 'number',\n status: 'optional',\n },\n showStepControls: {\n doc: 'Show buttons that in/decreases value input by the step value.',\n type: 'boolean',\n status: 'optional',\n },\n}\n"],"mappings":"AAAA,SAASA,eAAe,QAAQ,wCAAwC;AAGxE,OAAO,MAAMC,gBAAsC,GAAG;EACpDC,YAAY,EAAE;IACZC,GAAG,EAAE,sFAAsF;IAC3FC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,OAAO,EAAE;IACPH,GAAG,EAAE,gCAAgC;IACrCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDE,QAAQ,EAAE;IACRJ,GAAG,EAAE,4FAA4F;IACjGC,IAAI,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC;IAC3BC,MAAM,EAAE;EACV,CAAC;EACDG,OAAO,EAAE;IACPL,GAAG,EAAE,+GAA+G;IACpHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,OAAO,EAAE;IACPN,GAAG,EAAE,4GAA4G;IACjHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,gBAAgB,EAAE;IAChBP,GAAG,EAAE,+DAA+D;IACpEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,gBAAgB,EAAE;IAChBR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,KAAK,EAAE;IACLV,GAAG,EAAE,8IAA8I;IACnJC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDS,IAAI,EAAEd,eAAe,CAACc,IAAI;EAC1BC,KAAK,EAAE;IACLZ,GAAG,EAAE,8FAA8F;IACnGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDW,IAAI,EAAE;IACJb,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDY,YAAY,EAAE;IACZd,GAAG,EAAE,qCAAqC;IAC1CC,IAAI,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC;IACtBC,MAAM,EAAE;EACV,CAAC;EACDa,MAAM,EAAE;IACNf,GAAG,EAAE,oCAAoC;IACzCC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDc,MAAM,EAAE;IACNhB,GAAG,EAAE,mCAAmC;IACxCC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDe,IAAI,EAAE;IACJjB,GAAG,EAAE,yGAAyG;IAC9GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDgB,gBAAgB,EAAE;IAChBlB,GAAG,EAAE,+DAA+D;IACpEC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"NumberDocs.js","names":["inputProperties","numberProperties","decimalLimit","doc","type","status","percent","currency","minimum","maximum","exclusiveMinimum","exclusiveMaximum","multipleOf","width","size","align","help","autoComplete","prefix","suffix","step","startWith","showStepControls"],"sources":["../../../../../../src/extensions/forms/Field/Number/NumberDocs.ts"],"sourcesContent":["import { inputProperties } from '../../../../components/input/InputDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const numberProperties: PropertiesTableProps = {\n decimalLimit: {\n doc: 'Max number of decimals. Values with more decimals will be rounded. Defaults to `12`.',\n type: 'number',\n status: 'optional',\n },\n percent: {\n doc: 'Format a number as percentage.',\n type: 'boolean',\n status: 'optional',\n },\n currency: {\n doc: 'Currency code (ISO 4217) or `true` to use the default `NOK`. Uses two decimals by default.',\n type: ['boolean', 'string'],\n status: 'optional',\n },\n minimum: {\n doc: 'Validation for inclusive minimum number value (greater than or equal). Defaults to `Number.MIN_SAFE_INTEGER`.',\n type: 'number',\n status: 'optional',\n },\n maximum: {\n doc: 'Validation for inclusive maximum number value (less than or equal). Defaults to `Number.MAX_SAFE_INTEGER`.',\n type: 'number',\n status: 'optional',\n },\n exclusiveMinimum: {\n doc: 'Validation for exclusive minimum number value (greater than).',\n type: 'number',\n status: 'optional',\n },\n exclusiveMaximum: {\n doc: 'Validation for exclusive maximum number value (less than).',\n type: 'number',\n status: 'optional',\n },\n multipleOf: {\n doc: 'Validation that requires the number to be a multiple of given value.',\n type: 'number',\n status: 'optional',\n },\n width: {\n doc: '`false` for no width (use browser default), `small`, `medium` or `large` for predefined standard widths, `stretch` for fill available width.',\n type: ['string', 'false'],\n status: 'optional',\n },\n size: inputProperties.size,\n align: {\n doc: 'Lateral alignment of contents of input field, one of `left` (default), `center`, or `right`.',\n type: 'string',\n status: 'optional',\n },\n help: {\n doc: 'Provide a help button. Object consisting of `title` and `content`.',\n type: 'object',\n status: 'optional',\n },\n autoComplete: {\n doc: 'For HTML `autocomplete` attributes.',\n type: ['on', 'string'],\n status: 'optional',\n },\n prefix: {\n doc: 'Text added before the value input.',\n type: 'string',\n status: 'optional',\n },\n suffix: {\n doc: 'Text added after the value input.',\n type: 'string',\n status: 'optional',\n },\n step: {\n doc: 'Determines step granularity when in/decreasing value input through step controls buttons or arrow keys. Defaults to 1.',\n type: 'number',\n status: 'optional',\n },\n startWith: {\n doc: 'When no `value` or `defaultValue` is given, start with a given value when in/decreasing value input through step controls buttons or arrow keys. Defaults to `null`.',\n type: 'number',\n status: 'optional',\n },\n showStepControls: {\n doc: 'Show buttons that in/decreases value input by the step value.',\n type: 'boolean',\n status: 'optional',\n },\n}\n"],"mappings":"AAAA,SAASA,eAAe,QAAQ,wCAAwC;AAGxE,OAAO,MAAMC,gBAAsC,GAAG;EACpDC,YAAY,EAAE;IACZC,GAAG,EAAE,sFAAsF;IAC3FC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,OAAO,EAAE;IACPH,GAAG,EAAE,gCAAgC;IACrCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDE,QAAQ,EAAE;IACRJ,GAAG,EAAE,4FAA4F;IACjGC,IAAI,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC;IAC3BC,MAAM,EAAE;EACV,CAAC;EACDG,OAAO,EAAE;IACPL,GAAG,EAAE,+GAA+G;IACpHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,OAAO,EAAE;IACPN,GAAG,EAAE,4GAA4G;IACjHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,gBAAgB,EAAE;IAChBP,GAAG,EAAE,+DAA+D;IACpEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,gBAAgB,EAAE;IAChBR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,KAAK,EAAE;IACLV,GAAG,EAAE,8IAA8I;IACnJC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDS,IAAI,EAAEd,eAAe,CAACc,IAAI;EAC1BC,KAAK,EAAE;IACLZ,GAAG,EAAE,8FAA8F;IACnGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDW,IAAI,EAAE;IACJb,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDY,YAAY,EAAE;IACZd,GAAG,EAAE,qCAAqC;IAC1CC,IAAI,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC;IACtBC,MAAM,EAAE;EACV,CAAC;EACDa,MAAM,EAAE;IACNf,GAAG,EAAE,oCAAoC;IACzCC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDc,MAAM,EAAE;IACNhB,GAAG,EAAE,mCAAmC;IACxCC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDe,IAAI,EAAE;IACJjB,GAAG,EAAE,wHAAwH;IAC7HC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDgB,SAAS,EAAE;IACTlB,GAAG,EAAE,sKAAsK;IAC3KC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDiB,gBAAgB,EAAE;IAChBnB,GAAG,EAAE,+DAA+D;IACpEC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -1,7 +1,7 @@
1
- import { Props as FieldBlockProps } from '../../FieldBlock';
1
+ import { Props as FieldSectionProps } from '../../FieldBlock';
2
2
  import { Props as StringFieldProps } from '../String';
3
3
  import { FieldHelpProps } from '../../types';
4
- export type Props = FieldHelpProps & Omit<FieldBlockProps, 'children'> & Partial<Record<'postalCode' | 'city', StringFieldProps>>;
4
+ export type Props = FieldHelpProps & Omit<FieldSectionProps, 'children'> & Partial<Record<'postalCode' | 'city', StringFieldProps>>;
5
5
  declare function PostalCodeAndCity(props: Props): import("react/jsx-runtime").JSX.Element;
6
6
  declare namespace PostalCodeAndCity {
7
7
  var _supportsSpacingProps: boolean;
@@ -18,10 +18,10 @@ function PostalCodeAndCity(props) {
18
18
  help,
19
19
  width = 'large'
20
20
  } = props,
21
- fieldBlockProps = _objectWithoutProperties(props, _excluded);
21
+ fieldSectionProps = _objectWithoutProperties(props, _excluded);
22
22
  return React.createElement(CompositionField, _extends({
23
23
  className: classnames('dnb-forms-field-postal-code-and-city', props.className)
24
- }, fieldBlockProps, {
24
+ }, fieldSectionProps, {
25
25
  width: width
26
26
  }), React.createElement(StringField, _extends({}, postalCode, {
27
27
  pattern: (_postalCode$pattern = postalCode.pattern) !== null && _postalCode$pattern !== void 0 ? _postalCode$pattern : '^[0-9]{4}$',
@@ -1 +1 @@
1
- {"version":3,"file":"PostalCodeAndCity.js","names":["React","classnames","StringField","CompositionField","useTranslation","PostalCodeAndCity","props","_postalCode$pattern","_postalCode$label","_postalCode$placehold","_city$label","_city$pattern","translations","postalCode","city","help","width","fieldBlockProps","_objectWithoutProperties","_excluded","createElement","_extends","className","pattern","mask","label","PostalCode","errorMessages","_objectSpread","required","errorRequired","errorPattern","placeholder","inputClassName","inputMode","autoComplete","City","trim","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.tsx"],"sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\nimport { Props as FieldBlockProps } from '../../FieldBlock'\nimport StringField, { Props as StringFieldProps } from '../String'\nimport CompositionField from '../Composition'\nimport { FieldHelpProps } from '../../types'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type Props = FieldHelpProps &\n Omit<FieldBlockProps, 'children'> &\n Partial<Record<'postalCode' | 'city', StringFieldProps>>\n\nfunction PostalCodeAndCity(props: Props) {\n const translations = useTranslation()\n\n const {\n postalCode = {},\n city = {},\n help,\n width = 'large',\n ...fieldBlockProps\n } = props\n\n return (\n <CompositionField\n className={classnames(\n 'dnb-forms-field-postal-code-and-city',\n props.className\n )}\n {...fieldBlockProps}\n width={width}\n >\n <StringField\n {...postalCode}\n pattern={postalCode.pattern ?? '^[0-9]{4}$'}\n mask={[/\\d/, /\\d/, /\\d/, /\\d/]}\n className={classnames(\n 'dnb-forms-field-postal-code-and-city__postal-code',\n postalCode.className\n )}\n label={postalCode.label ?? translations.PostalCode.label}\n errorMessages={{\n required: translations.PostalCode.errorRequired,\n pattern: translations.PostalCode.errorPattern,\n ...postalCode.errorMessages,\n }}\n placeholder={postalCode.placeholder ?? '0000'}\n width={false}\n inputClassName=\"dnb-forms-field-postal-code-and-city__postal-code-input\"\n inputMode=\"numeric\"\n autoComplete=\"postal-code\"\n />\n <StringField\n {...city}\n className={classnames(\n 'dnb-forms-field-postal-code-and-city__city',\n city.className\n )}\n label={city.label ?? translations.City.label}\n errorMessages={{\n required: translations.City.errorRequired,\n pattern: translations.City.errorPattern,\n ...city.errorMessages,\n }}\n pattern={city.pattern ?? '^[A-Za-zÆØÅæøå -]+$'}\n trim\n width=\"stretch\"\n autoComplete=\"address-level2\"\n help={help}\n />\n </CompositionField>\n )\n}\n\nPostalCodeAndCity._supportsSpacingProps = true\nexport default PostalCodeAndCity\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AAEnC,OAAOC,WAAW,MAAqC,WAAW;AAClE,OAAOC,gBAAgB,MAAM,gBAAgB;AAE7C,OAAOC,cAAc,MAAM,4BAA4B;AAMvD,SAASC,iBAAiBA,CAACC,KAAY,EAAE;EAAA,IAAAC,mBAAA,EAAAC,iBAAA,EAAAC,qBAAA,EAAAC,WAAA,EAAAC,aAAA;EACvC,MAAMC,YAAY,GAAGR,cAAc,CAAC,CAAC;EAErC,MAAM;MACJS,UAAU,GAAG,CAAC,CAAC;MACfC,IAAI,GAAG,CAAC,CAAC;MACTC,IAAI;MACJC,KAAK,GAAG;IAEV,CAAC,GAAGV,KAAK;IADJW,eAAe,GAAAC,wBAAA,CAChBZ,KAAK,EAAAa,SAAA;EAET,OACEnB,KAAA,CAAAoB,aAAA,CAACjB,gBAAgB,EAAAkB,QAAA;IACfC,SAAS,EAAErB,UAAU,CACnB,sCAAsC,EACtCK,KAAK,CAACgB,SACR;EAAE,GACEL,eAAe;IACnBD,KAAK,EAAEA;EAAM,IAEbhB,KAAA,CAAAoB,aAAA,CAAClB,WAAW,EAAAmB,QAAA,KACNR,UAAU;IACdU,OAAO,GAAAhB,mBAAA,GAAEM,UAAU,CAACU,OAAO,cAAAhB,mBAAA,cAAAA,mBAAA,GAAI,YAAa;IAC5CiB,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAE;IAC/BF,SAAS,EAAErB,UAAU,CACnB,mDAAmD,EACnDY,UAAU,CAACS,SACb,CAAE;IACFG,KAAK,GAAAjB,iBAAA,GAAEK,UAAU,CAACY,KAAK,cAAAjB,iBAAA,cAAAA,iBAAA,GAAII,YAAY,CAACc,UAAU,CAACD,KAAM;IACzDE,aAAa,EAAAC,aAAA;MACXC,QAAQ,EAAEjB,YAAY,CAACc,UAAU,CAACI,aAAa;MAC/CP,OAAO,EAAEX,YAAY,CAACc,UAAU,CAACK;IAAY,GAC1ClB,UAAU,CAACc,aAAa,CAC3B;IACFK,WAAW,GAAAvB,qBAAA,GAAEI,UAAU,CAACmB,WAAW,cAAAvB,qBAAA,cAAAA,qBAAA,GAAI,MAAO;IAC9CO,KAAK,EAAE,KAAM;IACbiB,cAAc,EAAC,yDAAyD;IACxEC,SAAS,EAAC,SAAS;IACnBC,YAAY,EAAC;EAAa,EAC3B,CAAC,EACFnC,KAAA,CAAAoB,aAAA,CAAClB,WAAW,EAAAmB,QAAA,KACNP,IAAI;IACRQ,SAAS,EAAErB,UAAU,CACnB,4CAA4C,EAC5Ca,IAAI,CAACQ,SACP,CAAE;IACFG,KAAK,GAAAf,WAAA,GAAEI,IAAI,CAACW,KAAK,cAAAf,WAAA,cAAAA,WAAA,GAAIE,YAAY,CAACwB,IAAI,CAACX,KAAM;IAC7CE,aAAa,EAAAC,aAAA;MACXC,QAAQ,EAAEjB,YAAY,CAACwB,IAAI,CAACN,aAAa;MACzCP,OAAO,EAAEX,YAAY,CAACwB,IAAI,CAACL;IAAY,GACpCjB,IAAI,CAACa,aAAa,CACrB;IACFJ,OAAO,GAAAZ,aAAA,GAAEG,IAAI,CAACS,OAAO,cAAAZ,aAAA,cAAAA,aAAA,GAAI,qBAAsB;IAC/C0B,IAAI;IACJrB,KAAK,EAAC,SAAS;IACfmB,YAAY,EAAC,gBAAgB;IAC7BpB,IAAI,EAAEA;EAAK,EACZ,CACe,CAAC;AAEvB;AAEAV,iBAAiB,CAACiC,qBAAqB,GAAG,IAAI;AAC9C,eAAejC,iBAAiB"}
1
+ {"version":3,"file":"PostalCodeAndCity.js","names":["React","classnames","StringField","CompositionField","useTranslation","PostalCodeAndCity","props","_postalCode$pattern","_postalCode$label","_postalCode$placehold","_city$label","_city$pattern","translations","postalCode","city","help","width","fieldSectionProps","_objectWithoutProperties","_excluded","createElement","_extends","className","pattern","mask","label","PostalCode","errorMessages","_objectSpread","required","errorRequired","errorPattern","placeholder","inputClassName","inputMode","autoComplete","City","trim","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.tsx"],"sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\nimport { Props as FieldSectionProps } from '../../FieldBlock'\nimport StringField, { Props as StringFieldProps } from '../String'\nimport CompositionField from '../Composition'\nimport { FieldHelpProps } from '../../types'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type Props = FieldHelpProps &\n Omit<FieldSectionProps, 'children'> &\n Partial<Record<'postalCode' | 'city', StringFieldProps>>\n\nfunction PostalCodeAndCity(props: Props) {\n const translations = useTranslation()\n\n const {\n postalCode = {},\n city = {},\n help,\n width = 'large',\n ...fieldSectionProps\n } = props\n\n return (\n <CompositionField\n className={classnames(\n 'dnb-forms-field-postal-code-and-city',\n props.className\n )}\n {...fieldSectionProps}\n width={width}\n >\n <StringField\n {...postalCode}\n pattern={postalCode.pattern ?? '^[0-9]{4}$'}\n mask={[/\\d/, /\\d/, /\\d/, /\\d/]}\n className={classnames(\n 'dnb-forms-field-postal-code-and-city__postal-code',\n postalCode.className\n )}\n label={postalCode.label ?? translations.PostalCode.label}\n errorMessages={{\n required: translations.PostalCode.errorRequired,\n pattern: translations.PostalCode.errorPattern,\n ...postalCode.errorMessages,\n }}\n placeholder={postalCode.placeholder ?? '0000'}\n width={false}\n inputClassName=\"dnb-forms-field-postal-code-and-city__postal-code-input\"\n inputMode=\"numeric\"\n autoComplete=\"postal-code\"\n />\n <StringField\n {...city}\n className={classnames(\n 'dnb-forms-field-postal-code-and-city__city',\n city.className\n )}\n label={city.label ?? translations.City.label}\n errorMessages={{\n required: translations.City.errorRequired,\n pattern: translations.City.errorPattern,\n ...city.errorMessages,\n }}\n pattern={city.pattern ?? '^[A-Za-zÆØÅæøå -]+$'}\n trim\n width=\"stretch\"\n autoComplete=\"address-level2\"\n help={help}\n />\n </CompositionField>\n )\n}\n\nPostalCodeAndCity._supportsSpacingProps = true\nexport default PostalCodeAndCity\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AAEnC,OAAOC,WAAW,MAAqC,WAAW;AAClE,OAAOC,gBAAgB,MAAM,gBAAgB;AAE7C,OAAOC,cAAc,MAAM,4BAA4B;AAMvD,SAASC,iBAAiBA,CAACC,KAAY,EAAE;EAAA,IAAAC,mBAAA,EAAAC,iBAAA,EAAAC,qBAAA,EAAAC,WAAA,EAAAC,aAAA;EACvC,MAAMC,YAAY,GAAGR,cAAc,CAAC,CAAC;EAErC,MAAM;MACJS,UAAU,GAAG,CAAC,CAAC;MACfC,IAAI,GAAG,CAAC,CAAC;MACTC,IAAI;MACJC,KAAK,GAAG;IAEV,CAAC,GAAGV,KAAK;IADJW,iBAAiB,GAAAC,wBAAA,CAClBZ,KAAK,EAAAa,SAAA;EAET,OACEnB,KAAA,CAAAoB,aAAA,CAACjB,gBAAgB,EAAAkB,QAAA;IACfC,SAAS,EAAErB,UAAU,CACnB,sCAAsC,EACtCK,KAAK,CAACgB,SACR;EAAE,GACEL,iBAAiB;IACrBD,KAAK,EAAEA;EAAM,IAEbhB,KAAA,CAAAoB,aAAA,CAAClB,WAAW,EAAAmB,QAAA,KACNR,UAAU;IACdU,OAAO,GAAAhB,mBAAA,GAAEM,UAAU,CAACU,OAAO,cAAAhB,mBAAA,cAAAA,mBAAA,GAAI,YAAa;IAC5CiB,IAAI,EAAE,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAE;IAC/BF,SAAS,EAAErB,UAAU,CACnB,mDAAmD,EACnDY,UAAU,CAACS,SACb,CAAE;IACFG,KAAK,GAAAjB,iBAAA,GAAEK,UAAU,CAACY,KAAK,cAAAjB,iBAAA,cAAAA,iBAAA,GAAII,YAAY,CAACc,UAAU,CAACD,KAAM;IACzDE,aAAa,EAAAC,aAAA;MACXC,QAAQ,EAAEjB,YAAY,CAACc,UAAU,CAACI,aAAa;MAC/CP,OAAO,EAAEX,YAAY,CAACc,UAAU,CAACK;IAAY,GAC1ClB,UAAU,CAACc,aAAa,CAC3B;IACFK,WAAW,GAAAvB,qBAAA,GAAEI,UAAU,CAACmB,WAAW,cAAAvB,qBAAA,cAAAA,qBAAA,GAAI,MAAO;IAC9CO,KAAK,EAAE,KAAM;IACbiB,cAAc,EAAC,yDAAyD;IACxEC,SAAS,EAAC,SAAS;IACnBC,YAAY,EAAC;EAAa,EAC3B,CAAC,EACFnC,KAAA,CAAAoB,aAAA,CAAClB,WAAW,EAAAmB,QAAA,KACNP,IAAI;IACRQ,SAAS,EAAErB,UAAU,CACnB,4CAA4C,EAC5Ca,IAAI,CAACQ,SACP,CAAE;IACFG,KAAK,GAAAf,WAAA,GAAEI,IAAI,CAACW,KAAK,cAAAf,WAAA,cAAAA,WAAA,GAAIE,YAAY,CAACwB,IAAI,CAACX,KAAM;IAC7CE,aAAa,EAAAC,aAAA;MACXC,QAAQ,EAAEjB,YAAY,CAACwB,IAAI,CAACN,aAAa;MACzCP,OAAO,EAAEX,YAAY,CAACwB,IAAI,CAACL;IAAY,GACpCjB,IAAI,CAACa,aAAa,CACrB;IACFJ,OAAO,GAAAZ,aAAA,GAAEG,IAAI,CAACS,OAAO,cAAAZ,aAAA,cAAAA,aAAA,GAAI,qBAAsB;IAC/C0B,IAAI;IACJrB,KAAK,EAAC,SAAS;IACfmB,YAAY,EAAC,gBAAgB;IAC7BpB,IAAI,EAAEA;EAAK,EACZ,CACe,CAAC;AAEvB;AAEAV,iBAAiB,CAACiC,qBAAqB,GAAG,IAAI;AAC9C,eAAejC,iBAAiB"}
@@ -56,17 +56,17 @@ function SelectCountry(props) {
56
56
  langRef.current = lang;
57
57
  dataRef.current = getCountryData({
58
58
  lang,
59
- filter: !wasFilled.current ? country => country.iso === props.value : filterCountries,
59
+ filter: !wasFilled.current ? country => country.iso === value : filterCountries,
60
60
  sort: ccFilter
61
61
  });
62
- if (isLangChange && props.value && typeof window !== 'undefined') {
62
+ if (isLangChange && value && typeof window !== 'undefined') {
63
63
  updateValue(null);
64
64
  window.requestAnimationFrame(() => {
65
- updateValue(props.value);
65
+ updateValue(value);
66
66
  });
67
67
  }
68
68
  }
69
- }, [lang, filterCountries, ccFilter, updateValue, props.value]);
69
+ }, [lang, filterCountries, ccFilter, updateValue, value]);
70
70
  const handleCountryChange = useCallback(_ref => {
71
71
  let {
72
72
  data
@@ -1 +1 @@
1
- {"version":3,"file":"SelectCountry.js","names":["React","useCallback","useContext","useMemo","classnames","SharedContext","Autocomplete","HelpButton","pickSpacingProps","countries","prioritizedCountries","useFieldProps","FieldBlock","useErrorMessage","useTranslation","SelectCountry","props","_sharedContext$locale","sharedContext","translations","lang","locale","split","errorMessages","path","required","errorRequired","defaultProps","preparedProps","_objectSpread","className","placeholder","label","ccFilter","info","warning","error","hasError","disabled","value","width","help","htmlAttributes","handleFocus","handleBlur","handleChange","updateValue","forceUpdate","filterCountries","makeCountryFilterSet","undefined","dataRef","useRef","langRef","wasFilled","isLangChange","current","getCountryData","filter","country","iso","sort","window","requestAnimationFrame","handleCountryChange","_ref","data","newValue","selectedKey","find","_ref2","fillData","onFocusHandler","_ref3","updateData","onTypeHandler","_ref4","_event$nativeEvent","currentValue","setHidden","event","nativeEvent","search","toLowerCase","_ref5","i18n","Object","values","some","s","includes","createElement","_extends","label_direction","input_icon","on_show","on_focus","on_blur","on_change","on_type","stretch","status","show_submit_button","suffix","title","content","autoComplete","no_animation","noAnimation","makeObject","_country$i18n$lang","en","arguments","length","_ref6","_ref7","a","b","indexA","indexOf","indexB","priorityA","priorityB","localeCompare","map","_country$regions","regions","continent","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/SelectCountry/SelectCountry.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport SharedContext from '../../../../shared/Context'\nimport { Autocomplete, HelpButton } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport countries, {\n prioritizedCountries,\n type CountryType,\n type CountryLang,\n} from '../../constants/countries'\nimport { useFieldProps } from '../../hooks'\nimport { FieldBlockWidth, FieldHelpProps, FieldProps } from '../../types'\nimport FieldBlock from '../../FieldBlock'\nimport useErrorMessage from '../../hooks/useErrorMessage'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type CountryFilterSet =\n | 'Scandinavia'\n | 'Nordic'\n | 'Europe'\n | 'Prioritized'\n\nexport type Props = FieldHelpProps &\n FieldProps<string, undefined | string> & {\n countries?: CountryFilterSet\n\n // Styling\n width?: FieldBlockWidth\n\n /**\n * For internal use only.\n *\n * @param country\n * @returns boolean\n */\n filterCountries?: (country: CountryType) => boolean\n\n /**\n * For internal testing purposes\n */\n noAnimation?: boolean\n }\n\nfunction SelectCountry(props: Props) {\n const sharedContext = useContext(SharedContext)\n const translations = useTranslation().SelectCountry\n const lang = sharedContext.locale?.split('-')[0] as CountryLang\n\n const errorMessages = useErrorMessage(props.path, props.errorMessages, {\n required: translations.errorRequired,\n })\n\n const defaultProps: Partial<Props> = {\n errorMessages,\n }\n const preparedProps: Props = {\n ...defaultProps,\n ...props,\n }\n\n const {\n className,\n placeholder = translations.placeholder,\n label = translations.label,\n countries: ccFilter = 'Prioritized',\n info,\n warning,\n error,\n hasError,\n disabled,\n value,\n width = 'large',\n help,\n htmlAttributes,\n handleFocus,\n handleBlur,\n handleChange,\n updateValue,\n forceUpdate,\n filterCountries = ccFilter !== 'Prioritized'\n ? makeCountryFilterSet(ccFilter)\n : undefined,\n } = useFieldProps(preparedProps)\n\n const dataRef = React.useRef(null)\n const langRef = React.useRef(lang)\n const wasFilled = React.useRef(false)\n\n /**\n * We do not process the whole country list at the first render.\n * Only when the Autocomplete opens (focus).\n * To achieve this, we use memo instead of effect to update refs in sync.\n *\n * We set or update the data list depending on if the countrycode changes or lang changes.\n * We then update data set when value changes.\n */\n useMemo(() => {\n const isLangChange = lang !== langRef.current\n\n if (isLangChange || !wasFilled.current) {\n langRef.current = lang\n dataRef.current = getCountryData({\n lang,\n filter: !wasFilled.current\n ? (country) => country.iso === props.value\n : filterCountries,\n sort: ccFilter as Extract<CountryFilterSet, 'Prioritized'>,\n })\n\n // To force Autocomplete to re-evaluate the internal data\n if (isLangChange && props.value && typeof window !== 'undefined') {\n updateValue(null)\n window.requestAnimationFrame(() => {\n updateValue(props.value)\n })\n }\n }\n }, [lang, filterCountries, ccFilter, updateValue, props.value])\n\n const handleCountryChange = useCallback(\n ({ data }: { data: { selectedKey: string } }) => {\n const newValue = data?.selectedKey\n const country = countries.find(({ iso }) => newValue === iso)\n if (country?.iso) {\n handleChange(country.iso, country)\n }\n },\n [handleChange]\n )\n\n const fillData = useCallback(() => {\n if (!wasFilled.current) {\n wasFilled.current = true\n dataRef.current = getCountryData({\n lang: langRef.current,\n filter: filterCountries,\n sort: ccFilter as Extract<CountryFilterSet, 'Prioritized'>,\n })\n forceUpdate()\n }\n }, [ccFilter, filterCountries, forceUpdate])\n\n const onFocusHandler = useCallback(\n ({ updateData }) => {\n fillData()\n updateData(dataRef.current)\n handleFocus()\n },\n [fillData, handleFocus]\n )\n\n const onTypeHandler = useCallback(\n ({ value: currentValue, setHidden, event }) => {\n // Handle browser autofill/autocomplete\n if (typeof event?.nativeEvent?.data === 'undefined') {\n const search = currentValue.toLowerCase()\n const country = countries.find(({ i18n }) =>\n Object.values(i18n).some((s) => s.toLowerCase().includes(search))\n )\n if (country?.iso) {\n setHidden()\n handleChange(country.iso, country)\n }\n }\n },\n [handleChange]\n )\n\n return (\n <FieldBlock\n className={classnames('dnb-forms-field-select-country', className)}\n width={width}\n info={info}\n warning={warning}\n error={error}\n {...pickSpacingProps(props)}\n >\n <Autocomplete\n placeholder={placeholder}\n label_direction=\"vertical\"\n label={label}\n input_icon={false}\n data={dataRef.current}\n value={value}\n disabled={disabled}\n on_show={fillData}\n on_focus={onFocusHandler}\n on_blur={handleBlur}\n on_change={handleCountryChange}\n on_type={onTypeHandler}\n stretch\n status={hasError ? 'error' : undefined}\n show_submit_button\n suffix={\n help ? (\n <HelpButton title={help.title}>{help.content}</HelpButton>\n ) : undefined\n }\n autoComplete=\"country-name\"\n no_animation={props.noAnimation}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n}\n\ntype GetCountryData = {\n lang?: CountryLang\n filter?: Props['filterCountries']\n sort?: Extract<CountryFilterSet, 'Prioritized'>\n makeObject?: (\n country: CountryType,\n lang: string\n ) => {\n selectedKey: string\n selected_value?: string\n content: string\n }\n}\n\nexport function getCountryData({\n lang = 'nb',\n filter = null,\n sort = null,\n makeObject = (country: CountryType, lang: string) => {\n const content = country.i18n[lang] ?? country.i18n.en\n return {\n selectedKey: country.iso,\n content,\n }\n },\n}: GetCountryData = {}) {\n return countries\n .filter((country) => {\n if (typeof filter === 'function') {\n return filter(country)\n }\n\n return !filter\n })\n .sort(({ i18n: a }, { i18n: b }) => {\n if (sort === 'Prioritized') {\n const indexA = prioritizedCountries.indexOf(a['en'])\n const indexB = prioritizedCountries.indexOf(b['en'])\n\n const priorityA = indexA !== -1\n const priorityB = indexB !== -1\n\n if (priorityA && priorityB) {\n return indexA - indexB\n } else if (priorityA) {\n return -1\n } else if (priorityB) {\n return 1\n }\n }\n\n return a[lang].localeCompare(b[lang])\n })\n .map((country) => makeObject(country, lang))\n}\n\nexport function makeCountryFilterSet(ccFilter: CountryFilterSet) {\n return (country: CountryType) => {\n switch (ccFilter) {\n case 'Scandinavia':\n case 'Nordic':\n return country.regions?.includes(ccFilter)\n case 'Europe':\n return country.continent.includes(ccFilter)\n }\n return true\n }\n}\n\nSelectCountry._supportsSpacingProps = true\nexport default SelectCountry\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAC/D,OAAOC,UAAU,MAAM,YAAY;AACnC,OAAOC,aAAa,MAAM,4BAA4B;AACtD,SAASC,YAAY,EAAEC,UAAU,QAAQ,wBAAwB;AACjE,SAASC,gBAAgB,QAAQ,mCAAmC;AACpE,OAAOC,SAAS,IACdC,oBAAoB,QAGf,2BAA2B;AAClC,SAASC,aAAa,QAAQ,aAAa;AAE3C,OAAOC,UAAU,MAAM,kBAAkB;AACzC,OAAOC,eAAe,MAAM,6BAA6B;AACzD,OAAOC,cAAc,MAAM,4BAA4B;AA6BvD,SAASC,aAAaA,CAACC,KAAY,EAAE;EAAA,IAAAC,qBAAA;EACnC,MAAMC,aAAa,GAAGhB,UAAU,CAACG,aAAa,CAAC;EAC/C,MAAMc,YAAY,GAAGL,cAAc,CAAC,CAAC,CAACC,aAAa;EACnD,MAAMK,IAAI,IAAAH,qBAAA,GAAGC,aAAa,CAACG,MAAM,cAAAJ,qBAAA,uBAApBA,qBAAA,CAAsBK,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAgB;EAE/D,MAAMC,aAAa,GAAGV,eAAe,CAACG,KAAK,CAACQ,IAAI,EAAER,KAAK,CAACO,aAAa,EAAE;IACrEE,QAAQ,EAAEN,YAAY,CAACO;EACzB,CAAC,CAAC;EAEF,MAAMC,YAA4B,GAAG;IACnCJ;EACF,CAAC;EACD,MAAMK,aAAoB,GAAAC,aAAA,CAAAA,aAAA,KACrBF,YAAY,GACZX,KAAK,CACT;EAED,MAAM;IACJc,SAAS;IACTC,WAAW,GAAGZ,YAAY,CAACY,WAAW;IACtCC,KAAK,GAAGb,YAAY,CAACa,KAAK;IAC1BvB,SAAS,EAAEwB,QAAQ,GAAG,aAAa;IACnCC,IAAI;IACJC,OAAO;IACPC,KAAK;IACLC,QAAQ;IACRC,QAAQ;IACRC,KAAK;IACLC,KAAK,GAAG,OAAO;IACfC,IAAI;IACJC,cAAc;IACdC,WAAW;IACXC,UAAU;IACVC,YAAY;IACZC,WAAW;IACXC,WAAW;IACXC,eAAe,GAAGf,QAAQ,KAAK,aAAa,GACxCgB,oBAAoB,CAAChB,QAAQ,CAAC,GAC9BiB;EACN,CAAC,GAAGvC,aAAa,CAACiB,aAAa,CAAC;EAEhC,MAAMuB,OAAO,GAAGnD,KAAK,CAACoD,MAAM,CAAC,IAAI,CAAC;EAClC,MAAMC,OAAO,GAAGrD,KAAK,CAACoD,MAAM,CAAChC,IAAI,CAAC;EAClC,MAAMkC,SAAS,GAAGtD,KAAK,CAACoD,MAAM,CAAC,KAAK,CAAC;EAUrCjD,OAAO,CAAC,MAAM;IACZ,MAAMoD,YAAY,GAAGnC,IAAI,KAAKiC,OAAO,CAACG,OAAO;IAE7C,IAAID,YAAY,IAAI,CAACD,SAAS,CAACE,OAAO,EAAE;MACtCH,OAAO,CAACG,OAAO,GAAGpC,IAAI;MACtB+B,OAAO,CAACK,OAAO,GAAGC,cAAc,CAAC;QAC/BrC,IAAI;QACJsC,MAAM,EAAE,CAACJ,SAAS,CAACE,OAAO,GACrBG,OAAO,IAAKA,OAAO,CAACC,GAAG,KAAK5C,KAAK,CAACuB,KAAK,GACxCS,eAAe;QACnBa,IAAI,EAAE5B;MACR,CAAC,CAAC;MAGF,IAAIsB,YAAY,IAAIvC,KAAK,CAACuB,KAAK,IAAI,OAAOuB,MAAM,KAAK,WAAW,EAAE;QAChEhB,WAAW,CAAC,IAAI,CAAC;QACjBgB,MAAM,CAACC,qBAAqB,CAAC,MAAM;UACjCjB,WAAW,CAAC9B,KAAK,CAACuB,KAAK,CAAC;QAC1B,CAAC,CAAC;MACJ;IACF;EACF,CAAC,EAAE,CAACnB,IAAI,EAAE4B,eAAe,EAAEf,QAAQ,EAAEa,WAAW,EAAE9B,KAAK,CAACuB,KAAK,CAAC,CAAC;EAE/D,MAAMyB,mBAAmB,GAAG/D,WAAW,CACrCgE,IAAA,IAAiD;IAAA,IAAhD;MAAEC;IAAwC,CAAC,GAAAD,IAAA;IAC1C,MAAME,QAAQ,GAAGD,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEE,WAAW;IAClC,MAAMT,OAAO,GAAGlD,SAAS,CAAC4D,IAAI,CAACC,KAAA;MAAA,IAAC;QAAEV;MAAI,CAAC,GAAAU,KAAA;MAAA,OAAKH,QAAQ,KAAKP,GAAG;IAAA,EAAC;IAC7D,IAAID,OAAO,aAAPA,OAAO,eAAPA,OAAO,CAAEC,GAAG,EAAE;MAChBf,YAAY,CAACc,OAAO,CAACC,GAAG,EAAED,OAAO,CAAC;IACpC;EACF,CAAC,EACD,CAACd,YAAY,CACf,CAAC;EAED,MAAM0B,QAAQ,GAAGtE,WAAW,CAAC,MAAM;IACjC,IAAI,CAACqD,SAAS,CAACE,OAAO,EAAE;MACtBF,SAAS,CAACE,OAAO,GAAG,IAAI;MACxBL,OAAO,CAACK,OAAO,GAAGC,cAAc,CAAC;QAC/BrC,IAAI,EAAEiC,OAAO,CAACG,OAAO;QACrBE,MAAM,EAAEV,eAAe;QACvBa,IAAI,EAAE5B;MACR,CAAC,CAAC;MACFc,WAAW,CAAC,CAAC;IACf;EACF,CAAC,EAAE,CAACd,QAAQ,EAAEe,eAAe,EAAED,WAAW,CAAC,CAAC;EAE5C,MAAMyB,cAAc,GAAGvE,WAAW,CAChCwE,KAAA,IAAoB;IAAA,IAAnB;MAAEC;IAAW,CAAC,GAAAD,KAAA;IACbF,QAAQ,CAAC,CAAC;IACVG,UAAU,CAACvB,OAAO,CAACK,OAAO,CAAC;IAC3Bb,WAAW,CAAC,CAAC;EACf,CAAC,EACD,CAAC4B,QAAQ,EAAE5B,WAAW,CACxB,CAAC;EAED,MAAMgC,aAAa,GAAG1E,WAAW,CAC/B2E,KAAA,IAA+C;IAAA,IAAAC,kBAAA;IAAA,IAA9C;MAAEtC,KAAK,EAAEuC,YAAY;MAAEC,SAAS;MAAEC;IAAM,CAAC,GAAAJ,KAAA;IAExC,IAAI,QAAOI,KAAK,aAALA,KAAK,wBAAAH,kBAAA,GAALG,KAAK,CAAEC,WAAW,cAAAJ,kBAAA,uBAAlBA,kBAAA,CAAoBX,IAAI,MAAK,WAAW,EAAE;MACnD,MAAMgB,MAAM,GAAGJ,YAAY,CAACK,WAAW,CAAC,CAAC;MACzC,MAAMxB,OAAO,GAAGlD,SAAS,CAAC4D,IAAI,CAACe,KAAA;QAAA,IAAC;UAAEC;QAAK,CAAC,GAAAD,KAAA;QAAA,OACtCE,MAAM,CAACC,MAAM,CAACF,IAAI,CAAC,CAACG,IAAI,CAAEC,CAAC,IAAKA,CAAC,CAACN,WAAW,CAAC,CAAC,CAACO,QAAQ,CAACR,MAAM,CAAC,CAAC;MAAA,CACnE,CAAC;MACD,IAAIvB,OAAO,aAAPA,OAAO,eAAPA,OAAO,CAAEC,GAAG,EAAE;QAChBmB,SAAS,CAAC,CAAC;QACXlC,YAAY,CAACc,OAAO,CAACC,GAAG,EAAED,OAAO,CAAC;MACpC;IACF;EACF,CAAC,EACD,CAACd,YAAY,CACf,CAAC;EAED,OACE7C,KAAA,CAAA2F,aAAA,CAAC/E,UAAU,EAAAgF,QAAA;IACT9D,SAAS,EAAE1B,UAAU,CAAC,gCAAgC,EAAE0B,SAAS,CAAE;IACnEU,KAAK,EAAEA,KAAM;IACbN,IAAI,EAAEA,IAAK;IACXC,OAAO,EAAEA,OAAQ;IACjBC,KAAK,EAAEA;EAAM,GACT5B,gBAAgB,CAACQ,KAAK,CAAC,GAE3BhB,KAAA,CAAA2F,aAAA,CAACrF,YAAY,EAAAsF,QAAA;IACX7D,WAAW,EAAEA,WAAY;IACzB8D,eAAe,EAAC,UAAU;IAC1B7D,KAAK,EAAEA,KAAM;IACb8D,UAAU,EAAE,KAAM;IAClB5B,IAAI,EAAEf,OAAO,CAACK,OAAQ;IACtBjB,KAAK,EAAEA,KAAM;IACbD,QAAQ,EAAEA,QAAS;IACnByD,OAAO,EAAExB,QAAS;IAClByB,QAAQ,EAAExB,cAAe;IACzByB,OAAO,EAAErD,UAAW;IACpBsD,SAAS,EAAElC,mBAAoB;IAC/BmC,OAAO,EAAExB,aAAc;IACvByB,OAAO;IACPC,MAAM,EAAEhE,QAAQ,GAAG,OAAO,GAAGa,SAAU;IACvCoD,kBAAkB;IAClBC,MAAM,EACJ9D,IAAI,GACFzC,KAAA,CAAA2F,aAAA,CAACpF,UAAU;MAACiG,KAAK,EAAE/D,IAAI,CAAC+D;IAAM,GAAE/D,IAAI,CAACgE,OAAoB,CAAC,GACxDvD,SACL;IACDwD,YAAY,EAAC,cAAc;IAC3BC,YAAY,EAAE3F,KAAK,CAAC4F;EAAY,GAC5BlE,cAAc,CACnB,CACS,CAAC;AAEjB;AAgBA,OAAO,SAASe,cAAcA,CAAA,EAWN;EAAA,IAXO;IAC7BrC,IAAI,GAAG,IAAI;IACXsC,MAAM,GAAG,IAAI;IACbG,IAAI,GAAG,IAAI;IACXgD,UAAU,GAAGA,CAAClD,OAAoB,EAAEvC,IAAY,KAAK;MAAA,IAAA0F,kBAAA;MACnD,MAAML,OAAO,IAAAK,kBAAA,GAAGnD,OAAO,CAAC0B,IAAI,CAACjE,IAAI,CAAC,cAAA0F,kBAAA,cAAAA,kBAAA,GAAInD,OAAO,CAAC0B,IAAI,CAAC0B,EAAE;MACrD,OAAO;QACL3C,WAAW,EAAET,OAAO,CAACC,GAAG;QACxB6C;MACF,CAAC;IACH;EACc,CAAC,GAAAO,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAA9D,SAAA,GAAA8D,SAAA,MAAG,CAAC,CAAC;EACpB,OAAOvG,SAAS,CACbiD,MAAM,CAAEC,OAAO,IAAK;IACnB,IAAI,OAAOD,MAAM,KAAK,UAAU,EAAE;MAChC,OAAOA,MAAM,CAACC,OAAO,CAAC;IACxB;IAEA,OAAO,CAACD,MAAM;EAChB,CAAC,CAAC,CACDG,IAAI,CAAC,CAAAqD,KAAA,EAAAC,KAAA,KAA8B;IAAA,IAA7B;MAAE9B,IAAI,EAAE+B;IAAE,CAAC,GAAAF,KAAA;IAAA,IAAE;MAAE7B,IAAI,EAAEgC;IAAE,CAAC,GAAAF,KAAA;IAC7B,IAAItD,IAAI,KAAK,aAAa,EAAE;MAC1B,MAAMyD,MAAM,GAAG5G,oBAAoB,CAAC6G,OAAO,CAACH,CAAC,CAAC,IAAI,CAAC,CAAC;MACpD,MAAMI,MAAM,GAAG9G,oBAAoB,CAAC6G,OAAO,CAACF,CAAC,CAAC,IAAI,CAAC,CAAC;MAEpD,MAAMI,SAAS,GAAGH,MAAM,KAAK,CAAC,CAAC;MAC/B,MAAMI,SAAS,GAAGF,MAAM,KAAK,CAAC,CAAC;MAE/B,IAAIC,SAAS,IAAIC,SAAS,EAAE;QAC1B,OAAOJ,MAAM,GAAGE,MAAM;MACxB,CAAC,MAAM,IAAIC,SAAS,EAAE;QACpB,OAAO,CAAC,CAAC;MACX,CAAC,MAAM,IAAIC,SAAS,EAAE;QACpB,OAAO,CAAC;MACV;IACF;IAEA,OAAON,CAAC,CAAChG,IAAI,CAAC,CAACuG,aAAa,CAACN,CAAC,CAACjG,IAAI,CAAC,CAAC;EACvC,CAAC,CAAC,CACDwG,GAAG,CAAEjE,OAAO,IAAKkD,UAAU,CAAClD,OAAO,EAAEvC,IAAI,CAAC,CAAC;AAChD;AAEA,OAAO,SAAS6B,oBAAoBA,CAAChB,QAA0B,EAAE;EAC/D,OAAQ0B,OAAoB,IAAK;IAAA,IAAAkE,gBAAA;IAC/B,QAAQ5F,QAAQ;MACd,KAAK,aAAa;MAClB,KAAK,QAAQ;QACX,QAAA4F,gBAAA,GAAOlE,OAAO,CAACmE,OAAO,cAAAD,gBAAA,uBAAfA,gBAAA,CAAiBnC,QAAQ,CAACzD,QAAQ,CAAC;MAC5C,KAAK,QAAQ;QACX,OAAO0B,OAAO,CAACoE,SAAS,CAACrC,QAAQ,CAACzD,QAAQ,CAAC;IAC/C;IACA,OAAO,IAAI;EACb,CAAC;AACH;AAEAlB,aAAa,CAACiH,qBAAqB,GAAG,IAAI;AAC1C,eAAejH,aAAa"}
1
+ {"version":3,"file":"SelectCountry.js","names":["React","useCallback","useContext","useMemo","classnames","SharedContext","Autocomplete","HelpButton","pickSpacingProps","countries","prioritizedCountries","useFieldProps","FieldBlock","useErrorMessage","useTranslation","SelectCountry","props","_sharedContext$locale","sharedContext","translations","lang","locale","split","errorMessages","path","required","errorRequired","defaultProps","preparedProps","_objectSpread","className","placeholder","label","ccFilter","info","warning","error","hasError","disabled","value","width","help","htmlAttributes","handleFocus","handleBlur","handleChange","updateValue","forceUpdate","filterCountries","makeCountryFilterSet","undefined","dataRef","useRef","langRef","wasFilled","isLangChange","current","getCountryData","filter","country","iso","sort","window","requestAnimationFrame","handleCountryChange","_ref","data","newValue","selectedKey","find","_ref2","fillData","onFocusHandler","_ref3","updateData","onTypeHandler","_ref4","_event$nativeEvent","currentValue","setHidden","event","nativeEvent","search","toLowerCase","_ref5","i18n","Object","values","some","s","includes","createElement","_extends","label_direction","input_icon","on_show","on_focus","on_blur","on_change","on_type","stretch","status","show_submit_button","suffix","title","content","autoComplete","no_animation","noAnimation","makeObject","_country$i18n$lang","en","arguments","length","_ref6","_ref7","a","b","indexA","indexOf","indexB","priorityA","priorityB","localeCompare","map","_country$regions","regions","continent","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/SelectCountry/SelectCountry.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport SharedContext from '../../../../shared/Context'\nimport { Autocomplete, HelpButton } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport countries, {\n prioritizedCountries,\n type CountryType,\n type CountryLang,\n} from '../../constants/countries'\nimport { useFieldProps } from '../../hooks'\nimport { FieldBlockWidth, FieldHelpProps, FieldProps } from '../../types'\nimport FieldBlock from '../../FieldBlock'\nimport useErrorMessage from '../../hooks/useErrorMessage'\nimport useTranslation from '../../hooks/useTranslation'\n\nexport type CountryFilterSet =\n | 'Scandinavia'\n | 'Nordic'\n | 'Europe'\n | 'Prioritized'\n\nexport type Props = FieldHelpProps &\n FieldProps<string, undefined | string> & {\n countries?: CountryFilterSet\n\n // Styling\n width?: FieldBlockWidth\n\n /**\n * For internal use only.\n *\n * @param country\n * @returns boolean\n */\n filterCountries?: (country: CountryType) => boolean\n\n /**\n * For internal testing purposes\n */\n noAnimation?: boolean\n }\n\nfunction SelectCountry(props: Props) {\n const sharedContext = useContext(SharedContext)\n const translations = useTranslation().SelectCountry\n const lang = sharedContext.locale?.split('-')[0] as CountryLang\n\n const errorMessages = useErrorMessage(props.path, props.errorMessages, {\n required: translations.errorRequired,\n })\n\n const defaultProps: Partial<Props> = {\n errorMessages,\n }\n const preparedProps: Props = {\n ...defaultProps,\n ...props,\n }\n\n const {\n className,\n placeholder = translations.placeholder,\n label = translations.label,\n countries: ccFilter = 'Prioritized',\n info,\n warning,\n error,\n hasError,\n disabled,\n value,\n width = 'large',\n help,\n htmlAttributes,\n handleFocus,\n handleBlur,\n handleChange,\n updateValue,\n forceUpdate,\n filterCountries = ccFilter !== 'Prioritized'\n ? makeCountryFilterSet(ccFilter)\n : undefined,\n } = useFieldProps(preparedProps)\n\n const dataRef = React.useRef(null)\n const langRef = React.useRef(lang)\n const wasFilled = React.useRef(false)\n\n /**\n * We do not process the whole country list at the first render.\n * Only when the Autocomplete opens (focus).\n * To achieve this, we use memo instead of effect to update refs in sync.\n *\n * We set or update the data list depending on if the countrycode changes or lang changes.\n * We then update data set when value changes.\n */\n useMemo(() => {\n const isLangChange = lang !== langRef.current\n\n if (isLangChange || !wasFilled.current) {\n langRef.current = lang\n dataRef.current = getCountryData({\n lang,\n filter: !wasFilled.current\n ? (country) => country.iso === value\n : filterCountries,\n sort: ccFilter as Extract<CountryFilterSet, 'Prioritized'>,\n })\n\n // To force Autocomplete to re-evaluate the internal data\n if (isLangChange && value && typeof window !== 'undefined') {\n updateValue(null)\n window.requestAnimationFrame(() => {\n updateValue(value)\n })\n }\n }\n }, [lang, filterCountries, ccFilter, updateValue, value])\n\n const handleCountryChange = useCallback(\n ({ data }: { data: { selectedKey: string } }) => {\n const newValue = data?.selectedKey\n const country = countries.find(({ iso }) => newValue === iso)\n if (country?.iso) {\n handleChange(country.iso, country)\n }\n },\n [handleChange]\n )\n\n const fillData = useCallback(() => {\n if (!wasFilled.current) {\n wasFilled.current = true\n dataRef.current = getCountryData({\n lang: langRef.current,\n filter: filterCountries,\n sort: ccFilter as Extract<CountryFilterSet, 'Prioritized'>,\n })\n forceUpdate()\n }\n }, [ccFilter, filterCountries, forceUpdate])\n\n const onFocusHandler = useCallback(\n ({ updateData }) => {\n fillData()\n updateData(dataRef.current)\n handleFocus()\n },\n [fillData, handleFocus]\n )\n\n const onTypeHandler = useCallback(\n ({ value: currentValue, setHidden, event }) => {\n // Handle browser autofill/autocomplete\n if (typeof event?.nativeEvent?.data === 'undefined') {\n const search = currentValue.toLowerCase()\n const country = countries.find(({ i18n }) =>\n Object.values(i18n).some((s) => s.toLowerCase().includes(search))\n )\n if (country?.iso) {\n setHidden()\n handleChange(country.iso, country)\n }\n }\n },\n [handleChange]\n )\n\n return (\n <FieldBlock\n className={classnames('dnb-forms-field-select-country', className)}\n width={width}\n info={info}\n warning={warning}\n error={error}\n {...pickSpacingProps(props)}\n >\n <Autocomplete\n placeholder={placeholder}\n label_direction=\"vertical\"\n label={label}\n input_icon={false}\n data={dataRef.current}\n value={value}\n disabled={disabled}\n on_show={fillData}\n on_focus={onFocusHandler}\n on_blur={handleBlur}\n on_change={handleCountryChange}\n on_type={onTypeHandler}\n stretch\n status={hasError ? 'error' : undefined}\n show_submit_button\n suffix={\n help ? (\n <HelpButton title={help.title}>{help.content}</HelpButton>\n ) : undefined\n }\n autoComplete=\"country-name\"\n no_animation={props.noAnimation}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n}\n\ntype GetCountryData = {\n lang?: CountryLang\n filter?: Props['filterCountries']\n sort?: Extract<CountryFilterSet, 'Prioritized'>\n makeObject?: (\n country: CountryType,\n lang: string\n ) => {\n selectedKey: string\n selected_value?: string\n content: string\n }\n}\n\nexport function getCountryData({\n lang = 'nb',\n filter = null,\n sort = null,\n makeObject = (country: CountryType, lang: string) => {\n const content = country.i18n[lang] ?? country.i18n.en\n return {\n selectedKey: country.iso,\n content,\n }\n },\n}: GetCountryData = {}) {\n return countries\n .filter((country) => {\n if (typeof filter === 'function') {\n return filter(country)\n }\n\n return !filter\n })\n .sort(({ i18n: a }, { i18n: b }) => {\n if (sort === 'Prioritized') {\n const indexA = prioritizedCountries.indexOf(a['en'])\n const indexB = prioritizedCountries.indexOf(b['en'])\n\n const priorityA = indexA !== -1\n const priorityB = indexB !== -1\n\n if (priorityA && priorityB) {\n return indexA - indexB\n } else if (priorityA) {\n return -1\n } else if (priorityB) {\n return 1\n }\n }\n\n return a[lang].localeCompare(b[lang])\n })\n .map((country) => makeObject(country, lang))\n}\n\nexport function makeCountryFilterSet(ccFilter: CountryFilterSet) {\n return (country: CountryType) => {\n switch (ccFilter) {\n case 'Scandinavia':\n case 'Nordic':\n return country.regions?.includes(ccFilter)\n case 'Europe':\n return country.continent.includes(ccFilter)\n }\n return true\n }\n}\n\nSelectCountry._supportsSpacingProps = true\nexport default SelectCountry\n"],"mappings":"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"}
@@ -45,10 +45,9 @@ function Selection(props) {
45
45
  } = useFieldProps(props);
46
46
  const handleDropdownChange = useCallback(_ref => {
47
47
  let {
48
- data: {
49
- selectedKey
50
- }
48
+ data
51
49
  } = _ref;
50
+ const selectedKey = data === null || data === void 0 ? void 0 : data.selectedKey;
52
51
  handleChange === null || handleChange === void 0 ? void 0 : handleChange(!selectedKey || selectedKey === clearValue ? emptyValue : selectedKey);
53
52
  }, [handleChange, emptyValue, clearValue]);
54
53
  const onChangeHandler = useCallback(_ref2 => {
@@ -70,7 +69,7 @@ function Selection(props) {
70
69
  setHasFocus(false, data === null || data === void 0 ? void 0 : data.selectedKey);
71
70
  }, [setHasFocus]);
72
71
  const cn = classnames(`dnb-forms-field-selection dnb-forms-field-selection__variant--${variant} dnb-forms-field-selection__options-layout--${optionsLayout}`, className);
73
- const fieldBlockProps = _objectSpread(_objectSpread({
72
+ const fieldSectionProps = _objectSpread(_objectSpread({
74
73
  forId: id,
75
74
  className: cn
76
75
  }, pickSpacingProps(props)), {}, {
@@ -105,7 +104,7 @@ function Selection(props) {
105
104
  }, rest);
106
105
  });
107
106
  const Component = variant === 'radio' ? Radio : ToggleButton;
108
- return React.createElement(FieldBlock, fieldBlockProps, React.createElement(Component.Group, {
107
+ return React.createElement(FieldBlock, fieldSectionProps, React.createElement(Component.Group, {
109
108
  className: cn,
110
109
  layout_direction: optionsLayout === 'horizontal' ? 'row' : 'column',
111
110
  disabled: disabled,
@@ -149,7 +148,7 @@ function Selection(props) {
149
148
  on_hide: handleHide,
150
149
  stretch: true
151
150
  });
152
- return React.createElement(FieldBlock, _extends({}, fieldBlockProps, {
151
+ return React.createElement(FieldBlock, _extends({}, fieldSectionProps, {
153
152
  width: width
154
153
  }), variant === 'autocomplete' ? React.createElement(Autocomplete, _extends({}, sharedProps, autocompleteProps ? convertCamelCaseProps(autocompleteProps) : null)) : React.createElement(Dropdown, _extends({}, sharedProps, dropdownProps ? convertCamelCaseProps(dropdownProps) : null)));
155
154
  }