@dnb/eufemia 10.43.0 → 10.45.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 (803) hide show
  1. package/CHANGELOG.md +61 -0
  2. package/cjs/components/autocomplete/Autocomplete.d.ts +2 -2
  3. package/cjs/components/autocomplete/AutocompleteDocs.js +7 -7
  4. package/cjs/components/autocomplete/AutocompleteDocs.js.map +1 -1
  5. package/cjs/components/button/Button.d.ts +1 -1
  6. package/cjs/components/button/Button.js +6 -5
  7. package/cjs/components/button/Button.js.map +1 -1
  8. package/cjs/components/checkbox/style/dnb-checkbox.scss +1 -1
  9. package/cjs/components/input-masked/InputMaskedHooks.js +4 -0
  10. package/cjs/components/input-masked/InputMaskedHooks.js.map +1 -1
  11. package/cjs/components/radio/style/dnb-radio.scss +1 -1
  12. package/cjs/components/space/Space.d.ts +1 -1
  13. package/cjs/components/space/Space.js.map +1 -1
  14. package/cjs/components/table/TableStickyHeader.js.map +1 -1
  15. package/cjs/components/table/table-accordion/TableAccordionHead.js.map +1 -1
  16. package/cjs/components/table/table-navigation/TableNavigationHead.js +1 -1
  17. package/cjs/components/table/table-navigation/TableNavigationHead.js.map +1 -1
  18. package/cjs/components/upload/Upload.js +2 -1
  19. package/cjs/components/upload/Upload.js.map +1 -1
  20. package/cjs/components/upload/UploadDocs.d.ts +1 -0
  21. package/cjs/components/upload/UploadDocs.js +18 -5
  22. package/cjs/components/upload/UploadDocs.js.map +1 -1
  23. package/cjs/components/upload/UploadInfo.js +57 -5
  24. package/cjs/components/upload/UploadInfo.js.map +1 -1
  25. package/cjs/components/upload/UploadVerify.d.ts +4 -2
  26. package/cjs/components/upload/UploadVerify.js +34 -4
  27. package/cjs/components/upload/UploadVerify.js.map +1 -1
  28. package/cjs/components/upload/style/dnb-upload.css +15 -0
  29. package/cjs/components/upload/style/dnb-upload.min.css +1 -1
  30. package/cjs/components/upload/style/dnb-upload.scss +17 -0
  31. package/cjs/components/upload/types.d.ts +9 -3
  32. package/cjs/components/upload/types.js.map +1 -1
  33. package/cjs/extensions/forms/DataContext/Context.d.ts +9 -3
  34. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  35. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +8 -0
  36. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  37. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +8 -0
  38. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  39. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +5 -12
  40. package/cjs/extensions/forms/DataContext/Provider/Provider.js +58 -18
  41. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  42. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +6 -1
  43. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  44. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -1
  45. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +29 -24
  46. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  47. package/cjs/extensions/forms/Field/Currency/CurrencyDocs.d.ts +2 -0
  48. package/cjs/extensions/forms/Field/Currency/CurrencyDocs.js +31 -0
  49. package/cjs/extensions/forms/Field/Currency/CurrencyDocs.js.map +1 -0
  50. package/cjs/extensions/forms/Field/Expiry/Expiry.d.ts +1 -1
  51. package/cjs/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  52. package/cjs/extensions/forms/Field/FieldDocs.d.ts +7 -0
  53. package/cjs/extensions/forms/Field/FieldDocs.js +20 -1
  54. package/cjs/extensions/forms/Field/FieldDocs.js.map +1 -1
  55. package/cjs/extensions/forms/Field/Name/Name.js +2 -2
  56. package/cjs/extensions/forms/Field/Name/Name.js.map +1 -1
  57. package/cjs/extensions/forms/Field/Number/Number.js +7 -12
  58. package/cjs/extensions/forms/Field/Number/Number.js.map +1 -1
  59. package/cjs/extensions/forms/Field/Option/Option.d.ts +2 -4
  60. package/cjs/extensions/forms/Field/Option/Option.js +0 -21
  61. package/cjs/extensions/forms/Field/Option/Option.js.map +1 -1
  62. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -2
  63. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +33 -15
  64. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  65. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +3 -0
  66. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +28 -0
  67. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -0
  68. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +2 -2
  69. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +32 -16
  70. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  71. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.d.ts +1 -0
  72. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +16 -0
  73. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -0
  74. package/cjs/extensions/forms/Field/Selection/Selection.d.ts +42 -15
  75. package/cjs/extensions/forms/Field/Selection/Selection.js +92 -29
  76. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  77. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js +10 -0
  78. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  79. package/cjs/extensions/forms/Field/Toggle/Toggle.js +1 -1
  80. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  81. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +3 -3
  82. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  83. package/cjs/extensions/forms/Form/Element/Element.js +11 -9
  84. package/cjs/extensions/forms/Form/Element/Element.js.map +1 -1
  85. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  86. package/cjs/extensions/forms/Form/Handler/Handler.js +3 -1
  87. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  88. package/cjs/extensions/forms/Form/Isolation/Isolation.d.ts +26 -5
  89. package/cjs/extensions/forms/Form/Isolation/Isolation.js +84 -26
  90. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  91. package/cjs/extensions/forms/Form/Isolation/IsolationCommitButton.js +1 -0
  92. package/cjs/extensions/forms/Form/Isolation/IsolationCommitButton.js.map +1 -1
  93. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js +11 -1
  94. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  95. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +13 -5
  96. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  97. package/cjs/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +10 -13
  98. package/cjs/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -1
  99. package/cjs/extensions/forms/Form/Section/Section.js +2 -2
  100. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  101. package/cjs/extensions/forms/Form/data-context/clearData.d.ts +1 -0
  102. package/cjs/extensions/forms/Form/data-context/clearData.js +16 -0
  103. package/cjs/extensions/forms/Form/data-context/clearData.js.map +1 -0
  104. package/cjs/extensions/forms/Form/index.d.ts +1 -0
  105. package/cjs/extensions/forms/Form/index.js +7 -0
  106. package/cjs/extensions/forms/Form/index.js.map +1 -1
  107. package/cjs/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js +3 -3
  108. package/cjs/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js.map +1 -1
  109. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +2 -2
  110. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  111. package/cjs/extensions/forms/Iterate/Array/Array.js +7 -5
  112. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  113. package/cjs/extensions/forms/Iterate/Array/types.d.ts +1 -4
  114. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  115. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -3
  116. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +25 -19
  117. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  118. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +10 -0
  119. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  120. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +44 -14
  121. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  122. package/cjs/extensions/forms/Iterate/{IterateElementContext.d.ts → IterateItemContext.d.ts} +3 -3
  123. package/cjs/extensions/forms/Iterate/{IterateElementContext.js → IterateItemContext.js} +3 -3
  124. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -0
  125. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +3 -3
  126. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  127. package/cjs/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  128. package/cjs/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  129. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.d.ts +4 -0
  130. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js +42 -0
  131. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -0
  132. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +37 -0
  133. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +95 -0
  134. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -0
  135. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +11 -0
  136. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.js +12 -0
  137. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -0
  138. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.d.ts +3 -0
  139. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +42 -0
  140. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -0
  141. package/cjs/extensions/forms/Iterate/PushContainer/index.d.ts +2 -0
  142. package/cjs/extensions/forms/Iterate/PushContainer/index.js +27 -0
  143. package/cjs/extensions/forms/Iterate/PushContainer/index.js.map +1 -0
  144. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -4
  145. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  146. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +4 -0
  147. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +13 -5
  148. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  149. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  150. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  151. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +3 -3
  152. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  153. package/cjs/extensions/forms/Iterate/hooks/useItem.d.ts +1 -0
  154. package/cjs/extensions/forms/Iterate/hooks/useItem.js +15 -0
  155. package/cjs/extensions/forms/Iterate/hooks/useItem.js.map +1 -0
  156. package/cjs/extensions/forms/Iterate/index.d.ts +3 -1
  157. package/cjs/extensions/forms/Iterate/index.js +17 -3
  158. package/cjs/extensions/forms/Iterate/index.js.map +1 -1
  159. package/cjs/extensions/forms/Iterate/style/dnb-iterate.css +1 -1
  160. package/cjs/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -1
  161. package/cjs/extensions/forms/Iterate/style/dnb-iterate.scss +1 -1
  162. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +19 -0
  163. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js +81 -0
  164. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -0
  165. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.d.ts +2 -0
  166. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +15 -0
  167. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -0
  168. package/cjs/extensions/forms/Value/ArraySelection/index.d.ts +2 -0
  169. package/cjs/extensions/forms/Value/ArraySelection/index.js +27 -0
  170. package/cjs/extensions/forms/Value/ArraySelection/index.js.map +1 -0
  171. package/cjs/extensions/forms/Value/Selection/Selection.d.ts +9 -0
  172. package/cjs/extensions/forms/Value/Selection/Selection.js +58 -0
  173. package/cjs/extensions/forms/Value/Selection/Selection.js.map +1 -0
  174. package/cjs/extensions/forms/Value/Selection/SelectionDocs.d.ts +2 -0
  175. package/cjs/extensions/forms/Value/Selection/SelectionDocs.js +15 -0
  176. package/cjs/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -0
  177. package/cjs/extensions/forms/Value/Selection/index.d.ts +2 -0
  178. package/cjs/extensions/forms/Value/Selection/index.js +27 -0
  179. package/cjs/extensions/forms/Value/Selection/index.js.map +1 -0
  180. package/cjs/extensions/forms/Value/ValueDocs.js +6 -1
  181. package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
  182. package/cjs/extensions/forms/Value/index.d.ts +2 -0
  183. package/cjs/extensions/forms/Value/index.js +14 -0
  184. package/cjs/extensions/forms/Value/index.js.map +1 -1
  185. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +3 -3
  186. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  187. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +27 -11
  188. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  189. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +1 -0
  190. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  191. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +7 -0
  192. package/cjs/extensions/forms/constants/locales/en-GB.js +7 -0
  193. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  194. package/cjs/extensions/forms/constants/locales/en-US.d.ts +7 -0
  195. package/cjs/extensions/forms/constants/locales/index.d.ts +14 -0
  196. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +7 -0
  197. package/cjs/extensions/forms/constants/locales/nb-NO.js +7 -0
  198. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  199. package/cjs/extensions/forms/hooks/DataValueDocs.js +4 -4
  200. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  201. package/cjs/extensions/forms/hooks/useDataValue.d.ts +2 -0
  202. package/cjs/extensions/forms/hooks/useDataValue.js +29 -13
  203. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  204. package/cjs/extensions/forms/hooks/useExternalValue.js +4 -4
  205. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  206. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +5 -5
  207. package/cjs/extensions/forms/hooks/useFieldProps.js +49 -31
  208. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  209. package/cjs/extensions/forms/hooks/usePath.js +3 -3
  210. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  211. package/cjs/extensions/forms/hooks/useValueProps.js +4 -1
  212. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  213. package/cjs/extensions/forms/style/dnb-forms.css +1 -1
  214. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  215. package/cjs/extensions/forms/types.d.ts +20 -7
  216. package/cjs/extensions/forms/types.js.map +1 -1
  217. package/cjs/shared/Eufemia.d.ts +1 -1
  218. package/cjs/shared/Eufemia.js +2 -2
  219. package/cjs/shared/Eufemia.js.map +1 -1
  220. package/cjs/shared/helpers/isAsync.js +2 -2
  221. package/cjs/shared/helpers/isAsync.js.map +1 -1
  222. package/cjs/shared/locales/en-GB.d.ts +1 -0
  223. package/cjs/shared/locales/en-GB.js +1 -0
  224. package/cjs/shared/locales/en-GB.js.map +1 -1
  225. package/cjs/shared/locales/en-US.d.ts +1 -0
  226. package/cjs/shared/locales/index.d.ts +2 -0
  227. package/cjs/shared/locales/nb-NO.d.ts +1 -0
  228. package/cjs/shared/locales/nb-NO.js +2 -1
  229. package/cjs/shared/locales/nb-NO.js.map +1 -1
  230. package/cjs/shared/useTheme.d.ts +4 -10
  231. package/cjs/shared/useTheme.js +7 -5
  232. package/cjs/shared/useTheme.js.map +1 -1
  233. package/cjs/style/core/scopes.scss +1 -1
  234. package/cjs/style/dnb-ui-basis.css +1 -1
  235. package/cjs/style/dnb-ui-basis.min.css +1 -1
  236. package/cjs/style/dnb-ui-body.css +1 -1
  237. package/cjs/style/dnb-ui-body.min.css +1 -1
  238. package/cjs/style/dnb-ui-components.css +16 -1
  239. package/cjs/style/dnb-ui-components.min.css +2 -2
  240. package/cjs/style/dnb-ui-core.css +1 -1
  241. package/cjs/style/dnb-ui-core.min.css +1 -1
  242. package/cjs/style/dnb-ui-extensions.css +1 -1
  243. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  244. package/cjs/style/dnb-ui-forms.css +1 -1
  245. package/cjs/style/dnb-ui-forms.min.css +1 -1
  246. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +17 -2
  247. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
  248. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +1 -1
  249. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  250. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +1 -1
  251. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  252. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +17 -2
  253. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  254. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +1 -1
  255. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  256. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +1 -1
  257. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  258. package/cjs/style/themes/theme-ui/ui-theme-components.css +17 -2
  259. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +2 -2
  260. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +1 -1
  261. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  262. package/cjs/style/themes/theme-ui/ui-theme-forms.css +1 -1
  263. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  264. package/components/autocomplete/Autocomplete.d.ts +2 -2
  265. package/components/autocomplete/AutocompleteDocs.js +7 -7
  266. package/components/autocomplete/AutocompleteDocs.js.map +1 -1
  267. package/components/button/Button.d.ts +1 -1
  268. package/components/button/Button.js +6 -5
  269. package/components/button/Button.js.map +1 -1
  270. package/components/checkbox/style/dnb-checkbox.scss +1 -1
  271. package/components/input-masked/InputMaskedHooks.js +4 -0
  272. package/components/input-masked/InputMaskedHooks.js.map +1 -1
  273. package/components/radio/style/dnb-radio.scss +1 -1
  274. package/components/space/Space.d.ts +1 -1
  275. package/components/space/Space.js.map +1 -1
  276. package/components/table/TableStickyHeader.js.map +1 -1
  277. package/components/table/table-accordion/TableAccordionHead.js.map +1 -1
  278. package/components/table/table-navigation/TableNavigationHead.js +1 -1
  279. package/components/table/table-navigation/TableNavigationHead.js.map +1 -1
  280. package/components/upload/Upload.js +2 -1
  281. package/components/upload/Upload.js.map +1 -1
  282. package/components/upload/UploadDocs.d.ts +1 -0
  283. package/components/upload/UploadDocs.js +16 -4
  284. package/components/upload/UploadDocs.js.map +1 -1
  285. package/components/upload/UploadInfo.js +57 -5
  286. package/components/upload/UploadInfo.js.map +1 -1
  287. package/components/upload/UploadVerify.d.ts +4 -2
  288. package/components/upload/UploadVerify.js +32 -4
  289. package/components/upload/UploadVerify.js.map +1 -1
  290. package/components/upload/style/dnb-upload.css +15 -0
  291. package/components/upload/style/dnb-upload.min.css +1 -1
  292. package/components/upload/style/dnb-upload.scss +17 -0
  293. package/components/upload/types.d.ts +9 -3
  294. package/components/upload/types.js.map +1 -1
  295. package/es/components/autocomplete/Autocomplete.d.ts +2 -2
  296. package/es/components/autocomplete/AutocompleteDocs.js +7 -7
  297. package/es/components/autocomplete/AutocompleteDocs.js.map +1 -1
  298. package/es/components/button/Button.d.ts +1 -1
  299. package/es/components/button/Button.js +6 -5
  300. package/es/components/button/Button.js.map +1 -1
  301. package/es/components/checkbox/style/dnb-checkbox.scss +1 -1
  302. package/es/components/input-masked/InputMaskedHooks.js +4 -0
  303. package/es/components/input-masked/InputMaskedHooks.js.map +1 -1
  304. package/es/components/radio/style/dnb-radio.scss +1 -1
  305. package/es/components/space/Space.d.ts +1 -1
  306. package/es/components/space/Space.js.map +1 -1
  307. package/es/components/table/TableStickyHeader.js.map +1 -1
  308. package/es/components/table/table-accordion/TableAccordionHead.js.map +1 -1
  309. package/es/components/table/table-navigation/TableNavigationHead.js +1 -1
  310. package/es/components/table/table-navigation/TableNavigationHead.js.map +1 -1
  311. package/es/components/upload/Upload.js +2 -1
  312. package/es/components/upload/Upload.js.map +1 -1
  313. package/es/components/upload/UploadDocs.d.ts +1 -0
  314. package/es/components/upload/UploadDocs.js +16 -4
  315. package/es/components/upload/UploadDocs.js.map +1 -1
  316. package/es/components/upload/UploadInfo.js +57 -5
  317. package/es/components/upload/UploadInfo.js.map +1 -1
  318. package/es/components/upload/UploadVerify.d.ts +4 -2
  319. package/es/components/upload/UploadVerify.js +32 -4
  320. package/es/components/upload/UploadVerify.js.map +1 -1
  321. package/es/components/upload/style/dnb-upload.css +15 -0
  322. package/es/components/upload/style/dnb-upload.min.css +1 -1
  323. package/es/components/upload/style/dnb-upload.scss +17 -0
  324. package/es/components/upload/types.d.ts +9 -3
  325. package/es/components/upload/types.js.map +1 -1
  326. package/es/extensions/forms/DataContext/Context.d.ts +9 -3
  327. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  328. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +8 -0
  329. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  330. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +9 -1
  331. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  332. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +5 -12
  333. package/es/extensions/forms/DataContext/Provider/Provider.js +56 -18
  334. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  335. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +6 -1
  336. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  337. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -1
  338. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +28 -24
  339. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  340. package/es/extensions/forms/Field/Currency/CurrencyDocs.d.ts +2 -0
  341. package/es/extensions/forms/Field/Currency/CurrencyDocs.js +22 -0
  342. package/es/extensions/forms/Field/Currency/CurrencyDocs.js.map +1 -0
  343. package/es/extensions/forms/Field/Expiry/Expiry.d.ts +1 -1
  344. package/es/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  345. package/es/extensions/forms/Field/FieldDocs.d.ts +7 -0
  346. package/es/extensions/forms/Field/FieldDocs.js +16 -0
  347. package/es/extensions/forms/Field/FieldDocs.js.map +1 -1
  348. package/es/extensions/forms/Field/Name/Name.js +2 -2
  349. package/es/extensions/forms/Field/Name/Name.js.map +1 -1
  350. package/es/extensions/forms/Field/Number/Number.js +7 -12
  351. package/es/extensions/forms/Field/Number/Number.js.map +1 -1
  352. package/es/extensions/forms/Field/Option/Option.d.ts +2 -4
  353. package/es/extensions/forms/Field/Option/Option.js +0 -20
  354. package/es/extensions/forms/Field/Option/Option.js.map +1 -1
  355. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -2
  356. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +32 -15
  357. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  358. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +3 -0
  359. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +20 -0
  360. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -0
  361. package/es/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +2 -2
  362. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +16 -3
  363. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  364. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.d.ts +1 -0
  365. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +9 -0
  366. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -0
  367. package/es/extensions/forms/Field/Selection/Selection.d.ts +42 -15
  368. package/es/extensions/forms/Field/Selection/Selection.js +86 -28
  369. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  370. package/es/extensions/forms/Field/Selection/SelectionDocs.js +10 -0
  371. package/es/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  372. package/es/extensions/forms/Field/Toggle/Toggle.js +1 -1
  373. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  374. package/es/extensions/forms/FieldBlock/FieldBlock.js +3 -3
  375. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  376. package/es/extensions/forms/Form/Element/Element.js +9 -9
  377. package/es/extensions/forms/Form/Element/Element.js.map +1 -1
  378. package/es/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  379. package/es/extensions/forms/Form/Handler/Handler.js +3 -1
  380. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  381. package/es/extensions/forms/Form/Isolation/Isolation.d.ts +26 -5
  382. package/es/extensions/forms/Form/Isolation/Isolation.js +85 -27
  383. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  384. package/es/extensions/forms/Form/Isolation/IsolationCommitButton.js +1 -0
  385. package/es/extensions/forms/Form/Isolation/IsolationCommitButton.js.map +1 -1
  386. package/es/extensions/forms/Form/Isolation/IsolationDocs.js +11 -1
  387. package/es/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  388. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +13 -5
  389. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  390. package/es/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +10 -11
  391. package/es/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -1
  392. package/es/extensions/forms/Form/Section/Section.js +2 -2
  393. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  394. package/es/extensions/forms/Form/data-context/clearData.d.ts +1 -0
  395. package/es/extensions/forms/Form/data-context/clearData.js +10 -0
  396. package/es/extensions/forms/Form/data-context/clearData.js.map +1 -0
  397. package/es/extensions/forms/Form/index.d.ts +1 -0
  398. package/es/extensions/forms/Form/index.js +1 -0
  399. package/es/extensions/forms/Form/index.js.map +1 -1
  400. package/es/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js +3 -3
  401. package/es/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js.map +1 -1
  402. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +2 -2
  403. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  404. package/es/extensions/forms/Iterate/Array/Array.js +7 -5
  405. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  406. package/es/extensions/forms/Iterate/Array/types.d.ts +1 -4
  407. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  408. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -3
  409. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +26 -20
  410. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  411. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +10 -0
  412. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  413. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +44 -14
  414. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  415. package/{extensions/forms/Iterate/IterateElementContext.d.ts → es/extensions/forms/Iterate/IterateItemContext.d.ts} +3 -3
  416. package/es/extensions/forms/Iterate/IterateItemContext.js +4 -0
  417. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -0
  418. package/es/extensions/forms/Iterate/PushButton/PushButton.js +3 -3
  419. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  420. package/es/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  421. package/es/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  422. package/es/extensions/forms/Iterate/PushContainer/OpenButton.d.ts +4 -0
  423. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js +32 -0
  424. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -0
  425. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +37 -0
  426. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +80 -0
  427. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -0
  428. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +11 -0
  429. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.js +6 -0
  430. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -0
  431. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.d.ts +3 -0
  432. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +34 -0
  433. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -0
  434. package/es/extensions/forms/Iterate/PushContainer/index.d.ts +2 -0
  435. package/es/extensions/forms/Iterate/PushContainer/index.js +3 -0
  436. package/es/extensions/forms/Iterate/PushContainer/index.js.map +1 -0
  437. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -4
  438. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  439. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +4 -0
  440. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +15 -6
  441. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  442. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  443. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  444. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +3 -3
  445. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  446. package/es/extensions/forms/Iterate/hooks/useItem.d.ts +1 -0
  447. package/es/extensions/forms/Iterate/hooks/useItem.js +9 -0
  448. package/es/extensions/forms/Iterate/hooks/useItem.js.map +1 -0
  449. package/es/extensions/forms/Iterate/index.d.ts +3 -1
  450. package/es/extensions/forms/Iterate/index.js +3 -1
  451. package/es/extensions/forms/Iterate/index.js.map +1 -1
  452. package/es/extensions/forms/Iterate/style/dnb-iterate.css +1 -1
  453. package/es/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -1
  454. package/es/extensions/forms/Iterate/style/dnb-iterate.scss +1 -1
  455. package/es/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +19 -0
  456. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js +66 -0
  457. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -0
  458. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.d.ts +2 -0
  459. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +8 -0
  460. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -0
  461. package/es/extensions/forms/Value/ArraySelection/index.d.ts +2 -0
  462. package/es/extensions/forms/Value/ArraySelection/index.js +3 -0
  463. package/es/extensions/forms/Value/ArraySelection/index.js.map +1 -0
  464. package/es/extensions/forms/Value/Selection/Selection.d.ts +9 -0
  465. package/es/extensions/forms/Value/Selection/Selection.js +48 -0
  466. package/es/extensions/forms/Value/Selection/Selection.js.map +1 -0
  467. package/es/extensions/forms/Value/Selection/SelectionDocs.d.ts +2 -0
  468. package/es/extensions/forms/Value/Selection/SelectionDocs.js +8 -0
  469. package/es/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -0
  470. package/es/extensions/forms/Value/Selection/index.d.ts +2 -0
  471. package/es/extensions/forms/Value/Selection/index.js +3 -0
  472. package/es/extensions/forms/Value/Selection/index.js.map +1 -0
  473. package/es/extensions/forms/Value/ValueDocs.js +6 -1
  474. package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
  475. package/es/extensions/forms/Value/index.d.ts +2 -0
  476. package/es/extensions/forms/Value/index.js +2 -0
  477. package/es/extensions/forms/Value/index.js.map +1 -1
  478. package/es/extensions/forms/ValueBlock/ValueBlock.js +3 -3
  479. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  480. package/es/extensions/forms/Wizard/Container/WizardContainer.js +16 -1
  481. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  482. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +1 -0
  483. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  484. package/es/extensions/forms/constants/locales/en-GB.d.ts +7 -0
  485. package/es/extensions/forms/constants/locales/en-GB.js +7 -0
  486. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  487. package/es/extensions/forms/constants/locales/en-US.d.ts +7 -0
  488. package/es/extensions/forms/constants/locales/index.d.ts +14 -0
  489. package/es/extensions/forms/constants/locales/nb-NO.d.ts +7 -0
  490. package/es/extensions/forms/constants/locales/nb-NO.js +7 -0
  491. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  492. package/es/extensions/forms/hooks/DataValueDocs.js +4 -4
  493. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  494. package/es/extensions/forms/hooks/useDataValue.d.ts +2 -0
  495. package/es/extensions/forms/hooks/useDataValue.js +29 -13
  496. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  497. package/es/extensions/forms/hooks/useExternalValue.js +4 -4
  498. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  499. package/es/extensions/forms/hooks/useFieldProps.d.ts +5 -5
  500. package/es/extensions/forms/hooks/useFieldProps.js +49 -31
  501. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  502. package/es/extensions/forms/hooks/usePath.js +2 -2
  503. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  504. package/es/extensions/forms/hooks/useValueProps.js +4 -1
  505. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  506. package/es/extensions/forms/style/dnb-forms.css +1 -1
  507. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  508. package/es/extensions/forms/types.d.ts +20 -7
  509. package/es/extensions/forms/types.js.map +1 -1
  510. package/es/shared/Eufemia.d.ts +1 -1
  511. package/es/shared/Eufemia.js +2 -2
  512. package/es/shared/Eufemia.js.map +1 -1
  513. package/es/shared/helpers/isAsync.js +2 -2
  514. package/es/shared/helpers/isAsync.js.map +1 -1
  515. package/es/shared/locales/en-GB.d.ts +1 -0
  516. package/es/shared/locales/en-GB.js +1 -0
  517. package/es/shared/locales/en-GB.js.map +1 -1
  518. package/es/shared/locales/en-US.d.ts +1 -0
  519. package/es/shared/locales/index.d.ts +2 -0
  520. package/es/shared/locales/nb-NO.d.ts +1 -0
  521. package/es/shared/locales/nb-NO.js +2 -1
  522. package/es/shared/locales/nb-NO.js.map +1 -1
  523. package/es/shared/useTheme.d.ts +4 -10
  524. package/es/shared/useTheme.js +7 -5
  525. package/es/shared/useTheme.js.map +1 -1
  526. package/es/style/core/scopes.scss +1 -1
  527. package/es/style/dnb-ui-basis.css +1 -1
  528. package/es/style/dnb-ui-basis.min.css +1 -1
  529. package/es/style/dnb-ui-body.css +1 -1
  530. package/es/style/dnb-ui-body.min.css +1 -1
  531. package/es/style/dnb-ui-components.css +16 -1
  532. package/es/style/dnb-ui-components.min.css +2 -2
  533. package/es/style/dnb-ui-core.css +1 -1
  534. package/es/style/dnb-ui-core.min.css +1 -1
  535. package/es/style/dnb-ui-extensions.css +1 -1
  536. package/es/style/dnb-ui-extensions.min.css +1 -1
  537. package/es/style/dnb-ui-forms.css +1 -1
  538. package/es/style/dnb-ui-forms.min.css +1 -1
  539. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +17 -2
  540. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
  541. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +1 -1
  542. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  543. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +1 -1
  544. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  545. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +17 -2
  546. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  547. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +1 -1
  548. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  549. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +1 -1
  550. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  551. package/es/style/themes/theme-ui/ui-theme-components.css +17 -2
  552. package/es/style/themes/theme-ui/ui-theme-components.min.css +2 -2
  553. package/es/style/themes/theme-ui/ui-theme-extensions.css +1 -1
  554. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  555. package/es/style/themes/theme-ui/ui-theme-forms.css +1 -1
  556. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  557. package/esm/dnb-ui-basis.min.mjs +1 -1
  558. package/esm/dnb-ui-components.min.mjs +1 -1
  559. package/esm/dnb-ui-elements.min.mjs +1 -1
  560. package/esm/dnb-ui-extensions.min.mjs +5 -5
  561. package/esm/dnb-ui-lib.min.mjs +1 -1
  562. package/extensions/forms/DataContext/Context.d.ts +9 -3
  563. package/extensions/forms/DataContext/Context.js.map +1 -1
  564. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +8 -0
  565. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  566. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +9 -1
  567. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  568. package/extensions/forms/DataContext/Provider/Provider.d.ts +5 -12
  569. package/extensions/forms/DataContext/Provider/Provider.js +56 -18
  570. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  571. package/extensions/forms/DataContext/Provider/ProviderDocs.js +6 -1
  572. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  573. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -1
  574. package/extensions/forms/Field/ArraySelection/ArraySelection.js +28 -24
  575. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  576. package/extensions/forms/Field/Currency/CurrencyDocs.d.ts +2 -0
  577. package/extensions/forms/Field/Currency/CurrencyDocs.js +22 -0
  578. package/extensions/forms/Field/Currency/CurrencyDocs.js.map +1 -0
  579. package/extensions/forms/Field/Expiry/Expiry.d.ts +1 -1
  580. package/extensions/forms/Field/Expiry/Expiry.js.map +1 -1
  581. package/extensions/forms/Field/FieldDocs.d.ts +7 -0
  582. package/extensions/forms/Field/FieldDocs.js +18 -0
  583. package/extensions/forms/Field/FieldDocs.js.map +1 -1
  584. package/extensions/forms/Field/Name/Name.js +2 -2
  585. package/extensions/forms/Field/Name/Name.js.map +1 -1
  586. package/extensions/forms/Field/Number/Number.js +7 -12
  587. package/extensions/forms/Field/Number/Number.js.map +1 -1
  588. package/extensions/forms/Field/Option/Option.d.ts +2 -4
  589. package/extensions/forms/Field/Option/Option.js +0 -20
  590. package/extensions/forms/Field/Option/Option.js.map +1 -1
  591. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -2
  592. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +33 -15
  593. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  594. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +3 -0
  595. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +20 -0
  596. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -0
  597. package/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +2 -2
  598. package/extensions/forms/Field/SelectCountry/SelectCountry.js +32 -16
  599. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  600. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.d.ts +1 -0
  601. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +9 -0
  602. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -0
  603. package/extensions/forms/Field/Selection/Selection.d.ts +42 -15
  604. package/extensions/forms/Field/Selection/Selection.js +90 -28
  605. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  606. package/extensions/forms/Field/Selection/SelectionDocs.js +10 -0
  607. package/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  608. package/extensions/forms/Field/Toggle/Toggle.js +1 -1
  609. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  610. package/extensions/forms/FieldBlock/FieldBlock.js +3 -3
  611. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  612. package/extensions/forms/Form/Element/Element.js +9 -9
  613. package/extensions/forms/Form/Element/Element.js.map +1 -1
  614. package/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  615. package/extensions/forms/Form/Handler/Handler.js +3 -1
  616. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  617. package/extensions/forms/Form/Isolation/Isolation.d.ts +26 -5
  618. package/extensions/forms/Form/Isolation/Isolation.js +85 -27
  619. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  620. package/extensions/forms/Form/Isolation/IsolationCommitButton.js +1 -0
  621. package/extensions/forms/Form/Isolation/IsolationCommitButton.js.map +1 -1
  622. package/extensions/forms/Form/Isolation/IsolationDocs.js +11 -1
  623. package/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  624. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +13 -5
  625. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  626. package/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +10 -11
  627. package/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -1
  628. package/extensions/forms/Form/Section/Section.js +2 -2
  629. package/extensions/forms/Form/Section/Section.js.map +1 -1
  630. package/extensions/forms/Form/data-context/clearData.d.ts +1 -0
  631. package/extensions/forms/Form/data-context/clearData.js +10 -0
  632. package/extensions/forms/Form/data-context/clearData.js.map +1 -0
  633. package/extensions/forms/Form/index.d.ts +1 -0
  634. package/extensions/forms/Form/index.js +1 -0
  635. package/extensions/forms/Form/index.js.map +1 -1
  636. package/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js +3 -3
  637. package/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js.map +1 -1
  638. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +2 -2
  639. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  640. package/extensions/forms/Iterate/Array/Array.js +7 -5
  641. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  642. package/extensions/forms/Iterate/Array/types.d.ts +1 -4
  643. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  644. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -3
  645. package/extensions/forms/Iterate/EditContainer/EditContainer.js +26 -20
  646. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  647. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +10 -0
  648. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  649. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +44 -14
  650. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  651. package/{es/extensions/forms/Iterate/IterateElementContext.d.ts → extensions/forms/Iterate/IterateItemContext.d.ts} +3 -3
  652. package/extensions/forms/Iterate/IterateItemContext.js +4 -0
  653. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -0
  654. package/extensions/forms/Iterate/PushButton/PushButton.js +3 -3
  655. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  656. package/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  657. package/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  658. package/extensions/forms/Iterate/PushContainer/OpenButton.d.ts +4 -0
  659. package/extensions/forms/Iterate/PushContainer/OpenButton.js +32 -0
  660. package/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -0
  661. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +37 -0
  662. package/extensions/forms/Iterate/PushContainer/PushContainer.js +83 -0
  663. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -0
  664. package/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +11 -0
  665. package/extensions/forms/Iterate/PushContainer/PushContainerContext.js +6 -0
  666. package/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -0
  667. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.d.ts +3 -0
  668. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +34 -0
  669. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -0
  670. package/extensions/forms/Iterate/PushContainer/index.d.ts +2 -0
  671. package/extensions/forms/Iterate/PushContainer/index.js +3 -0
  672. package/extensions/forms/Iterate/PushContainer/index.js.map +1 -0
  673. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -4
  674. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  675. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +4 -0
  676. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +15 -6
  677. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  678. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  679. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  680. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +3 -3
  681. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  682. package/extensions/forms/Iterate/hooks/useItem.d.ts +1 -0
  683. package/extensions/forms/Iterate/hooks/useItem.js +9 -0
  684. package/extensions/forms/Iterate/hooks/useItem.js.map +1 -0
  685. package/extensions/forms/Iterate/index.d.ts +3 -1
  686. package/extensions/forms/Iterate/index.js +3 -1
  687. package/extensions/forms/Iterate/index.js.map +1 -1
  688. package/extensions/forms/Iterate/style/dnb-iterate.css +1 -1
  689. package/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -1
  690. package/extensions/forms/Iterate/style/dnb-iterate.scss +1 -1
  691. package/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +19 -0
  692. package/extensions/forms/Value/ArraySelection/ArraySelection.js +70 -0
  693. package/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -0
  694. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.d.ts +2 -0
  695. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +8 -0
  696. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -0
  697. package/extensions/forms/Value/ArraySelection/index.d.ts +2 -0
  698. package/extensions/forms/Value/ArraySelection/index.js +3 -0
  699. package/extensions/forms/Value/ArraySelection/index.js.map +1 -0
  700. package/extensions/forms/Value/Selection/Selection.d.ts +9 -0
  701. package/extensions/forms/Value/Selection/Selection.js +48 -0
  702. package/extensions/forms/Value/Selection/Selection.js.map +1 -0
  703. package/extensions/forms/Value/Selection/SelectionDocs.d.ts +2 -0
  704. package/extensions/forms/Value/Selection/SelectionDocs.js +8 -0
  705. package/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -0
  706. package/extensions/forms/Value/Selection/index.d.ts +2 -0
  707. package/extensions/forms/Value/Selection/index.js +3 -0
  708. package/extensions/forms/Value/Selection/index.js.map +1 -0
  709. package/extensions/forms/Value/ValueDocs.js +6 -1
  710. package/extensions/forms/Value/ValueDocs.js.map +1 -1
  711. package/extensions/forms/Value/index.d.ts +2 -0
  712. package/extensions/forms/Value/index.js +2 -0
  713. package/extensions/forms/Value/index.js.map +1 -1
  714. package/extensions/forms/ValueBlock/ValueBlock.js +3 -3
  715. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  716. package/extensions/forms/Wizard/Container/WizardContainer.js +27 -11
  717. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  718. package/extensions/forms/Wizard/Context/WizardContext.d.ts +1 -0
  719. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  720. package/extensions/forms/constants/locales/en-GB.d.ts +7 -0
  721. package/extensions/forms/constants/locales/en-GB.js +7 -0
  722. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  723. package/extensions/forms/constants/locales/en-US.d.ts +7 -0
  724. package/extensions/forms/constants/locales/index.d.ts +14 -0
  725. package/extensions/forms/constants/locales/nb-NO.d.ts +7 -0
  726. package/extensions/forms/constants/locales/nb-NO.js +7 -0
  727. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  728. package/extensions/forms/hooks/DataValueDocs.js +4 -4
  729. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  730. package/extensions/forms/hooks/useDataValue.d.ts +2 -0
  731. package/extensions/forms/hooks/useDataValue.js +29 -13
  732. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  733. package/extensions/forms/hooks/useExternalValue.js +4 -4
  734. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  735. package/extensions/forms/hooks/useFieldProps.d.ts +5 -5
  736. package/extensions/forms/hooks/useFieldProps.js +49 -31
  737. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  738. package/extensions/forms/hooks/usePath.js +2 -2
  739. package/extensions/forms/hooks/usePath.js.map +1 -1
  740. package/extensions/forms/hooks/useValueProps.js +4 -1
  741. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  742. package/extensions/forms/style/dnb-forms.css +1 -1
  743. package/extensions/forms/style/dnb-forms.min.css +1 -1
  744. package/extensions/forms/types.d.ts +20 -7
  745. package/extensions/forms/types.js.map +1 -1
  746. package/package.json +1 -1
  747. package/shared/Eufemia.d.ts +1 -1
  748. package/shared/Eufemia.js +2 -2
  749. package/shared/Eufemia.js.map +1 -1
  750. package/shared/helpers/isAsync.js +2 -2
  751. package/shared/helpers/isAsync.js.map +1 -1
  752. package/shared/locales/en-GB.d.ts +1 -0
  753. package/shared/locales/en-GB.js +1 -0
  754. package/shared/locales/en-GB.js.map +1 -1
  755. package/shared/locales/en-US.d.ts +1 -0
  756. package/shared/locales/index.d.ts +2 -0
  757. package/shared/locales/nb-NO.d.ts +1 -0
  758. package/shared/locales/nb-NO.js +2 -1
  759. package/shared/locales/nb-NO.js.map +1 -1
  760. package/shared/useTheme.d.ts +4 -10
  761. package/shared/useTheme.js +7 -5
  762. package/shared/useTheme.js.map +1 -1
  763. package/style/core/scopes.scss +1 -1
  764. package/style/dnb-ui-basis.css +1 -1
  765. package/style/dnb-ui-basis.min.css +1 -1
  766. package/style/dnb-ui-body.css +1 -1
  767. package/style/dnb-ui-body.min.css +1 -1
  768. package/style/dnb-ui-components.css +16 -1
  769. package/style/dnb-ui-components.min.css +2 -2
  770. package/style/dnb-ui-core.css +1 -1
  771. package/style/dnb-ui-core.min.css +1 -1
  772. package/style/dnb-ui-extensions.css +1 -1
  773. package/style/dnb-ui-extensions.min.css +1 -1
  774. package/style/dnb-ui-forms.css +1 -1
  775. package/style/dnb-ui-forms.min.css +1 -1
  776. package/style/themes/theme-eiendom/eiendom-theme-components.css +17 -2
  777. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
  778. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +1 -1
  779. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  780. package/style/themes/theme-eiendom/eiendom-theme-forms.css +1 -1
  781. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  782. package/style/themes/theme-sbanken/sbanken-theme-components.css +17 -2
  783. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  784. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +1 -1
  785. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  786. package/style/themes/theme-sbanken/sbanken-theme-forms.css +1 -1
  787. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  788. package/style/themes/theme-ui/ui-theme-components.css +17 -2
  789. package/style/themes/theme-ui/ui-theme-components.min.css +2 -2
  790. package/style/themes/theme-ui/ui-theme-extensions.css +1 -1
  791. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  792. package/style/themes/theme-ui/ui-theme-forms.css +1 -1
  793. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  794. package/umd/dnb-ui-basis.min.js +1 -1
  795. package/umd/dnb-ui-components.min.js +1 -1
  796. package/umd/dnb-ui-elements.min.js +1 -1
  797. package/umd/dnb-ui-extensions.min.js +5 -5
  798. package/umd/dnb-ui-lib.min.js +1 -1
  799. package/cjs/extensions/forms/Iterate/IterateElementContext.js.map +0 -1
  800. package/es/extensions/forms/Iterate/IterateElementContext.js +0 -4
  801. package/es/extensions/forms/Iterate/IterateElementContext.js.map +0 -1
  802. package/extensions/forms/Iterate/IterateElementContext.js +0 -4
  803. package/extensions/forms/Iterate/IterateElementContext.js.map +0 -1
@@ -1 +1 @@
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 type * from './types'\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":"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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","fileTypeTableCaption","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 type * from './types'\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 fileTypeTableCaption, // 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":"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"}
@@ -1,3 +1,4 @@
1
1
  import { PropertiesTableProps } from '../../shared/types';
2
2
  export declare const UploadProperties: PropertiesTableProps;
3
+ export declare const AcceptedFileTypeProperties: PropertiesTableProps;
3
4
  export declare const UploadEvents: PropertiesTableProps;
@@ -1,7 +1,7 @@
1
1
  export const UploadProperties = {
2
2
  acceptedFileTypes: {
3
- doc: 'List of accepted file types.',
4
- type: 'Array<string>',
3
+ doc: 'List of accepted file types. Either as string or [AcceptedFileType](/uilib/components/upload/properties/#acceptedfiletype). When providing a list of [AcceptedFileType](/uilib/components/upload/properties/#acceptedfiletype), the accepted file types will be presented in a table(see [example](/uilib/components/upload/demos/#upload-with-file-max-size-based-on-file-type)).',
4
+ type: ['Array<string>', 'Array<AcceptedFileType>'],
5
5
  status: 'required'
6
6
  },
7
7
  filesAmountLimit: {
@@ -10,8 +10,8 @@ export const UploadProperties = {
10
10
  status: 'optional'
11
11
  },
12
12
  fileMaxSize: {
13
- doc: '`fileMaxSize` is max size of each file in MB. Defaults to 5 MB.',
14
- type: 'number',
13
+ doc: 'Defines the max file size of each file in MB. Use either `0` or `false` to disable. Defaults to 5 MB.',
14
+ type: ['number', 'false'],
15
15
  status: 'optional'
16
16
  },
17
17
  title: {
@@ -35,6 +35,18 @@ export const UploadProperties = {
35
35
  status: 'optional'
36
36
  }
37
37
  };
38
+ export const AcceptedFileTypeProperties = {
39
+ fileType: {
40
+ doc: 'The name of the accepted file type.',
41
+ type: 'string',
42
+ status: 'required'
43
+ },
44
+ fileMaxSize: {
45
+ doc: 'Defines the max file size of the given file type in MB. Use either `0` or `false` to disable. If not provided, it defaults to the value of [Uploads](/uilib/components/upload/properties/#properties) `fileMaxSize` which defaults to 5 MB.',
46
+ type: ['number', 'false'],
47
+ status: 'optional'
48
+ }
49
+ };
38
50
  export const UploadEvents = {
39
51
  onChange: {
40
52
  doc: 'Will be called on `files` changes made by the user. Access the files with `{ files }` (containing each a `fileItem`).',
@@ -1 +1 @@
1
- {"version":3,"file":"UploadDocs.js","names":["UploadProperties","acceptedFileTypes","doc","type","status","filesAmountLimit","fileMaxSize","title","text","skeleton","UploadEvents","onChange","onFileDelete"],"sources":["../../../../src/components/upload/UploadDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../shared/types'\n\nexport const UploadProperties: PropertiesTableProps = {\n acceptedFileTypes: {\n doc: 'List of accepted file types.',\n type: 'Array<string>',\n status: 'required',\n },\n filesAmountLimit: {\n doc: 'Defines the amount of files the user can select and upload. Defaults to 100.',\n type: 'number',\n status: 'optional',\n },\n fileMaxSize: {\n doc: '`fileMaxSize` is max size of each file in MB. Defaults to 5 MB.',\n type: 'number',\n status: 'optional',\n },\n title: {\n doc: 'Custom text property. Replaces the default title.',\n type: 'string',\n status: 'optional',\n },\n text: {\n doc: 'Custom text property. Replaces the default text.',\n type: 'string',\n status: 'optional',\n },\n skeleton: {\n doc: 'Skeleton should be applied when loading content.',\n type: 'boolean',\n status: 'optional',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const UploadEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called on `files` changes made by the user. Access the files with `{ files }` (containing each a `fileItem`).',\n type: 'function',\n status: 'optional',\n },\n onFileDelete: {\n doc: 'Will be called once a file gets deleted by the user. Access the deleted file with `{ fileItem }`.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,gBAAsC,GAAG;EACpDC,iBAAiB,EAAE;IACjBC,GAAG,EAAE,8BAA8B;IACnCC,IAAI,EAAE,eAAe;IACrBC,MAAM,EAAE;EACV,CAAC;EACDC,gBAAgB,EAAE;IAChBH,GAAG,EAAE,8EAA8E;IACnFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,WAAW,EAAE;IACXJ,GAAG,EAAE,iEAAiE;IACtEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,KAAK,EAAE;IACLL,GAAG,EAAE,mDAAmD;IACxDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,IAAI,EAAE;IACJN,GAAG,EAAE,kDAAkD;IACvDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,QAAQ,EAAE;IACRP,GAAG,EAAE,kDAAkD;IACvDC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMM,YAAkC,GAAG;EAChDC,QAAQ,EAAE;IACRT,GAAG,EAAE,uHAAuH;IAC5HC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDQ,YAAY,EAAE;IACZV,GAAG,EAAE,mGAAmG;IACxGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"UploadDocs.js","names":["UploadProperties","acceptedFileTypes","doc","type","status","filesAmountLimit","fileMaxSize","title","text","skeleton","AcceptedFileTypeProperties","fileType","UploadEvents","onChange","onFileDelete"],"sources":["../../../../src/components/upload/UploadDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../shared/types'\n\nexport const UploadProperties: PropertiesTableProps = {\n acceptedFileTypes: {\n doc: 'List of accepted file types. Either as string or [AcceptedFileType](/uilib/components/upload/properties/#acceptedfiletype). When providing a list of [AcceptedFileType](/uilib/components/upload/properties/#acceptedfiletype), the accepted file types will be presented in a table(see [example](/uilib/components/upload/demos/#upload-with-file-max-size-based-on-file-type)).',\n type: ['Array<string>', 'Array<AcceptedFileType>'],\n status: 'required',\n },\n filesAmountLimit: {\n doc: 'Defines the amount of files the user can select and upload. Defaults to 100.',\n type: 'number',\n status: 'optional',\n },\n fileMaxSize: {\n doc: 'Defines the max file size of each file in MB. Use either `0` or `false` to disable. Defaults to 5 MB.',\n type: ['number', 'false'],\n status: 'optional',\n },\n title: {\n doc: 'Custom text property. Replaces the default title.',\n type: 'string',\n status: 'optional',\n },\n text: {\n doc: 'Custom text property. Replaces the default text.',\n type: 'string',\n status: 'optional',\n },\n skeleton: {\n doc: 'Skeleton should be applied when loading content.',\n type: 'boolean',\n status: 'optional',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const AcceptedFileTypeProperties: PropertiesTableProps = {\n fileType: {\n doc: 'The name of the accepted file type.',\n type: 'string',\n status: 'required',\n },\n fileMaxSize: {\n doc: 'Defines the max file size of the given file type in MB. Use either `0` or `false` to disable. If not provided, it defaults to the value of [Uploads](/uilib/components/upload/properties/#properties) `fileMaxSize` which defaults to 5 MB.',\n type: ['number', 'false'],\n status: 'optional',\n },\n}\n\nexport const UploadEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called on `files` changes made by the user. Access the files with `{ files }` (containing each a `fileItem`).',\n type: 'function',\n status: 'optional',\n },\n onFileDelete: {\n doc: 'Will be called once a file gets deleted by the user. Access the deleted file with `{ fileItem }`.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,gBAAsC,GAAG;EACpDC,iBAAiB,EAAE;IACjBC,GAAG,EAAE,oXAAoX;IACzXC,IAAI,EAAE,CAAC,eAAe,EAAE,yBAAyB,CAAC;IAClDC,MAAM,EAAE;EACV,CAAC;EACDC,gBAAgB,EAAE;IAChBH,GAAG,EAAE,8EAA8E;IACnFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,WAAW,EAAE;IACXJ,GAAG,EAAE,uGAAuG;IAC5GC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDG,KAAK,EAAE;IACLL,GAAG,EAAE,mDAAmD;IACxDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,IAAI,EAAE;IACJN,GAAG,EAAE,kDAAkD;IACvDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,QAAQ,EAAE;IACRP,GAAG,EAAE,kDAAkD;IACvDC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMM,0BAAgD,GAAG;EAC9DC,QAAQ,EAAE;IACRT,GAAG,EAAE,qCAAqC;IAC1CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,WAAW,EAAE;IACXJ,GAAG,EAAE,6OAA6O;IAClPC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMQ,YAAkC,GAAG;EAChDC,QAAQ,EAAE;IACRX,GAAG,EAAE,uHAAuH;IAC5HC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDU,YAAY,EAAE;IACZZ,GAAG,EAAE,mGAAmG;IACxGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -1,3 +1,4 @@
1
+ var _UploadInfoAcceptedFi;
1
2
  import React from 'react';
2
3
  import { defaultProps, UploadContext } from './UploadContext';
3
4
  import Lead from '../../elements/Lead';
@@ -6,6 +7,12 @@ import Dl from '../../elements/Dl';
6
7
  import Dt from '../../elements/Dt';
7
8
  import Dd from '../../elements/Dd';
8
9
  import { format } from '../number-format/NumberUtils';
10
+ import { isArrayOfObjects, isArrayOfStrings } from './UploadVerify';
11
+ import Table from '../Table';
12
+ import Tr from '../table/TableTr';
13
+ import Th from '../table/TableTh';
14
+ import Td from '../table/TableTd';
15
+ const prettifyAcceptedFileFormats = acceptedFileTypes => acceptedFileTypes.sort().join(', ').toUpperCase();
9
16
  const UploadInfo = () => {
10
17
  const context = React.useContext(UploadContext);
11
18
  const {
@@ -20,18 +27,63 @@ const UploadInfo = () => {
20
27
  fileMaxSize,
21
28
  children
22
29
  } = context;
23
- const prettifiedAcceptedFileFormats = acceptedFileTypes.join(', ').toUpperCase();
30
+ const prettifiedAcceptedFileFormats = prettifyAcceptedFileFormats(acceptedFileTypes);
31
+ const isAcceptedFileTypeListOfStrings = isArrayOfStrings(acceptedFileTypes);
32
+ const displayAcceptedFileFormatsListItem = isAcceptedFileTypeListOfStrings && prettifiedAcceptedFileFormats;
33
+ const displayFileMaxSizeItem = isAcceptedFileTypeListOfStrings && fileMaxSize;
34
+ const displayFilesAmountLimitItem = filesAmountLimit < defaultProps.filesAmountLimit;
35
+ const displayAcceptedFileFormatsTable = isArrayOfObjects(acceptedFileTypes);
36
+ const displayDl = displayAcceptedFileFormatsListItem || displayFileMaxSizeItem || displayFilesAmountLimitItem;
24
37
  return React.createElement(React.Fragment, null, React.createElement(Lead, {
25
38
  space: "0"
26
39
  }, title), React.createElement(P, {
27
40
  top: "xx-small",
28
41
  className: "dnb-upload__text"
29
- }, text), children, React.createElement(Dl, {
42
+ }, text), children, displayDl && React.createElement(Dl, {
30
43
  top: "small",
31
44
  bottom: 0,
32
- layout: "horizontal",
33
- className: "dnb-upload__condition-list"
34
- }, prettifiedAcceptedFileFormats && React.createElement(Dl.Item, null, React.createElement(Dt, null, fileTypeDescription), React.createElement(Dd, null, prettifiedAcceptedFileFormats)), React.createElement(Dl.Item, null, React.createElement(Dt, null, fileSizeDescription), React.createElement(Dd, null, String(fileSizeContent).replace('%size', format(fileMaxSize).toString()))), filesAmountLimit < defaultProps.filesAmountLimit && React.createElement(Dl.Item, null, React.createElement(Dt, null, fileAmountDescription), React.createElement(Dd, null, filesAmountLimit))));
45
+ layout: "horizontal"
46
+ }, displayAcceptedFileFormatsListItem && React.createElement(Dl.Item, null, React.createElement(Dt, null, fileTypeDescription), React.createElement(Dd, null, prettifiedAcceptedFileFormats)), displayFileMaxSizeItem && React.createElement(Dl.Item, null, React.createElement(Dt, null, fileSizeDescription), React.createElement(Dd, null, String(fileSizeContent).replace('%size', format(fileMaxSize).toString()))), displayFilesAmountLimitItem && React.createElement(Dl.Item, null, React.createElement(Dt, null, fileAmountDescription), React.createElement(Dd, null, filesAmountLimit))), displayAcceptedFileFormatsTable && (_UploadInfoAcceptedFi || (_UploadInfoAcceptedFi = React.createElement(UploadInfoAcceptedFileTypesTable, null))));
35
47
  };
48
+ function UploadInfoAcceptedFileTypesTable() {
49
+ const context = React.useContext(UploadContext);
50
+ const {
51
+ acceptedFileTypes,
52
+ fileTypeTableCaption,
53
+ fileTypeDescription,
54
+ fileSizeDescription,
55
+ fileSizeContent,
56
+ fileMaxSize
57
+ } = context;
58
+ const groupByFileMaxSize = (acceptedFileTypes, fallBackFileMaxSize) => {
59
+ const fileMaxSizeIsFalseOrZero = fileMaxSize => {
60
+ return fileMaxSize === false || fileMaxSize === 0;
61
+ };
62
+ const group = {};
63
+ acceptedFileTypes.forEach(item => {
64
+ const itemFileMaxSize = item.fileMaxSize;
65
+ const groupName = itemFileMaxSize ? itemFileMaxSize : fileMaxSizeIsFalseOrZero(itemFileMaxSize) ? 0 : fileMaxSizeIsFalseOrZero(fallBackFileMaxSize) ? 0 : fallBackFileMaxSize;
66
+ group[groupName] = group[groupName] || [];
67
+ group[groupName].push(item);
68
+ });
69
+ return group;
70
+ };
71
+ const acceptedFileTypesGroupedByFileMaxSize = groupByFileMaxSize(acceptedFileTypes, fileMaxSize);
72
+ return React.createElement(Table, {
73
+ border: true,
74
+ className: "dnb-upload__accepted-file-types-table",
75
+ size: "small"
76
+ }, React.createElement("caption", {
77
+ className: "dnb-sr-only"
78
+ }, fileTypeTableCaption), React.createElement("thead", null, React.createElement(Tr, {
79
+ variant: "odd",
80
+ cellSpacing: 0
81
+ }, React.createElement(Th, null, fileTypeDescription), React.createElement(Th, null, fileSizeDescription))), React.createElement("tbody", null, Object.keys(acceptedFileTypesGroupedByFileMaxSize).sort((a, b) => Number(b) - Number(a)).map(key => {
82
+ return React.createElement(Tr, {
83
+ variant: "odd",
84
+ key: key
85
+ }, React.createElement(Td, null, prettifyAcceptedFileFormats(acceptedFileTypesGroupedByFileMaxSize[key].map(acceptedFileTypesObj => acceptedFileTypesObj.fileType))), React.createElement(Td, null, key !== '0' && String(fileSizeContent).replace('%size', format(key).toString())));
86
+ })));
87
+ }
36
88
  export default UploadInfo;
37
89
  //# sourceMappingURL=UploadInfo.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"UploadInfo.js","names":["React","defaultProps","UploadContext","Lead","P","Dl","Dt","Dd","format","UploadInfo","context","useContext","title","text","acceptedFileTypes","fileTypeDescription","fileSizeDescription","fileAmountDescription","fileSizeContent","filesAmountLimit","fileMaxSize","children","prettifiedAcceptedFileFormats","join","toUpperCase","createElement","Fragment","space","top","className","bottom","layout","Item","String","replace","toString"],"sources":["../../../../src/components/upload/UploadInfo.tsx"],"sourcesContent":["import React from 'react'\nimport { defaultProps, UploadContext } from './UploadContext'\nimport Lead from '../../elements/Lead'\nimport P from '../../elements/P'\nimport Dl from '../../elements/Dl'\nimport Dt from '../../elements/Dt'\nimport Dd from '../../elements/Dd'\nimport { format } from '../number-format/NumberUtils'\n\nconst UploadInfo = () => {\n const context = React.useContext(UploadContext)\n\n const {\n title,\n text,\n acceptedFileTypes,\n fileTypeDescription,\n fileSizeDescription,\n fileAmountDescription,\n fileSizeContent,\n filesAmountLimit,\n fileMaxSize,\n children,\n } = context\n\n const prettifiedAcceptedFileFormats = acceptedFileTypes\n .join(', ')\n .toUpperCase()\n\n return (\n <>\n <Lead space=\"0\">{title}</Lead>\n\n <P top=\"xx-small\" className=\"dnb-upload__text\">\n {text}\n </P>\n\n {children}\n\n <Dl\n top=\"small\"\n bottom={0}\n layout=\"horizontal\"\n className=\"dnb-upload__condition-list\"\n >\n {prettifiedAcceptedFileFormats && (\n <Dl.Item>\n <Dt>{fileTypeDescription}</Dt>\n <Dd>{prettifiedAcceptedFileFormats}</Dd>\n </Dl.Item>\n )}\n\n <Dl.Item>\n <Dt>{fileSizeDescription}</Dt>\n <Dd>\n {String(fileSizeContent).replace(\n '%size',\n format(fileMaxSize).toString()\n )}\n </Dd>\n </Dl.Item>\n\n {filesAmountLimit < defaultProps.filesAmountLimit && (\n <Dl.Item>\n <Dt>{fileAmountDescription}</Dt>\n <Dd>{filesAmountLimit}</Dd>\n </Dl.Item>\n )}\n </Dl>\n </>\n )\n}\n\nexport default UploadInfo\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,YAAY,EAAEC,aAAa,QAAQ,iBAAiB;AAC7D,OAAOC,IAAI,MAAM,qBAAqB;AACtC,OAAOC,CAAC,MAAM,kBAAkB;AAChC,OAAOC,EAAE,MAAM,mBAAmB;AAClC,OAAOC,EAAE,MAAM,mBAAmB;AAClC,OAAOC,EAAE,MAAM,mBAAmB;AAClC,SAASC,MAAM,QAAQ,8BAA8B;AAErD,MAAMC,UAAU,GAAGA,CAAA,KAAM;EACvB,MAAMC,OAAO,GAAGV,KAAK,CAACW,UAAU,CAACT,aAAa,CAAC;EAE/C,MAAM;IACJU,KAAK;IACLC,IAAI;IACJC,iBAAiB;IACjBC,mBAAmB;IACnBC,mBAAmB;IACnBC,qBAAqB;IACrBC,eAAe;IACfC,gBAAgB;IAChBC,WAAW;IACXC;EACF,CAAC,GAAGX,OAAO;EAEX,MAAMY,6BAA6B,GAAGR,iBAAiB,CACpDS,IAAI,CAAC,IAAI,CAAC,CACVC,WAAW,CAAC,CAAC;EAEhB,OACExB,KAAA,CAAAyB,aAAA,CAAAzB,KAAA,CAAA0B,QAAA,QACE1B,KAAA,CAAAyB,aAAA,CAACtB,IAAI;IAACwB,KAAK,EAAC;EAAG,GAAEf,KAAY,CAAC,EAE9BZ,KAAA,CAAAyB,aAAA,CAACrB,CAAC;IAACwB,GAAG,EAAC,UAAU;IAACC,SAAS,EAAC;EAAkB,GAC3ChB,IACA,CAAC,EAEHQ,QAAQ,EAETrB,KAAA,CAAAyB,aAAA,CAACpB,EAAE;IACDuB,GAAG,EAAC,OAAO;IACXE,MAAM,EAAE,CAAE;IACVC,MAAM,EAAC,YAAY;IACnBF,SAAS,EAAC;EAA4B,GAErCP,6BAA6B,IAC5BtB,KAAA,CAAAyB,aAAA,CAACpB,EAAE,CAAC2B,IAAI,QACNhC,KAAA,CAAAyB,aAAA,CAACnB,EAAE,QAAES,mBAAwB,CAAC,EAC9Bf,KAAA,CAAAyB,aAAA,CAAClB,EAAE,QAAEe,6BAAkC,CAChC,CACV,EAEDtB,KAAA,CAAAyB,aAAA,CAACpB,EAAE,CAAC2B,IAAI,QACNhC,KAAA,CAAAyB,aAAA,CAACnB,EAAE,QAAEU,mBAAwB,CAAC,EAC9BhB,KAAA,CAAAyB,aAAA,CAAClB,EAAE,QACA0B,MAAM,CAACf,eAAe,CAAC,CAACgB,OAAO,CAC9B,OAAO,EACP1B,MAAM,CAACY,WAAW,CAAC,CAACe,QAAQ,CAAC,CAC/B,CACE,CACG,CAAC,EAEThB,gBAAgB,GAAGlB,YAAY,CAACkB,gBAAgB,IAC/CnB,KAAA,CAAAyB,aAAA,CAACpB,EAAE,CAAC2B,IAAI,QACNhC,KAAA,CAAAyB,aAAA,CAACnB,EAAE,QAAEW,qBAA0B,CAAC,EAChCjB,KAAA,CAAAyB,aAAA,CAAClB,EAAE,QAAEY,gBAAqB,CACnB,CAET,CACJ,CAAC;AAEP,CAAC;AAED,eAAeV,UAAU"}
1
+ {"version":3,"file":"UploadInfo.js","names":["React","defaultProps","UploadContext","Lead","P","Dl","Dt","Dd","format","isArrayOfObjects","isArrayOfStrings","Table","Tr","Th","Td","prettifyAcceptedFileFormats","acceptedFileTypes","sort","join","toUpperCase","UploadInfo","context","useContext","title","text","fileTypeDescription","fileSizeDescription","fileAmountDescription","fileSizeContent","filesAmountLimit","fileMaxSize","children","prettifiedAcceptedFileFormats","isAcceptedFileTypeListOfStrings","displayAcceptedFileFormatsListItem","displayFileMaxSizeItem","displayFilesAmountLimitItem","displayAcceptedFileFormatsTable","displayDl","createElement","Fragment","space","top","className","bottom","layout","Item","String","replace","toString","_UploadInfoAcceptedFi","UploadInfoAcceptedFileTypesTable","fileTypeTableCaption","groupByFileMaxSize","fallBackFileMaxSize","fileMaxSizeIsFalseOrZero","group","forEach","item","itemFileMaxSize","groupName","push","acceptedFileTypesGroupedByFileMaxSize","border","size","variant","cellSpacing","Object","keys","a","b","Number","map","key","acceptedFileTypesObj","fileType"],"sources":["../../../../src/components/upload/UploadInfo.tsx"],"sourcesContent":["import React from 'react'\nimport { defaultProps, UploadContext } from './UploadContext'\nimport Lead from '../../elements/Lead'\nimport P from '../../elements/P'\nimport Dl from '../../elements/Dl'\nimport Dt from '../../elements/Dt'\nimport Dd from '../../elements/Dd'\nimport { format } from '../number-format/NumberUtils'\nimport { isArrayOfObjects, isArrayOfStrings } from './UploadVerify'\nimport Table from '../Table'\nimport Tr from '../table/TableTr'\nimport Th from '../table/TableTh'\nimport Td from '../table/TableTd'\nimport { UploadAcceptedFileTypeObject, UploadProps } from './types'\n\nconst prettifyAcceptedFileFormats = (acceptedFileTypes) =>\n acceptedFileTypes.sort().join(', ').toUpperCase()\n\nconst UploadInfo = () => {\n const context = React.useContext(UploadContext)\n\n const {\n title,\n text,\n acceptedFileTypes,\n fileTypeDescription,\n fileSizeDescription,\n fileAmountDescription,\n fileSizeContent,\n filesAmountLimit,\n fileMaxSize,\n children,\n } = context\n\n const prettifiedAcceptedFileFormats =\n prettifyAcceptedFileFormats(acceptedFileTypes)\n\n const isAcceptedFileTypeListOfStrings =\n isArrayOfStrings(acceptedFileTypes)\n\n const displayAcceptedFileFormatsListItem =\n isAcceptedFileTypeListOfStrings && prettifiedAcceptedFileFormats\n\n const displayFileMaxSizeItem =\n isAcceptedFileTypeListOfStrings && fileMaxSize\n\n const displayFilesAmountLimitItem =\n filesAmountLimit < defaultProps.filesAmountLimit\n\n const displayAcceptedFileFormatsTable =\n isArrayOfObjects(acceptedFileTypes)\n\n const displayDl =\n displayAcceptedFileFormatsListItem ||\n displayFileMaxSizeItem ||\n displayFilesAmountLimitItem\n\n return (\n <>\n <Lead space=\"0\">{title}</Lead>\n\n <P top=\"xx-small\" className=\"dnb-upload__text\">\n {text}\n </P>\n\n {children}\n\n {displayDl && (\n <Dl top=\"small\" bottom={0} layout=\"horizontal\">\n {displayAcceptedFileFormatsListItem && (\n <Dl.Item>\n <Dt>{fileTypeDescription}</Dt>\n <Dd>{prettifiedAcceptedFileFormats}</Dd>\n </Dl.Item>\n )}\n\n {displayFileMaxSizeItem && (\n <Dl.Item>\n <Dt>{fileSizeDescription}</Dt>\n <Dd>\n {String(fileSizeContent).replace(\n '%size',\n format(fileMaxSize).toString()\n )}\n </Dd>\n </Dl.Item>\n )}\n\n {displayFilesAmountLimitItem && (\n <Dl.Item>\n <Dt>{fileAmountDescription}</Dt>\n <Dd>{filesAmountLimit}</Dd>\n </Dl.Item>\n )}\n </Dl>\n )}\n {displayAcceptedFileFormatsTable && (\n <UploadInfoAcceptedFileTypesTable />\n )}\n </>\n )\n}\n\nfunction UploadInfoAcceptedFileTypesTable() {\n const context = React.useContext(UploadContext)\n\n const {\n acceptedFileTypes,\n fileTypeTableCaption,\n fileTypeDescription,\n fileSizeDescription,\n fileSizeContent,\n fileMaxSize,\n } = context\n\n const groupByFileMaxSize = (\n acceptedFileTypes: UploadProps['acceptedFileTypes'],\n fallBackFileMaxSize: UploadProps['fileMaxSize']\n ) => {\n const fileMaxSizeIsFalseOrZero = (\n fileMaxSize: UploadProps['fileMaxSize']\n ) => {\n return fileMaxSize === false || fileMaxSize === 0\n }\n\n const group = {}\n acceptedFileTypes.forEach((item) => {\n const itemFileMaxSize = item.fileMaxSize\n const groupName = itemFileMaxSize\n ? itemFileMaxSize\n : fileMaxSizeIsFalseOrZero(itemFileMaxSize)\n ? 0\n : fileMaxSizeIsFalseOrZero(fallBackFileMaxSize)\n ? 0\n : fallBackFileMaxSize\n\n group[groupName] = group[groupName] || []\n group[groupName].push(item)\n })\n\n return group\n }\n\n const acceptedFileTypesGroupedByFileMaxSize = groupByFileMaxSize(\n acceptedFileTypes,\n fileMaxSize\n )\n\n return (\n <Table\n border\n className=\"dnb-upload__accepted-file-types-table\"\n size=\"small\"\n >\n <caption className=\"dnb-sr-only\">{fileTypeTableCaption}</caption>\n <thead>\n <Tr variant=\"odd\" cellSpacing={0}>\n <Th>{fileTypeDescription}</Th>\n <Th>{fileSizeDescription}</Th>\n </Tr>\n </thead>\n <tbody>\n {Object.keys(acceptedFileTypesGroupedByFileMaxSize)\n .sort((a, b) => Number(b) - Number(a))\n .map((key) => {\n return (\n <Tr variant=\"odd\" key={key}>\n <Td>\n {prettifyAcceptedFileFormats(\n acceptedFileTypesGroupedByFileMaxSize[key].map(\n (\n acceptedFileTypesObj: UploadAcceptedFileTypeObject\n ) => acceptedFileTypesObj.fileType\n )\n )}\n </Td>\n <Td>\n {key !== '0' &&\n String(fileSizeContent).replace(\n '%size',\n format(key).toString()\n )}\n </Td>\n </Tr>\n )\n })}\n </tbody>\n </Table>\n )\n}\n\nexport default UploadInfo\n"],"mappings":";AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,YAAY,EAAEC,aAAa,QAAQ,iBAAiB;AAC7D,OAAOC,IAAI,MAAM,qBAAqB;AACtC,OAAOC,CAAC,MAAM,kBAAkB;AAChC,OAAOC,EAAE,MAAM,mBAAmB;AAClC,OAAOC,EAAE,MAAM,mBAAmB;AAClC,OAAOC,EAAE,MAAM,mBAAmB;AAClC,SAASC,MAAM,QAAQ,8BAA8B;AACrD,SAASC,gBAAgB,EAAEC,gBAAgB,QAAQ,gBAAgB;AACnE,OAAOC,KAAK,MAAM,UAAU;AAC5B,OAAOC,EAAE,MAAM,kBAAkB;AACjC,OAAOC,EAAE,MAAM,kBAAkB;AACjC,OAAOC,EAAE,MAAM,kBAAkB;AAGjC,MAAMC,2BAA2B,GAAIC,iBAAiB,IACpDA,iBAAiB,CAACC,IAAI,CAAC,CAAC,CAACC,IAAI,CAAC,IAAI,CAAC,CAACC,WAAW,CAAC,CAAC;AAEnD,MAAMC,UAAU,GAAGA,CAAA,KAAM;EACvB,MAAMC,OAAO,GAAGrB,KAAK,CAACsB,UAAU,CAACpB,aAAa,CAAC;EAE/C,MAAM;IACJqB,KAAK;IACLC,IAAI;IACJR,iBAAiB;IACjBS,mBAAmB;IACnBC,mBAAmB;IACnBC,qBAAqB;IACrBC,eAAe;IACfC,gBAAgB;IAChBC,WAAW;IACXC;EACF,CAAC,GAAGV,OAAO;EAEX,MAAMW,6BAA6B,GACjCjB,2BAA2B,CAACC,iBAAiB,CAAC;EAEhD,MAAMiB,+BAA+B,GACnCvB,gBAAgB,CAACM,iBAAiB,CAAC;EAErC,MAAMkB,kCAAkC,GACtCD,+BAA+B,IAAID,6BAA6B;EAElE,MAAMG,sBAAsB,GAC1BF,+BAA+B,IAAIH,WAAW;EAEhD,MAAMM,2BAA2B,GAC/BP,gBAAgB,GAAG5B,YAAY,CAAC4B,gBAAgB;EAElD,MAAMQ,+BAA+B,GACnC5B,gBAAgB,CAACO,iBAAiB,CAAC;EAErC,MAAMsB,SAAS,GACbJ,kCAAkC,IAClCC,sBAAsB,IACtBC,2BAA2B;EAE7B,OACEpC,KAAA,CAAAuC,aAAA,CAAAvC,KAAA,CAAAwC,QAAA,QACExC,KAAA,CAAAuC,aAAA,CAACpC,IAAI;IAACsC,KAAK,EAAC;EAAG,GAAElB,KAAY,CAAC,EAE9BvB,KAAA,CAAAuC,aAAA,CAACnC,CAAC;IAACsC,GAAG,EAAC,UAAU;IAACC,SAAS,EAAC;EAAkB,GAC3CnB,IACA,CAAC,EAEHO,QAAQ,EAERO,SAAS,IACRtC,KAAA,CAAAuC,aAAA,CAAClC,EAAE;IAACqC,GAAG,EAAC,OAAO;IAACE,MAAM,EAAE,CAAE;IAACC,MAAM,EAAC;EAAY,GAC3CX,kCAAkC,IACjClC,KAAA,CAAAuC,aAAA,CAAClC,EAAE,CAACyC,IAAI,QACN9C,KAAA,CAAAuC,aAAA,CAACjC,EAAE,QAAEmB,mBAAwB,CAAC,EAC9BzB,KAAA,CAAAuC,aAAA,CAAChC,EAAE,QAAEyB,6BAAkC,CAChC,CACV,EAEAG,sBAAsB,IACrBnC,KAAA,CAAAuC,aAAA,CAAClC,EAAE,CAACyC,IAAI,QACN9C,KAAA,CAAAuC,aAAA,CAACjC,EAAE,QAAEoB,mBAAwB,CAAC,EAC9B1B,KAAA,CAAAuC,aAAA,CAAChC,EAAE,QACAwC,MAAM,CAACnB,eAAe,CAAC,CAACoB,OAAO,CAC9B,OAAO,EACPxC,MAAM,CAACsB,WAAW,CAAC,CAACmB,QAAQ,CAAC,CAC/B,CACE,CACG,CACV,EAEAb,2BAA2B,IAC1BpC,KAAA,CAAAuC,aAAA,CAAClC,EAAE,CAACyC,IAAI,QACN9C,KAAA,CAAAuC,aAAA,CAACjC,EAAE,QAAEqB,qBAA0B,CAAC,EAChC3B,KAAA,CAAAuC,aAAA,CAAChC,EAAE,QAAEsB,gBAAqB,CACnB,CAET,CACL,EACAQ,+BAA+B,KAAAa,qBAAA,KAAAA,qBAAA,GAC9BlD,KAAA,CAAAuC,aAAA,CAACY,gCAAgC,MAAE,CAAC,EAEtC,CAAC;AAEP,CAAC;AAED,SAASA,gCAAgCA,CAAA,EAAG;EAC1C,MAAM9B,OAAO,GAAGrB,KAAK,CAACsB,UAAU,CAACpB,aAAa,CAAC;EAE/C,MAAM;IACJc,iBAAiB;IACjBoC,oBAAoB;IACpB3B,mBAAmB;IACnBC,mBAAmB;IACnBE,eAAe;IACfE;EACF,CAAC,GAAGT,OAAO;EAEX,MAAMgC,kBAAkB,GAAGA,CACzBrC,iBAAmD,EACnDsC,mBAA+C,KAC5C;IACH,MAAMC,wBAAwB,GAC5BzB,WAAuC,IACpC;MACH,OAAOA,WAAW,KAAK,KAAK,IAAIA,WAAW,KAAK,CAAC;IACnD,CAAC;IAED,MAAM0B,KAAK,GAAG,CAAC,CAAC;IAChBxC,iBAAiB,CAACyC,OAAO,CAAEC,IAAI,IAAK;MAClC,MAAMC,eAAe,GAAGD,IAAI,CAAC5B,WAAW;MACxC,MAAM8B,SAAS,GAAGD,eAAe,GAC7BA,eAAe,GACfJ,wBAAwB,CAACI,eAAe,CAAC,GACzC,CAAC,GACDJ,wBAAwB,CAACD,mBAAmB,CAAC,GAC7C,CAAC,GACDA,mBAAmB;MAEvBE,KAAK,CAACI,SAAS,CAAC,GAAGJ,KAAK,CAACI,SAAS,CAAC,IAAI,EAAE;MACzCJ,KAAK,CAACI,SAAS,CAAC,CAACC,IAAI,CAACH,IAAI,CAAC;IAC7B,CAAC,CAAC;IAEF,OAAOF,KAAK;EACd,CAAC;EAED,MAAMM,qCAAqC,GAAGT,kBAAkB,CAC9DrC,iBAAiB,EACjBc,WACF,CAAC;EAED,OACE9B,KAAA,CAAAuC,aAAA,CAAC5B,KAAK;IACJoD,MAAM;IACNpB,SAAS,EAAC,uCAAuC;IACjDqB,IAAI,EAAC;EAAO,GAEZhE,KAAA,CAAAuC,aAAA;IAASI,SAAS,EAAC;EAAa,GAAES,oBAA8B,CAAC,EACjEpD,KAAA,CAAAuC,aAAA,gBACEvC,KAAA,CAAAuC,aAAA,CAAC3B,EAAE;IAACqD,OAAO,EAAC,KAAK;IAACC,WAAW,EAAE;EAAE,GAC/BlE,KAAA,CAAAuC,aAAA,CAAC1B,EAAE,QAAEY,mBAAwB,CAAC,EAC9BzB,KAAA,CAAAuC,aAAA,CAAC1B,EAAE,QAAEa,mBAAwB,CAC3B,CACC,CAAC,EACR1B,KAAA,CAAAuC,aAAA,gBACG4B,MAAM,CAACC,IAAI,CAACN,qCAAqC,CAAC,CAChD7C,IAAI,CAAC,CAACoD,CAAC,EAAEC,CAAC,KAAKC,MAAM,CAACD,CAAC,CAAC,GAAGC,MAAM,CAACF,CAAC,CAAC,CAAC,CACrCG,GAAG,CAAEC,GAAG,IAAK;IACZ,OACEzE,KAAA,CAAAuC,aAAA,CAAC3B,EAAE;MAACqD,OAAO,EAAC,KAAK;MAACQ,GAAG,EAAEA;IAAI,GACzBzE,KAAA,CAAAuC,aAAA,CAACzB,EAAE,QACAC,2BAA2B,CAC1B+C,qCAAqC,CAACW,GAAG,CAAC,CAACD,GAAG,CAE1CE,oBAAkD,IAC/CA,oBAAoB,CAACC,QAC5B,CACF,CACE,CAAC,EACL3E,KAAA,CAAAuC,aAAA,CAACzB,EAAE,QACA2D,GAAG,KAAK,GAAG,IACV1B,MAAM,CAACnB,eAAe,CAAC,CAACoB,OAAO,CAC7B,OAAO,EACPxC,MAAM,CAACiE,GAAG,CAAC,CAACxB,QAAQ,CAAC,CACvB,CACA,CACF,CAAC;EAET,CAAC,CACE,CACF,CAAC;AAEZ;AAEA,eAAe7B,UAAU"}
@@ -1,9 +1,11 @@
1
- import { UploadFile, UploadContextProps, UploadAcceptedFileTypes } from './types';
1
+ import { UploadFile, UploadContextProps, UploadAcceptedFileTypes, UploadAcceptedFileTypesWithFileMaxSize } from './types';
2
2
  export declare const BYTES_IN_A_MEGA_BYTE = 1048576;
3
3
  export declare function verifyFiles(files: UploadFile[], context: Pick<UploadContextProps, 'errorUnsupportedFile' | 'errorLargeFile' | 'acceptedFileTypes' | 'fileMaxSize'>): UploadFile[];
4
4
  export declare function getFileTypeFromExtension(file: File): string;
5
- export declare function getAcceptedFileTypes(acceptedFileTypes: UploadAcceptedFileTypes): string;
5
+ export declare function getAcceptedFileTypes(acceptedFileTypes: UploadAcceptedFileTypes | UploadAcceptedFileTypesWithFileMaxSize): string;
6
6
  export declare function hasPreferredMimeType(acceptedFileTypes: UploadAcceptedFileTypes, file: File): boolean;
7
+ export declare function isArrayOfStrings(arr: any): boolean;
8
+ export declare function isArrayOfObjects(arr: any): boolean;
7
9
  export declare function extendWithAbbreviation(acceptedFileTypes: UploadAcceptedFileTypes, abbreviations?: {
8
10
  jpg: string;
9
11
  }): string[];
@@ -7,15 +7,34 @@ export function verifyFiles(files, context) {
7
7
  errorLargeFile,
8
8
  errorUnsupportedFile
9
9
  } = context;
10
+ const getFileType = (file, listOfAcceptedFilesTypes) => {
11
+ return hasPreferredMimeType(listOfAcceptedFilesTypes, file) ? file.type : getFileTypeFromExtension(file) || file.type;
12
+ };
10
13
  const handleSize = file => {
11
- return file.size / BYTES_IN_A_MEGA_BYTE > fileMaxSize ? String(errorLargeFile).replace('%size', format(fileMaxSize).toString()) : null;
14
+ const validateFileSize = (fileSize, maxFileSize) => {
15
+ if (maxFileSize && fileSize / BYTES_IN_A_MEGA_BYTE > maxFileSize) {
16
+ return String(errorLargeFile).replace('%size', format(maxFileSize).toString());
17
+ }
18
+ return null;
19
+ };
20
+ if (isArrayOfStrings(acceptedFileTypes) || acceptedFileTypes.length === 0 || !acceptedFileTypes) {
21
+ return validateFileSize(file.size, fileMaxSize);
22
+ } else if (isArrayOfObjects(acceptedFileTypes)) {
23
+ const fileType = getFileType(file, getAcceptedFileTypesAsListOfStrings(acceptedFileTypes));
24
+ const acceptedFileTypeObj = acceptedFileTypes.find(item => {
25
+ return item.fileType === fileType;
26
+ });
27
+ return validateFileSize(file.size, acceptedFileTypeObj.fileMaxSize !== undefined ? acceptedFileTypeObj.fileMaxSize : fileMaxSize);
28
+ }
29
+ return null;
12
30
  };
13
31
  const handleType = file => {
14
32
  if (acceptedFileTypes.length === 0) {
15
33
  return false;
16
34
  }
17
- const fileType = hasPreferredMimeType(acceptedFileTypes, file) ? file.type : getFileTypeFromExtension(file) || file.type;
18
- const foundType = extendWithAbbreviation(acceptedFileTypes).some(type => {
35
+ const listOfAcceptedFilesTypes = getAcceptedFileTypesAsListOfStrings(acceptedFileTypes);
36
+ const fileType = getFileType(file, listOfAcceptedFilesTypes);
37
+ const foundType = extendWithAbbreviation(listOfAcceptedFilesTypes).some(type => {
19
38
  return fileType.includes(type);
20
39
  });
21
40
  return !foundType ? errorUnsupportedFile : null;
@@ -36,11 +55,20 @@ export function getFileTypeFromExtension(file) {
36
55
  return file.name.includes('.') && file.name.replace(/.*\.([^.]+)$/, '$1') || null;
37
56
  }
38
57
  export function getAcceptedFileTypes(acceptedFileTypes) {
39
- return extendWithAbbreviation(acceptedFileTypes).map(type => type.includes('/') ? type : `.${type}`).join(',');
58
+ return extendWithAbbreviation(getAcceptedFileTypesAsListOfStrings(acceptedFileTypes)).map(type => type.includes('/') ? type : `.${type}`).join(',');
40
59
  }
41
60
  export function hasPreferredMimeType(acceptedFileTypes, file) {
42
61
  return file.type.split('/')[1] && (!(acceptedFileTypes !== null && acceptedFileTypes !== void 0 && acceptedFileTypes.length) || (acceptedFileTypes === null || acceptedFileTypes === void 0 ? void 0 : acceptedFileTypes.some(type => type.toLowerCase() === file.type.toLowerCase())));
43
62
  }
63
+ function getAcceptedFileTypesAsListOfStrings(acceptedFileTypes) {
64
+ return isArrayOfStrings(acceptedFileTypes) ? acceptedFileTypes : acceptedFileTypes.map(obj => obj.fileType);
65
+ }
66
+ export function isArrayOfStrings(arr) {
67
+ return Array.isArray(arr) && arr.length > 0 && arr.every(i => typeof i === 'string');
68
+ }
69
+ export function isArrayOfObjects(arr) {
70
+ return Array.isArray(arr) && arr.length > 0 && arr.every(i => typeof i === 'object');
71
+ }
44
72
  export function extendWithAbbreviation(acceptedFileTypes, abbreviations = {
45
73
  jpg: 'jpeg'
46
74
  }) {
@@ -1 +1 @@
1
- {"version":3,"file":"UploadVerify.js","names":["format","BYTES_IN_A_MEGA_BYTE","verifyFiles","files","context","fileMaxSize","acceptedFileTypes","errorLargeFile","errorUnsupportedFile","handleSize","file","size","String","replace","toString","handleType","length","fileType","hasPreferredMimeType","type","getFileTypeFromExtension","foundType","extendWithAbbreviation","some","includes","cleanedFiles","map","item","errorMessage","name","getAcceptedFileTypes","join","split","toLowerCase","abbreviations","jpg","list","Object","entries","forEach","abbr","t","push"],"sources":["../../../../src/components/upload/UploadVerify.tsx"],"sourcesContent":["import { format } from '../number-format/NumberUtils'\nimport {\n UploadFile,\n UploadContextProps,\n UploadAcceptedFileTypes,\n} from './types'\n\nexport const BYTES_IN_A_MEGA_BYTE = 1048576\n\nexport function verifyFiles(\n files: UploadFile[],\n context: Pick<\n UploadContextProps,\n | 'errorUnsupportedFile'\n | 'errorLargeFile'\n | 'acceptedFileTypes'\n | 'fileMaxSize'\n >\n) {\n const {\n fileMaxSize,\n acceptedFileTypes,\n errorLargeFile,\n errorUnsupportedFile,\n } = context\n\n const handleSize = (file: File) => {\n return (\n // Converts from b (binary) to MB (decimal)\n file.size / BYTES_IN_A_MEGA_BYTE > fileMaxSize\n ? String(errorLargeFile).replace(\n '%size',\n format(fileMaxSize).toString()\n )\n : null\n )\n }\n\n const handleType = (file: File) => {\n if (acceptedFileTypes.length === 0) {\n return false\n }\n const fileType = hasPreferredMimeType(acceptedFileTypes, file)\n ? file.type\n : getFileTypeFromExtension(file) || file.type\n const foundType = extendWithAbbreviation(acceptedFileTypes).some(\n (type) => {\n /**\n * \"file.type\" can be e.g. \"images/png\"\n */\n return fileType.includes(type)\n }\n )\n return !foundType ? errorUnsupportedFile : null\n }\n\n const cleanedFiles = files.map((item) => {\n const { file } = item\n\n const errorMessage = handleSize(file) || handleType(file)\n\n if (errorMessage) {\n item.errorMessage = errorMessage\n }\n\n return item\n })\n\n return cleanedFiles\n}\n\nexport function getFileTypeFromExtension(file: File) {\n return (\n (file.name.includes('.') && file.name.replace(/.*\\.([^.]+)$/, '$1')) ||\n null\n )\n}\n\nexport function getAcceptedFileTypes(\n acceptedFileTypes: UploadAcceptedFileTypes\n) {\n return extendWithAbbreviation(acceptedFileTypes)\n .map((type) => (type.includes('/') ? type : `.${type}`))\n .join(',')\n}\n\nexport function hasPreferredMimeType(\n acceptedFileTypes: UploadAcceptedFileTypes,\n file: File\n) {\n return (\n file.type.split('/')[1] &&\n (!acceptedFileTypes?.length ||\n acceptedFileTypes?.some(\n (type) => type.toLowerCase() === file.type.toLowerCase()\n ))\n )\n}\n\nexport function extendWithAbbreviation(\n acceptedFileTypes: UploadAcceptedFileTypes,\n abbreviations = { jpg: 'jpeg' }\n) {\n const list = [...acceptedFileTypes]\n\n Object.entries(abbreviations).forEach(([type, abbr]) => {\n if (list.some((t) => t === type) && !list.some((t) => t === abbr)) {\n list.push(abbr)\n }\n })\n\n return list\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"UploadVerify.js","names":["format","BYTES_IN_A_MEGA_BYTE","verifyFiles","files","context","fileMaxSize","acceptedFileTypes","errorLargeFile","errorUnsupportedFile","getFileType","file","listOfAcceptedFilesTypes","hasPreferredMimeType","type","getFileTypeFromExtension","handleSize","validateFileSize","fileSize","maxFileSize","String","replace","toString","isArrayOfStrings","length","size","isArrayOfObjects","fileType","getAcceptedFileTypesAsListOfStrings","acceptedFileTypeObj","find","item","undefined","handleType","foundType","extendWithAbbreviation","some","includes","cleanedFiles","map","errorMessage","name","getAcceptedFileTypes","join","split","toLowerCase","obj","arr","Array","isArray","every","i","abbreviations","jpg","list","Object","entries","forEach","abbr","t","push"],"sources":["../../../../src/components/upload/UploadVerify.tsx"],"sourcesContent":["import { format } from '../number-format/NumberUtils'\nimport {\n UploadFile,\n UploadContextProps,\n UploadAcceptedFileTypes,\n UploadAcceptedFileTypesWithFileMaxSize,\n} from './types'\n\nexport const BYTES_IN_A_MEGA_BYTE = 1048576\n\nexport function verifyFiles(\n files: UploadFile[],\n context: Pick<\n UploadContextProps,\n | 'errorUnsupportedFile'\n | 'errorLargeFile'\n | 'acceptedFileTypes'\n | 'fileMaxSize'\n >\n) {\n const {\n fileMaxSize,\n acceptedFileTypes,\n errorLargeFile,\n errorUnsupportedFile,\n } = context\n\n const getFileType = (\n file: File,\n listOfAcceptedFilesTypes: UploadAcceptedFileTypes\n ) => {\n return hasPreferredMimeType(listOfAcceptedFilesTypes, file)\n ? file.type\n : getFileTypeFromExtension(file) || file.type\n }\n\n const handleSize = (file: File) => {\n const validateFileSize = (\n fileSize: number,\n maxFileSize: number | false\n ) => {\n if (\n maxFileSize &&\n // Converts from b (binary) to MB (decimal)\n fileSize / BYTES_IN_A_MEGA_BYTE > maxFileSize\n ) {\n return String(errorLargeFile).replace(\n '%size',\n format(maxFileSize).toString()\n )\n }\n return null\n }\n\n if (\n isArrayOfStrings(acceptedFileTypes) ||\n acceptedFileTypes.length === 0 ||\n !acceptedFileTypes\n ) {\n return validateFileSize(file.size, fileMaxSize)\n } else if (isArrayOfObjects(acceptedFileTypes)) {\n const fileType = getFileType(\n file,\n getAcceptedFileTypesAsListOfStrings(acceptedFileTypes)\n )\n\n const acceptedFileTypeObj = (\n acceptedFileTypes as UploadAcceptedFileTypesWithFileMaxSize\n ).find((item) => {\n return item.fileType === fileType\n })\n\n return validateFileSize(\n file.size,\n acceptedFileTypeObj.fileMaxSize !== undefined\n ? acceptedFileTypeObj.fileMaxSize\n : fileMaxSize\n )\n }\n return null\n }\n\n const handleType = (file: File) => {\n if (acceptedFileTypes.length === 0) {\n return false\n }\n\n const listOfAcceptedFilesTypes =\n getAcceptedFileTypesAsListOfStrings(acceptedFileTypes)\n const fileType = getFileType(file, listOfAcceptedFilesTypes)\n const foundType = extendWithAbbreviation(\n listOfAcceptedFilesTypes\n ).some((type) => {\n /**\n * \"file.type\" can be e.g. \"image/png\"\n */\n return fileType.includes(type)\n })\n return !foundType ? errorUnsupportedFile : null\n }\n\n const cleanedFiles = files.map((item) => {\n const { file } = item\n\n const errorMessage = handleSize(file) || handleType(file)\n\n if (errorMessage) {\n item.errorMessage = errorMessage\n }\n\n return item\n })\n\n return cleanedFiles\n}\n\nexport function getFileTypeFromExtension(file: File) {\n return (\n (file.name.includes('.') && file.name.replace(/.*\\.([^.]+)$/, '$1')) ||\n null\n )\n}\n\nexport function getAcceptedFileTypes(\n acceptedFileTypes:\n | UploadAcceptedFileTypes\n | UploadAcceptedFileTypesWithFileMaxSize\n) {\n return extendWithAbbreviation(\n getAcceptedFileTypesAsListOfStrings(acceptedFileTypes)\n )\n .map((type) => (type.includes('/') ? type : `.${type}`))\n .join(',')\n}\n\nexport function hasPreferredMimeType(\n acceptedFileTypes: UploadAcceptedFileTypes,\n file: File\n) {\n return (\n file.type.split('/')[1] &&\n (!acceptedFileTypes?.length ||\n acceptedFileTypes?.some(\n (type) => type.toLowerCase() === file.type.toLowerCase()\n ))\n )\n}\n\nfunction getAcceptedFileTypesAsListOfStrings(\n acceptedFileTypes:\n | UploadAcceptedFileTypes\n | UploadAcceptedFileTypesWithFileMaxSize\n) {\n return isArrayOfStrings(acceptedFileTypes)\n ? (acceptedFileTypes as UploadAcceptedFileTypes)\n : (acceptedFileTypes as UploadAcceptedFileTypesWithFileMaxSize).map(\n (obj) => obj.fileType\n )\n}\n\nexport function isArrayOfStrings(arr) {\n return (\n Array.isArray(arr) &&\n arr.length > 0 &&\n arr.every((i) => typeof i === 'string')\n )\n}\n\nexport function isArrayOfObjects(arr) {\n return (\n Array.isArray(arr) &&\n arr.length > 0 &&\n arr.every((i) => typeof i === 'object')\n )\n}\n\nexport function extendWithAbbreviation(\n acceptedFileTypes: UploadAcceptedFileTypes,\n abbreviations = { jpg: 'jpeg' }\n) {\n const list = [...acceptedFileTypes]\n\n Object.entries(abbreviations).forEach(([type, abbr]) => {\n if (list.some((t) => t === type) && !list.some((t) => t === abbr)) {\n list.push(abbr)\n }\n })\n\n return list\n}\n"],"mappings":"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"}
@@ -112,6 +112,21 @@
112
112
  .dnb-upload__text.dnb-p {
113
113
  color: var(--upload-text--secondary);
114
114
  }
115
+ .dnb-upload__accepted-file-types-table.dnb-table {
116
+ width: -moz-fit-content;
117
+ width: fit-content;
118
+ }
119
+ .dnb-upload__accepted-file-types-table.dnb-table thead th {
120
+ font-weight: var(--font-weight-medium);
121
+ font-size: var(--font-size-basis);
122
+ padding-top: var(--spacing-small);
123
+ }
124
+ .dnb-upload__accepted-file-types-table.dnb-table thead th:first-child {
125
+ padding-left: 0;
126
+ }
127
+ .dnb-upload__accepted-file-types-table.dnb-table tbody td:first-child {
128
+ padding-left: 0;
129
+ }
115
130
  .dnb-upload__subtitle.dnb-p {
116
131
  color: var(--upload-text--secondary);
117
132
  }
@@ -1 +1 @@
1
- .dnb-upload{--upload-background:#fff;--upload-background--active:#d3d3d3;--upload-border:gray;--upload-border--active:#000;--upload-list-border:#000;--upload-icon--default:#000;--upload-icon--warning:red;--upload-highlight:#ffffe0;--upload-text--primary:#000;--upload-text--secondary:#000;background-color:var(--upload-background);border-radius:.5rem;display:flex;flex-direction:column;padding:var(--spacing-medium);position:relative}@media screen and (max-width:40em){.dnb-upload{padding:var(--spacing-medium) var(--spacing-small)}}.dnb-upload__outline{stroke:var(--upload-border);stroke-width:.1875rem;border-radius:.5rem;content:"";height:100%;inset:0;pointer-events:none;position:absolute;width:100%}.dnb-upload--active .dnb-upload__outline{stroke:var(--upload-border--active);height:calc(100% + 2px);inset:-1px;width:calc(100% + 2px)}.dnb-upload--active .dnb-upload__outline rect{stroke-width:.25rem;stroke-dasharray:0}.dnb-upload--active{background-color:var(--upload-background--active)}.dnb-upload__file-input{position:absolute;visibility:hidden}.dnb-upload__file-list{list-style:none;margin-bottom:0;margin-top:var(--spacing-medium);padding:0;position:relative}.dnb-upload__file-cell:after,.dnb-upload__file-list:before{background-color:var(--upload-list-border);content:"";height:1px;inset:0;position:absolute}.dnb-upload__file-cell{padding:var(--spacing-small) 0;position:relative;transition:background-color;transition-duration:1.5s;transition-timing-function:var(--easing-default)}.dnb-upload__file-cell:after{top:auto}.dnb-upload__file-cell__content{justify-content:space-between}.dnb-upload__file-cell__content,.dnb-upload__file-cell__content__left{align-items:center;display:flex;flex-direction:row}.dnb-upload__file-cell__content__left .dnb-icon{color:var(--upload-icon--default)}.dnb-upload__file-cell--warning .dnb-upload__file-cell__content__left .dnb-icon{color:var(--upload-icon--warning)}.dnb-upload__file-cell--highlight{background-color:var(--upload-highlight)}.dnb-upload__file-cell__text-container{display:flex;flex-direction:column;margin-left:var(--spacing-small)}.dnb-upload__file-cell__text-container--loading{font-size:var(--font-size-basis)}.dnb-upload__subtitle.dnb-p,.dnb-upload__text.dnb-p{color:var(--upload-text--secondary)}
1
+ .dnb-upload{--upload-background:#fff;--upload-background--active:#d3d3d3;--upload-border:gray;--upload-border--active:#000;--upload-list-border:#000;--upload-icon--default:#000;--upload-icon--warning:red;--upload-highlight:#ffffe0;--upload-text--primary:#000;--upload-text--secondary:#000;background-color:var(--upload-background);border-radius:.5rem;display:flex;flex-direction:column;padding:var(--spacing-medium);position:relative}@media screen and (max-width:40em){.dnb-upload{padding:var(--spacing-medium) var(--spacing-small)}}.dnb-upload__outline{stroke:var(--upload-border);stroke-width:.1875rem;border-radius:.5rem;content:"";height:100%;inset:0;pointer-events:none;position:absolute;width:100%}.dnb-upload--active .dnb-upload__outline{stroke:var(--upload-border--active);height:calc(100% + 2px);inset:-1px;width:calc(100% + 2px)}.dnb-upload--active .dnb-upload__outline rect{stroke-width:.25rem;stroke-dasharray:0}.dnb-upload--active{background-color:var(--upload-background--active)}.dnb-upload__file-input{position:absolute;visibility:hidden}.dnb-upload__file-list{list-style:none;margin-bottom:0;margin-top:var(--spacing-medium);padding:0;position:relative}.dnb-upload__file-cell:after,.dnb-upload__file-list:before{background-color:var(--upload-list-border);content:"";height:1px;inset:0;position:absolute}.dnb-upload__file-cell{padding:var(--spacing-small) 0;position:relative;transition:background-color;transition-duration:1.5s;transition-timing-function:var(--easing-default)}.dnb-upload__file-cell:after{top:auto}.dnb-upload__file-cell__content{justify-content:space-between}.dnb-upload__file-cell__content,.dnb-upload__file-cell__content__left{align-items:center;display:flex;flex-direction:row}.dnb-upload__file-cell__content__left .dnb-icon{color:var(--upload-icon--default)}.dnb-upload__file-cell--warning .dnb-upload__file-cell__content__left .dnb-icon{color:var(--upload-icon--warning)}.dnb-upload__file-cell--highlight{background-color:var(--upload-highlight)}.dnb-upload__file-cell__text-container{display:flex;flex-direction:column;margin-left:var(--spacing-small)}.dnb-upload__file-cell__text-container--loading{font-size:var(--font-size-basis)}.dnb-upload__text.dnb-p{color:var(--upload-text--secondary)}.dnb-upload__accepted-file-types-table.dnb-table{width:-moz-fit-content;width:fit-content}.dnb-upload__accepted-file-types-table.dnb-table thead th{font-size:var(--font-size-basis);font-weight:var(--font-weight-medium);padding-top:var(--spacing-small)}.dnb-upload__accepted-file-types-table.dnb-table tbody td:first-child,.dnb-upload__accepted-file-types-table.dnb-table thead th:first-child{padding-left:0}.dnb-upload__subtitle.dnb-p{color:var(--upload-text--secondary)}
@@ -145,6 +145,23 @@
145
145
  color: var(--upload-text--secondary);
146
146
  }
147
147
 
148
+ &__accepted-file-types-table {
149
+ &.dnb-table {
150
+ width: fit-content;
151
+ & thead th {
152
+ font-weight: var(--font-weight-medium);
153
+ font-size: var(--font-size-basis);
154
+ padding-top: var(--spacing-small);
155
+ &:first-child {
156
+ padding-left: 0;
157
+ }
158
+ }
159
+ & tbody td:first-child {
160
+ padding-left: 0;
161
+ }
162
+ }
163
+ }
164
+
148
165
  &__subtitle.dnb-p {
149
166
  color: var(--upload-text--secondary);
150
167
  }
@@ -2,6 +2,11 @@ import React from 'react';
2
2
  import type { SkeletonShow } from '../skeleton/Skeleton';
3
3
  import type { LocaleProps, SpacingProps } from '../../shared/types';
4
4
  export type UploadAcceptedFileTypes = string[];
5
+ export type UploadAcceptedFileTypesWithFileMaxSize = UploadAcceptedFileTypeObject[];
6
+ export type UploadAcceptedFileTypeObject = {
7
+ fileType: string;
8
+ fileMaxSize?: number | false;
9
+ };
5
10
  export type UploadProps = {
6
11
  /**
7
12
  * unique id used with the useUpload hook to manage the files
@@ -10,7 +15,7 @@ export type UploadProps = {
10
15
  /**
11
16
  * list of accepted file types.
12
17
  */
13
- acceptedFileTypes: UploadAcceptedFileTypes;
18
+ acceptedFileTypes: UploadAcceptedFileTypes | UploadAcceptedFileTypesWithFileMaxSize;
14
19
  /**
15
20
  * Skeleton should be applied when loading content
16
21
  * Default: null
@@ -22,10 +27,10 @@ export type UploadProps = {
22
27
  */
23
28
  filesAmountLimit?: number;
24
29
  /**
25
- * fileMaxSize is max size of each file in MB
30
+ * Defines the max file size of each file in MB. Use either `0` or `false` to disable.
26
31
  * Default: 5 MB
27
32
  */
28
- fileMaxSize?: number;
33
+ fileMaxSize?: number | false;
29
34
  /**
30
35
  * will be called on `files` changes made by the user. Access the files with `{ files }`.
31
36
  */
@@ -43,6 +48,7 @@ export type UploadProps = {
43
48
  */
44
49
  title?: React.ReactNode;
45
50
  text?: React.ReactNode;
51
+ fileTypeTableCaption?: React.ReactNode;
46
52
  fileTypeDescription?: React.ReactNode;
47
53
  fileSizeDescription?: React.ReactNode;
48
54
  fileAmountDescription?: React.ReactNode;
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../src/components/upload/types.ts"],"sourcesContent":["import React from 'react'\nimport type { SkeletonShow } from '../skeleton/Skeleton'\nimport type { LocaleProps, SpacingProps } from '../../shared/types'\n\nexport type UploadAcceptedFileTypes = string[]\n\nexport type UploadProps = {\n /**\n * unique id used with the useUpload hook to manage the files\n */\n id: string\n\n /**\n * list of accepted file types.\n */\n acceptedFileTypes: UploadAcceptedFileTypes\n\n /**\n * Skeleton should be applied when loading content\n * Default: null\n */\n skeleton?: SkeletonShow\n\n /**\n * Defines the amount of files the user can select and upload\n * Default: 100\n */\n filesAmountLimit?: number\n\n /**\n * fileMaxSize is max size of each file in MB\n * Default: 5 MB\n */\n fileMaxSize?: number\n\n /**\n * will be called on `files` changes made by the user. Access the files with `{ files }`.\n */\n onChange?: ({ files }: { files: UploadFile[] }) => void\n\n /**\n * will be called once a file gets deleted by the user. Access the deleted file with `{ fileItem }`.\n */\n onFileDelete?: ({ fileItem }: { fileItem: UploadFile }) => void\n\n /**\n * Custom text properties\n */\n title?: React.ReactNode\n text?: React.ReactNode\n fileTypeDescription?: React.ReactNode\n fileSizeDescription?: React.ReactNode\n fileAmountDescription?: React.ReactNode\n fileSizeContent?: React.ReactNode\n buttonText?: React.ReactNode\n errorLargeFile?: React.ReactNode\n errorUnsupportedFile?: React.ReactNode\n errorAmountLimit?: React.ReactNode\n loadingText?: React.ReactNode\n deleteButton?: React.ReactNode\n fileListAriaLabel?: string\n children?: React.ReactNode\n}\n\nexport type UploadAllProps = UploadProps &\n SpacingProps &\n LocaleProps &\n Omit<React.HTMLProps<HTMLElement>, 'onChange' | 'title'>\n\nexport type UploadContextProps = {\n id?: string\n onInputUpload: (files: UploadFile[]) => void\n} & Partial<UploadProps>\n\nexport type UploadFile = {\n file: File\n errorMessage?: React.ReactNode\n isLoading?: boolean\n exists?: boolean\n id?: string\n}\n"],"mappings":""}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../../src/components/upload/types.ts"],"sourcesContent":["import React from 'react'\nimport type { SkeletonShow } from '../skeleton/Skeleton'\nimport type { LocaleProps, SpacingProps } from '../../shared/types'\n\nexport type UploadAcceptedFileTypes = string[]\n\nexport type UploadAcceptedFileTypesWithFileMaxSize =\n UploadAcceptedFileTypeObject[]\n\nexport type UploadAcceptedFileTypeObject = {\n fileType: string\n fileMaxSize?: number | false\n}\n\nexport type UploadProps = {\n /**\n * unique id used with the useUpload hook to manage the files\n */\n id: string\n\n /**\n * list of accepted file types.\n */\n acceptedFileTypes:\n | UploadAcceptedFileTypes\n | UploadAcceptedFileTypesWithFileMaxSize\n\n /**\n * Skeleton should be applied when loading content\n * Default: null\n */\n skeleton?: SkeletonShow\n\n /**\n * Defines the amount of files the user can select and upload\n * Default: 100\n */\n filesAmountLimit?: number\n\n /**\n * Defines the max file size of each file in MB. Use either `0` or `false` to disable.\n * Default: 5 MB\n */\n fileMaxSize?: number | false\n\n /**\n * will be called on `files` changes made by the user. Access the files with `{ files }`.\n */\n onChange?: ({ files }: { files: UploadFile[] }) => void\n\n /**\n * will be called once a file gets deleted by the user. Access the deleted file with `{ fileItem }`.\n */\n onFileDelete?: ({ fileItem }: { fileItem: UploadFile }) => void\n\n /**\n * Custom text properties\n */\n title?: React.ReactNode\n text?: React.ReactNode\n fileTypeTableCaption?: React.ReactNode\n fileTypeDescription?: React.ReactNode\n fileSizeDescription?: React.ReactNode\n fileAmountDescription?: React.ReactNode\n fileSizeContent?: React.ReactNode\n buttonText?: React.ReactNode\n errorLargeFile?: React.ReactNode\n errorUnsupportedFile?: React.ReactNode\n errorAmountLimit?: React.ReactNode\n loadingText?: React.ReactNode\n deleteButton?: React.ReactNode\n fileListAriaLabel?: string\n children?: React.ReactNode\n}\n\nexport type UploadAllProps = UploadProps &\n SpacingProps &\n LocaleProps &\n Omit<React.HTMLProps<HTMLElement>, 'onChange' | 'title'>\n\nexport type UploadContextProps = {\n id?: string\n onInputUpload: (files: UploadFile[]) => void\n} & Partial<UploadProps>\n\nexport type UploadFile = {\n file: File\n errorMessage?: React.ReactNode\n isLoading?: boolean\n exists?: boolean\n id?: string\n}\n"],"mappings":""}
@@ -8,7 +8,7 @@ type HandleSubmitProps = {
8
8
  export type EventListenerCall = {
9
9
  path?: Path;
10
10
  type?: 'onSubmit';
11
- callback: () => any;
11
+ callback: () => void;
12
12
  };
13
13
  export type FilterDataHandler<Data> = (data: Data, filter: FilterData) => Partial<Data>;
14
14
  export type FilterDataHandlerCallback<R> = (parameters: FilterDataHandlerParameters) => R;
@@ -27,6 +27,9 @@ export type FilterDataPathConditionParameters<Data = unknown> = {
27
27
  export type FilterDataPathObject<Data> = Record<Path, FilterDataPathCondition<Data> | boolean | undefined>;
28
28
  export type FilterData<Data = unknown> = FilterDataPathObject<Data> | FilterDataHandlerCallback<boolean | undefined>;
29
29
  export type TransformData = FilterDataHandlerCallback<unknown>;
30
+ export type HandleSubmitCallback = ({ preventSubmit, }: {
31
+ preventSubmit: () => void;
32
+ }) => void;
30
33
  export interface ContextState {
31
34
  id?: Identifier;
32
35
  hasContext: boolean;
@@ -64,16 +67,19 @@ export interface ContextState {
64
67
  }) => void;
65
68
  setFieldEventListener: (path: EventListenerCall['path'], type: EventListenerCall['type'], callback: EventListenerCall['callback']) => void;
66
69
  setHasVisibleError?: (path: Path, hasError: boolean) => void;
67
- setFieldProps?: (path: Path, props: any) => void;
68
- setValueProps?: (path: Path, props: any) => void;
70
+ setFieldProps?: (path: Path, props: unknown) => void;
71
+ setValueProps?: (path: Path, props: unknown) => void;
72
+ setHandleSubmit?: (callback: HandleSubmitCallback) => void;
69
73
  fieldPropsRef?: React.MutableRefObject<Record<string, FieldProps>>;
70
74
  valuePropsRef?: React.MutableRefObject<Record<string, ValueProps>>;
75
+ mountedFieldPathsRef?: React.MutableRefObject<Path[]>;
71
76
  showAllErrors: boolean;
72
77
  hasVisibleError: boolean;
73
78
  formState: SubmitState;
74
79
  ajvInstance: Ajv;
75
80
  contextErrorMessages: CustomErrorMessagesWithPaths;
76
81
  schema: AllJSONSchemaVersions;
82
+ path?: Path;
77
83
  disabled?: boolean;
78
84
  required?: boolean;
79
85
  submitState: Partial<EventStateObject>;
@@ -1 +1 @@
1
- {"version":3,"file":"Context.js","names":["React","makeAjvInstance","defaultContextState","hasContext","data","undefined","schema","submitState","handlePathChange","handlePathChangeUnvalidated","updateDataValue","setData","validateData","handleSubmit","scrollToTop","showAllErrors","hasVisibleError","formState","setFormState","setSubmitState","setFieldEventListener","handleSubmitCall","setShowAllErrors","handleMountField","handleUnMountField","hasErrors","hasFieldState","hasFieldError","setFieldState","setFieldError","ajvInstance","contextErrorMessages","isInsideFormElement","props","Context","createContext"],"sources":["../../../../../src/extensions/forms/DataContext/Context.ts"],"sourcesContent":["import React from 'react'\nimport { Ajv, makeAjvInstance } from '../utils/ajv'\nimport {\n AllJSONSchemaVersions,\n CustomErrorMessagesWithPaths,\n SubmitState,\n Path,\n EventStateObject,\n EventReturnWithStateObject,\n Identifier,\n FieldProps,\n FormError,\n ValueProps,\n} from '../types'\nimport { Props as ProviderProps } from './Provider'\n\ntype HandleSubmitProps = {\n formElement?: HTMLFormElement\n}\n\nexport type EventListenerCall = {\n path?: Path\n type?: 'onSubmit'\n callback: () => any\n}\n\nexport type FilterDataHandler<Data> = (\n data: Data,\n filter: FilterData\n) => Partial<Data>\nexport type FilterDataHandlerCallback<R> = (\n parameters: FilterDataHandlerParameters\n) => R\nexport type FilterDataHandlerParameters =\n FilterDataPathConditionParameters & {\n path: Path\n }\nexport type FilterDataPathCondition<Data = unknown> = (\n parameters: FilterDataPathConditionParameters<Data>\n) => boolean | undefined\nexport type FilterDataPathConditionParameters<Data = unknown> = {\n value: unknown\n props: FieldProps\n data: Data\n internal: {\n error: Error | undefined\n }\n}\nexport type FilterDataPathObject<Data> = Record<\n Path,\n FilterDataPathCondition<Data> | boolean | undefined\n>\nexport type FilterData<Data = unknown> =\n | FilterDataPathObject<Data>\n | FilterDataHandlerCallback<boolean | undefined>\nexport type TransformData = FilterDataHandlerCallback<unknown>\n\nexport interface ContextState {\n id?: Identifier\n hasContext: boolean\n /** The dataset for the form / form wizard */\n data: any\n /** Should the form validate data before submitting? */\n errors?: Record<string, Error>\n /** Will set autoComplete=\"on\" on each nested Field.String and Field.Number */\n autoComplete?: boolean\n handlePathChange: (\n path: Path,\n value?: any\n ) =>\n | EventReturnWithStateObject\n | unknown\n | Promise<EventReturnWithStateObject | unknown>\n handlePathChangeUnvalidated: (path: Path, value: any) => void\n updateDataValue: (path: Path, value: any) => void\n setData: (data: any) => void\n mutateDataHandler?: (data: any, mutate: TransformData) => any\n filterDataHandler?: (data: any, filter: FilterData) => any\n validateData: () => void\n handleSubmit: (props?: HandleSubmitProps) => any\n scrollToTop: () => void\n setShowAllErrors: (showAllErrors: boolean) => void\n hasErrors: () => boolean\n hasFieldState: (state: SubmitState) => boolean\n hasFieldError: (path: Path) => boolean\n setFieldState: (path: Path, fieldState: SubmitState) => void\n setFieldError: (path: Path, error: Error | FormError) => void\n handleMountField: (path: Path) => void\n handleUnMountField: (path: Path) => void\n setFormState?: (state: SubmitState) => void\n setSubmitState?: (state: EventStateObject) => void\n addOnChangeHandler?: (callback: (data: unknown) => void) => void\n handleSubmitCall: ({\n onSubmit,\n enableAsyncBehaviour,\n skipFieldValidation,\n skipErrorCheck,\n }: {\n onSubmit: () =>\n | EventReturnWithStateObject\n | void\n | Promise<EventReturnWithStateObject | void>\n enableAsyncBehaviour: boolean\n skipFieldValidation?: boolean\n skipErrorCheck?: boolean\n }) => void\n setFieldEventListener: (\n path: EventListenerCall['path'],\n type: EventListenerCall['type'],\n callback: EventListenerCall['callback']\n ) => void\n setHasVisibleError?: (path: Path, hasError: boolean) => void\n setFieldProps?: (path: Path, props: any) => void\n setValueProps?: (path: Path, props: any) => void\n fieldPropsRef?: React.MutableRefObject<Record<string, FieldProps>>\n valuePropsRef?: React.MutableRefObject<Record<string, ValueProps>>\n showAllErrors: boolean\n hasVisibleError: boolean\n formState: SubmitState\n ajvInstance: Ajv\n contextErrorMessages: CustomErrorMessagesWithPaths\n schema: AllJSONSchemaVersions\n disabled?: boolean\n required?: boolean\n submitState: Partial<EventStateObject>\n isInsideFormElement?: boolean\n prerenderFieldProps?: boolean\n props: ProviderProps<unknown>\n}\n\nexport const defaultContextState: ContextState = {\n hasContext: false,\n data: undefined,\n schema: undefined,\n submitState: undefined,\n handlePathChange: () => null,\n handlePathChangeUnvalidated: () => null,\n updateDataValue: () => null,\n setData: () => null,\n validateData: () => null,\n handleSubmit: () => null,\n scrollToTop: () => null,\n showAllErrors: false,\n hasVisibleError: false,\n formState: undefined,\n setFormState: () => null,\n setSubmitState: () => null,\n setFieldEventListener: () => null,\n handleSubmitCall: () => null,\n setShowAllErrors: () => null,\n handleMountField: () => null,\n handleUnMountField: () => null,\n hasErrors: () => false,\n hasFieldState: () => false,\n hasFieldError: () => false,\n setFieldState: () => null,\n setFieldError: () => null,\n ajvInstance: makeAjvInstance(),\n contextErrorMessages: undefined,\n isInsideFormElement: false,\n props: null,\n}\n\nconst Context = React.createContext<ContextState>(defaultContextState)\n\nexport default Context\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAAcC,eAAe,QAAQ,cAAc;AAiInD,OAAO,MAAMC,mBAAiC,GAAG;EAC/CC,UAAU,EAAE,KAAK;EACjBC,IAAI,EAAEC,SAAS;EACfC,MAAM,EAAED,SAAS;EACjBE,WAAW,EAAEF,SAAS;EACtBG,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,2BAA2B,EAAEA,CAAA,KAAM,IAAI;EACvCC,eAAe,EAAEA,CAAA,KAAM,IAAI;EAC3BC,OAAO,EAAEA,CAAA,KAAM,IAAI;EACnBC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,WAAW,EAAEA,CAAA,KAAM,IAAI;EACvBC,aAAa,EAAE,KAAK;EACpBC,eAAe,EAAE,KAAK;EACtBC,SAAS,EAAEZ,SAAS;EACpBa,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,cAAc,EAAEA,CAAA,KAAM,IAAI;EAC1BC,qBAAqB,EAAEA,CAAA,KAAM,IAAI;EACjCC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,kBAAkB,EAAEA,CAAA,KAAM,IAAI;EAC9BC,SAAS,EAAEA,CAAA,KAAM,KAAK;EACtBC,aAAa,EAAEA,CAAA,KAAM,KAAK;EAC1BC,aAAa,EAAEA,CAAA,KAAM,KAAK;EAC1BC,aAAa,EAAEA,CAAA,KAAM,IAAI;EACzBC,aAAa,EAAEA,CAAA,KAAM,IAAI;EACzBC,WAAW,EAAE7B,eAAe,CAAC,CAAC;EAC9B8B,oBAAoB,EAAE1B,SAAS;EAC/B2B,mBAAmB,EAAE,KAAK;EAC1BC,KAAK,EAAE;AACT,CAAC;AAED,MAAMC,OAAO,GAAGlC,KAAK,CAACmC,aAAa,CAAejC,mBAAmB,CAAC;AAEtE,eAAegC,OAAO"}
1
+ {"version":3,"file":"Context.js","names":["React","makeAjvInstance","defaultContextState","hasContext","data","undefined","schema","submitState","handlePathChange","handlePathChangeUnvalidated","updateDataValue","setData","validateData","handleSubmit","scrollToTop","showAllErrors","hasVisibleError","formState","setFormState","setSubmitState","setFieldEventListener","handleSubmitCall","setShowAllErrors","handleMountField","handleUnMountField","hasErrors","hasFieldState","hasFieldError","setFieldState","setFieldError","ajvInstance","contextErrorMessages","isInsideFormElement","props","Context","createContext"],"sources":["../../../../../src/extensions/forms/DataContext/Context.ts"],"sourcesContent":["import React from 'react'\nimport { Ajv, makeAjvInstance } from '../utils/ajv'\nimport {\n AllJSONSchemaVersions,\n CustomErrorMessagesWithPaths,\n SubmitState,\n Path,\n EventStateObject,\n EventReturnWithStateObject,\n Identifier,\n FieldProps,\n FormError,\n ValueProps,\n} from '../types'\nimport { Props as ProviderProps } from './Provider'\n\ntype HandleSubmitProps = {\n formElement?: HTMLFormElement\n}\n\nexport type EventListenerCall = {\n path?: Path\n type?: 'onSubmit'\n callback: () => void\n}\n\nexport type FilterDataHandler<Data> = (\n data: Data,\n filter: FilterData\n) => Partial<Data>\nexport type FilterDataHandlerCallback<R> = (\n parameters: FilterDataHandlerParameters\n) => R\nexport type FilterDataHandlerParameters =\n FilterDataPathConditionParameters & {\n path: Path\n }\nexport type FilterDataPathCondition<Data = unknown> = (\n parameters: FilterDataPathConditionParameters<Data>\n) => boolean | undefined\nexport type FilterDataPathConditionParameters<Data = unknown> = {\n value: unknown\n props: FieldProps\n data: Data\n internal: {\n error: Error | undefined\n }\n}\nexport type FilterDataPathObject<Data> = Record<\n Path,\n FilterDataPathCondition<Data> | boolean | undefined\n>\nexport type FilterData<Data = unknown> =\n | FilterDataPathObject<Data>\n | FilterDataHandlerCallback<boolean | undefined>\nexport type TransformData = FilterDataHandlerCallback<unknown>\nexport type HandleSubmitCallback = ({\n preventSubmit,\n}: {\n preventSubmit: () => void\n}) => void\n\nexport interface ContextState {\n id?: Identifier\n hasContext: boolean\n /** The dataset for the form / form wizard */\n data: any\n /** Should the form validate data before submitting? */\n errors?: Record<string, Error>\n /** Will set autoComplete=\"on\" on each nested Field.String and Field.Number */\n autoComplete?: boolean\n handlePathChange: (\n path: Path,\n value?: any\n ) =>\n | EventReturnWithStateObject\n | unknown\n | Promise<EventReturnWithStateObject | unknown>\n handlePathChangeUnvalidated: (path: Path, value: any) => void\n updateDataValue: (path: Path, value: any) => void\n setData: (data: any) => void\n mutateDataHandler?: (data: any, mutate: TransformData) => any\n filterDataHandler?: (data: any, filter: FilterData) => any\n validateData: () => void\n handleSubmit: (props?: HandleSubmitProps) => any\n scrollToTop: () => void\n setShowAllErrors: (showAllErrors: boolean) => void\n hasErrors: () => boolean\n hasFieldState: (state: SubmitState) => boolean\n hasFieldError: (path: Path) => boolean\n setFieldState: (path: Path, fieldState: SubmitState) => void\n setFieldError: (path: Path, error: Error | FormError) => void\n handleMountField: (path: Path) => void\n handleUnMountField: (path: Path) => void\n setFormState?: (state: SubmitState) => void\n setSubmitState?: (state: EventStateObject) => void\n addOnChangeHandler?: (callback: (data: unknown) => void) => void\n handleSubmitCall: ({\n onSubmit,\n enableAsyncBehaviour,\n skipFieldValidation,\n skipErrorCheck,\n }: {\n onSubmit: () =>\n | EventReturnWithStateObject\n | void\n | Promise<EventReturnWithStateObject | void>\n enableAsyncBehaviour: boolean\n skipFieldValidation?: boolean\n skipErrorCheck?: boolean\n }) => void\n setFieldEventListener: (\n path: EventListenerCall['path'],\n type: EventListenerCall['type'],\n callback: EventListenerCall['callback']\n ) => void\n setHasVisibleError?: (path: Path, hasError: boolean) => void\n setFieldProps?: (path: Path, props: unknown) => void\n setValueProps?: (path: Path, props: unknown) => void\n setHandleSubmit?: (callback: HandleSubmitCallback) => void\n fieldPropsRef?: React.MutableRefObject<Record<string, FieldProps>>\n valuePropsRef?: React.MutableRefObject<Record<string, ValueProps>>\n mountedFieldPathsRef?: React.MutableRefObject<Path[]>\n showAllErrors: boolean\n hasVisibleError: boolean\n formState: SubmitState\n ajvInstance: Ajv\n contextErrorMessages: CustomErrorMessagesWithPaths\n schema: AllJSONSchemaVersions\n path?: Path\n disabled?: boolean\n required?: boolean\n submitState: Partial<EventStateObject>\n isInsideFormElement?: boolean\n prerenderFieldProps?: boolean\n props: ProviderProps<unknown>\n}\n\nexport const defaultContextState: ContextState = {\n hasContext: false,\n data: undefined,\n schema: undefined,\n submitState: undefined,\n handlePathChange: () => null,\n handlePathChangeUnvalidated: () => null,\n updateDataValue: () => null,\n setData: () => null,\n validateData: () => null,\n handleSubmit: () => null,\n scrollToTop: () => null,\n showAllErrors: false,\n hasVisibleError: false,\n formState: undefined,\n setFormState: () => null,\n setSubmitState: () => null,\n setFieldEventListener: () => null,\n handleSubmitCall: () => null,\n setShowAllErrors: () => null,\n handleMountField: () => null,\n handleUnMountField: () => null,\n hasErrors: () => false,\n hasFieldState: () => false,\n hasFieldError: () => false,\n setFieldState: () => null,\n setFieldError: () => null,\n ajvInstance: makeAjvInstance(),\n contextErrorMessages: undefined,\n isInsideFormElement: false,\n props: null,\n}\n\nconst Context = React.createContext<ContextState>(defaultContextState)\n\nexport default Context\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAAcC,eAAe,QAAQ,cAAc;AAyInD,OAAO,MAAMC,mBAAiC,GAAG;EAC/CC,UAAU,EAAE,KAAK;EACjBC,IAAI,EAAEC,SAAS;EACfC,MAAM,EAAED,SAAS;EACjBE,WAAW,EAAEF,SAAS;EACtBG,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,2BAA2B,EAAEA,CAAA,KAAM,IAAI;EACvCC,eAAe,EAAEA,CAAA,KAAM,IAAI;EAC3BC,OAAO,EAAEA,CAAA,KAAM,IAAI;EACnBC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,WAAW,EAAEA,CAAA,KAAM,IAAI;EACvBC,aAAa,EAAE,KAAK;EACpBC,eAAe,EAAE,KAAK;EACtBC,SAAS,EAAEZ,SAAS;EACpBa,YAAY,EAAEA,CAAA,KAAM,IAAI;EACxBC,cAAc,EAAEA,CAAA,KAAM,IAAI;EAC1BC,qBAAqB,EAAEA,CAAA,KAAM,IAAI;EACjCC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,gBAAgB,EAAEA,CAAA,KAAM,IAAI;EAC5BC,kBAAkB,EAAEA,CAAA,KAAM,IAAI;EAC9BC,SAAS,EAAEA,CAAA,KAAM,KAAK;EACtBC,aAAa,EAAEA,CAAA,KAAM,KAAK;EAC1BC,aAAa,EAAEA,CAAA,KAAM,KAAK;EAC1BC,aAAa,EAAEA,CAAA,KAAM,IAAI;EACzBC,aAAa,EAAEA,CAAA,KAAM,IAAI;EACzBC,WAAW,EAAE7B,eAAe,CAAC,CAAC;EAC9B8B,oBAAoB,EAAE1B,SAAS;EAC/B2B,mBAAmB,EAAE,KAAK;EAC1BC,KAAK,EAAE;AACT,CAAC;AAED,MAAMC,OAAO,GAAGlC,KAAK,CAACmC,aAAa,CAAejC,mBAAmB,CAAC;AAEtE,eAAegC,OAAO"}
@@ -17,6 +17,14 @@ export interface FieldBoundaryContextState {
17
17
  * Contains the nested field errors.
18
18
  */
19
19
  errorsRef?: React.RefObject<unknown>;
20
+ /**
21
+ * Will be set to true when the boundary context error state should be shown.
22
+ */
23
+ showBoundaryErrors?: boolean;
24
+ /**
25
+ * To set the boundary context error state.
26
+ */
27
+ setShowBoundaryErrors?: (showBoundaryErrors: boolean) => void;
20
28
  /**
21
29
  * To set the local error state.
22
30
  */
@@ -1 +1 @@
1
- {"version":3,"file":"FieldBoundaryContext.js","names":["React","FieldBoundaryContext","createContext","undefined"],"sources":["../../../../../../src/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../../types'\n\nexport interface FieldBoundaryContextState {\n /**\n * Will be set to true when one or more nested fields are in error state.\n */\n hasError?: boolean\n\n /**\n * Will be set to true when the inherited data context has submit errors and the `hasError` has errors as well.\n */\n hasSubmitError?: boolean\n\n /**\n * Will be set to true when a nested field contains a visible error.\n */\n hasVisibleError?: boolean\n\n /**\n * Contains the nested field errors.\n */\n errorsRef?: React.RefObject<unknown>\n\n /**\n * To set the local error state.\n */\n setFieldError?: (path: Path, error: Error) => void\n}\n\nconst FieldBoundaryContext = React.createContext<\n FieldBoundaryContextState | undefined\n>(undefined)\n\nexport default FieldBoundaryContext\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AA8BzB,MAAMC,oBAAoB,GAAGD,KAAK,CAACE,aAAa,CAE9CC,SAAS,CAAC;AAEZ,eAAeF,oBAAoB"}
1
+ {"version":3,"file":"FieldBoundaryContext.js","names":["React","FieldBoundaryContext","createContext","undefined"],"sources":["../../../../../../src/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../../types'\n\nexport interface FieldBoundaryContextState {\n /**\n * Will be set to true when one or more nested fields are in error state.\n */\n hasError?: boolean\n\n /**\n * Will be set to true when the inherited data context has submit errors and the `hasError` has errors as well.\n */\n hasSubmitError?: boolean\n\n /**\n * Will be set to true when a nested field contains a visible error.\n */\n hasVisibleError?: boolean\n\n /**\n * Contains the nested field errors.\n */\n errorsRef?: React.RefObject<unknown>\n\n /**\n * Will be set to true when the boundary context error state should be shown.\n */\n showBoundaryErrors?: boolean\n\n /**\n * To set the boundary context error state.\n */\n setShowBoundaryErrors?: (showBoundaryErrors: boolean) => void\n\n /**\n * To set the local error state.\n */\n setFieldError?: (path: Path, error: Error) => void\n}\n\nconst FieldBoundaryContext = React.createContext<\n FieldBoundaryContextState | undefined\n>(undefined)\n\nexport default FieldBoundaryContext\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAwCzB,MAAMC,oBAAoB,GAAGD,KAAK,CAACE,aAAa,CAE9CC,SAAS,CAAC;AAEZ,eAAeF,oBAAoB"}