@dnb/eufemia 10.15.1 → 10.16.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 (919) hide show
  1. package/CHANGELOG.md +43 -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/style/anchor-mixins.scss +8 -6
  25. package/cjs/components/anchor/style/dnb-anchor.css +28 -8
  26. package/cjs/components/anchor/style/dnb-anchor.min.css +1 -1
  27. package/cjs/components/card/Card.d.ts +1 -1
  28. package/cjs/components/card/Card.js +48 -9
  29. package/cjs/components/card/Card.js.map +1 -1
  30. package/cjs/components/card/style/dnb-card.css +0 -20
  31. package/cjs/components/card/style/dnb-card.min.css +1 -1
  32. package/cjs/components/card/style/dnb-card.scss +0 -20
  33. package/cjs/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  34. package/cjs/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  35. package/cjs/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  36. package/cjs/components/date-picker/DatePicker.d.ts +5 -1
  37. package/cjs/components/date-picker/DatePicker.js +4 -2
  38. package/cjs/components/date-picker/DatePicker.js.map +1 -1
  39. package/cjs/components/date-picker/DatePickerInput.js +20 -6
  40. package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
  41. package/cjs/components/date-picker/DatePickerProvider.js +2 -2
  42. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  43. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  44. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  45. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  46. package/cjs/components/flex/Container.d.ts +2 -4
  47. package/cjs/components/flex/Container.js.map +1 -1
  48. package/cjs/components/flex/Item.d.ts +2 -3
  49. package/cjs/components/flex/Item.js +2 -1
  50. package/cjs/components/flex/Item.js.map +1 -1
  51. package/cjs/components/input/Input.d.ts +3 -2
  52. package/cjs/components/input-masked/InputMaskedHooks.js +5 -5
  53. package/cjs/components/input-masked/InputMaskedHooks.js.map +1 -1
  54. package/cjs/components/input-masked/InputMaskedUtils.d.ts +4 -2
  55. package/cjs/components/input-masked/InputMaskedUtils.js +9 -7
  56. package/cjs/components/input-masked/InputMaskedUtils.js.map +1 -1
  57. package/cjs/components/input-masked/MultiInputMask.d.ts +1 -1
  58. package/cjs/components/input-masked/MultiInputMask.js +4 -2
  59. package/cjs/components/input-masked/MultiInputMask.js.map +1 -1
  60. package/cjs/components/input-masked/TextMask.js +15 -4
  61. package/cjs/components/input-masked/TextMask.js.map +1 -1
  62. package/cjs/components/input-masked/style/dnb-input-masked.css +3 -0
  63. package/cjs/components/input-masked/style/dnb-input-masked.min.css +1 -1
  64. package/cjs/components/input-masked/style/dnb-input-masked.scss +5 -0
  65. package/cjs/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  66. package/cjs/components/input-masked/text-mask/InputModeNumber.js +93 -0
  67. package/cjs/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  68. package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  69. package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  70. package/cjs/components/radio/RadioGroup.js +0 -1
  71. package/cjs/components/radio/RadioGroup.js.map +1 -1
  72. package/cjs/components/section/Section.d.ts +7 -0
  73. package/cjs/components/section/Section.js +11 -12
  74. package/cjs/components/section/Section.js.map +1 -1
  75. package/cjs/components/section/style/dnb-section.css +6 -4
  76. package/cjs/components/section/style/dnb-section.min.css +1 -1
  77. package/cjs/components/section/style/dnb-section.scss +7 -4
  78. package/cjs/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  79. package/cjs/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  80. package/cjs/components/textarea/Textarea.js +4 -9
  81. package/cjs/components/textarea/Textarea.js.map +1 -1
  82. package/cjs/components/toggle-button/ToggleButtonGroup.js +0 -1
  83. package/cjs/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  84. package/cjs/components/toggle-button/style/dnb-toggle-button.css +4 -6
  85. package/cjs/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  86. package/cjs/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  87. package/cjs/components/tooltip/style/dnb-tooltip.css +1 -0
  88. package/cjs/components/tooltip/style/dnb-tooltip.min.css +1 -1
  89. package/cjs/components/tooltip/style/dnb-tooltip.scss +2 -0
  90. package/cjs/components/upload/types.d.ts +1 -1
  91. package/cjs/components/upload/types.js.map +1 -1
  92. package/cjs/extensions/forms/DataContext/Context.d.ts +1 -0
  93. package/cjs/extensions/forms/DataContext/Context.js +1 -0
  94. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  95. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  96. package/cjs/extensions/forms/DataContext/Provider/Provider.js +37 -13
  97. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  98. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  99. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  100. package/cjs/extensions/forms/Field/Date/Date.js +3 -1
  101. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  102. package/cjs/extensions/forms/Field/Email/Email.js +7 -5
  103. package/cjs/extensions/forms/Field/Email/Email.js.map +1 -1
  104. package/cjs/extensions/forms/Field/Expiry/Expiry.js +26 -4
  105. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  106. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  107. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  108. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  109. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  110. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +69 -30
  111. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  112. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  113. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  114. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  115. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  116. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  117. package/cjs/extensions/forms/Field/Selection/Selection.js +59 -50
  118. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  119. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  120. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  121. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  122. package/cjs/extensions/forms/Field/String/String.d.ts +1 -0
  123. package/cjs/extensions/forms/Field/String/String.js +13 -8
  124. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  125. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +2 -2
  126. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  127. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +1 -1
  128. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  129. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +1 -1
  130. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  131. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  132. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  133. package/cjs/extensions/forms/Form/Handler/Handler.js +2 -2
  134. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  135. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  136. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  137. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  138. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  139. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  140. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  141. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  142. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  143. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  144. package/cjs/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  145. package/cjs/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  146. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  147. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  148. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  149. package/cjs/extensions/forms/hooks/useDataValue.d.ts +3 -0
  150. package/cjs/extensions/forms/hooks/useDataValue.js +98 -48
  151. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  152. package/cjs/extensions/forms/style/dnb-forms.css +42 -25
  153. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  154. package/cjs/extensions/forms/types.d.ts +12 -2
  155. package/cjs/extensions/forms/types.js +1 -1
  156. package/cjs/extensions/forms/types.js.map +1 -1
  157. package/cjs/icons/browser.d.ts +3 -0
  158. package/cjs/icons/browser.js +11 -0
  159. package/cjs/icons/browser.js.map +1 -0
  160. package/cjs/icons/browser_medium.d.ts +3 -0
  161. package/cjs/icons/browser_medium.js +11 -0
  162. package/cjs/icons/browser_medium.js.map +1 -0
  163. package/cjs/icons/digipass_corporate.d.ts +3 -0
  164. package/cjs/icons/digipass_corporate.js +11 -0
  165. package/cjs/icons/digipass_corporate.js.map +1 -0
  166. package/cjs/icons/digipass_corporate_medium.d.ts +3 -0
  167. package/cjs/icons/digipass_corporate_medium.js +11 -0
  168. package/cjs/icons/digipass_corporate_medium.js.map +1 -0
  169. package/cjs/icons/digipass_private.d.ts +3 -0
  170. package/cjs/icons/digipass_private.js +11 -0
  171. package/cjs/icons/digipass_private.js.map +1 -0
  172. package/cjs/icons/digipass_private_medium.d.ts +3 -0
  173. package/cjs/icons/digipass_private_medium.js +11 -0
  174. package/cjs/icons/digipass_private_medium.js.map +1 -0
  175. package/cjs/icons/dnb/browser.d.ts +3 -0
  176. package/cjs/icons/dnb/browser.js +25 -0
  177. package/cjs/icons/dnb/browser.js.map +1 -0
  178. package/cjs/icons/dnb/browser_medium.d.ts +3 -0
  179. package/cjs/icons/dnb/browser_medium.js +25 -0
  180. package/cjs/icons/dnb/browser_medium.js.map +1 -0
  181. package/cjs/icons/dnb/coins_1.js +1 -1
  182. package/cjs/icons/dnb/coins_1.js.map +1 -1
  183. package/cjs/icons/dnb/coins_1_medium.js +1 -1
  184. package/cjs/icons/dnb/coins_1_medium.js.map +1 -1
  185. package/cjs/icons/dnb/digipass_corporate.d.ts +3 -0
  186. package/cjs/icons/dnb/digipass_corporate.js +25 -0
  187. package/cjs/icons/dnb/digipass_corporate.js.map +1 -0
  188. package/cjs/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  189. package/cjs/icons/dnb/digipass_corporate_medium.js +25 -0
  190. package/cjs/icons/dnb/digipass_corporate_medium.js.map +1 -0
  191. package/cjs/icons/dnb/digipass_private.d.ts +3 -0
  192. package/cjs/icons/dnb/digipass_private.js +25 -0
  193. package/cjs/icons/dnb/digipass_private.js.map +1 -0
  194. package/cjs/icons/dnb/digipass_private_medium.d.ts +3 -0
  195. package/cjs/icons/dnb/digipass_private_medium.js +25 -0
  196. package/cjs/icons/dnb/digipass_private_medium.js.map +1 -0
  197. package/cjs/icons/dnb/envelope_open.d.ts +3 -0
  198. package/cjs/icons/dnb/envelope_open.js +26 -0
  199. package/cjs/icons/dnb/envelope_open.js.map +1 -0
  200. package/cjs/icons/dnb/envelope_open_medium.d.ts +3 -0
  201. package/cjs/icons/dnb/envelope_open_medium.js +26 -0
  202. package/cjs/icons/dnb/envelope_open_medium.js.map +1 -0
  203. package/cjs/icons/dnb/icons-meta.json +230 -20
  204. package/cjs/icons/dnb/icons-svg.lock +1272 -1064
  205. package/cjs/icons/dnb/index.d.ts +17 -1
  206. package/cjs/icons/dnb/index.js +112 -0
  207. package/cjs/icons/dnb/index.js.map +1 -1
  208. package/cjs/icons/dnb/laptop.d.ts +3 -0
  209. package/cjs/icons/dnb/laptop.js +26 -0
  210. package/cjs/icons/dnb/laptop.js.map +1 -0
  211. package/cjs/icons/dnb/laptop_medium.d.ts +3 -0
  212. package/cjs/icons/dnb/laptop_medium.js +26 -0
  213. package/cjs/icons/dnb/laptop_medium.js.map +1 -0
  214. package/cjs/icons/dnb/mobile.d.ts +3 -0
  215. package/cjs/icons/dnb/mobile.js +23 -0
  216. package/cjs/icons/dnb/mobile.js.map +1 -0
  217. package/cjs/icons/dnb/mobile_medium.d.ts +3 -0
  218. package/cjs/icons/dnb/mobile_medium.js +23 -0
  219. package/cjs/icons/dnb/mobile_medium.js.map +1 -0
  220. package/cjs/icons/dnb/money_left.d.ts +3 -0
  221. package/cjs/icons/dnb/money_left.js +25 -0
  222. package/cjs/icons/dnb/money_left.js.map +1 -0
  223. package/cjs/icons/dnb/money_left_medium.d.ts +3 -0
  224. package/cjs/icons/dnb/money_left_medium.js +26 -0
  225. package/cjs/icons/dnb/money_left_medium.js.map +1 -0
  226. package/cjs/icons/dnb/scan.js +5 -2
  227. package/cjs/icons/dnb/scan.js.map +1 -1
  228. package/cjs/icons/dnb/scan_medium.js +8 -12
  229. package/cjs/icons/dnb/scan_medium.js.map +1 -1
  230. package/cjs/icons/dnb/secondary_icons.d.ts +9 -1
  231. package/cjs/icons/dnb/secondary_icons.js +56 -0
  232. package/cjs/icons/dnb/secondary_icons.js.map +1 -1
  233. package/cjs/icons/dnb/secondary_icons_medium.d.ts +9 -1
  234. package/cjs/icons/dnb/secondary_icons_medium.js +56 -0
  235. package/cjs/icons/dnb/secondary_icons_medium.js.map +1 -1
  236. package/cjs/icons/dnb/teenager.d.ts +3 -0
  237. package/cjs/icons/dnb/teenager.js +26 -0
  238. package/cjs/icons/dnb/teenager.js.map +1 -0
  239. package/cjs/icons/dnb/teenager_medium.d.ts +3 -0
  240. package/cjs/icons/dnb/teenager_medium.js +26 -0
  241. package/cjs/icons/dnb/teenager_medium.js.map +1 -0
  242. package/cjs/icons/envelope_open.d.ts +3 -0
  243. package/cjs/icons/envelope_open.js +11 -0
  244. package/cjs/icons/envelope_open.js.map +1 -0
  245. package/cjs/icons/envelope_open_medium.d.ts +3 -0
  246. package/cjs/icons/envelope_open_medium.js +11 -0
  247. package/cjs/icons/envelope_open_medium.js.map +1 -0
  248. package/cjs/icons/index.d.ts +17 -1
  249. package/cjs/icons/index.js +112 -0
  250. package/cjs/icons/index.js.map +1 -1
  251. package/cjs/icons/laptop.d.ts +3 -0
  252. package/cjs/icons/laptop.js +11 -0
  253. package/cjs/icons/laptop.js.map +1 -0
  254. package/cjs/icons/laptop_medium.d.ts +3 -0
  255. package/cjs/icons/laptop_medium.js +11 -0
  256. package/cjs/icons/laptop_medium.js.map +1 -0
  257. package/cjs/icons/mobile.d.ts +3 -0
  258. package/cjs/icons/mobile.js +11 -0
  259. package/cjs/icons/mobile.js.map +1 -0
  260. package/cjs/icons/mobile_medium.d.ts +3 -0
  261. package/cjs/icons/mobile_medium.js +11 -0
  262. package/cjs/icons/mobile_medium.js.map +1 -0
  263. package/cjs/icons/money_left.d.ts +3 -0
  264. package/cjs/icons/money_left.js +11 -0
  265. package/cjs/icons/money_left.js.map +1 -0
  266. package/cjs/icons/money_left_medium.d.ts +3 -0
  267. package/cjs/icons/money_left_medium.js +11 -0
  268. package/cjs/icons/money_left_medium.js.map +1 -0
  269. package/cjs/icons/teenager.d.ts +3 -0
  270. package/cjs/icons/teenager.js +11 -0
  271. package/cjs/icons/teenager.js.map +1 -0
  272. package/cjs/icons/teenager_medium.d.ts +3 -0
  273. package/cjs/icons/teenager_medium.js +11 -0
  274. package/cjs/icons/teenager_medium.js.map +1 -0
  275. package/cjs/shared/Eufemia.d.ts +1 -1
  276. package/cjs/shared/Eufemia.js +2 -2
  277. package/cjs/shared/Eufemia.js.map +1 -1
  278. package/cjs/shared/component-helper.d.ts +1 -0
  279. package/cjs/shared/component-helper.js +6 -1
  280. package/cjs/shared/component-helper.js.map +1 -1
  281. package/cjs/style/dnb-ui-components.css +84 -63
  282. package/cjs/style/dnb-ui-components.min.css +3 -3
  283. package/cjs/style/dnb-ui-extensions.css +42 -25
  284. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  285. package/cjs/style/dnb-ui-forms.css +42 -25
  286. package/cjs/style/dnb-ui-forms.min.css +1 -1
  287. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  288. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  289. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +166 -91
  290. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +5 -5
  291. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  292. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  293. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  294. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +42 -25
  295. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  296. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +42 -25
  297. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  298. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +155 -90
  299. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +4 -4
  300. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  301. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +42 -25
  302. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  303. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +42 -25
  304. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  305. package/cjs/style/themes/theme-ui/ui-theme-basis.css +14 -2
  306. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  307. package/cjs/style/themes/theme-ui/ui-theme-components.css +166 -91
  308. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +5 -5
  309. package/cjs/style/themes/theme-ui/ui-theme-components.scss +1 -0
  310. package/cjs/style/themes/theme-ui/ui-theme-elements.css +14 -2
  311. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  312. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +42 -25
  313. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  314. package/cjs/style/themes/theme-ui/ui-theme-forms.css +42 -25
  315. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  316. package/cjs/style/themes/theme-ui/ui-theme-tags.css +3 -3
  317. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  318. package/components/anchor/style/anchor-mixins.scss +8 -6
  319. package/components/anchor/style/dnb-anchor.css +28 -8
  320. package/components/anchor/style/dnb-anchor.min.css +1 -1
  321. package/components/card/Card.d.ts +1 -1
  322. package/components/card/Card.js +46 -9
  323. package/components/card/Card.js.map +1 -1
  324. package/components/card/style/dnb-card.css +0 -20
  325. package/components/card/style/dnb-card.min.css +1 -1
  326. package/components/card/style/dnb-card.scss +0 -20
  327. package/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  328. package/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  329. package/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  330. package/components/date-picker/DatePicker.d.ts +5 -1
  331. package/components/date-picker/DatePicker.js +4 -2
  332. package/components/date-picker/DatePicker.js.map +1 -1
  333. package/components/date-picker/DatePickerInput.js +20 -6
  334. package/components/date-picker/DatePickerInput.js.map +1 -1
  335. package/components/date-picker/DatePickerProvider.js +2 -2
  336. package/components/date-picker/DatePickerProvider.js.map +1 -1
  337. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  338. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  339. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  340. package/components/flex/Container.d.ts +2 -4
  341. package/components/flex/Container.js.map +1 -1
  342. package/components/flex/Item.d.ts +2 -3
  343. package/components/flex/Item.js +2 -1
  344. package/components/flex/Item.js.map +1 -1
  345. package/components/input/Input.d.ts +3 -2
  346. package/components/input-masked/InputMaskedHooks.js +6 -6
  347. package/components/input-masked/InputMaskedHooks.js.map +1 -1
  348. package/components/input-masked/InputMaskedUtils.d.ts +4 -2
  349. package/components/input-masked/InputMaskedUtils.js +9 -7
  350. package/components/input-masked/InputMaskedUtils.js.map +1 -1
  351. package/components/input-masked/MultiInputMask.d.ts +1 -1
  352. package/components/input-masked/MultiInputMask.js +4 -2
  353. package/components/input-masked/MultiInputMask.js.map +1 -1
  354. package/components/input-masked/TextMask.js +15 -4
  355. package/components/input-masked/TextMask.js.map +1 -1
  356. package/components/input-masked/style/dnb-input-masked.css +3 -0
  357. package/components/input-masked/style/dnb-input-masked.min.css +1 -1
  358. package/components/input-masked/style/dnb-input-masked.scss +5 -0
  359. package/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  360. package/components/input-masked/text-mask/InputModeNumber.js +84 -0
  361. package/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  362. package/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  363. package/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  364. package/components/radio/RadioGroup.js +0 -1
  365. package/components/radio/RadioGroup.js.map +1 -1
  366. package/components/section/Section.d.ts +7 -0
  367. package/components/section/Section.js +10 -12
  368. package/components/section/Section.js.map +1 -1
  369. package/components/section/style/dnb-section.css +6 -4
  370. package/components/section/style/dnb-section.min.css +1 -1
  371. package/components/section/style/dnb-section.scss +7 -4
  372. package/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  373. package/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  374. package/components/textarea/Textarea.js +4 -9
  375. package/components/textarea/Textarea.js.map +1 -1
  376. package/components/toggle-button/ToggleButtonGroup.js +0 -1
  377. package/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  378. package/components/toggle-button/style/dnb-toggle-button.css +4 -6
  379. package/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  380. package/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  381. package/components/tooltip/style/dnb-tooltip.css +1 -0
  382. package/components/tooltip/style/dnb-tooltip.min.css +1 -1
  383. package/components/tooltip/style/dnb-tooltip.scss +2 -0
  384. package/components/upload/types.d.ts +1 -1
  385. package/components/upload/types.js.map +1 -1
  386. package/es/components/anchor/style/anchor-mixins.scss +8 -6
  387. package/es/components/anchor/style/dnb-anchor.css +28 -8
  388. package/es/components/anchor/style/dnb-anchor.min.css +1 -1
  389. package/es/components/card/Card.d.ts +1 -1
  390. package/es/components/card/Card.js +46 -9
  391. package/es/components/card/Card.js.map +1 -1
  392. package/es/components/card/style/dnb-card.css +0 -20
  393. package/es/components/card/style/dnb-card.min.css +1 -1
  394. package/es/components/card/style/dnb-card.scss +0 -20
  395. package/es/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  396. package/es/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  397. package/es/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  398. package/es/components/date-picker/DatePicker.d.ts +5 -1
  399. package/es/components/date-picker/DatePicker.js +4 -2
  400. package/es/components/date-picker/DatePicker.js.map +1 -1
  401. package/es/components/date-picker/DatePickerInput.js +20 -6
  402. package/es/components/date-picker/DatePickerInput.js.map +1 -1
  403. package/es/components/date-picker/DatePickerProvider.js +2 -2
  404. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  405. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  406. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  407. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  408. package/es/components/flex/Container.d.ts +2 -4
  409. package/es/components/flex/Container.js.map +1 -1
  410. package/es/components/flex/Item.d.ts +2 -3
  411. package/es/components/flex/Item.js +2 -1
  412. package/es/components/flex/Item.js.map +1 -1
  413. package/es/components/input/Input.d.ts +3 -2
  414. package/es/components/input-masked/InputMaskedHooks.js +6 -6
  415. package/es/components/input-masked/InputMaskedHooks.js.map +1 -1
  416. package/es/components/input-masked/InputMaskedUtils.d.ts +4 -2
  417. package/es/components/input-masked/InputMaskedUtils.js +9 -7
  418. package/es/components/input-masked/InputMaskedUtils.js.map +1 -1
  419. package/es/components/input-masked/MultiInputMask.d.ts +1 -1
  420. package/es/components/input-masked/MultiInputMask.js +4 -2
  421. package/es/components/input-masked/MultiInputMask.js.map +1 -1
  422. package/es/components/input-masked/TextMask.js +15 -4
  423. package/es/components/input-masked/TextMask.js.map +1 -1
  424. package/es/components/input-masked/style/dnb-input-masked.css +3 -0
  425. package/es/components/input-masked/style/dnb-input-masked.min.css +1 -1
  426. package/es/components/input-masked/style/dnb-input-masked.scss +5 -0
  427. package/es/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  428. package/es/components/input-masked/text-mask/InputModeNumber.js +84 -0
  429. package/es/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  430. package/es/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  431. package/es/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  432. package/es/components/radio/RadioGroup.js +0 -1
  433. package/es/components/radio/RadioGroup.js.map +1 -1
  434. package/es/components/section/Section.d.ts +7 -0
  435. package/es/components/section/Section.js +10 -12
  436. package/es/components/section/Section.js.map +1 -1
  437. package/es/components/section/style/dnb-section.css +6 -4
  438. package/es/components/section/style/dnb-section.min.css +1 -1
  439. package/es/components/section/style/dnb-section.scss +7 -4
  440. package/es/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  441. package/es/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  442. package/es/components/textarea/Textarea.js +4 -9
  443. package/es/components/textarea/Textarea.js.map +1 -1
  444. package/es/components/toggle-button/ToggleButtonGroup.js +0 -1
  445. package/es/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  446. package/es/components/toggle-button/style/dnb-toggle-button.css +4 -6
  447. package/es/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  448. package/es/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  449. package/es/components/tooltip/style/dnb-tooltip.css +1 -0
  450. package/es/components/tooltip/style/dnb-tooltip.min.css +1 -1
  451. package/es/components/tooltip/style/dnb-tooltip.scss +2 -0
  452. package/es/components/upload/types.d.ts +1 -1
  453. package/es/components/upload/types.js.map +1 -1
  454. package/es/extensions/forms/DataContext/Context.d.ts +1 -0
  455. package/es/extensions/forms/DataContext/Context.js +1 -0
  456. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  457. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  458. package/es/extensions/forms/DataContext/Provider/Provider.js +37 -13
  459. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  460. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  461. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  462. package/es/extensions/forms/Field/Date/Date.js +3 -1
  463. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  464. package/es/extensions/forms/Field/Email/Email.js +7 -5
  465. package/es/extensions/forms/Field/Email/Email.js.map +1 -1
  466. package/es/extensions/forms/Field/Expiry/Expiry.js +26 -4
  467. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  468. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  469. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  470. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  471. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  472. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +59 -21
  473. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  474. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  475. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  476. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  477. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  478. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  479. package/es/extensions/forms/Field/Selection/Selection.js +58 -50
  480. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  481. package/es/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  482. package/es/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  483. package/es/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  484. package/es/extensions/forms/Field/String/String.d.ts +1 -0
  485. package/es/extensions/forms/Field/String/String.js +13 -7
  486. package/es/extensions/forms/Field/String/String.js.map +1 -1
  487. package/es/extensions/forms/FieldBlock/FieldBlock.js +2 -2
  488. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  489. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +1 -1
  490. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  491. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +1 -1
  492. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  493. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  494. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  495. package/es/extensions/forms/Form/Handler/Handler.js +2 -2
  496. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  497. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  498. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  499. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  500. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  501. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  502. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  503. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  504. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  505. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  506. package/es/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  507. package/es/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  508. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  509. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  510. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  511. package/es/extensions/forms/hooks/useDataValue.d.ts +3 -0
  512. package/es/extensions/forms/hooks/useDataValue.js +94 -45
  513. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  514. package/es/extensions/forms/style/dnb-forms.css +42 -25
  515. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  516. package/es/extensions/forms/types.d.ts +12 -2
  517. package/es/extensions/forms/types.js +1 -1
  518. package/es/extensions/forms/types.js.map +1 -1
  519. package/es/icons/browser.d.ts +3 -0
  520. package/es/icons/browser.js +3 -0
  521. package/es/icons/browser.js.map +1 -0
  522. package/es/icons/browser_medium.d.ts +3 -0
  523. package/es/icons/browser_medium.js +3 -0
  524. package/es/icons/browser_medium.js.map +1 -0
  525. package/es/icons/digipass_corporate.d.ts +3 -0
  526. package/es/icons/digipass_corporate.js +3 -0
  527. package/es/icons/digipass_corporate.js.map +1 -0
  528. package/es/icons/digipass_corporate_medium.d.ts +3 -0
  529. package/es/icons/digipass_corporate_medium.js +3 -0
  530. package/es/icons/digipass_corporate_medium.js.map +1 -0
  531. package/es/icons/digipass_private.d.ts +3 -0
  532. package/es/icons/digipass_private.js +3 -0
  533. package/es/icons/digipass_private.js.map +1 -0
  534. package/es/icons/digipass_private_medium.d.ts +3 -0
  535. package/es/icons/digipass_private_medium.js +3 -0
  536. package/es/icons/digipass_private_medium.js.map +1 -0
  537. package/es/icons/dnb/browser.d.ts +3 -0
  538. package/es/icons/dnb/browser.js +17 -0
  539. package/es/icons/dnb/browser.js.map +1 -0
  540. package/es/icons/dnb/browser_medium.d.ts +3 -0
  541. package/es/icons/dnb/browser_medium.js +17 -0
  542. package/es/icons/dnb/browser_medium.js.map +1 -0
  543. package/es/icons/dnb/coins_1.js +1 -1
  544. package/es/icons/dnb/coins_1.js.map +1 -1
  545. package/es/icons/dnb/coins_1_medium.js +1 -1
  546. package/es/icons/dnb/coins_1_medium.js.map +1 -1
  547. package/es/icons/dnb/digipass_corporate.d.ts +3 -0
  548. package/es/icons/dnb/digipass_corporate.js +17 -0
  549. package/es/icons/dnb/digipass_corporate.js.map +1 -0
  550. package/es/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  551. package/es/icons/dnb/digipass_corporate_medium.js +17 -0
  552. package/es/icons/dnb/digipass_corporate_medium.js.map +1 -0
  553. package/es/icons/dnb/digipass_private.d.ts +3 -0
  554. package/es/icons/dnb/digipass_private.js +17 -0
  555. package/es/icons/dnb/digipass_private.js.map +1 -0
  556. package/es/icons/dnb/digipass_private_medium.d.ts +3 -0
  557. package/es/icons/dnb/digipass_private_medium.js +17 -0
  558. package/es/icons/dnb/digipass_private_medium.js.map +1 -0
  559. package/es/icons/dnb/envelope_open.d.ts +3 -0
  560. package/es/icons/dnb/envelope_open.js +18 -0
  561. package/es/icons/dnb/envelope_open.js.map +1 -0
  562. package/es/icons/dnb/envelope_open_medium.d.ts +3 -0
  563. package/es/icons/dnb/envelope_open_medium.js +18 -0
  564. package/es/icons/dnb/envelope_open_medium.js.map +1 -0
  565. package/es/icons/dnb/icons-meta.json +230 -20
  566. package/es/icons/dnb/icons-svg.lock +1272 -1064
  567. package/es/icons/dnb/index.d.ts +17 -1
  568. package/es/icons/dnb/index.js +17 -1
  569. package/es/icons/dnb/index.js.map +1 -1
  570. package/es/icons/dnb/laptop.d.ts +3 -0
  571. package/es/icons/dnb/laptop.js +18 -0
  572. package/es/icons/dnb/laptop.js.map +1 -0
  573. package/es/icons/dnb/laptop_medium.d.ts +3 -0
  574. package/es/icons/dnb/laptop_medium.js +18 -0
  575. package/es/icons/dnb/laptop_medium.js.map +1 -0
  576. package/es/icons/dnb/mobile.d.ts +3 -0
  577. package/es/icons/dnb/mobile.js +15 -0
  578. package/es/icons/dnb/mobile.js.map +1 -0
  579. package/es/icons/dnb/mobile_medium.d.ts +3 -0
  580. package/es/icons/dnb/mobile_medium.js +15 -0
  581. package/es/icons/dnb/mobile_medium.js.map +1 -0
  582. package/es/icons/dnb/money_left.d.ts +3 -0
  583. package/es/icons/dnb/money_left.js +17 -0
  584. package/es/icons/dnb/money_left.js.map +1 -0
  585. package/es/icons/dnb/money_left_medium.d.ts +3 -0
  586. package/es/icons/dnb/money_left_medium.js +18 -0
  587. package/es/icons/dnb/money_left_medium.js.map +1 -0
  588. package/es/icons/dnb/scan.js +5 -2
  589. package/es/icons/dnb/scan.js.map +1 -1
  590. package/es/icons/dnb/scan_medium.js +8 -12
  591. package/es/icons/dnb/scan_medium.js.map +1 -1
  592. package/es/icons/dnb/secondary_icons.d.ts +9 -1
  593. package/es/icons/dnb/secondary_icons.js +9 -1
  594. package/es/icons/dnb/secondary_icons.js.map +1 -1
  595. package/es/icons/dnb/secondary_icons_medium.d.ts +9 -1
  596. package/es/icons/dnb/secondary_icons_medium.js +9 -1
  597. package/es/icons/dnb/secondary_icons_medium.js.map +1 -1
  598. package/es/icons/dnb/teenager.d.ts +3 -0
  599. package/es/icons/dnb/teenager.js +18 -0
  600. package/es/icons/dnb/teenager.js.map +1 -0
  601. package/es/icons/dnb/teenager_medium.d.ts +3 -0
  602. package/es/icons/dnb/teenager_medium.js +18 -0
  603. package/es/icons/dnb/teenager_medium.js.map +1 -0
  604. package/es/icons/envelope_open.d.ts +3 -0
  605. package/es/icons/envelope_open.js +3 -0
  606. package/es/icons/envelope_open.js.map +1 -0
  607. package/es/icons/envelope_open_medium.d.ts +3 -0
  608. package/es/icons/envelope_open_medium.js +3 -0
  609. package/es/icons/envelope_open_medium.js.map +1 -0
  610. package/es/icons/index.d.ts +17 -1
  611. package/es/icons/index.js +17 -1
  612. package/es/icons/index.js.map +1 -1
  613. package/es/icons/laptop.d.ts +3 -0
  614. package/es/icons/laptop.js +3 -0
  615. package/es/icons/laptop.js.map +1 -0
  616. package/es/icons/laptop_medium.d.ts +3 -0
  617. package/es/icons/laptop_medium.js +3 -0
  618. package/es/icons/laptop_medium.js.map +1 -0
  619. package/es/icons/mobile.d.ts +3 -0
  620. package/es/icons/mobile.js +3 -0
  621. package/es/icons/mobile.js.map +1 -0
  622. package/es/icons/mobile_medium.d.ts +3 -0
  623. package/es/icons/mobile_medium.js +3 -0
  624. package/es/icons/mobile_medium.js.map +1 -0
  625. package/es/icons/money_left.d.ts +3 -0
  626. package/es/icons/money_left.js +3 -0
  627. package/es/icons/money_left.js.map +1 -0
  628. package/es/icons/money_left_medium.d.ts +3 -0
  629. package/es/icons/money_left_medium.js +3 -0
  630. package/es/icons/money_left_medium.js.map +1 -0
  631. package/es/icons/teenager.d.ts +3 -0
  632. package/es/icons/teenager.js +3 -0
  633. package/es/icons/teenager.js.map +1 -0
  634. package/es/icons/teenager_medium.d.ts +3 -0
  635. package/es/icons/teenager_medium.js +3 -0
  636. package/es/icons/teenager_medium.js.map +1 -0
  637. package/es/shared/Eufemia.d.ts +1 -1
  638. package/es/shared/Eufemia.js +2 -2
  639. package/es/shared/Eufemia.js.map +1 -1
  640. package/es/shared/component-helper.d.ts +1 -0
  641. package/es/shared/component-helper.js +3 -0
  642. package/es/shared/component-helper.js.map +1 -1
  643. package/es/style/dnb-ui-components.css +84 -63
  644. package/es/style/dnb-ui-components.min.css +3 -3
  645. package/es/style/dnb-ui-extensions.css +42 -25
  646. package/es/style/dnb-ui-extensions.min.css +1 -1
  647. package/es/style/dnb-ui-forms.css +42 -25
  648. package/es/style/dnb-ui-forms.min.css +1 -1
  649. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  650. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  651. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +166 -91
  652. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +5 -5
  653. package/es/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  654. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  655. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  656. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +42 -25
  657. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  658. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +42 -25
  659. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  660. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +155 -90
  661. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +4 -4
  662. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  663. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +42 -25
  664. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  665. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +42 -25
  666. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  667. package/es/style/themes/theme-ui/ui-theme-basis.css +14 -2
  668. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  669. package/es/style/themes/theme-ui/ui-theme-components.css +166 -91
  670. package/es/style/themes/theme-ui/ui-theme-components.min.css +5 -5
  671. package/es/style/themes/theme-ui/ui-theme-components.scss +1 -0
  672. package/es/style/themes/theme-ui/ui-theme-elements.css +14 -2
  673. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  674. package/es/style/themes/theme-ui/ui-theme-extensions.css +42 -25
  675. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  676. package/es/style/themes/theme-ui/ui-theme-forms.css +42 -25
  677. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  678. package/es/style/themes/theme-ui/ui-theme-tags.css +3 -3
  679. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  680. package/esm/dnb-ui-basis.min.mjs +1 -1
  681. package/esm/dnb-ui-components.min.mjs +1 -1
  682. package/esm/dnb-ui-elements.min.mjs +1 -1
  683. package/esm/dnb-ui-extensions.min.mjs +3 -3
  684. package/esm/dnb-ui-lib.min.mjs +1 -1
  685. package/extensions/forms/DataContext/Context.d.ts +1 -0
  686. package/extensions/forms/DataContext/Context.js +1 -0
  687. package/extensions/forms/DataContext/Context.js.map +1 -1
  688. package/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  689. package/extensions/forms/DataContext/Provider/Provider.js +37 -13
  690. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  691. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  692. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  693. package/extensions/forms/Field/Date/Date.js +3 -1
  694. package/extensions/forms/Field/Date/Date.js.map +1 -1
  695. package/extensions/forms/Field/Email/Email.js +7 -5
  696. package/extensions/forms/Field/Email/Email.js.map +1 -1
  697. package/extensions/forms/Field/Expiry/Expiry.js +26 -4
  698. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  699. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  700. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  701. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  702. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  703. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +70 -31
  704. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  705. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  706. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  707. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  708. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  709. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  710. package/extensions/forms/Field/Selection/Selection.js +58 -50
  711. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  712. package/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  713. package/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  714. package/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  715. package/extensions/forms/Field/String/String.d.ts +1 -0
  716. package/extensions/forms/Field/String/String.js +13 -8
  717. package/extensions/forms/Field/String/String.js.map +1 -1
  718. package/extensions/forms/FieldBlock/FieldBlock.js +2 -2
  719. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  720. package/extensions/forms/FieldBlock/style/dnb-field-block.css +1 -1
  721. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  722. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +1 -1
  723. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  724. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  725. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  726. package/extensions/forms/Form/Handler/Handler.js +2 -2
  727. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  728. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  729. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  730. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  731. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  732. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  733. package/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  734. package/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  735. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  736. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  737. package/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  738. package/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  739. package/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  740. package/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  741. package/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  742. package/extensions/forms/hooks/useDataValue.d.ts +3 -0
  743. package/extensions/forms/hooks/useDataValue.js +99 -49
  744. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  745. package/extensions/forms/style/dnb-forms.css +42 -25
  746. package/extensions/forms/style/dnb-forms.min.css +1 -1
  747. package/extensions/forms/types.d.ts +12 -2
  748. package/extensions/forms/types.js +1 -1
  749. package/extensions/forms/types.js.map +1 -1
  750. package/icons/browser.d.ts +3 -0
  751. package/icons/browser.js +3 -0
  752. package/icons/browser.js.map +1 -0
  753. package/icons/browser_medium.d.ts +3 -0
  754. package/icons/browser_medium.js +3 -0
  755. package/icons/browser_medium.js.map +1 -0
  756. package/icons/digipass_corporate.d.ts +3 -0
  757. package/icons/digipass_corporate.js +3 -0
  758. package/icons/digipass_corporate.js.map +1 -0
  759. package/icons/digipass_corporate_medium.d.ts +3 -0
  760. package/icons/digipass_corporate_medium.js +3 -0
  761. package/icons/digipass_corporate_medium.js.map +1 -0
  762. package/icons/digipass_private.d.ts +3 -0
  763. package/icons/digipass_private.js +3 -0
  764. package/icons/digipass_private.js.map +1 -0
  765. package/icons/digipass_private_medium.d.ts +3 -0
  766. package/icons/digipass_private_medium.js +3 -0
  767. package/icons/digipass_private_medium.js.map +1 -0
  768. package/icons/dnb/browser.d.ts +3 -0
  769. package/icons/dnb/browser.js +17 -0
  770. package/icons/dnb/browser.js.map +1 -0
  771. package/icons/dnb/browser_medium.d.ts +3 -0
  772. package/icons/dnb/browser_medium.js +17 -0
  773. package/icons/dnb/browser_medium.js.map +1 -0
  774. package/icons/dnb/coins_1.js +1 -1
  775. package/icons/dnb/coins_1.js.map +1 -1
  776. package/icons/dnb/coins_1_medium.js +1 -1
  777. package/icons/dnb/coins_1_medium.js.map +1 -1
  778. package/icons/dnb/digipass_corporate.d.ts +3 -0
  779. package/icons/dnb/digipass_corporate.js +17 -0
  780. package/icons/dnb/digipass_corporate.js.map +1 -0
  781. package/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  782. package/icons/dnb/digipass_corporate_medium.js +17 -0
  783. package/icons/dnb/digipass_corporate_medium.js.map +1 -0
  784. package/icons/dnb/digipass_private.d.ts +3 -0
  785. package/icons/dnb/digipass_private.js +17 -0
  786. package/icons/dnb/digipass_private.js.map +1 -0
  787. package/icons/dnb/digipass_private_medium.d.ts +3 -0
  788. package/icons/dnb/digipass_private_medium.js +17 -0
  789. package/icons/dnb/digipass_private_medium.js.map +1 -0
  790. package/icons/dnb/envelope_open.d.ts +3 -0
  791. package/icons/dnb/envelope_open.js +18 -0
  792. package/icons/dnb/envelope_open.js.map +1 -0
  793. package/icons/dnb/envelope_open_medium.d.ts +3 -0
  794. package/icons/dnb/envelope_open_medium.js +18 -0
  795. package/icons/dnb/envelope_open_medium.js.map +1 -0
  796. package/icons/dnb/icons-meta.json +230 -20
  797. package/icons/dnb/icons-svg.lock +1272 -1064
  798. package/icons/dnb/index.d.ts +17 -1
  799. package/icons/dnb/index.js +17 -1
  800. package/icons/dnb/index.js.map +1 -1
  801. package/icons/dnb/laptop.d.ts +3 -0
  802. package/icons/dnb/laptop.js +18 -0
  803. package/icons/dnb/laptop.js.map +1 -0
  804. package/icons/dnb/laptop_medium.d.ts +3 -0
  805. package/icons/dnb/laptop_medium.js +18 -0
  806. package/icons/dnb/laptop_medium.js.map +1 -0
  807. package/icons/dnb/mobile.d.ts +3 -0
  808. package/icons/dnb/mobile.js +15 -0
  809. package/icons/dnb/mobile.js.map +1 -0
  810. package/icons/dnb/mobile_medium.d.ts +3 -0
  811. package/icons/dnb/mobile_medium.js +15 -0
  812. package/icons/dnb/mobile_medium.js.map +1 -0
  813. package/icons/dnb/money_left.d.ts +3 -0
  814. package/icons/dnb/money_left.js +17 -0
  815. package/icons/dnb/money_left.js.map +1 -0
  816. package/icons/dnb/money_left_medium.d.ts +3 -0
  817. package/icons/dnb/money_left_medium.js +18 -0
  818. package/icons/dnb/money_left_medium.js.map +1 -0
  819. package/icons/dnb/scan.js +5 -2
  820. package/icons/dnb/scan.js.map +1 -1
  821. package/icons/dnb/scan_medium.js +8 -12
  822. package/icons/dnb/scan_medium.js.map +1 -1
  823. package/icons/dnb/secondary_icons.d.ts +9 -1
  824. package/icons/dnb/secondary_icons.js +9 -1
  825. package/icons/dnb/secondary_icons.js.map +1 -1
  826. package/icons/dnb/secondary_icons_medium.d.ts +9 -1
  827. package/icons/dnb/secondary_icons_medium.js +9 -1
  828. package/icons/dnb/secondary_icons_medium.js.map +1 -1
  829. package/icons/dnb/teenager.d.ts +3 -0
  830. package/icons/dnb/teenager.js +18 -0
  831. package/icons/dnb/teenager.js.map +1 -0
  832. package/icons/dnb/teenager_medium.d.ts +3 -0
  833. package/icons/dnb/teenager_medium.js +18 -0
  834. package/icons/dnb/teenager_medium.js.map +1 -0
  835. package/icons/envelope_open.d.ts +3 -0
  836. package/icons/envelope_open.js +3 -0
  837. package/icons/envelope_open.js.map +1 -0
  838. package/icons/envelope_open_medium.d.ts +3 -0
  839. package/icons/envelope_open_medium.js +3 -0
  840. package/icons/envelope_open_medium.js.map +1 -0
  841. package/icons/index.d.ts +17 -1
  842. package/icons/index.js +17 -1
  843. package/icons/index.js.map +1 -1
  844. package/icons/laptop.d.ts +3 -0
  845. package/icons/laptop.js +3 -0
  846. package/icons/laptop.js.map +1 -0
  847. package/icons/laptop_medium.d.ts +3 -0
  848. package/icons/laptop_medium.js +3 -0
  849. package/icons/laptop_medium.js.map +1 -0
  850. package/icons/mobile.d.ts +3 -0
  851. package/icons/mobile.js +3 -0
  852. package/icons/mobile.js.map +1 -0
  853. package/icons/mobile_medium.d.ts +3 -0
  854. package/icons/mobile_medium.js +3 -0
  855. package/icons/mobile_medium.js.map +1 -0
  856. package/icons/money_left.d.ts +3 -0
  857. package/icons/money_left.js +3 -0
  858. package/icons/money_left.js.map +1 -0
  859. package/icons/money_left_medium.d.ts +3 -0
  860. package/icons/money_left_medium.js +3 -0
  861. package/icons/money_left_medium.js.map +1 -0
  862. package/icons/teenager.d.ts +3 -0
  863. package/icons/teenager.js +3 -0
  864. package/icons/teenager.js.map +1 -0
  865. package/icons/teenager_medium.d.ts +3 -0
  866. package/icons/teenager_medium.js +3 -0
  867. package/icons/teenager_medium.js.map +1 -0
  868. package/package.json +1 -1
  869. package/shared/Eufemia.d.ts +1 -1
  870. package/shared/Eufemia.js +2 -2
  871. package/shared/Eufemia.js.map +1 -1
  872. package/shared/component-helper.d.ts +1 -0
  873. package/shared/component-helper.js +3 -0
  874. package/shared/component-helper.js.map +1 -1
  875. package/style/dnb-ui-components.css +84 -63
  876. package/style/dnb-ui-components.min.css +3 -3
  877. package/style/dnb-ui-extensions.css +42 -25
  878. package/style/dnb-ui-extensions.min.css +1 -1
  879. package/style/dnb-ui-forms.css +42 -25
  880. package/style/dnb-ui-forms.min.css +1 -1
  881. package/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  882. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  883. package/style/themes/theme-eiendom/eiendom-theme-components.css +166 -91
  884. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +5 -5
  885. package/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  886. package/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  887. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  888. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +42 -25
  889. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  890. package/style/themes/theme-eiendom/eiendom-theme-forms.css +42 -25
  891. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  892. package/style/themes/theme-sbanken/sbanken-theme-components.css +155 -90
  893. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +4 -4
  894. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  895. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +42 -25
  896. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  897. package/style/themes/theme-sbanken/sbanken-theme-forms.css +42 -25
  898. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  899. package/style/themes/theme-ui/ui-theme-basis.css +14 -2
  900. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  901. package/style/themes/theme-ui/ui-theme-components.css +166 -91
  902. package/style/themes/theme-ui/ui-theme-components.min.css +5 -5
  903. package/style/themes/theme-ui/ui-theme-components.scss +1 -0
  904. package/style/themes/theme-ui/ui-theme-elements.css +14 -2
  905. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  906. package/style/themes/theme-ui/ui-theme-extensions.css +42 -25
  907. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  908. package/style/themes/theme-ui/ui-theme-forms.css +42 -25
  909. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  910. package/style/themes/theme-ui/ui-theme-tags.css +3 -3
  911. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  912. package/umd/dnb-ui-basis.min.js +1 -1
  913. package/umd/dnb-ui-components.min.js +1 -1
  914. package/umd/dnb-ui-elements.min.js +1 -1
  915. package/umd/dnb-ui-extensions.min.js +3 -3
  916. package/umd/dnb-ui-lib.min.js +1 -1
  917. package/cjs/icons/icons-meta.json +0 -3748
  918. package/es/icons/icons-meta.json +0 -3748
  919. package/icons/icons-meta.json +0 -3748
@@ -1 +1 @@
1
- {"version":3,"file":"ToggleButtonGroup.js","names":["React","PropTypes","classnames","isTrue","makeUniqueId","extendPropsWithContextInClassComponent","validateDOMAttributes","getStatusState","combineDescribedBy","combineLabelledBy","dispatchCustomElementEvent","spacingPropTypes","createSpacingClasses","AlignmentHelper","FormLabel","FormStatus","Flex","Context","Suffix","ToggleButtonGroupContext","pickFormElementProps","ToggleButtonGroup","PureComponent","getDerivedStateFromProps","props","state","_listenForPropChanges","value","values","getValues","JSON","parse","constructor","_defineProperty","event","multiselect","includes","push","splice","indexOf","setState","_refInput","createRef","_id","id","_name","name","render","_this$context","_this$context2","defaultProps","context","getTranslation","ToggleButton","FormRow","formElement","status","status_state","status_props","status_no_animation","globalStatus","suffix","label_direction","label_sr_only","vertical","layout_direction","label","variant","left_component","disabled","skeleton","className","class","_className","_value","_values","children","on_change","rest","_objectWithoutProperties","_excluded","showStatus","classes","params","_objectSpread","setContext","_tmp","onChange","onChangeHandler","Fieldset","createElement","Provider","_AlignmentHelper","Container","align","direction","spacing","undefined","element","srOnly","_extends","role","show","text_id","text","no_animation","title","attributes","process","env","NODE_ENV","propTypes","oneOfType","string","func","node","oneOf","bool","object","shape","message","number","array","_formElement","_supportsSpacingProps"],"sources":["../../../../src/components/toggle-button/ToggleButtonGroup.js"],"sourcesContent":["/**\n * Web ToggleButtonGroup Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport {\n isTrue,\n makeUniqueId,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n getStatusState,\n combineDescribedBy,\n combineLabelledBy,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\nimport FormLabel from '../FormLabel'\nimport FormStatus from '../FormStatus'\nimport Flex from '../Flex'\nimport Context from '../../shared/Context'\nimport Suffix from '../../shared/helpers/Suffix'\nimport ToggleButtonGroupContext from './ToggleButtonGroupContext'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\n\nexport default class ToggleButtonGroup extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n label: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n label_direction: PropTypes.oneOf(['horizontal', 'vertical']),\n label_sr_only: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n title: PropTypes.string,\n multiselect: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n variant: PropTypes.oneOf(['default', 'checkbox', 'radio']),\n left_component: PropTypes.node,\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n id: PropTypes.string,\n name: PropTypes.string,\n status: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n PropTypes.func,\n PropTypes.node,\n ]),\n status_state: PropTypes.string,\n status_props: PropTypes.object,\n status_no_animation: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n globalStatus: PropTypes.shape({\n id: PropTypes.string,\n message: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n }),\n suffix: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n vertical: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n layout_direction: PropTypes.oneOf(['column', 'row']),\n value: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number,\n PropTypes.object,\n PropTypes.array,\n ]),\n values: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),\n attributes: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n\n ...spacingPropTypes,\n\n class: PropTypes.string,\n className: PropTypes.string,\n children: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n\n on_change: PropTypes.func,\n }\n\n static defaultProps = {\n label: null,\n label_direction: null,\n label_sr_only: null,\n title: null,\n multiselect: null,\n variant: null,\n left_component: null,\n disabled: null,\n skeleton: null,\n id: null,\n name: null,\n status: null,\n status_state: 'error',\n status_props: null,\n status_no_animation: null,\n globalStatus: null,\n suffix: null,\n vertical: null,\n layout_direction: 'row',\n value: undefined,\n values: undefined,\n attributes: null,\n class: null,\n\n className: null,\n children: null,\n\n on_change: null,\n }\n\n static getDerivedStateFromProps(props, state) {\n if (state._listenForPropChanges) {\n if (\n typeof props.value !== 'undefined' &&\n props.value !== state.value\n ) {\n state.value = props.value\n }\n if (\n typeof props.values !== 'undefined' &&\n props.values !== state.values\n ) {\n state.values = ToggleButtonGroup.getValues(props)\n }\n }\n state._listenForPropChanges = true\n\n return state\n }\n\n static getValues(props) {\n if (typeof props.values === 'string' && props.values[0] === '[') {\n return JSON.parse(props.values)\n }\n return props.values\n }\n\n constructor(props) {\n super(props)\n this._refInput = React.createRef()\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n this._name = props.name || makeUniqueId() // cause we need an id anyway\n this.state = {\n // do not set the value here, else get true in this check } else if (context.values && Array.isArray(context.values)) {\n _listenForPropChanges: true,\n }\n }\n\n onChangeHandler = ({ value, event }) => {\n const { multiselect } = this.props\n const values = this.state.values || []\n\n if (isTrue(multiselect)) {\n if (!values.includes(value)) {\n values.push(value)\n } else {\n values.splice(values.indexOf(value), 1)\n }\n }\n\n this.setState({\n value,\n values,\n _listenForPropChanges: false,\n })\n\n dispatchCustomElementEvent(this, 'on_change', {\n value,\n values,\n event,\n })\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n ToggleButtonGroup.defaultProps,\n this.context.getTranslation(this.props).ToggleButton,\n // Deprecated – can be removed in v11\n pickFormElementProps(this.context?.FormRow),\n pickFormElementProps(this.context?.formElement),\n this.context.ToggleButtonGroup\n )\n\n const {\n status,\n status_state,\n status_props,\n status_no_animation,\n globalStatus,\n suffix,\n label_direction,\n label_sr_only,\n vertical,\n layout_direction,\n label,\n variant,\n left_component,\n disabled,\n skeleton,\n className,\n class: _className,\n\n multiselect,\n id: _id, // eslint-disable-line\n name: _name, // eslint-disable-line\n value: _value, // eslint-disable-line\n values: _values, // eslint-disable-line\n children, // eslint-disable-line\n on_change, // eslint-disable-line\n\n ...rest\n } = props\n\n const { value, values } = this.state\n\n const id = this._id\n const showStatus = getStatusState(status)\n\n const classes = classnames(\n 'dnb-toggle-button-group',\n status && `dnb-toggle-button-group__status--${status_state}`,\n !label && 'dnb-toggle-button-group--no-label',\n `dnb-toggle-button-group--${layout_direction}`,\n 'dnb-form-component',\n createSpacingClasses(props),\n className,\n _className\n )\n\n const params = {\n ...rest,\n }\n\n if (showStatus || suffix) {\n params['aria-describedby'] = combineDescribedBy(\n params,\n showStatus ? id + '-status' : null,\n suffix ? id + '-suffix' : null\n )\n }\n if (label) {\n params['aria-labelledby'] = combineLabelledBy(params, id + '-label')\n }\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n const context = {\n name: this._name,\n value,\n values,\n multiselect: isTrue(multiselect),\n variant,\n left_component,\n disabled,\n skeleton,\n setContext: (context) => {\n // also look for a function, where we are able to fill old values\n // this is used in the \"constructor\" inside the ToggleButton.js component\n if (typeof context === 'function') {\n context = context(this._tmp)\n }\n this._tmp = { ...this._tmp, ...context }\n this.setState({\n ...context,\n _listenForPropChanges: false,\n })\n },\n onChange: this.onChangeHandler,\n }\n\n const Fieldset = label ? 'fieldset' : 'div'\n\n return (\n <ToggleButtonGroupContext.Provider value={context}>\n <div className={classes}>\n <AlignmentHelper />\n <Fieldset>\n <Flex.Container\n align=\"baseline\"\n direction={\n vertical || label_direction === 'vertical'\n ? 'vertical'\n : 'horizontal'\n }\n spacing={vertical ? 'x-small' : undefined}\n >\n {label && (\n <FormLabel\n element=\"legend\"\n id={id + '-label'}\n srOnly={label_sr_only}\n >\n {label}\n </FormLabel>\n )}\n\n <span\n id={id}\n className=\"dnb-toggle-button-group__shell\"\n role=\"group\"\n {...params}\n >\n <FormStatus\n show={showStatus}\n id={id + '-form-status'}\n globalStatus={globalStatus}\n label={label}\n text_id={id + '-status'} // used for \"aria-describedby\"\n text={status}\n state={status_state}\n no_animation={status_no_animation}\n skeleton={skeleton}\n {...status_props}\n />\n\n <span className=\"dnb-toggle-button-group__children\">\n {children}\n\n {suffix && (\n <Suffix\n className=\"dnb-toggle-button-group__suffix\"\n id={id + '-suffix'} // used for \"aria-describedby\"\n context={props}\n >\n {suffix}\n </Suffix>\n )}\n </span>\n </span>\n </Flex.Container>\n </Fieldset>\n </div>\n </ToggleButtonGroupContext.Provider>\n )\n }\n}\n\nToggleButtonGroup._formElement = true\nToggleButtonGroup._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"ToggleButtonGroup.js","names":["React","PropTypes","classnames","isTrue","makeUniqueId","extendPropsWithContextInClassComponent","validateDOMAttributes","getStatusState","combineDescribedBy","combineLabelledBy","dispatchCustomElementEvent","spacingPropTypes","createSpacingClasses","AlignmentHelper","FormLabel","FormStatus","Flex","Context","Suffix","ToggleButtonGroupContext","pickFormElementProps","ToggleButtonGroup","PureComponent","getDerivedStateFromProps","props","state","_listenForPropChanges","value","values","getValues","JSON","parse","constructor","_defineProperty","event","multiselect","includes","push","splice","indexOf","setState","_refInput","createRef","_id","id","_name","name","render","_this$context","_this$context2","defaultProps","context","getTranslation","ToggleButton","FormRow","formElement","status","status_state","status_props","status_no_animation","globalStatus","suffix","label_direction","label_sr_only","vertical","layout_direction","label","variant","left_component","disabled","skeleton","className","class","_className","_value","_values","children","on_change","rest","_objectWithoutProperties","_excluded","showStatus","classes","params","_objectSpread","setContext","_tmp","onChange","onChangeHandler","Fieldset","createElement","Provider","_AlignmentHelper","Container","align","direction","spacing","undefined","element","srOnly","_extends","role","show","text_id","text","no_animation","title","attributes","process","env","NODE_ENV","propTypes","oneOfType","string","func","node","oneOf","bool","object","shape","message","number","array","_supportsSpacingProps"],"sources":["../../../../src/components/toggle-button/ToggleButtonGroup.js"],"sourcesContent":["/**\n * Web ToggleButtonGroup Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport {\n isTrue,\n makeUniqueId,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n getStatusState,\n combineDescribedBy,\n combineLabelledBy,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\nimport FormLabel from '../FormLabel'\nimport FormStatus from '../FormStatus'\nimport Flex from '../Flex'\nimport Context from '../../shared/Context'\nimport Suffix from '../../shared/helpers/Suffix'\nimport ToggleButtonGroupContext from './ToggleButtonGroupContext'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\n\nexport default class ToggleButtonGroup extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n label: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n label_direction: PropTypes.oneOf(['horizontal', 'vertical']),\n label_sr_only: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n title: PropTypes.string,\n multiselect: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n variant: PropTypes.oneOf(['default', 'checkbox', 'radio']),\n left_component: PropTypes.node,\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n id: PropTypes.string,\n name: PropTypes.string,\n status: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n PropTypes.func,\n PropTypes.node,\n ]),\n status_state: PropTypes.string,\n status_props: PropTypes.object,\n status_no_animation: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n ]),\n globalStatus: PropTypes.shape({\n id: PropTypes.string,\n message: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n }),\n suffix: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n vertical: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n layout_direction: PropTypes.oneOf(['column', 'row']),\n value: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number,\n PropTypes.object,\n PropTypes.array,\n ]),\n values: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),\n attributes: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),\n\n ...spacingPropTypes,\n\n class: PropTypes.string,\n className: PropTypes.string,\n children: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.node,\n ]),\n\n on_change: PropTypes.func,\n }\n\n static defaultProps = {\n label: null,\n label_direction: null,\n label_sr_only: null,\n title: null,\n multiselect: null,\n variant: null,\n left_component: null,\n disabled: null,\n skeleton: null,\n id: null,\n name: null,\n status: null,\n status_state: 'error',\n status_props: null,\n status_no_animation: null,\n globalStatus: null,\n suffix: null,\n vertical: null,\n layout_direction: 'row',\n value: undefined,\n values: undefined,\n attributes: null,\n class: null,\n\n className: null,\n children: null,\n\n on_change: null,\n }\n\n static getDerivedStateFromProps(props, state) {\n if (state._listenForPropChanges) {\n if (\n typeof props.value !== 'undefined' &&\n props.value !== state.value\n ) {\n state.value = props.value\n }\n if (\n typeof props.values !== 'undefined' &&\n props.values !== state.values\n ) {\n state.values = ToggleButtonGroup.getValues(props)\n }\n }\n state._listenForPropChanges = true\n\n return state\n }\n\n static getValues(props) {\n if (typeof props.values === 'string' && props.values[0] === '[') {\n return JSON.parse(props.values)\n }\n return props.values\n }\n\n constructor(props) {\n super(props)\n this._refInput = React.createRef()\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n this._name = props.name || makeUniqueId() // cause we need an id anyway\n this.state = {\n // do not set the value here, else get true in this check } else if (context.values && Array.isArray(context.values)) {\n _listenForPropChanges: true,\n }\n }\n\n onChangeHandler = ({ value, event }) => {\n const { multiselect } = this.props\n const values = this.state.values || []\n\n if (isTrue(multiselect)) {\n if (!values.includes(value)) {\n values.push(value)\n } else {\n values.splice(values.indexOf(value), 1)\n }\n }\n\n this.setState({\n value,\n values,\n _listenForPropChanges: false,\n })\n\n dispatchCustomElementEvent(this, 'on_change', {\n value,\n values,\n event,\n })\n }\n\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n ToggleButtonGroup.defaultProps,\n this.context.getTranslation(this.props).ToggleButton,\n // Deprecated – can be removed in v11\n pickFormElementProps(this.context?.FormRow),\n pickFormElementProps(this.context?.formElement),\n this.context.ToggleButtonGroup\n )\n\n const {\n status,\n status_state,\n status_props,\n status_no_animation,\n globalStatus,\n suffix,\n label_direction,\n label_sr_only,\n vertical,\n layout_direction,\n label,\n variant,\n left_component,\n disabled,\n skeleton,\n className,\n class: _className,\n\n multiselect,\n id: _id, // eslint-disable-line\n name: _name, // eslint-disable-line\n value: _value, // eslint-disable-line\n values: _values, // eslint-disable-line\n children, // eslint-disable-line\n on_change, // eslint-disable-line\n\n ...rest\n } = props\n\n const { value, values } = this.state\n\n const id = this._id\n const showStatus = getStatusState(status)\n\n const classes = classnames(\n 'dnb-toggle-button-group',\n status && `dnb-toggle-button-group__status--${status_state}`,\n !label && 'dnb-toggle-button-group--no-label',\n `dnb-toggle-button-group--${layout_direction}`,\n 'dnb-form-component',\n createSpacingClasses(props),\n className,\n _className\n )\n\n const params = {\n ...rest,\n }\n\n if (showStatus || suffix) {\n params['aria-describedby'] = combineDescribedBy(\n params,\n showStatus ? id + '-status' : null,\n suffix ? id + '-suffix' : null\n )\n }\n if (label) {\n params['aria-labelledby'] = combineLabelledBy(params, id + '-label')\n }\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, params)\n\n const context = {\n name: this._name,\n value,\n values,\n multiselect: isTrue(multiselect),\n variant,\n left_component,\n disabled,\n skeleton,\n setContext: (context) => {\n // also look for a function, where we are able to fill old values\n // this is used in the \"constructor\" inside the ToggleButton.js component\n if (typeof context === 'function') {\n context = context(this._tmp)\n }\n this._tmp = { ...this._tmp, ...context }\n this.setState({\n ...context,\n _listenForPropChanges: false,\n })\n },\n onChange: this.onChangeHandler,\n }\n\n const Fieldset = label ? 'fieldset' : 'div'\n\n return (\n <ToggleButtonGroupContext.Provider value={context}>\n <div className={classes}>\n <AlignmentHelper />\n <Fieldset>\n <Flex.Container\n align=\"baseline\"\n direction={\n vertical || label_direction === 'vertical'\n ? 'vertical'\n : 'horizontal'\n }\n spacing={vertical ? 'x-small' : undefined}\n >\n {label && (\n <FormLabel\n element=\"legend\"\n id={id + '-label'}\n srOnly={label_sr_only}\n >\n {label}\n </FormLabel>\n )}\n\n <span\n id={id}\n className=\"dnb-toggle-button-group__shell\"\n role=\"group\"\n {...params}\n >\n <FormStatus\n show={showStatus}\n id={id + '-form-status'}\n globalStatus={globalStatus}\n label={label}\n text_id={id + '-status'} // used for \"aria-describedby\"\n text={status}\n state={status_state}\n no_animation={status_no_animation}\n skeleton={skeleton}\n {...status_props}\n />\n\n <span className=\"dnb-toggle-button-group__children\">\n {children}\n\n {suffix && (\n <Suffix\n className=\"dnb-toggle-button-group__suffix\"\n id={id + '-suffix'} // used for \"aria-describedby\"\n context={props}\n >\n {suffix}\n </Suffix>\n )}\n </span>\n </span>\n </Flex.Container>\n </Fieldset>\n </div>\n </ToggleButtonGroupContext.Provider>\n )\n }\n}\n\nToggleButtonGroup._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -114,13 +114,11 @@
114
114
  transform: translateY(-0.5rem);
115
115
  }
116
116
  .dnb-toggle-button-group .dnb-flex-container {
117
- margin-bottom: calc(0px - var(--toggle-button-group-margin-bottom));
117
+ margin-bottom: calc(var(--toggle-button-group-margin-bottom) * -1);
118
118
  }
119
- .dnb-toggle-button-group .dnb-flex-container--vertical-label {
120
- align-items: flex-start;
121
- }
122
- .dnb-toggle-button-group .dnb-flex-container::before {
123
- font-size: var(--font-size-basis);
119
+ .dnb-toggle-button-group .dnb-flex-container--direction-horizontal .dnb-form-label {
120
+ margin-top: 0.5rem;
121
+ align-self: flex-start;
124
122
  }
125
123
  .dnb-toggle-button-group .dnb-alignment-helper {
126
124
  line-height: 2.5rem;
@@ -1 +1 @@
1
- .dnb-toggle-button{align-items:center;display:inline-flex;font-size:var(--font-size-small);line-height:var(--line-height-basis)}.dnb-toggle-button__inner{display:inline-flex;flex-direction:column}.dnb-toggle-button__shell{left:0;position:relative;-webkit-user-select:none;user-select:none}.dnb-toggle-button--vertical{align-items:flex-start;flex-direction:column}.dnb-toggle-button__component{align-items:center;display:inline-flex;padding-right:.5rem}.dnb-toggle-button__button.dnb-button--has-text{padding-left:1.5rem;padding-right:1.5rem}.dnb-toggle-button__button .dnb-checkbox{margin-left:-.5rem}.dnb-toggle-button__button .dnb-checkbox__input{pointer-events:none}.dnb-toggle-button__button .dnb-checkbox__button{display:unset}.dnb-toggle-button__button .dnb-checkbox__button,.dnb-toggle-button__button .dnb-checkbox__focus{border-width:.0625rem;height:calc(var(--checkbox-height--medium) - .5rem);width:calc(var(--checkbox-width--medium) - .5rem)}.dnb-toggle-button__button .dnb-checkbox__dot{height:calc(var(--checkbox-height--medium) - 1rem);width:calc(var(--checkbox-width--medium) - 1rem)}.dnb-toggle-button__button .dnb-checkbox__gfx{height:calc(var(--checkbox-height--medium) - .75rem);width:calc(var(--checkbox-width--medium) - .75rem)}.dnb-toggle-button__button .dnb-radio{margin-left:-.5rem}.dnb-toggle-button__button .dnb-radio__input{pointer-events:none}.dnb-toggle-button__button .dnb-radio__button,.dnb-toggle-button__button .dnb-radio__focus{border-width:.0625rem;height:calc(var(--radio-height--medium) - .5rem);width:calc(var(--radio-width--medium) - .5rem)}.dnb-toggle-button__button .dnb-radio__dot{height:calc(var(--radio-height--medium) - 1rem);width:calc(var(--radio-width--medium) - 1rem)}:not(.dnb-toggle-button-group)>.dnb-form-label+.dnb-toggle-button{vertical-align:top}.dnb-toggle-button .dnb-form-status{margin-top:.5rem;order:2}.dnb-toggle-button .dnb-form-label{margin-right:1rem}.dnb-toggle-button-group{--toggle-button-group-margin-right:1rem;--toggle-button-group-margin-bottom:1rem;display:inline-flex}.dnb-toggle-button-group fieldset{border:none;margin:0;padding:0}.dnb-toggle-button-group .dnb-toggle-button{margin-bottom:var(--toggle-button-group-margin-bottom);margin-right:var(--toggle-button-group-margin-right)}.dnb-toggle-button-group--column .dnb-toggle-button{display:flex;margin-right:0}.dnb-toggle-button-group .dnb-toggle-button:last-of-type{margin-right:0}.dnb-toggle-button-group__shell{display:flex;flex-direction:column}.dnb-toggle-button-group__shell__children{order:1}.dnb-toggle-button-group__shell>.dnb-form-status{order:2;transform:translateY(-.5rem)}.dnb-toggle-button-group .dnb-flex-container{margin-bottom:calc(0px - var(--toggle-button-group-margin-bottom))}.dnb-toggle-button-group .dnb-flex-container--vertical-label{align-items:flex-start}.dnb-toggle-button-group .dnb-flex-container:before{font-size:var(--font-size-basis)}.dnb-toggle-button-group .dnb-alignment-helper{line-height:2.5rem}.dnb-toggle-button-group__suffix{font-size:var(--font-size-basis)}@media screen and (min-width:40em){.dnb-form-label+.dnb-toggle-button{transform:translateY(-.5rem)}}
1
+ .dnb-toggle-button{align-items:center;display:inline-flex;font-size:var(--font-size-small);line-height:var(--line-height-basis)}.dnb-toggle-button__inner{display:inline-flex;flex-direction:column}.dnb-toggle-button__shell{left:0;position:relative;-webkit-user-select:none;user-select:none}.dnb-toggle-button--vertical{align-items:flex-start;flex-direction:column}.dnb-toggle-button__component{align-items:center;display:inline-flex;padding-right:.5rem}.dnb-toggle-button__button.dnb-button--has-text{padding-left:1.5rem;padding-right:1.5rem}.dnb-toggle-button__button .dnb-checkbox{margin-left:-.5rem}.dnb-toggle-button__button .dnb-checkbox__input{pointer-events:none}.dnb-toggle-button__button .dnb-checkbox__button{display:unset}.dnb-toggle-button__button .dnb-checkbox__button,.dnb-toggle-button__button .dnb-checkbox__focus{border-width:.0625rem;height:calc(var(--checkbox-height--medium) - .5rem);width:calc(var(--checkbox-width--medium) - .5rem)}.dnb-toggle-button__button .dnb-checkbox__dot{height:calc(var(--checkbox-height--medium) - 1rem);width:calc(var(--checkbox-width--medium) - 1rem)}.dnb-toggle-button__button .dnb-checkbox__gfx{height:calc(var(--checkbox-height--medium) - .75rem);width:calc(var(--checkbox-width--medium) - .75rem)}.dnb-toggle-button__button .dnb-radio{margin-left:-.5rem}.dnb-toggle-button__button .dnb-radio__input{pointer-events:none}.dnb-toggle-button__button .dnb-radio__button,.dnb-toggle-button__button .dnb-radio__focus{border-width:.0625rem;height:calc(var(--radio-height--medium) - .5rem);width:calc(var(--radio-width--medium) - .5rem)}.dnb-toggle-button__button .dnb-radio__dot{height:calc(var(--radio-height--medium) - 1rem);width:calc(var(--radio-width--medium) - 1rem)}:not(.dnb-toggle-button-group)>.dnb-form-label+.dnb-toggle-button{vertical-align:top}.dnb-toggle-button .dnb-form-status{margin-top:.5rem;order:2}.dnb-toggle-button .dnb-form-label{margin-right:1rem}.dnb-toggle-button-group{--toggle-button-group-margin-right:1rem;--toggle-button-group-margin-bottom:1rem;display:inline-flex}.dnb-toggle-button-group fieldset{border:none;margin:0;padding:0}.dnb-toggle-button-group .dnb-toggle-button{margin-bottom:var(--toggle-button-group-margin-bottom);margin-right:var(--toggle-button-group-margin-right)}.dnb-toggle-button-group--column .dnb-toggle-button{display:flex;margin-right:0}.dnb-toggle-button-group .dnb-toggle-button:last-of-type{margin-right:0}.dnb-toggle-button-group__shell{display:flex;flex-direction:column}.dnb-toggle-button-group__shell__children{order:1}.dnb-toggle-button-group__shell>.dnb-form-status{order:2;transform:translateY(-.5rem)}.dnb-toggle-button-group .dnb-flex-container{margin-bottom:calc(var(--toggle-button-group-margin-bottom)*-1)}.dnb-toggle-button-group .dnb-flex-container--direction-horizontal .dnb-form-label{align-self:flex-start;margin-top:.5rem}.dnb-toggle-button-group .dnb-alignment-helper{line-height:2.5rem}.dnb-toggle-button-group__suffix{font-size:var(--font-size-basis)}@media screen and (min-width:40em){.dnb-form-label+.dnb-toggle-button{transform:translateY(-.5rem)}}
@@ -155,17 +155,11 @@
155
155
  }
156
156
 
157
157
  .dnb-flex-container {
158
- &--vertical-label {
159
- align-items: flex-start;
160
- }
161
-
162
- margin-bottom: calc(
163
- 1px - 1px - var(--toggle-button-group-margin-bottom)
164
- );
158
+ margin-bottom: calc(var(--toggle-button-group-margin-bottom) * -1);
165
159
 
166
- &::before {
167
- // move the group 2px up if label exists
168
- font-size: var(--font-size-basis);
160
+ &--direction-horizontal .dnb-form-label {
161
+ margin-top: 0.5rem;
162
+ align-self: flex-start;
169
163
  }
170
164
  }
171
165
 
@@ -18,6 +18,7 @@
18
18
  align-items: center;
19
19
  padding: 0 1rem;
20
20
  color: var(--tooltip-color);
21
+ text-align: center;
21
22
  background-color: var(--tooltip-background-color);
22
23
  border-radius: var(--tooltip-border-radius);
23
24
  box-shadow: var(--shadow-default);
@@ -1 +1 @@
1
- .dnb-tooltip{--tooltip-color:#fff;--tooltip-background-color:#000;--tooltip-border-color:1px solid #000;--tooltip-border-radius:1rem;align-items:center;background-color:var(--tooltip-background-color);border-radius:var(--tooltip-border-radius);box-shadow:var(--shadow-default);color:var(--tooltip-color);display:flex;flex-direction:column;justify-content:center;opacity:0;padding:0 1rem;position:absolute;transition:opacity .2s var(--easing-default);visibility:hidden;z-index:3100}.dnb-tooltip--large{padding:.25rem 1rem}.dnb-tooltip--active{animation:show-tooltip .2s var(--easing-default) forwards;visibility:visible}.dnb-tooltip--active.dnb-tooltip--no-animation,html[data-visual-test] .dnb-tooltip--active{animation:show-tooltip 1ms var(--easing-default) forwards}.dnb-tooltip--hide{animation:hide-tooltip .2s var(--easing-default) forwards;visibility:visible}.dnb-tooltip--hide.dnb-tooltip--no-animation{animation:hide-tooltip 1ms linear forwards}.dnb-tooltip--fixed{position:fixed}html[data-visual-test] .dnb-tooltip--hide{animation:hide-tooltip 1ms linear 1s forwards}.dnb-tooltip__portal{left:0;position:absolute;right:0;top:0}.dnb-tooltip__content{min-height:1.5rem;min-width:2rem;padding:0}.dnb-tooltip__arrow{height:.5rem;margin:0;overflow:hidden;pointer-events:none;position:absolute;width:1rem}.dnb-tooltip__arrow:before{background-color:var(--tooltip-background-color);border:var(--tooltip-border-color);bottom:0;content:"";height:1rem;left:0;position:absolute;transform:translateY(70%) rotate(45deg);width:1rem}.dnb-tooltip__arrow__position--bottom{top:-.5rem}.dnb-tooltip__arrow__position--top{bottom:-.5rem;transform:rotate(180deg)}.dnb-tooltip__arrow__position--left{margin-right:3px;right:-.75rem;transform:rotate(90deg)}.dnb-tooltip__arrow__position--right{left:-.75rem;margin-left:3px;transform:rotate(270deg)}.dnb-tooltip__arrow__arrow--left{align-self:flex-start}.dnb-tooltip__arrow__arrow--right{align-self:flex-end}@keyframes show-tooltip{0%{opacity:0}to{opacity:1}}@keyframes hide-tooltip{0%{opacity:1}to{opacity:0;visibility:hidden}}
1
+ .dnb-tooltip{--tooltip-color:#fff;--tooltip-background-color:#000;--tooltip-border-color:1px solid #000;--tooltip-border-radius:1rem;align-items:center;background-color:var(--tooltip-background-color);border-radius:var(--tooltip-border-radius);box-shadow:var(--shadow-default);color:var(--tooltip-color);display:flex;flex-direction:column;justify-content:center;opacity:0;padding:0 1rem;position:absolute;text-align:center;transition:opacity .2s var(--easing-default);visibility:hidden;z-index:3100}.dnb-tooltip--large{padding:.25rem 1rem}.dnb-tooltip--active{animation:show-tooltip .2s var(--easing-default) forwards;visibility:visible}.dnb-tooltip--active.dnb-tooltip--no-animation,html[data-visual-test] .dnb-tooltip--active{animation:show-tooltip 1ms var(--easing-default) forwards}.dnb-tooltip--hide{animation:hide-tooltip .2s var(--easing-default) forwards;visibility:visible}.dnb-tooltip--hide.dnb-tooltip--no-animation{animation:hide-tooltip 1ms linear forwards}.dnb-tooltip--fixed{position:fixed}html[data-visual-test] .dnb-tooltip--hide{animation:hide-tooltip 1ms linear 1s forwards}.dnb-tooltip__portal{left:0;position:absolute;right:0;top:0}.dnb-tooltip__content{min-height:1.5rem;min-width:2rem;padding:0}.dnb-tooltip__arrow{height:.5rem;margin:0;overflow:hidden;pointer-events:none;position:absolute;width:1rem}.dnb-tooltip__arrow:before{background-color:var(--tooltip-background-color);border:var(--tooltip-border-color);bottom:0;content:"";height:1rem;left:0;position:absolute;transform:translateY(70%) rotate(45deg);width:1rem}.dnb-tooltip__arrow__position--bottom{top:-.5rem}.dnb-tooltip__arrow__position--top{bottom:-.5rem;transform:rotate(180deg)}.dnb-tooltip__arrow__position--left{margin-right:3px;right:-.75rem;transform:rotate(90deg)}.dnb-tooltip__arrow__position--right{left:-.75rem;margin-left:3px;transform:rotate(270deg)}.dnb-tooltip__arrow__arrow--left{align-self:flex-start}.dnb-tooltip__arrow__arrow--right{align-self:flex-end}@keyframes show-tooltip{0%{opacity:0}to{opacity:1}}@keyframes hide-tooltip{0%{opacity:1}to{opacity:0;visibility:hidden}}
@@ -22,6 +22,8 @@
22
22
  padding: 0 1rem;
23
23
  color: var(--tooltip-color);
24
24
 
25
+ text-align: center;
26
+
25
27
  background-color: var(--tooltip-background-color);
26
28
  border-radius: var(--tooltip-border-radius);
27
29
  @include defaultDropShadow();
@@ -55,7 +55,7 @@ export type UploadProps = {
55
55
  deleteButton?: React.ReactNode;
56
56
  fileListAriaLabel?: string;
57
57
  };
58
- export type UploadAllProps = UploadProps & SpacingProps & LocaleProps & React.HTMLProps<HTMLElement>;
58
+ export type UploadAllProps = UploadProps & SpacingProps & LocaleProps & Omit<React.HTMLProps<HTMLElement>, 'onChange'>;
59
59
  export type UploadContextProps = {
60
60
  id?: string;
61
61
  onInputUpload: (files: UploadFile[]) => void;
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../src/components/upload/types.ts"],"sourcesContent":["import React from 'react'\nimport type { SkeletonShow } from '../skeleton/Skeleton'\nimport type { LocaleProps, SpacingProps } from '../../shared/types'\n\nexport type UploadAcceptedFileTypes = string[]\n\nexport type UploadProps = {\n /**\n * unique id used with the useUpload hook to manage the files\n */\n id: string\n\n /**\n * list of accepted file types.\n */\n acceptedFileTypes: UploadAcceptedFileTypes\n\n /**\n * Skeleton should be applied when loading content\n * Default: null\n */\n skeleton?: SkeletonShow\n\n /**\n * Defines the amount of files the user can select and upload\n * Default: 100\n */\n filesAmountLimit?: number\n\n /**\n * fileMaxSize is max size of each file in MB\n * Default: 5 MB\n */\n fileMaxSize?: number\n\n /**\n * will be called on `files` changes made by the user. Access the files with `{ files }`.\n */\n onChange?: ({ files }: { files: UploadFile[] }) => void\n\n /**\n * will be called once a file gets deleted by the user. Access the deleted file with `{ fileItem }`.\n */\n onFileDelete?: ({ fileItem }: { fileItem: UploadFile }) => void\n\n /**\n * Custom text properties\n */\n title?: React.ReactNode\n text?: React.ReactNode\n fileTypeDescription?: React.ReactNode\n fileSizeDescription?: React.ReactNode\n fileAmountDescription?: React.ReactNode\n fileSizeContent?: React.ReactNode\n buttonText?: React.ReactNode\n errorLargeFile?: React.ReactNode\n errorUnsupportedFile?: React.ReactNode\n errorAmountLimit?: React.ReactNode\n loadingText?: React.ReactNode\n deleteButton?: React.ReactNode\n fileListAriaLabel?: string\n}\n\nexport type UploadAllProps = UploadProps &\n SpacingProps &\n LocaleProps &\n React.HTMLProps<HTMLElement>\n\nexport type UploadContextProps = {\n id?: string\n onInputUpload: (files: UploadFile[]) => void\n} & Partial<UploadProps>\n\nexport type UploadFile = {\n file: File\n errorMessage?: React.ReactNode\n isLoading?: boolean\n exists?: boolean\n id?: string\n}\n"],"mappings":""}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../../src/components/upload/types.ts"],"sourcesContent":["import React from 'react'\nimport type { SkeletonShow } from '../skeleton/Skeleton'\nimport type { LocaleProps, SpacingProps } from '../../shared/types'\n\nexport type UploadAcceptedFileTypes = string[]\n\nexport type UploadProps = {\n /**\n * unique id used with the useUpload hook to manage the files\n */\n id: string\n\n /**\n * list of accepted file types.\n */\n acceptedFileTypes: UploadAcceptedFileTypes\n\n /**\n * Skeleton should be applied when loading content\n * Default: null\n */\n skeleton?: SkeletonShow\n\n /**\n * Defines the amount of files the user can select and upload\n * Default: 100\n */\n filesAmountLimit?: number\n\n /**\n * fileMaxSize is max size of each file in MB\n * Default: 5 MB\n */\n fileMaxSize?: number\n\n /**\n * will be called on `files` changes made by the user. Access the files with `{ files }`.\n */\n onChange?: ({ files }: { files: UploadFile[] }) => void\n\n /**\n * will be called once a file gets deleted by the user. Access the deleted file with `{ fileItem }`.\n */\n onFileDelete?: ({ fileItem }: { fileItem: UploadFile }) => void\n\n /**\n * Custom text properties\n */\n title?: React.ReactNode\n text?: React.ReactNode\n fileTypeDescription?: React.ReactNode\n fileSizeDescription?: React.ReactNode\n fileAmountDescription?: React.ReactNode\n fileSizeContent?: React.ReactNode\n buttonText?: React.ReactNode\n errorLargeFile?: React.ReactNode\n errorUnsupportedFile?: React.ReactNode\n errorAmountLimit?: React.ReactNode\n loadingText?: React.ReactNode\n deleteButton?: React.ReactNode\n fileListAriaLabel?: string\n}\n\nexport type UploadAllProps = UploadProps &\n SpacingProps &\n LocaleProps &\n Omit<React.HTMLProps<HTMLElement>, 'onChange'>\n\nexport type UploadContextProps = {\n id?: string\n onInputUpload: (files: UploadFile[]) => void\n} & Partial<UploadProps>\n\nexport type UploadFile = {\n file: File\n errorMessage?: React.ReactNode\n isLoading?: boolean\n exists?: boolean\n id?: string\n}\n"],"mappings":""}
@@ -10,6 +10,7 @@ export interface ContextState {
10
10
  /** Will set autoComplete="on" on each nested Field.String and Field.Number */
11
11
  autoComplete?: boolean;
12
12
  handlePathChange: (path: string, value: any) => void;
13
+ updateDataValue: (path: string, value: any) => void;
13
14
  handleSubmit: (props?: HandleSubmitProps) => any;
14
15
  showAllErrors: boolean;
15
16
  setShowAllErrors: (showAllErrors: boolean) => void;
@@ -2,6 +2,7 @@ import React from 'react';
2
2
  export const defaultContextState = {
3
3
  data: undefined,
4
4
  handlePathChange: () => null,
5
+ updateDataValue: () => null,
5
6
  handleSubmit: () => null,
6
7
  showAllErrors: false,
7
8
  setShowAllErrors: () => null,
@@ -1 +1 @@
1
- {"version":3,"file":"Context.js","names":["React","defaultContextState","data","undefined","handlePathChange","handleSubmit","showAllErrors","setShowAllErrors","mountedFieldPaths","handleMountField","handleUnMountField","hasErrors","setValueWithError","_isInsideFormElement","Context","createContext"],"sources":["../../../../../src/extensions/forms/DataContext/Context.ts"],"sourcesContent":["import React from 'react'\n\ntype HandleSubmitProps = {\n formElement?: HTMLFormElement\n}\n\nexport interface ContextState {\n /** The dataset for the form / form steps */\n data: any\n /** Should the form validate data before submitting? */\n errors?: Record<string, Error>\n /** Will set autoComplete=\"on\" on each nested Field.String and Field.Number */\n autoComplete?: boolean\n handlePathChange: (path: string, value: any) => void\n handleSubmit: (props?: HandleSubmitProps) => any\n // Error status\n showAllErrors: boolean\n setShowAllErrors: (showAllErrors: boolean) => void\n // Mounted fields - Components telling the provider what fields is on screen at any time\n mountedFieldPaths: string[]\n handleMountField: (path: string) => void\n handleUnMountField: (path: string) => void\n setValueWithError: (identifier: string, hasError: boolean) => void\n hasErrors: () => boolean\n _isInsideFormElement?: boolean\n}\n\nexport const defaultContextState: ContextState = {\n data: undefined,\n handlePathChange: () => null,\n handleSubmit: () => null,\n showAllErrors: false,\n setShowAllErrors: () => null,\n mountedFieldPaths: [],\n handleMountField: () => null,\n handleUnMountField: () => null,\n hasErrors: () => false,\n setValueWithError: () => null,\n _isInsideFormElement: false,\n}\n\nconst Context = React.createContext<ContextState>(defaultContextState)\n\nexport default Context\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AA2BzB,OAAO,MAAMC,mBAAiC,GAAG;EAC/CC,IAAI,EAAEC,SAAS;EACfC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,aAAa,EAAE,KAAK;EACpBC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,iBAAiB,EAAE,EAAE;EACrBC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,kBAAkB,EAAEA,CAAA,KAAM,IAAI;EAC9BC,SAAS,EAAEA,CAAA,KAAM,KAAK;EACtBC,iBAAiB,EAAEA,CAAA,KAAM,IAAI;EAC7BC,oBAAoB,EAAE;AACxB,CAAC;AAED,MAAMC,OAAO,GAAGd,KAAK,CAACe,aAAa,CAAed,mBAAmB,CAAC;AAEtE,eAAea,OAAO"}
1
+ {"version":3,"file":"Context.js","names":["React","defaultContextState","data","undefined","handlePathChange","updateDataValue","handleSubmit","showAllErrors","setShowAllErrors","mountedFieldPaths","handleMountField","handleUnMountField","hasErrors","setValueWithError","_isInsideFormElement","Context","createContext"],"sources":["../../../../../src/extensions/forms/DataContext/Context.ts"],"sourcesContent":["import React from 'react'\n\ntype HandleSubmitProps = {\n formElement?: HTMLFormElement\n}\n\nexport interface ContextState {\n /** The dataset for the form / form steps */\n data: any\n /** Should the form validate data before submitting? */\n errors?: Record<string, Error>\n /** Will set autoComplete=\"on\" on each nested Field.String and Field.Number */\n autoComplete?: boolean\n handlePathChange: (path: string, value: any) => void\n updateDataValue: (path: string, value: any) => void\n handleSubmit: (props?: HandleSubmitProps) => any\n // Error status\n showAllErrors: boolean\n setShowAllErrors: (showAllErrors: boolean) => void\n // Mounted fields - Components telling the provider what fields is on screen at any time\n mountedFieldPaths: string[]\n handleMountField: (path: string) => void\n handleUnMountField: (path: string) => void\n setValueWithError: (identifier: string, hasError: boolean) => void\n hasErrors: () => boolean\n _isInsideFormElement?: boolean\n}\n\nexport const defaultContextState: ContextState = {\n data: undefined,\n handlePathChange: () => null,\n updateDataValue: () => null,\n handleSubmit: () => null,\n showAllErrors: false,\n setShowAllErrors: () => null,\n mountedFieldPaths: [],\n handleMountField: () => null,\n handleUnMountField: () => null,\n hasErrors: () => false,\n setValueWithError: () => null,\n _isInsideFormElement: false,\n}\n\nconst Context = React.createContext<ContextState>(defaultContextState)\n\nexport default Context\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AA4BzB,OAAO,MAAMC,mBAAiC,GAAG;EAC/CC,IAAI,EAAEC,SAAS;EACfC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,eAAe,EAAEA,CAAA,KAAM,IAAI;EAC3BC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,aAAa,EAAE,KAAK;EACpBC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,iBAAiB,EAAE,EAAE;EACrBC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,kBAAkB,EAAEA,CAAA,KAAM,IAAI;EAC9BC,SAAS,EAAEA,CAAA,KAAM,KAAK;EACtBC,iBAAiB,EAAEA,CAAA,KAAM,IAAI;EAC7BC,oBAAoB,EAAE;AACxB,CAAC;AAED,MAAMC,OAAO,GAAGf,KAAK,CAACgB,aAAa,CAAef,mBAAmB,CAAC;AAEtE,eAAec,OAAO"}
@@ -13,7 +13,12 @@ export interface Props<Data extends JsonObject> {
13
13
  /** Change handler for each value */
14
14
  onPathChange?: (path: string, value: any) => void;
15
15
  /** Submit called, data was valid (if validation available) */
16
- onSubmit?: (data: Data) => void;
16
+ onSubmit?: (data: Data, { resetForm, clearData, }: {
17
+ /** Will remove browser-side stored autocomplete data */
18
+ resetForm: () => void;
19
+ /** Will empty the whole internal data set of the form */
20
+ clearData: () => void;
21
+ }) => void;
17
22
  /** Submit was requested, but data was invalid */
18
23
  onSubmitRequest?: () => void;
19
24
  scrollTopOnSubmit?: boolean;
@@ -55,6 +55,7 @@ export default function Provider(_ref) {
55
55
  return data !== null && data !== void 0 ? data : defaultData;
56
56
  }, []);
57
57
  const internalDataRef = useRef(initialData);
58
+ const dataCacheRef = useRef(data);
58
59
  const ajvSchemaValidatorRef = useRef();
59
60
  const validateData = useCallback(() => {
60
61
  if (!ajvSchemaValidatorRef.current) {
@@ -85,26 +86,33 @@ export default function Provider(_ref) {
85
86
  forceUpdate();
86
87
  }
87
88
  }, []);
88
- const handlePathChange = useCallback((path, value) => {
89
+ const updateDataValue = useCallback((path, value) => {
89
90
  var _internalDataRef$curr;
90
91
  if (!path) {
91
92
  return;
92
93
  }
93
- onPathChange === null || onPathChange === void 0 ? void 0 : onPathChange(path, value);
94
94
  const newData = structuredClone(path === '/' ? value : (_internalDataRef$curr = internalDataRef.current) !== null && _internalDataRef$curr !== void 0 ? _internalDataRef$curr : path.match(isArrayJsonPointer) ? [] : {});
95
95
  if (path !== '/') {
96
96
  pointer.set(newData, path, value);
97
97
  }
98
- onChange === null || onChange === void 0 ? void 0 : onChange(newData);
99
98
  if (sessionStorageId && typeof window !== 'undefined') {
100
99
  var _window$sessionStorag2;
101
100
  (_window$sessionStorag2 = window.sessionStorage) === null || _window$sessionStorag2 === void 0 ? void 0 : _window$sessionStorag2.setItem(sessionStorageId, JSON.stringify(newData));
102
101
  }
103
102
  internalDataRef.current = newData;
104
- validateData();
105
- showAllErrorsRef.current = false;
106
103
  forceUpdate();
107
- }, [onChange, onPathChange, validateData, sessionStorageId]);
104
+ return newData;
105
+ }, [sessionStorageId]);
106
+ const handlePathChange = useCallback((path, value) => {
107
+ if (!path) {
108
+ return;
109
+ }
110
+ onPathChange === null || onPathChange === void 0 ? void 0 : onPathChange(path, value);
111
+ const newData = updateDataValue(path, value);
112
+ onChange === null || onChange === void 0 ? void 0 : onChange(newData);
113
+ showAllErrorsRef.current = false;
114
+ validateData();
115
+ }, [onPathChange, updateDataValue, onChange, validateData]);
108
116
  const handleMountField = useCallback(path => {
109
117
  mountedFieldPathsRef.current = addListPath(mountedFieldPathsRef.current, path);
110
118
  }, []);
@@ -115,13 +123,25 @@ export default function Provider(_ref) {
115
123
  formElement = null
116
124
  } = {}) => {
117
125
  if (!hasErrors()) {
118
- var _formElement$reset;
119
- onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit(internalDataRef.current);
120
- formElement === null || formElement === void 0 ? void 0 : (_formElement$reset = formElement.reset) === null || _formElement$reset === void 0 ? void 0 : _formElement$reset.call(formElement);
121
- if (typeof window !== 'undefined') {
122
- if (sessionStorageId) {
123
- window.sessionStorage.removeItem(sessionStorageId);
126
+ const resetForm = () => {
127
+ var _formElement$reset;
128
+ formElement === null || formElement === void 0 ? void 0 : (_formElement$reset = formElement.reset) === null || _formElement$reset === void 0 ? void 0 : _formElement$reset.call(formElement);
129
+ if (typeof window !== 'undefined') {
130
+ if (sessionStorageId) {
131
+ window.sessionStorage.removeItem(sessionStorageId);
132
+ }
124
133
  }
134
+ forceUpdate();
135
+ };
136
+ const clearData = () => {
137
+ internalDataRef.current = {};
138
+ forceUpdate();
139
+ };
140
+ onSubmit === null || onSubmit === void 0 ? void 0 : onSubmit(internalDataRef.current, {
141
+ resetForm,
142
+ clearData
143
+ });
144
+ if (typeof window !== 'undefined') {
125
145
  if (scrollTopOnSubmit) {
126
146
  var _window;
127
147
  (_window = window) === null || _window === void 0 ? void 0 : _window.scrollTo({
@@ -141,7 +161,10 @@ export default function Provider(_ref) {
141
161
  validateData();
142
162
  });
143
163
  useUpdateEffect(() => {
144
- internalDataRef.current = data;
164
+ if (data !== dataCacheRef.current) {
165
+ dataCacheRef.current = data;
166
+ internalDataRef.current = data;
167
+ }
145
168
  validateData();
146
169
  forceUpdate();
147
170
  }, [data, validateData, forceUpdate]);
@@ -150,6 +173,7 @@ export default function Provider(_ref) {
150
173
  data: internalDataRef.current
151
174
  }, rest), {}, {
152
175
  handlePathChange,
176
+ updateDataValue,
153
177
  handleSubmit,
154
178
  errors: errorsRef.current,
155
179
  showAllErrors: showAllErrorsRef.current,
@@ -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"}
@@ -16,7 +16,8 @@ function DateComponent(props) {
16
16
  date
17
17
  }) => {
18
18
  return date;
19
- }
19
+ },
20
+ emptyValue: null
20
21
  });
21
22
  const {
22
23
  className,
@@ -43,6 +44,7 @@ function DateComponent(props) {
43
44
  title: help.title
44
45
  }, help.contents) : undefined,
45
46
  on_change: handleChange,
47
+ on_reset: handleChange,
46
48
  on_show: handleFocus,
47
49
  on_hide: handleBlur
48
50
  }, pickSpacingProps(props)));
@@ -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","useContext","DatePicker","HelpButton","useDataValue","pickSpacingProps","SharedContext","DateComponent","props","sharedContext","preparedProps","_objectSpread","fromInput","date","emptyValue","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_reset","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 emptyValue: null,\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_reset={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,CAAC;IACDC,UAAU,EAAE;EAAI,EACjB;EAED,MAAM;IACJC,SAAS;IACTC,KAAK;IACLC,KAAK;IACLC,IAAI;IACJC,KAAK;IACLC,QAAQ;IACRC,WAAW;IACXC,UAAU;IACVC;EACF,CAAC,GAAGnB,YAAY,CAACM,aAAa,CAAC;EAE/B,OACEV,KAAA,CAAAwB,aAAA,CAACtB,UAAU,EAAAuB,QAAA;IACTV,SAAS,EAAEA,SAAU;IACrBC,KAAK,EAAEA,KAAK,aAALA,KAAK,cAALA,KAAK,GAAIP,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEiB,WAAW,CAACC,KAAK,CAACC,SAAU;IAC3DC,eAAe,EAAC,UAAU;IAC1BhB,IAAI,EAAEI,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,GACFlB,KAAA,CAAAwB,aAAA,CAACrB,UAAU;MAACiC,KAAK,EAAElB,IAAI,CAACkB;IAAM,GAAElB,IAAI,CAACmB,QAAqB,CAAC,GACzDC,SACL;IACDC,SAAS,EAAEhB,YAAa;IACxBiB,QAAQ,EAAEjB,YAAa;IACvBkB,OAAO,EAAEpB,WAAY;IACrBqB,OAAO,EAAEpB;EAAW,GAChBjB,gBAAgB,CAACG,KAAK,CAAC,CAC5B,CAAC;AAEN;AAEAD,aAAa,CAACoC,qBAAqB,GAAG,IAAI;AAC1C,eAAepC,aAAa"}
@@ -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"}