@dnb/eufemia 10.15.1 → 10.17.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1177) hide show
  1. package/CHANGELOG.md +79 -0
  2. package/assets/icons/dnb/browser.svg +1 -0
  3. package/assets/icons/dnb/browser_medium.svg +1 -0
  4. package/assets/icons/dnb/coins_1.svg +1 -1
  5. package/assets/icons/dnb/coins_1_medium.svg +1 -1
  6. package/assets/icons/dnb/digipass_corporate.svg +1 -0
  7. package/assets/icons/dnb/digipass_corporate_medium.svg +1 -0
  8. package/assets/icons/dnb/digipass_private.svg +1 -0
  9. package/assets/icons/dnb/digipass_private_medium.svg +1 -0
  10. package/assets/icons/dnb/envelope_open.svg +1 -0
  11. package/assets/icons/dnb/envelope_open_medium.svg +1 -0
  12. package/assets/icons/dnb/eufemia-icons-xml-categorized.tgz +0 -0
  13. package/assets/icons/dnb/eufemia-icons-xml.tgz +0 -0
  14. package/assets/icons/dnb/laptop.svg +1 -0
  15. package/assets/icons/dnb/laptop_medium.svg +1 -0
  16. package/assets/icons/dnb/mobile.svg +1 -0
  17. package/assets/icons/dnb/mobile_medium.svg +1 -0
  18. package/assets/icons/dnb/money_left.svg +1 -0
  19. package/assets/icons/dnb/money_left_medium.svg +1 -0
  20. package/assets/icons/dnb/scan.svg +1 -1
  21. package/assets/icons/dnb/scan_medium.svg +1 -1
  22. package/assets/icons/dnb/teenager.svg +1 -0
  23. package/assets/icons/dnb/teenager_medium.svg +1 -0
  24. package/cjs/components/anchor/Anchor.js +9 -5
  25. package/cjs/components/anchor/Anchor.js.map +1 -1
  26. package/cjs/components/anchor/style/anchor-mixins.scss +8 -17
  27. package/cjs/components/anchor/style/dnb-anchor.css +28 -24
  28. package/cjs/components/anchor/style/dnb-anchor.min.css +1 -1
  29. package/cjs/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +16 -4
  30. package/cjs/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  31. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.css +16 -4
  32. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  33. package/cjs/components/anchor/style/themes/dnb-anchor-theme-ui.scss +10 -2
  34. package/cjs/components/autocomplete/Autocomplete.js +2 -2
  35. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  36. package/cjs/components/button/style/dnb-button.css +13 -0
  37. package/cjs/components/button/style/dnb-button.min.css +1 -1
  38. package/cjs/components/button/style/dnb-button.scss +16 -0
  39. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.css +12 -1
  40. package/cjs/components/button/style/themes/dnb-button-theme-eiendom.min.css +1 -1
  41. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.css +12 -0
  42. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.min.css +2 -2
  43. package/cjs/components/button/style/themes/dnb-button-theme-sbanken.scss +10 -0
  44. package/cjs/components/button/style/themes/dnb-button-theme-ui.css +12 -1
  45. package/cjs/components/button/style/themes/dnb-button-theme-ui.min.css +1 -1
  46. package/cjs/components/button/style/themes/dnb-button-theme-ui.scss +12 -3
  47. package/cjs/components/card/Card.d.ts +1 -1
  48. package/cjs/components/card/Card.js +48 -9
  49. package/cjs/components/card/Card.js.map +1 -1
  50. package/cjs/components/card/style/dnb-card.css +0 -20
  51. package/cjs/components/card/style/dnb-card.min.css +1 -1
  52. package/cjs/components/card/style/dnb-card.scss +0 -20
  53. package/cjs/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  54. package/cjs/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  55. package/cjs/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  56. package/cjs/components/date-picker/DatePicker.d.ts +18 -1
  57. package/cjs/components/date-picker/DatePicker.js +4 -3
  58. package/cjs/components/date-picker/DatePicker.js.map +1 -1
  59. package/cjs/components/date-picker/DatePickerCalc.js +2 -1
  60. package/cjs/components/date-picker/DatePickerCalc.js.map +1 -1
  61. package/cjs/components/date-picker/DatePickerInput.d.ts +3 -0
  62. package/cjs/components/date-picker/DatePickerInput.js +27 -6
  63. package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
  64. package/cjs/components/date-picker/DatePickerProvider.js +2 -2
  65. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  66. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  67. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  68. package/cjs/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  69. package/cjs/components/dropdown/Dropdown.js +3 -2
  70. package/cjs/components/dropdown/Dropdown.js.map +1 -1
  71. package/cjs/components/flex/Container.d.ts +2 -4
  72. package/cjs/components/flex/Container.js +11 -2
  73. package/cjs/components/flex/Container.js.map +1 -1
  74. package/cjs/components/flex/Item.d.ts +2 -3
  75. package/cjs/components/flex/Item.js +2 -1
  76. package/cjs/components/flex/Item.js.map +1 -1
  77. package/cjs/components/flex/export.d.ts +1 -0
  78. package/cjs/components/flex/export.js +7 -0
  79. package/cjs/components/flex/export.js.map +1 -1
  80. package/cjs/components/flex/withChildren.d.ts +6 -0
  81. package/cjs/components/flex/withChildren.js +13 -0
  82. package/cjs/components/flex/withChildren.js.map +1 -0
  83. package/cjs/components/input/Input.d.ts +3 -2
  84. package/cjs/components/input/Input.js +3 -3
  85. package/cjs/components/input/Input.js.map +1 -1
  86. package/cjs/components/input/style/themes/dnb-input-theme-ui.css +2 -0
  87. package/cjs/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  88. package/cjs/components/input/style/themes/dnb-input-theme-ui.scss +2 -0
  89. package/cjs/components/input-masked/InputMaskedHooks.d.ts +1 -0
  90. package/cjs/components/input-masked/InputMaskedHooks.js +14 -9
  91. package/cjs/components/input-masked/InputMaskedHooks.js.map +1 -1
  92. package/cjs/components/input-masked/InputMaskedUtils.d.ts +4 -2
  93. package/cjs/components/input-masked/InputMaskedUtils.js +9 -7
  94. package/cjs/components/input-masked/InputMaskedUtils.js.map +1 -1
  95. package/cjs/components/input-masked/MultiInputMask.d.ts +1 -1
  96. package/cjs/components/input-masked/MultiInputMask.js +4 -2
  97. package/cjs/components/input-masked/MultiInputMask.js.map +1 -1
  98. package/cjs/components/input-masked/TextMask.js +15 -4
  99. package/cjs/components/input-masked/TextMask.js.map +1 -1
  100. package/cjs/components/input-masked/hooks/useHandleCursorPosition.js +7 -3
  101. package/cjs/components/input-masked/hooks/useHandleCursorPosition.js.map +1 -1
  102. package/cjs/components/input-masked/style/dnb-input-masked.css +3 -0
  103. package/cjs/components/input-masked/style/dnb-input-masked.min.css +1 -1
  104. package/cjs/components/input-masked/style/dnb-input-masked.scss +5 -0
  105. package/cjs/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  106. package/cjs/components/input-masked/text-mask/InputModeNumber.js +93 -0
  107. package/cjs/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  108. package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  109. package/cjs/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  110. package/cjs/components/radio/RadioGroup.js +0 -1
  111. package/cjs/components/radio/RadioGroup.js.map +1 -1
  112. package/cjs/components/section/Section.d.ts +7 -0
  113. package/cjs/components/section/Section.js +11 -12
  114. package/cjs/components/section/Section.js.map +1 -1
  115. package/cjs/components/section/style/dnb-section.css +6 -4
  116. package/cjs/components/section/style/dnb-section.min.css +1 -1
  117. package/cjs/components/section/style/dnb-section.scss +7 -4
  118. package/cjs/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  119. package/cjs/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  120. package/cjs/components/textarea/Textarea.js +4 -9
  121. package/cjs/components/textarea/Textarea.js.map +1 -1
  122. package/cjs/components/textarea/style/dnb-textarea.css +5 -0
  123. package/cjs/components/textarea/style/dnb-textarea.min.css +1 -1
  124. package/cjs/components/textarea/style/dnb-textarea.scss +4 -0
  125. package/cjs/components/toggle-button/ToggleButtonGroup.js +0 -1
  126. package/cjs/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  127. package/cjs/components/toggle-button/style/dnb-toggle-button.css +4 -6
  128. package/cjs/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  129. package/cjs/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  130. package/cjs/components/tooltip/style/dnb-tooltip.css +1 -0
  131. package/cjs/components/tooltip/style/dnb-tooltip.min.css +1 -1
  132. package/cjs/components/tooltip/style/dnb-tooltip.scss +2 -0
  133. package/cjs/components/upload/types.d.ts +1 -1
  134. package/cjs/components/upload/types.js.map +1 -1
  135. package/cjs/extensions/forms/DataContext/Context.d.ts +1 -0
  136. package/cjs/extensions/forms/DataContext/Context.js +1 -0
  137. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  138. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  139. package/cjs/extensions/forms/DataContext/Provider/Provider.js +37 -13
  140. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  141. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  142. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  143. package/cjs/extensions/forms/Field/Currency/Currency.d.ts +1 -5
  144. package/cjs/extensions/forms/Field/Currency/Currency.js.map +1 -1
  145. package/cjs/extensions/forms/Field/Date/Date.d.ts +3 -1
  146. package/cjs/extensions/forms/Field/Date/Date.js +53 -10
  147. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  148. package/cjs/extensions/forms/Field/Email/Email.js +7 -5
  149. package/cjs/extensions/forms/Field/Email/Email.js.map +1 -1
  150. package/cjs/extensions/forms/Field/Expiry/Expiry.js +26 -4
  151. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  152. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  153. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  154. package/cjs/extensions/forms/Field/Number/Number.d.ts +5 -1
  155. package/cjs/extensions/forms/Field/Number/Number.js +112 -28
  156. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  157. package/cjs/extensions/forms/Field/Number/style/dnb-number.css +192 -0
  158. package/cjs/extensions/forms/Field/Number/style/dnb-number.min.css +1 -0
  159. package/cjs/extensions/forms/Field/Number/style/dnb-number.scss +176 -0
  160. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +74 -0
  161. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +3 -0
  162. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +81 -0
  163. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +15 -0
  164. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +5 -0
  165. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +15 -0
  166. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  167. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  168. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +67 -30
  169. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  170. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  171. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  172. package/cjs/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  173. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  174. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  175. package/cjs/extensions/forms/Field/Selection/Selection.js +59 -50
  176. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  177. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  178. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  179. package/cjs/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  180. package/cjs/extensions/forms/Field/String/String.d.ts +1 -0
  181. package/cjs/extensions/forms/Field/String/String.js +34 -9
  182. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  183. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +18 -20
  184. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  185. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +10 -1
  186. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  187. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +3 -1
  188. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  189. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  190. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  191. package/cjs/extensions/forms/Form/Handler/Handler.js +2 -2
  192. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  193. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  194. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  195. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  196. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  197. package/cjs/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  198. package/cjs/extensions/forms/{Visibility → Form/Visibility}/Visibility.d.ts +5 -2
  199. package/cjs/extensions/forms/{Visibility → Form/Visibility}/Visibility.js +8 -2
  200. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -0
  201. package/cjs/extensions/forms/Form/Visibility/index.js.map +1 -0
  202. package/cjs/extensions/forms/Form/index.d.ts +1 -0
  203. package/cjs/extensions/forms/Form/index.js +7 -0
  204. package/cjs/extensions/forms/Form/index.js.map +1 -1
  205. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  206. package/cjs/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  207. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  208. package/cjs/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  209. package/cjs/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  210. package/cjs/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  211. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  212. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  213. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  214. package/cjs/extensions/forms/hooks/useDataValue.d.ts +3 -0
  215. package/cjs/extensions/forms/hooks/useDataValue.js +96 -53
  216. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  217. package/cjs/extensions/forms/hooks/useId.d.ts +1 -0
  218. package/cjs/extensions/forms/hooks/useId.js +18 -0
  219. package/cjs/extensions/forms/hooks/useId.js.map +1 -0
  220. package/cjs/extensions/forms/index.d.ts +6 -1
  221. package/cjs/extensions/forms/index.js +5 -8
  222. package/cjs/extensions/forms/index.js.map +1 -1
  223. package/cjs/extensions/forms/style/dnb-forms.css +244 -25
  224. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  225. package/cjs/extensions/forms/types.d.ts +20 -8
  226. package/cjs/extensions/forms/types.js +1 -1
  227. package/cjs/extensions/forms/types.js.map +1 -1
  228. package/cjs/extensions/forms/utils/TestElement/TestElement.d.ts +5 -1
  229. package/cjs/extensions/forms/utils/TestElement/TestElement.js +1 -0
  230. package/cjs/extensions/forms/utils/TestElement/TestElement.js.map +1 -1
  231. package/cjs/icons/browser.d.ts +3 -0
  232. package/cjs/icons/browser.js +11 -0
  233. package/cjs/icons/browser.js.map +1 -0
  234. package/cjs/icons/browser_medium.d.ts +3 -0
  235. package/cjs/icons/browser_medium.js +11 -0
  236. package/cjs/icons/browser_medium.js.map +1 -0
  237. package/cjs/icons/digipass_corporate.d.ts +3 -0
  238. package/cjs/icons/digipass_corporate.js +11 -0
  239. package/cjs/icons/digipass_corporate.js.map +1 -0
  240. package/cjs/icons/digipass_corporate_medium.d.ts +3 -0
  241. package/cjs/icons/digipass_corporate_medium.js +11 -0
  242. package/cjs/icons/digipass_corporate_medium.js.map +1 -0
  243. package/cjs/icons/digipass_private.d.ts +3 -0
  244. package/cjs/icons/digipass_private.js +11 -0
  245. package/cjs/icons/digipass_private.js.map +1 -0
  246. package/cjs/icons/digipass_private_medium.d.ts +3 -0
  247. package/cjs/icons/digipass_private_medium.js +11 -0
  248. package/cjs/icons/digipass_private_medium.js.map +1 -0
  249. package/cjs/icons/dnb/browser.d.ts +3 -0
  250. package/cjs/icons/dnb/browser.js +25 -0
  251. package/cjs/icons/dnb/browser.js.map +1 -0
  252. package/cjs/icons/dnb/browser_medium.d.ts +3 -0
  253. package/cjs/icons/dnb/browser_medium.js +25 -0
  254. package/cjs/icons/dnb/browser_medium.js.map +1 -0
  255. package/cjs/icons/dnb/coins_1.js +1 -1
  256. package/cjs/icons/dnb/coins_1.js.map +1 -1
  257. package/cjs/icons/dnb/coins_1_medium.js +1 -1
  258. package/cjs/icons/dnb/coins_1_medium.js.map +1 -1
  259. package/cjs/icons/dnb/digipass_corporate.d.ts +3 -0
  260. package/cjs/icons/dnb/digipass_corporate.js +25 -0
  261. package/cjs/icons/dnb/digipass_corporate.js.map +1 -0
  262. package/cjs/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  263. package/cjs/icons/dnb/digipass_corporate_medium.js +25 -0
  264. package/cjs/icons/dnb/digipass_corporate_medium.js.map +1 -0
  265. package/cjs/icons/dnb/digipass_private.d.ts +3 -0
  266. package/cjs/icons/dnb/digipass_private.js +25 -0
  267. package/cjs/icons/dnb/digipass_private.js.map +1 -0
  268. package/cjs/icons/dnb/digipass_private_medium.d.ts +3 -0
  269. package/cjs/icons/dnb/digipass_private_medium.js +25 -0
  270. package/cjs/icons/dnb/digipass_private_medium.js.map +1 -0
  271. package/cjs/icons/dnb/envelope_open.d.ts +3 -0
  272. package/cjs/icons/dnb/envelope_open.js +26 -0
  273. package/cjs/icons/dnb/envelope_open.js.map +1 -0
  274. package/cjs/icons/dnb/envelope_open_medium.d.ts +3 -0
  275. package/cjs/icons/dnb/envelope_open_medium.js +26 -0
  276. package/cjs/icons/dnb/envelope_open_medium.js.map +1 -0
  277. package/cjs/icons/dnb/icons-meta.json +230 -20
  278. package/cjs/icons/dnb/icons-svg.lock +1272 -1064
  279. package/cjs/icons/dnb/index.d.ts +17 -1
  280. package/cjs/icons/dnb/index.js +112 -0
  281. package/cjs/icons/dnb/index.js.map +1 -1
  282. package/cjs/icons/dnb/laptop.d.ts +3 -0
  283. package/cjs/icons/dnb/laptop.js +26 -0
  284. package/cjs/icons/dnb/laptop.js.map +1 -0
  285. package/cjs/icons/dnb/laptop_medium.d.ts +3 -0
  286. package/cjs/icons/dnb/laptop_medium.js +26 -0
  287. package/cjs/icons/dnb/laptop_medium.js.map +1 -0
  288. package/cjs/icons/dnb/mobile.d.ts +3 -0
  289. package/cjs/icons/dnb/mobile.js +23 -0
  290. package/cjs/icons/dnb/mobile.js.map +1 -0
  291. package/cjs/icons/dnb/mobile_medium.d.ts +3 -0
  292. package/cjs/icons/dnb/mobile_medium.js +23 -0
  293. package/cjs/icons/dnb/mobile_medium.js.map +1 -0
  294. package/cjs/icons/dnb/money_left.d.ts +3 -0
  295. package/cjs/icons/dnb/money_left.js +25 -0
  296. package/cjs/icons/dnb/money_left.js.map +1 -0
  297. package/cjs/icons/dnb/money_left_medium.d.ts +3 -0
  298. package/cjs/icons/dnb/money_left_medium.js +26 -0
  299. package/cjs/icons/dnb/money_left_medium.js.map +1 -0
  300. package/cjs/icons/dnb/scan.js +5 -2
  301. package/cjs/icons/dnb/scan.js.map +1 -1
  302. package/cjs/icons/dnb/scan_medium.js +8 -12
  303. package/cjs/icons/dnb/scan_medium.js.map +1 -1
  304. package/cjs/icons/dnb/secondary_icons.d.ts +9 -1
  305. package/cjs/icons/dnb/secondary_icons.js +56 -0
  306. package/cjs/icons/dnb/secondary_icons.js.map +1 -1
  307. package/cjs/icons/dnb/secondary_icons_medium.d.ts +9 -1
  308. package/cjs/icons/dnb/secondary_icons_medium.js +56 -0
  309. package/cjs/icons/dnb/secondary_icons_medium.js.map +1 -1
  310. package/cjs/icons/dnb/teenager.d.ts +3 -0
  311. package/cjs/icons/dnb/teenager.js +26 -0
  312. package/cjs/icons/dnb/teenager.js.map +1 -0
  313. package/cjs/icons/dnb/teenager_medium.d.ts +3 -0
  314. package/cjs/icons/dnb/teenager_medium.js +26 -0
  315. package/cjs/icons/dnb/teenager_medium.js.map +1 -0
  316. package/cjs/icons/envelope_open.d.ts +3 -0
  317. package/cjs/icons/envelope_open.js +11 -0
  318. package/cjs/icons/envelope_open.js.map +1 -0
  319. package/cjs/icons/envelope_open_medium.d.ts +3 -0
  320. package/cjs/icons/envelope_open_medium.js +11 -0
  321. package/cjs/icons/envelope_open_medium.js.map +1 -0
  322. package/cjs/icons/index.d.ts +17 -1
  323. package/cjs/icons/index.js +112 -0
  324. package/cjs/icons/index.js.map +1 -1
  325. package/cjs/icons/laptop.d.ts +3 -0
  326. package/cjs/icons/laptop.js +11 -0
  327. package/cjs/icons/laptop.js.map +1 -0
  328. package/cjs/icons/laptop_medium.d.ts +3 -0
  329. package/cjs/icons/laptop_medium.js +11 -0
  330. package/cjs/icons/laptop_medium.js.map +1 -0
  331. package/cjs/icons/mobile.d.ts +3 -0
  332. package/cjs/icons/mobile.js +11 -0
  333. package/cjs/icons/mobile.js.map +1 -0
  334. package/cjs/icons/mobile_medium.d.ts +3 -0
  335. package/cjs/icons/mobile_medium.js +11 -0
  336. package/cjs/icons/mobile_medium.js.map +1 -0
  337. package/cjs/icons/money_left.d.ts +3 -0
  338. package/cjs/icons/money_left.js +11 -0
  339. package/cjs/icons/money_left.js.map +1 -0
  340. package/cjs/icons/money_left_medium.d.ts +3 -0
  341. package/cjs/icons/money_left_medium.js +11 -0
  342. package/cjs/icons/money_left_medium.js.map +1 -0
  343. package/cjs/icons/teenager.d.ts +3 -0
  344. package/cjs/icons/teenager.js +11 -0
  345. package/cjs/icons/teenager.js.map +1 -0
  346. package/cjs/icons/teenager_medium.d.ts +3 -0
  347. package/cjs/icons/teenager_medium.js +11 -0
  348. package/cjs/icons/teenager_medium.js.map +1 -0
  349. package/cjs/shared/Eufemia.d.ts +1 -1
  350. package/cjs/shared/Eufemia.js +2 -2
  351. package/cjs/shared/Eufemia.js.map +1 -1
  352. package/cjs/shared/component-helper.d.ts +1 -0
  353. package/cjs/shared/component-helper.js +6 -1
  354. package/cjs/shared/component-helper.js.map +1 -1
  355. package/cjs/style/core/utilities.scss +1 -2
  356. package/cjs/style/dnb-ui-components.css +304 -79
  357. package/cjs/style/dnb-ui-components.min.css +3 -3
  358. package/cjs/style/dnb-ui-extensions.css +244 -25
  359. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  360. package/cjs/style/dnb-ui-forms.css +244 -25
  361. package/cjs/style/dnb-ui-forms.min.css +1 -1
  362. package/cjs/style/dnb-ui-forms.scss +1 -0
  363. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  364. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  365. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +636 -113
  366. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +10 -6
  367. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  368. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  369. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  370. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +260 -25
  371. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +5 -1
  372. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  373. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +260 -26
  374. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +5 -1
  375. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.scss +2 -0
  376. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +664 -107
  377. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -6
  378. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  379. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +319 -25
  380. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +3 -1
  381. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  382. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +319 -26
  383. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +3 -1
  384. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.scss +2 -0
  385. package/cjs/style/themes/theme-ui/ui-theme-basis.css +14 -2
  386. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  387. package/cjs/style/themes/theme-ui/ui-theme-components.css +634 -113
  388. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +10 -6
  389. package/cjs/style/themes/theme-ui/ui-theme-components.scss +1 -0
  390. package/cjs/style/themes/theme-ui/ui-theme-elements.css +14 -2
  391. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  392. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +260 -25
  393. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +5 -1
  394. package/cjs/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  395. package/cjs/style/themes/theme-ui/ui-theme-forms.css +260 -26
  396. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +5 -1
  397. package/cjs/style/themes/theme-ui/ui-theme-forms.scss +2 -0
  398. package/cjs/style/themes/theme-ui/ui-theme-tags.css +11 -13
  399. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  400. package/components/anchor/Anchor.js +9 -5
  401. package/components/anchor/Anchor.js.map +1 -1
  402. package/components/anchor/style/anchor-mixins.scss +8 -17
  403. package/components/anchor/style/dnb-anchor.css +28 -24
  404. package/components/anchor/style/dnb-anchor.min.css +1 -1
  405. package/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +16 -4
  406. package/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  407. package/components/anchor/style/themes/dnb-anchor-theme-ui.css +16 -4
  408. package/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  409. package/components/anchor/style/themes/dnb-anchor-theme-ui.scss +10 -2
  410. package/components/autocomplete/Autocomplete.js +2 -2
  411. package/components/autocomplete/Autocomplete.js.map +1 -1
  412. package/components/button/style/dnb-button.css +13 -0
  413. package/components/button/style/dnb-button.min.css +1 -1
  414. package/components/button/style/dnb-button.scss +16 -0
  415. package/components/button/style/themes/dnb-button-theme-eiendom.css +12 -1
  416. package/components/button/style/themes/dnb-button-theme-eiendom.min.css +1 -1
  417. package/components/button/style/themes/dnb-button-theme-sbanken.css +12 -0
  418. package/components/button/style/themes/dnb-button-theme-sbanken.min.css +2 -2
  419. package/components/button/style/themes/dnb-button-theme-sbanken.scss +10 -0
  420. package/components/button/style/themes/dnb-button-theme-ui.css +12 -1
  421. package/components/button/style/themes/dnb-button-theme-ui.min.css +1 -1
  422. package/components/button/style/themes/dnb-button-theme-ui.scss +12 -3
  423. package/components/card/Card.d.ts +1 -1
  424. package/components/card/Card.js +46 -9
  425. package/components/card/Card.js.map +1 -1
  426. package/components/card/style/dnb-card.css +0 -20
  427. package/components/card/style/dnb-card.min.css +1 -1
  428. package/components/card/style/dnb-card.scss +0 -20
  429. package/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  430. package/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  431. package/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  432. package/components/date-picker/DatePicker.d.ts +18 -1
  433. package/components/date-picker/DatePicker.js +4 -3
  434. package/components/date-picker/DatePicker.js.map +1 -1
  435. package/components/date-picker/DatePickerCalc.js +2 -1
  436. package/components/date-picker/DatePickerCalc.js.map +1 -1
  437. package/components/date-picker/DatePickerInput.d.ts +3 -0
  438. package/components/date-picker/DatePickerInput.js +27 -6
  439. package/components/date-picker/DatePickerInput.js.map +1 -1
  440. package/components/date-picker/DatePickerProvider.js +2 -2
  441. package/components/date-picker/DatePickerProvider.js.map +1 -1
  442. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  443. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  444. package/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  445. package/components/dropdown/Dropdown.js +3 -2
  446. package/components/dropdown/Dropdown.js.map +1 -1
  447. package/components/flex/Container.d.ts +2 -4
  448. package/components/flex/Container.js +11 -2
  449. package/components/flex/Container.js.map +1 -1
  450. package/components/flex/Item.d.ts +2 -3
  451. package/components/flex/Item.js +2 -1
  452. package/components/flex/Item.js.map +1 -1
  453. package/components/flex/export.d.ts +1 -0
  454. package/components/flex/export.js +1 -0
  455. package/components/flex/export.js.map +1 -1
  456. package/components/flex/withChildren.d.ts +6 -0
  457. package/components/flex/withChildren.js +6 -0
  458. package/components/flex/withChildren.js.map +1 -0
  459. package/components/input/Input.d.ts +3 -2
  460. package/components/input/Input.js +3 -3
  461. package/components/input/Input.js.map +1 -1
  462. package/components/input/style/themes/dnb-input-theme-ui.css +2 -0
  463. package/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  464. package/components/input/style/themes/dnb-input-theme-ui.scss +2 -0
  465. package/components/input-masked/InputMaskedHooks.d.ts +1 -0
  466. package/components/input-masked/InputMaskedHooks.js +15 -10
  467. package/components/input-masked/InputMaskedHooks.js.map +1 -1
  468. package/components/input-masked/InputMaskedUtils.d.ts +4 -2
  469. package/components/input-masked/InputMaskedUtils.js +9 -7
  470. package/components/input-masked/InputMaskedUtils.js.map +1 -1
  471. package/components/input-masked/MultiInputMask.d.ts +1 -1
  472. package/components/input-masked/MultiInputMask.js +4 -2
  473. package/components/input-masked/MultiInputMask.js.map +1 -1
  474. package/components/input-masked/TextMask.js +15 -4
  475. package/components/input-masked/TextMask.js.map +1 -1
  476. package/components/input-masked/hooks/useHandleCursorPosition.js +7 -3
  477. package/components/input-masked/hooks/useHandleCursorPosition.js.map +1 -1
  478. package/components/input-masked/style/dnb-input-masked.css +3 -0
  479. package/components/input-masked/style/dnb-input-masked.min.css +1 -1
  480. package/components/input-masked/style/dnb-input-masked.scss +5 -0
  481. package/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  482. package/components/input-masked/text-mask/InputModeNumber.js +84 -0
  483. package/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  484. package/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  485. package/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  486. package/components/radio/RadioGroup.js +0 -1
  487. package/components/radio/RadioGroup.js.map +1 -1
  488. package/components/section/Section.d.ts +7 -0
  489. package/components/section/Section.js +10 -12
  490. package/components/section/Section.js.map +1 -1
  491. package/components/section/style/dnb-section.css +6 -4
  492. package/components/section/style/dnb-section.min.css +1 -1
  493. package/components/section/style/dnb-section.scss +7 -4
  494. package/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  495. package/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  496. package/components/textarea/Textarea.js +4 -9
  497. package/components/textarea/Textarea.js.map +1 -1
  498. package/components/textarea/style/dnb-textarea.css +5 -0
  499. package/components/textarea/style/dnb-textarea.min.css +1 -1
  500. package/components/textarea/style/dnb-textarea.scss +4 -0
  501. package/components/toggle-button/ToggleButtonGroup.js +0 -1
  502. package/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  503. package/components/toggle-button/style/dnb-toggle-button.css +4 -6
  504. package/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  505. package/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  506. package/components/tooltip/style/dnb-tooltip.css +1 -0
  507. package/components/tooltip/style/dnb-tooltip.min.css +1 -1
  508. package/components/tooltip/style/dnb-tooltip.scss +2 -0
  509. package/components/upload/types.d.ts +1 -1
  510. package/components/upload/types.js.map +1 -1
  511. package/es/components/anchor/Anchor.js +9 -5
  512. package/es/components/anchor/Anchor.js.map +1 -1
  513. package/es/components/anchor/style/anchor-mixins.scss +8 -17
  514. package/es/components/anchor/style/dnb-anchor.css +28 -24
  515. package/es/components/anchor/style/dnb-anchor.min.css +1 -1
  516. package/es/components/anchor/style/themes/dnb-anchor-theme-eiendom.css +16 -4
  517. package/es/components/anchor/style/themes/dnb-anchor-theme-eiendom.min.css +1 -1
  518. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.css +16 -4
  519. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.min.css +1 -1
  520. package/es/components/anchor/style/themes/dnb-anchor-theme-ui.scss +10 -2
  521. package/es/components/autocomplete/Autocomplete.js +2 -2
  522. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  523. package/es/components/button/style/dnb-button.css +13 -0
  524. package/es/components/button/style/dnb-button.min.css +1 -1
  525. package/es/components/button/style/dnb-button.scss +16 -0
  526. package/es/components/button/style/themes/dnb-button-theme-eiendom.css +12 -1
  527. package/es/components/button/style/themes/dnb-button-theme-eiendom.min.css +1 -1
  528. package/es/components/button/style/themes/dnb-button-theme-sbanken.css +12 -0
  529. package/es/components/button/style/themes/dnb-button-theme-sbanken.min.css +2 -2
  530. package/es/components/button/style/themes/dnb-button-theme-sbanken.scss +10 -0
  531. package/es/components/button/style/themes/dnb-button-theme-ui.css +12 -1
  532. package/es/components/button/style/themes/dnb-button-theme-ui.min.css +1 -1
  533. package/es/components/button/style/themes/dnb-button-theme-ui.scss +12 -3
  534. package/es/components/card/Card.d.ts +1 -1
  535. package/es/components/card/Card.js +46 -9
  536. package/es/components/card/Card.js.map +1 -1
  537. package/es/components/card/style/dnb-card.css +0 -20
  538. package/es/components/card/style/dnb-card.min.css +1 -1
  539. package/es/components/card/style/dnb-card.scss +0 -20
  540. package/es/components/card/style/themes/dnb-card-theme-ui.css +26 -0
  541. package/es/components/card/style/themes/dnb-card-theme-ui.min.css +1 -0
  542. package/es/components/card/style/themes/dnb-card-theme-ui.scss +35 -0
  543. package/es/components/date-picker/DatePicker.d.ts +18 -1
  544. package/es/components/date-picker/DatePicker.js +4 -3
  545. package/es/components/date-picker/DatePicker.js.map +1 -1
  546. package/es/components/date-picker/DatePickerCalc.js +2 -1
  547. package/es/components/date-picker/DatePickerCalc.js.map +1 -1
  548. package/es/components/date-picker/DatePickerInput.d.ts +3 -0
  549. package/es/components/date-picker/DatePickerInput.js +27 -6
  550. package/es/components/date-picker/DatePickerInput.js.map +1 -1
  551. package/es/components/date-picker/DatePickerProvider.js +2 -2
  552. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  553. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.css +2 -2
  554. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.min.css +1 -1
  555. package/es/components/date-picker/style/themes/dnb-date-picker-theme-ui.scss +5 -17
  556. package/es/components/dropdown/Dropdown.js +3 -2
  557. package/es/components/dropdown/Dropdown.js.map +1 -1
  558. package/es/components/flex/Container.d.ts +2 -4
  559. package/es/components/flex/Container.js +11 -2
  560. package/es/components/flex/Container.js.map +1 -1
  561. package/es/components/flex/Item.d.ts +2 -3
  562. package/es/components/flex/Item.js +2 -1
  563. package/es/components/flex/Item.js.map +1 -1
  564. package/es/components/flex/export.d.ts +1 -0
  565. package/es/components/flex/export.js +1 -0
  566. package/es/components/flex/export.js.map +1 -1
  567. package/es/components/flex/withChildren.d.ts +6 -0
  568. package/es/components/flex/withChildren.js +6 -0
  569. package/es/components/flex/withChildren.js.map +1 -0
  570. package/es/components/input/Input.d.ts +3 -2
  571. package/es/components/input/Input.js +3 -3
  572. package/es/components/input/Input.js.map +1 -1
  573. package/es/components/input/style/themes/dnb-input-theme-ui.css +2 -0
  574. package/es/components/input/style/themes/dnb-input-theme-ui.min.css +1 -1
  575. package/es/components/input/style/themes/dnb-input-theme-ui.scss +2 -0
  576. package/es/components/input-masked/InputMaskedHooks.d.ts +1 -0
  577. package/es/components/input-masked/InputMaskedHooks.js +15 -10
  578. package/es/components/input-masked/InputMaskedHooks.js.map +1 -1
  579. package/es/components/input-masked/InputMaskedUtils.d.ts +4 -2
  580. package/es/components/input-masked/InputMaskedUtils.js +9 -7
  581. package/es/components/input-masked/InputMaskedUtils.js.map +1 -1
  582. package/es/components/input-masked/MultiInputMask.d.ts +1 -1
  583. package/es/components/input-masked/MultiInputMask.js +4 -2
  584. package/es/components/input-masked/MultiInputMask.js.map +1 -1
  585. package/es/components/input-masked/TextMask.js +15 -4
  586. package/es/components/input-masked/TextMask.js.map +1 -1
  587. package/es/components/input-masked/hooks/useHandleCursorPosition.js +7 -3
  588. package/es/components/input-masked/hooks/useHandleCursorPosition.js.map +1 -1
  589. package/es/components/input-masked/style/dnb-input-masked.css +3 -0
  590. package/es/components/input-masked/style/dnb-input-masked.min.css +1 -1
  591. package/es/components/input-masked/style/dnb-input-masked.scss +5 -0
  592. package/es/components/input-masked/text-mask/InputModeNumber.d.ts +20 -0
  593. package/es/components/input-masked/text-mask/InputModeNumber.js +84 -0
  594. package/es/components/input-masked/text-mask/InputModeNumber.js.map +1 -0
  595. package/es/components/input-masked/text-mask/createTextMaskInputElement.js +1 -1
  596. package/es/components/input-masked/text-mask/createTextMaskInputElement.js.map +1 -1
  597. package/es/components/radio/RadioGroup.js +0 -1
  598. package/es/components/radio/RadioGroup.js.map +1 -1
  599. package/es/components/section/Section.d.ts +7 -0
  600. package/es/components/section/Section.js +10 -12
  601. package/es/components/section/Section.js.map +1 -1
  602. package/es/components/section/style/dnb-section.css +6 -4
  603. package/es/components/section/style/dnb-section.min.css +1 -1
  604. package/es/components/section/style/dnb-section.scss +7 -4
  605. package/es/components/section/style/themes/dnb-section-theme-ui.css +11 -1
  606. package/es/components/section/style/themes/dnb-section-theme-ui.min.css +1 -1
  607. package/es/components/textarea/Textarea.js +4 -9
  608. package/es/components/textarea/Textarea.js.map +1 -1
  609. package/es/components/textarea/style/dnb-textarea.css +5 -0
  610. package/es/components/textarea/style/dnb-textarea.min.css +1 -1
  611. package/es/components/textarea/style/dnb-textarea.scss +4 -0
  612. package/es/components/toggle-button/ToggleButtonGroup.js +0 -1
  613. package/es/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  614. package/es/components/toggle-button/style/dnb-toggle-button.css +4 -6
  615. package/es/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  616. package/es/components/toggle-button/style/dnb-toggle-button.scss +4 -10
  617. package/es/components/tooltip/style/dnb-tooltip.css +1 -0
  618. package/es/components/tooltip/style/dnb-tooltip.min.css +1 -1
  619. package/es/components/tooltip/style/dnb-tooltip.scss +2 -0
  620. package/es/components/upload/types.d.ts +1 -1
  621. package/es/components/upload/types.js.map +1 -1
  622. package/es/extensions/forms/DataContext/Context.d.ts +1 -0
  623. package/es/extensions/forms/DataContext/Context.js +1 -0
  624. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  625. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  626. package/es/extensions/forms/DataContext/Provider/Provider.js +37 -13
  627. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  628. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  629. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  630. package/es/extensions/forms/Field/Currency/Currency.d.ts +1 -5
  631. package/es/extensions/forms/Field/Currency/Currency.js.map +1 -1
  632. package/es/extensions/forms/Field/Date/Date.d.ts +3 -1
  633. package/es/extensions/forms/Field/Date/Date.js +51 -9
  634. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  635. package/es/extensions/forms/Field/Email/Email.js +7 -5
  636. package/es/extensions/forms/Field/Email/Email.js.map +1 -1
  637. package/es/extensions/forms/Field/Expiry/Expiry.js +26 -4
  638. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  639. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  640. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  641. package/es/extensions/forms/Field/Number/Number.d.ts +5 -1
  642. package/es/extensions/forms/Field/Number/Number.js +112 -29
  643. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  644. package/es/extensions/forms/Field/Number/style/dnb-number.css +192 -0
  645. package/es/extensions/forms/Field/Number/style/dnb-number.min.css +1 -0
  646. package/es/extensions/forms/Field/Number/style/dnb-number.scss +176 -0
  647. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +74 -0
  648. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +3 -0
  649. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +81 -0
  650. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +15 -0
  651. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +5 -0
  652. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +15 -0
  653. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  654. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  655. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +57 -21
  656. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  657. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  658. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  659. package/es/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  660. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  661. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  662. package/es/extensions/forms/Field/Selection/Selection.js +58 -50
  663. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  664. package/es/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  665. package/es/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  666. package/es/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  667. package/es/extensions/forms/Field/String/String.d.ts +1 -0
  668. package/es/extensions/forms/Field/String/String.js +34 -8
  669. package/es/extensions/forms/Field/String/String.js.map +1 -1
  670. package/es/extensions/forms/FieldBlock/FieldBlock.js +16 -17
  671. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  672. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +10 -1
  673. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  674. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +3 -1
  675. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  676. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  677. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  678. package/es/extensions/forms/Form/Handler/Handler.js +2 -2
  679. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  680. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  681. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  682. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  683. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  684. package/es/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  685. package/{extensions/forms → es/extensions/forms/Form}/Visibility/Visibility.d.ts +5 -2
  686. package/es/extensions/forms/{Visibility → Form/Visibility}/Visibility.js +8 -2
  687. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -0
  688. package/es/extensions/forms/Form/Visibility/index.js.map +1 -0
  689. package/es/extensions/forms/Form/index.d.ts +1 -0
  690. package/es/extensions/forms/Form/index.js +1 -0
  691. package/es/extensions/forms/Form/index.js.map +1 -1
  692. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  693. package/es/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  694. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  695. package/es/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  696. package/es/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  697. package/es/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  698. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  699. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  700. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  701. package/es/extensions/forms/hooks/useDataValue.d.ts +3 -0
  702. package/es/extensions/forms/hooks/useDataValue.js +91 -49
  703. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  704. package/es/extensions/forms/hooks/useId.d.ts +1 -0
  705. package/es/extensions/forms/hooks/useId.js +11 -0
  706. package/es/extensions/forms/hooks/useId.js.map +1 -0
  707. package/es/extensions/forms/index.d.ts +6 -1
  708. package/es/extensions/forms/index.js +3 -1
  709. package/es/extensions/forms/index.js.map +1 -1
  710. package/es/extensions/forms/style/dnb-forms.css +244 -25
  711. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  712. package/es/extensions/forms/types.d.ts +20 -8
  713. package/es/extensions/forms/types.js +1 -1
  714. package/es/extensions/forms/types.js.map +1 -1
  715. package/es/extensions/forms/utils/TestElement/TestElement.d.ts +5 -1
  716. package/es/extensions/forms/utils/TestElement/TestElement.js +1 -0
  717. package/es/extensions/forms/utils/TestElement/TestElement.js.map +1 -1
  718. package/es/icons/browser.d.ts +3 -0
  719. package/es/icons/browser.js +3 -0
  720. package/es/icons/browser.js.map +1 -0
  721. package/es/icons/browser_medium.d.ts +3 -0
  722. package/es/icons/browser_medium.js +3 -0
  723. package/es/icons/browser_medium.js.map +1 -0
  724. package/es/icons/digipass_corporate.d.ts +3 -0
  725. package/es/icons/digipass_corporate.js +3 -0
  726. package/es/icons/digipass_corporate.js.map +1 -0
  727. package/es/icons/digipass_corporate_medium.d.ts +3 -0
  728. package/es/icons/digipass_corporate_medium.js +3 -0
  729. package/es/icons/digipass_corporate_medium.js.map +1 -0
  730. package/es/icons/digipass_private.d.ts +3 -0
  731. package/es/icons/digipass_private.js +3 -0
  732. package/es/icons/digipass_private.js.map +1 -0
  733. package/es/icons/digipass_private_medium.d.ts +3 -0
  734. package/es/icons/digipass_private_medium.js +3 -0
  735. package/es/icons/digipass_private_medium.js.map +1 -0
  736. package/es/icons/dnb/browser.d.ts +3 -0
  737. package/es/icons/dnb/browser.js +17 -0
  738. package/es/icons/dnb/browser.js.map +1 -0
  739. package/es/icons/dnb/browser_medium.d.ts +3 -0
  740. package/es/icons/dnb/browser_medium.js +17 -0
  741. package/es/icons/dnb/browser_medium.js.map +1 -0
  742. package/es/icons/dnb/coins_1.js +1 -1
  743. package/es/icons/dnb/coins_1.js.map +1 -1
  744. package/es/icons/dnb/coins_1_medium.js +1 -1
  745. package/es/icons/dnb/coins_1_medium.js.map +1 -1
  746. package/es/icons/dnb/digipass_corporate.d.ts +3 -0
  747. package/es/icons/dnb/digipass_corporate.js +17 -0
  748. package/es/icons/dnb/digipass_corporate.js.map +1 -0
  749. package/es/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  750. package/es/icons/dnb/digipass_corporate_medium.js +17 -0
  751. package/es/icons/dnb/digipass_corporate_medium.js.map +1 -0
  752. package/es/icons/dnb/digipass_private.d.ts +3 -0
  753. package/es/icons/dnb/digipass_private.js +17 -0
  754. package/es/icons/dnb/digipass_private.js.map +1 -0
  755. package/es/icons/dnb/digipass_private_medium.d.ts +3 -0
  756. package/es/icons/dnb/digipass_private_medium.js +17 -0
  757. package/es/icons/dnb/digipass_private_medium.js.map +1 -0
  758. package/es/icons/dnb/envelope_open.d.ts +3 -0
  759. package/es/icons/dnb/envelope_open.js +18 -0
  760. package/es/icons/dnb/envelope_open.js.map +1 -0
  761. package/es/icons/dnb/envelope_open_medium.d.ts +3 -0
  762. package/es/icons/dnb/envelope_open_medium.js +18 -0
  763. package/es/icons/dnb/envelope_open_medium.js.map +1 -0
  764. package/es/icons/dnb/icons-meta.json +230 -20
  765. package/es/icons/dnb/icons-svg.lock +1272 -1064
  766. package/es/icons/dnb/index.d.ts +17 -1
  767. package/es/icons/dnb/index.js +17 -1
  768. package/es/icons/dnb/index.js.map +1 -1
  769. package/es/icons/dnb/laptop.d.ts +3 -0
  770. package/es/icons/dnb/laptop.js +18 -0
  771. package/es/icons/dnb/laptop.js.map +1 -0
  772. package/es/icons/dnb/laptop_medium.d.ts +3 -0
  773. package/es/icons/dnb/laptop_medium.js +18 -0
  774. package/es/icons/dnb/laptop_medium.js.map +1 -0
  775. package/es/icons/dnb/mobile.d.ts +3 -0
  776. package/es/icons/dnb/mobile.js +15 -0
  777. package/es/icons/dnb/mobile.js.map +1 -0
  778. package/es/icons/dnb/mobile_medium.d.ts +3 -0
  779. package/es/icons/dnb/mobile_medium.js +15 -0
  780. package/es/icons/dnb/mobile_medium.js.map +1 -0
  781. package/es/icons/dnb/money_left.d.ts +3 -0
  782. package/es/icons/dnb/money_left.js +17 -0
  783. package/es/icons/dnb/money_left.js.map +1 -0
  784. package/es/icons/dnb/money_left_medium.d.ts +3 -0
  785. package/es/icons/dnb/money_left_medium.js +18 -0
  786. package/es/icons/dnb/money_left_medium.js.map +1 -0
  787. package/es/icons/dnb/scan.js +5 -2
  788. package/es/icons/dnb/scan.js.map +1 -1
  789. package/es/icons/dnb/scan_medium.js +8 -12
  790. package/es/icons/dnb/scan_medium.js.map +1 -1
  791. package/es/icons/dnb/secondary_icons.d.ts +9 -1
  792. package/es/icons/dnb/secondary_icons.js +9 -1
  793. package/es/icons/dnb/secondary_icons.js.map +1 -1
  794. package/es/icons/dnb/secondary_icons_medium.d.ts +9 -1
  795. package/es/icons/dnb/secondary_icons_medium.js +9 -1
  796. package/es/icons/dnb/secondary_icons_medium.js.map +1 -1
  797. package/es/icons/dnb/teenager.d.ts +3 -0
  798. package/es/icons/dnb/teenager.js +18 -0
  799. package/es/icons/dnb/teenager.js.map +1 -0
  800. package/es/icons/dnb/teenager_medium.d.ts +3 -0
  801. package/es/icons/dnb/teenager_medium.js +18 -0
  802. package/es/icons/dnb/teenager_medium.js.map +1 -0
  803. package/es/icons/envelope_open.d.ts +3 -0
  804. package/es/icons/envelope_open.js +3 -0
  805. package/es/icons/envelope_open.js.map +1 -0
  806. package/es/icons/envelope_open_medium.d.ts +3 -0
  807. package/es/icons/envelope_open_medium.js +3 -0
  808. package/es/icons/envelope_open_medium.js.map +1 -0
  809. package/es/icons/index.d.ts +17 -1
  810. package/es/icons/index.js +17 -1
  811. package/es/icons/index.js.map +1 -1
  812. package/es/icons/laptop.d.ts +3 -0
  813. package/es/icons/laptop.js +3 -0
  814. package/es/icons/laptop.js.map +1 -0
  815. package/es/icons/laptop_medium.d.ts +3 -0
  816. package/es/icons/laptop_medium.js +3 -0
  817. package/es/icons/laptop_medium.js.map +1 -0
  818. package/es/icons/mobile.d.ts +3 -0
  819. package/es/icons/mobile.js +3 -0
  820. package/es/icons/mobile.js.map +1 -0
  821. package/es/icons/mobile_medium.d.ts +3 -0
  822. package/es/icons/mobile_medium.js +3 -0
  823. package/es/icons/mobile_medium.js.map +1 -0
  824. package/es/icons/money_left.d.ts +3 -0
  825. package/es/icons/money_left.js +3 -0
  826. package/es/icons/money_left.js.map +1 -0
  827. package/es/icons/money_left_medium.d.ts +3 -0
  828. package/es/icons/money_left_medium.js +3 -0
  829. package/es/icons/money_left_medium.js.map +1 -0
  830. package/es/icons/teenager.d.ts +3 -0
  831. package/es/icons/teenager.js +3 -0
  832. package/es/icons/teenager.js.map +1 -0
  833. package/es/icons/teenager_medium.d.ts +3 -0
  834. package/es/icons/teenager_medium.js +3 -0
  835. package/es/icons/teenager_medium.js.map +1 -0
  836. package/es/shared/Eufemia.d.ts +1 -1
  837. package/es/shared/Eufemia.js +2 -2
  838. package/es/shared/Eufemia.js.map +1 -1
  839. package/es/shared/component-helper.d.ts +1 -0
  840. package/es/shared/component-helper.js +3 -0
  841. package/es/shared/component-helper.js.map +1 -1
  842. package/es/style/core/utilities.scss +1 -2
  843. package/es/style/dnb-ui-components.css +304 -79
  844. package/es/style/dnb-ui-components.min.css +3 -3
  845. package/es/style/dnb-ui-extensions.css +244 -25
  846. package/es/style/dnb-ui-extensions.min.css +1 -1
  847. package/es/style/dnb-ui-forms.css +244 -25
  848. package/es/style/dnb-ui-forms.min.css +1 -1
  849. package/es/style/dnb-ui-forms.scss +1 -0
  850. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  851. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  852. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +636 -113
  853. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +10 -6
  854. package/es/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  855. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  856. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  857. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +260 -25
  858. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +5 -1
  859. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  860. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +260 -26
  861. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +5 -1
  862. package/es/style/themes/theme-eiendom/eiendom-theme-forms.scss +2 -0
  863. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +664 -107
  864. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -6
  865. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  866. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +319 -25
  867. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +3 -1
  868. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  869. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +319 -26
  870. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +3 -1
  871. package/es/style/themes/theme-sbanken/sbanken-theme-forms.scss +2 -0
  872. package/es/style/themes/theme-ui/ui-theme-basis.css +14 -2
  873. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  874. package/es/style/themes/theme-ui/ui-theme-components.css +634 -113
  875. package/es/style/themes/theme-ui/ui-theme-components.min.css +10 -6
  876. package/es/style/themes/theme-ui/ui-theme-components.scss +1 -0
  877. package/es/style/themes/theme-ui/ui-theme-elements.css +14 -2
  878. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  879. package/es/style/themes/theme-ui/ui-theme-extensions.css +260 -25
  880. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +5 -1
  881. package/es/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  882. package/es/style/themes/theme-ui/ui-theme-forms.css +260 -26
  883. package/es/style/themes/theme-ui/ui-theme-forms.min.css +5 -1
  884. package/es/style/themes/theme-ui/ui-theme-forms.scss +2 -0
  885. package/es/style/themes/theme-ui/ui-theme-tags.css +11 -13
  886. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  887. package/esm/dnb-ui-basis.min.mjs +1 -1
  888. package/esm/dnb-ui-components.min.mjs +1 -1
  889. package/esm/dnb-ui-elements.min.mjs +1 -1
  890. package/esm/dnb-ui-extensions.min.mjs +3 -3
  891. package/esm/dnb-ui-lib.min.mjs +1 -1
  892. package/extensions/forms/DataContext/Context.d.ts +1 -0
  893. package/extensions/forms/DataContext/Context.js +1 -0
  894. package/extensions/forms/DataContext/Context.js.map +1 -1
  895. package/extensions/forms/DataContext/Provider/Provider.d.ts +6 -1
  896. package/extensions/forms/DataContext/Provider/Provider.js +37 -13
  897. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  898. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +2 -1
  899. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  900. package/extensions/forms/Field/Currency/Currency.d.ts +1 -5
  901. package/extensions/forms/Field/Currency/Currency.js.map +1 -1
  902. package/extensions/forms/Field/Date/Date.d.ts +3 -1
  903. package/extensions/forms/Field/Date/Date.js +54 -11
  904. package/extensions/forms/Field/Date/Date.js.map +1 -1
  905. package/extensions/forms/Field/Email/Email.js +7 -5
  906. package/extensions/forms/Field/Email/Email.js.map +1 -1
  907. package/extensions/forms/Field/Expiry/Expiry.js +26 -4
  908. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  909. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +2 -1
  910. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  911. package/extensions/forms/Field/Number/Number.d.ts +5 -1
  912. package/extensions/forms/Field/Number/Number.js +113 -29
  913. package/extensions/forms/Field/Number/Number.js.map +1 -1
  914. package/extensions/forms/Field/Number/style/dnb-number.css +192 -0
  915. package/extensions/forms/Field/Number/style/dnb-number.min.css +1 -0
  916. package/extensions/forms/Field/Number/style/dnb-number.scss +176 -0
  917. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +74 -0
  918. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +3 -0
  919. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +81 -0
  920. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +15 -0
  921. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +5 -0
  922. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +15 -0
  923. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +2 -1
  924. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  925. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +68 -31
  926. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  927. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.css +3 -0
  928. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.min.css +1 -1
  929. package/extensions/forms/Field/PhoneNumber/style/dnb-phone-number.scss +4 -0
  930. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -1
  931. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  932. package/extensions/forms/Field/Selection/Selection.js +58 -50
  933. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  934. package/extensions/forms/Field/Selection/style/dnb-selection.css +6 -6
  935. package/extensions/forms/Field/Selection/style/dnb-selection.min.css +1 -1
  936. package/extensions/forms/Field/Selection/style/dnb-selection.scss +15 -10
  937. package/extensions/forms/Field/String/String.d.ts +1 -0
  938. package/extensions/forms/Field/String/String.js +34 -9
  939. package/extensions/forms/Field/String/String.js.map +1 -1
  940. package/extensions/forms/FieldBlock/FieldBlock.js +18 -20
  941. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  942. package/extensions/forms/FieldBlock/style/dnb-field-block.css +10 -1
  943. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  944. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +3 -1
  945. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +8 -0
  946. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  947. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.scss +10 -0
  948. package/extensions/forms/Form/Handler/Handler.js +2 -2
  949. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  950. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +7 -2
  951. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  952. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.scss +6 -1
  953. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.css +3 -0
  954. package/extensions/forms/Form/SubHeading/style/dnb-form-sub-heading.scss +2 -0
  955. package/{es/extensions/forms → extensions/forms/Form}/Visibility/Visibility.d.ts +5 -2
  956. package/extensions/forms/{Visibility → Form/Visibility}/Visibility.js +8 -2
  957. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -0
  958. package/extensions/forms/Form/Visibility/index.js.map +1 -0
  959. package/extensions/forms/Form/index.d.ts +1 -0
  960. package/extensions/forms/Form/index.js +1 -0
  961. package/extensions/forms/Form/index.js.map +1 -1
  962. package/extensions/forms/StepsLayout/NextButton/NextButton.js +3 -2
  963. package/extensions/forms/StepsLayout/NextButton/NextButton.js.map +1 -1
  964. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js +3 -2
  965. package/extensions/forms/StepsLayout/PreviousButton/PreviousButton.js.map +1 -1
  966. package/extensions/forms/StepsLayout/StepsLayout.js +1 -1
  967. package/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  968. package/extensions/forms/StepsLayout/style/dnb-steps-layout.css +14 -16
  969. package/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  970. package/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +15 -16
  971. package/extensions/forms/hooks/useDataValue.d.ts +3 -0
  972. package/extensions/forms/hooks/useDataValue.js +96 -53
  973. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  974. package/extensions/forms/hooks/useId.d.ts +1 -0
  975. package/extensions/forms/hooks/useId.js +11 -0
  976. package/extensions/forms/hooks/useId.js.map +1 -0
  977. package/extensions/forms/index.d.ts +6 -1
  978. package/extensions/forms/index.js +3 -1
  979. package/extensions/forms/index.js.map +1 -1
  980. package/extensions/forms/style/dnb-forms.css +244 -25
  981. package/extensions/forms/style/dnb-forms.min.css +1 -1
  982. package/extensions/forms/types.d.ts +20 -8
  983. package/extensions/forms/types.js +1 -1
  984. package/extensions/forms/types.js.map +1 -1
  985. package/extensions/forms/utils/TestElement/TestElement.d.ts +5 -1
  986. package/extensions/forms/utils/TestElement/TestElement.js +1 -0
  987. package/extensions/forms/utils/TestElement/TestElement.js.map +1 -1
  988. package/icons/browser.d.ts +3 -0
  989. package/icons/browser.js +3 -0
  990. package/icons/browser.js.map +1 -0
  991. package/icons/browser_medium.d.ts +3 -0
  992. package/icons/browser_medium.js +3 -0
  993. package/icons/browser_medium.js.map +1 -0
  994. package/icons/digipass_corporate.d.ts +3 -0
  995. package/icons/digipass_corporate.js +3 -0
  996. package/icons/digipass_corporate.js.map +1 -0
  997. package/icons/digipass_corporate_medium.d.ts +3 -0
  998. package/icons/digipass_corporate_medium.js +3 -0
  999. package/icons/digipass_corporate_medium.js.map +1 -0
  1000. package/icons/digipass_private.d.ts +3 -0
  1001. package/icons/digipass_private.js +3 -0
  1002. package/icons/digipass_private.js.map +1 -0
  1003. package/icons/digipass_private_medium.d.ts +3 -0
  1004. package/icons/digipass_private_medium.js +3 -0
  1005. package/icons/digipass_private_medium.js.map +1 -0
  1006. package/icons/dnb/browser.d.ts +3 -0
  1007. package/icons/dnb/browser.js +17 -0
  1008. package/icons/dnb/browser.js.map +1 -0
  1009. package/icons/dnb/browser_medium.d.ts +3 -0
  1010. package/icons/dnb/browser_medium.js +17 -0
  1011. package/icons/dnb/browser_medium.js.map +1 -0
  1012. package/icons/dnb/coins_1.js +1 -1
  1013. package/icons/dnb/coins_1.js.map +1 -1
  1014. package/icons/dnb/coins_1_medium.js +1 -1
  1015. package/icons/dnb/coins_1_medium.js.map +1 -1
  1016. package/icons/dnb/digipass_corporate.d.ts +3 -0
  1017. package/icons/dnb/digipass_corporate.js +17 -0
  1018. package/icons/dnb/digipass_corporate.js.map +1 -0
  1019. package/icons/dnb/digipass_corporate_medium.d.ts +3 -0
  1020. package/icons/dnb/digipass_corporate_medium.js +17 -0
  1021. package/icons/dnb/digipass_corporate_medium.js.map +1 -0
  1022. package/icons/dnb/digipass_private.d.ts +3 -0
  1023. package/icons/dnb/digipass_private.js +17 -0
  1024. package/icons/dnb/digipass_private.js.map +1 -0
  1025. package/icons/dnb/digipass_private_medium.d.ts +3 -0
  1026. package/icons/dnb/digipass_private_medium.js +17 -0
  1027. package/icons/dnb/digipass_private_medium.js.map +1 -0
  1028. package/icons/dnb/envelope_open.d.ts +3 -0
  1029. package/icons/dnb/envelope_open.js +18 -0
  1030. package/icons/dnb/envelope_open.js.map +1 -0
  1031. package/icons/dnb/envelope_open_medium.d.ts +3 -0
  1032. package/icons/dnb/envelope_open_medium.js +18 -0
  1033. package/icons/dnb/envelope_open_medium.js.map +1 -0
  1034. package/icons/dnb/icons-meta.json +230 -20
  1035. package/icons/dnb/icons-svg.lock +1272 -1064
  1036. package/icons/dnb/index.d.ts +17 -1
  1037. package/icons/dnb/index.js +17 -1
  1038. package/icons/dnb/index.js.map +1 -1
  1039. package/icons/dnb/laptop.d.ts +3 -0
  1040. package/icons/dnb/laptop.js +18 -0
  1041. package/icons/dnb/laptop.js.map +1 -0
  1042. package/icons/dnb/laptop_medium.d.ts +3 -0
  1043. package/icons/dnb/laptop_medium.js +18 -0
  1044. package/icons/dnb/laptop_medium.js.map +1 -0
  1045. package/icons/dnb/mobile.d.ts +3 -0
  1046. package/icons/dnb/mobile.js +15 -0
  1047. package/icons/dnb/mobile.js.map +1 -0
  1048. package/icons/dnb/mobile_medium.d.ts +3 -0
  1049. package/icons/dnb/mobile_medium.js +15 -0
  1050. package/icons/dnb/mobile_medium.js.map +1 -0
  1051. package/icons/dnb/money_left.d.ts +3 -0
  1052. package/icons/dnb/money_left.js +17 -0
  1053. package/icons/dnb/money_left.js.map +1 -0
  1054. package/icons/dnb/money_left_medium.d.ts +3 -0
  1055. package/icons/dnb/money_left_medium.js +18 -0
  1056. package/icons/dnb/money_left_medium.js.map +1 -0
  1057. package/icons/dnb/scan.js +5 -2
  1058. package/icons/dnb/scan.js.map +1 -1
  1059. package/icons/dnb/scan_medium.js +8 -12
  1060. package/icons/dnb/scan_medium.js.map +1 -1
  1061. package/icons/dnb/secondary_icons.d.ts +9 -1
  1062. package/icons/dnb/secondary_icons.js +9 -1
  1063. package/icons/dnb/secondary_icons.js.map +1 -1
  1064. package/icons/dnb/secondary_icons_medium.d.ts +9 -1
  1065. package/icons/dnb/secondary_icons_medium.js +9 -1
  1066. package/icons/dnb/secondary_icons_medium.js.map +1 -1
  1067. package/icons/dnb/teenager.d.ts +3 -0
  1068. package/icons/dnb/teenager.js +18 -0
  1069. package/icons/dnb/teenager.js.map +1 -0
  1070. package/icons/dnb/teenager_medium.d.ts +3 -0
  1071. package/icons/dnb/teenager_medium.js +18 -0
  1072. package/icons/dnb/teenager_medium.js.map +1 -0
  1073. package/icons/envelope_open.d.ts +3 -0
  1074. package/icons/envelope_open.js +3 -0
  1075. package/icons/envelope_open.js.map +1 -0
  1076. package/icons/envelope_open_medium.d.ts +3 -0
  1077. package/icons/envelope_open_medium.js +3 -0
  1078. package/icons/envelope_open_medium.js.map +1 -0
  1079. package/icons/index.d.ts +17 -1
  1080. package/icons/index.js +17 -1
  1081. package/icons/index.js.map +1 -1
  1082. package/icons/laptop.d.ts +3 -0
  1083. package/icons/laptop.js +3 -0
  1084. package/icons/laptop.js.map +1 -0
  1085. package/icons/laptop_medium.d.ts +3 -0
  1086. package/icons/laptop_medium.js +3 -0
  1087. package/icons/laptop_medium.js.map +1 -0
  1088. package/icons/mobile.d.ts +3 -0
  1089. package/icons/mobile.js +3 -0
  1090. package/icons/mobile.js.map +1 -0
  1091. package/icons/mobile_medium.d.ts +3 -0
  1092. package/icons/mobile_medium.js +3 -0
  1093. package/icons/mobile_medium.js.map +1 -0
  1094. package/icons/money_left.d.ts +3 -0
  1095. package/icons/money_left.js +3 -0
  1096. package/icons/money_left.js.map +1 -0
  1097. package/icons/money_left_medium.d.ts +3 -0
  1098. package/icons/money_left_medium.js +3 -0
  1099. package/icons/money_left_medium.js.map +1 -0
  1100. package/icons/teenager.d.ts +3 -0
  1101. package/icons/teenager.js +3 -0
  1102. package/icons/teenager.js.map +1 -0
  1103. package/icons/teenager_medium.d.ts +3 -0
  1104. package/icons/teenager_medium.js +3 -0
  1105. package/icons/teenager_medium.js.map +1 -0
  1106. package/package.json +1 -1
  1107. package/shared/Eufemia.d.ts +1 -1
  1108. package/shared/Eufemia.js +2 -2
  1109. package/shared/Eufemia.js.map +1 -1
  1110. package/shared/component-helper.d.ts +1 -0
  1111. package/shared/component-helper.js +3 -0
  1112. package/shared/component-helper.js.map +1 -1
  1113. package/style/core/utilities.scss +1 -2
  1114. package/style/dnb-ui-components.css +304 -79
  1115. package/style/dnb-ui-components.min.css +3 -3
  1116. package/style/dnb-ui-extensions.css +244 -25
  1117. package/style/dnb-ui-extensions.min.css +1 -1
  1118. package/style/dnb-ui-forms.css +244 -25
  1119. package/style/dnb-ui-forms.min.css +1 -1
  1120. package/style/dnb-ui-forms.scss +1 -0
  1121. package/style/themes/theme-eiendom/eiendom-theme-basis.css +14 -2
  1122. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  1123. package/style/themes/theme-eiendom/eiendom-theme-components.css +636 -113
  1124. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +10 -6
  1125. package/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  1126. package/style/themes/theme-eiendom/eiendom-theme-elements.css +14 -2
  1127. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  1128. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +260 -25
  1129. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +5 -1
  1130. package/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  1131. package/style/themes/theme-eiendom/eiendom-theme-forms.css +260 -26
  1132. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +5 -1
  1133. package/style/themes/theme-eiendom/eiendom-theme-forms.scss +2 -0
  1134. package/style/themes/theme-sbanken/sbanken-theme-components.css +664 -107
  1135. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +8 -6
  1136. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  1137. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +319 -25
  1138. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +3 -1
  1139. package/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  1140. package/style/themes/theme-sbanken/sbanken-theme-forms.css +319 -26
  1141. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +3 -1
  1142. package/style/themes/theme-sbanken/sbanken-theme-forms.scss +2 -0
  1143. package/style/themes/theme-ui/ui-theme-basis.css +14 -2
  1144. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  1145. package/style/themes/theme-ui/ui-theme-components.css +634 -113
  1146. package/style/themes/theme-ui/ui-theme-components.min.css +10 -6
  1147. package/style/themes/theme-ui/ui-theme-components.scss +1 -0
  1148. package/style/themes/theme-ui/ui-theme-elements.css +14 -2
  1149. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  1150. package/style/themes/theme-ui/ui-theme-extensions.css +260 -25
  1151. package/style/themes/theme-ui/ui-theme-extensions.min.css +5 -1
  1152. package/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  1153. package/style/themes/theme-ui/ui-theme-forms.css +260 -26
  1154. package/style/themes/theme-ui/ui-theme-forms.min.css +5 -1
  1155. package/style/themes/theme-ui/ui-theme-forms.scss +2 -0
  1156. package/style/themes/theme-ui/ui-theme-tags.css +11 -13
  1157. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  1158. package/umd/dnb-ui-basis.min.js +1 -1
  1159. package/umd/dnb-ui-components.min.js +1 -1
  1160. package/umd/dnb-ui-elements.min.js +1 -1
  1161. package/umd/dnb-ui-extensions.min.js +3 -3
  1162. package/umd/dnb-ui-lib.min.js +1 -1
  1163. package/cjs/extensions/forms/Visibility/Visibility.js.map +0 -1
  1164. package/cjs/extensions/forms/Visibility/index.js.map +0 -1
  1165. package/cjs/icons/icons-meta.json +0 -3748
  1166. package/es/extensions/forms/Visibility/Visibility.js.map +0 -1
  1167. package/es/extensions/forms/Visibility/index.js.map +0 -1
  1168. package/es/icons/icons-meta.json +0 -3748
  1169. package/extensions/forms/Visibility/Visibility.js.map +0 -1
  1170. package/extensions/forms/Visibility/index.js.map +0 -1
  1171. package/icons/icons-meta.json +0 -3748
  1172. /package/cjs/extensions/forms/{Visibility → Form/Visibility}/index.d.ts +0 -0
  1173. /package/cjs/extensions/forms/{Visibility → Form/Visibility}/index.js +0 -0
  1174. /package/es/extensions/forms/{Visibility → Form/Visibility}/index.d.ts +0 -0
  1175. /package/es/extensions/forms/{Visibility → Form/Visibility}/index.js +0 -0
  1176. /package/extensions/forms/{Visibility → Form/Visibility}/index.d.ts +0 -0
  1177. /package/extensions/forms/{Visibility → Form/Visibility}/index.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"Textarea.js","names":["React","PropTypes","classnames","FormLabel","FormStatus","isTrue","makeUniqueId","extendPropsWithContextInClassComponent","validateDOMAttributes","processChildren","getStatusState","combineDescribedBy","warn","dispatchCustomElementEvent","pickFormElementProps","AlignmentHelper","spacingPropTypes","createSpacingClasses","skeletonDOMAttributes","createSkeletonClass","Context","Suffix","Textarea","PureComponent","getDerivedStateFromProps","props","state","value","getValue","_listenForPropChanges","_value","on_state_update","textarea_state","textareaState","hasValue","String","length","constructor","_defineProperty","event","_ref","current","setState","target","autoresize","prepareAutosize","rows","getRows","ret","setAutosize","elem","style","height","e","_heightOffset","offsetHeight","clientHeight","lineHeight","getLineHeight","newHeight","scrollHeight","maxRows","parseFloat","autoresize_max_rows","maxHeight","createRef","_id","id","componentDidMount","inner_ref","window","resizeObserver","ResizeObserver","observe","document","body","addEventListener","componentWillUnmount","disconnect","removeEventListener","Math","floor","getComputedStyle","render","_this$context","_this$context2","_this$context3","defaultProps","skeleton","context","getTranslation","FormRow","formElement","label","label_direction","label_sr_only","status","status_state","status_props","status_no_animation","globalStatus","suffix","disabled","stretch","placeholder","align","textarea_class","readOnly","textarea_attributes","class","_className","className","children","textarea_element","_textarea_element","attributes","_objectWithoutProperties","_excluded","showStatus","TextareaElement","textareaAttributes","JSON","parse","textareaParams","_objectSpread","role","name","onChange","onChangeHandler","onFocus","onFocusHandler","onBlur","onBlurHandler","onKeyDown","onKeyDownHandler","mainParams","innerParams","shellParams","placeholderStyle","createElement","for_id","text","sr_only","_AlignmentHelper","_extends","show","text_id","no_animation","ref","_span","cols","on_change","on_focus","on_blur","on_key_down","process","env","NODE_ENV","propTypes","string","oneOfType","func","node","oneOf","bool","object","shape","message","number","_formElement","_supportsSpacingProps"],"sources":["../../../../src/components/textarea/Textarea.js"],"sourcesContent":["/**\n * Web Textarea Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport FormLabel from '../form-label/FormLabel'\nimport FormStatus from '../form-status/FormStatus'\nimport {\n isTrue,\n makeUniqueId,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n processChildren,\n getStatusState,\n combineDescribedBy,\n warn,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\nimport {\n skeletonDOMAttributes,\n createSkeletonClass,\n} from '../skeleton/SkeletonHelper'\n\nimport Context from '../../shared/Context'\nimport Suffix from '../../shared/helpers/Suffix'\n\n/**\n * The textarea component is an umbrella component for all textareas which share the same style as the classic `text` textarea field.\n */\nexport default class Textarea extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n value: PropTypes.string,\n id: PropTypes.string,\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 status: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n PropTypes.func,\n PropTypes.node,\n ]),\n textarea_state: PropTypes.string,\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 placeholder: PropTypes.string,\n align: PropTypes.oneOf(['left', 'right']),\n stretch: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n autoresize: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n autoresize_max_rows: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number,\n ]),\n class: PropTypes.string,\n textarea_class: PropTypes.string,\n textarea_attributes: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n ]),\n readOnly: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n rows: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n cols: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n inner_ref: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n\n ...spacingPropTypes,\n\n className: PropTypes.string,\n textarea_element: PropTypes.oneOfType([\n PropTypes.func,\n PropTypes.node,\n ]),\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),\n\n on_change: PropTypes.func,\n on_focus: PropTypes.func,\n on_blur: PropTypes.func,\n on_key_down: PropTypes.func,\n on_state_update: PropTypes.func,\n }\n\n static defaultProps = {\n value: 'initval',\n id: null,\n label: null,\n label_direction: null,\n label_sr_only: null,\n status: null,\n textarea_state: null,\n status_state: 'error',\n status_props: null,\n status_no_animation: null,\n globalStatus: null,\n suffix: null,\n placeholder: null,\n align: null,\n stretch: null,\n disabled: null,\n skeleton: null,\n autoresize: null,\n autoresize_max_rows: null,\n textarea_class: null,\n class: null,\n textarea_attributes: null,\n readOnly: false,\n rows: null,\n cols: null,\n inner_ref: null,\n\n className: null,\n textarea_element: null,\n children: null,\n\n on_change: null,\n on_focus: null,\n on_blur: null,\n on_key_down: null,\n on_state_update: null,\n }\n\n static getDerivedStateFromProps(props, state) {\n const value = Textarea.getValue(props)\n if (\n state._listenForPropChanges &&\n value !== 'initval' &&\n value !== state.value\n ) {\n if (\n value !== state.value &&\n value !== state._value &&\n typeof props.on_state_update === 'function'\n ) {\n dispatchCustomElementEvent({ props }, 'on_state_update', { value })\n }\n state.value = value\n }\n if (props.textarea_state) {\n state.textareaState = props.textarea_state\n }\n state._listenForPropChanges = true\n return state\n }\n\n static hasValue(value) {\n return (\n ((typeof value === 'string' || typeof value === 'number') &&\n String(value).length > 0) ||\n false\n )\n }\n\n static getValue(props) {\n const value = processChildren(props)\n if (value === '' || Textarea.hasValue(value)) {\n return value\n }\n return props.value\n }\n\n state = {\n textareaState: 'virgin',\n value: null,\n _value: null,\n }\n\n constructor(props) {\n super(props)\n\n this._ref = React.createRef()\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n\n // make sure we don't trigger getDerivedStateFromProps on startup\n this.state._listenForPropChanges = true\n if (props.textarea_state) {\n this.state.textareaState = props.textarea_state\n }\n this.state._value = props.value\n }\n componentDidMount() {\n if (this.props.inner_ref) {\n typeof this.props.inner_ref === 'function'\n ? this.props.inner_ref(this._ref.current)\n : (this.props.inner_ref.current = this._ref.current)\n }\n\n if (isTrue(this.props.autoresize) && typeof window !== 'undefined') {\n this.setAutosize()\n try {\n this.resizeObserver = new ResizeObserver(this.setAutosize)\n this.resizeObserver.observe(document.body)\n } catch (e) {\n window.addEventListener('resize', this.setAutosize)\n }\n }\n }\n componentWillUnmount() {\n if (this.resizeObserver) {\n this.resizeObserver.disconnect()\n this.resizeObserver = null\n }\n if (typeof window !== 'undefined') {\n window.removeEventListener('resize', this.setAutosize)\n }\n }\n onFocusHandler = (event) => {\n const { value } = this._ref.current\n this.setState({\n value,\n _listenForPropChanges: false,\n textareaState: 'focus',\n })\n dispatchCustomElementEvent(this, 'on_focus', { value, event })\n }\n onBlurHandler = (event) => {\n const { value } = event.target\n this.setState({\n value,\n _listenForPropChanges: false,\n textareaState: Textarea.hasValue(value) ? 'dirty' : 'initial',\n })\n dispatchCustomElementEvent(this, 'on_blur', { value, event })\n }\n onChangeHandler = (event) => {\n const { value } = event.target\n\n if (isTrue(this.props.autoresize)) {\n this.prepareAutosize()\n }\n\n const rows = this.getRows(value)\n\n const ret = dispatchCustomElementEvent(this, 'on_change', {\n value,\n rows,\n event,\n })\n if (ret !== false) {\n this.setState({ value, _listenForPropChanges: false })\n if (isTrue(this.props.autoresize)) {\n this.setAutosize(rows)\n }\n }\n }\n onKeyDownHandler = (event) => {\n const rows = this.getRows()\n const { value } = event.target\n dispatchCustomElementEvent(this, 'on_key_down', {\n value,\n rows,\n event,\n })\n }\n prepareAutosize = () => {\n const elem = this._ref.current\n if (!elem) {\n return // stop here if no element was gotten\n }\n try {\n elem.style.height = 'auto'\n } catch (e) {\n warn(e)\n }\n }\n setAutosize = (rows = null) => {\n const elem = this._ref.current\n if (!elem) {\n return // stop here if no element was gotten\n }\n try {\n if (typeof this._heightOffset === 'undefined') {\n this._heightOffset = elem.offsetHeight - elem.clientHeight\n }\n\n elem.style.height = 'auto'\n\n // get rows after we set height to auto, this way we get 100% correct rows\n const lineHeight = this.getLineHeight()\n let newHeight = elem.scrollHeight + this._heightOffset\n if (!rows) {\n rows = this.getRows()\n }\n\n if (rows === 1) {\n if (newHeight > lineHeight) {\n newHeight = lineHeight\n }\n }\n\n const maxRows = parseFloat(this.props.autoresize_max_rows)\n if (maxRows > 0) {\n const maxHeight = maxRows * lineHeight\n\n if (rows > maxRows || newHeight > maxHeight) {\n newHeight = maxHeight\n }\n }\n\n elem.style.height = newHeight + 'px'\n } catch (e) {\n warn(e)\n }\n }\n getRows() {\n return (\n Math.floor(this._ref.current.scrollHeight / this.getLineHeight()) ||\n 1\n )\n }\n getLineHeight() {\n return parseFloat(getComputedStyle(this._ref.current).lineHeight) || 0\n }\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n Textarea.defaultProps,\n { skeleton: this.context?.skeleton },\n this.context.getTranslation(this.props).Textarea,\n // Deprecated – can be removed in v11\n pickFormElementProps(this.context?.FormRow),\n pickFormElementProps(this.context?.formElement),\n this.context.Textarea\n )\n\n const {\n label,\n label_direction,\n label_sr_only,\n status,\n status_state,\n status_props,\n status_no_animation,\n globalStatus,\n suffix,\n disabled,\n skeleton,\n stretch,\n placeholder,\n align,\n textarea_class,\n readOnly,\n textarea_attributes,\n class: _className,\n className,\n\n autoresize,\n autoresize_max_rows, //eslint-disable-line\n id: _id, //eslint-disable-line\n children, //eslint-disable-line\n value: _value, //eslint-disable-line\n textarea_element: _textarea_element, //eslint-disable-line\n\n ...attributes\n } = props\n\n const { value, textareaState } = this.state\n\n const id = this._id\n const showStatus = getStatusState(status)\n const hasValue = Textarea.hasValue(value)\n\n // pass along all props we wish to have as params\n let { textarea_element: TextareaElement } = props\n\n const textareaAttributes = textarea_attributes\n ? typeof textarea_attributes === 'string'\n ? JSON.parse(textarea_attributes)\n : textarea_attributes\n : {}\n\n const textareaParams = {\n className: classnames('dnb-textarea__textarea', textarea_class),\n role: 'textbox',\n value: hasValue ? value : '',\n id,\n disabled: isTrue(disabled) || isTrue(skeleton),\n name: id,\n 'aria-placeholder': placeholder,\n ...attributes,\n ...textareaAttributes,\n onChange: this.onChangeHandler,\n onFocus: this.onFocusHandler,\n onBlur: this.onBlurHandler,\n // onPaste: this.onChangeHandler,\n onKeyDown: this.onKeyDownHandler,\n }\n\n // we may consider using: aria-details\n if (showStatus || suffix) {\n textareaParams['aria-describedby'] = combineDescribedBy(\n textareaParams,\n showStatus ? id + '-status' : null,\n suffix ? id + '-suffix' : null\n )\n }\n if (readOnly) {\n textareaParams['aria-readonly'] = textareaParams.readOnly = true\n }\n\n const mainParams = {\n className: classnames(\n 'dnb-textarea',\n `dnb-textarea--${textareaState}`,\n hasValue && 'dnb-textarea--has-content',\n align && `dnb-textarea__align--${align}`,\n status && `dnb-textarea__status--${status_state}`,\n autoresize && 'dnb-textarea__autoresize',\n label_direction && `dnb-textarea--${label_direction}`,\n isTrue(stretch) && `dnb-textarea--stretch`,\n 'dnb-form-component',\n createSkeletonClass(null, skeleton),\n createSpacingClasses(props),\n _className,\n className\n ),\n }\n\n const innerParams = {\n className: classnames(\n 'dnb-textarea__inner',\n createSkeletonClass('shape', skeleton, this.context)\n ),\n }\n\n const shellParams = {\n className: classnames('dnb-textarea__shell'),\n }\n\n if (isTrue(disabled) || isTrue(skeleton)) {\n shellParams['aria-disabled'] = true\n }\n\n // to show the ending dots on a placeholder, if the text is longer\n const placeholderStyle =\n parseFloat(this.props.rows) > 0\n ? {\n '--textarea-rows': parseFloat(this.props.rows),\n // '--textarea-cols': parseFloat(this.props.cols)\n }\n : null\n\n skeletonDOMAttributes(innerParams, skeleton, this.context)\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, textareaParams)\n validateDOMAttributes(null, innerParams)\n validateDOMAttributes(null, shellParams)\n\n if (TextareaElement && typeof TextareaElement === 'function') {\n TextareaElement = TextareaElement(textareaParams, this._ref)\n } else if (!TextareaElement && _textarea_element) {\n TextareaElement = _textarea_element\n }\n\n return (\n <span {...mainParams}>\n {label && (\n <FormLabel\n id={id + '-label'}\n for_id={id}\n text={label}\n label_direction={label_direction}\n sr_only={label_sr_only}\n disabled={disabled}\n skeleton={skeleton}\n />\n )}\n\n <span {...innerParams}>\n <AlignmentHelper />\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-textarea__row\">\n <span {...shellParams}>\n {TextareaElement || (\n <textarea ref={this._ref} {...textareaParams} />\n )}\n\n {placeholder && (\n <span\n aria-hidden\n className={classnames(\n 'dnb-textarea__placeholder',\n align ? `dnb-textarea__align--${align}` : null\n )}\n style={placeholderStyle}\n >\n {placeholder}\n </span>\n )}\n\n <span className=\"dnb-textarea__state\" />\n </span>\n\n {suffix && (\n <Suffix\n className=\"dnb-textarea__suffix\"\n id={id + '-suffix'} // used for \"aria-describedby\"\n context={props}\n >\n {suffix}\n </Suffix>\n )}\n </span>\n </span>\n </span>\n )\n }\n}\n\nTextarea._formElement = true\nTextarea._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"Textarea.js","names":["React","PropTypes","classnames","FormLabel","FormStatus","isTrue","makeUniqueId","extendPropsWithContextInClassComponent","validateDOMAttributes","processChildren","getStatusState","combineDescribedBy","warn","dispatchCustomElementEvent","pickFormElementProps","AlignmentHelper","spacingPropTypes","createSpacingClasses","skeletonDOMAttributes","createSkeletonClass","Context","Suffix","Textarea","PureComponent","getDerivedStateFromProps","props","state","value","getValue","_value","on_state_update","textarea_state","textareaState","hasValue","String","length","constructor","_defineProperty","event","_ref","current","setState","target","autoresize","prepareAutosize","rows","getRows","ret","setAutosize","elem","style","height","e","_heightOffset","offsetHeight","clientHeight","lineHeight","getLineHeight","newHeight","scrollHeight","maxRows","parseFloat","autoresize_max_rows","maxHeight","createRef","_id","id","componentDidMount","inner_ref","window","resizeObserver","ResizeObserver","observe","document","body","addEventListener","componentWillUnmount","disconnect","removeEventListener","Math","floor","getComputedStyle","render","_this$context","_this$context2","_this$context3","defaultProps","skeleton","context","getTranslation","FormRow","formElement","label","label_direction","label_sr_only","status","status_state","status_props","status_no_animation","globalStatus","suffix","disabled","stretch","placeholder","align","textarea_class","readOnly","textarea_attributes","class","_className","className","children","textarea_element","_textarea_element","attributes","_objectWithoutProperties","_excluded","showStatus","TextareaElement","textareaAttributes","JSON","parse","textareaParams","_objectSpread","role","name","onChange","onChangeHandler","onFocus","onFocusHandler","onBlur","onBlurHandler","onKeyDown","onKeyDownHandler","mainParams","innerParams","shellParams","placeholderStyle","createElement","for_id","text","sr_only","_AlignmentHelper","_extends","show","text_id","no_animation","ref","_span","cols","on_change","on_focus","on_blur","on_key_down","process","env","NODE_ENV","propTypes","string","oneOfType","func","node","oneOf","bool","object","shape","message","number","_formElement","_supportsSpacingProps"],"sources":["../../../../src/components/textarea/Textarea.js"],"sourcesContent":["/**\n * Web Textarea Component\n *\n */\n\nimport React from 'react'\nimport PropTypes from 'prop-types'\nimport classnames from 'classnames'\nimport FormLabel from '../form-label/FormLabel'\nimport FormStatus from '../form-status/FormStatus'\nimport {\n isTrue,\n makeUniqueId,\n extendPropsWithContextInClassComponent,\n validateDOMAttributes,\n processChildren,\n getStatusState,\n combineDescribedBy,\n warn,\n dispatchCustomElementEvent,\n} from '../../shared/component-helper'\nimport { pickFormElementProps } from '../../shared/helpers/filterValidProps'\nimport AlignmentHelper from '../../shared/AlignmentHelper'\nimport {\n spacingPropTypes,\n createSpacingClasses,\n} from '../space/SpacingHelper'\nimport {\n skeletonDOMAttributes,\n createSkeletonClass,\n} from '../skeleton/SkeletonHelper'\n\nimport Context from '../../shared/Context'\nimport Suffix from '../../shared/helpers/Suffix'\n\n/**\n * The textarea component is an umbrella component for all textareas which share the same style as the classic `text` textarea field.\n */\nexport default class Textarea extends React.PureComponent {\n static contextType = Context\n\n static propTypes = {\n value: PropTypes.string,\n id: PropTypes.string,\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 status: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.bool,\n PropTypes.func,\n PropTypes.node,\n ]),\n textarea_state: PropTypes.string,\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 placeholder: PropTypes.string,\n align: PropTypes.oneOf(['left', 'right']),\n stretch: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n disabled: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n skeleton: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n autoresize: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n autoresize_max_rows: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number,\n ]),\n class: PropTypes.string,\n textarea_class: PropTypes.string,\n textarea_attributes: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n ]),\n readOnly: PropTypes.oneOfType([PropTypes.string, PropTypes.bool]),\n rows: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n cols: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n inner_ref: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n\n ...spacingPropTypes,\n\n className: PropTypes.string,\n textarea_element: PropTypes.oneOfType([\n PropTypes.func,\n PropTypes.node,\n ]),\n children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),\n\n on_change: PropTypes.func,\n on_focus: PropTypes.func,\n on_blur: PropTypes.func,\n on_key_down: PropTypes.func,\n on_state_update: PropTypes.func,\n }\n\n static defaultProps = {\n value: 'initval',\n id: null,\n label: null,\n label_direction: null,\n label_sr_only: null,\n status: null,\n textarea_state: null,\n status_state: 'error',\n status_props: null,\n status_no_animation: null,\n globalStatus: null,\n suffix: null,\n placeholder: null,\n align: null,\n stretch: null,\n disabled: null,\n skeleton: null,\n autoresize: null,\n autoresize_max_rows: null,\n textarea_class: null,\n class: null,\n textarea_attributes: null,\n readOnly: false,\n rows: null,\n cols: null,\n inner_ref: null,\n\n className: null,\n textarea_element: null,\n children: null,\n\n on_change: null,\n on_focus: null,\n on_blur: null,\n on_key_down: null,\n on_state_update: null,\n }\n\n static getDerivedStateFromProps(props, state) {\n const value = Textarea.getValue(props)\n if (\n value !== 'initval' &&\n value !== state.value &&\n value !== state._value\n ) {\n if (\n value !== state.value &&\n typeof props.on_state_update === 'function'\n ) {\n dispatchCustomElementEvent({ props }, 'on_state_update', { value })\n }\n state.value = value\n }\n if (props.textarea_state) {\n state.textareaState = props.textarea_state\n }\n state._value = props.value\n return state\n }\n\n static hasValue(value) {\n return (\n ((typeof value === 'string' || typeof value === 'number') &&\n String(value).length > 0) ||\n false\n )\n }\n\n static getValue(props) {\n const value = processChildren(props)\n if (value === '' || Textarea.hasValue(value)) {\n return value\n }\n return props.value\n }\n\n state = {\n textareaState: 'virgin',\n value: null,\n _value: null,\n }\n\n constructor(props) {\n super(props)\n\n this._ref = React.createRef()\n this._id = props.id || makeUniqueId() // cause we need an id anyway\n\n if (props.textarea_state) {\n this.state.textareaState = props.textarea_state\n }\n }\n componentDidMount() {\n if (this.props.inner_ref) {\n typeof this.props.inner_ref === 'function'\n ? this.props.inner_ref(this._ref.current)\n : (this.props.inner_ref.current = this._ref.current)\n }\n\n if (isTrue(this.props.autoresize) && typeof window !== 'undefined') {\n this.setAutosize()\n try {\n this.resizeObserver = new ResizeObserver(this.setAutosize)\n this.resizeObserver.observe(document.body)\n } catch (e) {\n window.addEventListener('resize', this.setAutosize)\n }\n }\n }\n componentWillUnmount() {\n if (this.resizeObserver) {\n this.resizeObserver.disconnect()\n this.resizeObserver = null\n }\n if (typeof window !== 'undefined') {\n window.removeEventListener('resize', this.setAutosize)\n }\n }\n onFocusHandler = (event) => {\n const { value } = this._ref.current\n this.setState({\n value,\n\n textareaState: 'focus',\n })\n dispatchCustomElementEvent(this, 'on_focus', { value, event })\n }\n onBlurHandler = (event) => {\n const { value } = event.target\n this.setState({\n value,\n\n textareaState: Textarea.hasValue(value) ? 'dirty' : 'initial',\n })\n dispatchCustomElementEvent(this, 'on_blur', { value, event })\n }\n onChangeHandler = (event) => {\n const { value } = event.target\n\n if (isTrue(this.props.autoresize)) {\n this.prepareAutosize()\n }\n\n const rows = this.getRows(value)\n\n const ret = dispatchCustomElementEvent(this, 'on_change', {\n value,\n rows,\n event,\n })\n if (ret !== false) {\n this.setState({ value })\n if (isTrue(this.props.autoresize)) {\n this.setAutosize(rows)\n }\n }\n }\n onKeyDownHandler = (event) => {\n const rows = this.getRows()\n const { value } = event.target\n dispatchCustomElementEvent(this, 'on_key_down', {\n value,\n rows,\n event,\n })\n }\n prepareAutosize = () => {\n const elem = this._ref.current\n if (!elem) {\n return // stop here if no element was gotten\n }\n try {\n elem.style.height = 'auto'\n } catch (e) {\n warn(e)\n }\n }\n setAutosize = (rows = null) => {\n const elem = this._ref.current\n if (!elem) {\n return // stop here if no element was gotten\n }\n try {\n if (typeof this._heightOffset === 'undefined') {\n this._heightOffset = elem.offsetHeight - elem.clientHeight\n }\n\n elem.style.height = 'auto'\n\n // get rows after we set height to auto, this way we get 100% correct rows\n const lineHeight = this.getLineHeight()\n let newHeight = elem.scrollHeight + this._heightOffset\n if (!rows) {\n rows = this.getRows()\n }\n\n if (rows === 1) {\n if (newHeight > lineHeight) {\n newHeight = lineHeight\n }\n }\n\n const maxRows = parseFloat(this.props.autoresize_max_rows)\n if (maxRows > 0) {\n const maxHeight = maxRows * lineHeight\n\n if (rows > maxRows || newHeight > maxHeight) {\n newHeight = maxHeight\n }\n }\n\n elem.style.height = newHeight + 'px'\n } catch (e) {\n warn(e)\n }\n }\n getRows() {\n return (\n Math.floor(this._ref.current.scrollHeight / this.getLineHeight()) ||\n 1\n )\n }\n getLineHeight() {\n return parseFloat(getComputedStyle(this._ref.current).lineHeight) || 0\n }\n render() {\n // use only the props from context, who are available here anyway\n const props = extendPropsWithContextInClassComponent(\n this.props,\n Textarea.defaultProps,\n { skeleton: this.context?.skeleton },\n this.context.getTranslation(this.props).Textarea,\n // Deprecated – can be removed in v11\n pickFormElementProps(this.context?.FormRow),\n pickFormElementProps(this.context?.formElement),\n this.context.Textarea\n )\n\n const {\n label,\n label_direction,\n label_sr_only,\n status,\n status_state,\n status_props,\n status_no_animation,\n globalStatus,\n suffix,\n disabled,\n skeleton,\n stretch,\n placeholder,\n align,\n textarea_class,\n readOnly,\n textarea_attributes,\n class: _className,\n className,\n\n autoresize,\n autoresize_max_rows, //eslint-disable-line\n id: _id, //eslint-disable-line\n children, //eslint-disable-line\n value: _value, //eslint-disable-line\n textarea_element: _textarea_element, //eslint-disable-line\n\n ...attributes\n } = props\n\n const { value, textareaState } = this.state\n\n const id = this._id\n const showStatus = getStatusState(status)\n const hasValue = Textarea.hasValue(value)\n\n // pass along all props we wish to have as params\n let { textarea_element: TextareaElement } = props\n\n const textareaAttributes = textarea_attributes\n ? typeof textarea_attributes === 'string'\n ? JSON.parse(textarea_attributes)\n : textarea_attributes\n : {}\n\n const textareaParams = {\n className: classnames('dnb-textarea__textarea', textarea_class),\n role: 'textbox',\n value: hasValue ? value : '',\n id,\n disabled: isTrue(disabled) || isTrue(skeleton),\n name: id,\n 'aria-placeholder': placeholder,\n ...attributes,\n ...textareaAttributes,\n onChange: this.onChangeHandler,\n onFocus: this.onFocusHandler,\n onBlur: this.onBlurHandler,\n // onPaste: this.onChangeHandler,\n onKeyDown: this.onKeyDownHandler,\n }\n\n // we may consider using: aria-details\n if (showStatus || suffix) {\n textareaParams['aria-describedby'] = combineDescribedBy(\n textareaParams,\n showStatus ? id + '-status' : null,\n suffix ? id + '-suffix' : null\n )\n }\n if (readOnly) {\n textareaParams['aria-readonly'] = textareaParams.readOnly = true\n }\n\n const mainParams = {\n className: classnames(\n 'dnb-textarea',\n `dnb-textarea--${textareaState}`,\n hasValue && 'dnb-textarea--has-content',\n align && `dnb-textarea__align--${align}`,\n status && `dnb-textarea__status--${status_state}`,\n autoresize && 'dnb-textarea__autoresize',\n label_direction && `dnb-textarea--${label_direction}`,\n isTrue(stretch) && `dnb-textarea--stretch`,\n 'dnb-form-component',\n createSkeletonClass(null, skeleton),\n createSpacingClasses(props),\n _className,\n className\n ),\n }\n\n const innerParams = {\n className: classnames(\n 'dnb-textarea__inner',\n createSkeletonClass('shape', skeleton, this.context)\n ),\n }\n\n const shellParams = {\n className: classnames('dnb-textarea__shell'),\n }\n\n if (isTrue(disabled) || isTrue(skeleton)) {\n shellParams['aria-disabled'] = true\n }\n\n // to show the ending dots on a placeholder, if the text is longer\n const placeholderStyle =\n parseFloat(this.props.rows) > 0\n ? {\n '--textarea-rows': parseFloat(this.props.rows),\n // '--textarea-cols': parseFloat(this.props.cols)\n }\n : null\n\n skeletonDOMAttributes(innerParams, skeleton, this.context)\n\n // also used for code markup simulation\n validateDOMAttributes(this.props, textareaParams)\n validateDOMAttributes(null, innerParams)\n validateDOMAttributes(null, shellParams)\n\n if (TextareaElement && typeof TextareaElement === 'function') {\n TextareaElement = TextareaElement(textareaParams, this._ref)\n } else if (!TextareaElement && _textarea_element) {\n TextareaElement = _textarea_element\n }\n\n return (\n <span {...mainParams}>\n {label && (\n <FormLabel\n id={id + '-label'}\n for_id={id}\n text={label}\n label_direction={label_direction}\n sr_only={label_sr_only}\n disabled={disabled}\n skeleton={skeleton}\n />\n )}\n\n <span {...innerParams}>\n <AlignmentHelper />\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-textarea__row\">\n <span {...shellParams}>\n {TextareaElement || (\n <textarea ref={this._ref} {...textareaParams} />\n )}\n\n {placeholder && (\n <span\n aria-hidden\n className={classnames(\n 'dnb-textarea__placeholder',\n align ? `dnb-textarea__align--${align}` : null\n )}\n style={placeholderStyle}\n >\n {placeholder}\n </span>\n )}\n\n <span className=\"dnb-textarea__state\" />\n </span>\n\n {suffix && (\n <Suffix\n className=\"dnb-textarea__suffix\"\n id={id + '-suffix'} // used for \"aria-describedby\"\n context={props}\n >\n {suffix}\n </Suffix>\n )}\n </span>\n </span>\n </span>\n )\n }\n}\n\nTextarea._formElement = true\nTextarea._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -78,6 +78,11 @@ html:not([data-visual-test]) .dnb-textarea__textarea {
78
78
  background-color: var(--scrollbar-thumb-hover-color, #666);
79
79
  }
80
80
  }
81
+ @-moz-document url-prefix() {
82
+ .dnb-textarea__textarea {
83
+ overflow-x: clip;
84
+ }
85
+ }
81
86
  .dnb-textarea__input:-webkit-autofill {
82
87
  box-shadow: 0 0 0 var(--border-width) var(--border-color), 0 0 0 10em var(--textarea-background-color) inset;
83
88
  }
@@ -1 +1 @@
1
- .dnb-textarea{--textarea-padding-width:0.5rem;--textarea-rows:2;--textarea-background-color:var(--color-white);display:inline-flex;font-size:var(--font-size-small);line-height:var(--line-height-basis)}.dnb-textarea__inner{display:inline-flex;flex-direction:column;margin:var(--textarea-padding-width)}.dnb-textarea__shell{display:inline-flex;font-size:var(--font-size-basis);position:relative}.dnb-textarea__state{background-color:var(--color-white);border-radius:.25rem;bottom:-.5rem;box-shadow:0 0 0 .0625rem var(--color-sea-green);left:-.5rem;position:absolute;right:-.5rem;top:-.5rem;z-index:1}.dnb-textarea__row{display:inline-flex}.dnb-textarea__suffix.dnb-suffix{padding-left:1rem}.dnb-textarea__textarea{-webkit-overflow-scrolling:touch;-ms-overflow-style:auto;border:none;cursor:auto;font-size:var(--font-size-basis);line-height:var(--line-height-basis);margin:0;outline:none;overflow-y:auto;overscroll-behavior:contain;padding:0 var(--textarea-padding-width);position:relative;scrollbar-color:var(--scrollbar-thumb-color,#888) transparent;z-index:2}html:not([data-visual-test]) .dnb-textarea__textarea{scroll-behavior:smooth}@supports not (scrollbar-color:auto){.dnb-textarea__textarea::-webkit-scrollbar{background-color:var(--scrollbar-track-color,#eee);border-radius:var(--scrollbar-thumb-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar:vertical{width:var(--scrollbar-track-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar:horizontal{height:var(--scrollbar-track-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb-color,#888);border-radius:var(--scrollbar-thumb-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover-color,#666)}}.dnb-textarea__input:-webkit-autofill{box-shadow:0 0 0 var(--border-width) var(--border-color),0 0 0 10em var(--textarea-background-color) inset}.dnb-textarea__input:autofill{box-shadow:0 0 0 var(--border-width) var(--border-color),0 0 0 10em var(--textarea-background-color) inset}.dnb-textarea__placeholder{-webkit-box-orient:vertical;-webkit-line-clamp:var(--textarea-rows,2);border:none;cursor:auto;display:-webkit-box;font-size:var(--font-size-basis);height:100%;left:0;line-height:var(--line-height-basis);margin:0;outline:none;overflow:hidden;padding:0 var(--textarea-padding-width);pointer-events:none;position:absolute;top:0;width:100%;z-index:3}.dnb-textarea__placeholder,.dnb-textarea__textarea{text-align:left}.dnb-textarea__align--right .dnb-textarea__placeholder,.dnb-textarea__align--right .dnb-textarea__textarea{text-align:right}.dnb-textarea__autoresize .dnb-textarea__textarea{resize:none}.dnb-textarea--disabled .dnb-textarea__textarea,.dnb-textarea__textarea[disabled]{-webkit-user-select:none;user-select:none}.dnb-textarea--disabled .dnb-textarea__textarea::-webkit-scrollbar,.dnb-textarea__textarea[disabled]::-webkit-scrollbar{width:0}.dnb-textarea--focus .dnb-textarea__textarea:not([disabled]):not([readonly])~.dnb-textarea__placeholder,.dnb-textarea--has-content .dnb-textarea__textarea~.dnb-textarea__placeholder{display:none}.dnb-textarea__inner>.dnb-form-status{margin:1rem 0 0 calc(0px - var(--textarea-padding-width));order:2}.dnb-textarea:not(.dnb-textarea--vertical) .dnb-form-label{margin-top:.5rem}.dnb-textarea--vertical{align-items:flex-start;display:flex;flex-direction:column}.dnb-textarea:not(.dnb-textarea--vertical)[class*=__status]{align-items:flex-start}.dnb-textarea:not(.dnb-textarea--vertical)[class*=__status]>.dnb-form-label{margin-top:.25rem}@media screen and (max-width:40em){.dnb-textarea{flex-wrap:wrap}.dnb-textarea>.dnb-form-label{margin-bottom:.5rem;margin-top:.5rem}}.dnb-textarea--stretch{display:flex;flex-grow:1}.dnb-textarea--stretch .dnb-textarea__inner{flex-grow:1}.dnb-textarea--stretch .dnb-textarea__inner,.dnb-textarea--stretch .dnb-textarea__shell,.dnb-textarea--stretch .dnb-textarea__textarea{width:100%}.dnb-textarea--stretch .dnb-form-label+.dnb-textarea__inner{width:auto}.dnb-form-row--horizontal .dnb-textarea--stretch,.dnb-textarea--vertical.dnb-textarea--stretch .dnb-textarea__inner{width:100%}@media screen and (max-width:40em){.dnb-responsive-component .dnb-textarea{align-items:flex-start;display:flex;flex-direction:column;margin-bottom:.5rem}.dnb-responsive-component .dnb-textarea>.dnb-form-label{margin-bottom:.5rem}}html[data-visual-test] .dnb-textarea__textarea{caret-color:var(--color-white)}.dnb-textarea.dnb-skeleton .dnb-textarea__inner{border-radius:.25rem;margin:0}.dnb-textarea.dnb-skeleton .dnb-textarea__inner .dnb-textarea__shell{margin:var(--textarea-padding-width)}.dnb-textarea.dnb-skeleton .dnb-textarea__state,.dnb-textarea.dnb-skeleton .dnb-textarea__textarea{visibility:hidden}
1
+ .dnb-textarea{--textarea-padding-width:0.5rem;--textarea-rows:2;--textarea-background-color:var(--color-white);display:inline-flex;font-size:var(--font-size-small);line-height:var(--line-height-basis)}.dnb-textarea__inner{display:inline-flex;flex-direction:column;margin:var(--textarea-padding-width)}.dnb-textarea__shell{display:inline-flex;font-size:var(--font-size-basis);position:relative}.dnb-textarea__state{background-color:var(--color-white);border-radius:.25rem;bottom:-.5rem;box-shadow:0 0 0 .0625rem var(--color-sea-green);left:-.5rem;position:absolute;right:-.5rem;top:-.5rem;z-index:1}.dnb-textarea__row{display:inline-flex}.dnb-textarea__suffix.dnb-suffix{padding-left:1rem}.dnb-textarea__textarea{-webkit-overflow-scrolling:touch;-ms-overflow-style:auto;border:none;cursor:auto;font-size:var(--font-size-basis);line-height:var(--line-height-basis);margin:0;outline:none;overflow-y:auto;overscroll-behavior:contain;padding:0 var(--textarea-padding-width);position:relative;scrollbar-color:var(--scrollbar-thumb-color,#888) transparent;z-index:2}html:not([data-visual-test]) .dnb-textarea__textarea{scroll-behavior:smooth}@supports not (scrollbar-color:auto){.dnb-textarea__textarea::-webkit-scrollbar{background-color:var(--scrollbar-track-color,#eee);border-radius:var(--scrollbar-thumb-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar:vertical{width:var(--scrollbar-track-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar:horizontal{height:var(--scrollbar-track-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar-thumb{background-color:var(--scrollbar-thumb-color,#888);border-radius:var(--scrollbar-thumb-width,.5rem)}.dnb-textarea__textarea::-webkit-scrollbar-thumb:hover{background-color:var(--scrollbar-thumb-hover-color,#666)}}@-moz-document url-prefix(){.dnb-textarea__textarea{overflow-x:clip}}.dnb-textarea__input:-webkit-autofill{box-shadow:0 0 0 var(--border-width) var(--border-color),0 0 0 10em var(--textarea-background-color) inset}.dnb-textarea__input:autofill{box-shadow:0 0 0 var(--border-width) var(--border-color),0 0 0 10em var(--textarea-background-color) inset}.dnb-textarea__placeholder{-webkit-box-orient:vertical;-webkit-line-clamp:var(--textarea-rows,2);border:none;cursor:auto;display:-webkit-box;font-size:var(--font-size-basis);height:100%;left:0;line-height:var(--line-height-basis);margin:0;outline:none;overflow:hidden;padding:0 var(--textarea-padding-width);pointer-events:none;position:absolute;top:0;width:100%;z-index:3}.dnb-textarea__placeholder,.dnb-textarea__textarea{text-align:left}.dnb-textarea__align--right .dnb-textarea__placeholder,.dnb-textarea__align--right .dnb-textarea__textarea{text-align:right}.dnb-textarea__autoresize .dnb-textarea__textarea{resize:none}.dnb-textarea--disabled .dnb-textarea__textarea,.dnb-textarea__textarea[disabled]{-webkit-user-select:none;user-select:none}.dnb-textarea--disabled .dnb-textarea__textarea::-webkit-scrollbar,.dnb-textarea__textarea[disabled]::-webkit-scrollbar{width:0}.dnb-textarea--focus .dnb-textarea__textarea:not([disabled]):not([readonly])~.dnb-textarea__placeholder,.dnb-textarea--has-content .dnb-textarea__textarea~.dnb-textarea__placeholder{display:none}.dnb-textarea__inner>.dnb-form-status{margin:1rem 0 0 calc(0px - var(--textarea-padding-width));order:2}.dnb-textarea:not(.dnb-textarea--vertical) .dnb-form-label{margin-top:.5rem}.dnb-textarea--vertical{align-items:flex-start;display:flex;flex-direction:column}.dnb-textarea:not(.dnb-textarea--vertical)[class*=__status]{align-items:flex-start}.dnb-textarea:not(.dnb-textarea--vertical)[class*=__status]>.dnb-form-label{margin-top:.25rem}@media screen and (max-width:40em){.dnb-textarea{flex-wrap:wrap}.dnb-textarea>.dnb-form-label{margin-bottom:.5rem;margin-top:.5rem}}.dnb-textarea--stretch{display:flex;flex-grow:1}.dnb-textarea--stretch .dnb-textarea__inner{flex-grow:1}.dnb-textarea--stretch .dnb-textarea__inner,.dnb-textarea--stretch .dnb-textarea__shell,.dnb-textarea--stretch .dnb-textarea__textarea{width:100%}.dnb-textarea--stretch .dnb-form-label+.dnb-textarea__inner{width:auto}.dnb-form-row--horizontal .dnb-textarea--stretch,.dnb-textarea--vertical.dnb-textarea--stretch .dnb-textarea__inner{width:100%}@media screen and (max-width:40em){.dnb-responsive-component .dnb-textarea{align-items:flex-start;display:flex;flex-direction:column;margin-bottom:.5rem}.dnb-responsive-component .dnb-textarea>.dnb-form-label{margin-bottom:.5rem}}html[data-visual-test] .dnb-textarea__textarea{caret-color:var(--color-white)}.dnb-textarea.dnb-skeleton .dnb-textarea__inner{border-radius:.25rem;margin:0}.dnb-textarea.dnb-skeleton .dnb-textarea__inner .dnb-textarea__shell{margin:var(--textarea-padding-width)}.dnb-textarea.dnb-skeleton .dnb-textarea__state,.dnb-textarea.dnb-skeleton .dnb-textarea__textarea{visibility:hidden}
@@ -71,6 +71,10 @@
71
71
  @include textareaStyleCommon();
72
72
 
73
73
  @include scrollY(auto);
74
+
75
+ @include IS_FF() {
76
+ overflow-x: clip;
77
+ }
74
78
  }
75
79
 
76
80
  // change the autocomplete appearance once filled out
@@ -236,6 +236,5 @@ process.env.NODE_ENV !== "production" ? ToggleButtonGroup.propTypes = _objectSpr
236
236
  children: PropTypes.oneOfType([PropTypes.string, PropTypes.func, PropTypes.node]),
237
237
  on_change: PropTypes.func
238
238
  }) : void 0;
239
- ToggleButtonGroup._formElement = true;
240
239
  ToggleButtonGroup._supportsSpacingProps = true;
241
240
  //# sourceMappingURL=ToggleButtonGroup.js.map
@@ -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,