@dnb/eufemia 10.18.0 → 10.20.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 (1199) hide show
  1. package/CHANGELOG.md +67 -0
  2. package/cjs/components/AriaLive.d.ts +12 -0
  3. package/cjs/components/AriaLive.js +24 -0
  4. package/cjs/components/AriaLive.js.map +1 -0
  5. package/cjs/components/accordion/AccordionContent.d.ts +1 -1
  6. package/cjs/components/accordion/AccordionContent.js.map +1 -1
  7. package/cjs/components/accordion/style/dnb-accordion.css +0 -3
  8. package/cjs/components/accordion/style/dnb-accordion.min.css +1 -1
  9. package/cjs/components/accordion/style/dnb-accordion.scss +0 -5
  10. package/cjs/components/aria-live/AriaLive.d.ts +6 -0
  11. package/cjs/components/aria-live/AriaLive.js +23 -0
  12. package/cjs/components/aria-live/AriaLive.js.map +1 -0
  13. package/cjs/components/aria-live/index.d.ts +7 -0
  14. package/cjs/components/aria-live/index.js +24 -0
  15. package/cjs/components/aria-live/index.js.map +1 -0
  16. package/cjs/components/aria-live/types.d.ts +44 -0
  17. package/cjs/components/aria-live/types.js +1 -0
  18. package/cjs/components/aria-live/types.js.map +1 -0
  19. package/cjs/components/aria-live/useAriaLive.d.ts +273 -0
  20. package/cjs/components/aria-live/useAriaLive.js +84 -0
  21. package/cjs/components/aria-live/useAriaLive.js.map +1 -0
  22. package/cjs/components/autocomplete/Autocomplete.d.ts +0 -1
  23. package/cjs/components/autocomplete/Autocomplete.js +24 -46
  24. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  25. package/cjs/components/breadcrumb/Breadcrumb.js +24 -21
  26. package/cjs/components/breadcrumb/Breadcrumb.js.map +1 -1
  27. package/cjs/components/breadcrumb/BreadcrumbItem.js +16 -7
  28. package/cjs/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  29. package/cjs/components/breadcrumb/BreadcrumbMultiple.js +1 -1
  30. package/cjs/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  31. package/cjs/components/breadcrumb/style/dnb-breadcrumb.css +13 -3
  32. package/cjs/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  33. package/cjs/components/breadcrumb/style/dnb-breadcrumb.scss +15 -3
  34. package/cjs/components/card/Card.d.ts +6 -4
  35. package/cjs/components/card/Card.js +11 -15
  36. package/cjs/components/card/Card.js.map +1 -1
  37. package/cjs/components/card/style/dnb-card.css +29 -0
  38. package/cjs/components/card/style/dnb-card.min.css +1 -1
  39. package/cjs/components/card/style/dnb-card.scss +41 -0
  40. package/cjs/components/card/style/themes/dnb-card-theme-ui.css +1 -19
  41. package/cjs/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  42. package/cjs/components/card/style/themes/dnb-card-theme-ui.scss +1 -27
  43. package/cjs/components/date-picker/DatePicker.d.ts +3 -0
  44. package/cjs/components/date-picker/DatePickerProvider.js +9 -5
  45. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  46. package/cjs/components/flex/Container.d.ts +4 -2
  47. package/cjs/components/flex/Container.js +28 -9
  48. package/cjs/components/flex/Container.js.map +1 -1
  49. package/cjs/components/flex/Item.js +8 -13
  50. package/cjs/components/flex/Item.js.map +1 -1
  51. package/cjs/components/flex/style/dnb-flex.css +6 -3
  52. package/cjs/components/flex/style/dnb-flex.min.css +1 -1
  53. package/cjs/components/flex/style/flex-container.scss +6 -7
  54. package/cjs/components/flex/utils.d.ts +35 -7
  55. package/cjs/components/flex/utils.js +65 -33
  56. package/cjs/components/flex/utils.js.map +1 -1
  57. package/cjs/components/form-status/FormStatus.d.ts +5 -1
  58. package/cjs/components/form-status/FormStatus.js +38 -44
  59. package/cjs/components/form-status/FormStatus.js.map +1 -1
  60. package/cjs/components/form-status/style/dnb-form-status.css +0 -18
  61. package/cjs/components/form-status/style/dnb-form-status.min.css +1 -1
  62. package/cjs/components/form-status/style/dnb-form-status.scss +0 -45
  63. package/cjs/components/global-status/GlobalStatus.js +52 -138
  64. package/cjs/components/global-status/GlobalStatus.js.map +1 -1
  65. package/cjs/components/global-status/style/dnb-global-status.css +6 -16
  66. package/cjs/components/global-status/style/dnb-global-status.min.css +1 -1
  67. package/cjs/components/global-status/style/dnb-global-status.scss +11 -23
  68. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.css +0 -3
  69. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  70. package/cjs/components/global-status/style/themes/dnb-global-status-theme-ui.scss +0 -10
  71. package/cjs/components/height-animation/HeightAnimation.d.ts +12 -4
  72. package/cjs/components/height-animation/HeightAnimation.js +31 -14
  73. package/cjs/components/height-animation/HeightAnimation.js.map +1 -1
  74. package/cjs/components/height-animation/HeightAnimationInstance.d.ts +35 -18
  75. package/cjs/components/height-animation/HeightAnimationInstance.js +186 -158
  76. package/cjs/components/height-animation/HeightAnimationInstance.js.map +1 -1
  77. package/cjs/components/height-animation/style/dnb-height-animation.css +16 -2
  78. package/cjs/components/height-animation/style/dnb-height-animation.min.css +1 -1
  79. package/cjs/components/height-animation/style/dnb-height-animation.scss +18 -2
  80. package/cjs/components/height-animation/useHeightAnimation.d.ts +6 -1
  81. package/cjs/components/height-animation/useHeightAnimation.js +125 -92
  82. package/cjs/components/height-animation/useHeightAnimation.js.map +1 -1
  83. package/cjs/components/index.d.ts +2 -1
  84. package/cjs/components/index.js +7 -0
  85. package/cjs/components/index.js.map +1 -1
  86. package/cjs/components/input/Input.js +0 -3
  87. package/cjs/components/input/Input.js.map +1 -1
  88. package/cjs/components/input-masked/MultiInputMask.d.ts +1 -1
  89. package/cjs/components/input-masked/MultiInputMask.js +52 -41
  90. package/cjs/components/input-masked/MultiInputMask.js.map +1 -1
  91. package/cjs/components/lib.d.ts +3 -1
  92. package/cjs/components/lib.js +8 -0
  93. package/cjs/components/lib.js.map +1 -1
  94. package/cjs/components/number-format/NumberFormat.d.ts +7 -12
  95. package/cjs/components/number-format/NumberUtils.d.ts +8 -2
  96. package/cjs/components/number-format/useNumberFormat.d.ts +1 -1
  97. package/cjs/components/section/Section.d.ts +6 -3
  98. package/cjs/components/section/Section.js.map +1 -1
  99. package/cjs/components/section/style/dnb-section.css +1 -0
  100. package/cjs/components/section/style/dnb-section.min.css +1 -1
  101. package/cjs/components/section/style/dnb-section.scss +1 -0
  102. package/cjs/components/space/SpacingUtils.js +5 -1
  103. package/cjs/components/space/SpacingUtils.js.map +1 -1
  104. package/cjs/components/step-indicator/StepIndicatorItem.js +3 -21
  105. package/cjs/components/step-indicator/StepIndicatorItem.js.map +1 -1
  106. package/cjs/components/step-indicator/StepIndicatorTriggerButton.js +2 -16
  107. package/cjs/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  108. package/cjs/components/step-indicator/style/dnb-step-indicator.css +0 -5
  109. package/cjs/components/step-indicator/style/dnb-step-indicator.min.css +1 -1
  110. package/cjs/components/step-indicator/style/dnb-step-indicator.scss +0 -7
  111. package/cjs/components/table/TableAccordion.js +1 -1
  112. package/cjs/components/table/TableAccordion.js.map +1 -1
  113. package/cjs/components/table/TableAccordionContent.js +51 -23
  114. package/cjs/components/table/TableAccordionContent.js.map +1 -1
  115. package/cjs/components/table/style/dnb-table.css +6 -3
  116. package/cjs/components/table/style/dnb-table.min.css +1 -1
  117. package/cjs/components/table/style/table-accordion.scss +6 -3
  118. package/cjs/components/tabs/Tabs.js +2 -1
  119. package/cjs/components/tabs/Tabs.js.map +1 -1
  120. package/cjs/components/tabs/TabsContentWrapper.d.ts +1 -0
  121. package/cjs/components/tabs/TabsContentWrapper.js +8 -6
  122. package/cjs/components/tabs/TabsContentWrapper.js.map +1 -1
  123. package/cjs/components/textarea/Textarea.d.ts +5 -0
  124. package/cjs/components/textarea/Textarea.js +16 -3
  125. package/cjs/components/textarea/Textarea.js.map +1 -1
  126. package/cjs/components/textarea/style/dnb-textarea.css +10 -3
  127. package/cjs/components/textarea/style/dnb-textarea.min.css +1 -1
  128. package/cjs/components/textarea/style/dnb-textarea.scss +13 -3
  129. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.css +15 -2
  130. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  131. package/cjs/components/textarea/style/themes/dnb-textarea-theme-ui.scss +15 -2
  132. package/cjs/components/upload/Upload.js +15 -18
  133. package/cjs/components/upload/Upload.js.map +1 -1
  134. package/cjs/components/upload/UploadFileInput.js +3 -1
  135. package/cjs/components/upload/UploadFileInput.js.map +1 -1
  136. package/cjs/components/upload/UploadFileList.js +1 -1
  137. package/cjs/components/upload/UploadFileList.js.map +1 -1
  138. package/cjs/components/upload/UploadStatus.js +6 -2
  139. package/cjs/components/upload/UploadStatus.js.map +1 -1
  140. package/cjs/components/upload/useUpload.js +5 -6
  141. package/cjs/components/upload/useUpload.js.map +1 -1
  142. package/cjs/elements/lib.d.ts +6 -0
  143. package/cjs/elements/typography/H1.d.ts +1 -0
  144. package/cjs/elements/typography/H1.js +1 -1
  145. package/cjs/elements/typography/H1.js.map +1 -1
  146. package/cjs/elements/typography/H2.d.ts +1 -0
  147. package/cjs/elements/typography/H2.js +1 -1
  148. package/cjs/elements/typography/H2.js.map +1 -1
  149. package/cjs/elements/typography/H3.d.ts +1 -0
  150. package/cjs/elements/typography/H3.js +1 -1
  151. package/cjs/elements/typography/H3.js.map +1 -1
  152. package/cjs/elements/typography/H4.d.ts +1 -0
  153. package/cjs/elements/typography/H4.js +1 -1
  154. package/cjs/elements/typography/H4.js.map +1 -1
  155. package/cjs/elements/typography/H5.d.ts +1 -0
  156. package/cjs/elements/typography/H5.js +1 -1
  157. package/cjs/elements/typography/H5.js.map +1 -1
  158. package/cjs/elements/typography/H6.d.ts +1 -0
  159. package/cjs/elements/typography/H6.js +1 -1
  160. package/cjs/elements/typography/H6.js.map +1 -1
  161. package/cjs/extensions/forms/DataContext/Context.d.ts +18 -5
  162. package/cjs/extensions/forms/DataContext/Context.js +9 -0
  163. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  164. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +57 -19
  165. package/cjs/extensions/forms/DataContext/Provider/Provider.js +128 -48
  166. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  167. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +3 -1
  168. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  169. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  170. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +5 -4
  171. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  172. package/cjs/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  173. package/cjs/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  174. package/cjs/extensions/forms/Field/Currency/Currency.d.ts +2 -2
  175. package/cjs/extensions/forms/Field/Currency/Currency.js.map +1 -1
  176. package/cjs/extensions/forms/Field/Date/Date.js +8 -4
  177. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  178. package/cjs/extensions/forms/Field/Email/Email.d.ts +2 -2
  179. package/cjs/extensions/forms/Field/Email/Email.js +5 -4
  180. package/cjs/extensions/forms/Field/Email/Email.js.map +1 -1
  181. package/cjs/extensions/forms/Field/Expiry/Expiry.js +18 -16
  182. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  183. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  184. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +5 -4
  185. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  186. package/cjs/extensions/forms/Field/Number/Number.d.ts +2 -4
  187. package/cjs/extensions/forms/Field/Number/Number.js +28 -27
  188. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  189. package/cjs/extensions/forms/Field/Number/style/dnb-number.css +0 -6
  190. package/cjs/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  191. package/cjs/extensions/forms/Field/Number/style/dnb-number.scss +0 -1
  192. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +4 -0
  193. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +1 -1
  194. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +7 -0
  195. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +4 -0
  196. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +1 -1
  197. package/cjs/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +9 -0
  198. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +2 -2
  199. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +5 -4
  200. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  201. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  202. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +15 -7
  203. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  204. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  205. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  206. package/cjs/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.css +9 -0
  207. package/cjs/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.min.css +1 -1
  208. package/cjs/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.scss +7 -0
  209. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +9 -5
  210. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  211. package/cjs/extensions/forms/Field/Selection/Selection.js +12 -7
  212. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  213. package/cjs/extensions/forms/Field/String/String.d.ts +4 -2
  214. package/cjs/extensions/forms/Field/String/String.js +17 -9
  215. package/cjs/extensions/forms/Field/String/String.js.map +1 -1
  216. package/cjs/extensions/forms/Field/Toggle/Toggle.js +20 -13
  217. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  218. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +2 -2
  219. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +11 -8
  220. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  221. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +22 -5
  222. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  223. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.scss +29 -1
  224. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.css +4 -0
  225. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.min.css +1 -0
  226. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.scss +6 -0
  227. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +4 -0
  228. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -0
  229. package/cjs/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +6 -0
  230. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  231. package/cjs/extensions/forms/Form/Handler/Handler.js +7 -1
  232. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  233. package/cjs/extensions/forms/Form/Visibility/Visibility.d.ts +6 -1
  234. package/cjs/extensions/forms/Form/Visibility/Visibility.js +54 -39
  235. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  236. package/cjs/extensions/forms/Form/data-context/getData.d.ts +8 -0
  237. package/cjs/extensions/forms/Form/data-context/getData.js +21 -0
  238. package/cjs/extensions/forms/Form/data-context/getData.js.map +1 -0
  239. package/cjs/extensions/forms/Form/data-context/setData.d.ts +2 -0
  240. package/cjs/extensions/forms/Form/data-context/setData.js +12 -0
  241. package/cjs/extensions/forms/Form/data-context/setData.js.map +1 -0
  242. package/cjs/extensions/forms/Form/data-context/useData.d.ts +22 -0
  243. package/cjs/extensions/forms/Form/data-context/useData.js +65 -0
  244. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -0
  245. package/cjs/extensions/forms/Form/data-context/useError.d.ts +5 -0
  246. package/cjs/extensions/forms/Form/data-context/useError.js +18 -0
  247. package/cjs/extensions/forms/Form/data-context/useError.js.map +1 -0
  248. package/cjs/extensions/forms/Form/index.d.ts +4 -1
  249. package/cjs/extensions/forms/Form/index.js +22 -1
  250. package/cjs/extensions/forms/Form/index.js.map +1 -1
  251. package/cjs/extensions/forms/Iterate/Array/Array.d.ts +2 -2
  252. package/cjs/extensions/forms/Iterate/Array/Array.js +3 -1
  253. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  254. package/cjs/extensions/forms/StepsLayout/StepsLayout.d.ts +3 -0
  255. package/cjs/extensions/forms/StepsLayout/StepsLayout.js +30 -21
  256. package/cjs/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  257. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -0
  258. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  259. package/cjs/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +7 -0
  260. package/cjs/extensions/forms/Value/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  261. package/cjs/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js.map +1 -1
  262. package/cjs/extensions/forms/Value/Currency/Currency.d.ts +2 -2
  263. package/cjs/extensions/forms/Value/Currency/Currency.js +2 -3
  264. package/cjs/extensions/forms/Value/Currency/Currency.js.map +1 -1
  265. package/cjs/extensions/forms/Value/Date/Date.d.ts +2 -2
  266. package/cjs/extensions/forms/Value/Date/Date.js.map +1 -1
  267. package/cjs/extensions/forms/Value/Email/Email.d.ts +2 -2
  268. package/cjs/extensions/forms/Value/Email/Email.js.map +1 -1
  269. package/cjs/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  270. package/cjs/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  271. package/cjs/extensions/forms/Value/Number/Number.d.ts +6 -10
  272. package/cjs/extensions/forms/Value/Number/Number.js +25 -27
  273. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  274. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.d.ts +2 -2
  275. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.js +6 -4
  276. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  277. package/cjs/extensions/forms/hooks/index.d.ts +1 -0
  278. package/cjs/extensions/forms/hooks/index.js +7 -0
  279. package/cjs/extensions/forms/hooks/index.js.map +1 -1
  280. package/cjs/extensions/forms/hooks/useDataValue.d.ts +10 -1
  281. package/cjs/extensions/forms/hooks/useDataValue.js +87 -28
  282. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  283. package/cjs/extensions/forms/hooks/useErrorMessage.d.ts +10 -0
  284. package/cjs/extensions/forms/hooks/useErrorMessage.js +23 -0
  285. package/cjs/extensions/forms/hooks/useErrorMessage.js.map +1 -0
  286. package/cjs/extensions/forms/index.d.ts +1 -0
  287. package/cjs/extensions/forms/index.js +9 -1
  288. package/cjs/extensions/forms/index.js.map +1 -1
  289. package/cjs/extensions/forms/style/dnb-forms.css +37 -11
  290. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  291. package/cjs/extensions/forms/types.d.ts +26 -9
  292. package/cjs/extensions/forms/types.js.map +1 -1
  293. package/cjs/extensions/forms/utils/ajv.d.ts +47 -6
  294. package/cjs/extensions/forms/utils/ajv.js +29 -13
  295. package/cjs/extensions/forms/utils/ajv.js.map +1 -1
  296. package/cjs/extensions/forms/utils/index.d.ts +0 -1
  297. package/cjs/extensions/forms/utils/index.js +0 -12
  298. package/cjs/extensions/forms/utils/index.js.map +1 -1
  299. package/cjs/fragments/TextCounter.d.ts +12 -0
  300. package/cjs/fragments/TextCounter.js +24 -0
  301. package/cjs/fragments/TextCounter.js.map +1 -0
  302. package/cjs/fragments/drawer-list/DrawerListHelpers.js +1 -0
  303. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  304. package/cjs/fragments/index.d.ts +2 -1
  305. package/cjs/fragments/index.js +7 -0
  306. package/cjs/fragments/index.js.map +1 -1
  307. package/cjs/fragments/lib.d.ts +3 -1
  308. package/cjs/fragments/lib.js +9 -1
  309. package/cjs/fragments/lib.js.map +1 -1
  310. package/cjs/fragments/text-counter/TextCounter.d.ts +8 -0
  311. package/cjs/fragments/text-counter/TextCounter.js +61 -0
  312. package/cjs/fragments/text-counter/TextCounter.js.map +1 -0
  313. package/cjs/fragments/text-counter/index.d.ts +5 -0
  314. package/cjs/fragments/text-counter/index.js +17 -0
  315. package/cjs/fragments/text-counter/index.js.map +1 -0
  316. package/cjs/fragments/text-counter/style/dnb-text-counter.scss +15 -0
  317. package/cjs/fragments/text-counter/style/index.d.ts +1 -0
  318. package/cjs/fragments/text-counter/style/index.js +4 -0
  319. package/cjs/fragments/text-counter/style/index.js.map +1 -0
  320. package/cjs/fragments/text-counter/style/themes/dnb-text-counter-theme-sbanken.scss +8 -0
  321. package/cjs/fragments/text-counter/style/themes/dnb-text-counter-theme-ui.scss +8 -0
  322. package/cjs/fragments/text-counter/style/themes/ui.d.ts +1 -0
  323. package/cjs/fragments/text-counter/style/themes/ui.js +4 -0
  324. package/cjs/fragments/text-counter/style/themes/ui.js.map +1 -0
  325. package/cjs/fragments/text-counter/style.d.ts +5 -0
  326. package/cjs/fragments/text-counter/style.js +4 -0
  327. package/cjs/fragments/text-counter/style.js.map +1 -0
  328. package/cjs/index.d.ts +2 -1
  329. package/cjs/index.js +7 -0
  330. package/cjs/index.js.map +1 -1
  331. package/cjs/shared/Eufemia.d.ts +1 -1
  332. package/cjs/shared/Eufemia.js +2 -2
  333. package/cjs/shared/Eufemia.js.map +1 -1
  334. package/cjs/shared/component-helper.js +0 -3
  335. package/cjs/shared/component-helper.js.map +1 -1
  336. package/cjs/shared/helpers/useSharedState.d.ts +33 -10
  337. package/cjs/shared/helpers/useSharedState.js +78 -40
  338. package/cjs/shared/helpers/useSharedState.js.map +1 -1
  339. package/cjs/shared/locales/en-GB.d.ts +7 -0
  340. package/cjs/shared/locales/en-GB.js +9 -2
  341. package/cjs/shared/locales/en-GB.js.map +1 -1
  342. package/cjs/shared/locales/en-US.d.ts +7 -0
  343. package/cjs/shared/locales/index.d.ts +14 -0
  344. package/cjs/shared/locales/nb-NO.d.ts +7 -0
  345. package/cjs/shared/locales/nb-NO.js +7 -0
  346. package/cjs/shared/locales/nb-NO.js.map +1 -1
  347. package/cjs/style/core/utilities.scss +1 -1
  348. package/cjs/style/dnb-ui-components.css +134 -67
  349. package/cjs/style/dnb-ui-components.min.css +3 -3
  350. package/cjs/style/dnb-ui-extensions.css +37 -11
  351. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  352. package/cjs/style/dnb-ui-forms.css +37 -11
  353. package/cjs/style/dnb-ui-forms.min.css +1 -1
  354. package/cjs/style/dnb-ui-fragments.css +10 -0
  355. package/cjs/style/dnb-ui-fragments.min.css +1 -1
  356. package/cjs/style/dnb-ui-fragments.scss +1 -0
  357. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +203 -102
  358. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  359. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  360. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +46 -11
  361. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  362. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  363. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +46 -11
  364. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  365. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  366. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +188 -97
  367. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  368. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  369. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +46 -11
  370. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  371. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  372. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +46 -11
  373. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  374. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  375. package/cjs/style/themes/theme-ui/ui-theme-components.css +203 -102
  376. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  377. package/cjs/style/themes/theme-ui/ui-theme-components.scss +1 -0
  378. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +46 -11
  379. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  380. package/cjs/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  381. package/cjs/style/themes/theme-ui/ui-theme-forms.css +46 -11
  382. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  383. package/cjs/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  384. package/components/AriaLive.d.ts +12 -0
  385. package/components/AriaLive.js +4 -0
  386. package/components/AriaLive.js.map +1 -0
  387. package/components/accordion/AccordionContent.d.ts +1 -1
  388. package/components/accordion/AccordionContent.js.map +1 -1
  389. package/components/accordion/style/dnb-accordion.css +0 -3
  390. package/components/accordion/style/dnb-accordion.min.css +1 -1
  391. package/components/accordion/style/dnb-accordion.scss +0 -5
  392. package/components/aria-live/AriaLive.d.ts +6 -0
  393. package/components/aria-live/AriaLive.js +15 -0
  394. package/components/aria-live/AriaLive.js.map +1 -0
  395. package/components/aria-live/index.d.ts +7 -0
  396. package/components/aria-live/index.js +4 -0
  397. package/components/aria-live/index.js.map +1 -0
  398. package/components/aria-live/types.d.ts +44 -0
  399. package/components/aria-live/types.js +1 -0
  400. package/components/aria-live/types.js.map +1 -0
  401. package/components/aria-live/useAriaLive.d.ts +273 -0
  402. package/components/aria-live/useAriaLive.js +75 -0
  403. package/components/aria-live/useAriaLive.js.map +1 -0
  404. package/components/autocomplete/Autocomplete.d.ts +0 -1
  405. package/components/autocomplete/Autocomplete.js +24 -46
  406. package/components/autocomplete/Autocomplete.js.map +1 -1
  407. package/components/breadcrumb/Breadcrumb.js +25 -22
  408. package/components/breadcrumb/Breadcrumb.js.map +1 -1
  409. package/components/breadcrumb/BreadcrumbItem.js +16 -7
  410. package/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  411. package/components/breadcrumb/BreadcrumbMultiple.js +1 -1
  412. package/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  413. package/components/breadcrumb/style/dnb-breadcrumb.css +13 -3
  414. package/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  415. package/components/breadcrumb/style/dnb-breadcrumb.scss +15 -3
  416. package/components/card/Card.d.ts +6 -4
  417. package/components/card/Card.js +11 -15
  418. package/components/card/Card.js.map +1 -1
  419. package/components/card/style/dnb-card.css +29 -0
  420. package/components/card/style/dnb-card.min.css +1 -1
  421. package/components/card/style/dnb-card.scss +41 -0
  422. package/components/card/style/themes/dnb-card-theme-ui.css +1 -19
  423. package/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  424. package/components/card/style/themes/dnb-card-theme-ui.scss +1 -27
  425. package/components/date-picker/DatePicker.d.ts +3 -0
  426. package/components/date-picker/DatePickerProvider.js +9 -5
  427. package/components/date-picker/DatePickerProvider.js.map +1 -1
  428. package/components/flex/Container.d.ts +4 -2
  429. package/components/flex/Container.js +26 -9
  430. package/components/flex/Container.js.map +1 -1
  431. package/components/flex/Item.js +8 -11
  432. package/components/flex/Item.js.map +1 -1
  433. package/components/flex/style/dnb-flex.css +6 -3
  434. package/components/flex/style/dnb-flex.min.css +1 -1
  435. package/components/flex/style/flex-container.scss +6 -7
  436. package/components/flex/utils.d.ts +35 -7
  437. package/components/flex/utils.js +56 -24
  438. package/components/flex/utils.js.map +1 -1
  439. package/components/form-status/FormStatus.d.ts +5 -1
  440. package/components/form-status/FormStatus.js +38 -44
  441. package/components/form-status/FormStatus.js.map +1 -1
  442. package/components/form-status/style/dnb-form-status.css +0 -18
  443. package/components/form-status/style/dnb-form-status.min.css +1 -1
  444. package/components/form-status/style/dnb-form-status.scss +0 -45
  445. package/components/global-status/GlobalStatus.js +53 -139
  446. package/components/global-status/GlobalStatus.js.map +1 -1
  447. package/components/global-status/style/dnb-global-status.css +6 -16
  448. package/components/global-status/style/dnb-global-status.min.css +1 -1
  449. package/components/global-status/style/dnb-global-status.scss +11 -23
  450. package/components/global-status/style/themes/dnb-global-status-theme-ui.css +0 -3
  451. package/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  452. package/components/global-status/style/themes/dnb-global-status-theme-ui.scss +0 -10
  453. package/components/height-animation/HeightAnimation.d.ts +12 -4
  454. package/components/height-animation/HeightAnimation.js +27 -14
  455. package/components/height-animation/HeightAnimation.js.map +1 -1
  456. package/components/height-animation/HeightAnimationInstance.d.ts +35 -18
  457. package/components/height-animation/HeightAnimationInstance.js +186 -158
  458. package/components/height-animation/HeightAnimationInstance.js.map +1 -1
  459. package/components/height-animation/style/dnb-height-animation.css +16 -2
  460. package/components/height-animation/style/dnb-height-animation.min.css +1 -1
  461. package/components/height-animation/style/dnb-height-animation.scss +18 -2
  462. package/components/height-animation/useHeightAnimation.d.ts +6 -1
  463. package/components/height-animation/useHeightAnimation.js +124 -92
  464. package/components/height-animation/useHeightAnimation.js.map +1 -1
  465. package/components/index.d.ts +2 -1
  466. package/components/index.js +2 -1
  467. package/components/index.js.map +1 -1
  468. package/components/input/Input.js +0 -3
  469. package/components/input/Input.js.map +1 -1
  470. package/components/input-masked/MultiInputMask.d.ts +1 -1
  471. package/components/input-masked/MultiInputMask.js +52 -41
  472. package/components/input-masked/MultiInputMask.js.map +1 -1
  473. package/components/lib.d.ts +3 -1
  474. package/components/lib.js +3 -1
  475. package/components/lib.js.map +1 -1
  476. package/components/number-format/NumberFormat.d.ts +7 -12
  477. package/components/number-format/NumberUtils.d.ts +8 -2
  478. package/components/number-format/useNumberFormat.d.ts +1 -1
  479. package/components/section/Section.d.ts +6 -3
  480. package/components/section/Section.js.map +1 -1
  481. package/components/section/style/dnb-section.css +1 -0
  482. package/components/section/style/dnb-section.min.css +1 -1
  483. package/components/section/style/dnb-section.scss +1 -0
  484. package/components/space/SpacingUtils.js +5 -1
  485. package/components/space/SpacingUtils.js.map +1 -1
  486. package/components/step-indicator/StepIndicatorItem.js +4 -22
  487. package/components/step-indicator/StepIndicatorItem.js.map +1 -1
  488. package/components/step-indicator/StepIndicatorTriggerButton.js +3 -17
  489. package/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  490. package/components/step-indicator/style/dnb-step-indicator.css +0 -5
  491. package/components/step-indicator/style/dnb-step-indicator.min.css +1 -1
  492. package/components/step-indicator/style/dnb-step-indicator.scss +0 -7
  493. package/components/table/TableAccordion.js +1 -1
  494. package/components/table/TableAccordion.js.map +1 -1
  495. package/components/table/TableAccordionContent.js +48 -23
  496. package/components/table/TableAccordionContent.js.map +1 -1
  497. package/components/table/style/dnb-table.css +6 -3
  498. package/components/table/style/dnb-table.min.css +1 -1
  499. package/components/table/style/table-accordion.scss +6 -3
  500. package/components/tabs/Tabs.js +2 -1
  501. package/components/tabs/Tabs.js.map +1 -1
  502. package/components/tabs/TabsContentWrapper.d.ts +1 -0
  503. package/components/tabs/TabsContentWrapper.js +8 -6
  504. package/components/tabs/TabsContentWrapper.js.map +1 -1
  505. package/components/textarea/Textarea.d.ts +5 -0
  506. package/components/textarea/Textarea.js +16 -3
  507. package/components/textarea/Textarea.js.map +1 -1
  508. package/components/textarea/style/dnb-textarea.css +10 -3
  509. package/components/textarea/style/dnb-textarea.min.css +1 -1
  510. package/components/textarea/style/dnb-textarea.scss +13 -3
  511. package/components/textarea/style/themes/dnb-textarea-theme-ui.css +15 -2
  512. package/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  513. package/components/textarea/style/themes/dnb-textarea-theme-ui.scss +15 -2
  514. package/components/upload/Upload.js +13 -18
  515. package/components/upload/Upload.js.map +1 -1
  516. package/components/upload/UploadFileInput.js +3 -1
  517. package/components/upload/UploadFileInput.js.map +1 -1
  518. package/components/upload/UploadFileList.js +1 -1
  519. package/components/upload/UploadFileList.js.map +1 -1
  520. package/components/upload/UploadStatus.js +6 -2
  521. package/components/upload/UploadStatus.js.map +1 -1
  522. package/components/upload/useUpload.js +5 -7
  523. package/components/upload/useUpload.js.map +1 -1
  524. package/elements/lib.d.ts +6 -0
  525. package/elements/typography/H1.d.ts +1 -0
  526. package/elements/typography/H1.js +1 -1
  527. package/elements/typography/H1.js.map +1 -1
  528. package/elements/typography/H2.d.ts +1 -0
  529. package/elements/typography/H2.js +1 -1
  530. package/elements/typography/H2.js.map +1 -1
  531. package/elements/typography/H3.d.ts +1 -0
  532. package/elements/typography/H3.js +1 -1
  533. package/elements/typography/H3.js.map +1 -1
  534. package/elements/typography/H4.d.ts +1 -0
  535. package/elements/typography/H4.js +1 -1
  536. package/elements/typography/H4.js.map +1 -1
  537. package/elements/typography/H5.d.ts +1 -0
  538. package/elements/typography/H5.js +1 -1
  539. package/elements/typography/H5.js.map +1 -1
  540. package/elements/typography/H6.d.ts +1 -0
  541. package/elements/typography/H6.js +1 -1
  542. package/elements/typography/H6.js.map +1 -1
  543. package/es/components/AriaLive.d.ts +12 -0
  544. package/es/components/AriaLive.js +4 -0
  545. package/es/components/AriaLive.js.map +1 -0
  546. package/es/components/accordion/AccordionContent.d.ts +1 -1
  547. package/es/components/accordion/AccordionContent.js.map +1 -1
  548. package/es/components/accordion/style/dnb-accordion.css +0 -3
  549. package/es/components/accordion/style/dnb-accordion.min.css +1 -1
  550. package/es/components/accordion/style/dnb-accordion.scss +0 -5
  551. package/es/components/aria-live/AriaLive.d.ts +6 -0
  552. package/es/components/aria-live/AriaLive.js +15 -0
  553. package/es/components/aria-live/AriaLive.js.map +1 -0
  554. package/es/components/aria-live/index.d.ts +7 -0
  555. package/es/components/aria-live/index.js +4 -0
  556. package/es/components/aria-live/index.js.map +1 -0
  557. package/es/components/aria-live/types.d.ts +44 -0
  558. package/es/components/aria-live/types.js +1 -0
  559. package/es/components/aria-live/types.js.map +1 -0
  560. package/es/components/aria-live/useAriaLive.d.ts +273 -0
  561. package/es/components/aria-live/useAriaLive.js +75 -0
  562. package/es/components/aria-live/useAriaLive.js.map +1 -0
  563. package/es/components/autocomplete/Autocomplete.d.ts +0 -1
  564. package/es/components/autocomplete/Autocomplete.js +24 -46
  565. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  566. package/es/components/breadcrumb/Breadcrumb.js +25 -22
  567. package/es/components/breadcrumb/Breadcrumb.js.map +1 -1
  568. package/es/components/breadcrumb/BreadcrumbItem.js +16 -7
  569. package/es/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  570. package/es/components/breadcrumb/BreadcrumbMultiple.js +1 -1
  571. package/es/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  572. package/es/components/breadcrumb/style/dnb-breadcrumb.css +13 -3
  573. package/es/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  574. package/es/components/breadcrumb/style/dnb-breadcrumb.scss +15 -3
  575. package/es/components/card/Card.d.ts +6 -4
  576. package/es/components/card/Card.js +11 -15
  577. package/es/components/card/Card.js.map +1 -1
  578. package/es/components/card/style/dnb-card.css +29 -0
  579. package/es/components/card/style/dnb-card.min.css +1 -1
  580. package/es/components/card/style/dnb-card.scss +41 -0
  581. package/es/components/card/style/themes/dnb-card-theme-ui.css +1 -19
  582. package/es/components/card/style/themes/dnb-card-theme-ui.min.css +1 -1
  583. package/es/components/card/style/themes/dnb-card-theme-ui.scss +1 -27
  584. package/es/components/date-picker/DatePicker.d.ts +3 -0
  585. package/es/components/date-picker/DatePickerProvider.js +9 -5
  586. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  587. package/es/components/flex/Container.d.ts +4 -2
  588. package/es/components/flex/Container.js +26 -9
  589. package/es/components/flex/Container.js.map +1 -1
  590. package/es/components/flex/Item.js +8 -11
  591. package/es/components/flex/Item.js.map +1 -1
  592. package/es/components/flex/style/dnb-flex.css +6 -3
  593. package/es/components/flex/style/dnb-flex.min.css +1 -1
  594. package/es/components/flex/style/flex-container.scss +6 -7
  595. package/es/components/flex/utils.d.ts +35 -7
  596. package/es/components/flex/utils.js +55 -24
  597. package/es/components/flex/utils.js.map +1 -1
  598. package/es/components/form-status/FormStatus.d.ts +5 -1
  599. package/es/components/form-status/FormStatus.js +38 -44
  600. package/es/components/form-status/FormStatus.js.map +1 -1
  601. package/es/components/form-status/style/dnb-form-status.css +0 -18
  602. package/es/components/form-status/style/dnb-form-status.min.css +1 -1
  603. package/es/components/form-status/style/dnb-form-status.scss +0 -45
  604. package/es/components/global-status/GlobalStatus.js +51 -133
  605. package/es/components/global-status/GlobalStatus.js.map +1 -1
  606. package/es/components/global-status/style/dnb-global-status.css +6 -16
  607. package/es/components/global-status/style/dnb-global-status.min.css +1 -1
  608. package/es/components/global-status/style/dnb-global-status.scss +11 -23
  609. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.css +0 -3
  610. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.min.css +1 -1
  611. package/es/components/global-status/style/themes/dnb-global-status-theme-ui.scss +0 -10
  612. package/es/components/height-animation/HeightAnimation.d.ts +12 -4
  613. package/es/components/height-animation/HeightAnimation.js +27 -14
  614. package/es/components/height-animation/HeightAnimation.js.map +1 -1
  615. package/es/components/height-animation/HeightAnimationInstance.d.ts +35 -18
  616. package/es/components/height-animation/HeightAnimationInstance.js +188 -155
  617. package/es/components/height-animation/HeightAnimationInstance.js.map +1 -1
  618. package/es/components/height-animation/style/dnb-height-animation.css +16 -2
  619. package/es/components/height-animation/style/dnb-height-animation.min.css +1 -1
  620. package/es/components/height-animation/style/dnb-height-animation.scss +18 -2
  621. package/es/components/height-animation/useHeightAnimation.d.ts +6 -1
  622. package/es/components/height-animation/useHeightAnimation.js +124 -92
  623. package/es/components/height-animation/useHeightAnimation.js.map +1 -1
  624. package/es/components/index.d.ts +2 -1
  625. package/es/components/index.js +2 -1
  626. package/es/components/index.js.map +1 -1
  627. package/es/components/input/Input.js +0 -3
  628. package/es/components/input/Input.js.map +1 -1
  629. package/es/components/input-masked/MultiInputMask.d.ts +1 -1
  630. package/es/components/input-masked/MultiInputMask.js +50 -39
  631. package/es/components/input-masked/MultiInputMask.js.map +1 -1
  632. package/es/components/lib.d.ts +3 -1
  633. package/es/components/lib.js +3 -1
  634. package/es/components/lib.js.map +1 -1
  635. package/es/components/number-format/NumberFormat.d.ts +7 -12
  636. package/es/components/number-format/NumberUtils.d.ts +8 -2
  637. package/es/components/number-format/useNumberFormat.d.ts +1 -1
  638. package/es/components/section/Section.d.ts +6 -3
  639. package/es/components/section/Section.js.map +1 -1
  640. package/es/components/section/style/dnb-section.css +1 -0
  641. package/es/components/section/style/dnb-section.min.css +1 -1
  642. package/es/components/section/style/dnb-section.scss +1 -0
  643. package/es/components/space/SpacingUtils.js +5 -1
  644. package/es/components/space/SpacingUtils.js.map +1 -1
  645. package/es/components/step-indicator/StepIndicatorItem.js +4 -22
  646. package/es/components/step-indicator/StepIndicatorItem.js.map +1 -1
  647. package/es/components/step-indicator/StepIndicatorTriggerButton.js +3 -17
  648. package/es/components/step-indicator/StepIndicatorTriggerButton.js.map +1 -1
  649. package/es/components/step-indicator/style/dnb-step-indicator.css +0 -5
  650. package/es/components/step-indicator/style/dnb-step-indicator.min.css +1 -1
  651. package/es/components/step-indicator/style/dnb-step-indicator.scss +0 -7
  652. package/es/components/table/TableAccordion.js +1 -1
  653. package/es/components/table/TableAccordion.js.map +1 -1
  654. package/es/components/table/TableAccordionContent.js +47 -23
  655. package/es/components/table/TableAccordionContent.js.map +1 -1
  656. package/es/components/table/style/dnb-table.css +6 -3
  657. package/es/components/table/style/dnb-table.min.css +1 -1
  658. package/es/components/table/style/table-accordion.scss +6 -3
  659. package/es/components/tabs/Tabs.js +2 -1
  660. package/es/components/tabs/Tabs.js.map +1 -1
  661. package/es/components/tabs/TabsContentWrapper.d.ts +1 -0
  662. package/es/components/tabs/TabsContentWrapper.js +8 -6
  663. package/es/components/tabs/TabsContentWrapper.js.map +1 -1
  664. package/es/components/textarea/Textarea.d.ts +5 -0
  665. package/es/components/textarea/Textarea.js +16 -3
  666. package/es/components/textarea/Textarea.js.map +1 -1
  667. package/es/components/textarea/style/dnb-textarea.css +10 -3
  668. package/es/components/textarea/style/dnb-textarea.min.css +1 -1
  669. package/es/components/textarea/style/dnb-textarea.scss +13 -3
  670. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.css +15 -2
  671. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.min.css +1 -1
  672. package/es/components/textarea/style/themes/dnb-textarea-theme-ui.scss +15 -2
  673. package/es/components/upload/Upload.js +13 -18
  674. package/es/components/upload/Upload.js.map +1 -1
  675. package/es/components/upload/UploadFileInput.js +3 -1
  676. package/es/components/upload/UploadFileInput.js.map +1 -1
  677. package/es/components/upload/UploadFileList.js +1 -1
  678. package/es/components/upload/UploadFileList.js.map +1 -1
  679. package/es/components/upload/UploadStatus.js +6 -2
  680. package/es/components/upload/UploadStatus.js.map +1 -1
  681. package/es/components/upload/useUpload.js +5 -7
  682. package/es/components/upload/useUpload.js.map +1 -1
  683. package/es/elements/lib.d.ts +6 -0
  684. package/es/elements/typography/H1.d.ts +1 -0
  685. package/es/elements/typography/H1.js +1 -1
  686. package/es/elements/typography/H1.js.map +1 -1
  687. package/es/elements/typography/H2.d.ts +1 -0
  688. package/es/elements/typography/H2.js +1 -1
  689. package/es/elements/typography/H2.js.map +1 -1
  690. package/es/elements/typography/H3.d.ts +1 -0
  691. package/es/elements/typography/H3.js +1 -1
  692. package/es/elements/typography/H3.js.map +1 -1
  693. package/es/elements/typography/H4.d.ts +1 -0
  694. package/es/elements/typography/H4.js +1 -1
  695. package/es/elements/typography/H4.js.map +1 -1
  696. package/es/elements/typography/H5.d.ts +1 -0
  697. package/es/elements/typography/H5.js +1 -1
  698. package/es/elements/typography/H5.js.map +1 -1
  699. package/es/elements/typography/H6.d.ts +1 -0
  700. package/es/elements/typography/H6.js +1 -1
  701. package/es/elements/typography/H6.js.map +1 -1
  702. package/es/extensions/forms/DataContext/Context.d.ts +18 -5
  703. package/es/extensions/forms/DataContext/Context.js +9 -0
  704. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  705. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +57 -19
  706. package/es/extensions/forms/DataContext/Provider/Provider.js +127 -49
  707. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  708. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +5 -3
  709. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  710. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  711. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +6 -5
  712. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  713. package/es/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  714. package/es/extensions/forms/Field/Boolean/Boolean.js +2 -2
  715. package/es/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  716. package/es/extensions/forms/Field/Currency/Currency.d.ts +2 -2
  717. package/es/extensions/forms/Field/Currency/Currency.js +2 -2
  718. package/es/extensions/forms/Field/Currency/Currency.js.map +1 -1
  719. package/es/extensions/forms/Field/Date/Date.js +8 -4
  720. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  721. package/es/extensions/forms/Field/Email/Email.d.ts +2 -2
  722. package/es/extensions/forms/Field/Email/Email.js +7 -6
  723. package/es/extensions/forms/Field/Email/Email.js.map +1 -1
  724. package/es/extensions/forms/Field/Expiry/Expiry.js +19 -17
  725. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  726. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  727. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +6 -5
  728. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  729. package/es/extensions/forms/Field/Number/Number.d.ts +2 -4
  730. package/es/extensions/forms/Field/Number/Number.js +28 -27
  731. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  732. package/es/extensions/forms/Field/Number/style/dnb-number.css +0 -6
  733. package/es/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  734. package/es/extensions/forms/Field/Number/style/dnb-number.scss +0 -1
  735. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +4 -0
  736. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +1 -1
  737. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +7 -0
  738. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +4 -0
  739. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +1 -1
  740. package/es/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +9 -0
  741. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +2 -2
  742. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +6 -5
  743. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  744. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  745. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +17 -9
  746. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  747. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  748. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -3
  749. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  750. package/es/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.css +9 -0
  751. package/es/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.min.css +1 -1
  752. package/es/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.scss +7 -0
  753. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +9 -5
  754. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  755. package/es/extensions/forms/Field/Selection/Selection.js +15 -10
  756. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  757. package/es/extensions/forms/Field/String/String.d.ts +4 -2
  758. package/es/extensions/forms/Field/String/String.js +17 -9
  759. package/es/extensions/forms/Field/String/String.js.map +1 -1
  760. package/es/extensions/forms/Field/Toggle/Toggle.js +20 -13
  761. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  762. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +2 -2
  763. package/es/extensions/forms/FieldBlock/FieldBlock.js +11 -8
  764. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  765. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +22 -5
  766. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  767. package/es/extensions/forms/FieldBlock/style/dnb-field-block.scss +29 -1
  768. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.css +4 -0
  769. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.min.css +1 -0
  770. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.scss +6 -0
  771. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +4 -0
  772. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -0
  773. package/es/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +6 -0
  774. package/es/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  775. package/es/extensions/forms/Form/Handler/Handler.js +7 -1
  776. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  777. package/es/extensions/forms/Form/Visibility/Visibility.d.ts +6 -1
  778. package/es/extensions/forms/Form/Visibility/Visibility.js +55 -40
  779. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  780. package/es/extensions/forms/Form/data-context/getData.d.ts +8 -0
  781. package/es/extensions/forms/Form/data-context/getData.js +15 -0
  782. package/es/extensions/forms/Form/data-context/getData.js.map +1 -0
  783. package/es/extensions/forms/Form/data-context/setData.d.ts +2 -0
  784. package/es/extensions/forms/Form/data-context/setData.js +6 -0
  785. package/es/extensions/forms/Form/data-context/setData.js.map +1 -0
  786. package/es/extensions/forms/Form/data-context/useData.d.ts +22 -0
  787. package/es/extensions/forms/Form/data-context/useData.js +58 -0
  788. package/es/extensions/forms/Form/data-context/useData.js.map +1 -0
  789. package/es/extensions/forms/Form/data-context/useError.d.ts +5 -0
  790. package/es/extensions/forms/Form/data-context/useError.js +13 -0
  791. package/es/extensions/forms/Form/data-context/useError.js.map +1 -0
  792. package/es/extensions/forms/Form/index.d.ts +4 -1
  793. package/es/extensions/forms/Form/index.js +4 -1
  794. package/es/extensions/forms/Form/index.js.map +1 -1
  795. package/es/extensions/forms/Iterate/Array/Array.d.ts +2 -2
  796. package/es/extensions/forms/Iterate/Array/Array.js +3 -1
  797. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  798. package/es/extensions/forms/StepsLayout/StepsLayout.d.ts +3 -0
  799. package/es/extensions/forms/StepsLayout/StepsLayout.js +31 -22
  800. package/es/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  801. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -0
  802. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  803. package/es/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +7 -0
  804. package/es/extensions/forms/Value/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  805. package/es/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js +2 -2
  806. package/es/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js.map +1 -1
  807. package/es/extensions/forms/Value/Currency/Currency.d.ts +2 -2
  808. package/es/extensions/forms/Value/Currency/Currency.js +4 -5
  809. package/es/extensions/forms/Value/Currency/Currency.js.map +1 -1
  810. package/es/extensions/forms/Value/Date/Date.d.ts +2 -2
  811. package/es/extensions/forms/Value/Date/Date.js +2 -2
  812. package/es/extensions/forms/Value/Date/Date.js.map +1 -1
  813. package/es/extensions/forms/Value/Email/Email.d.ts +2 -2
  814. package/es/extensions/forms/Value/Email/Email.js +2 -2
  815. package/es/extensions/forms/Value/Email/Email.js.map +1 -1
  816. package/es/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  817. package/es/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js +2 -2
  818. package/es/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  819. package/es/extensions/forms/Value/Number/Number.d.ts +6 -10
  820. package/es/extensions/forms/Value/Number/Number.js +22 -27
  821. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  822. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.d.ts +2 -2
  823. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.js +8 -6
  824. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  825. package/es/extensions/forms/hooks/index.d.ts +1 -0
  826. package/es/extensions/forms/hooks/index.js +1 -0
  827. package/es/extensions/forms/hooks/index.js.map +1 -1
  828. package/es/extensions/forms/hooks/useDataValue.d.ts +10 -1
  829. package/es/extensions/forms/hooks/useDataValue.js +81 -24
  830. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  831. package/es/extensions/forms/hooks/useErrorMessage.d.ts +10 -0
  832. package/es/extensions/forms/hooks/useErrorMessage.js +15 -0
  833. package/es/extensions/forms/hooks/useErrorMessage.js.map +1 -0
  834. package/es/extensions/forms/index.d.ts +1 -0
  835. package/es/extensions/forms/index.js +1 -0
  836. package/es/extensions/forms/index.js.map +1 -1
  837. package/es/extensions/forms/style/dnb-forms.css +37 -11
  838. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  839. package/es/extensions/forms/types.d.ts +26 -9
  840. package/es/extensions/forms/types.js.map +1 -1
  841. package/es/extensions/forms/utils/ajv.d.ts +47 -6
  842. package/es/extensions/forms/utils/ajv.js +23 -15
  843. package/es/extensions/forms/utils/ajv.js.map +1 -1
  844. package/es/extensions/forms/utils/index.d.ts +0 -1
  845. package/es/extensions/forms/utils/index.js +0 -1
  846. package/es/extensions/forms/utils/index.js.map +1 -1
  847. package/es/fragments/TextCounter.d.ts +12 -0
  848. package/es/fragments/TextCounter.js +4 -0
  849. package/es/fragments/TextCounter.js.map +1 -0
  850. package/es/fragments/drawer-list/DrawerListHelpers.js +1 -0
  851. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  852. package/es/fragments/index.d.ts +2 -1
  853. package/es/fragments/index.js +2 -1
  854. package/es/fragments/index.js.map +1 -1
  855. package/es/fragments/lib.d.ts +3 -1
  856. package/es/fragments/lib.js +4 -2
  857. package/es/fragments/lib.js.map +1 -1
  858. package/es/fragments/text-counter/TextCounter.d.ts +8 -0
  859. package/es/fragments/text-counter/TextCounter.js +52 -0
  860. package/es/fragments/text-counter/TextCounter.js.map +1 -0
  861. package/es/fragments/text-counter/index.d.ts +5 -0
  862. package/es/fragments/text-counter/index.js +1 -0
  863. package/es/fragments/text-counter/index.js.map +1 -0
  864. package/es/fragments/text-counter/style/dnb-text-counter.scss +15 -0
  865. package/es/fragments/text-counter/style/index.d.ts +1 -0
  866. package/es/fragments/text-counter/style/index.js +1 -0
  867. package/es/fragments/text-counter/style/index.js.map +1 -0
  868. package/es/fragments/text-counter/style/themes/dnb-text-counter-theme-sbanken.scss +8 -0
  869. package/es/fragments/text-counter/style/themes/dnb-text-counter-theme-ui.scss +8 -0
  870. package/es/fragments/text-counter/style/themes/ui.d.ts +1 -0
  871. package/es/fragments/text-counter/style/themes/ui.js +1 -0
  872. package/es/fragments/text-counter/style/themes/ui.js.map +1 -0
  873. package/es/fragments/text-counter/style.d.ts +5 -0
  874. package/es/fragments/text-counter/style.js +1 -0
  875. package/es/fragments/text-counter/style.js.map +1 -0
  876. package/es/index.d.ts +2 -1
  877. package/es/index.js +2 -1
  878. package/es/index.js.map +1 -1
  879. package/es/shared/Eufemia.d.ts +1 -1
  880. package/es/shared/Eufemia.js +2 -2
  881. package/es/shared/Eufemia.js.map +1 -1
  882. package/es/shared/component-helper.js +0 -3
  883. package/es/shared/component-helper.js.map +1 -1
  884. package/es/shared/helpers/useSharedState.d.ts +33 -10
  885. package/es/shared/helpers/useSharedState.js +76 -40
  886. package/es/shared/helpers/useSharedState.js.map +1 -1
  887. package/es/shared/locales/en-GB.d.ts +7 -0
  888. package/es/shared/locales/en-GB.js +9 -2
  889. package/es/shared/locales/en-GB.js.map +1 -1
  890. package/es/shared/locales/en-US.d.ts +7 -0
  891. package/es/shared/locales/index.d.ts +14 -0
  892. package/es/shared/locales/nb-NO.d.ts +7 -0
  893. package/es/shared/locales/nb-NO.js +7 -0
  894. package/es/shared/locales/nb-NO.js.map +1 -1
  895. package/es/style/core/utilities.scss +1 -1
  896. package/es/style/dnb-ui-components.css +134 -67
  897. package/es/style/dnb-ui-components.min.css +3 -3
  898. package/es/style/dnb-ui-extensions.css +37 -11
  899. package/es/style/dnb-ui-extensions.min.css +1 -1
  900. package/es/style/dnb-ui-forms.css +37 -11
  901. package/es/style/dnb-ui-forms.min.css +1 -1
  902. package/es/style/dnb-ui-fragments.css +10 -0
  903. package/es/style/dnb-ui-fragments.min.css +1 -1
  904. package/es/style/dnb-ui-fragments.scss +1 -0
  905. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +203 -102
  906. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  907. package/es/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  908. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +46 -11
  909. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  910. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  911. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +46 -11
  912. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  913. package/es/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  914. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +188 -97
  915. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  916. package/es/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  917. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +46 -11
  918. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  919. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  920. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +46 -11
  921. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  922. package/es/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  923. package/es/style/themes/theme-ui/ui-theme-components.css +203 -102
  924. package/es/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  925. package/es/style/themes/theme-ui/ui-theme-components.scss +1 -0
  926. package/es/style/themes/theme-ui/ui-theme-extensions.css +46 -11
  927. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  928. package/es/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  929. package/es/style/themes/theme-ui/ui-theme-forms.css +46 -11
  930. package/es/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  931. package/es/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  932. package/esm/dnb-ui-basis.min.mjs +1 -1
  933. package/esm/dnb-ui-components.min.mjs +1 -1
  934. package/esm/dnb-ui-elements.min.mjs +1 -1
  935. package/esm/dnb-ui-extensions.min.mjs +3 -3
  936. package/esm/dnb-ui-lib.min.mjs +1 -1
  937. package/extensions/forms/DataContext/Context.d.ts +18 -5
  938. package/extensions/forms/DataContext/Context.js +9 -0
  939. package/extensions/forms/DataContext/Context.js.map +1 -1
  940. package/extensions/forms/DataContext/Provider/Provider.d.ts +57 -19
  941. package/extensions/forms/DataContext/Provider/Provider.js +129 -49
  942. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  943. package/extensions/forms/Field/ArraySelection/ArraySelection.js +5 -3
  944. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  945. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  946. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js +6 -5
  947. package/extensions/forms/Field/BankAccountNumber/BankAccountNumber.js.map +1 -1
  948. package/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  949. package/extensions/forms/Field/Boolean/Boolean.js +2 -2
  950. package/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  951. package/extensions/forms/Field/Currency/Currency.d.ts +2 -2
  952. package/extensions/forms/Field/Currency/Currency.js +2 -2
  953. package/extensions/forms/Field/Currency/Currency.js.map +1 -1
  954. package/extensions/forms/Field/Date/Date.js +8 -4
  955. package/extensions/forms/Field/Date/Date.js.map +1 -1
  956. package/extensions/forms/Field/Email/Email.d.ts +2 -2
  957. package/extensions/forms/Field/Email/Email.js +7 -6
  958. package/extensions/forms/Field/Email/Email.js.map +1 -1
  959. package/extensions/forms/Field/Expiry/Expiry.js +19 -17
  960. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  961. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  962. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +6 -5
  963. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  964. package/extensions/forms/Field/Number/Number.d.ts +2 -4
  965. package/extensions/forms/Field/Number/Number.js +28 -27
  966. package/extensions/forms/Field/Number/Number.js.map +1 -1
  967. package/extensions/forms/Field/Number/style/dnb-number.css +0 -6
  968. package/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  969. package/extensions/forms/Field/Number/style/dnb-number.scss +0 -1
  970. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.css +4 -0
  971. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.min.css +1 -1
  972. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-sbanken.scss +7 -0
  973. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.css +4 -0
  974. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.min.css +1 -1
  975. package/extensions/forms/Field/Number/style/themes/dnb-number-theme-ui.scss +9 -0
  976. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +2 -2
  977. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +6 -5
  978. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  979. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +2 -2
  980. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +17 -9
  981. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  982. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.d.ts +2 -2
  983. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js +3 -3
  984. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCity.js.map +1 -1
  985. package/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.css +9 -0
  986. package/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.min.css +1 -1
  987. package/extensions/forms/Field/PostalCodeAndCity/style/dnb-postal-code-and-city.scss +7 -0
  988. package/extensions/forms/Field/SelectCountry/SelectCountry.js +9 -5
  989. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  990. package/extensions/forms/Field/Selection/Selection.js +15 -10
  991. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  992. package/extensions/forms/Field/String/String.d.ts +4 -2
  993. package/extensions/forms/Field/String/String.js +17 -9
  994. package/extensions/forms/Field/String/String.js.map +1 -1
  995. package/extensions/forms/Field/Toggle/Toggle.js +20 -13
  996. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  997. package/extensions/forms/FieldBlock/FieldBlock.d.ts +2 -2
  998. package/extensions/forms/FieldBlock/FieldBlock.js +11 -8
  999. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  1000. package/extensions/forms/FieldBlock/style/dnb-field-block.css +22 -5
  1001. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  1002. package/extensions/forms/FieldBlock/style/dnb-field-block.scss +29 -1
  1003. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.css +4 -0
  1004. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.min.css +1 -0
  1005. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-sbanken.scss +6 -0
  1006. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.css +4 -0
  1007. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.min.css +1 -0
  1008. package/extensions/forms/FieldBlock/style/themes/dnb-field-block-theme-ui.scss +6 -0
  1009. package/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  1010. package/extensions/forms/Form/Handler/Handler.js +7 -1
  1011. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  1012. package/extensions/forms/Form/Visibility/Visibility.d.ts +6 -1
  1013. package/extensions/forms/Form/Visibility/Visibility.js +53 -39
  1014. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  1015. package/extensions/forms/Form/data-context/getData.d.ts +8 -0
  1016. package/extensions/forms/Form/data-context/getData.js +15 -0
  1017. package/extensions/forms/Form/data-context/getData.js.map +1 -0
  1018. package/extensions/forms/Form/data-context/setData.d.ts +2 -0
  1019. package/extensions/forms/Form/data-context/setData.js +6 -0
  1020. package/extensions/forms/Form/data-context/setData.js.map +1 -0
  1021. package/extensions/forms/Form/data-context/useData.d.ts +22 -0
  1022. package/extensions/forms/Form/data-context/useData.js +59 -0
  1023. package/extensions/forms/Form/data-context/useData.js.map +1 -0
  1024. package/extensions/forms/Form/data-context/useError.d.ts +5 -0
  1025. package/extensions/forms/Form/data-context/useError.js +13 -0
  1026. package/extensions/forms/Form/data-context/useError.js.map +1 -0
  1027. package/extensions/forms/Form/index.d.ts +4 -1
  1028. package/extensions/forms/Form/index.js +4 -1
  1029. package/extensions/forms/Form/index.js.map +1 -1
  1030. package/extensions/forms/Iterate/Array/Array.d.ts +2 -2
  1031. package/extensions/forms/Iterate/Array/Array.js +3 -1
  1032. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  1033. package/extensions/forms/StepsLayout/StepsLayout.d.ts +3 -0
  1034. package/extensions/forms/StepsLayout/StepsLayout.js +31 -22
  1035. package/extensions/forms/StepsLayout/StepsLayout.js.map +1 -1
  1036. package/extensions/forms/StepsLayout/style/dnb-steps-layout.css +6 -0
  1037. package/extensions/forms/StepsLayout/style/dnb-steps-layout.min.css +1 -1
  1038. package/extensions/forms/StepsLayout/style/dnb-steps-layout.scss +7 -0
  1039. package/extensions/forms/Value/BankAccountNumber/BankAccountNumber.d.ts +2 -2
  1040. package/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js +2 -2
  1041. package/extensions/forms/Value/BankAccountNumber/BankAccountNumber.js.map +1 -1
  1042. package/extensions/forms/Value/Currency/Currency.d.ts +2 -2
  1043. package/extensions/forms/Value/Currency/Currency.js +4 -5
  1044. package/extensions/forms/Value/Currency/Currency.js.map +1 -1
  1045. package/extensions/forms/Value/Date/Date.d.ts +2 -2
  1046. package/extensions/forms/Value/Date/Date.js +2 -2
  1047. package/extensions/forms/Value/Date/Date.js.map +1 -1
  1048. package/extensions/forms/Value/Email/Email.d.ts +2 -2
  1049. package/extensions/forms/Value/Email/Email.js +2 -2
  1050. package/extensions/forms/Value/Email/Email.js.map +1 -1
  1051. package/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.d.ts +2 -2
  1052. package/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js +2 -2
  1053. package/extensions/forms/Value/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  1054. package/extensions/forms/Value/Number/Number.d.ts +6 -10
  1055. package/extensions/forms/Value/Number/Number.js +22 -27
  1056. package/extensions/forms/Value/Number/Number.js.map +1 -1
  1057. package/extensions/forms/Value/PhoneNumber/PhoneNumber.d.ts +2 -2
  1058. package/extensions/forms/Value/PhoneNumber/PhoneNumber.js +8 -6
  1059. package/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  1060. package/extensions/forms/hooks/index.d.ts +1 -0
  1061. package/extensions/forms/hooks/index.js +1 -0
  1062. package/extensions/forms/hooks/index.js.map +1 -1
  1063. package/extensions/forms/hooks/useDataValue.d.ts +10 -1
  1064. package/extensions/forms/hooks/useDataValue.js +85 -26
  1065. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  1066. package/extensions/forms/hooks/useErrorMessage.d.ts +10 -0
  1067. package/extensions/forms/hooks/useErrorMessage.js +15 -0
  1068. package/extensions/forms/hooks/useErrorMessage.js.map +1 -0
  1069. package/extensions/forms/index.d.ts +1 -0
  1070. package/extensions/forms/index.js +1 -0
  1071. package/extensions/forms/index.js.map +1 -1
  1072. package/extensions/forms/style/dnb-forms.css +37 -11
  1073. package/extensions/forms/style/dnb-forms.min.css +1 -1
  1074. package/extensions/forms/types.d.ts +26 -9
  1075. package/extensions/forms/types.js.map +1 -1
  1076. package/extensions/forms/utils/ajv.d.ts +47 -6
  1077. package/extensions/forms/utils/ajv.js +23 -15
  1078. package/extensions/forms/utils/ajv.js.map +1 -1
  1079. package/extensions/forms/utils/index.d.ts +0 -1
  1080. package/extensions/forms/utils/index.js +0 -1
  1081. package/extensions/forms/utils/index.js.map +1 -1
  1082. package/fragments/TextCounter.d.ts +12 -0
  1083. package/fragments/TextCounter.js +4 -0
  1084. package/fragments/TextCounter.js.map +1 -0
  1085. package/fragments/drawer-list/DrawerListHelpers.js +1 -0
  1086. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  1087. package/fragments/index.d.ts +2 -1
  1088. package/fragments/index.js +2 -1
  1089. package/fragments/index.js.map +1 -1
  1090. package/fragments/lib.d.ts +3 -1
  1091. package/fragments/lib.js +4 -2
  1092. package/fragments/lib.js.map +1 -1
  1093. package/fragments/text-counter/TextCounter.d.ts +8 -0
  1094. package/fragments/text-counter/TextCounter.js +52 -0
  1095. package/fragments/text-counter/TextCounter.js.map +1 -0
  1096. package/fragments/text-counter/index.d.ts +5 -0
  1097. package/fragments/text-counter/index.js +1 -0
  1098. package/fragments/text-counter/index.js.map +1 -0
  1099. package/fragments/text-counter/style/dnb-text-counter.scss +15 -0
  1100. package/fragments/text-counter/style/index.d.ts +1 -0
  1101. package/fragments/text-counter/style/index.js +1 -0
  1102. package/fragments/text-counter/style/index.js.map +1 -0
  1103. package/fragments/text-counter/style/themes/dnb-text-counter-theme-sbanken.scss +8 -0
  1104. package/fragments/text-counter/style/themes/dnb-text-counter-theme-ui.scss +8 -0
  1105. package/fragments/text-counter/style/themes/ui.d.ts +1 -0
  1106. package/fragments/text-counter/style/themes/ui.js +1 -0
  1107. package/fragments/text-counter/style/themes/ui.js.map +1 -0
  1108. package/fragments/text-counter/style.d.ts +5 -0
  1109. package/fragments/text-counter/style.js +1 -0
  1110. package/fragments/text-counter/style.js.map +1 -0
  1111. package/index.d.ts +2 -1
  1112. package/index.js +2 -1
  1113. package/index.js.map +1 -1
  1114. package/package.json +1 -1
  1115. package/shared/Eufemia.d.ts +1 -1
  1116. package/shared/Eufemia.js +2 -2
  1117. package/shared/Eufemia.js.map +1 -1
  1118. package/shared/component-helper.js +0 -3
  1119. package/shared/component-helper.js.map +1 -1
  1120. package/shared/helpers/useSharedState.d.ts +33 -10
  1121. package/shared/helpers/useSharedState.js +78 -40
  1122. package/shared/helpers/useSharedState.js.map +1 -1
  1123. package/shared/locales/en-GB.d.ts +7 -0
  1124. package/shared/locales/en-GB.js +9 -2
  1125. package/shared/locales/en-GB.js.map +1 -1
  1126. package/shared/locales/en-US.d.ts +7 -0
  1127. package/shared/locales/index.d.ts +14 -0
  1128. package/shared/locales/nb-NO.d.ts +7 -0
  1129. package/shared/locales/nb-NO.js +7 -0
  1130. package/shared/locales/nb-NO.js.map +1 -1
  1131. package/style/core/utilities.scss +1 -1
  1132. package/style/dnb-ui-components.css +134 -67
  1133. package/style/dnb-ui-components.min.css +3 -3
  1134. package/style/dnb-ui-extensions.css +37 -11
  1135. package/style/dnb-ui-extensions.min.css +1 -1
  1136. package/style/dnb-ui-forms.css +37 -11
  1137. package/style/dnb-ui-forms.min.css +1 -1
  1138. package/style/dnb-ui-fragments.css +10 -0
  1139. package/style/dnb-ui-fragments.min.css +1 -1
  1140. package/style/dnb-ui-fragments.scss +1 -0
  1141. package/style/themes/theme-eiendom/eiendom-theme-components.css +203 -102
  1142. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +7 -7
  1143. package/style/themes/theme-eiendom/eiendom-theme-components.scss +1 -0
  1144. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +46 -11
  1145. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  1146. package/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  1147. package/style/themes/theme-eiendom/eiendom-theme-forms.css +46 -11
  1148. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  1149. package/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  1150. package/style/themes/theme-sbanken/sbanken-theme-components.css +188 -97
  1151. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +6 -6
  1152. package/style/themes/theme-sbanken/sbanken-theme-components.scss +1 -0
  1153. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +46 -11
  1154. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  1155. package/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  1156. package/style/themes/theme-sbanken/sbanken-theme-forms.css +46 -11
  1157. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  1158. package/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  1159. package/style/themes/theme-ui/ui-theme-components.css +203 -102
  1160. package/style/themes/theme-ui/ui-theme-components.min.css +7 -7
  1161. package/style/themes/theme-ui/ui-theme-components.scss +1 -0
  1162. package/style/themes/theme-ui/ui-theme-extensions.css +46 -11
  1163. package/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  1164. package/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  1165. package/style/themes/theme-ui/ui-theme-forms.css +46 -11
  1166. package/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  1167. package/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  1168. package/umd/dnb-ui-basis.min.js +1 -1
  1169. package/umd/dnb-ui-components.min.js +1 -1
  1170. package/umd/dnb-ui-elements.min.js +1 -1
  1171. package/umd/dnb-ui-extensions.min.js +3 -3
  1172. package/umd/dnb-ui-lib.min.js +1 -1
  1173. package/cjs/components/global-status/AnimationHelper.d.ts +0 -12
  1174. package/cjs/components/global-status/AnimationHelper.js +0 -109
  1175. package/cjs/components/global-status/AnimationHelper.js.map +0 -1
  1176. package/cjs/extensions/forms/Form/hooks/useData.d.ts +0 -10
  1177. package/cjs/extensions/forms/Form/hooks/useData.js +0 -36
  1178. package/cjs/extensions/forms/Form/hooks/useData.js.map +0 -1
  1179. package/cjs/extensions/forms/utils/numbers.d.ts +0 -17
  1180. package/cjs/extensions/forms/utils/numbers.js +0 -42
  1181. package/cjs/extensions/forms/utils/numbers.js.map +0 -1
  1182. package/components/global-status/AnimationHelper.d.ts +0 -12
  1183. package/components/global-status/AnimationHelper.js +0 -100
  1184. package/components/global-status/AnimationHelper.js.map +0 -1
  1185. package/es/components/global-status/AnimationHelper.d.ts +0 -12
  1186. package/es/components/global-status/AnimationHelper.js +0 -100
  1187. package/es/components/global-status/AnimationHelper.js.map +0 -1
  1188. package/es/extensions/forms/Form/hooks/useData.d.ts +0 -10
  1189. package/es/extensions/forms/Form/hooks/useData.js +0 -29
  1190. package/es/extensions/forms/Form/hooks/useData.js.map +0 -1
  1191. package/es/extensions/forms/utils/numbers.d.ts +0 -17
  1192. package/es/extensions/forms/utils/numbers.js +0 -35
  1193. package/es/extensions/forms/utils/numbers.js.map +0 -1
  1194. package/extensions/forms/Form/hooks/useData.d.ts +0 -10
  1195. package/extensions/forms/Form/hooks/useData.js +0 -30
  1196. package/extensions/forms/Form/hooks/useData.js.map +0 -1
  1197. package/extensions/forms/utils/numbers.d.ts +0 -17
  1198. package/extensions/forms/utils/numbers.js +0 -35
  1199. package/extensions/forms/utils/numbers.js.map +0 -1
@@ -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","_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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"}
1
+ {"version":3,"file":"Textarea.js","names":["React","PropTypes","classnames","FormLabel","FormStatus","TextCounter","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","characterCounter","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","top","max","lang","locale","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","variant","_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 TextCounter from '../../fragments/text-counter/TextCounter'\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 characterCounter: PropTypes.oneOfType([\n PropTypes.shape({\n max: PropTypes.number,\n variant: PropTypes.oneOf(['down', 'up']),\n }),\n PropTypes.number,\n ]),\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 characterCounter: 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 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 autoresize,\n characterCounter,\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 name: id,\n disabled: isTrue(disabled) || isTrue(skeleton),\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\n {characterCounter && (\n <TextCounter\n top=\"x-small\"\n text={value}\n max={characterCounter}\n lang={this.props.lang}\n locale={this.props.locale}\n {...characterCounter}\n />\n )}\n </span>\n </span>\n )\n }\n}\n\nTextarea._formElement = true\nTextarea._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -16,7 +16,7 @@
16
16
  .dnb-textarea__inner {
17
17
  display: inline-flex;
18
18
  flex-direction: column;
19
- margin: var(--textarea-padding-width);
19
+ margin: 0 var(--textarea-padding-width);
20
20
  }
21
21
  .dnb-textarea__shell {
22
22
  display: inline-flex;
@@ -31,15 +31,22 @@
31
31
  bottom: -0.5rem;
32
32
  right: -0.5rem;
33
33
  background-color: var(--color-white);
34
- box-shadow: 0 0 0 0.0625rem var(--color-sea-green);
34
+ --border-color: var(--textarea-border-color);
35
+ --border-width: var(--textarea-border-width);
36
+ box-shadow: inset 0 0 0 var(--border-width) var(--border-color);
37
+ border-color: transparent;
35
38
  border-radius: 0.25rem;
36
39
  }
37
40
  .dnb-textarea__row {
38
41
  display: inline-flex;
42
+ margin: var(--textarea-padding-width) 0;
39
43
  }
40
44
  .dnb-textarea__suffix.dnb-suffix {
41
45
  padding-left: 1rem;
42
46
  }
47
+ .dnb-textarea .dnb-text-counter {
48
+ margin-left: -0.5rem;
49
+ }
43
50
  .dnb-textarea__textarea {
44
51
  position: relative;
45
52
  z-index: 2;
@@ -130,7 +137,7 @@ html:not([data-visual-test]) .dnb-textarea__textarea {
130
137
  }
131
138
  .dnb-textarea__inner > .dnb-form-status {
132
139
  order: 2;
133
- margin: 1rem 0 0 calc(0px - var(--textarea-padding-width));
140
+ margin: 0.5rem 0 0 calc(0px - var(--textarea-padding-width));
134
141
  }
135
142
  .dnb-textarea:not(.dnb-textarea--vertical) .dnb-form-label {
136
143
  margin-top: 0.5rem;
@@ -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)}}@-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}
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:0 var(--textarea-padding-width)}.dnb-textarea__shell{display:inline-flex;font-size:var(--font-size-basis);position:relative}.dnb-textarea__state{--border-color:var(--textarea-border-color);--border-width:var(--textarea-border-width);background-color:var(--color-white);border-color:transparent;border-radius:.25rem;bottom:-.5rem;box-shadow:inset 0 0 0 var(--border-width) var(--border-color);left:-.5rem;position:absolute;right:-.5rem;top:-.5rem;z-index:1}.dnb-textarea__row{display:inline-flex;margin:var(--textarea-padding-width) 0}.dnb-textarea__suffix.dnb-suffix{padding-left:1rem}.dnb-textarea .dnb-text-counter{margin-left:-.5rem}.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:.5rem 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}
@@ -31,7 +31,7 @@
31
31
  display: inline-flex;
32
32
  flex-direction: column;
33
33
 
34
- margin: var(--textarea-padding-width);
34
+ margin: 0 var(--textarea-padding-width);
35
35
  }
36
36
 
37
37
  &__shell {
@@ -51,19 +51,29 @@
51
51
  right: -0.5rem;
52
52
 
53
53
  background-color: var(--color-white);
54
- box-shadow: 0 0 0 0.0625rem var(--color-sea-green);
54
+ @include fakeBorder(
55
+ var(--textarea-border-color),
56
+ var(--textarea-border-width),
57
+ inset
58
+ );
55
59
 
56
60
  border-radius: 0.25rem;
57
61
  }
58
62
 
59
63
  &__row {
60
64
  display: inline-flex;
65
+
66
+ margin: var(--textarea-padding-width) 0;
61
67
  }
62
68
 
63
69
  &__suffix.dnb-suffix {
64
70
  padding-left: 1rem;
65
71
  }
66
72
 
73
+ .dnb-text-counter {
74
+ margin-left: -0.5rem;
75
+ }
76
+
67
77
  &__textarea {
68
78
  position: relative;
69
79
  z-index: 2;
@@ -138,7 +148,7 @@
138
148
 
139
149
  &__inner > .dnb-form-status {
140
150
  order: 2;
141
- margin: 1rem 0 0 calc(1px - 1px - var(--textarea-padding-width));
151
+ margin: 0.5rem 0 0 calc(1px - 1px - var(--textarea-padding-width));
142
152
  }
143
153
 
144
154
  &:not(#{&}--vertical) .dnb-form-label {
@@ -5,6 +5,13 @@
5
5
  /*
6
6
  * Utilities
7
7
  */
8
+ .dnb-textarea {
9
+ --textarea-border-color: var(--color-sea-green);
10
+ --textarea-border-color--hover: var(--color-emerald-green);
11
+ --textarea-border-color--disabled: var(--color-black-55);
12
+ --textarea-border-width: 0.0625rem;
13
+ --textarea-border-width--hover: 0.125rem;
14
+ }
8
15
  .dnb-textarea__textarea {
9
16
  color: var(--color-black);
10
17
  background-color: var(--textarea-background-color);
@@ -18,14 +25,20 @@
18
25
  color: var(--color-black-55);
19
26
  }
20
27
  .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):focus ~ .dnb-textarea__state, .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover ~ .dnb-textarea__state {
21
- box-shadow: 0 0 0 0.125rem var(--color-emerald-green);
28
+ --border-color: var(--textarea-border-color--hover);
29
+ --border-width: var(--textarea-border-width--hover);
30
+ box-shadow: 0 0 0 var(--border-width) var(--border-color);
31
+ border-color: transparent;
22
32
  }
23
33
  .dnb-textarea--disabled .dnb-textarea__textarea, .dnb-textarea__textarea[disabled] {
24
34
  color: var(--color-black-55);
25
35
  background-color: var(--color-black-3);
26
36
  }
27
37
  .dnb-textarea--disabled .dnb-textarea__state, .dnb-textarea__textarea[disabled] ~ .dnb-textarea__state {
28
- box-shadow: 0 0 0 0.0625rem var(--color-black-55);
38
+ --border-color: var(--textarea-border-color--disabled);
39
+ --border-width: var(--textarea-border-width);
40
+ box-shadow: inset 0 0 0 var(--border-width) var(--border-color);
41
+ border-color: transparent;
29
42
  background-color: var(--color-black-3);
30
43
  }
31
44
  .dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled), .dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover {
@@ -1 +1 @@
1
- .dnb-textarea__textarea{background-color:var(--textarea-background-color);color:var(--color-black)}.dnb-textarea__textarea ::selection{background-color:var(--color-mint-green);color:var(--color-black);text-shadow:none}.dnb-textarea__placeholder{color:var(--color-black-55)}.dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):focus~.dnb-textarea__state,.dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover~.dnb-textarea__state{box-shadow:0 0 0 .125rem var(--color-emerald-green)}.dnb-textarea--disabled .dnb-textarea__textarea,.dnb-textarea__textarea[disabled]{background-color:var(--color-black-3);color:var(--color-black-55)}.dnb-textarea--disabled .dnb-textarea__state,.dnb-textarea__textarea[disabled]~.dnb-textarea__state{background-color:var(--color-black-3);box-shadow:0 0 0 .0625rem var(--color-black-55)}.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled),.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover{color:var(--color-fire-red)}.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled)~.dnb-textarea__state{--border-color:var(--color-fire-red);--border-width:0.0625rem;border-color:transparent;box-shadow:0 0 0 var(--border-width) var(--border-color)}.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover~.dnb-textarea__state{--border-color:var(--color-fire-red);--border-width:0.125rem;border-color:transparent;box-shadow:0 0 0 var(--border-width) var(--border-color)}
1
+ .dnb-textarea{--textarea-border-color:var(--color-sea-green);--textarea-border-color--hover:var(--color-emerald-green);--textarea-border-color--disabled:var(--color-black-55);--textarea-border-width:0.0625rem;--textarea-border-width--hover:0.125rem}.dnb-textarea__textarea{background-color:var(--textarea-background-color);color:var(--color-black)}.dnb-textarea__textarea ::selection{background-color:var(--color-mint-green);color:var(--color-black);text-shadow:none}.dnb-textarea__placeholder{color:var(--color-black-55)}.dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):focus~.dnb-textarea__state,.dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover~.dnb-textarea__state{--border-color:var(--textarea-border-color--hover);--border-width:var(--textarea-border-width--hover);border-color:transparent;box-shadow:0 0 0 var(--border-width) var(--border-color)}.dnb-textarea--disabled .dnb-textarea__textarea,.dnb-textarea__textarea[disabled]{background-color:var(--color-black-3);color:var(--color-black-55)}.dnb-textarea--disabled .dnb-textarea__state,.dnb-textarea__textarea[disabled]~.dnb-textarea__state{--border-color:var(--textarea-border-color--disabled);--border-width:var(--textarea-border-width);background-color:var(--color-black-3);border-color:transparent;box-shadow:inset 0 0 0 var(--border-width) var(--border-color)}.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled),.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover{color:var(--color-fire-red)}.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled)~.dnb-textarea__state{--border-color:var(--color-fire-red);--border-width:0.0625rem;border-color:transparent;box-shadow:0 0 0 var(--border-width) var(--border-color)}.dnb-textarea__status--error:not(.dnb-textarea--focus) .dnb-textarea__textarea:not([disabled]):not(.dnb-textarea--disabled):hover~.dnb-textarea__state{--border-color:var(--color-fire-red);--border-width:0.125rem;border-color:transparent;box-shadow:0 0 0 var(--border-width) var(--border-color)}
@@ -6,6 +6,12 @@
6
6
  @import '../../../../style/core/utilities.scss';
7
7
 
8
8
  .dnb-textarea {
9
+ --textarea-border-color: var(--color-sea-green);
10
+ --textarea-border-color--hover: var(--color-emerald-green);
11
+ --textarea-border-color--disabled: var(--color-black-55);
12
+ --textarea-border-width: 0.0625rem;
13
+ --textarea-border-width--hover: 0.125rem;
14
+
9
15
  &__textarea {
10
16
  color: var(--color-black);
11
17
  background-color: var(--textarea-background-color);
@@ -23,7 +29,10 @@
23
29
 
24
30
  &__textarea:not([disabled]):not(#{&}--disabled):focus ~ &__state,
25
31
  &__textarea:not([disabled]):not(#{&}--disabled):hover ~ &__state {
26
- box-shadow: 0 0 0 0.125rem var(--color-emerald-green);
32
+ @include fakeBorder(
33
+ var(--textarea-border-color--hover),
34
+ var(--textarea-border-width--hover)
35
+ );
27
36
  }
28
37
 
29
38
  // We may enable this in future – right now it's unclear
@@ -41,7 +50,11 @@
41
50
 
42
51
  &--disabled &__state,
43
52
  &__textarea[disabled] ~ &__state {
44
- box-shadow: 0 0 0 0.0625rem var(--color-black-55);
53
+ @include fakeBorder(
54
+ var(--textarea-border-color--disabled),
55
+ var(--textarea-border-width),
56
+ inset
57
+ );
45
58
  background-color: var(--color-black-3);
46
59
  }
47
60
 
@@ -8,7 +8,7 @@ const _excluded = ["buttonTextSingular", "textSingular"],
8
8
  _excluded2 = ["id", "skeleton", "className", "acceptedFileTypes", "filesAmountLimit", "fileMaxSize", "onChange", "onFileDelete", "title", "text", "fileTypeDescription", "fileSizeDescription", "fileAmountDescription", "fileSizeContent", "buttonText", "loadingText", "errorLargeFile", "errorUnsupportedFile", "errorAmountLimit", "deleteButton", "fileListAriaLabel"];
9
9
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
10
10
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
11
- import React from 'react';
11
+ import React, { useCallback } from 'react';
12
12
  import classnames from 'classnames';
13
13
  import { createSpacingClasses } from '../space/SpacingHelper';
14
14
  import Provider from '../../shared/Provider';
@@ -68,22 +68,7 @@ const Upload = localProps => {
68
68
  setInternalFiles,
69
69
  getExistingFile
70
70
  } = useUpload(id);
71
- const filesRef = React.useRef(files);
72
- React.useEffect(() => {
73
- filesRef.current = files;
74
- });
75
- return React.createElement(UploadContext.Provider, {
76
- value: _objectSpread(_objectSpread({}, extendedProps), {}, {
77
- id,
78
- onInputUpload
79
- })
80
- }, React.createElement(Provider, {
81
- skeleton: skeleton
82
- }, React.createElement(UploadDropzone, _extends({
83
- className: classnames('dnb-upload', spacingClasses, className)
84
- }, props), _UploadInfo || (_UploadInfo = React.createElement(UploadInfo, null)), _UploadFileInput || (_UploadFileInput = React.createElement(UploadFileInput, null)), _UploadFileList || (_UploadFileList = React.createElement(UploadFileList, null)))));
85
- function onInputUpload(newFiles) {
86
- const files = filesRef.current;
71
+ const onInputUpload = useCallback(newFiles => {
87
72
  const mergedFiles = [...files, ...newFiles.map(fileItem => {
88
73
  const {
89
74
  file
@@ -110,7 +95,17 @@ const Upload = localProps => {
110
95
  });
111
96
  }
112
97
  return validFiles;
113
- }
98
+ }, [acceptedFileTypes, errorLargeFile, errorUnsupportedFile, fileMaxSize, files, filesAmountLimit, getExistingFile, onChange, setFiles, setInternalFiles]);
99
+ return React.createElement(UploadContext.Provider, {
100
+ value: _objectSpread(_objectSpread({}, extendedProps), {}, {
101
+ id,
102
+ onInputUpload
103
+ })
104
+ }, React.createElement(Provider, {
105
+ skeleton: skeleton
106
+ }, React.createElement(UploadDropzone, _extends({
107
+ className: classnames('dnb-upload', spacingClasses, className)
108
+ }, props), _UploadInfo || (_UploadInfo = React.createElement(UploadInfo, null)), _UploadFileInput || (_UploadFileInput = React.createElement(UploadFileInput, null)), _UploadFileList || (_UploadFileList = React.createElement(UploadFileList, null)))));
114
109
  };
115
110
  Upload.useUpload = useUpload;
116
111
  Upload._formElement = true;
@@ -1 +1 @@
1
- {"version":3,"file":"Upload.js","names":["React","classnames","createSpacingClasses","Provider","Context","extendPropsWithContext","makeUniqueId","UploadFileInput","useUpload","UploadDropzone","UploadContext","defaultProps","verifyFiles","UploadFileList","UploadInfo","Upload","localProps","context","useContext","_context$getTranslati","getTranslation","buttonTextSingular","textSingular","translations","_objectWithoutProperties","_excluded","filesAmountLimit","buttonText","text","extendedProps","skeleton","id","className","acceptedFileTypes","fileMaxSize","onChange","onFileDelete","title","fileTypeDescription","fileSizeDescription","fileAmountDescription","fileSizeContent","loadingText","errorLargeFile","errorUnsupportedFile","errorAmountLimit","deleteButton","fileListAriaLabel","props","_excluded2","spacingClasses","files","setFiles","setInternalFiles","getExistingFile","filesRef","useRef","useEffect","current","createElement","value","_objectSpread","onInputUpload","_extends","_UploadInfo","_UploadFileInput","_UploadFileList","newFiles","mergedFiles","map","fileItem","file","existingFile","exists","Boolean","verifiedFiles","filter","validFiles","slice","_formElement","_supportsSpacingProps"],"sources":["../../../../src/components/upload/Upload.tsx"],"sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\n\n// Shared\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport Provider from '../../shared/Provider'\nimport Context from '../../shared/Context'\nimport {\n extendPropsWithContext,\n makeUniqueId,\n} from '../../shared/component-helper'\n\n// Internal\nimport UploadFileInput from './UploadFileInput'\nimport useUpload from './useUpload'\nimport UploadDropzone from './UploadDropzone'\nimport { UploadContext, defaultProps } from './UploadContext'\nimport { verifyFiles } from './UploadVerify'\n\nimport type { UploadFile, UploadAllProps } from './types'\nimport UploadFileList from './UploadFileList'\nimport UploadInfo from './UploadInfo'\n\nexport { defaultProps }\n\nconst Upload = (localProps: UploadAllProps) => {\n const context = React.useContext(Context)\n\n const { buttonTextSingular, textSingular, ...translations } =\n context.getTranslation(localProps).Upload\n\n if (localProps?.filesAmountLimit === 1) {\n translations.buttonText = buttonTextSingular\n translations.text = textSingular\n }\n\n const extendedProps = extendPropsWithContext(\n localProps,\n defaultProps,\n { skeleton: context?.skeleton },\n translations,\n context.Upload\n )\n\n const {\n id,\n skeleton,\n className,\n acceptedFileTypes,\n filesAmountLimit,\n fileMaxSize,\n onChange,\n onFileDelete, // eslint-disable-line\n title, // eslint-disable-line\n text, // eslint-disable-line\n fileTypeDescription, // eslint-disable-line\n fileSizeDescription, // eslint-disable-line\n fileAmountDescription, // eslint-disable-line\n fileSizeContent, // eslint-disable-line\n buttonText, // eslint-disable-line\n loadingText, // eslint-disable-line\n errorLargeFile,\n errorUnsupportedFile,\n errorAmountLimit, // eslint-disable-line\n deleteButton, // eslint-disable-line\n fileListAriaLabel, // eslint-disable-line\n ...props\n } = extendedProps\n\n const spacingClasses = createSpacingClasses(props)\n\n const { files, setFiles, setInternalFiles, getExistingFile } =\n useUpload(id)\n\n const filesRef = React.useRef<UploadFile[]>(files)\n React.useEffect(() => {\n filesRef.current = files\n }) // keep our ref updated on every re-render\n\n return (\n <UploadContext.Provider\n value={{\n ...extendedProps,\n id,\n onInputUpload,\n }}\n >\n <Provider skeleton={skeleton}>\n <UploadDropzone\n className={classnames('dnb-upload', spacingClasses, className)}\n {...props}\n >\n <UploadInfo />\n\n <UploadFileInput />\n\n <UploadFileList />\n </UploadDropzone>\n </Provider>\n </UploadContext.Provider>\n )\n\n function onInputUpload(newFiles: UploadFile[]) {\n const files = filesRef.current\n const mergedFiles = [\n ...files,\n ...newFiles.map((fileItem) => {\n const { file } = fileItem\n\n const existingFile = getExistingFile(file, files)\n\n fileItem.exists = Boolean(existingFile)\n fileItem.id = fileItem.exists ? existingFile.id : makeUniqueId()\n\n return fileItem\n }),\n ]\n\n const verifiedFiles = verifyFiles(\n mergedFiles.filter(({ exists }) => !exists),\n {\n fileMaxSize,\n acceptedFileTypes,\n errorUnsupportedFile,\n errorLargeFile,\n }\n )\n\n const validFiles = [...verifiedFiles].slice(0, filesAmountLimit)\n\n setFiles(validFiles)\n setInternalFiles(mergedFiles)\n\n if (typeof onChange === 'function') {\n onChange({ files: validFiles })\n }\n\n return validFiles\n }\n}\n\nUpload.useUpload = useUpload\n\nUpload._formElement = true\nUpload._supportsSpacingProps = true\n\nexport default Upload\n"],"mappings":"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"}
1
+ {"version":3,"file":"Upload.js","names":["React","useCallback","classnames","createSpacingClasses","Provider","Context","extendPropsWithContext","makeUniqueId","UploadFileInput","useUpload","UploadDropzone","UploadContext","defaultProps","verifyFiles","UploadFileList","UploadInfo","Upload","localProps","context","useContext","_context$getTranslati","getTranslation","buttonTextSingular","textSingular","translations","_objectWithoutProperties","_excluded","filesAmountLimit","buttonText","text","extendedProps","skeleton","id","className","acceptedFileTypes","fileMaxSize","onChange","onFileDelete","title","fileTypeDescription","fileSizeDescription","fileAmountDescription","fileSizeContent","loadingText","errorLargeFile","errorUnsupportedFile","errorAmountLimit","deleteButton","fileListAriaLabel","props","_excluded2","spacingClasses","files","setFiles","setInternalFiles","getExistingFile","onInputUpload","newFiles","mergedFiles","map","fileItem","file","existingFile","exists","Boolean","verifiedFiles","filter","validFiles","slice","createElement","value","_objectSpread","_extends","_UploadInfo","_UploadFileInput","_UploadFileList","_formElement","_supportsSpacingProps"],"sources":["../../../../src/components/upload/Upload.tsx"],"sourcesContent":["import React, { useCallback } from 'react'\nimport classnames from 'classnames'\n\n// Shared\nimport { createSpacingClasses } from '../space/SpacingHelper'\nimport Provider from '../../shared/Provider'\nimport Context from '../../shared/Context'\nimport {\n extendPropsWithContext,\n makeUniqueId,\n} from '../../shared/component-helper'\n\n// Internal\nimport UploadFileInput from './UploadFileInput'\nimport useUpload from './useUpload'\nimport UploadDropzone from './UploadDropzone'\nimport { UploadContext, defaultProps } from './UploadContext'\nimport { verifyFiles } from './UploadVerify'\n\nimport type { UploadFile, UploadAllProps } from './types'\nimport UploadFileList from './UploadFileList'\nimport UploadInfo from './UploadInfo'\n\nexport { defaultProps }\n\nconst Upload = (localProps: UploadAllProps) => {\n const context = React.useContext(Context)\n\n const { buttonTextSingular, textSingular, ...translations } =\n context.getTranslation(localProps).Upload\n\n if (localProps?.filesAmountLimit === 1) {\n translations.buttonText = buttonTextSingular\n translations.text = textSingular\n }\n\n const extendedProps = extendPropsWithContext(\n localProps,\n defaultProps,\n { skeleton: context?.skeleton },\n translations,\n context.Upload\n )\n\n const {\n id,\n skeleton,\n className,\n acceptedFileTypes,\n filesAmountLimit,\n fileMaxSize,\n onChange,\n onFileDelete, // eslint-disable-line\n title, // eslint-disable-line\n text, // eslint-disable-line\n fileTypeDescription, // eslint-disable-line\n fileSizeDescription, // eslint-disable-line\n fileAmountDescription, // eslint-disable-line\n fileSizeContent, // eslint-disable-line\n buttonText, // eslint-disable-line\n loadingText, // eslint-disable-line\n errorLargeFile,\n errorUnsupportedFile,\n errorAmountLimit, // eslint-disable-line\n deleteButton, // eslint-disable-line\n fileListAriaLabel, // eslint-disable-line\n ...props\n } = extendedProps\n\n const spacingClasses = createSpacingClasses(props)\n\n const { files, setFiles, setInternalFiles, getExistingFile } =\n useUpload(id)\n\n const onInputUpload = useCallback(\n (newFiles: UploadFile[]) => {\n const mergedFiles = [\n ...files,\n ...newFiles.map((fileItem) => {\n const { file } = fileItem\n\n const existingFile = getExistingFile(file, files)\n\n fileItem.exists = Boolean(existingFile)\n fileItem.id = fileItem.exists ? existingFile.id : makeUniqueId()\n\n return fileItem\n }),\n ]\n\n const verifiedFiles = verifyFiles(\n mergedFiles.filter(({ exists }) => !exists),\n {\n fileMaxSize,\n acceptedFileTypes,\n errorUnsupportedFile,\n errorLargeFile,\n }\n )\n\n const validFiles = [...verifiedFiles].slice(0, filesAmountLimit)\n\n setFiles(validFiles)\n setInternalFiles(mergedFiles)\n\n if (typeof onChange === 'function') {\n onChange({ files: validFiles })\n }\n\n return validFiles\n },\n [\n acceptedFileTypes,\n errorLargeFile,\n errorUnsupportedFile,\n fileMaxSize,\n files,\n filesAmountLimit,\n getExistingFile,\n onChange,\n setFiles,\n setInternalFiles,\n ]\n )\n\n return (\n <UploadContext.Provider\n value={{\n ...extendedProps,\n id,\n onInputUpload,\n }}\n >\n <Provider skeleton={skeleton}>\n <UploadDropzone\n className={classnames('dnb-upload', spacingClasses, className)}\n {...props}\n >\n <UploadInfo />\n\n <UploadFileInput />\n\n <UploadFileList />\n </UploadDropzone>\n </Provider>\n </UploadContext.Provider>\n )\n}\n\nUpload.useUpload = useUpload\n\nUpload._formElement = true\nUpload._supportsSpacingProps = true\n\nexport default Upload\n"],"mappings":";;;;;;;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,QAAQ,OAAO;AAC1C,OAAOC,UAAU,MAAM,YAAY;AAGnC,SAASC,oBAAoB,QAAQ,wBAAwB;AAC7D,OAAOC,QAAQ,MAAM,uBAAuB;AAC5C,OAAOC,OAAO,MAAM,sBAAsB;AAC1C,SACEC,sBAAsB,EACtBC,YAAY,QACP,+BAA+B;AAGtC,OAAOC,eAAe,MAAM,mBAAmB;AAC/C,OAAOC,SAAS,MAAM,aAAa;AACnC,OAAOC,cAAc,MAAM,kBAAkB;AAC7C,SAASC,aAAa,EAAEC,YAAY,QAAQ,iBAAiB;AAC7D,SAASC,WAAW,QAAQ,gBAAgB;AAG5C,OAAOC,cAAc,MAAM,kBAAkB;AAC7C,OAAOC,UAAU,MAAM,cAAc;AAErC,SAASH,YAAY;AAErB,MAAMI,MAAM,GAAIC,UAA0B,IAAK;EAC7C,MAAMC,OAAO,GAAGlB,KAAK,CAACmB,UAAU,CAACd,OAAO,CAAC;EAEzC,MAAAe,qBAAA,GACEF,OAAO,CAACG,cAAc,CAACJ,UAAU,CAAC,CAACD,MAAM;IADrC;MAAEM,kBAAkB;MAAEC;IAA8B,CAAC,GAAAH,qBAAA;IAAdI,YAAY,GAAAC,wBAAA,CAAAL,qBAAA,EAAAM,SAAA;EAGzD,IAAI,CAAAT,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAEU,gBAAgB,MAAK,CAAC,EAAE;IACtCH,YAAY,CAACI,UAAU,GAAGN,kBAAkB;IAC5CE,YAAY,CAACK,IAAI,GAAGN,YAAY;EAClC;EAEA,MAAMO,aAAa,GAAGxB,sBAAsB,CAC1CW,UAAU,EACVL,YAAY,EACZ;IAAEmB,QAAQ,EAAEb,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEa;EAAS,CAAC,EAC/BP,YAAY,EACZN,OAAO,CAACF,MACV,CAAC;EAED,MAAM;MACJgB,EAAE;MACFD,QAAQ;MACRE,SAAS;MACTC,iBAAiB;MACjBP,gBAAgB;MAChBQ,WAAW;MACXC,QAAQ;MACRC,YAAY;MACZC,KAAK;MACLT,IAAI;MACJU,mBAAmB;MACnBC,mBAAmB;MACnBC,qBAAqB;MACrBC,eAAe;MACfd,UAAU;MACVe,WAAW;MACXC,cAAc;MACdC,oBAAoB;MACpBC,gBAAgB;MAChBC,YAAY;MACZC;IAEF,CAAC,GAAGlB,aAAa;IADZmB,KAAK,GAAAxB,wBAAA,CACNK,aAAa,EAAAoB,UAAA;EAEjB,MAAMC,cAAc,GAAGhD,oBAAoB,CAAC8C,KAAK,CAAC;EAElD,MAAM;IAAEG,KAAK;IAAEC,QAAQ;IAAEC,gBAAgB;IAAEC;EAAgB,CAAC,GAC1D9C,SAAS,CAACuB,EAAE,CAAC;EAEf,MAAMwB,aAAa,GAAGvD,WAAW,CAC9BwD,QAAsB,IAAK;IAC1B,MAAMC,WAAW,GAAG,CAClB,GAAGN,KAAK,EACR,GAAGK,QAAQ,CAACE,GAAG,CAAEC,QAAQ,IAAK;MAC5B,MAAM;QAAEC;MAAK,CAAC,GAAGD,QAAQ;MAEzB,MAAME,YAAY,GAAGP,eAAe,CAACM,IAAI,EAAET,KAAK,CAAC;MAEjDQ,QAAQ,CAACG,MAAM,GAAGC,OAAO,CAACF,YAAY,CAAC;MACvCF,QAAQ,CAAC5B,EAAE,GAAG4B,QAAQ,CAACG,MAAM,GAAGD,YAAY,CAAC9B,EAAE,GAAGzB,YAAY,CAAC,CAAC;MAEhE,OAAOqD,QAAQ;IACjB,CAAC,CAAC,CACH;IAED,MAAMK,aAAa,GAAGpD,WAAW,CAC/B6C,WAAW,CAACQ,MAAM,CAAC,CAAC;MAAEH;IAAO,CAAC,KAAK,CAACA,MAAM,CAAC,EAC3C;MACE5B,WAAW;MACXD,iBAAiB;MACjBW,oBAAoB;MACpBD;IACF,CACF,CAAC;IAED,MAAMuB,UAAU,GAAG,CAAC,GAAGF,aAAa,CAAC,CAACG,KAAK,CAAC,CAAC,EAAEzC,gBAAgB,CAAC;IAEhE0B,QAAQ,CAACc,UAAU,CAAC;IACpBb,gBAAgB,CAACI,WAAW,CAAC;IAE7B,IAAI,OAAOtB,QAAQ,KAAK,UAAU,EAAE;MAClCA,QAAQ,CAAC;QAAEgB,KAAK,EAAEe;MAAW,CAAC,CAAC;IACjC;IAEA,OAAOA,UAAU;EACnB,CAAC,EACD,CACEjC,iBAAiB,EACjBU,cAAc,EACdC,oBAAoB,EACpBV,WAAW,EACXiB,KAAK,EACLzB,gBAAgB,EAChB4B,eAAe,EACfnB,QAAQ,EACRiB,QAAQ,EACRC,gBAAgB,CAEpB,CAAC;EAED,OACEtD,KAAA,CAAAqE,aAAA,CAAC1D,aAAa,CAACP,QAAQ;IACrBkE,KAAK,EAAAC,aAAA,CAAAA,aAAA,KACAzC,aAAa;MAChBE,EAAE;MACFwB;IAAa;EACb,GAEFxD,KAAA,CAAAqE,aAAA,CAACjE,QAAQ;IAAC2B,QAAQ,EAAEA;EAAS,GAC3B/B,KAAA,CAAAqE,aAAA,CAAC3D,cAAc,EAAA8D,QAAA;IACbvC,SAAS,EAAE/B,UAAU,CAAC,YAAY,EAAEiD,cAAc,EAAElB,SAAS;EAAE,GAC3DgB,KAAK,GAAAwB,WAAA,KAAAA,WAAA,GAETzE,KAAA,CAAAqE,aAAA,CAACtD,UAAU,MAAE,CAAC,GAAA2D,gBAAA,KAAAA,gBAAA,GAEd1E,KAAA,CAAAqE,aAAA,CAAC7D,eAAe,MAAE,CAAC,GAAAmE,eAAA,KAAAA,eAAA,GAEnB3E,KAAA,CAAAqE,aAAA,CAACvD,cAAc,MAAE,CAAC,CACJ,CACR,CACY,CAAC;AAE7B,CAAC;AAEDE,MAAM,CAACP,SAAS,GAAGA,SAAS;AAE5BO,MAAM,CAAC4D,YAAY,GAAG,IAAI;AAC1B5D,MAAM,CAAC6D,qBAAqB,GAAG,IAAI;AAEnC,eAAe7D,MAAM"}
@@ -24,7 +24,9 @@ const UploadFileInput = () => {
24
24
  };
25
25
  const sharedId = id || makeUniqueId();
26
26
  const accept = getAcceptedFileTypes(acceptedFileTypes);
27
- return React.createElement("div", null, React.createElement(Button, {
27
+ return React.createElement("div", {
28
+ className: "dnb-upload__file-input-area"
29
+ }, React.createElement(Button, {
28
30
  top: "medium",
29
31
  id: `${sharedId}-input`,
30
32
  className: "dnb-upload__file-input-button",
@@ -1 +1 @@
1
- {"version":3,"file":"UploadFileInput.js","names":["React","useRef","Button","folder","FolderIcon","makeUniqueId","UploadContext","UploadStatus","getAcceptedFileTypes","UploadFileInput","fileInput","context","useContext","id","acceptedFileTypes","buttonText","onInputUpload","filesAmountLimit","openFileDialog","_fileInput$current","current","click","sharedId","accept","createElement","top","className","icon","icon_position","variant","wrap","onClick","_UploadStatus","ref","type","onChange","onChangeHandler","onClickHandler","multiple","event","target","files","Array","from","map","file","value"],"sources":["../../../../src/components/upload/UploadFileInput.tsx"],"sourcesContent":["import React, { useRef } from 'react'\n\n// Components\nimport Button from '../button/Button'\n\n// Icons\nimport { folder as FolderIcon } from '../../icons'\n\n// Shared\nimport { makeUniqueId } from '../../shared/component-helper'\n\n// Internal\nimport { UploadContext } from './UploadContext'\nimport UploadStatus from './UploadStatus'\nimport { getAcceptedFileTypes } from './UploadVerify'\n\nconst UploadFileInput = () => {\n const fileInput = useRef<HTMLInputElement>(null)\n\n const context = React.useContext(UploadContext)\n\n const {\n id,\n acceptedFileTypes,\n buttonText,\n onInputUpload,\n filesAmountLimit,\n } = context\n\n const openFileDialog = () => fileInput.current?.click()\n\n const sharedId = id || makeUniqueId()\n const accept = getAcceptedFileTypes(acceptedFileTypes)\n\n return (\n <div>\n <Button\n top=\"medium\"\n id={`${sharedId}-input`}\n className=\"dnb-upload__file-input-button\"\n icon={FolderIcon}\n icon_position=\"left\"\n variant=\"secondary\"\n wrap\n onClick={openFileDialog}\n >\n {buttonText}\n </Button>\n\n <UploadStatus />\n\n <input\n aria-labelledby={`${sharedId}-input`}\n ref={fileInput}\n accept={accept}\n className=\"dnb-upload__file-input\"\n type=\"file\"\n onChange={onChangeHandler}\n onClick={onClickHandler}\n multiple={filesAmountLimit > 1}\n />\n </div>\n )\n\n function onChangeHandler(event: React.SyntheticEvent) {\n const target = event.target as HTMLInputElement\n const { files } = target\n\n onInputUpload(\n Array.from(files).map((file) => {\n return { file }\n })\n )\n }\n\n function onClickHandler(event: React.SyntheticEvent) {\n const target = event.target as HTMLInputElement\n\n /**\n * This resets the internal state.\n * Some browsers (chromium) to check for already selected files.\n * But we have our own logic for that.\n * We also align the UX to be the same to all browsers,\n * and to be same when the drag file API is used.\n */\n target.value = null\n }\n}\n\nexport default UploadFileInput\n"],"mappings":";;;AAAA,OAAOA,KAAK,IAAIC,MAAM,QAAQ,OAAO;AAGrC,OAAOC,MAAM,MAAM,kBAAkB;AAGrC,SAASC,MAAM,IAAIC,UAAU,QAAQ,aAAa;AAGlD,SAASC,YAAY,QAAQ,+BAA+B;AAG5D,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,OAAOC,YAAY,MAAM,gBAAgB;AACzC,SAASC,oBAAoB,QAAQ,gBAAgB;AAErD,MAAMC,eAAe,GAAGA,CAAA,KAAM;EAC5B,MAAMC,SAAS,GAAGT,MAAM,CAAmB,IAAI,CAAC;EAEhD,MAAMU,OAAO,GAAGX,KAAK,CAACY,UAAU,CAACN,aAAa,CAAC;EAE/C,MAAM;IACJO,EAAE;IACFC,iBAAiB;IACjBC,UAAU;IACVC,aAAa;IACbC;EACF,CAAC,GAAGN,OAAO;EAEX,MAAMO,cAAc,GAAGA,CAAA;IAAA,IAAAC,kBAAA;IAAA,QAAAA,kBAAA,GAAMT,SAAS,CAACU,OAAO,cAAAD,kBAAA,uBAAjBA,kBAAA,CAAmBE,KAAK,CAAC,CAAC;EAAA;EAEvD,MAAMC,QAAQ,GAAGT,EAAE,IAAIR,YAAY,CAAC,CAAC;EACrC,MAAMkB,MAAM,GAAGf,oBAAoB,CAACM,iBAAiB,CAAC;EAEtD,OACEd,KAAA,CAAAwB,aAAA,cACExB,KAAA,CAAAwB,aAAA,CAACtB,MAAM;IACLuB,GAAG,EAAC,QAAQ;IACZZ,EAAE,EAAG,GAAES,QAAS,QAAQ;IACxBI,SAAS,EAAC,+BAA+B;IACzCC,IAAI,EAAEvB,UAAW;IACjBwB,aAAa,EAAC,MAAM;IACpBC,OAAO,EAAC,WAAW;IACnBC,IAAI;IACJC,OAAO,EAAEb;EAAe,GAEvBH,UACK,CAAC,EAAAiB,aAAA,KAAAA,aAAA,GAEThC,KAAA,CAAAwB,aAAA,CAACjB,YAAY,MAAE,CAAC,GAEhBP,KAAA,CAAAwB,aAAA;IACE,mBAAkB,GAAEF,QAAS,QAAQ;IACrCW,GAAG,EAAEvB,SAAU;IACfa,MAAM,EAAEA,MAAO;IACfG,SAAS,EAAC,wBAAwB;IAClCQ,IAAI,EAAC,MAAM;IACXC,QAAQ,EAAEC,eAAgB;IAC1BL,OAAO,EAAEM,cAAe;IACxBC,QAAQ,EAAErB,gBAAgB,GAAG;EAAE,CAChC,CACE,CAAC;EAGR,SAASmB,eAAeA,CAACG,KAA2B,EAAE;IACpD,MAAMC,MAAM,GAAGD,KAAK,CAACC,MAA0B;IAC/C,MAAM;MAAEC;IAAM,CAAC,GAAGD,MAAM;IAExBxB,aAAa,CACX0B,KAAK,CAACC,IAAI,CAACF,KAAK,CAAC,CAACG,GAAG,CAAEC,IAAI,IAAK;MAC9B,OAAO;QAAEA;MAAK,CAAC;IACjB,CAAC,CACH,CAAC;EACH;EAEA,SAASR,cAAcA,CAACE,KAA2B,EAAE;IACnD,MAAMC,MAAM,GAAGD,KAAK,CAACC,MAA0B;IAS/CA,MAAM,CAACM,KAAK,GAAG,IAAI;EACrB;AACF,CAAC;AAED,eAAerC,eAAe"}
1
+ {"version":3,"file":"UploadFileInput.js","names":["React","useRef","Button","folder","FolderIcon","makeUniqueId","UploadContext","UploadStatus","getAcceptedFileTypes","UploadFileInput","fileInput","context","useContext","id","acceptedFileTypes","buttonText","onInputUpload","filesAmountLimit","openFileDialog","_fileInput$current","current","click","sharedId","accept","createElement","className","top","icon","icon_position","variant","wrap","onClick","_UploadStatus","ref","type","onChange","onChangeHandler","onClickHandler","multiple","event","target","files","Array","from","map","file","value"],"sources":["../../../../src/components/upload/UploadFileInput.tsx"],"sourcesContent":["import React, { useRef } from 'react'\n\n// Components\nimport Button from '../button/Button'\n\n// Icons\nimport { folder as FolderIcon } from '../../icons'\n\n// Shared\nimport { makeUniqueId } from '../../shared/component-helper'\n\n// Internal\nimport { UploadContext } from './UploadContext'\nimport UploadStatus from './UploadStatus'\nimport { getAcceptedFileTypes } from './UploadVerify'\n\nconst UploadFileInput = () => {\n const fileInput = useRef<HTMLInputElement>(null)\n\n const context = React.useContext(UploadContext)\n\n const {\n id,\n acceptedFileTypes,\n buttonText,\n onInputUpload,\n filesAmountLimit,\n } = context\n\n const openFileDialog = () => fileInput.current?.click()\n\n const sharedId = id || makeUniqueId()\n const accept = getAcceptedFileTypes(acceptedFileTypes)\n\n return (\n <div className=\"dnb-upload__file-input-area\">\n <Button\n top=\"medium\"\n id={`${sharedId}-input`}\n className=\"dnb-upload__file-input-button\"\n icon={FolderIcon}\n icon_position=\"left\"\n variant=\"secondary\"\n wrap\n onClick={openFileDialog}\n >\n {buttonText}\n </Button>\n\n <UploadStatus />\n\n <input\n aria-labelledby={`${sharedId}-input`}\n ref={fileInput}\n accept={accept}\n className=\"dnb-upload__file-input\"\n type=\"file\"\n onChange={onChangeHandler}\n onClick={onClickHandler}\n multiple={filesAmountLimit > 1}\n />\n </div>\n )\n\n function onChangeHandler(event: React.SyntheticEvent) {\n const target = event.target as HTMLInputElement\n const { files } = target\n\n onInputUpload(\n Array.from(files).map((file) => {\n return { file }\n })\n )\n }\n\n function onClickHandler(event: React.SyntheticEvent) {\n const target = event.target as HTMLInputElement\n\n /**\n * This resets the internal state.\n * Some browsers (chromium) to check for already selected files.\n * But we have our own logic for that.\n * We also align the UX to be the same to all browsers,\n * and to be same when the drag file API is used.\n */\n target.value = null\n }\n}\n\nexport default UploadFileInput\n"],"mappings":";;;AAAA,OAAOA,KAAK,IAAIC,MAAM,QAAQ,OAAO;AAGrC,OAAOC,MAAM,MAAM,kBAAkB;AAGrC,SAASC,MAAM,IAAIC,UAAU,QAAQ,aAAa;AAGlD,SAASC,YAAY,QAAQ,+BAA+B;AAG5D,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,OAAOC,YAAY,MAAM,gBAAgB;AACzC,SAASC,oBAAoB,QAAQ,gBAAgB;AAErD,MAAMC,eAAe,GAAGA,CAAA,KAAM;EAC5B,MAAMC,SAAS,GAAGT,MAAM,CAAmB,IAAI,CAAC;EAEhD,MAAMU,OAAO,GAAGX,KAAK,CAACY,UAAU,CAACN,aAAa,CAAC;EAE/C,MAAM;IACJO,EAAE;IACFC,iBAAiB;IACjBC,UAAU;IACVC,aAAa;IACbC;EACF,CAAC,GAAGN,OAAO;EAEX,MAAMO,cAAc,GAAGA,CAAA;IAAA,IAAAC,kBAAA;IAAA,QAAAA,kBAAA,GAAMT,SAAS,CAACU,OAAO,cAAAD,kBAAA,uBAAjBA,kBAAA,CAAmBE,KAAK,CAAC,CAAC;EAAA;EAEvD,MAAMC,QAAQ,GAAGT,EAAE,IAAIR,YAAY,CAAC,CAAC;EACrC,MAAMkB,MAAM,GAAGf,oBAAoB,CAACM,iBAAiB,CAAC;EAEtD,OACEd,KAAA,CAAAwB,aAAA;IAAKC,SAAS,EAAC;EAA6B,GAC1CzB,KAAA,CAAAwB,aAAA,CAACtB,MAAM;IACLwB,GAAG,EAAC,QAAQ;IACZb,EAAE,EAAG,GAAES,QAAS,QAAQ;IACxBG,SAAS,EAAC,+BAA+B;IACzCE,IAAI,EAAEvB,UAAW;IACjBwB,aAAa,EAAC,MAAM;IACpBC,OAAO,EAAC,WAAW;IACnBC,IAAI;IACJC,OAAO,EAAEb;EAAe,GAEvBH,UACK,CAAC,EAAAiB,aAAA,KAAAA,aAAA,GAEThC,KAAA,CAAAwB,aAAA,CAACjB,YAAY,MAAE,CAAC,GAEhBP,KAAA,CAAAwB,aAAA;IACE,mBAAkB,GAAEF,QAAS,QAAQ;IACrCW,GAAG,EAAEvB,SAAU;IACfa,MAAM,EAAEA,MAAO;IACfE,SAAS,EAAC,wBAAwB;IAClCS,IAAI,EAAC,MAAM;IACXC,QAAQ,EAAEC,eAAgB;IAC1BL,OAAO,EAAEM,cAAe;IACxBC,QAAQ,EAAErB,gBAAgB,GAAG;EAAE,CAChC,CACE,CAAC;EAGR,SAASmB,eAAeA,CAACG,KAA2B,EAAE;IACpD,MAAMC,MAAM,GAAGD,KAAK,CAACC,MAA0B;IAC/C,MAAM;MAAEC;IAAM,CAAC,GAAGD,MAAM;IAExBxB,aAAa,CACX0B,KAAK,CAACC,IAAI,CAACF,KAAK,CAAC,CAACG,GAAG,CAAEC,IAAI,IAAK;MAC9B,OAAO;QAAEA;MAAK,CAAC;IACjB,CAAC,CACH,CAAC;EACH;EAEA,SAASR,cAAcA,CAACE,KAA2B,EAAE;IACnD,MAAMC,MAAM,GAAGD,KAAK,CAACC,MAA0B;IAS/CA,MAAM,CAACM,KAAK,GAAG,IAAI;EACrB;AACF,CAAC;AAED,eAAerC,eAAe"}
@@ -17,7 +17,7 @@ function UploadFileList() {
17
17
  setFiles,
18
18
  setInternalFiles
19
19
  } = useUpload(id);
20
- if (files == null || files.length < 1) {
20
+ if (files === null || files.length < 1) {
21
21
  return null;
22
22
  }
23
23
  return React.createElement("ul", {
@@ -1 +1 @@
1
- {"version":3,"file":"UploadFileList.js","names":["React","UploadContext","UploadFileListCell","useUpload","UploadFileList","context","useContext","id","fileListAriaLabel","deleteButton","loadingText","onFileDelete","onChange","files","setFiles","setInternalFiles","length","createElement","className","map","uploadFile","index","onDeleteHandler","fileItem","cleanedFiles","filter","fileListElement","file","key","onDelete","deleteButtonText"],"sources":["../../../../src/components/upload/UploadFileList.tsx"],"sourcesContent":["import React from 'react'\nimport { UploadFile } from './types'\nimport { UploadContext } from './UploadContext'\nimport UploadFileListCell from './UploadFileListCell'\nimport useUpload from './useUpload'\n\nfunction UploadFileList() {\n const context = React.useContext(UploadContext)\n\n const {\n id,\n fileListAriaLabel,\n deleteButton,\n loadingText,\n onFileDelete,\n onChange,\n } = context\n\n const { files, setFiles, setInternalFiles } = useUpload(id)\n\n if (files == null || files.length < 1) {\n return null\n }\n\n return (\n <ul className=\"dnb-upload__file-list\" aria-label={fileListAriaLabel}>\n {files.map((uploadFile: UploadFile, index: number) => {\n const onDeleteHandler = () => {\n if (typeof onFileDelete === 'function') {\n onFileDelete({ fileItem: uploadFile })\n }\n\n const cleanedFiles = files.filter(\n (fileListElement) => fileListElement.file != uploadFile.file\n )\n\n setFiles(cleanedFiles)\n setInternalFiles(cleanedFiles)\n\n if (typeof onChange === 'function') {\n onChange({ files: cleanedFiles })\n }\n }\n\n return (\n <UploadFileListCell\n key={index}\n id={id}\n uploadFile={uploadFile}\n onDelete={onDeleteHandler}\n deleteButtonText={deleteButton}\n loadingText={loadingText}\n />\n )\n })}\n </ul>\n )\n}\n\nexport default UploadFileList\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,OAAOC,kBAAkB,MAAM,sBAAsB;AACrD,OAAOC,SAAS,MAAM,aAAa;AAEnC,SAASC,cAAcA,CAAA,EAAG;EACxB,MAAMC,OAAO,GAAGL,KAAK,CAACM,UAAU,CAACL,aAAa,CAAC;EAE/C,MAAM;IACJM,EAAE;IACFC,iBAAiB;IACjBC,YAAY;IACZC,WAAW;IACXC,YAAY;IACZC;EACF,CAAC,GAAGP,OAAO;EAEX,MAAM;IAAEQ,KAAK;IAAEC,QAAQ;IAAEC;EAAiB,CAAC,GAAGZ,SAAS,CAACI,EAAE,CAAC;EAE3D,IAAIM,KAAK,IAAI,IAAI,IAAIA,KAAK,CAACG,MAAM,GAAG,CAAC,EAAE;IACrC,OAAO,IAAI;EACb;EAEA,OACEhB,KAAA,CAAAiB,aAAA;IAAIC,SAAS,EAAC,uBAAuB;IAAC,cAAYV;EAAkB,GACjEK,KAAK,CAACM,GAAG,CAAC,CAACC,UAAsB,EAAEC,KAAa,KAAK;IACpD,MAAMC,eAAe,GAAGA,CAAA,KAAM;MAC5B,IAAI,OAAOX,YAAY,KAAK,UAAU,EAAE;QACtCA,YAAY,CAAC;UAAEY,QAAQ,EAAEH;QAAW,CAAC,CAAC;MACxC;MAEA,MAAMI,YAAY,GAAGX,KAAK,CAACY,MAAM,CAC9BC,eAAe,IAAKA,eAAe,CAACC,IAAI,IAAIP,UAAU,CAACO,IAC1D,CAAC;MAEDb,QAAQ,CAACU,YAAY,CAAC;MACtBT,gBAAgB,CAACS,YAAY,CAAC;MAE9B,IAAI,OAAOZ,QAAQ,KAAK,UAAU,EAAE;QAClCA,QAAQ,CAAC;UAAEC,KAAK,EAAEW;QAAa,CAAC,CAAC;MACnC;IACF,CAAC;IAED,OACExB,KAAA,CAAAiB,aAAA,CAACf,kBAAkB;MACjB0B,GAAG,EAAEP,KAAM;MACXd,EAAE,EAAEA,EAAG;MACPa,UAAU,EAAEA,UAAW;MACvBS,QAAQ,EAAEP,eAAgB;MAC1BQ,gBAAgB,EAAErB,YAAa;MAC/BC,WAAW,EAAEA;IAAY,CAC1B,CAAC;EAEN,CAAC,CACC,CAAC;AAET;AAEA,eAAeN,cAAc"}
1
+ {"version":3,"file":"UploadFileList.js","names":["React","UploadContext","UploadFileListCell","useUpload","UploadFileList","context","useContext","id","fileListAriaLabel","deleteButton","loadingText","onFileDelete","onChange","files","setFiles","setInternalFiles","length","createElement","className","map","uploadFile","index","onDeleteHandler","fileItem","cleanedFiles","filter","fileListElement","file","key","onDelete","deleteButtonText"],"sources":["../../../../src/components/upload/UploadFileList.tsx"],"sourcesContent":["import React from 'react'\nimport { UploadFile } from './types'\nimport { UploadContext } from './UploadContext'\nimport UploadFileListCell from './UploadFileListCell'\nimport useUpload from './useUpload'\n\nfunction UploadFileList() {\n const context = React.useContext(UploadContext)\n\n const {\n id,\n fileListAriaLabel,\n deleteButton,\n loadingText,\n onFileDelete,\n onChange,\n } = context\n\n const { files, setFiles, setInternalFiles } = useUpload(id)\n\n if (files === null || files.length < 1) {\n return null\n }\n\n return (\n <ul className=\"dnb-upload__file-list\" aria-label={fileListAriaLabel}>\n {files.map((uploadFile: UploadFile, index: number) => {\n const onDeleteHandler = () => {\n if (typeof onFileDelete === 'function') {\n onFileDelete({ fileItem: uploadFile })\n }\n\n const cleanedFiles = files.filter(\n (fileListElement) => fileListElement.file != uploadFile.file\n )\n\n setFiles(cleanedFiles)\n setInternalFiles(cleanedFiles)\n\n if (typeof onChange === 'function') {\n onChange({ files: cleanedFiles })\n }\n }\n\n return (\n <UploadFileListCell\n key={index}\n id={id}\n uploadFile={uploadFile}\n onDelete={onDeleteHandler}\n deleteButtonText={deleteButton}\n loadingText={loadingText}\n />\n )\n })}\n </ul>\n )\n}\n\nexport default UploadFileList\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,OAAOC,kBAAkB,MAAM,sBAAsB;AACrD,OAAOC,SAAS,MAAM,aAAa;AAEnC,SAASC,cAAcA,CAAA,EAAG;EACxB,MAAMC,OAAO,GAAGL,KAAK,CAACM,UAAU,CAACL,aAAa,CAAC;EAE/C,MAAM;IACJM,EAAE;IACFC,iBAAiB;IACjBC,YAAY;IACZC,WAAW;IACXC,YAAY;IACZC;EACF,CAAC,GAAGP,OAAO;EAEX,MAAM;IAAEQ,KAAK;IAAEC,QAAQ;IAAEC;EAAiB,CAAC,GAAGZ,SAAS,CAACI,EAAE,CAAC;EAE3D,IAAIM,KAAK,KAAK,IAAI,IAAIA,KAAK,CAACG,MAAM,GAAG,CAAC,EAAE;IACtC,OAAO,IAAI;EACb;EAEA,OACEhB,KAAA,CAAAiB,aAAA;IAAIC,SAAS,EAAC,uBAAuB;IAAC,cAAYV;EAAkB,GACjEK,KAAK,CAACM,GAAG,CAAC,CAACC,UAAsB,EAAEC,KAAa,KAAK;IACpD,MAAMC,eAAe,GAAGA,CAAA,KAAM;MAC5B,IAAI,OAAOX,YAAY,KAAK,UAAU,EAAE;QACtCA,YAAY,CAAC;UAAEY,QAAQ,EAAEH;QAAW,CAAC,CAAC;MACxC;MAEA,MAAMI,YAAY,GAAGX,KAAK,CAACY,MAAM,CAC9BC,eAAe,IAAKA,eAAe,CAACC,IAAI,IAAIP,UAAU,CAACO,IAC1D,CAAC;MAEDb,QAAQ,CAACU,YAAY,CAAC;MACtBT,gBAAgB,CAACS,YAAY,CAAC;MAE9B,IAAI,OAAOZ,QAAQ,KAAK,UAAU,EAAE;QAClCA,QAAQ,CAAC;UAAEC,KAAK,EAAEW;QAAa,CAAC,CAAC;MACnC;IACF,CAAC;IAED,OACExB,KAAA,CAAAiB,aAAA,CAACf,kBAAkB;MACjB0B,GAAG,EAAEP,KAAM;MACXd,EAAE,EAAEA,EAAG;MACPa,UAAU,EAAEA,UAAW;MACvBS,QAAQ,EAAEP,eAAgB;MAC1BQ,gBAAgB,EAAErB,YAAa;MAC/BC,WAAW,EAAEA;IAAY,CAC1B,CAAC;EAEN,CAAC,CACC,CAAC;AAET;AAEA,eAAeN,cAAc"}
@@ -13,10 +13,14 @@ const UploadStatus = () => {
13
13
  const {
14
14
  internalFiles
15
15
  } = useUpload(id);
16
+ const open = internalFiles.length > filesAmountLimit;
16
17
  return React.createElement(HeightAnimation, {
17
- open: internalFiles.length > filesAmountLimit
18
+ open: open,
19
+ delay: 500
18
20
  }, React.createElement(FormStatus, {
19
- top: true,
21
+ shellSpace: {
22
+ top: 'small'
23
+ },
20
24
  stretch: true
21
25
  }, String(errorAmountLimit).replace('%amount', String(filesAmountLimit))));
22
26
  };
@@ -1 +1 @@
1
- {"version":3,"file":"UploadStatus.js","names":["React","UploadContext","FormStatus","useUpload","HeightAnimation","UploadStatus","context","useContext","id","filesAmountLimit","errorAmountLimit","internalFiles","createElement","open","length","top","stretch","String","replace"],"sources":["../../../../src/components/upload/UploadStatus.tsx"],"sourcesContent":["import React from 'react'\nimport { UploadContext } from './UploadContext'\nimport FormStatus from '../FormStatus'\nimport useUpload from './useUpload'\nimport HeightAnimation from '../height-animation/HeightAnimation'\n\nconst UploadStatus = () => {\n const context = React.useContext(UploadContext)\n\n const { id, filesAmountLimit, errorAmountLimit } = context\n\n const { internalFiles } = useUpload(id)\n\n return (\n <HeightAnimation open={internalFiles.length > filesAmountLimit}>\n <FormStatus top stretch>\n {String(errorAmountLimit).replace(\n '%amount',\n String(filesAmountLimit)\n )}\n </FormStatus>\n </HeightAnimation>\n )\n}\n\nexport default UploadStatus\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,OAAOC,UAAU,MAAM,eAAe;AACtC,OAAOC,SAAS,MAAM,aAAa;AACnC,OAAOC,eAAe,MAAM,qCAAqC;AAEjE,MAAMC,YAAY,GAAGA,CAAA,KAAM;EACzB,MAAMC,OAAO,GAAGN,KAAK,CAACO,UAAU,CAACN,aAAa,CAAC;EAE/C,MAAM;IAAEO,EAAE;IAAEC,gBAAgB;IAAEC;EAAiB,CAAC,GAAGJ,OAAO;EAE1D,MAAM;IAAEK;EAAc,CAAC,GAAGR,SAAS,CAACK,EAAE,CAAC;EAEvC,OACER,KAAA,CAAAY,aAAA,CAACR,eAAe;IAACS,IAAI,EAAEF,aAAa,CAACG,MAAM,GAAGL;EAAiB,GAC7DT,KAAA,CAAAY,aAAA,CAACV,UAAU;IAACa,GAAG;IAACC,OAAO;EAAA,GACpBC,MAAM,CAACP,gBAAgB,CAAC,CAACQ,OAAO,CAC/B,SAAS,EACTD,MAAM,CAACR,gBAAgB,CACzB,CACU,CACG,CAAC;AAEtB,CAAC;AAED,eAAeJ,YAAY"}
1
+ {"version":3,"file":"UploadStatus.js","names":["React","UploadContext","FormStatus","useUpload","HeightAnimation","UploadStatus","context","useContext","id","filesAmountLimit","errorAmountLimit","internalFiles","open","length","createElement","delay","shellSpace","top","stretch","String","replace"],"sources":["../../../../src/components/upload/UploadStatus.tsx"],"sourcesContent":["import React from 'react'\nimport { UploadContext } from './UploadContext'\nimport FormStatus from '../FormStatus'\nimport useUpload from './useUpload'\nimport HeightAnimation from '../height-animation/HeightAnimation'\n\nconst UploadStatus = () => {\n const context = React.useContext(UploadContext)\n\n const { id, filesAmountLimit, errorAmountLimit } = context\n const { internalFiles } = useUpload(id)\n const open = internalFiles.length > filesAmountLimit\n\n return (\n <HeightAnimation\n open={open}\n delay={\n 500 /* delay the animation to avoid flickering while each file animates */\n }\n >\n <FormStatus shellSpace={{ top: 'small' }} stretch>\n {String(errorAmountLimit).replace(\n '%amount',\n String(filesAmountLimit)\n )}\n </FormStatus>\n </HeightAnimation>\n )\n}\n\nexport default UploadStatus\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,OAAOC,UAAU,MAAM,eAAe;AACtC,OAAOC,SAAS,MAAM,aAAa;AACnC,OAAOC,eAAe,MAAM,qCAAqC;AAEjE,MAAMC,YAAY,GAAGA,CAAA,KAAM;EACzB,MAAMC,OAAO,GAAGN,KAAK,CAACO,UAAU,CAACN,aAAa,CAAC;EAE/C,MAAM;IAAEO,EAAE;IAAEC,gBAAgB;IAAEC;EAAiB,CAAC,GAAGJ,OAAO;EAC1D,MAAM;IAAEK;EAAc,CAAC,GAAGR,SAAS,CAACK,EAAE,CAAC;EACvC,MAAMI,IAAI,GAAGD,aAAa,CAACE,MAAM,GAAGJ,gBAAgB;EAEpD,OACET,KAAA,CAAAc,aAAA,CAACV,eAAe;IACdQ,IAAI,EAAEA,IAAK;IACXG,KAAK,EACH;EACD,GAEDf,KAAA,CAAAc,aAAA,CAACZ,UAAU;IAACc,UAAU,EAAE;MAAEC,GAAG,EAAE;IAAQ,CAAE;IAACC,OAAO;EAAA,GAC9CC,MAAM,CAACT,gBAAgB,CAAC,CAACU,OAAO,CAC/B,SAAS,EACTD,MAAM,CAACV,gBAAgB,CACzB,CACU,CACG,CAAC;AAEtB,CAAC;AAED,eAAeJ,YAAY"}
@@ -1,18 +1,16 @@
1
- "use client";
2
-
3
- import { useEventEmitter } from '../../shared/component-helper';
1
+ import { useSharedState } from '../../shared/helpers/useSharedState';
4
2
  function useUpload(id) {
5
3
  const {
6
4
  data,
7
- update
8
- } = useEventEmitter(id);
5
+ extend
6
+ } = useSharedState(id);
9
7
  const setFiles = files => {
10
- update({
8
+ extend({
11
9
  files
12
10
  });
13
11
  };
14
12
  const setInternalFiles = internalFiles => {
15
- update({
13
+ extend({
16
14
  internalFiles
17
15
  });
18
16
  };