@dnb/eufemia 10.15.1 → 10.17.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 (1177) hide show
  1. package/CHANGELOG.md +79 -0
  2. package/assets/icons/dnb/browser.svg +1 -0
  3. package/assets/icons/dnb/browser_medium.svg +1 -0
  4. package/assets/icons/dnb/coins_1.svg +1 -1
  5. package/assets/icons/dnb/coins_1_medium.svg +1 -1
  6. package/assets/icons/dnb/digipass_corporate.svg +1 -0
  7. package/assets/icons/dnb/digipass_corporate_medium.svg +1 -0
  8. package/assets/icons/dnb/digipass_private.svg +1 -0
  9. package/assets/icons/dnb/digipass_private_medium.svg +1 -0
  10. package/assets/icons/dnb/envelope_open.svg +1 -0
  11. package/assets/icons/dnb/envelope_open_medium.svg +1 -0
  12. package/assets/icons/dnb/eufemia-icons-xml-categorized.tgz +0 -0
  13. package/assets/icons/dnb/eufemia-icons-xml.tgz +0 -0
  14. package/assets/icons/dnb/laptop.svg +1 -0
  15. package/assets/icons/dnb/laptop_medium.svg +1 -0
  16. package/assets/icons/dnb/mobile.svg +1 -0
  17. package/assets/icons/dnb/mobile_medium.svg +1 -0
  18. package/assets/icons/dnb/money_left.svg +1 -0
  19. package/assets/icons/dnb/money_left_medium.svg +1 -0
  20. package/assets/icons/dnb/scan.svg +1 -1
  21. package/assets/icons/dnb/scan_medium.svg +1 -1
  22. package/assets/icons/dnb/teenager.svg +1 -0
  23. package/assets/icons/dnb/teenager_medium.svg +1 -0
  24. package/cjs/components/anchor/Anchor.js +9 -5
  25. package/cjs/components/anchor/Anchor.js.map +1 -1
  26. package/cjs/components/anchor/style/anchor-mixins.scss +8 -17
  27. package/cjs/components/anchor/style/dnb-anchor.css +28 -24
  28. package/cjs/components/anchor/style/dnb-anchor.min.css +1 -1
  29. package/cjs/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +16 -4
  30. package/cjs/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  31. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.css +16 -4
  32. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  33. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.scss +10 -2
  34. package/cjs/components/autocomplete/Autocomplete.js +2 -2
  35. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  36. package/cjs/components/button/style/dnb-button.css +13 -0
  37. package/cjs/components/button/style/dnb-button.min.css +1 -1
  38. package/cjs/components/button/style/dnb-button.scss +16 -0
  39. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.css +12 -1
  40. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.min.css +1 -1
  41. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.css +12 -0
  42. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.min.css +2 -2
  43. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.scss +10 -0
  44. package/cjs/components/button/style/themes/dnb-button-theme-ui.css +12 -1
  45. package/cjs/components/button/style/themes/dnb-button-theme-ui.min.css +1 -1
  46. package/cjs/components/button/style/themes/dnb-button-theme-ui.scss +12 -3
  47. package/cjs/components/card/Card.d.ts +1 -1
  48. package/cjs/components/card/Card.js +48 -9
  49. package/cjs/components/card/Card.js.map +1 -1
  50. package/cjs/components/card/style/dnb-card.css +0 -20
  51. package/cjs/components/card/style/dnb-card.min.css +1 -1
  52. package/cjs/components/card/style/dnb-card.scss +0 -20
  53. package/cjs/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  54. package/cjs/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  55. package/cjs/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  56. package/cjs/components/date-picker/DatePicker.d.ts +18 -1
  57. package/cjs/components/date-picker/DatePicker.js +4 -3
  58. package/cjs/components/date-picker/DatePicker.js.map +1 -1
  59. package/cjs/components/date-picker/DatePickerCalc.js +2 -1
  60. package/cjs/components/date-picker/DatePickerCalc.js.map +1 -1
  61. package/cjs/components/date-picker/DatePickerInput.d.ts +3 -0
  62. package/cjs/components/date-picker/DatePickerInput.js +27 -6
  63. package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
  64. package/cjs/components/date-picker/DatePickerProvider.js +2 -2
  65. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  66. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  67. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  68. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  69. package/cjs/components/dropdown/Dropdown.js +3 -2
  70. package/cjs/components/dropdown/Dropdown.js.map +1 -1
  71. package/cjs/components/flex/Container.d.ts +2 -4
  72. package/cjs/components/flex/Container.js +11 -2
  73. package/cjs/components/flex/Container.js.map +1 -1
  74. package/cjs/components/flex/Item.d.ts +2 -3
  75. package/cjs/components/flex/Item.js +2 -1
  76. package/cjs/components/flex/Item.js.map +1 -1
  77. package/cjs/components/flex/export.d.ts +1 -0
  78. package/cjs/components/flex/export.js +7 -0
  79. package/cjs/components/flex/export.js.map +1 -1
  80. package/cjs/components/flex/withChildren.d.ts +6 -0
  81. package/cjs/components/flex/withChildren.js +13 -0
  82. package/cjs/components/flex/withChildren.js.map +1 -0
  83. package/cjs/components/input/Input.d.ts +3 -2
  84. package/cjs/components/input/Input.js +3 -3
  85. package/cjs/components/input/Input.js.map +1 -1
  86. package/cjs/components/input/style/themes/dnb-input-theme-ui.css +2 -0
  87. package/cjs/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  88. package/cjs/components/input/style/themes/dnb-input-theme-ui.scss +2 -0
  89. package/cjs/components/input-masked/InputMaskedHooks.d.ts +1 -0
  90. package/cjs/components/input-masked/InputMaskedHooks.js +14 -9
  91. package/cjs/components/input-masked/InputMaskedHooks.js.map +1 -1
  92. package/cjs/components/input-masked/InputMaskedUtils.d.ts +4 -2
  93. package/cjs/components/input-masked/InputMaskedUtils.js +9 -7
  94. package/cjs/components/input-masked/InputMaskedUtils.js.map +1 -1
  95. package/cjs/components/input-masked/MultiInputMask.d.ts +1 -1
  96. package/cjs/components/input-masked/MultiInputMask.js +4 -2
  97. package/cjs/components/input-masked/MultiInputMask.js.map +1 -1
  98. package/cjs/components/input-masked/TextMask.js +15 -4
  99. package/cjs/components/input-masked/TextMask.js.map +1 -1
  100. package/cjs/components/input-masked/hooks/useHandleCursorPosition.js +7 -3
  101. package/cjs/components/input-masked/hooks/useHandleCursorPosition.js.map +1 -1
  102. package/cjs/components/input-masked/style/dnb-input-masked.css +3 -0
  103. package/cjs/components/input-masked/style/dnb-input-masked.min.css +1 -1
  104. package/cjs/components/input-masked/style/dnb-input-masked.scss +5 -0
  105. package/cjs/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  106. package/cjs/components/input-masked/text-mask/InputModeNumber.js +93 -0
  107. package/cjs/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  108. package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  109. package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  110. package/cjs/components/radio/RadioGroup.js +0 -1
  111. package/cjs/components/radio/RadioGroup.js.map +1 -1
  112. package/cjs/components/section/Section.d.ts +7 -0
  113. package/cjs/components/section/Section.js +11 -12
  114. package/cjs/components/section/Section.js.map +1 -1
  115. package/cjs/components/section/style/dnb-section.css +6 -4
  116. package/cjs/components/section/style/dnb-section.min.css +1 -1
  117. package/cjs/components/section/style/dnb-section.scss +7 -4
  118. package/cjs/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  119. package/cjs/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  120. package/cjs/components/textarea/Textarea.js +4 -9
  121. package/cjs/components/textarea/Textarea.js.map +1 -1
  122. package/cjs/components/textarea/style/dnb-textarea.css +5 -0
  123. package/cjs/components/textarea/style/dnb-textarea.min.css +1 -1
  124. package/cjs/components/textarea/style/dnb-textarea.scss +4 -0
  125. package/cjs/components/toggle-button/ToggleButtonGroup.js +0 -1
  126. package/cjs/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  127. package/cjs/components/toggle-button/style/dnb-toggle-button.css +4 -6
  128. package/cjs/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  129. package/cjs/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  130. package/cjs/components/tooltip/style/dnb-tooltip.css +1 -0
  131. package/cjs/components/tooltip/style/dnb-tooltip.min.css +1 -1
  132. package/cjs/components/tooltip/style/dnb-tooltip.scss +2 -0
  133. package/cjs/components/upload/types.d.ts +1 -1
  134. package/cjs/components/upload/types.js.map +1 -1
  135. package/cjs/extensions/forms/DataContext/Context.d.ts +1 -0
  136. package/cjs/extensions/forms/DataContext/Context.js +1 -0
  137. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  138. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  139. package/cjs/extensions/forms/DataContext/Provider/Provider.js +37 -13
  140. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  141. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  142. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  143. package/cjs/extensions/forms/Field/Currency/Currency.d.ts +1 -5
  144. package/cjs/extensions/forms/Field/Currency/Currency.js.map +1 -1
  145. package/cjs/extensions/forms/Field/Date/Date.d.ts +3 -1
  146. package/cjs/extensions/forms/Field/Date/Date.js +53 -10
  147. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  148. package/cjs/extensions/forms/Field/Email/Email.js +7 -5
  149. package/cjs/extensions/forms/Field/Email/Email.js.map +1 -1
  150. package/cjs/extensions/forms/Field/Expiry/Expiry.js +26 -4
  151. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  152. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  153. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  154. package/cjs/extensions/forms/Field/Number/Number.d.ts +5 -1
  155. package/cjs/extensions/forms/Field/Number/Number.js +112 -28
  156. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  157. package/cjs/extensions/forms/Field/Number/style/dnb-number.css +192 -0
  158. package/cjs/extensions/forms/Field/Number/style/dnb-number.min.css +1 -0
  159. package/cjs/extensions/forms/Field/Number/style/dnb-number.scss +176 -0
  160. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +74 -0
  161. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +3 -0
  162. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +81 -0
  163. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +15 -0
  164. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +5 -0
  165. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +15 -0
  166. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  167. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  168. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +67 -30
  169. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  170. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  171. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  172. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  173. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  174. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  175. package/cjs/extensions/forms/Field/Selection/Selection.js +59 -50
  176. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  177. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  178. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  179. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  180. package/cjs/extensions/forms/Field/String/String.d.ts +1 -0
  181. package/cjs/extensions/forms/Field/String/String.js +34 -9
  182. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  183. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +18 -20
  184. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  185. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +10 -1
  186. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  187. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +3 -1
  188. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  189. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  190. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  191. package/cjs/extensions/forms/Form/Handler/Handler.js +2 -2
  192. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  193. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  194. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  195. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  196. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  197. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  198. package/cjs/extensions/forms/{Visibility → Form/Visibility}/Visibility.d.ts +5 -2
  199. package/cjs/extensions/forms/{Visibility → Form/Visibility}/Visibility.js +8 -2
  200. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -0
  201. package/cjs/extensions/forms/Form/Visibility/index.js.map +1 -0
  202. package/cjs/extensions/forms/Form/index.d.ts +1 -0
  203. package/cjs/extensions/forms/Form/index.js +7 -0
  204. package/cjs/extensions/forms/Form/index.js.map +1 -1
  205. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  206. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  207. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  208. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  209. package/cjs/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  210. package/cjs/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  211. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  212. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  213. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  214. package/cjs/extensions/forms/hooks/useDataValue.d.ts +3 -0
  215. package/cjs/extensions/forms/hooks/useDataValue.js +96 -53
  216. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  217. package/cjs/extensions/forms/hooks/useId.d.ts +1 -0
  218. package/cjs/extensions/forms/hooks/useId.js +18 -0
  219. package/cjs/extensions/forms/hooks/useId.js.map +1 -0
  220. package/cjs/extensions/forms/index.d.ts +6 -1
  221. package/cjs/extensions/forms/index.js +5 -8
  222. package/cjs/extensions/forms/index.js.map +1 -1
  223. package/cjs/extensions/forms/style/dnb-forms.css +244 -25
  224. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  225. package/cjs/extensions/forms/types.d.ts +20 -8
  226. package/cjs/extensions/forms/types.js +1 -1
  227. package/cjs/extensions/forms/types.js.map +1 -1
  228. package/cjs/extensions/forms/utils/TestElement/TestElement.d.ts +5 -1
  229. package/cjs/extensions/forms/utils/TestElement/TestElement.js +1 -0
  230. package/cjs/extensions/forms/utils/TestElement/TestElement.js.map +1 -1
  231. package/cjs/icons/browser.d.ts +3 -0
  232. package/cjs/icons/browser.js +11 -0
  233. package/cjs/icons/browser.js.map +1 -0
  234. package/cjs/icons/browser_medium.d.ts +3 -0
  235. package/cjs/icons/browser_medium.js +11 -0
  236. package/cjs/icons/browser_medium.js.map +1 -0
  237. package/cjs/icons/digipass_corporate.d.ts +3 -0
  238. package/cjs/icons/digipass_corporate.js +11 -0
  239. package/cjs/icons/digipass_corporate.js.map +1 -0
  240. package/cjs/icons/digipass_corporate_medium.d.ts +3 -0
  241. package/cjs/icons/digipass_corporate_medium.js +11 -0
  242. package/cjs/icons/digipass_corporate_medium.js.map +1 -0
  243. package/cjs/icons/digipass_private.d.ts +3 -0
  244. package/cjs/icons/digipass_private.js +11 -0
  245. package/cjs/icons/digipass_private.js.map +1 -0
  246. package/cjs/icons/digipass_private_medium.d.ts +3 -0
  247. package/cjs/icons/digipass_private_medium.js +11 -0
  248. package/cjs/icons/digipass_private_medium.js.map +1 -0
  249. package/cjs/icons/dnb/browser.d.ts +3 -0
  250. package/cjs/icons/dnb/browser.js +25 -0
  251. package/cjs/icons/dnb/browser.js.map +1 -0
  252. package/cjs/icons/dnb/browser_medium.d.ts +3 -0
  253. package/cjs/icons/dnb/browser_medium.js +25 -0
  254. package/cjs/icons/dnb/browser_medium.js.map +1 -0
  255. package/cjs/icons/dnb/coins_1.js +1 -1
  256. package/cjs/icons/dnb/coins_1.js.map +1 -1
  257. package/cjs/icons/dnb/coins_1_medium.js +1 -1
  258. package/cjs/icons/dnb/coins_1_medium.js.map +1 -1
  259. package/cjs/icons/dnb/digipass_corporate.d.ts +3 -0
  260. package/cjs/icons/dnb/digipass_corporate.js +25 -0
  261. package/cjs/icons/dnb/digipass_corporate.js.map +1 -0
  262. package/cjs/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  263. package/cjs/icons/dnb/digipass_corporate_medium.js +25 -0
  264. package/cjs/icons/dnb/digipass_corporate_medium.js.map +1 -0
  265. package/cjs/icons/dnb/digipass_private.d.ts +3 -0
  266. package/cjs/icons/dnb/digipass_private.js +25 -0
  267. package/cjs/icons/dnb/digipass_private.js.map +1 -0
  268. package/cjs/icons/dnb/digipass_private_medium.d.ts +3 -0
  269. package/cjs/icons/dnb/digipass_private_medium.js +25 -0
  270. package/cjs/icons/dnb/digipass_private_medium.js.map +1 -0
  271. package/cjs/icons/dnb/envelope_open.d.ts +3 -0
  272. package/cjs/icons/dnb/envelope_open.js +26 -0
  273. package/cjs/icons/dnb/envelope_open.js.map +1 -0
  274. package/cjs/icons/dnb/envelope_open_medium.d.ts +3 -0
  275. package/cjs/icons/dnb/envelope_open_medium.js +26 -0
  276. package/cjs/icons/dnb/envelope_open_medium.js.map +1 -0
  277. package/cjs/icons/dnb/icons-meta.json +230 -20
  278. package/cjs/icons/dnb/icons-svg.lock +1272 -1064
  279. package/cjs/icons/dnb/index.d.ts +17 -1
  280. package/cjs/icons/dnb/index.js +112 -0
  281. package/cjs/icons/dnb/index.js.map +1 -1
  282. package/cjs/icons/dnb/laptop.d.ts +3 -0
  283. package/cjs/icons/dnb/laptop.js +26 -0
  284. package/cjs/icons/dnb/laptop.js.map +1 -0
  285. package/cjs/icons/dnb/laptop_medium.d.ts +3 -0
  286. package/cjs/icons/dnb/laptop_medium.js +26 -0
  287. package/cjs/icons/dnb/laptop_medium.js.map +1 -0
  288. package/cjs/icons/dnb/mobile.d.ts +3 -0
  289. package/cjs/icons/dnb/mobile.js +23 -0
  290. package/cjs/icons/dnb/mobile.js.map +1 -0
  291. package/cjs/icons/dnb/mobile_medium.d.ts +3 -0
  292. package/cjs/icons/dnb/mobile_medium.js +23 -0
  293. package/cjs/icons/dnb/mobile_medium.js.map +1 -0
  294. package/cjs/icons/dnb/money_left.d.ts +3 -0
  295. package/cjs/icons/dnb/money_left.js +25 -0
  296. package/cjs/icons/dnb/money_left.js.map +1 -0
  297. package/cjs/icons/dnb/money_left_medium.d.ts +3 -0
  298. package/cjs/icons/dnb/money_left_medium.js +26 -0
  299. package/cjs/icons/dnb/money_left_medium.js.map +1 -0
  300. package/cjs/icons/dnb/scan.js +5 -2
  301. package/cjs/icons/dnb/scan.js.map +1 -1
  302. package/cjs/icons/dnb/scan_medium.js +8 -12
  303. package/cjs/icons/dnb/scan_medium.js.map +1 -1
  304. package/cjs/icons/dnb/secondary_icons.d.ts +9 -1
  305. package/cjs/icons/dnb/secondary_icons.js +56 -0
  306. package/cjs/icons/dnb/secondary_icons.js.map +1 -1
  307. package/cjs/icons/dnb/secondary_icons_medium.d.ts +9 -1
  308. package/cjs/icons/dnb/secondary_icons_medium.js +56 -0
  309. package/cjs/icons/dnb/secondary_icons_medium.js.map +1 -1
  310. package/cjs/icons/dnb/teenager.d.ts +3 -0
  311. package/cjs/icons/dnb/teenager.js +26 -0
  312. package/cjs/icons/dnb/teenager.js.map +1 -0
  313. package/cjs/icons/dnb/teenager_medium.d.ts +3 -0
  314. package/cjs/icons/dnb/teenager_medium.js +26 -0
  315. package/cjs/icons/dnb/teenager_medium.js.map +1 -0
  316. package/cjs/icons/envelope_open.d.ts +3 -0
  317. package/cjs/icons/envelope_open.js +11 -0
  318. package/cjs/icons/envelope_open.js.map +1 -0
  319. package/cjs/icons/envelope_open_medium.d.ts +3 -0
  320. package/cjs/icons/envelope_open_medium.js +11 -0
  321. package/cjs/icons/envelope_open_medium.js.map +1 -0
  322. package/cjs/icons/index.d.ts +17 -1
  323. package/cjs/icons/index.js +112 -0
  324. package/cjs/icons/index.js.map +1 -1
  325. package/cjs/icons/laptop.d.ts +3 -0
  326. package/cjs/icons/laptop.js +11 -0
  327. package/cjs/icons/laptop.js.map +1 -0
  328. package/cjs/icons/laptop_medium.d.ts +3 -0
  329. package/cjs/icons/laptop_medium.js +11 -0
  330. package/cjs/icons/laptop_medium.js.map +1 -0
  331. package/cjs/icons/mobile.d.ts +3 -0
  332. package/cjs/icons/mobile.js +11 -0
  333. package/cjs/icons/mobile.js.map +1 -0
  334. package/cjs/icons/mobile_medium.d.ts +3 -0
  335. package/cjs/icons/mobile_medium.js +11 -0
  336. package/cjs/icons/mobile_medium.js.map +1 -0
  337. package/cjs/icons/money_left.d.ts +3 -0
  338. package/cjs/icons/money_left.js +11 -0
  339. package/cjs/icons/money_left.js.map +1 -0
  340. package/cjs/icons/money_left_medium.d.ts +3 -0
  341. package/cjs/icons/money_left_medium.js +11 -0
  342. package/cjs/icons/money_left_medium.js.map +1 -0
  343. package/cjs/icons/teenager.d.ts +3 -0
  344. package/cjs/icons/teenager.js +11 -0
  345. package/cjs/icons/teenager.js.map +1 -0
  346. package/cjs/icons/teenager_medium.d.ts +3 -0
  347. package/cjs/icons/teenager_medium.js +11 -0
  348. package/cjs/icons/teenager_medium.js.map +1 -0
  349. package/cjs/shared/Eufemia.d.ts +1 -1
  350. package/cjs/shared/Eufemia.js +2 -2
  351. package/cjs/shared/Eufemia.js.map +1 -1
  352. package/cjs/shared/component-helper.d.ts +1 -0
  353. package/cjs/shared/component-helper.js +6 -1
  354. package/cjs/shared/component-helper.js.map +1 -1
  355. package/cjs/style/core/utilities.scss +1 -2
  356. package/cjs/style/dnb-ui-components.css +304 -79
  357. package/cjs/style/dnb-ui-components.min.css +3 -3
  358. package/cjs/style/dnb-ui-extensions.css +244 -25
  359. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  360. package/cjs/style/dnb-ui-forms.css +244 -25
  361. package/cjs/style/dnb-ui-forms.min.css +1 -1
  362. package/cjs/style/dnb-ui-forms.scss +1 -0
  363. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  364. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  365. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +636 -113
  366. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +10 -6
  367. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  368. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  369. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  370. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +260 -25
  371. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +5 -1
  372. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  373. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +260 -26
  374. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +5 -1
  375. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.scss +2 -0
  376. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +664 -107
  377. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -6
  378. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  379. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +319 -25
  380. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +3 -1
  381. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  382. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +319 -26
  383. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +3 -1
  384. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.scss +2 -0
  385. package/cjs/style/themes/theme-ui/ui-theme-basis.css +14 -2
  386. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  387. package/cjs/style/themes/theme-ui/ui-theme-components.css +634 -113
  388. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +10 -6
  389. package/cjs/style/themes/theme-ui/ui-theme-components.scss +1 -0
  390. package/cjs/style/themes/theme-ui/ui-theme-elements.css +14 -2
  391. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  392. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +260 -25
  393. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +5 -1
  394. package/cjs/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  395. package/cjs/style/themes/theme-ui/ui-theme-forms.css +260 -26
  396. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +5 -1
  397. package/cjs/style/themes/theme-ui/ui-theme-forms.scss +2 -0
  398. package/cjs/style/themes/theme-ui/ui-theme-tags.css +11 -13
  399. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  400. package/components/anchor/Anchor.js +9 -5
  401. package/components/anchor/Anchor.js.map +1 -1
  402. package/components/anchor/style/anchor-mixins.scss +8 -17
  403. package/components/anchor/style/dnb-anchor.css +28 -24
  404. package/components/anchor/style/dnb-anchor.min.css +1 -1
  405. package/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +16 -4
  406. package/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  407. package/components/anchor/style/themes/dnb-anchor-theme-ui.css +16 -4
  408. package/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  409. package/components/anchor/style/themes/dnb-anchor-theme-ui.scss +10 -2
  410. package/components/autocomplete/Autocomplete.js +2 -2
  411. package/components/autocomplete/Autocomplete.js.map +1 -1
  412. package/components/button/style/dnb-button.css +13 -0
  413. package/components/button/style/dnb-button.min.css +1 -1
  414. package/components/button/style/dnb-button.scss +16 -0
  415. package/components/button/style/themes/dnb-button-theme-eiendom.css +12 -1
  416. package/components/button/style/themes/dnb-button-theme-eiendom.min.css +1 -1
  417. package/components/button/style/themes/dnb-button-theme-sbanken.css +12 -0
  418. package/components/button/style/themes/dnb-button-theme-sbanken.min.css +2 -2
  419. package/components/button/style/themes/dnb-button-theme-sbanken.scss +10 -0
  420. package/components/button/style/themes/dnb-button-theme-ui.css +12 -1
  421. package/components/button/style/themes/dnb-button-theme-ui.min.css +1 -1
  422. package/components/button/style/themes/dnb-button-theme-ui.scss +12 -3
  423. package/components/card/Card.d.ts +1 -1
  424. package/components/card/Card.js +46 -9
  425. package/components/card/Card.js.map +1 -1
  426. package/components/card/style/dnb-card.css +0 -20
  427. package/components/card/style/dnb-card.min.css +1 -1
  428. package/components/card/style/dnb-card.scss +0 -20
  429. package/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  430. package/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  431. package/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  432. package/components/date-picker/DatePicker.d.ts +18 -1
  433. package/components/date-picker/DatePicker.js +4 -3
  434. package/components/date-picker/DatePicker.js.map +1 -1
  435. package/components/date-picker/DatePickerCalc.js +2 -1
  436. package/components/date-picker/DatePickerCalc.js.map +1 -1
  437. package/components/date-picker/DatePickerInput.d.ts +3 -0
  438. package/components/date-picker/DatePickerInput.js +27 -6
  439. package/components/date-picker/DatePickerInput.js.map +1 -1
  440. package/components/date-picker/DatePickerProvider.js +2 -2
  441. package/components/date-picker/DatePickerProvider.js.map +1 -1
  442. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  443. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  444. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  445. package/components/dropdown/Dropdown.js +3 -2
  446. package/components/dropdown/Dropdown.js.map +1 -1
  447. package/components/flex/Container.d.ts +2 -4
  448. package/components/flex/Container.js +11 -2
  449. package/components/flex/Container.js.map +1 -1
  450. package/components/flex/Item.d.ts +2 -3
  451. package/components/flex/Item.js +2 -1
  452. package/components/flex/Item.js.map +1 -1
  453. package/components/flex/export.d.ts +1 -0
  454. package/components/flex/export.js +1 -0
  455. package/components/flex/export.js.map +1 -1
  456. package/components/flex/withChildren.d.ts +6 -0
  457. package/components/flex/withChildren.js +6 -0
  458. package/components/flex/withChildren.js.map +1 -0
  459. package/components/input/Input.d.ts +3 -2
  460. package/components/input/Input.js +3 -3
  461. package/components/input/Input.js.map +1 -1
  462. package/components/input/style/themes/dnb-input-theme-ui.css +2 -0
  463. package/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  464. package/components/input/style/themes/dnb-input-theme-ui.scss +2 -0
  465. package/components/input-masked/InputMaskedHooks.d.ts +1 -0
  466. package/components/input-masked/InputMaskedHooks.js +15 -10
  467. package/components/input-masked/InputMaskedHooks.js.map +1 -1
  468. package/components/input-masked/InputMaskedUtils.d.ts +4 -2
  469. package/components/input-masked/InputMaskedUtils.js +9 -7
  470. package/components/input-masked/InputMaskedUtils.js.map +1 -1
  471. package/components/input-masked/MultiInputMask.d.ts +1 -1
  472. package/components/input-masked/MultiInputMask.js +4 -2
  473. package/components/input-masked/MultiInputMask.js.map +1 -1
  474. package/components/input-masked/TextMask.js +15 -4
  475. package/components/input-masked/TextMask.js.map +1 -1
  476. package/components/input-masked/hooks/useHandleCursorPosition.js +7 -3
  477. package/components/input-masked/hooks/useHandleCursorPosition.js.map +1 -1
  478. package/components/input-masked/style/dnb-input-masked.css +3 -0
  479. package/components/input-masked/style/dnb-input-masked.min.css +1 -1
  480. package/components/input-masked/style/dnb-input-masked.scss +5 -0
  481. package/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  482. package/components/input-masked/text-mask/InputModeNumber.js +84 -0
  483. package/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  484. package/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  485. package/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  486. package/components/radio/RadioGroup.js +0 -1
  487. package/components/radio/RadioGroup.js.map +1 -1
  488. package/components/section/Section.d.ts +7 -0
  489. package/components/section/Section.js +10 -12
  490. package/components/section/Section.js.map +1 -1
  491. package/components/section/style/dnb-section.css +6 -4
  492. package/components/section/style/dnb-section.min.css +1 -1
  493. package/components/section/style/dnb-section.scss +7 -4
  494. package/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  495. package/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  496. package/components/textarea/Textarea.js +4 -9
  497. package/components/textarea/Textarea.js.map +1 -1
  498. package/components/textarea/style/dnb-textarea.css +5 -0
  499. package/components/textarea/style/dnb-textarea.min.css +1 -1
  500. package/components/textarea/style/dnb-textarea.scss +4 -0
  501. package/components/toggle-button/ToggleButtonGroup.js +0 -1
  502. package/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  503. package/components/toggle-button/style/dnb-toggle-button.css +4 -6
  504. package/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  505. package/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  506. package/components/tooltip/style/dnb-tooltip.css +1 -0
  507. package/components/tooltip/style/dnb-tooltip.min.css +1 -1
  508. package/components/tooltip/style/dnb-tooltip.scss +2 -0
  509. package/components/upload/types.d.ts +1 -1
  510. package/components/upload/types.js.map +1 -1
  511. package/es/components/anchor/Anchor.js +9 -5
  512. package/es/components/anchor/Anchor.js.map +1 -1
  513. package/es/components/anchor/style/anchor-mixins.scss +8 -17
  514. package/es/components/anchor/style/dnb-anchor.css +28 -24
  515. package/es/components/anchor/style/dnb-anchor.min.css +1 -1
  516. package/es/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +16 -4
  517. package/es/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  518. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.css +16 -4
  519. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  520. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.scss +10 -2
  521. package/es/components/autocomplete/Autocomplete.js +2 -2
  522. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  523. package/es/components/button/style/dnb-button.css +13 -0
  524. package/es/components/button/style/dnb-button.min.css +1 -1
  525. package/es/components/button/style/dnb-button.scss +16 -0
  526. package/es/components/button/style/themes/dnb-button-theme-eiendom.css +12 -1
  527. package/es/components/button/style/themes/dnb-button-theme-eiendom.min.css +1 -1
  528. package/es/components/button/style/themes/dnb-button-theme-sbanken.css +12 -0
  529. package/es/components/button/style/themes/dnb-button-theme-sbanken.min.css +2 -2
  530. package/es/components/button/style/themes/dnb-button-theme-sbanken.scss +10 -0
  531. package/es/components/button/style/themes/dnb-button-theme-ui.css +12 -1
  532. package/es/components/button/style/themes/dnb-button-theme-ui.min.css +1 -1
  533. package/es/components/button/style/themes/dnb-button-theme-ui.scss +12 -3
  534. package/es/components/card/Card.d.ts +1 -1
  535. package/es/components/card/Card.js +46 -9
  536. package/es/components/card/Card.js.map +1 -1
  537. package/es/components/card/style/dnb-card.css +0 -20
  538. package/es/components/card/style/dnb-card.min.css +1 -1
  539. package/es/components/card/style/dnb-card.scss +0 -20
  540. package/es/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  541. package/es/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  542. package/es/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  543. package/es/components/date-picker/DatePicker.d.ts +18 -1
  544. package/es/components/date-picker/DatePicker.js +4 -3
  545. package/es/components/date-picker/DatePicker.js.map +1 -1
  546. package/es/components/date-picker/DatePickerCalc.js +2 -1
  547. package/es/components/date-picker/DatePickerCalc.js.map +1 -1
  548. package/es/components/date-picker/DatePickerInput.d.ts +3 -0
  549. package/es/components/date-picker/DatePickerInput.js +27 -6
  550. package/es/components/date-picker/DatePickerInput.js.map +1 -1
  551. package/es/components/date-picker/DatePickerProvider.js +2 -2
  552. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  553. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  554. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  555. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  556. package/es/components/dropdown/Dropdown.js +3 -2
  557. package/es/components/dropdown/Dropdown.js.map +1 -1
  558. package/es/components/flex/Container.d.ts +2 -4
  559. package/es/components/flex/Container.js +11 -2
  560. package/es/components/flex/Container.js.map +1 -1
  561. package/es/components/flex/Item.d.ts +2 -3
  562. package/es/components/flex/Item.js +2 -1
  563. package/es/components/flex/Item.js.map +1 -1
  564. package/es/components/flex/export.d.ts +1 -0
  565. package/es/components/flex/export.js +1 -0
  566. package/es/components/flex/export.js.map +1 -1
  567. package/es/components/flex/withChildren.d.ts +6 -0
  568. package/es/components/flex/withChildren.js +6 -0
  569. package/es/components/flex/withChildren.js.map +1 -0
  570. package/es/components/input/Input.d.ts +3 -2
  571. package/es/components/input/Input.js +3 -3
  572. package/es/components/input/Input.js.map +1 -1
  573. package/es/components/input/style/themes/dnb-input-theme-ui.css +2 -0
  574. package/es/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  575. package/es/components/input/style/themes/dnb-input-theme-ui.scss +2 -0
  576. package/es/components/input-masked/InputMaskedHooks.d.ts +1 -0
  577. package/es/components/input-masked/InputMaskedHooks.js +15 -10
  578. package/es/components/input-masked/InputMaskedHooks.js.map +1 -1
  579. package/es/components/input-masked/InputMaskedUtils.d.ts +4 -2
  580. package/es/components/input-masked/InputMaskedUtils.js +9 -7
  581. package/es/components/input-masked/InputMaskedUtils.js.map +1 -1
  582. package/es/components/input-masked/MultiInputMask.d.ts +1 -1
  583. package/es/components/input-masked/MultiInputMask.js +4 -2
  584. package/es/components/input-masked/MultiInputMask.js.map +1 -1
  585. package/es/components/input-masked/TextMask.js +15 -4
  586. package/es/components/input-masked/TextMask.js.map +1 -1
  587. package/es/components/input-masked/hooks/useHandleCursorPosition.js +7 -3
  588. package/es/components/input-masked/hooks/useHandleCursorPosition.js.map +1 -1
  589. package/es/components/input-masked/style/dnb-input-masked.css +3 -0
  590. package/es/components/input-masked/style/dnb-input-masked.min.css +1 -1
  591. package/es/components/input-masked/style/dnb-input-masked.scss +5 -0
  592. package/es/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  593. package/es/components/input-masked/text-mask/InputModeNumber.js +84 -0
  594. package/es/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  595. package/es/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  596. package/es/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  597. package/es/components/radio/RadioGroup.js +0 -1
  598. package/es/components/radio/RadioGroup.js.map +1 -1
  599. package/es/components/section/Section.d.ts +7 -0
  600. package/es/components/section/Section.js +10 -12
  601. package/es/components/section/Section.js.map +1 -1
  602. package/es/components/section/style/dnb-section.css +6 -4
  603. package/es/components/section/style/dnb-section.min.css +1 -1
  604. package/es/components/section/style/dnb-section.scss +7 -4
  605. package/es/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  606. package/es/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  607. package/es/components/textarea/Textarea.js +4 -9
  608. package/es/components/textarea/Textarea.js.map +1 -1
  609. package/es/components/textarea/style/dnb-textarea.css +5 -0
  610. package/es/components/textarea/style/dnb-textarea.min.css +1 -1
  611. package/es/components/textarea/style/dnb-textarea.scss +4 -0
  612. package/es/components/toggle-button/ToggleButtonGroup.js +0 -1
  613. package/es/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  614. package/es/components/toggle-button/style/dnb-toggle-button.css +4 -6
  615. package/es/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  616. package/es/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  617. package/es/components/tooltip/style/dnb-tooltip.css +1 -0
  618. package/es/components/tooltip/style/dnb-tooltip.min.css +1 -1
  619. package/es/components/tooltip/style/dnb-tooltip.scss +2 -0
  620. package/es/components/upload/types.d.ts +1 -1
  621. package/es/components/upload/types.js.map +1 -1
  622. package/es/extensions/forms/DataContext/Context.d.ts +1 -0
  623. package/es/extensions/forms/DataContext/Context.js +1 -0
  624. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  625. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  626. package/es/extensions/forms/DataContext/Provider/Provider.js +37 -13
  627. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  628. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  629. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  630. package/es/extensions/forms/Field/Currency/Currency.d.ts +1 -5
  631. package/es/extensions/forms/Field/Currency/Currency.js.map +1 -1
  632. package/es/extensions/forms/Field/Date/Date.d.ts +3 -1
  633. package/es/extensions/forms/Field/Date/Date.js +51 -9
  634. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  635. package/es/extensions/forms/Field/Email/Email.js +7 -5
  636. package/es/extensions/forms/Field/Email/Email.js.map +1 -1
  637. package/es/extensions/forms/Field/Expiry/Expiry.js +26 -4
  638. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  639. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  640. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  641. package/es/extensions/forms/Field/Number/Number.d.ts +5 -1
  642. package/es/extensions/forms/Field/Number/Number.js +112 -29
  643. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  644. package/es/extensions/forms/Field/Number/style/dnb-number.css +192 -0
  645. package/es/extensions/forms/Field/Number/style/dnb-number.min.css +1 -0
  646. package/es/extensions/forms/Field/Number/style/dnb-number.scss +176 -0
  647. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +74 -0
  648. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +3 -0
  649. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +81 -0
  650. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +15 -0
  651. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +5 -0
  652. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +15 -0
  653. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  654. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  655. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +57 -21
  656. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  657. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  658. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  659. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  660. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  661. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  662. package/es/extensions/forms/Field/Selection/Selection.js +58 -50
  663. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  664. package/es/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  665. package/es/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  666. package/es/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  667. package/es/extensions/forms/Field/String/String.d.ts +1 -0
  668. package/es/extensions/forms/Field/String/String.js +34 -8
  669. package/es/extensions/forms/Field/String/String.js.map +1 -1
  670. package/es/extensions/forms/FieldBlock/FieldBlock.js +16 -17
  671. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  672. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +10 -1
  673. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  674. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +3 -1
  675. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  676. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  677. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  678. package/es/extensions/forms/Form/Handler/Handler.js +2 -2
  679. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  680. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  681. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  682. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  683. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  684. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  685. package/{extensions/forms → es/extensions/forms/Form}/Visibility/Visibility.d.ts +5 -2
  686. package/es/extensions/forms/{Visibility → Form/Visibility}/Visibility.js +8 -2
  687. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -0
  688. package/es/extensions/forms/Form/Visibility/index.js.map +1 -0
  689. package/es/extensions/forms/Form/index.d.ts +1 -0
  690. package/es/extensions/forms/Form/index.js +1 -0
  691. package/es/extensions/forms/Form/index.js.map +1 -1
  692. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  693. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  694. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  695. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  696. package/es/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  697. package/es/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  698. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  699. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  700. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  701. package/es/extensions/forms/hooks/useDataValue.d.ts +3 -0
  702. package/es/extensions/forms/hooks/useDataValue.js +91 -49
  703. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  704. package/es/extensions/forms/hooks/useId.d.ts +1 -0
  705. package/es/extensions/forms/hooks/useId.js +11 -0
  706. package/es/extensions/forms/hooks/useId.js.map +1 -0
  707. package/es/extensions/forms/index.d.ts +6 -1
  708. package/es/extensions/forms/index.js +3 -1
  709. package/es/extensions/forms/index.js.map +1 -1
  710. package/es/extensions/forms/style/dnb-forms.css +244 -25
  711. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  712. package/es/extensions/forms/types.d.ts +20 -8
  713. package/es/extensions/forms/types.js +1 -1
  714. package/es/extensions/forms/types.js.map +1 -1
  715. package/es/extensions/forms/utils/TestElement/TestElement.d.ts +5 -1
  716. package/es/extensions/forms/utils/TestElement/TestElement.js +1 -0
  717. package/es/extensions/forms/utils/TestElement/TestElement.js.map +1 -1
  718. package/es/icons/browser.d.ts +3 -0
  719. package/es/icons/browser.js +3 -0
  720. package/es/icons/browser.js.map +1 -0
  721. package/es/icons/browser_medium.d.ts +3 -0
  722. package/es/icons/browser_medium.js +3 -0
  723. package/es/icons/browser_medium.js.map +1 -0
  724. package/es/icons/digipass_corporate.d.ts +3 -0
  725. package/es/icons/digipass_corporate.js +3 -0
  726. package/es/icons/digipass_corporate.js.map +1 -0
  727. package/es/icons/digipass_corporate_medium.d.ts +3 -0
  728. package/es/icons/digipass_corporate_medium.js +3 -0
  729. package/es/icons/digipass_corporate_medium.js.map +1 -0
  730. package/es/icons/digipass_private.d.ts +3 -0
  731. package/es/icons/digipass_private.js +3 -0
  732. package/es/icons/digipass_private.js.map +1 -0
  733. package/es/icons/digipass_private_medium.d.ts +3 -0
  734. package/es/icons/digipass_private_medium.js +3 -0
  735. package/es/icons/digipass_private_medium.js.map +1 -0
  736. package/es/icons/dnb/browser.d.ts +3 -0
  737. package/es/icons/dnb/browser.js +17 -0
  738. package/es/icons/dnb/browser.js.map +1 -0
  739. package/es/icons/dnb/browser_medium.d.ts +3 -0
  740. package/es/icons/dnb/browser_medium.js +17 -0
  741. package/es/icons/dnb/browser_medium.js.map +1 -0
  742. package/es/icons/dnb/coins_1.js +1 -1
  743. package/es/icons/dnb/coins_1.js.map +1 -1
  744. package/es/icons/dnb/coins_1_medium.js +1 -1
  745. package/es/icons/dnb/coins_1_medium.js.map +1 -1
  746. package/es/icons/dnb/digipass_corporate.d.ts +3 -0
  747. package/es/icons/dnb/digipass_corporate.js +17 -0
  748. package/es/icons/dnb/digipass_corporate.js.map +1 -0
  749. package/es/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  750. package/es/icons/dnb/digipass_corporate_medium.js +17 -0
  751. package/es/icons/dnb/digipass_corporate_medium.js.map +1 -0
  752. package/es/icons/dnb/digipass_private.d.ts +3 -0
  753. package/es/icons/dnb/digipass_private.js +17 -0
  754. package/es/icons/dnb/digipass_private.js.map +1 -0
  755. package/es/icons/dnb/digipass_private_medium.d.ts +3 -0
  756. package/es/icons/dnb/digipass_private_medium.js +17 -0
  757. package/es/icons/dnb/digipass_private_medium.js.map +1 -0
  758. package/es/icons/dnb/envelope_open.d.ts +3 -0
  759. package/es/icons/dnb/envelope_open.js +18 -0
  760. package/es/icons/dnb/envelope_open.js.map +1 -0
  761. package/es/icons/dnb/envelope_open_medium.d.ts +3 -0
  762. package/es/icons/dnb/envelope_open_medium.js +18 -0
  763. package/es/icons/dnb/envelope_open_medium.js.map +1 -0
  764. package/es/icons/dnb/icons-meta.json +230 -20
  765. package/es/icons/dnb/icons-svg.lock +1272 -1064
  766. package/es/icons/dnb/index.d.ts +17 -1
  767. package/es/icons/dnb/index.js +17 -1
  768. package/es/icons/dnb/index.js.map +1 -1
  769. package/es/icons/dnb/laptop.d.ts +3 -0
  770. package/es/icons/dnb/laptop.js +18 -0
  771. package/es/icons/dnb/laptop.js.map +1 -0
  772. package/es/icons/dnb/laptop_medium.d.ts +3 -0
  773. package/es/icons/dnb/laptop_medium.js +18 -0
  774. package/es/icons/dnb/laptop_medium.js.map +1 -0
  775. package/es/icons/dnb/mobile.d.ts +3 -0
  776. package/es/icons/dnb/mobile.js +15 -0
  777. package/es/icons/dnb/mobile.js.map +1 -0
  778. package/es/icons/dnb/mobile_medium.d.ts +3 -0
  779. package/es/icons/dnb/mobile_medium.js +15 -0
  780. package/es/icons/dnb/mobile_medium.js.map +1 -0
  781. package/es/icons/dnb/money_left.d.ts +3 -0
  782. package/es/icons/dnb/money_left.js +17 -0
  783. package/es/icons/dnb/money_left.js.map +1 -0
  784. package/es/icons/dnb/money_left_medium.d.ts +3 -0
  785. package/es/icons/dnb/money_left_medium.js +18 -0
  786. package/es/icons/dnb/money_left_medium.js.map +1 -0
  787. package/es/icons/dnb/scan.js +5 -2
  788. package/es/icons/dnb/scan.js.map +1 -1
  789. package/es/icons/dnb/scan_medium.js +8 -12
  790. package/es/icons/dnb/scan_medium.js.map +1 -1
  791. package/es/icons/dnb/secondary_icons.d.ts +9 -1
  792. package/es/icons/dnb/secondary_icons.js +9 -1
  793. package/es/icons/dnb/secondary_icons.js.map +1 -1
  794. package/es/icons/dnb/secondary_icons_medium.d.ts +9 -1
  795. package/es/icons/dnb/secondary_icons_medium.js +9 -1
  796. package/es/icons/dnb/secondary_icons_medium.js.map +1 -1
  797. package/es/icons/dnb/teenager.d.ts +3 -0
  798. package/es/icons/dnb/teenager.js +18 -0
  799. package/es/icons/dnb/teenager.js.map +1 -0
  800. package/es/icons/dnb/teenager_medium.d.ts +3 -0
  801. package/es/icons/dnb/teenager_medium.js +18 -0
  802. package/es/icons/dnb/teenager_medium.js.map +1 -0
  803. package/es/icons/envelope_open.d.ts +3 -0
  804. package/es/icons/envelope_open.js +3 -0
  805. package/es/icons/envelope_open.js.map +1 -0
  806. package/es/icons/envelope_open_medium.d.ts +3 -0
  807. package/es/icons/envelope_open_medium.js +3 -0
  808. package/es/icons/envelope_open_medium.js.map +1 -0
  809. package/es/icons/index.d.ts +17 -1
  810. package/es/icons/index.js +17 -1
  811. package/es/icons/index.js.map +1 -1
  812. package/es/icons/laptop.d.ts +3 -0
  813. package/es/icons/laptop.js +3 -0
  814. package/es/icons/laptop.js.map +1 -0
  815. package/es/icons/laptop_medium.d.ts +3 -0
  816. package/es/icons/laptop_medium.js +3 -0
  817. package/es/icons/laptop_medium.js.map +1 -0
  818. package/es/icons/mobile.d.ts +3 -0
  819. package/es/icons/mobile.js +3 -0
  820. package/es/icons/mobile.js.map +1 -0
  821. package/es/icons/mobile_medium.d.ts +3 -0
  822. package/es/icons/mobile_medium.js +3 -0
  823. package/es/icons/mobile_medium.js.map +1 -0
  824. package/es/icons/money_left.d.ts +3 -0
  825. package/es/icons/money_left.js +3 -0
  826. package/es/icons/money_left.js.map +1 -0
  827. package/es/icons/money_left_medium.d.ts +3 -0
  828. package/es/icons/money_left_medium.js +3 -0
  829. package/es/icons/money_left_medium.js.map +1 -0
  830. package/es/icons/teenager.d.ts +3 -0
  831. package/es/icons/teenager.js +3 -0
  832. package/es/icons/teenager.js.map +1 -0
  833. package/es/icons/teenager_medium.d.ts +3 -0
  834. package/es/icons/teenager_medium.js +3 -0
  835. package/es/icons/teenager_medium.js.map +1 -0
  836. package/es/shared/Eufemia.d.ts +1 -1
  837. package/es/shared/Eufemia.js +2 -2
  838. package/es/shared/Eufemia.js.map +1 -1
  839. package/es/shared/component-helper.d.ts +1 -0
  840. package/es/shared/component-helper.js +3 -0
  841. package/es/shared/component-helper.js.map +1 -1
  842. package/es/style/core/utilities.scss +1 -2
  843. package/es/style/dnb-ui-components.css +304 -79
  844. package/es/style/dnb-ui-components.min.css +3 -3
  845. package/es/style/dnb-ui-extensions.css +244 -25
  846. package/es/style/dnb-ui-extensions.min.css +1 -1
  847. package/es/style/dnb-ui-forms.css +244 -25
  848. package/es/style/dnb-ui-forms.min.css +1 -1
  849. package/es/style/dnb-ui-forms.scss +1 -0
  850. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  851. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  852. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +636 -113
  853. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +10 -6
  854. package/es/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  855. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  856. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  857. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +260 -25
  858. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +5 -1
  859. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  860. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +260 -26
  861. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +5 -1
  862. package/es/style/themes/theme-eiendom/eiendom-theme-forms.scss +2 -0
  863. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +664 -107
  864. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -6
  865. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  866. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +319 -25
  867. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +3 -1
  868. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  869. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +319 -26
  870. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +3 -1
  871. package/es/style/themes/theme-sbanken/sbanken-theme-forms.scss +2 -0
  872. package/es/style/themes/theme-ui/ui-theme-basis.css +14 -2
  873. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  874. package/es/style/themes/theme-ui/ui-theme-components.css +634 -113
  875. package/es/style/themes/theme-ui/ui-theme-components.min.css +10 -6
  876. package/es/style/themes/theme-ui/ui-theme-components.scss +1 -0
  877. package/es/style/themes/theme-ui/ui-theme-elements.css +14 -2
  878. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  879. package/es/style/themes/theme-ui/ui-theme-extensions.css +260 -25
  880. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +5 -1
  881. package/es/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  882. package/es/style/themes/theme-ui/ui-theme-forms.css +260 -26
  883. package/es/style/themes/theme-ui/ui-theme-forms.min.css +5 -1
  884. package/es/style/themes/theme-ui/ui-theme-forms.scss +2 -0
  885. package/es/style/themes/theme-ui/ui-theme-tags.css +11 -13
  886. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  887. package/esm/dnb-ui-basis.min.mjs +1 -1
  888. package/esm/dnb-ui-components.min.mjs +1 -1
  889. package/esm/dnb-ui-elements.min.mjs +1 -1
  890. package/esm/dnb-ui-extensions.min.mjs +3 -3
  891. package/esm/dnb-ui-lib.min.mjs +1 -1
  892. package/extensions/forms/DataContext/Context.d.ts +1 -0
  893. package/extensions/forms/DataContext/Context.js +1 -0
  894. package/extensions/forms/DataContext/Context.js.map +1 -1
  895. package/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  896. package/extensions/forms/DataContext/Provider/Provider.js +37 -13
  897. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  898. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  899. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  900. package/extensions/forms/Field/Currency/Currency.d.ts +1 -5
  901. package/extensions/forms/Field/Currency/Currency.js.map +1 -1
  902. package/extensions/forms/Field/Date/Date.d.ts +3 -1
  903. package/extensions/forms/Field/Date/Date.js +54 -11
  904. package/extensions/forms/Field/Date/Date.js.map +1 -1
  905. package/extensions/forms/Field/Email/Email.js +7 -5
  906. package/extensions/forms/Field/Email/Email.js.map +1 -1
  907. package/extensions/forms/Field/Expiry/Expiry.js +26 -4
  908. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  909. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  910. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  911. package/extensions/forms/Field/Number/Number.d.ts +5 -1
  912. package/extensions/forms/Field/Number/Number.js +113 -29
  913. package/extensions/forms/Field/Number/Number.js.map +1 -1
  914. package/extensions/forms/Field/Number/style/dnb-number.css +192 -0
  915. package/extensions/forms/Field/Number/style/dnb-number.min.css +1 -0
  916. package/extensions/forms/Field/Number/style/dnb-number.scss +176 -0
  917. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +74 -0
  918. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +3 -0
  919. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +81 -0
  920. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +15 -0
  921. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +5 -0
  922. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +15 -0
  923. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  924. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  925. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +68 -31
  926. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  927. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  928. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  929. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  930. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  931. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  932. package/extensions/forms/Field/Selection/Selection.js +58 -50
  933. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  934. package/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  935. package/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  936. package/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  937. package/extensions/forms/Field/String/String.d.ts +1 -0
  938. package/extensions/forms/Field/String/String.js +34 -9
  939. package/extensions/forms/Field/String/String.js.map +1 -1
  940. package/extensions/forms/FieldBlock/FieldBlock.js +18 -20
  941. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  942. package/extensions/forms/FieldBlock/style/dnb-field-block.css +10 -1
  943. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  944. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +3 -1
  945. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  946. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  947. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  948. package/extensions/forms/Form/Handler/Handler.js +2 -2
  949. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  950. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  951. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  952. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  953. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  954. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  955. package/{es/extensions/forms → extensions/forms/Form}/Visibility/Visibility.d.ts +5 -2
  956. package/extensions/forms/{Visibility → Form/Visibility}/Visibility.js +8 -2
  957. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -0
  958. package/extensions/forms/Form/Visibility/index.js.map +1 -0
  959. package/extensions/forms/Form/index.d.ts +1 -0
  960. package/extensions/forms/Form/index.js +1 -0
  961. package/extensions/forms/Form/index.js.map +1 -1
  962. package/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  963. package/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  964. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  965. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  966. package/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  967. package/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  968. package/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  969. package/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  970. package/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  971. package/extensions/forms/hooks/useDataValue.d.ts +3 -0
  972. package/extensions/forms/hooks/useDataValue.js +96 -53
  973. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  974. package/extensions/forms/hooks/useId.d.ts +1 -0
  975. package/extensions/forms/hooks/useId.js +11 -0
  976. package/extensions/forms/hooks/useId.js.map +1 -0
  977. package/extensions/forms/index.d.ts +6 -1
  978. package/extensions/forms/index.js +3 -1
  979. package/extensions/forms/index.js.map +1 -1
  980. package/extensions/forms/style/dnb-forms.css +244 -25
  981. package/extensions/forms/style/dnb-forms.min.css +1 -1
  982. package/extensions/forms/types.d.ts +20 -8
  983. package/extensions/forms/types.js +1 -1
  984. package/extensions/forms/types.js.map +1 -1
  985. package/extensions/forms/utils/TestElement/TestElement.d.ts +5 -1
  986. package/extensions/forms/utils/TestElement/TestElement.js +1 -0
  987. package/extensions/forms/utils/TestElement/TestElement.js.map +1 -1
  988. package/icons/browser.d.ts +3 -0
  989. package/icons/browser.js +3 -0
  990. package/icons/browser.js.map +1 -0
  991. package/icons/browser_medium.d.ts +3 -0
  992. package/icons/browser_medium.js +3 -0
  993. package/icons/browser_medium.js.map +1 -0
  994. package/icons/digipass_corporate.d.ts +3 -0
  995. package/icons/digipass_corporate.js +3 -0
  996. package/icons/digipass_corporate.js.map +1 -0
  997. package/icons/digipass_corporate_medium.d.ts +3 -0
  998. package/icons/digipass_corporate_medium.js +3 -0
  999. package/icons/digipass_corporate_medium.js.map +1 -0
  1000. package/icons/digipass_private.d.ts +3 -0
  1001. package/icons/digipass_private.js +3 -0
  1002. package/icons/digipass_private.js.map +1 -0
  1003. package/icons/digipass_private_medium.d.ts +3 -0
  1004. package/icons/digipass_private_medium.js +3 -0
  1005. package/icons/digipass_private_medium.js.map +1 -0
  1006. package/icons/dnb/browser.d.ts +3 -0
  1007. package/icons/dnb/browser.js +17 -0
  1008. package/icons/dnb/browser.js.map +1 -0
  1009. package/icons/dnb/browser_medium.d.ts +3 -0
  1010. package/icons/dnb/browser_medium.js +17 -0
  1011. package/icons/dnb/browser_medium.js.map +1 -0
  1012. package/icons/dnb/coins_1.js +1 -1
  1013. package/icons/dnb/coins_1.js.map +1 -1
  1014. package/icons/dnb/coins_1_medium.js +1 -1
  1015. package/icons/dnb/coins_1_medium.js.map +1 -1
  1016. package/icons/dnb/digipass_corporate.d.ts +3 -0
  1017. package/icons/dnb/digipass_corporate.js +17 -0
  1018. package/icons/dnb/digipass_corporate.js.map +1 -0
  1019. package/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  1020. package/icons/dnb/digipass_corporate_medium.js +17 -0
  1021. package/icons/dnb/digipass_corporate_medium.js.map +1 -0
  1022. package/icons/dnb/digipass_private.d.ts +3 -0
  1023. package/icons/dnb/digipass_private.js +17 -0
  1024. package/icons/dnb/digipass_private.js.map +1 -0
  1025. package/icons/dnb/digipass_private_medium.d.ts +3 -0
  1026. package/icons/dnb/digipass_private_medium.js +17 -0
  1027. package/icons/dnb/digipass_private_medium.js.map +1 -0
  1028. package/icons/dnb/envelope_open.d.ts +3 -0
  1029. package/icons/dnb/envelope_open.js +18 -0
  1030. package/icons/dnb/envelope_open.js.map +1 -0
  1031. package/icons/dnb/envelope_open_medium.d.ts +3 -0
  1032. package/icons/dnb/envelope_open_medium.js +18 -0
  1033. package/icons/dnb/envelope_open_medium.js.map +1 -0
  1034. package/icons/dnb/icons-meta.json +230 -20
  1035. package/icons/dnb/icons-svg.lock +1272 -1064
  1036. package/icons/dnb/index.d.ts +17 -1
  1037. package/icons/dnb/index.js +17 -1
  1038. package/icons/dnb/index.js.map +1 -1
  1039. package/icons/dnb/laptop.d.ts +3 -0
  1040. package/icons/dnb/laptop.js +18 -0
  1041. package/icons/dnb/laptop.js.map +1 -0
  1042. package/icons/dnb/laptop_medium.d.ts +3 -0
  1043. package/icons/dnb/laptop_medium.js +18 -0
  1044. package/icons/dnb/laptop_medium.js.map +1 -0
  1045. package/icons/dnb/mobile.d.ts +3 -0
  1046. package/icons/dnb/mobile.js +15 -0
  1047. package/icons/dnb/mobile.js.map +1 -0
  1048. package/icons/dnb/mobile_medium.d.ts +3 -0
  1049. package/icons/dnb/mobile_medium.js +15 -0
  1050. package/icons/dnb/mobile_medium.js.map +1 -0
  1051. package/icons/dnb/money_left.d.ts +3 -0
  1052. package/icons/dnb/money_left.js +17 -0
  1053. package/icons/dnb/money_left.js.map +1 -0
  1054. package/icons/dnb/money_left_medium.d.ts +3 -0
  1055. package/icons/dnb/money_left_medium.js +18 -0
  1056. package/icons/dnb/money_left_medium.js.map +1 -0
  1057. package/icons/dnb/scan.js +5 -2
  1058. package/icons/dnb/scan.js.map +1 -1
  1059. package/icons/dnb/scan_medium.js +8 -12
  1060. package/icons/dnb/scan_medium.js.map +1 -1
  1061. package/icons/dnb/secondary_icons.d.ts +9 -1
  1062. package/icons/dnb/secondary_icons.js +9 -1
  1063. package/icons/dnb/secondary_icons.js.map +1 -1
  1064. package/icons/dnb/secondary_icons_medium.d.ts +9 -1
  1065. package/icons/dnb/secondary_icons_medium.js +9 -1
  1066. package/icons/dnb/secondary_icons_medium.js.map +1 -1
  1067. package/icons/dnb/teenager.d.ts +3 -0
  1068. package/icons/dnb/teenager.js +18 -0
  1069. package/icons/dnb/teenager.js.map +1 -0
  1070. package/icons/dnb/teenager_medium.d.ts +3 -0
  1071. package/icons/dnb/teenager_medium.js +18 -0
  1072. package/icons/dnb/teenager_medium.js.map +1 -0
  1073. package/icons/envelope_open.d.ts +3 -0
  1074. package/icons/envelope_open.js +3 -0
  1075. package/icons/envelope_open.js.map +1 -0
  1076. package/icons/envelope_open_medium.d.ts +3 -0
  1077. package/icons/envelope_open_medium.js +3 -0
  1078. package/icons/envelope_open_medium.js.map +1 -0
  1079. package/icons/index.d.ts +17 -1
  1080. package/icons/index.js +17 -1
  1081. package/icons/index.js.map +1 -1
  1082. package/icons/laptop.d.ts +3 -0
  1083. package/icons/laptop.js +3 -0
  1084. package/icons/laptop.js.map +1 -0
  1085. package/icons/laptop_medium.d.ts +3 -0
  1086. package/icons/laptop_medium.js +3 -0
  1087. package/icons/laptop_medium.js.map +1 -0
  1088. package/icons/mobile.d.ts +3 -0
  1089. package/icons/mobile.js +3 -0
  1090. package/icons/mobile.js.map +1 -0
  1091. package/icons/mobile_medium.d.ts +3 -0
  1092. package/icons/mobile_medium.js +3 -0
  1093. package/icons/mobile_medium.js.map +1 -0
  1094. package/icons/money_left.d.ts +3 -0
  1095. package/icons/money_left.js +3 -0
  1096. package/icons/money_left.js.map +1 -0
  1097. package/icons/money_left_medium.d.ts +3 -0
  1098. package/icons/money_left_medium.js +3 -0
  1099. package/icons/money_left_medium.js.map +1 -0
  1100. package/icons/teenager.d.ts +3 -0
  1101. package/icons/teenager.js +3 -0
  1102. package/icons/teenager.js.map +1 -0
  1103. package/icons/teenager_medium.d.ts +3 -0
  1104. package/icons/teenager_medium.js +3 -0
  1105. package/icons/teenager_medium.js.map +1 -0
  1106. package/package.json +1 -1
  1107. package/shared/Eufemia.d.ts +1 -1
  1108. package/shared/Eufemia.js +2 -2
  1109. package/shared/Eufemia.js.map +1 -1
  1110. package/shared/component-helper.d.ts +1 -0
  1111. package/shared/component-helper.js +3 -0
  1112. package/shared/component-helper.js.map +1 -1
  1113. package/style/core/utilities.scss +1 -2
  1114. package/style/dnb-ui-components.css +304 -79
  1115. package/style/dnb-ui-components.min.css +3 -3
  1116. package/style/dnb-ui-extensions.css +244 -25
  1117. package/style/dnb-ui-extensions.min.css +1 -1
  1118. package/style/dnb-ui-forms.css +244 -25
  1119. package/style/dnb-ui-forms.min.css +1 -1
  1120. package/style/dnb-ui-forms.scss +1 -0
  1121. package/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  1122. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  1123. package/style/themes/theme-eiendom/eiendom-theme-components.css +636 -113
  1124. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +10 -6
  1125. package/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  1126. package/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  1127. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  1128. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +260 -25
  1129. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +5 -1
  1130. package/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  1131. package/style/themes/theme-eiendom/eiendom-theme-forms.css +260 -26
  1132. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +5 -1
  1133. package/style/themes/theme-eiendom/eiendom-theme-forms.scss +2 -0
  1134. package/style/themes/theme-sbanken/sbanken-theme-components.css +664 -107
  1135. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -6
  1136. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  1137. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +319 -25
  1138. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +3 -1
  1139. package/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  1140. package/style/themes/theme-sbanken/sbanken-theme-forms.css +319 -26
  1141. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +3 -1
  1142. package/style/themes/theme-sbanken/sbanken-theme-forms.scss +2 -0
  1143. package/style/themes/theme-ui/ui-theme-basis.css +14 -2
  1144. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  1145. package/style/themes/theme-ui/ui-theme-components.css +634 -113
  1146. package/style/themes/theme-ui/ui-theme-components.min.css +10 -6
  1147. package/style/themes/theme-ui/ui-theme-components.scss +1 -0
  1148. package/style/themes/theme-ui/ui-theme-elements.css +14 -2
  1149. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  1150. package/style/themes/theme-ui/ui-theme-extensions.css +260 -25
  1151. package/style/themes/theme-ui/ui-theme-extensions.min.css +5 -1
  1152. package/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  1153. package/style/themes/theme-ui/ui-theme-forms.css +260 -26
  1154. package/style/themes/theme-ui/ui-theme-forms.min.css +5 -1
  1155. package/style/themes/theme-ui/ui-theme-forms.scss +2 -0
  1156. package/style/themes/theme-ui/ui-theme-tags.css +11 -13
  1157. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  1158. package/umd/dnb-ui-basis.min.js +1 -1
  1159. package/umd/dnb-ui-components.min.js +1 -1
  1160. package/umd/dnb-ui-elements.min.js +1 -1
  1161. package/umd/dnb-ui-extensions.min.js +3 -3
  1162. package/umd/dnb-ui-lib.min.js +1 -1
  1163. package/cjs/extensions/forms/Visibility/Visibility.js.map +0 -1
  1164. package/cjs/extensions/forms/Visibility/index.js.map +0 -1
  1165. package/cjs/icons/icons-meta.json +0 -3748
  1166. package/es/extensions/forms/Visibility/Visibility.js.map +0 -1
  1167. package/es/extensions/forms/Visibility/index.js.map +0 -1
  1168. package/es/icons/icons-meta.json +0 -3748
  1169. package/extensions/forms/Visibility/Visibility.js.map +0 -1
  1170. package/extensions/forms/Visibility/index.js.map +0 -1
  1171. package/icons/icons-meta.json +0 -3748
  1172. /package/cjs/extensions/forms/{Visibility → Form/Visibility}/index.d.ts +0 -0
  1173. /package/cjs/extensions/forms/{Visibility → Form/Visibility}/index.js +0 -0
  1174. /package/es/extensions/forms/{Visibility → Form/Visibility}/index.d.ts +0 -0
  1175. /package/es/extensions/forms/{Visibility → Form/Visibility}/index.js +0 -0
  1176. /package/extensions/forms/{Visibility → Form/Visibility}/index.d.ts +0 -0
  1177. /package/extensions/forms/{Visibility → Form/Visibility}/index.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"Provider.js","names":["React","useEffect","useRef","useMemo","useCallback","useReducer","pointer","ajv","ajvErrorsToFormErrors","useMountEffect","useUpdateEffect","Context","structuredClone","addListPath","paths","path","includes","concat","removeListPath","filter","thisPath","isArrayJsonPointer","Provider","_ref","defaultData","data","schema","onChange","onPathChange","onSubmit","onSubmitRequest","scrollTopOnSubmit","sessionStorageId","children","rest","_objectWithoutProperties","_excluded","forceUpdate","undefined","console","error","mountedFieldPathsRef","errorsRef","showAllErrorsRef","setShowAllErrors","showAllErrors","current","valuesWithErrorRef","initialData","window","_window$sessionStorag","sessionDataJSON","sessionStorage","getItem","JSON","parse","internalDataRef","ajvSchemaValidatorRef","validateData","errors","compile","hasErrors","Boolean","find","mountedFieldPath","_errorsRef$current","setValueWithError","identifier","withError","handlePathChange","value","_internalDataRef$curr","newData","match","set","_window$sessionStorag2","setItem","stringify","handleMountField","handleUnMountField","handleSubmit","formElement","_formElement$reset","reset","call","removeItem","_window","scrollTo","top","behavior","createElement","_objectSpread","mountedFieldPaths"],"sources":["../../../../../../src/extensions/forms/DataContext/Provider/Provider.tsx"],"sourcesContent":["import React, {\n useEffect,\n useRef,\n useMemo,\n useCallback,\n useReducer,\n} from 'react'\nimport pointer, { JsonObject } from 'json-pointer'\nimport { JSONSchema7 } from 'json-schema'\nimport { ValidateFunction } from 'ajv'\nimport ajv, { ajvErrorsToFormErrors } from '../../utils/ajv'\nimport { FormError } from '../../types'\nimport useMountEffect from '../../hooks/useMountEffect'\nimport useUpdateEffect from '../../hooks/useUpdateEffect'\nimport Context, { ContextState } from '../Context'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport interface Props<Data extends JsonObject> {\n /** Default source data, only used if no other source is available, and not leading to updates if changed after mount */\n defaultData?: Partial<Data>\n /** Dynamic source data used as both initial data, and updates internal data if changed after mount */\n data?: Partial<Data>\n /** JSON Schema for validating the data, like during input or after attempting submit */\n schema?: JSONSchema7\n /** Change handler for the whole data set */\n onChange?: (data: Data) => void\n /** Change handler for each value */\n onPathChange?: (path: string, value: any) => void\n /** Submit called, data was valid (if validation available) */\n onSubmit?: (data: Data) => void\n /** Submit was requested, but data was invalid */\n onSubmitRequest?: () => void\n scrollTopOnSubmit?: boolean\n /** Key for caching the data in session storage */\n sessionStorageId?: string\n children: React.ReactNode\n}\n\ntype PathList = string[]\n\nfunction addListPath(paths: PathList, path: string): PathList {\n return paths.includes(path) ? paths : paths.concat(path)\n}\n\nfunction removeListPath(paths: PathList, path: string): PathList {\n return paths.filter((thisPath) => thisPath !== path)\n}\n\nconst isArrayJsonPointer = /^\\/\\d+(\\/|$)/\n\nexport default function Provider<Data extends JsonObject>({\n defaultData,\n data,\n schema,\n onChange,\n onPathChange,\n onSubmit,\n onSubmitRequest,\n scrollTopOnSubmit,\n sessionStorageId,\n children,\n ...rest\n}: Props<Data>) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n // Prop error handling\n if (data !== undefined && sessionStorageId !== undefined) {\n console.error(\n 'Providing both data and sessionStorageId could lead to competing data sources. To provide default data to use only before anything is changed in the interface, use defaultData.'\n )\n }\n\n // State\n const mountedFieldPathsRef = useRef<string[]>([])\n // - Errors from provider validation (the whole data set)\n const errorsRef = useRef<Record<string, FormError> | undefined>()\n const showAllErrorsRef = useRef<boolean>(false)\n const setShowAllErrors = useCallback((showAllErrors: boolean) => {\n showAllErrorsRef.current = showAllErrors\n }, [])\n // - Errors reported by fields, based on their direct validation rules\n const valuesWithErrorRef = useRef<string[]>([])\n // - Data\n const initialData = useMemo(() => {\n if (sessionStorageId && typeof window !== 'undefined') {\n const sessionDataJSON =\n window.sessionStorage?.getItem(sessionStorageId)\n if (sessionDataJSON) {\n return JSON.parse(sessionDataJSON)\n }\n }\n return data ?? defaultData\n // eslint-disable-next-line react-hooks/exhaustive-deps -- Avoid triggering code that should only run initially\n }, [])\n const internalDataRef = useRef<Partial<Data>>(initialData)\n // - Validator\n const ajvSchemaValidatorRef = useRef<ValidateFunction>()\n\n const validateData = useCallback(() => {\n if (!ajvSchemaValidatorRef.current) {\n // No schema-based validator. Assume data is valid.\n return\n }\n\n if (!ajvSchemaValidatorRef.current(internalDataRef.current)) {\n // Errors found\n const errors = ajvErrorsToFormErrors(\n ajvSchemaValidatorRef.current.errors\n )\n errorsRef.current = errors\n } else {\n errorsRef.current = undefined\n }\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!schema) {\n return\n }\n ajvSchemaValidatorRef.current = ajv.compile(schema)\n validateData()\n }, [schema, validateData])\n\n // Error handling\n const hasErrors = useCallback(\n () =>\n Boolean(\n mountedFieldPathsRef.current.find(\n (mountedFieldPath) =>\n errorsRef.current?.[mountedFieldPath] !== undefined ||\n valuesWithErrorRef.current.includes(mountedFieldPath)\n )\n ),\n []\n )\n\n const setValueWithError = useCallback(\n (identifier: string, withError: boolean) => {\n if (withError !== valuesWithErrorRef.current.includes(identifier)) {\n // The boolean error state for the target value was changed\n valuesWithErrorRef.current = withError\n ? addListPath(valuesWithErrorRef.current, identifier)\n : removeListPath(valuesWithErrorRef.current, identifier)\n forceUpdate()\n }\n },\n []\n )\n\n const handlePathChange = useCallback(\n (path, value) => {\n if (!path) {\n return\n }\n onPathChange?.(path, value)\n\n // Update the data even if it contains errors. Submit/SubmitRequest will be called accordingly\n const newData = structuredClone(\n path === '/'\n ? // When setting the root of the data, the whole data set should be the new value\n value\n : // For sub paths, use the the existing data set (or empty array/object), but modify it below (since pointer.set is not immutable)\n internalDataRef.current ??\n (path.match(isArrayJsonPointer) ? [] : {})\n )\n if (path !== '/') {\n pointer.set(newData as Data, path, value)\n }\n\n onChange?.(newData as Data)\n\n if (sessionStorageId && typeof window !== 'undefined') {\n window.sessionStorage?.setItem(\n sessionStorageId,\n JSON.stringify(newData)\n )\n }\n\n internalDataRef.current = newData\n\n validateData()\n showAllErrorsRef.current = false\n forceUpdate()\n },\n [onChange, onPathChange, validateData, sessionStorageId]\n )\n\n // Mounted fields\n const handleMountField = useCallback((path: string) => {\n mountedFieldPathsRef.current = addListPath(\n mountedFieldPathsRef.current,\n path\n )\n }, [])\n\n const handleUnMountField = useCallback((path: string) => {\n mountedFieldPathsRef.current = removeListPath(\n mountedFieldPathsRef.current,\n path\n )\n }, [])\n\n /**\n * Request to submit the whole form\n */\n const handleSubmit = useCallback<ContextState['handleSubmit']>(\n ({ formElement = null } = {}) => {\n if (!hasErrors()) {\n onSubmit?.(internalDataRef.current as Data)\n\n formElement?.reset?.()\n\n if (typeof window !== 'undefined') {\n if (sessionStorageId) {\n window.sessionStorage.removeItem(sessionStorageId)\n }\n\n if (scrollTopOnSubmit) {\n window?.scrollTo({ top: 0, behavior: 'smooth' })\n }\n }\n } else {\n showAllErrorsRef.current = true\n onSubmitRequest?.()\n forceUpdate()\n }\n return internalDataRef.current\n },\n [\n scrollTopOnSubmit,\n hasErrors,\n onSubmit,\n onSubmitRequest,\n sessionStorageId,\n ]\n )\n\n useMountEffect(() => {\n // Validate the initial data\n validateData()\n })\n\n useUpdateEffect(() => {\n // Update and validate changes to the external data set\n internalDataRef.current = data\n validateData()\n forceUpdate()\n }, [data, validateData, forceUpdate])\n\n return (\n <Context.Provider\n value={{\n data: internalDataRef.current,\n ...rest,\n handlePathChange,\n handleSubmit,\n errors: errorsRef.current,\n showAllErrors: showAllErrorsRef.current,\n setShowAllErrors,\n mountedFieldPaths: mountedFieldPathsRef.current,\n handleMountField,\n handleUnMountField,\n hasErrors,\n setValueWithError,\n }}\n >\n {children}\n </Context.Provider>\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"Provider.js","names":["React","useEffect","useRef","useMemo","useCallback","useReducer","pointer","ajv","ajvErrorsToFormErrors","useMountEffect","useUpdateEffect","Context","structuredClone","addListPath","paths","path","includes","concat","removeListPath","filter","thisPath","isArrayJsonPointer","Provider","_ref","defaultData","data","schema","onChange","onPathChange","onSubmit","onSubmitRequest","scrollTopOnSubmit","sessionStorageId","children","rest","_objectWithoutProperties","_excluded","forceUpdate","undefined","console","error","mountedFieldPathsRef","errorsRef","showAllErrorsRef","setShowAllErrors","showAllErrors","current","valuesWithErrorRef","initialData","window","_window$sessionStorag","sessionDataJSON","sessionStorage","getItem","JSON","parse","internalDataRef","dataCacheRef","ajvSchemaValidatorRef","validateData","errors","compile","hasErrors","Boolean","find","mountedFieldPath","_errorsRef$current","setValueWithError","identifier","withError","updateDataValue","value","_internalDataRef$curr","newData","match","set","_window$sessionStorag2","setItem","stringify","handlePathChange","handleMountField","handleUnMountField","handleSubmit","formElement","resetForm","_formElement$reset","reset","call","removeItem","clearData","_window","scrollTo","top","behavior","createElement","_objectSpread","mountedFieldPaths"],"sources":["../../../../../../src/extensions/forms/DataContext/Provider/Provider.tsx"],"sourcesContent":["import React, {\n useEffect,\n useRef,\n useMemo,\n useCallback,\n useReducer,\n} from 'react'\nimport pointer, { JsonObject } from 'json-pointer'\nimport { JSONSchema7 } from 'json-schema'\nimport { ValidateFunction } from 'ajv'\nimport ajv, { ajvErrorsToFormErrors } from '../../utils/ajv'\nimport { FormError } from '../../types'\nimport useMountEffect from '../../hooks/useMountEffect'\nimport useUpdateEffect from '../../hooks/useUpdateEffect'\nimport Context, { ContextState } from '../Context'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport interface Props<Data extends JsonObject> {\n /** Default source data, only used if no other source is available, and not leading to updates if changed after mount */\n defaultData?: Partial<Data>\n /** Dynamic source data used as both initial data, and updates internal data if changed after mount */\n data?: Partial<Data>\n /** JSON Schema for validating the data, like during input or after attempting submit */\n schema?: JSONSchema7\n /** Change handler for the whole data set */\n onChange?: (data: Data) => void\n /** Change handler for each value */\n onPathChange?: (path: string, value: any) => void\n /** Submit called, data was valid (if validation available) */\n onSubmit?: (\n data: Data,\n {\n resetForm,\n clearData,\n }: {\n /** Will remove browser-side stored autocomplete data */\n resetForm: () => void\n /** Will empty the whole internal data set of the form */\n clearData: () => void\n }\n ) => void\n /** Submit was requested, but data was invalid */\n onSubmitRequest?: () => void\n scrollTopOnSubmit?: boolean\n /** Key for caching the data in session storage */\n sessionStorageId?: string\n children: React.ReactNode\n}\n\ntype PathList = string[]\n\nfunction addListPath(paths: PathList, path: string): PathList {\n return paths.includes(path) ? paths : paths.concat(path)\n}\n\nfunction removeListPath(paths: PathList, path: string): PathList {\n return paths.filter((thisPath) => thisPath !== path)\n}\n\nconst isArrayJsonPointer = /^\\/\\d+(\\/|$)/\n\nexport default function Provider<Data extends JsonObject>({\n defaultData,\n data,\n schema,\n onChange,\n onPathChange,\n onSubmit,\n onSubmitRequest,\n scrollTopOnSubmit,\n sessionStorageId,\n children,\n ...rest\n}: Props<Data>) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n // Prop error handling\n if (data !== undefined && sessionStorageId !== undefined) {\n console.error(\n 'Providing both data and sessionStorageId could lead to competing data sources. To provide default data to use only before anything is changed in the interface, use defaultData.'\n )\n }\n\n // State\n const mountedFieldPathsRef = useRef<string[]>([])\n // - Errors from provider validation (the whole data set)\n const errorsRef = useRef<Record<string, FormError> | undefined>()\n const showAllErrorsRef = useRef<boolean>(false)\n const setShowAllErrors = useCallback((showAllErrors: boolean) => {\n showAllErrorsRef.current = showAllErrors\n }, [])\n // - Errors reported by fields, based on their direct validation rules\n const valuesWithErrorRef = useRef<string[]>([])\n // - Data\n const initialData = useMemo(() => {\n if (sessionStorageId && typeof window !== 'undefined') {\n const sessionDataJSON =\n window.sessionStorage?.getItem(sessionStorageId)\n if (sessionDataJSON) {\n return JSON.parse(sessionDataJSON)\n }\n }\n return data ?? defaultData\n // eslint-disable-next-line react-hooks/exhaustive-deps -- Avoid triggering code that should only run initially\n }, [])\n const internalDataRef = useRef<Partial<Data>>(initialData)\n const dataCacheRef = useRef<Partial<Data>>(data)\n // - Validator\n const ajvSchemaValidatorRef = useRef<ValidateFunction>()\n\n const validateData = useCallback(() => {\n if (!ajvSchemaValidatorRef.current) {\n // No schema-based validator. Assume data is valid.\n return\n }\n\n if (!ajvSchemaValidatorRef.current(internalDataRef.current)) {\n // Errors found\n const errors = ajvErrorsToFormErrors(\n ajvSchemaValidatorRef.current.errors\n )\n errorsRef.current = errors\n } else {\n errorsRef.current = undefined\n }\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!schema) {\n return\n }\n ajvSchemaValidatorRef.current = ajv.compile(schema)\n validateData()\n }, [schema, validateData])\n\n // Error handling\n const hasErrors = useCallback(\n () =>\n Boolean(\n mountedFieldPathsRef.current.find(\n (mountedFieldPath) =>\n errorsRef.current?.[mountedFieldPath] !== undefined ||\n valuesWithErrorRef.current.includes(mountedFieldPath)\n )\n ),\n []\n )\n\n const setValueWithError = useCallback(\n (identifier: string, withError: boolean) => {\n if (withError !== valuesWithErrorRef.current.includes(identifier)) {\n // The boolean error state for the target value was changed\n valuesWithErrorRef.current = withError\n ? addListPath(valuesWithErrorRef.current, identifier)\n : removeListPath(valuesWithErrorRef.current, identifier)\n forceUpdate()\n }\n },\n []\n )\n\n const updateDataValue = useCallback(\n (path, value) => {\n if (!path) {\n return\n }\n\n // Update the data even if it contains errors. Submit/SubmitRequest will be called accordingly\n const newData = structuredClone(\n path === '/'\n ? // When setting the root of the data, the whole data set should be the new value\n value\n : // For sub paths, use the the existing data set (or empty array/object), but modify it below (since pointer.set is not immutable)\n internalDataRef.current ??\n (path.match(isArrayJsonPointer) ? [] : {})\n )\n\n if (path !== '/') {\n pointer.set(newData as Data, path, value)\n }\n\n if (sessionStorageId && typeof window !== 'undefined') {\n window.sessionStorage?.setItem(\n sessionStorageId,\n JSON.stringify(newData)\n )\n }\n\n internalDataRef.current = newData\n\n forceUpdate()\n\n return newData\n },\n [sessionStorageId]\n )\n\n const handlePathChange = useCallback(\n (path, value) => {\n if (!path) {\n return\n }\n\n onPathChange?.(path, value)\n\n const newData = updateDataValue(path, value)\n\n onChange?.(newData as Data)\n\n showAllErrorsRef.current = false\n\n validateData()\n },\n [onPathChange, updateDataValue, onChange, validateData]\n )\n\n // Mounted fields\n const handleMountField = useCallback((path: string) => {\n mountedFieldPathsRef.current = addListPath(\n mountedFieldPathsRef.current,\n path\n )\n }, [])\n\n const handleUnMountField = useCallback((path: string) => {\n mountedFieldPathsRef.current = removeListPath(\n mountedFieldPathsRef.current,\n path\n )\n }, [])\n\n /**\n * Request to submit the whole form\n */\n const handleSubmit = useCallback<ContextState['handleSubmit']>(\n ({ formElement = null } = {}) => {\n if (!hasErrors()) {\n const resetForm = () => {\n formElement?.reset?.()\n\n if (typeof window !== 'undefined') {\n if (sessionStorageId) {\n window.sessionStorage.removeItem(sessionStorageId)\n }\n }\n\n forceUpdate() // in order to fill \"empty fields\" again with their internal states\n }\n const clearData = () => {\n internalDataRef.current = {}\n forceUpdate()\n }\n\n onSubmit?.(internalDataRef.current as Data, {\n resetForm,\n clearData,\n })\n\n if (typeof window !== 'undefined') {\n if (scrollTopOnSubmit) {\n window?.scrollTo({ top: 0, behavior: 'smooth' })\n }\n }\n } else {\n showAllErrorsRef.current = true\n onSubmitRequest?.()\n forceUpdate()\n }\n return internalDataRef.current\n },\n [\n scrollTopOnSubmit,\n hasErrors,\n onSubmit,\n onSubmitRequest,\n sessionStorageId,\n ]\n )\n\n useMountEffect(() => {\n // Validate the initial data\n validateData()\n })\n\n useUpdateEffect(() => {\n // Update and validate changes to the external data set,\n // And avoid \"resetting\" the data with the originally given data (React.StrictMode)\n if (data !== dataCacheRef.current) {\n dataCacheRef.current = data\n internalDataRef.current = data\n }\n validateData()\n forceUpdate()\n }, [data, validateData, forceUpdate])\n\n return (\n <Context.Provider\n value={{\n data: internalDataRef.current,\n ...rest,\n handlePathChange,\n updateDataValue,\n handleSubmit,\n errors: errorsRef.current,\n showAllErrors: showAllErrorsRef.current,\n setShowAllErrors,\n mountedFieldPaths: mountedFieldPathsRef.current,\n handleMountField,\n handleUnMountField,\n hasErrors,\n setValueWithError,\n }}\n >\n {children}\n </Context.Provider>\n )\n}\n"],"mappings":"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"}
@@ -25,7 +25,8 @@ function BankAccountNumber(props) {
25
25
  label: (_props$label = props.label) !== null && _props$label !== void 0 ? _props$label : sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.Forms.bankAccountNumberLabel,
26
26
  errorMessages,
27
27
  mask,
28
- width: (_props$width = props.width) !== null && _props$width !== void 0 ? _props$width : 'medium'
28
+ width: (_props$width = props.width) !== null && _props$width !== void 0 ? _props$width : 'medium',
29
+ inputMode: 'numeric'
29
30
  });
30
31
  return React.createElement(StringComponent, stringComponentProps);
31
32
  }
@@ -1 +1 @@
1
- {"version":3,"file":"BankAccountNumber.js","names":["React","useContext","useMemo","StringComponent","SharedContext","BankAccountNumber","props","_props$pattern","_props$label","_props$width","sharedContext","tr","translation","Forms","validate","omitMask","errorMessages","_objectSpread","required","bankAccountNumberErrorRequired","pattern","bankAccountNumberErrorPattern","mask","stringComponentProps","className","undefined","label","bankAccountNumberLabel","width","createElement","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/BankAccountNumber/BankAccountNumber.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport StringComponent, { Props as StringComponentProps } from '../String'\nimport SharedContext from '../../../../shared/Context'\n\nexport type Props = StringComponentProps & {\n validate?: boolean\n omitMask?: boolean\n}\n\nfunction BankAccountNumber(props: Props) {\n const sharedContext = useContext(SharedContext)\n const tr = sharedContext?.translation.Forms\n const { validate = true, omitMask } = props\n\n const errorMessages = useMemo(\n () => ({\n required: tr.bankAccountNumberErrorRequired,\n pattern: tr.bankAccountNumberErrorPattern,\n ...props.errorMessages,\n }),\n [tr, props.errorMessages]\n )\n const mask = useMemo(\n () =>\n omitMask\n ? [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ]\n : [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ],\n [omitMask]\n )\n\n const stringComponentProps: Props = {\n ...props,\n className: 'dnb-forms-field-bank-account-number',\n pattern: props.pattern ?? (validate ? '^[0-9]{11}$' : undefined),\n label:\n props.label ??\n sharedContext?.translation.Forms.bankAccountNumberLabel,\n errorMessages,\n mask,\n width: props.width ?? 'medium',\n }\n\n return <StringComponent {...stringComponentProps} />\n}\n\nBankAccountNumber._supportsSpacingProps = true\nexport default BankAccountNumber\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,eAAe,MAAyC,WAAW;AAC1E,OAAOC,aAAa,MAAM,4BAA4B;AAOtD,SAASC,iBAAiBA,CAACC,KAAY,EAAE;EAAA,IAAAC,cAAA,EAAAC,YAAA,EAAAC,YAAA;EACvC,MAAMC,aAAa,GAAGT,UAAU,CAACG,aAAa,CAAC;EAC/C,MAAMO,EAAE,GAAGD,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK;EAC3C,MAAM;IAAEC,QAAQ,GAAG,IAAI;IAAEC;EAAS,CAAC,GAAGT,KAAK;EAE3C,MAAMU,aAAa,GAAGd,OAAO,CAC3B,MAAAe,aAAA;IACEC,QAAQ,EAAEP,EAAE,CAACQ,8BAA8B;IAC3CC,OAAO,EAAET,EAAE,CAACU;EAA6B,GACtCf,KAAK,CAACU,aAAa,CACtB,EACF,CAACL,EAAE,EAAEL,KAAK,CAACU,aAAa,CAC1B,CAAC;EACD,MAAMM,IAAI,GAAGpB,OAAO,CAClB,MACEa,QAAQ,GACJ,CACE,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,CACL,GACD,CACE,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,CACL,EACP,CAACA,QAAQ,CACX,CAAC;EAED,MAAMQ,oBAA2B,GAAAN,aAAA,CAAAA,aAAA,KAC5BX,KAAK;IACRkB,SAAS,EAAE,qCAAqC;IAChDJ,OAAO,GAAAb,cAAA,GAAED,KAAK,CAACc,OAAO,cAAAb,cAAA,cAAAA,cAAA,GAAKO,QAAQ,GAAG,aAAa,GAAGW,SAAU;IAChEC,KAAK,GAAAlB,YAAA,GACHF,KAAK,CAACoB,KAAK,cAAAlB,YAAA,cAAAA,YAAA,GACXE,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK,CAACc,sBAAsB;IACzDX,aAAa;IACbM,IAAI;IACJM,KAAK,GAAAnB,YAAA,GAAEH,KAAK,CAACsB,KAAK,cAAAnB,YAAA,cAAAA,YAAA,GAAI;EAAQ,EAC/B;EAED,OAAOT,KAAA,CAAA6B,aAAA,CAAC1B,eAAe,EAAKoB,oBAAuB,CAAC;AACtD;AAEAlB,iBAAiB,CAACyB,qBAAqB,GAAG,IAAI;AAC9C,eAAezB,iBAAiB"}
1
+ {"version":3,"file":"BankAccountNumber.js","names":["React","useContext","useMemo","StringComponent","SharedContext","BankAccountNumber","props","_props$pattern","_props$label","_props$width","sharedContext","tr","translation","Forms","validate","omitMask","errorMessages","_objectSpread","required","bankAccountNumberErrorRequired","pattern","bankAccountNumberErrorPattern","mask","stringComponentProps","className","undefined","label","bankAccountNumberLabel","width","inputMode","createElement","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/BankAccountNumber/BankAccountNumber.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport StringComponent, { Props as StringComponentProps } from '../String'\nimport SharedContext from '../../../../shared/Context'\n\nexport type Props = StringComponentProps & {\n validate?: boolean\n omitMask?: boolean\n}\n\nfunction BankAccountNumber(props: Props) {\n const sharedContext = useContext(SharedContext)\n const tr = sharedContext?.translation.Forms\n const { validate = true, omitMask } = props\n\n const errorMessages = useMemo(\n () => ({\n required: tr.bankAccountNumberErrorRequired,\n pattern: tr.bankAccountNumberErrorPattern,\n ...props.errorMessages,\n }),\n [tr, props.errorMessages]\n )\n const mask = useMemo(\n () =>\n omitMask\n ? [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ]\n : [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ],\n [omitMask]\n )\n\n const stringComponentProps: Props = {\n ...props,\n className: 'dnb-forms-field-bank-account-number',\n pattern: props.pattern ?? (validate ? '^[0-9]{11}$' : undefined),\n label:\n props.label ??\n sharedContext?.translation.Forms.bankAccountNumberLabel,\n errorMessages,\n mask,\n width: props.width ?? 'medium',\n inputMode: 'numeric',\n }\n\n return <StringComponent {...stringComponentProps} />\n}\n\nBankAccountNumber._supportsSpacingProps = true\nexport default BankAccountNumber\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,eAAe,MAAyC,WAAW;AAC1E,OAAOC,aAAa,MAAM,4BAA4B;AAOtD,SAASC,iBAAiBA,CAACC,KAAY,EAAE;EAAA,IAAAC,cAAA,EAAAC,YAAA,EAAAC,YAAA;EACvC,MAAMC,aAAa,GAAGT,UAAU,CAACG,aAAa,CAAC;EAC/C,MAAMO,EAAE,GAAGD,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK;EAC3C,MAAM;IAAEC,QAAQ,GAAG,IAAI;IAAEC;EAAS,CAAC,GAAGT,KAAK;EAE3C,MAAMU,aAAa,GAAGd,OAAO,CAC3B,MAAAe,aAAA;IACEC,QAAQ,EAAEP,EAAE,CAACQ,8BAA8B;IAC3CC,OAAO,EAAET,EAAE,CAACU;EAA6B,GACtCf,KAAK,CAACU,aAAa,CACtB,EACF,CAACL,EAAE,EAAEL,KAAK,CAACU,aAAa,CAC1B,CAAC;EACD,MAAMM,IAAI,GAAGpB,OAAO,CAClB,MACEa,QAAQ,GACJ,CACE,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,CACL,GACD,CACE,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,CACL,EACP,CAACA,QAAQ,CACX,CAAC;EAED,MAAMQ,oBAA2B,GAAAN,aAAA,CAAAA,aAAA,KAC5BX,KAAK;IACRkB,SAAS,EAAE,qCAAqC;IAChDJ,OAAO,GAAAb,cAAA,GAAED,KAAK,CAACc,OAAO,cAAAb,cAAA,cAAAA,cAAA,GAAKO,QAAQ,GAAG,aAAa,GAAGW,SAAU;IAChEC,KAAK,GAAAlB,YAAA,GACHF,KAAK,CAACoB,KAAK,cAAAlB,YAAA,cAAAA,YAAA,GACXE,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK,CAACc,sBAAsB;IACzDX,aAAa;IACbM,IAAI;IACJM,KAAK,GAAAnB,YAAA,GAAEH,KAAK,CAACsB,KAAK,cAAAnB,YAAA,cAAAA,YAAA,GAAI,QAAQ;IAC9BoB,SAAS,EAAE;EAAS,EACrB;EAED,OAAO7B,KAAA,CAAA8B,aAAA,CAAC3B,eAAe,EAAKoB,oBAAuB,CAAC;AACtD;AAEAlB,iBAAiB,CAAC0B,qBAAqB,GAAG,IAAI;AAC9C,eAAe1B,iBAAiB"}
@@ -1,9 +1,5 @@
1
1
  import { Props as NumberProps } from '../Number';
2
- import type { FieldProps, FieldHelpProps } from '../../types';
3
- export type Props = FieldHelpProps & FieldProps<number, undefined> & {
4
- currency?: NumberProps['currency'];
5
- rightAligned?: NumberProps['rightAligned'];
6
- };
2
+ export type Props = NumberProps;
7
3
  declare function Currency(props: Props): import("react/jsx-runtime").JSX.Element;
8
4
  declare namespace Currency {
9
5
  var _supportsSpacingProps: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"Currency.js","names":["React","classnames","Context","getCurrencySymbol","CURRENCY","NumberComponent","Currency","props","_props$currency","_props$placeholder","context","useContext","preparedProps","_objectSpread","currency","placeholder","locale","createElement","_extends","className","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Currency/Currency.tsx"],"sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\nimport { Context } from '../../../../shared'\nimport { getCurrencySymbol } from '../../../../components/number-format/NumberUtils'\nimport { CURRENCY } from '../../../../shared/defaults'\nimport NumberComponent, { Props as NumberProps } from '../Number'\nimport type { FieldProps, FieldHelpProps } from '../../types'\n\nexport type Props = FieldHelpProps &\n FieldProps<number, undefined> & {\n currency?: NumberProps['currency']\n rightAligned?: NumberProps['rightAligned']\n }\n\nfunction Currency(props: Props) {\n const context = React.useContext(Context)\n const preparedProps = {\n ...props,\n currency: props.currency ?? CURRENCY,\n placeholder:\n props.placeholder ??\n getCurrencySymbol(context?.locale, props.currency),\n }\n\n return (\n <NumberComponent\n {...preparedProps}\n className={classnames('dnb-forms-field-currency', props.className)}\n />\n )\n}\n\nCurrency._supportsSpacingProps = true\nexport default Currency\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,OAAO,QAAQ,oBAAoB;AAC5C,SAASC,iBAAiB,QAAQ,kDAAkD;AACpF,SAASC,QAAQ,QAAQ,6BAA6B;AACtD,OAAOC,eAAe,MAAgC,WAAW;AASjE,SAASC,QAAQA,CAACC,KAAY,EAAE;EAAA,IAAAC,eAAA,EAAAC,kBAAA;EAC9B,MAAMC,OAAO,GAAGV,KAAK,CAACW,UAAU,CAACT,OAAO,CAAC;EACzC,MAAMU,aAAa,GAAAC,aAAA,CAAAA,aAAA,KACdN,KAAK;IACRO,QAAQ,GAAAN,eAAA,GAAED,KAAK,CAACO,QAAQ,cAAAN,eAAA,cAAAA,eAAA,GAAIJ,QAAQ;IACpCW,WAAW,GAAAN,kBAAA,GACTF,KAAK,CAACQ,WAAW,cAAAN,kBAAA,cAAAA,kBAAA,GACjBN,iBAAiB,CAACO,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEM,MAAM,EAAET,KAAK,CAACO,QAAQ;EAAC,EACrD;EAED,OACEd,KAAA,CAAAiB,aAAA,CAACZ,eAAe,EAAAa,QAAA,KACVN,aAAa;IACjBO,SAAS,EAAElB,UAAU,CAAC,0BAA0B,EAAEM,KAAK,CAACY,SAAS;EAAE,EACpE,CAAC;AAEN;AAEAb,QAAQ,CAACc,qBAAqB,GAAG,IAAI;AACrC,eAAed,QAAQ"}
1
+ {"version":3,"file":"Currency.js","names":["React","classnames","Context","getCurrencySymbol","CURRENCY","NumberComponent","Currency","props","_props$currency","_props$placeholder","context","useContext","preparedProps","_objectSpread","currency","placeholder","locale","createElement","_extends","className","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Currency/Currency.tsx"],"sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\nimport { Context } from '../../../../shared'\nimport { getCurrencySymbol } from '../../../../components/number-format/NumberUtils'\nimport { CURRENCY } from '../../../../shared/defaults'\nimport NumberComponent, { Props as NumberProps } from '../Number'\n\nexport type Props = NumberProps\n\nfunction Currency(props: Props) {\n const context = React.useContext(Context)\n const preparedProps = {\n ...props,\n currency: props.currency ?? CURRENCY,\n placeholder:\n props.placeholder ??\n getCurrencySymbol(context?.locale, props.currency),\n }\n\n return (\n <NumberComponent\n {...preparedProps}\n className={classnames('dnb-forms-field-currency', props.className)}\n />\n )\n}\n\nCurrency._supportsSpacingProps = true\nexport default Currency\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,OAAO,QAAQ,oBAAoB;AAC5C,SAASC,iBAAiB,QAAQ,kDAAkD;AACpF,SAASC,QAAQ,QAAQ,6BAA6B;AACtD,OAAOC,eAAe,MAAgC,WAAW;AAIjE,SAASC,QAAQA,CAACC,KAAY,EAAE;EAAA,IAAAC,eAAA,EAAAC,kBAAA;EAC9B,MAAMC,OAAO,GAAGV,KAAK,CAACW,UAAU,CAACT,OAAO,CAAC;EACzC,MAAMU,aAAa,GAAAC,aAAA,CAAAA,aAAA,KACdN,KAAK;IACRO,QAAQ,GAAAN,eAAA,GAAED,KAAK,CAACO,QAAQ,cAAAN,eAAA,cAAAA,eAAA,GAAIJ,QAAQ;IACpCW,WAAW,GAAAN,kBAAA,GACTF,KAAK,CAACQ,WAAW,cAAAN,kBAAA,cAAAA,kBAAA,GACjBN,iBAAiB,CAACO,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEM,MAAM,EAAET,KAAK,CAACO,QAAQ;EAAC,EACrD;EAED,OACEd,KAAA,CAAAiB,aAAA,CAACZ,eAAe,EAAAa,QAAA,KACVN,aAAa;IACjBO,SAAS,EAAElB,UAAU,CAAC,0BAA0B,EAAEM,KAAK,CAACY,SAAS;EAAE,EACpE,CAAC;AAEN;AAEAb,QAAQ,CAACc,qBAAqB,GAAG,IAAI;AACrC,eAAed,QAAQ"}
@@ -1,5 +1,7 @@
1
1
  import { FieldProps, FieldHelpProps } from '../../types';
2
- export type Props = FieldHelpProps & FieldProps<string>;
2
+ export type Props = FieldHelpProps & FieldProps<string> & {
3
+ pattern?: string;
4
+ };
3
5
  declare function DateComponent(props: Props): import("react/jsx-runtime").JSX.Element;
4
6
  declare namespace DateComponent {
5
7
  var _supportsSpacingProps: boolean;
@@ -4,48 +4,90 @@ import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
5
5
  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; }
6
6
  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; }
7
- import React, { useContext } from 'react';
7
+ import React, { useCallback, useContext, useMemo } from 'react';
8
8
  import { DatePicker, HelpButton } from '../../../../components';
9
9
  import { useDataValue } from '../../hooks';
10
10
  import { pickSpacingProps } from '../../../../components/flex/utils';
11
11
  import SharedContext from '../../../../shared/Context';
12
+ import classnames from 'classnames';
13
+ import FieldBlock from '../../FieldBlock';
14
+ import { parseISO, isValid } from 'date-fns';
12
15
  function DateComponent(props) {
13
16
  const sharedContext = useContext(SharedContext);
17
+ const tr = sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.Forms;
18
+ const errorMessages = useMemo(() => _objectSpread({
19
+ required: tr.dateErrorRequired,
20
+ pattern: tr.inputErrorPattern
21
+ }, props.errorMessages), [tr, props.errorMessages]);
22
+ const schema = useMemo(() => {
23
+ var _props$schema;
24
+ return (_props$schema = props.schema) !== null && _props$schema !== void 0 ? _props$schema : {
25
+ type: 'string',
26
+ pattern: props.pattern
27
+ };
28
+ }, [props.schema, props.pattern]);
29
+ const validateRequired = useCallback((value, {
30
+ required,
31
+ error
32
+ }) => {
33
+ if (required && (!value || !isValid(parseISO(value)))) {
34
+ return error;
35
+ }
36
+ return undefined;
37
+ }, []);
14
38
  const preparedProps = _objectSpread(_objectSpread({}, props), {}, {
39
+ errorMessages,
40
+ schema,
15
41
  fromInput: ({
16
42
  date
17
43
  }) => {
18
44
  return date;
19
- }
45
+ },
46
+ validateRequired
20
47
  });
21
48
  const {
49
+ id,
22
50
  className,
23
51
  label,
52
+ labelDescription,
53
+ labelSecondary,
24
54
  value,
25
55
  help,
56
+ info,
57
+ warning,
26
58
  error,
59
+ hasError,
27
60
  disabled,
28
61
  handleFocus,
29
62
  handleBlur,
30
63
  handleChange
31
64
  } = useDataValue(preparedProps);
32
- return React.createElement(DatePicker, _extends({
33
- className: className,
65
+ return React.createElement(FieldBlock, _extends({
66
+ className: classnames('dnb-forms-field-string', className),
67
+ forId: id,
34
68
  label: label !== null && label !== void 0 ? label : sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.Forms.dateLabel,
35
- label_direction: "vertical",
69
+ labelDescription: labelDescription,
70
+ labelSecondary: labelSecondary,
71
+ info: info,
72
+ warning: warning,
73
+ disabled: disabled,
74
+ error: error
75
+ }, pickSpacingProps(props)), React.createElement(DatePicker, _extends({
76
+ id: id,
36
77
  date: value,
37
- status: error === null || error === void 0 ? void 0 : error.message,
38
78
  disabled: disabled,
39
79
  show_input: true,
40
80
  show_cancel_button: true,
41
81
  show_reset_button: true,
82
+ status: error || hasError ? 'error' : undefined,
42
83
  suffix: help ? React.createElement(HelpButton, {
43
84
  title: help.title
44
85
  }, help.contents) : undefined,
45
86
  on_change: handleChange,
46
- on_show: handleFocus,
47
- on_hide: handleBlur
48
- }, pickSpacingProps(props)));
87
+ on_reset: handleChange,
88
+ onFocus: handleFocus,
89
+ onBlur: handleBlur
90
+ }, pickSpacingProps(props))));
49
91
  }
50
92
  DateComponent._supportsSpacingProps = true;
51
93
  export default DateComponent;
@@ -1 +1 @@
1
- {"version":3,"file":"Date.js","names":["React","useContext","DatePicker","HelpButton","useDataValue","pickSpacingProps","SharedContext","DateComponent","props","sharedContext","preparedProps","_objectSpread","fromInput","date","className","label","value","help","error","disabled","handleFocus","handleBlur","handleChange","createElement","_extends","translation","Forms","dateLabel","label_direction","status","message","show_input","show_cancel_button","show_reset_button","suffix","title","contents","undefined","on_change","on_show","on_hide","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Date/Date.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport { DatePicker, HelpButton } from '../../../../components'\nimport { useDataValue } from '../../hooks'\nimport { FieldProps, FieldHelpProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport SharedContext from '../../../../shared/Context'\n\nexport type Props = FieldHelpProps & FieldProps<string>\n\nfunction DateComponent(props: Props) {\n const sharedContext = useContext(SharedContext)\n const preparedProps: Props = {\n ...props,\n fromInput: ({ date }: { date: string }) => {\n return date\n },\n }\n\n const {\n className,\n label,\n value,\n help,\n error,\n disabled,\n handleFocus,\n handleBlur,\n handleChange,\n } = useDataValue(preparedProps)\n\n return (\n <DatePicker\n className={className}\n label={label ?? sharedContext?.translation.Forms.dateLabel}\n label_direction=\"vertical\"\n date={value}\n status={error?.message}\n disabled={disabled}\n show_input={true}\n show_cancel_button={true}\n show_reset_button={true}\n suffix={\n help ? (\n <HelpButton title={help.title}>{help.contents}</HelpButton>\n ) : undefined\n }\n on_change={handleChange}\n on_show={handleFocus}\n on_hide={handleBlur}\n {...pickSpacingProps(props)}\n />\n )\n}\n\nDateComponent._supportsSpacingProps = true\nexport default DateComponent\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,SAASC,UAAU,EAAEC,UAAU,QAAQ,wBAAwB;AAC/D,SAASC,YAAY,QAAQ,aAAa;AAE1C,SAASC,gBAAgB,QAAQ,mCAAmC;AACpE,OAAOC,aAAa,MAAM,4BAA4B;AAItD,SAASC,aAAaA,CAACC,KAAY,EAAE;EACnC,MAAMC,aAAa,GAAGR,UAAU,CAACK,aAAa,CAAC;EAC/C,MAAMI,aAAoB,GAAAC,aAAA,CAAAA,aAAA,KACrBH,KAAK;IACRI,SAAS,EAAEA,CAAC;MAAEC;IAAuB,CAAC,KAAK;MACzC,OAAOA,IAAI;IACb;EAAC,EACF;EAED,MAAM;IACJC,SAAS;IACTC,KAAK;IACLC,KAAK;IACLC,IAAI;IACJC,KAAK;IACLC,QAAQ;IACRC,WAAW;IACXC,UAAU;IACVC;EACF,CAAC,GAAGlB,YAAY,CAACM,aAAa,CAAC;EAE/B,OACEV,KAAA,CAAAuB,aAAA,CAACrB,UAAU,EAAAsB,QAAA;IACTV,SAAS,EAAEA,SAAU;IACrBC,KAAK,EAAEA,KAAK,aAALA,KAAK,cAALA,KAAK,GAAIN,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEgB,WAAW,CAACC,KAAK,CAACC,SAAU;IAC3DC,eAAe,EAAC,UAAU;IAC1Bf,IAAI,EAAEG,KAAM;IACZa,MAAM,EAAEX,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEY,OAAQ;IACvBX,QAAQ,EAAEA,QAAS;IACnBY,UAAU,EAAE,IAAK;IACjBC,kBAAkB,EAAE,IAAK;IACzBC,iBAAiB,EAAE,IAAK;IACxBC,MAAM,EACJjB,IAAI,GACFjB,KAAA,CAAAuB,aAAA,CAACpB,UAAU;MAACgC,KAAK,EAAElB,IAAI,CAACkB;IAAM,GAAElB,IAAI,CAACmB,QAAqB,CAAC,GACzDC,SACL;IACDC,SAAS,EAAEhB,YAAa;IACxBiB,OAAO,EAAEnB,WAAY;IACrBoB,OAAO,EAAEnB;EAAW,GAChBhB,gBAAgB,CAACG,KAAK,CAAC,CAC5B,CAAC;AAEN;AAEAD,aAAa,CAACkC,qBAAqB,GAAG,IAAI;AAC1C,eAAelC,aAAa"}
1
+ {"version":3,"file":"Date.js","names":["React","useCallback","useContext","useMemo","DatePicker","HelpButton","useDataValue","pickSpacingProps","SharedContext","classnames","FieldBlock","parseISO","isValid","DateComponent","props","sharedContext","tr","translation","Forms","errorMessages","_objectSpread","required","dateErrorRequired","pattern","inputErrorPattern","schema","_props$schema","type","validateRequired","value","error","undefined","preparedProps","fromInput","date","id","className","label","labelDescription","labelSecondary","help","info","warning","hasError","disabled","handleFocus","handleBlur","handleChange","createElement","_extends","forId","dateLabel","show_input","show_cancel_button","show_reset_button","status","suffix","title","contents","on_change","on_reset","onFocus","onBlur","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Date/Date.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport { DatePicker, HelpButton } from '../../../../components'\nimport { useDataValue } from '../../hooks'\nimport { FieldProps, FieldHelpProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport SharedContext from '../../../../shared/Context'\nimport { JSONSchema7 } from 'json-schema'\nimport classnames from 'classnames'\nimport FieldBlock from '../../FieldBlock'\nimport { parseISO, isValid } from 'date-fns'\n\nexport type Props = FieldHelpProps &\n FieldProps<string> & {\n // Validation\n pattern?: string\n }\n\nfunction DateComponent(props: Props) {\n const sharedContext = useContext(SharedContext)\n const tr = sharedContext?.translation.Forms\n\n const errorMessages = useMemo(\n () => ({\n required: tr.dateErrorRequired,\n pattern: tr.inputErrorPattern,\n ...props.errorMessages,\n }),\n [tr, props.errorMessages]\n )\n\n const schema = useMemo<JSONSchema7>(\n () =>\n props.schema ?? {\n type: 'string',\n pattern: props.pattern,\n },\n [props.schema, props.pattern]\n )\n\n const validateRequired = useCallback(\n (value: string, { required, error }) => {\n if (required && (!value || !isValid(parseISO(value)))) {\n return error\n }\n\n return undefined\n },\n []\n )\n\n const preparedProps: Props = {\n ...props,\n errorMessages,\n schema,\n fromInput: ({ date }: { date: string }) => {\n return date\n },\n validateRequired,\n }\n\n const {\n id,\n className,\n label,\n labelDescription,\n labelSecondary,\n value,\n help,\n info,\n warning,\n error,\n hasError,\n disabled,\n handleFocus,\n handleBlur,\n handleChange,\n } = useDataValue(preparedProps)\n\n return (\n <FieldBlock\n className={classnames('dnb-forms-field-string', className)}\n forId={id}\n label={label ?? sharedContext?.translation.Forms.dateLabel}\n labelDescription={labelDescription}\n labelSecondary={labelSecondary}\n info={info}\n warning={warning}\n disabled={disabled}\n error={error}\n {...pickSpacingProps(props)}\n >\n <DatePicker\n id={id}\n date={value}\n disabled={disabled}\n show_input={true}\n show_cancel_button={true}\n show_reset_button={true}\n status={error || hasError ? 'error' : undefined}\n suffix={\n help ? (\n <HelpButton title={help.title}>{help.contents}</HelpButton>\n ) : undefined\n }\n on_change={handleChange}\n on_reset={handleChange}\n onFocus={handleFocus}\n onBlur={handleBlur}\n {...pickSpacingProps(props)}\n />\n </FieldBlock>\n )\n}\n\nDateComponent._supportsSpacingProps = true\nexport default DateComponent\n"],"mappings":"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"}
@@ -7,17 +7,19 @@ import React, { useContext, useMemo } from 'react';
7
7
  import StringComponent from '../String';
8
8
  import SharedContext from '../../../../shared/Context';
9
9
  function Email(props) {
10
- var _props$type, _props$pattern, _props$label;
11
10
  const sharedContext = useContext(SharedContext);
12
11
  const tr = sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.Forms;
13
12
  const errorMessages = useMemo(() => _objectSpread({
14
13
  required: tr.emailErrorRequired,
15
14
  pattern: tr.emailErrorPattern
16
15
  }, props.errorMessages), [tr, props.errorMessages]);
17
- const stringComponentProps = _objectSpread(_objectSpread({}, props), {}, {
18
- type: (_props$type = props.type) !== null && _props$type !== void 0 ? _props$type : 'email',
19
- pattern: (_props$pattern = props.pattern) !== null && _props$pattern !== void 0 ? _props$pattern : "^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:.[a-zA-Z0-9-]+)*$",
20
- label: (_props$label = props.label) !== null && _props$label !== void 0 ? _props$label : sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.Forms.emailLabel,
16
+ const stringComponentProps = _objectSpread(_objectSpread({
17
+ label: sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.Forms.emailLabel,
18
+ autoComplete: 'email',
19
+ inputMode: 'email',
20
+ pattern: "^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:.[a-zA-Z0-9-]+)*$",
21
+ trim: true
22
+ }, props), {}, {
21
23
  errorMessages
22
24
  });
23
25
  return React.createElement(StringComponent, stringComponentProps);
@@ -1 +1 @@
1
- {"version":3,"file":"Email.js","names":["React","useContext","useMemo","StringComponent","SharedContext","Email","props","_props$type","_props$pattern","_props$label","sharedContext","tr","translation","Forms","errorMessages","_objectSpread","required","emailErrorRequired","pattern","emailErrorPattern","stringComponentProps","type","label","emailLabel","createElement","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Email/Email.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport StringComponent, { Props as StringComponentProps } from '../String'\nimport SharedContext from '../../../../shared/Context'\n\nexport type Props = StringComponentProps\n\nfunction Email(props: Props) {\n const sharedContext = useContext(SharedContext)\n const tr = sharedContext?.translation.Forms\n\n const errorMessages = useMemo(\n () => ({\n required: tr.emailErrorRequired,\n pattern: tr.emailErrorPattern,\n ...props.errorMessages,\n }),\n [tr, props.errorMessages]\n )\n\n const stringComponentProps: Props = {\n ...props,\n type: props.type ?? 'email',\n pattern:\n props.pattern ??\n \"^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:.[a-zA-Z0-9-]+)*$\",\n label: props.label ?? sharedContext?.translation.Forms.emailLabel,\n errorMessages,\n }\n\n return <StringComponent {...stringComponentProps} />\n}\n\nEmail._supportsSpacingProps = true\nexport default Email\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,eAAe,MAAyC,WAAW;AAC1E,OAAOC,aAAa,MAAM,4BAA4B;AAItD,SAASC,KAAKA,CAACC,KAAY,EAAE;EAAA,IAAAC,WAAA,EAAAC,cAAA,EAAAC,YAAA;EAC3B,MAAMC,aAAa,GAAGT,UAAU,CAACG,aAAa,CAAC;EAC/C,MAAMO,EAAE,GAAGD,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK;EAE3C,MAAMC,aAAa,GAAGZ,OAAO,CAC3B,MAAAa,aAAA;IACEC,QAAQ,EAAEL,EAAE,CAACM,kBAAkB;IAC/BC,OAAO,EAAEP,EAAE,CAACQ;EAAiB,GAC1Bb,KAAK,CAACQ,aAAa,CACtB,EACF,CAACH,EAAE,EAAEL,KAAK,CAACQ,aAAa,CAC1B,CAAC;EAED,MAAMM,oBAA2B,GAAAL,aAAA,CAAAA,aAAA,KAC5BT,KAAK;IACRe,IAAI,GAAAd,WAAA,GAAED,KAAK,CAACe,IAAI,cAAAd,WAAA,cAAAA,WAAA,GAAI,OAAO;IAC3BW,OAAO,GAAAV,cAAA,GACLF,KAAK,CAACY,OAAO,cAAAV,cAAA,cAAAA,cAAA,GACb,qEAAqE;IACvEc,KAAK,GAAAb,YAAA,GAAEH,KAAK,CAACgB,KAAK,cAAAb,YAAA,cAAAA,YAAA,GAAIC,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK,CAACU,UAAU;IACjET;EAAa,EACd;EAED,OAAOd,KAAA,CAAAwB,aAAA,CAACrB,eAAe,EAAKiB,oBAAuB,CAAC;AACtD;AAEAf,KAAK,CAACoB,qBAAqB,GAAG,IAAI;AAClC,eAAepB,KAAK"}
1
+ {"version":3,"file":"Email.js","names":["React","useContext","useMemo","StringComponent","SharedContext","Email","props","sharedContext","tr","translation","Forms","errorMessages","_objectSpread","required","emailErrorRequired","pattern","emailErrorPattern","stringComponentProps","label","emailLabel","autoComplete","inputMode","trim","createElement","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Email/Email.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport StringComponent, { Props as StringComponentProps } from '../String'\nimport SharedContext from '../../../../shared/Context'\n\nexport type Props = StringComponentProps\n\nfunction Email(props: Props) {\n const sharedContext = useContext(SharedContext)\n const tr = sharedContext?.translation.Forms\n\n const errorMessages = useMemo(\n () => ({\n required: tr.emailErrorRequired,\n pattern: tr.emailErrorPattern,\n ...props.errorMessages,\n }),\n [tr, props.errorMessages]\n )\n\n const stringComponentProps: Props = {\n label: sharedContext?.translation.Forms.emailLabel,\n autoComplete: 'email',\n inputMode: 'email',\n pattern:\n \"^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:.[a-zA-Z0-9-]+)*$\",\n trim: true,\n ...props,\n errorMessages,\n }\n\n return <StringComponent {...stringComponentProps} />\n}\n\nEmail._supportsSpacingProps = true\nexport default Email\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,eAAe,MAAyC,WAAW;AAC1E,OAAOC,aAAa,MAAM,4BAA4B;AAItD,SAASC,KAAKA,CAACC,KAAY,EAAE;EAC3B,MAAMC,aAAa,GAAGN,UAAU,CAACG,aAAa,CAAC;EAC/C,MAAMI,EAAE,GAAGD,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK;EAE3C,MAAMC,aAAa,GAAGT,OAAO,CAC3B,MAAAU,aAAA;IACEC,QAAQ,EAAEL,EAAE,CAACM,kBAAkB;IAC/BC,OAAO,EAAEP,EAAE,CAACQ;EAAiB,GAC1BV,KAAK,CAACK,aAAa,CACtB,EACF,CAACH,EAAE,EAAEF,KAAK,CAACK,aAAa,CAC1B,CAAC;EAED,MAAMM,oBAA2B,GAAAL,aAAA,CAAAA,aAAA;IAC/BM,KAAK,EAAEX,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK,CAACS,UAAU;IAClDC,YAAY,EAAE,OAAO;IACrBC,SAAS,EAAE,OAAO;IAClBN,OAAO,EACL,qEAAqE;IACvEO,IAAI,EAAE;EAAI,GACPhB,KAAK;IACRK;EAAa,EACd;EAED,OAAOX,KAAA,CAAAuB,aAAA,CAACpB,eAAe,EAAKc,oBAAuB,CAAC;AACtD;AAEAZ,KAAK,CAACmB,qBAAqB,GAAG,IAAI;AAClC,eAAenB,KAAK"}
@@ -14,7 +14,7 @@ import FieldBlock from '../../FieldBlock';
14
14
  import { MultiInputMask } from '../../../../components/input-masked';
15
15
  import { HelpButton } from '../../../../components';
16
16
  function Expiry(props) {
17
- var _value$substring, _value$substring2;
17
+ var _value$substring;
18
18
  const sharedContext = useContext(SharedContext);
19
19
  const placeholders = sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.DatePicker.placeholder_characters;
20
20
  const {
@@ -38,8 +38,8 @@ function Expiry(props) {
38
38
  emptyValue: ''
39
39
  }));
40
40
  const expiry = {
41
- month: (_value$substring = value.substring(0, 2)) !== null && _value$substring !== void 0 ? _value$substring : '',
42
- year: (_value$substring2 = value.substring(2, 4)) !== null && _value$substring2 !== void 0 ? _value$substring2 : ''
41
+ month: ensureValidMonth(value === null || value === void 0 ? void 0 : value.substring(0, 2)),
42
+ year: (_value$substring = value === null || value === void 0 ? void 0 : value.substring(2, 4)) !== null && _value$substring !== void 0 ? _value$substring : ''
43
43
  };
44
44
  const idRef = useRef(propsId || makeUniqueId()).current;
45
45
  const status = error ? 'error' : warning ? 'warn' : info ? 'info' : null;
@@ -64,10 +64,11 @@ function Expiry(props) {
64
64
  onBlur: handleBlur,
65
65
  onFocus: handleFocus,
66
66
  delimiter: "/",
67
+ inputMode: "numeric",
67
68
  inputs: [{
68
69
  id: 'month',
69
70
  label: sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.DatePicker['month'],
70
- mask: [/[0-1]/, expiry.month.charAt(0) === '0' || expiry.month.charAt(0) === '' ? /[1-9]/ : /[0-2]/],
71
+ mask: getMonthMask(expiry === null || expiry === void 0 ? void 0 : expiry.month),
71
72
  placeholderCharacter: placeholders['month'],
72
73
  autoComplete: 'cc-exp-month'
73
74
  }, {
@@ -84,6 +85,27 @@ function Expiry(props) {
84
85
  function expiryToString(values) {
85
86
  return Object.values(values).join('');
86
87
  }
88
+ function ensureValidMonth(month) {
89
+ if (!month) {
90
+ return '';
91
+ }
92
+ const [firstMask, secondMask] = getMonthMask(month);
93
+ const firstDigit = month === null || month === void 0 ? void 0 : month.charAt(0);
94
+ const isFirstDigitValid = firstMask.test(firstDigit);
95
+ if (firstDigit && !isFirstDigitValid) {
96
+ return '';
97
+ }
98
+ const seconDigit = month === null || month === void 0 ? void 0 : month.charAt(1);
99
+ const isSecondDigitValid = secondMask.test(seconDigit);
100
+ if (seconDigit && !isSecondDigitValid) {
101
+ return '';
102
+ }
103
+ return month;
104
+ }
105
+ function getMonthMask(month) {
106
+ const firstDigit = month === null || month === void 0 ? void 0 : month.charAt(0);
107
+ return [/[0-1]/, firstDigit === '0' || firstDigit === '' ? /[1-9]/ : /[0-2]/];
108
+ }
87
109
  }
88
110
  Expiry._supportsEufemiaSpacingProps = true;
89
111
  export default Expiry;
@@ -1 +1 @@
1
- {"version":3,"file":"Expiry.js","names":["React","useContext","useRef","makeUniqueId","SharedContext","pickSpacingProps","useDataValue","classnames","FieldBlock","MultiInputMask","HelpButton","Expiry","props","_value$substring","_value$substring2","sharedContext","placeholders","translation","DatePicker","placeholder_characters","id","propsId","className","label","Forms","expiryLabel","error","info","warning","help","disabled","value","labelDescription","labelSecondary","layout","required","handleFocus","handleBlur","handleChange","_objectSpread","emptyValue","expiry","month","substring","year","idRef","current","status","createElement","_extends","stretch","labelDirection","values","statusState","undefined","onChange","expiryToString","onBlur","onFocus","delimiter","inputs","mask","charAt","placeholderCharacter","autoComplete","suffix","title","contents","Object","join","_supportsEufemiaSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Expiry/Expiry.tsx"],"sourcesContent":["import React, { useContext, useRef } from 'react'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport SharedContext from '../../../../shared/Context'\nimport { FieldHelpProps, FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport { useDataValue } from '../../hooks'\nimport classnames from 'classnames'\nimport FieldBlock from '../../FieldBlock'\nimport { MultiInputMask } from '../../../../components/input-masked'\nimport type { MultiInputMaskValue } from '../../../../components/input-masked'\nimport { HelpButton } from '../../../../components'\n\ntype ExpiryValue = MultiInputMaskValue<'month' | 'year'>\n\nexport type ExpiryProps = FieldProps<string> & FieldHelpProps\n\nfunction Expiry(props: ExpiryProps) {\n const sharedContext = useContext(SharedContext)\n const placeholders =\n sharedContext?.translation.DatePicker.placeholder_characters\n\n const {\n id: propsId,\n className,\n label = sharedContext?.translation.Forms.expiryLabel,\n error,\n info,\n warning,\n help,\n disabled,\n value = '',\n labelDescription,\n labelSecondary,\n layout = 'vertical',\n required,\n handleFocus,\n handleBlur,\n handleChange,\n } = useDataValue({\n ...props,\n emptyValue: '',\n })\n\n const expiry: ExpiryValue = {\n month: value.substring(0, 2) ?? '',\n year: value.substring(2, 4) ?? '',\n }\n\n const idRef = useRef(propsId || makeUniqueId()).current\n\n const status = error ? 'error' : warning ? 'warn' : info ? 'info' : null\n\n return (\n <FieldBlock\n className={classnames('dnb-forms-field-expiry', className)}\n labelSecondary={labelSecondary}\n labelDescription={labelDescription}\n info={info}\n warning={warning}\n error={error}\n {...pickSpacingProps(props)}\n >\n <MultiInputMask\n stretch\n id={`${idRef}__input`}\n label={label}\n labelDirection={layout}\n values={expiry}\n status={status}\n statusState={disabled ? 'disabled' : undefined}\n disabled={disabled}\n required={required}\n onChange={(expiry) => handleChange(expiryToString(expiry))}\n onBlur={handleBlur}\n onFocus={handleFocus}\n delimiter=\"/\"\n inputs={[\n {\n id: 'month',\n label: sharedContext?.translation.DatePicker['month'],\n mask: [\n /[0-1]/,\n expiry.month.charAt(0) === '0' ||\n expiry.month.charAt(0) === ''\n ? /[1-9]/\n : /[0-2]/,\n ],\n placeholderCharacter: placeholders['month'],\n autoComplete: 'cc-exp-month',\n },\n {\n id: 'year',\n label: sharedContext?.translation.DatePicker['year'],\n mask: [/[0-9]/, /[0-9]/],\n placeholderCharacter: placeholders['year'],\n autoComplete: 'cc-exp-year',\n },\n ]}\n suffix={\n help ? (\n <HelpButton title={help.title}>{help.contents}</HelpButton>\n ) : undefined\n }\n />\n </FieldBlock>\n )\n\n function expiryToString(values: ExpiryValue) {\n return Object.values(values).join('')\n }\n}\n\nExpiry._supportsEufemiaSpacingProps = true\nexport default Expiry\n"],"mappings":"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"}
1
+ {"version":3,"file":"Expiry.js","names":["React","useContext","useRef","makeUniqueId","SharedContext","pickSpacingProps","useDataValue","classnames","FieldBlock","MultiInputMask","HelpButton","Expiry","props","_value$substring","sharedContext","placeholders","translation","DatePicker","placeholder_characters","id","propsId","className","label","Forms","expiryLabel","error","info","warning","help","disabled","value","labelDescription","labelSecondary","layout","required","handleFocus","handleBlur","handleChange","_objectSpread","emptyValue","expiry","month","ensureValidMonth","substring","year","idRef","current","status","createElement","_extends","stretch","labelDirection","values","statusState","undefined","onChange","expiryToString","onBlur","onFocus","delimiter","inputMode","inputs","mask","getMonthMask","placeholderCharacter","autoComplete","suffix","title","contents","Object","join","firstMask","secondMask","firstDigit","charAt","isFirstDigitValid","test","seconDigit","isSecondDigitValid","_supportsEufemiaSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Expiry/Expiry.tsx"],"sourcesContent":["import React, { useContext, useRef } from 'react'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport SharedContext from '../../../../shared/Context'\nimport { FieldHelpProps, FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport { useDataValue } from '../../hooks'\nimport classnames from 'classnames'\nimport FieldBlock from '../../FieldBlock'\nimport { MultiInputMask } from '../../../../components/input-masked'\nimport type { MultiInputMaskValue } from '../../../../components/input-masked'\nimport { HelpButton } from '../../../../components'\n\ntype ExpiryValue = MultiInputMaskValue<'month' | 'year'>\n\nexport type ExpiryProps = FieldProps<string> & FieldHelpProps\n\nfunction Expiry(props: ExpiryProps) {\n const sharedContext = useContext(SharedContext)\n const placeholders =\n sharedContext?.translation.DatePicker.placeholder_characters\n\n const {\n id: propsId,\n className,\n label = sharedContext?.translation.Forms.expiryLabel,\n error,\n info,\n warning,\n help,\n disabled,\n value = '',\n labelDescription,\n labelSecondary,\n layout = 'vertical',\n required,\n handleFocus,\n handleBlur,\n handleChange,\n } = useDataValue({\n ...props,\n emptyValue: '',\n })\n\n const expiry: ExpiryValue = {\n month: ensureValidMonth(value?.substring(0, 2)),\n year: value?.substring(2, 4) ?? '',\n }\n\n const idRef = useRef(propsId || makeUniqueId()).current\n\n const status = error ? 'error' : warning ? 'warn' : info ? 'info' : null\n\n return (\n <FieldBlock\n className={classnames('dnb-forms-field-expiry', className)}\n labelSecondary={labelSecondary}\n labelDescription={labelDescription}\n info={info}\n warning={warning}\n error={error}\n {...pickSpacingProps(props)}\n >\n <MultiInputMask\n stretch\n id={`${idRef}__input`}\n label={label}\n labelDirection={layout}\n values={expiry}\n status={status}\n statusState={disabled ? 'disabled' : undefined}\n disabled={disabled}\n required={required}\n onChange={(expiry) => handleChange(expiryToString(expiry))}\n onBlur={handleBlur}\n onFocus={handleFocus}\n delimiter=\"/\"\n inputMode=\"numeric\"\n inputs={[\n {\n id: 'month',\n label: sharedContext?.translation.DatePicker['month'],\n mask: getMonthMask(expiry?.month),\n placeholderCharacter: placeholders['month'],\n autoComplete: 'cc-exp-month',\n },\n {\n id: 'year',\n label: sharedContext?.translation.DatePicker['year'],\n mask: [/[0-9]/, /[0-9]/],\n placeholderCharacter: placeholders['year'],\n autoComplete: 'cc-exp-year',\n },\n ]}\n suffix={\n help ? (\n <HelpButton title={help.title}>{help.contents}</HelpButton>\n ) : undefined\n }\n />\n </FieldBlock>\n )\n\n function expiryToString(values: ExpiryValue) {\n return Object.values(values).join('')\n }\n\n function ensureValidMonth(month: string) {\n // Return empty value if no month is given\n if (!month) {\n return ''\n }\n\n const [firstMask, secondMask] = getMonthMask(month)\n\n const firstDigit = month?.charAt(0)\n const isFirstDigitValid = firstMask.test(firstDigit)\n\n if (firstDigit && !isFirstDigitValid) {\n // Return empty value if the first digit is invalid\n return ''\n }\n\n const seconDigit = month?.charAt(1)\n const isSecondDigitValid = secondMask.test(seconDigit)\n\n if (seconDigit && !isSecondDigitValid) {\n // Return empty value if the second digit is invalid\n return ''\n }\n\n // Return given month of month value is valid\n return month\n }\n\n function getMonthMask(month: string) {\n const firstDigit = month?.charAt(0)\n\n return [\n /[0-1]/,\n firstDigit === '0' || firstDigit === '' ? /[1-9]/ : /[0-2]/,\n ]\n }\n}\n\nExpiry._supportsEufemiaSpacingProps = true\nexport default Expiry\n"],"mappings":"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"}
@@ -25,7 +25,8 @@ function NationalIdentityNumber(props) {
25
25
  label: (_props$label = props.label) !== null && _props$label !== void 0 ? _props$label : sharedContext === null || sharedContext === void 0 ? void 0 : sharedContext.translation.Forms.nationalIdentityNumberLabel,
26
26
  errorMessages,
27
27
  mask,
28
- width: (_props$width = props.width) !== null && _props$width !== void 0 ? _props$width : 'medium'
28
+ width: (_props$width = props.width) !== null && _props$width !== void 0 ? _props$width : 'medium',
29
+ inputMode: 'numeric'
29
30
  });
30
31
  return React.createElement(StringComponent, stringComponentProps);
31
32
  }
@@ -1 +1 @@
1
- {"version":3,"file":"NationalIdentityNumber.js","names":["React","useContext","useMemo","StringComponent","SharedContext","NationalIdentityNumber","props","_props$pattern","_props$label","_props$width","sharedContext","tr","translation","Forms","errorMessage","nationalIdentityNumberErrorRequired","validate","omitMask","errorMessages","_objectSpread","required","pattern","mask","Array","fill","stringComponentProps","validator","undefined","label","nationalIdentityNumberLabel","width","createElement","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport StringComponent, { Props as StringComponentProps } from '../String'\nimport SharedContext from '../../../../shared/Context'\n\nexport type Props = StringComponentProps & {\n omitMask?: boolean\n validate?: boolean\n}\n\nfunction NationalIdentityNumber(props: Props) {\n const sharedContext = useContext(SharedContext)\n const tr = sharedContext?.translation.Forms\n const errorMessage = tr.nationalIdentityNumberErrorRequired\n\n const { validate = true, omitMask } = props\n\n const errorMessages = useMemo(\n () => ({\n required: errorMessage,\n pattern: errorMessage,\n ...props.errorMessages,\n }),\n [errorMessage, props.errorMessages]\n )\n const mask = useMemo(\n () =>\n omitMask\n ? Array(11).fill(/\\d/)\n : [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ],\n [omitMask]\n )\n\n const stringComponentProps: Props = {\n ...props,\n pattern:\n props.pattern ??\n (validate && !props.validator ? '^[0-9]{11}$' : undefined),\n label:\n props.label ??\n sharedContext?.translation.Forms.nationalIdentityNumberLabel,\n errorMessages,\n mask,\n width: props.width ?? 'medium',\n }\n\n return <StringComponent {...stringComponentProps} />\n}\n\nNationalIdentityNumber._supportsSpacingProps = true\nexport default NationalIdentityNumber\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,eAAe,MAAyC,WAAW;AAC1E,OAAOC,aAAa,MAAM,4BAA4B;AAOtD,SAASC,sBAAsBA,CAACC,KAAY,EAAE;EAAA,IAAAC,cAAA,EAAAC,YAAA,EAAAC,YAAA;EAC5C,MAAMC,aAAa,GAAGT,UAAU,CAACG,aAAa,CAAC;EAC/C,MAAMO,EAAE,GAAGD,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK;EAC3C,MAAMC,YAAY,GAAGH,EAAE,CAACI,mCAAmC;EAE3D,MAAM;IAAEC,QAAQ,GAAG,IAAI;IAAEC;EAAS,CAAC,GAAGX,KAAK;EAE3C,MAAMY,aAAa,GAAGhB,OAAO,CAC3B,MAAAiB,aAAA;IACEC,QAAQ,EAAEN,YAAY;IACtBO,OAAO,EAAEP;EAAY,GAClBR,KAAK,CAACY,aAAa,CACtB,EACF,CAACJ,YAAY,EAAER,KAAK,CAACY,aAAa,CACpC,CAAC;EACD,MAAMI,IAAI,GAAGpB,OAAO,CAClB,MACEe,QAAQ,GACJM,KAAK,CAAC,EAAE,CAAC,CAACC,IAAI,CAAC,IAAI,CAAC,GACpB,CACE,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,CACL,EACP,CAACP,QAAQ,CACX,CAAC;EAED,MAAMQ,oBAA2B,GAAAN,aAAA,CAAAA,aAAA,KAC5Bb,KAAK;IACRe,OAAO,GAAAd,cAAA,GACLD,KAAK,CAACe,OAAO,cAAAd,cAAA,cAAAA,cAAA,GACZS,QAAQ,IAAI,CAACV,KAAK,CAACoB,SAAS,GAAG,aAAa,GAAGC,SAAU;IAC5DC,KAAK,GAAApB,YAAA,GACHF,KAAK,CAACsB,KAAK,cAAApB,YAAA,cAAAA,YAAA,GACXE,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK,CAACgB,2BAA2B;IAC9DX,aAAa;IACbI,IAAI;IACJQ,KAAK,GAAArB,YAAA,GAAEH,KAAK,CAACwB,KAAK,cAAArB,YAAA,cAAAA,YAAA,GAAI;EAAQ,EAC/B;EAED,OAAOT,KAAA,CAAA+B,aAAA,CAAC5B,eAAe,EAAKsB,oBAAuB,CAAC;AACtD;AAEApB,sBAAsB,CAAC2B,qBAAqB,GAAG,IAAI;AACnD,eAAe3B,sBAAsB"}
1
+ {"version":3,"file":"NationalIdentityNumber.js","names":["React","useContext","useMemo","StringComponent","SharedContext","NationalIdentityNumber","props","_props$pattern","_props$label","_props$width","sharedContext","tr","translation","Forms","errorMessage","nationalIdentityNumberErrorRequired","validate","omitMask","errorMessages","_objectSpread","required","pattern","mask","Array","fill","stringComponentProps","validator","undefined","label","nationalIdentityNumberLabel","width","inputMode","createElement","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport StringComponent, { Props as StringComponentProps } from '../String'\nimport SharedContext from '../../../../shared/Context'\n\nexport type Props = StringComponentProps & {\n omitMask?: boolean\n validate?: boolean\n}\n\nfunction NationalIdentityNumber(props: Props) {\n const sharedContext = useContext(SharedContext)\n const tr = sharedContext?.translation.Forms\n const errorMessage = tr.nationalIdentityNumberErrorRequired\n\n const { validate = true, omitMask } = props\n\n const errorMessages = useMemo(\n () => ({\n required: errorMessage,\n pattern: errorMessage,\n ...props.errorMessages,\n }),\n [errorMessage, props.errorMessages]\n )\n const mask = useMemo(\n () =>\n omitMask\n ? Array(11).fill(/\\d/)\n : [\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ],\n [omitMask]\n )\n\n const stringComponentProps: Props = {\n ...props,\n pattern:\n props.pattern ??\n (validate && !props.validator ? '^[0-9]{11}$' : undefined),\n label:\n props.label ??\n sharedContext?.translation.Forms.nationalIdentityNumberLabel,\n errorMessages,\n mask,\n width: props.width ?? 'medium',\n inputMode: 'numeric',\n }\n\n return <StringComponent {...stringComponentProps} />\n}\n\nNationalIdentityNumber._supportsSpacingProps = true\nexport default NationalIdentityNumber\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,eAAe,MAAyC,WAAW;AAC1E,OAAOC,aAAa,MAAM,4BAA4B;AAOtD,SAASC,sBAAsBA,CAACC,KAAY,EAAE;EAAA,IAAAC,cAAA,EAAAC,YAAA,EAAAC,YAAA;EAC5C,MAAMC,aAAa,GAAGT,UAAU,CAACG,aAAa,CAAC;EAC/C,MAAMO,EAAE,GAAGD,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK;EAC3C,MAAMC,YAAY,GAAGH,EAAE,CAACI,mCAAmC;EAE3D,MAAM;IAAEC,QAAQ,GAAG,IAAI;IAAEC;EAAS,CAAC,GAAGX,KAAK;EAE3C,MAAMY,aAAa,GAAGhB,OAAO,CAC3B,MAAAiB,aAAA;IACEC,QAAQ,EAAEN,YAAY;IACtBO,OAAO,EAAEP;EAAY,GAClBR,KAAK,CAACY,aAAa,CACtB,EACF,CAACJ,YAAY,EAAER,KAAK,CAACY,aAAa,CACpC,CAAC;EACD,MAAMI,IAAI,GAAGpB,OAAO,CAClB,MACEe,QAAQ,GACJM,KAAK,CAAC,EAAE,CAAC,CAACC,IAAI,CAAC,IAAI,CAAC,GACpB,CACE,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,CACL,EACP,CAACP,QAAQ,CACX,CAAC;EAED,MAAMQ,oBAA2B,GAAAN,aAAA,CAAAA,aAAA,KAC5Bb,KAAK;IACRe,OAAO,GAAAd,cAAA,GACLD,KAAK,CAACe,OAAO,cAAAd,cAAA,cAAAA,cAAA,GACZS,QAAQ,IAAI,CAACV,KAAK,CAACoB,SAAS,GAAG,aAAa,GAAGC,SAAU;IAC5DC,KAAK,GAAApB,YAAA,GACHF,KAAK,CAACsB,KAAK,cAAApB,YAAA,cAAAA,YAAA,GACXE,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEE,WAAW,CAACC,KAAK,CAACgB,2BAA2B;IAC9DX,aAAa;IACbI,IAAI;IACJQ,KAAK,GAAArB,YAAA,GAAEH,KAAK,CAACwB,KAAK,cAAArB,YAAA,cAAAA,YAAA,GAAI,QAAQ;IAC9BsB,SAAS,EAAE;EAAS,EACrB;EAED,OAAO/B,KAAA,CAAAgC,aAAA,CAAC7B,eAAe,EAAKsB,oBAAuB,CAAC;AACtD;AAEApB,sBAAsB,CAAC4B,qBAAqB,GAAG,IAAI;AACnD,eAAe5B,sBAAsB"}
@@ -1,4 +1,5 @@
1
1
  import { InputMaskedProps } from '../../../../components/InputMasked';
2
+ import type { InputAlign, InputSize } from '../../../../components/Input';
2
3
  import { FieldProps, FieldHelpProps } from '../../types';
3
4
  interface ErrorMessages {
4
5
  required?: string;
@@ -14,6 +15,7 @@ export type Props = FieldHelpProps & FieldProps<number, undefined, ErrorMessages
14
15
  currency?: InputMaskedProps['as_currency'];
15
16
  percent?: InputMaskedProps['as_percent'];
16
17
  mask?: InputMaskedProps['mask'];
18
+ step?: number;
17
19
  thousandSeparator?: string | true;
18
20
  decimalSymbol?: string;
19
21
  decimalLimit?: number;
@@ -24,8 +26,10 @@ export type Props = FieldHelpProps & FieldProps<number, undefined, ErrorMessages
24
26
  exclusiveMinimum?: number;
25
27
  exclusiveMaximum?: number;
26
28
  multipleOf?: number;
29
+ size?: InputSize;
27
30
  width?: false | 'small' | 'medium' | 'large' | 'stretch';
28
- rightAligned?: boolean;
31
+ align?: InputAlign;
32
+ showStepControls?: boolean;
29
33
  };
30
34
  declare function NumberComponent(props: Props): import("react/jsx-runtime").JSX.Element;
31
35
  declare namespace NumberComponent {