@dnb/eufemia 10.75.1 → 10.75.3

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 (689) hide show
  1. package/CHANGELOG.md +41 -0
  2. package/cjs/components/accordion/Accordion.js +2 -3
  3. package/cjs/components/accordion/Accordion.js.map +1 -1
  4. package/cjs/components/accordion/AccordionContext.d.ts +0 -4
  5. package/cjs/components/accordion/AccordionContext.js.map +1 -1
  6. package/cjs/components/accordion/AccordionGroup.js +1 -3
  7. package/cjs/components/accordion/AccordionGroup.js.map +1 -1
  8. package/cjs/components/accordion/AccordionProviderContext.d.ts +0 -4
  9. package/cjs/components/accordion/AccordionProviderContext.js +3 -1
  10. package/cjs/components/accordion/AccordionProviderContext.js.map +1 -1
  11. package/cjs/components/accordion/AccordionStore.js +1 -2
  12. package/cjs/components/accordion/AccordionStore.js.map +1 -1
  13. package/cjs/components/accordion/style/dnb-accordion.css +0 -6
  14. package/cjs/components/accordion/style/dnb-accordion.min.css +1 -1
  15. package/cjs/components/accordion/style/dnb-accordion.scss +0 -5
  16. package/cjs/components/autocomplete/Autocomplete.d.ts +1 -1
  17. package/cjs/components/autocomplete/Autocomplete.js +2 -2
  18. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  19. package/cjs/components/autocomplete/AutocompleteDocs.js +1 -1
  20. package/cjs/components/autocomplete/AutocompleteDocs.js.map +1 -1
  21. package/cjs/components/button/Button.js +8 -7
  22. package/cjs/components/button/Button.js.map +1 -1
  23. package/cjs/components/date-picker/DatePickerDocs.js +3 -3
  24. package/cjs/components/date-picker/DatePickerDocs.js.map +1 -1
  25. package/cjs/components/date-picker/DatePickerInput.js +2 -2
  26. package/cjs/components/date-picker/DatePickerInput.js.map +1 -1
  27. package/cjs/components/date-picker/style/dnb-date-picker.css +0 -1
  28. package/cjs/components/date-picker/style/dnb-date-picker.min.css +1 -1
  29. package/cjs/components/dialog/style/dnb-dialog.css +0 -4
  30. package/cjs/components/dialog/style/dnb-dialog.min.css +1 -1
  31. package/cjs/components/dialog/style/dnb-dialog.scss +0 -5
  32. package/cjs/components/drawer/DrawerDocs.js +2 -2
  33. package/cjs/components/drawer/DrawerDocs.js.map +1 -1
  34. package/cjs/components/drawer/style/dnb-drawer.css +0 -4
  35. package/cjs/components/drawer/style/dnb-drawer.min.css +1 -1
  36. package/cjs/components/drawer/style/dnb-drawer.scss +0 -5
  37. package/cjs/components/dropdown/Dropdown.js +1 -1
  38. package/cjs/components/dropdown/Dropdown.js.map +1 -1
  39. package/cjs/components/form-label/style/dnb-form-label.css +0 -1
  40. package/cjs/components/form-label/style/dnb-form-label.min.css +1 -1
  41. package/cjs/components/form-row/FormRow.d.ts +1 -1
  42. package/cjs/components/form-row/FormRowDocs.js +1 -1
  43. package/cjs/components/form-row/FormRowDocs.js.map +1 -1
  44. package/cjs/components/input-masked/style/dnb-input-masked.css +0 -1
  45. package/cjs/components/input-masked/style/dnb-input-masked.min.css +1 -1
  46. package/cjs/components/list-format/ListFormatDocs.js +2 -2
  47. package/cjs/components/list-format/ListFormatDocs.js.map +1 -1
  48. package/cjs/components/modal/style/dnb-modal.css +0 -4
  49. package/cjs/components/modal/style/dnb-modal.min.css +1 -1
  50. package/cjs/components/modal/style/dnb-modal.scss +0 -5
  51. package/cjs/components/pagination/PaginationDocs.js +2 -2
  52. package/cjs/components/pagination/PaginationDocs.js.map +1 -1
  53. package/cjs/components/slider/SliderDocs.js +1 -1
  54. package/cjs/components/slider/SliderDocs.js.map +1 -1
  55. package/cjs/components/step-indicator/StepIndicatorDocs.js +4 -4
  56. package/cjs/components/step-indicator/StepIndicatorDocs.js.map +1 -1
  57. package/cjs/components/timeline/TimelineItem.js +5 -5
  58. package/cjs/components/timeline/TimelineItem.js.map +1 -1
  59. package/cjs/components/toggle-button/ToggleButton.d.ts +1 -1
  60. package/cjs/components/toggle-button/ToggleButtonDocs.js +2 -2
  61. package/cjs/components/toggle-button/ToggleButtonDocs.js.map +1 -1
  62. package/cjs/components/upload/Upload.js +5 -2
  63. package/cjs/components/upload/Upload.js.map +1 -1
  64. package/cjs/components/upload/UploadFileInput.d.ts +2 -1
  65. package/cjs/components/upload/UploadFileInput.js +7 -4
  66. package/cjs/components/upload/UploadFileInput.js.map +1 -1
  67. package/cjs/components/upload/style/dnb-upload.css +0 -1
  68. package/cjs/components/upload/style/dnb-upload.min.css +1 -1
  69. package/cjs/core/jest/jestSetupScreenshots.css +6 -0
  70. package/cjs/extensions/forms/DataContext/Context.d.ts +5 -2
  71. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  72. package/cjs/extensions/forms/DataContext/Provider/Provider.js +22 -4
  73. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  74. package/cjs/extensions/forms/DataContext/Provider/useEventListener.d.ts +3 -0
  75. package/cjs/extensions/forms/DataContext/Provider/useEventListener.js +29 -0
  76. package/cjs/extensions/forms/DataContext/Provider/useEventListener.js.map +1 -0
  77. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +8 -2
  78. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  79. package/cjs/extensions/forms/Field/Date/Date.js +10 -4
  80. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  81. package/cjs/extensions/forms/Field/Indeterminate/Indeterminate.js +4 -2
  82. package/cjs/extensions/forms/Field/Indeterminate/Indeterminate.js.map +1 -1
  83. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.d.ts +1 -0
  84. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js +12 -5
  85. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  86. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +8 -2
  87. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  88. package/cjs/extensions/forms/Field/Number/NumberDocs.js +1 -1
  89. package/cjs/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  90. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +8 -2
  91. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  92. package/cjs/extensions/forms/Field/Password/PasswordDocs.js +8 -2
  93. package/cjs/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
  94. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +1 -1
  95. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  96. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +9 -0
  97. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  98. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +1 -1
  99. package/cjs/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
  100. package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
  101. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js +1 -1
  102. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  103. package/cjs/extensions/forms/Field/String/StringDocs.js +7 -7
  104. package/cjs/extensions/forms/Field/String/StringDocs.js.map +1 -1
  105. package/cjs/extensions/forms/Field/Toggle/Toggle.js +2 -2
  106. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  107. package/cjs/extensions/forms/Field/Upload/Upload.d.ts +1 -1
  108. package/cjs/extensions/forms/Field/Upload/Upload.js +3 -1
  109. package/cjs/extensions/forms/Field/Upload/Upload.js.map +1 -1
  110. package/cjs/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
  111. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +2 -2
  112. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  113. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  114. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  115. package/cjs/extensions/forms/Form/Isolation/IsolatedContainer.js +4 -6
  116. package/cjs/extensions/forms/Form/Isolation/IsolatedContainer.js.map +1 -1
  117. package/cjs/extensions/forms/Form/Isolation/Isolation.js +2 -3
  118. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  119. package/cjs/extensions/forms/Form/Isolation/IsolationDataReference.d.ts +4 -2
  120. package/cjs/extensions/forms/Form/Isolation/IsolationDataReference.js +20 -4
  121. package/cjs/extensions/forms/Form/Isolation/IsolationDataReference.js.map +1 -1
  122. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js +1 -1
  123. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  124. package/cjs/extensions/forms/Form/Isolation/IsolationResetButton.js +2 -1
  125. package/cjs/extensions/forms/Form/Isolation/IsolationResetButton.js.map +1 -1
  126. package/cjs/extensions/forms/Form/Isolation/useDataContextSnapshot.js +15 -8
  127. package/cjs/extensions/forms/Form/Isolation/useDataContextSnapshot.js.map +1 -1
  128. package/cjs/extensions/forms/Form/Isolation/useHandleStatus.d.ts +2 -1
  129. package/cjs/extensions/forms/Form/Isolation/useHandleStatus.js +10 -3
  130. package/cjs/extensions/forms/Form/Isolation/useHandleStatus.js.map +1 -1
  131. package/cjs/extensions/forms/Form/Isolation/useHasContentChanged.d.ts +3 -1
  132. package/cjs/extensions/forms/Form/Isolation/useHasContentChanged.js +4 -1
  133. package/cjs/extensions/forms/Form/Isolation/useHasContentChanged.js.map +1 -1
  134. package/cjs/extensions/forms/Form/Isolation/useReportError.d.ts +1 -1
  135. package/cjs/extensions/forms/Form/Isolation/useReportError.js +22 -7
  136. package/cjs/extensions/forms/Form/Isolation/useReportError.js.map +1 -1
  137. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +6 -6
  138. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  139. package/cjs/extensions/forms/Iterate/EditContainer/ResetButton.js +3 -1
  140. package/cjs/extensions/forms/Iterate/EditContainer/ResetButton.js.map +1 -1
  141. package/cjs/extensions/forms/Iterate/ItemNo/{useIItemNo.js → useIterateItemNo.js} +2 -2
  142. package/cjs/extensions/forms/Iterate/ItemNo/useIterateItemNo.js.map +1 -0
  143. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +3 -1
  144. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -3
  145. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  146. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +6 -1
  147. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  148. package/cjs/extensions/forms/Tools/Errors.d.ts +5 -0
  149. package/cjs/extensions/forms/Tools/Errors.js +46 -0
  150. package/cjs/extensions/forms/Tools/Errors.js.map +1 -0
  151. package/cjs/extensions/forms/Tools/index.d.ts +1 -0
  152. package/cjs/extensions/forms/Tools/index.js +7 -0
  153. package/cjs/extensions/forms/Tools/index.js.map +1 -1
  154. package/cjs/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js +2 -4
  155. package/cjs/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js.map +1 -1
  156. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +11 -5
  157. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  158. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  159. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  160. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  161. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  162. package/cjs/extensions/forms/Wizard/Step/Step.js +1 -1
  163. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  164. package/cjs/extensions/forms/Wizard/hooks/useStep.js +13 -5
  165. package/cjs/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  166. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -3
  167. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  168. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +1 -0
  169. package/cjs/extensions/forms/constants/locales/en-GB.js +2 -1
  170. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  171. package/cjs/extensions/forms/constants/locales/en-US.d.ts +1 -0
  172. package/cjs/extensions/forms/constants/locales/index.d.ts +2 -0
  173. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +1 -0
  174. package/cjs/extensions/forms/constants/locales/nb-NO.js +2 -1
  175. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  176. package/cjs/extensions/forms/constants/locales/sv-SE.d.ts +1 -0
  177. package/cjs/extensions/forms/constants/locales/sv-SE.js +2 -1
  178. package/cjs/extensions/forms/constants/locales/sv-SE.js.map +1 -1
  179. package/cjs/extensions/forms/hooks/useFieldProps.js +6 -6
  180. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  181. package/cjs/extensions/payment-card/PaymentCard.js +8 -1
  182. package/cjs/extensions/payment-card/PaymentCard.js.map +1 -1
  183. package/cjs/extensions/payment-card/icons/brandLogos/DNB.js +2 -2
  184. package/cjs/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -1
  185. package/cjs/extensions/payment-card/icons/providers/BankAxept.js +2 -2
  186. package/cjs/extensions/payment-card/icons/providers/BankAxept.js.map +1 -1
  187. package/cjs/extensions/payment-card/icons/providers/ClickToPay.js +2 -2
  188. package/cjs/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -1
  189. package/cjs/extensions/payment-card/icons/providers/MastercardDefault.js +2 -2
  190. package/cjs/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -1
  191. package/cjs/extensions/payment-card/icons/providers/VisaDefault.js +2 -2
  192. package/cjs/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -1
  193. package/cjs/extensions/payment-card/icons/providers/VisaPlatinum.js +2 -2
  194. package/cjs/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -1
  195. package/cjs/fragments/drawer-list/DrawerListHelpers.js +2 -1
  196. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  197. package/cjs/shared/AlignmentHelper.d.ts +14 -8
  198. package/cjs/shared/AlignmentHelper.js +4 -8
  199. package/cjs/shared/AlignmentHelper.js.map +1 -1
  200. package/cjs/shared/BuildInfo.d.cts +2 -0
  201. package/cjs/shared/BuildInfo.js +5 -0
  202. package/cjs/shared/BuildInfo.js.map +1 -0
  203. package/cjs/shared/Eufemia.d.ts +14 -1
  204. package/cjs/shared/Eufemia.js +31 -3
  205. package/cjs/shared/Eufemia.js.map +1 -1
  206. package/cjs/shared/helpers/runCssVersionMismatchWarning.d.ts +0 -7
  207. package/cjs/shared/helpers/runCssVersionMismatchWarning.js.map +1 -1
  208. package/cjs/shared/useMedia.js +66 -55
  209. package/cjs/shared/useMedia.js.map +1 -1
  210. package/cjs/style/core/helper-classes/helper-classes.scss +3 -0
  211. package/cjs/style/core/scopes.scss +1 -1
  212. package/cjs/style/core/utilities.scss +3 -1
  213. package/cjs/style/dnb-ui-basis.css +13 -2
  214. package/cjs/style/dnb-ui-basis.min.css +1 -1
  215. package/cjs/style/dnb-ui-body.css +1 -2
  216. package/cjs/style/dnb-ui-body.min.css +1 -1
  217. package/cjs/style/dnb-ui-components.css +0 -22
  218. package/cjs/style/dnb-ui-components.min.css +3 -3
  219. package/cjs/style/dnb-ui-core.css +13 -3
  220. package/cjs/style/dnb-ui-core.min.css +1 -1
  221. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +0 -22
  222. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +3 -3
  223. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +0 -22
  224. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +3 -3
  225. package/cjs/style/themes/theme-ui/ui-theme-components.css +0 -22
  226. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +3 -3
  227. package/components/accordion/Accordion.js +2 -3
  228. package/components/accordion/Accordion.js.map +1 -1
  229. package/components/accordion/AccordionContext.d.ts +0 -4
  230. package/components/accordion/AccordionContext.js.map +1 -1
  231. package/components/accordion/AccordionGroup.js +1 -3
  232. package/components/accordion/AccordionGroup.js.map +1 -1
  233. package/components/accordion/AccordionProviderContext.d.ts +0 -4
  234. package/components/accordion/AccordionProviderContext.js +3 -1
  235. package/components/accordion/AccordionProviderContext.js.map +1 -1
  236. package/components/accordion/AccordionStore.js +1 -2
  237. package/components/accordion/AccordionStore.js.map +1 -1
  238. package/components/accordion/style/dnb-accordion.css +0 -6
  239. package/components/accordion/style/dnb-accordion.min.css +1 -1
  240. package/components/accordion/style/dnb-accordion.scss +0 -5
  241. package/components/autocomplete/Autocomplete.d.ts +1 -1
  242. package/components/autocomplete/Autocomplete.js +2 -2
  243. package/components/autocomplete/Autocomplete.js.map +1 -1
  244. package/components/autocomplete/AutocompleteDocs.js +1 -1
  245. package/components/autocomplete/AutocompleteDocs.js.map +1 -1
  246. package/components/button/Button.js +8 -7
  247. package/components/button/Button.js.map +1 -1
  248. package/components/date-picker/DatePickerDocs.js +3 -3
  249. package/components/date-picker/DatePickerDocs.js.map +1 -1
  250. package/components/date-picker/DatePickerInput.js +2 -2
  251. package/components/date-picker/DatePickerInput.js.map +1 -1
  252. package/components/date-picker/style/dnb-date-picker.css +0 -1
  253. package/components/date-picker/style/dnb-date-picker.min.css +1 -1
  254. package/components/dialog/style/dnb-dialog.css +0 -4
  255. package/components/dialog/style/dnb-dialog.min.css +1 -1
  256. package/components/dialog/style/dnb-dialog.scss +0 -5
  257. package/components/drawer/DrawerDocs.js +2 -2
  258. package/components/drawer/DrawerDocs.js.map +1 -1
  259. package/components/drawer/style/dnb-drawer.css +0 -4
  260. package/components/drawer/style/dnb-drawer.min.css +1 -1
  261. package/components/drawer/style/dnb-drawer.scss +0 -5
  262. package/components/dropdown/Dropdown.js +2 -2
  263. package/components/dropdown/Dropdown.js.map +1 -1
  264. package/components/form-label/style/dnb-form-label.css +0 -1
  265. package/components/form-label/style/dnb-form-label.min.css +1 -1
  266. package/components/form-row/FormRow.d.ts +1 -1
  267. package/components/form-row/FormRowDocs.js +1 -1
  268. package/components/form-row/FormRowDocs.js.map +1 -1
  269. package/components/input-masked/style/dnb-input-masked.css +0 -1
  270. package/components/input-masked/style/dnb-input-masked.min.css +1 -1
  271. package/components/list-format/ListFormatDocs.js +2 -2
  272. package/components/list-format/ListFormatDocs.js.map +1 -1
  273. package/components/modal/style/dnb-modal.css +0 -4
  274. package/components/modal/style/dnb-modal.min.css +1 -1
  275. package/components/modal/style/dnb-modal.scss +0 -5
  276. package/components/pagination/PaginationDocs.js +2 -2
  277. package/components/pagination/PaginationDocs.js.map +1 -1
  278. package/components/slider/SliderDocs.js +1 -1
  279. package/components/slider/SliderDocs.js.map +1 -1
  280. package/components/step-indicator/StepIndicatorDocs.js +4 -4
  281. package/components/step-indicator/StepIndicatorDocs.js.map +1 -1
  282. package/components/timeline/TimelineItem.js +5 -5
  283. package/components/timeline/TimelineItem.js.map +1 -1
  284. package/components/toggle-button/ToggleButton.d.ts +1 -1
  285. package/components/toggle-button/ToggleButtonDocs.js +2 -2
  286. package/components/toggle-button/ToggleButtonDocs.js.map +1 -1
  287. package/components/upload/Upload.js +5 -2
  288. package/components/upload/Upload.js.map +1 -1
  289. package/components/upload/UploadFileInput.d.ts +2 -1
  290. package/components/upload/UploadFileInput.js +7 -4
  291. package/components/upload/UploadFileInput.js.map +1 -1
  292. package/components/upload/style/dnb-upload.css +0 -1
  293. package/components/upload/style/dnb-upload.min.css +1 -1
  294. package/core/jest/jestSetupScreenshots.css +6 -0
  295. package/es/components/accordion/Accordion.js +2 -3
  296. package/es/components/accordion/Accordion.js.map +1 -1
  297. package/es/components/accordion/AccordionContext.d.ts +0 -4
  298. package/es/components/accordion/AccordionContext.js.map +1 -1
  299. package/es/components/accordion/AccordionGroup.js +1 -3
  300. package/es/components/accordion/AccordionGroup.js.map +1 -1
  301. package/es/components/accordion/AccordionProviderContext.d.ts +0 -4
  302. package/es/components/accordion/AccordionProviderContext.js +3 -1
  303. package/es/components/accordion/AccordionProviderContext.js.map +1 -1
  304. package/es/components/accordion/AccordionStore.js +1 -2
  305. package/es/components/accordion/AccordionStore.js.map +1 -1
  306. package/es/components/accordion/style/dnb-accordion.css +0 -6
  307. package/es/components/accordion/style/dnb-accordion.min.css +1 -1
  308. package/es/components/accordion/style/dnb-accordion.scss +0 -5
  309. package/es/components/autocomplete/Autocomplete.d.ts +1 -1
  310. package/es/components/autocomplete/Autocomplete.js +2 -2
  311. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  312. package/es/components/autocomplete/AutocompleteDocs.js +1 -1
  313. package/es/components/autocomplete/AutocompleteDocs.js.map +1 -1
  314. package/es/components/button/Button.js +8 -7
  315. package/es/components/button/Button.js.map +1 -1
  316. package/es/components/date-picker/DatePickerDocs.js +3 -3
  317. package/es/components/date-picker/DatePickerDocs.js.map +1 -1
  318. package/es/components/date-picker/DatePickerInput.js +2 -2
  319. package/es/components/date-picker/DatePickerInput.js.map +1 -1
  320. package/es/components/date-picker/style/dnb-date-picker.css +0 -1
  321. package/es/components/date-picker/style/dnb-date-picker.min.css +1 -1
  322. package/es/components/dialog/style/dnb-dialog.css +0 -4
  323. package/es/components/dialog/style/dnb-dialog.min.css +1 -1
  324. package/es/components/dialog/style/dnb-dialog.scss +0 -5
  325. package/es/components/drawer/DrawerDocs.js +2 -2
  326. package/es/components/drawer/DrawerDocs.js.map +1 -1
  327. package/es/components/drawer/style/dnb-drawer.css +0 -4
  328. package/es/components/drawer/style/dnb-drawer.min.css +1 -1
  329. package/es/components/drawer/style/dnb-drawer.scss +0 -5
  330. package/es/components/dropdown/Dropdown.js +2 -2
  331. package/es/components/dropdown/Dropdown.js.map +1 -1
  332. package/es/components/form-label/style/dnb-form-label.css +0 -1
  333. package/es/components/form-label/style/dnb-form-label.min.css +1 -1
  334. package/es/components/form-row/FormRow.d.ts +1 -1
  335. package/es/components/form-row/FormRowDocs.js +1 -1
  336. package/es/components/form-row/FormRowDocs.js.map +1 -1
  337. package/es/components/input-masked/style/dnb-input-masked.css +0 -1
  338. package/es/components/input-masked/style/dnb-input-masked.min.css +1 -1
  339. package/es/components/list-format/ListFormatDocs.js +2 -2
  340. package/es/components/list-format/ListFormatDocs.js.map +1 -1
  341. package/es/components/modal/style/dnb-modal.css +0 -4
  342. package/es/components/modal/style/dnb-modal.min.css +1 -1
  343. package/es/components/modal/style/dnb-modal.scss +0 -5
  344. package/es/components/pagination/PaginationDocs.js +2 -2
  345. package/es/components/pagination/PaginationDocs.js.map +1 -1
  346. package/es/components/slider/SliderDocs.js +1 -1
  347. package/es/components/slider/SliderDocs.js.map +1 -1
  348. package/es/components/step-indicator/StepIndicatorDocs.js +4 -4
  349. package/es/components/step-indicator/StepIndicatorDocs.js.map +1 -1
  350. package/es/components/timeline/TimelineItem.js +5 -5
  351. package/es/components/timeline/TimelineItem.js.map +1 -1
  352. package/es/components/toggle-button/ToggleButton.d.ts +1 -1
  353. package/es/components/toggle-button/ToggleButtonDocs.js +2 -2
  354. package/es/components/toggle-button/ToggleButtonDocs.js.map +1 -1
  355. package/es/components/upload/Upload.js +5 -2
  356. package/es/components/upload/Upload.js.map +1 -1
  357. package/es/components/upload/UploadFileInput.d.ts +2 -1
  358. package/es/components/upload/UploadFileInput.js +7 -4
  359. package/es/components/upload/UploadFileInput.js.map +1 -1
  360. package/es/components/upload/style/dnb-upload.css +0 -1
  361. package/es/components/upload/style/dnb-upload.min.css +1 -1
  362. package/es/core/jest/jestSetupScreenshots.css +6 -0
  363. package/es/extensions/forms/DataContext/Context.d.ts +5 -2
  364. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  365. package/es/extensions/forms/DataContext/Provider/Provider.js +22 -4
  366. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  367. package/es/extensions/forms/DataContext/Provider/useEventListener.d.ts +3 -0
  368. package/es/extensions/forms/DataContext/Provider/useEventListener.js +22 -0
  369. package/es/extensions/forms/DataContext/Provider/useEventListener.js.map +1 -0
  370. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +6 -2
  371. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  372. package/es/extensions/forms/Field/Date/Date.js +10 -4
  373. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  374. package/es/extensions/forms/Field/Indeterminate/Indeterminate.js +4 -2
  375. package/es/extensions/forms/Field/Indeterminate/Indeterminate.js.map +1 -1
  376. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.d.ts +1 -0
  377. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js +12 -5
  378. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  379. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +6 -2
  380. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  381. package/es/extensions/forms/Field/Number/NumberDocs.js +1 -1
  382. package/es/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  383. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +6 -2
  384. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  385. package/es/extensions/forms/Field/Password/PasswordDocs.js +6 -2
  386. package/es/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
  387. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +1 -1
  388. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  389. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +7 -0
  390. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  391. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +1 -1
  392. package/es/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
  393. package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
  394. package/es/extensions/forms/Field/Selection/SelectionDocs.js +1 -1
  395. package/es/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  396. package/es/extensions/forms/Field/String/StringDocs.js +7 -7
  397. package/es/extensions/forms/Field/String/StringDocs.js.map +1 -1
  398. package/es/extensions/forms/Field/Toggle/Toggle.js +1 -1
  399. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  400. package/es/extensions/forms/Field/Upload/Upload.d.ts +1 -1
  401. package/es/extensions/forms/Field/Upload/Upload.js +3 -1
  402. package/es/extensions/forms/Field/Upload/Upload.js.map +1 -1
  403. package/es/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
  404. package/es/extensions/forms/FieldBlock/FieldBlock.js +1 -1
  405. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  406. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  407. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  408. package/es/extensions/forms/Form/Isolation/IsolatedContainer.js +4 -6
  409. package/es/extensions/forms/Form/Isolation/IsolatedContainer.js.map +1 -1
  410. package/es/extensions/forms/Form/Isolation/Isolation.js +2 -3
  411. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  412. package/es/extensions/forms/Form/Isolation/IsolationDataReference.d.ts +4 -2
  413. package/es/extensions/forms/Form/Isolation/IsolationDataReference.js +18 -4
  414. package/es/extensions/forms/Form/Isolation/IsolationDataReference.js.map +1 -1
  415. package/es/extensions/forms/Form/Isolation/IsolationDocs.js +1 -1
  416. package/es/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  417. package/es/extensions/forms/Form/Isolation/IsolationResetButton.js +2 -1
  418. package/es/extensions/forms/Form/Isolation/IsolationResetButton.js.map +1 -1
  419. package/es/extensions/forms/Form/Isolation/useDataContextSnapshot.js +14 -8
  420. package/es/extensions/forms/Form/Isolation/useDataContextSnapshot.js.map +1 -1
  421. package/es/extensions/forms/Form/Isolation/useHandleStatus.d.ts +2 -1
  422. package/es/extensions/forms/Form/Isolation/useHandleStatus.js +10 -3
  423. package/es/extensions/forms/Form/Isolation/useHandleStatus.js.map +1 -1
  424. package/es/extensions/forms/Form/Isolation/useHasContentChanged.d.ts +3 -1
  425. package/es/extensions/forms/Form/Isolation/useHasContentChanged.js +4 -2
  426. package/es/extensions/forms/Form/Isolation/useHasContentChanged.js.map +1 -1
  427. package/es/extensions/forms/Form/Isolation/useReportError.d.ts +1 -1
  428. package/es/extensions/forms/Form/Isolation/useReportError.js +22 -7
  429. package/es/extensions/forms/Form/Isolation/useReportError.js.map +1 -1
  430. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +6 -6
  431. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  432. package/es/extensions/forms/Iterate/EditContainer/ResetButton.js +3 -1
  433. package/es/extensions/forms/Iterate/EditContainer/ResetButton.js.map +1 -1
  434. package/es/extensions/forms/Iterate/ItemNo/{useIItemNo.js → useIterateItemNo.js} +2 -2
  435. package/es/extensions/forms/Iterate/ItemNo/useIterateItemNo.js.map +1 -0
  436. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +3 -1
  437. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -3
  438. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  439. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +6 -1
  440. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  441. package/es/extensions/forms/Tools/Errors.d.ts +5 -0
  442. package/es/extensions/forms/Tools/Errors.js +37 -0
  443. package/es/extensions/forms/Tools/Errors.js.map +1 -0
  444. package/es/extensions/forms/Tools/index.d.ts +1 -0
  445. package/es/extensions/forms/Tools/index.js +1 -0
  446. package/es/extensions/forms/Tools/index.js.map +1 -1
  447. package/es/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js +2 -4
  448. package/es/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js.map +1 -1
  449. package/es/extensions/forms/Wizard/Container/WizardContainer.js +11 -5
  450. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  451. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  452. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  453. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  454. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  455. package/es/extensions/forms/Wizard/Step/Step.js +1 -1
  456. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  457. package/es/extensions/forms/Wizard/hooks/useStep.js +13 -5
  458. package/es/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  459. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -3
  460. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  461. package/es/extensions/forms/constants/locales/en-GB.d.ts +1 -0
  462. package/es/extensions/forms/constants/locales/en-GB.js +2 -1
  463. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  464. package/es/extensions/forms/constants/locales/en-US.d.ts +1 -0
  465. package/es/extensions/forms/constants/locales/index.d.ts +2 -0
  466. package/es/extensions/forms/constants/locales/nb-NO.d.ts +1 -0
  467. package/es/extensions/forms/constants/locales/nb-NO.js +2 -1
  468. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  469. package/es/extensions/forms/constants/locales/sv-SE.d.ts +1 -0
  470. package/es/extensions/forms/constants/locales/sv-SE.js +2 -1
  471. package/es/extensions/forms/constants/locales/sv-SE.js.map +1 -1
  472. package/es/extensions/forms/hooks/useFieldProps.js +8 -8
  473. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  474. package/es/extensions/payment-card/PaymentCard.js +1 -0
  475. package/es/extensions/payment-card/PaymentCard.js.map +1 -1
  476. package/es/extensions/payment-card/icons/brandLogos/DNB.js +2 -2
  477. package/es/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -1
  478. package/es/extensions/payment-card/icons/providers/BankAxept.js +2 -2
  479. package/es/extensions/payment-card/icons/providers/BankAxept.js.map +1 -1
  480. package/es/extensions/payment-card/icons/providers/ClickToPay.js +2 -2
  481. package/es/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -1
  482. package/es/extensions/payment-card/icons/providers/MastercardDefault.js +2 -2
  483. package/es/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -1
  484. package/es/extensions/payment-card/icons/providers/VisaDefault.js +2 -2
  485. package/es/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -1
  486. package/es/extensions/payment-card/icons/providers/VisaPlatinum.js +2 -2
  487. package/es/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -1
  488. package/es/fragments/drawer-list/DrawerListHelpers.js +2 -1
  489. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  490. package/es/shared/AlignmentHelper.d.ts +14 -8
  491. package/es/shared/AlignmentHelper.js +4 -8
  492. package/es/shared/AlignmentHelper.js.map +1 -1
  493. package/es/shared/BuildInfo.cjs +6 -0
  494. package/es/shared/BuildInfo.d.cts +2 -0
  495. package/es/shared/Eufemia.d.ts +14 -1
  496. package/es/shared/Eufemia.js +27 -2
  497. package/es/shared/Eufemia.js.map +1 -1
  498. package/es/shared/helpers/runCssVersionMismatchWarning.d.ts +0 -7
  499. package/es/shared/helpers/runCssVersionMismatchWarning.js.map +1 -1
  500. package/es/shared/useMedia.js +66 -55
  501. package/es/shared/useMedia.js.map +1 -1
  502. package/es/style/core/helper-classes/helper-classes.scss +3 -0
  503. package/es/style/core/scopes.scss +1 -1
  504. package/es/style/core/utilities.scss +3 -1
  505. package/es/style/dnb-ui-basis.css +13 -2
  506. package/es/style/dnb-ui-basis.min.css +1 -1
  507. package/es/style/dnb-ui-body.css +1 -2
  508. package/es/style/dnb-ui-body.min.css +1 -1
  509. package/es/style/dnb-ui-components.css +0 -22
  510. package/es/style/dnb-ui-components.min.css +3 -3
  511. package/es/style/dnb-ui-core.css +13 -3
  512. package/es/style/dnb-ui-core.min.css +1 -1
  513. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +0 -22
  514. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +3 -3
  515. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +0 -22
  516. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +3 -3
  517. package/es/style/themes/theme-ui/ui-theme-components.css +0 -22
  518. package/es/style/themes/theme-ui/ui-theme-components.min.css +3 -3
  519. package/esm/dnb-ui-components.min.mjs +1 -1
  520. package/esm/dnb-ui-elements.min.mjs +1 -1
  521. package/esm/dnb-ui-extensions.min.mjs +3 -3
  522. package/esm/dnb-ui-lib.min.mjs +1 -1
  523. package/extensions/forms/DataContext/Context.d.ts +5 -2
  524. package/extensions/forms/DataContext/Context.js.map +1 -1
  525. package/extensions/forms/DataContext/Provider/Provider.js +22 -4
  526. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  527. package/extensions/forms/DataContext/Provider/useEventListener.d.ts +3 -0
  528. package/extensions/forms/DataContext/Provider/useEventListener.js +23 -0
  529. package/extensions/forms/DataContext/Provider/useEventListener.js.map +1 -0
  530. package/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +6 -2
  531. package/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  532. package/extensions/forms/Field/Date/Date.js +10 -4
  533. package/extensions/forms/Field/Date/Date.js.map +1 -1
  534. package/extensions/forms/Field/Indeterminate/Indeterminate.js +4 -2
  535. package/extensions/forms/Field/Indeterminate/Indeterminate.js.map +1 -1
  536. package/extensions/forms/Field/Indeterminate/useDependencePaths.d.ts +1 -0
  537. package/extensions/forms/Field/Indeterminate/useDependencePaths.js +12 -5
  538. package/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  539. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +6 -2
  540. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  541. package/extensions/forms/Field/Number/NumberDocs.js +1 -1
  542. package/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  543. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +6 -2
  544. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  545. package/extensions/forms/Field/Password/PasswordDocs.js +6 -2
  546. package/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
  547. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +1 -1
  548. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  549. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +7 -0
  550. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  551. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js +1 -1
  552. package/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.js.map +1 -1
  553. package/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
  554. package/extensions/forms/Field/Selection/SelectionDocs.js +1 -1
  555. package/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  556. package/extensions/forms/Field/String/StringDocs.js +7 -7
  557. package/extensions/forms/Field/String/StringDocs.js.map +1 -1
  558. package/extensions/forms/Field/Toggle/Toggle.js +1 -1
  559. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  560. package/extensions/forms/Field/Upload/Upload.d.ts +1 -1
  561. package/extensions/forms/Field/Upload/Upload.js +3 -1
  562. package/extensions/forms/Field/Upload/Upload.js.map +1 -1
  563. package/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
  564. package/extensions/forms/FieldBlock/FieldBlock.js +1 -1
  565. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  566. package/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  567. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  568. package/extensions/forms/Form/Isolation/IsolatedContainer.js +4 -6
  569. package/extensions/forms/Form/Isolation/IsolatedContainer.js.map +1 -1
  570. package/extensions/forms/Form/Isolation/Isolation.js +2 -3
  571. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  572. package/extensions/forms/Form/Isolation/IsolationDataReference.d.ts +4 -2
  573. package/extensions/forms/Form/Isolation/IsolationDataReference.js +20 -4
  574. package/extensions/forms/Form/Isolation/IsolationDataReference.js.map +1 -1
  575. package/extensions/forms/Form/Isolation/IsolationDocs.js +1 -1
  576. package/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  577. package/extensions/forms/Form/Isolation/IsolationResetButton.js +2 -1
  578. package/extensions/forms/Form/Isolation/IsolationResetButton.js.map +1 -1
  579. package/extensions/forms/Form/Isolation/useDataContextSnapshot.js +15 -8
  580. package/extensions/forms/Form/Isolation/useDataContextSnapshot.js.map +1 -1
  581. package/extensions/forms/Form/Isolation/useHandleStatus.d.ts +2 -1
  582. package/extensions/forms/Form/Isolation/useHandleStatus.js +10 -3
  583. package/extensions/forms/Form/Isolation/useHandleStatus.js.map +1 -1
  584. package/extensions/forms/Form/Isolation/useHasContentChanged.d.ts +3 -1
  585. package/extensions/forms/Form/Isolation/useHasContentChanged.js +4 -1
  586. package/extensions/forms/Form/Isolation/useHasContentChanged.js.map +1 -1
  587. package/extensions/forms/Form/Isolation/useReportError.d.ts +1 -1
  588. package/extensions/forms/Form/Isolation/useReportError.js +22 -7
  589. package/extensions/forms/Form/Isolation/useReportError.js.map +1 -1
  590. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +6 -6
  591. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  592. package/extensions/forms/Iterate/EditContainer/ResetButton.js +3 -1
  593. package/extensions/forms/Iterate/EditContainer/ResetButton.js.map +1 -1
  594. package/extensions/forms/Iterate/ItemNo/{useIItemNo.js → useIterateItemNo.js} +2 -2
  595. package/extensions/forms/Iterate/ItemNo/useIterateItemNo.js.map +1 -0
  596. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +3 -1
  597. package/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -3
  598. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  599. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +6 -1
  600. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  601. package/extensions/forms/Tools/Errors.d.ts +5 -0
  602. package/extensions/forms/Tools/Errors.js +38 -0
  603. package/extensions/forms/Tools/Errors.js.map +1 -0
  604. package/extensions/forms/Tools/index.d.ts +1 -0
  605. package/extensions/forms/Tools/index.js +1 -0
  606. package/extensions/forms/Tools/index.js.map +1 -1
  607. package/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js +2 -4
  608. package/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js.map +1 -1
  609. package/extensions/forms/Wizard/Container/WizardContainer.js +11 -5
  610. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  611. package/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  612. package/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  613. package/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  614. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  615. package/extensions/forms/Wizard/Step/Step.js +1 -1
  616. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  617. package/extensions/forms/Wizard/hooks/useStep.js +13 -5
  618. package/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  619. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -3
  620. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  621. package/extensions/forms/constants/locales/en-GB.d.ts +1 -0
  622. package/extensions/forms/constants/locales/en-GB.js +2 -1
  623. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  624. package/extensions/forms/constants/locales/en-US.d.ts +1 -0
  625. package/extensions/forms/constants/locales/index.d.ts +2 -0
  626. package/extensions/forms/constants/locales/nb-NO.d.ts +1 -0
  627. package/extensions/forms/constants/locales/nb-NO.js +2 -1
  628. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  629. package/extensions/forms/constants/locales/sv-SE.d.ts +1 -0
  630. package/extensions/forms/constants/locales/sv-SE.js +2 -1
  631. package/extensions/forms/constants/locales/sv-SE.js.map +1 -1
  632. package/extensions/forms/hooks/useFieldProps.js +8 -8
  633. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  634. package/extensions/payment-card/PaymentCard.js +1 -0
  635. package/extensions/payment-card/PaymentCard.js.map +1 -1
  636. package/extensions/payment-card/icons/brandLogos/DNB.js +2 -2
  637. package/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -1
  638. package/extensions/payment-card/icons/providers/BankAxept.js +2 -2
  639. package/extensions/payment-card/icons/providers/BankAxept.js.map +1 -1
  640. package/extensions/payment-card/icons/providers/ClickToPay.js +2 -2
  641. package/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -1
  642. package/extensions/payment-card/icons/providers/MastercardDefault.js +2 -2
  643. package/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -1
  644. package/extensions/payment-card/icons/providers/VisaDefault.js +2 -2
  645. package/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -1
  646. package/extensions/payment-card/icons/providers/VisaPlatinum.js +2 -2
  647. package/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -1
  648. package/fragments/drawer-list/DrawerListHelpers.js +2 -1
  649. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  650. package/package.json +1 -1
  651. package/shared/AlignmentHelper.d.ts +14 -8
  652. package/shared/AlignmentHelper.js +4 -8
  653. package/shared/AlignmentHelper.js.map +1 -1
  654. package/shared/BuildInfo.cjs +6 -0
  655. package/shared/BuildInfo.d.cts +2 -0
  656. package/shared/Eufemia.d.ts +14 -1
  657. package/shared/Eufemia.js +27 -2
  658. package/shared/Eufemia.js.map +1 -1
  659. package/shared/helpers/runCssVersionMismatchWarning.d.ts +0 -7
  660. package/shared/helpers/runCssVersionMismatchWarning.js.map +1 -1
  661. package/shared/useMedia.js +67 -56
  662. package/shared/useMedia.js.map +1 -1
  663. package/style/core/helper-classes/helper-classes.scss +3 -0
  664. package/style/core/scopes.scss +1 -1
  665. package/style/core/utilities.scss +3 -1
  666. package/style/dnb-ui-basis.css +13 -2
  667. package/style/dnb-ui-basis.min.css +1 -1
  668. package/style/dnb-ui-body.css +1 -2
  669. package/style/dnb-ui-body.min.css +1 -1
  670. package/style/dnb-ui-components.css +0 -22
  671. package/style/dnb-ui-components.min.css +3 -3
  672. package/style/dnb-ui-core.css +13 -3
  673. package/style/dnb-ui-core.min.css +1 -1
  674. package/style/themes/theme-eiendom/eiendom-theme-components.css +0 -22
  675. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +3 -3
  676. package/style/themes/theme-sbanken/sbanken-theme-components.css +0 -22
  677. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +3 -3
  678. package/style/themes/theme-ui/ui-theme-components.css +0 -22
  679. package/style/themes/theme-ui/ui-theme-components.min.css +3 -3
  680. package/umd/dnb-ui-components.min.js +1 -1
  681. package/umd/dnb-ui-elements.min.js +1 -1
  682. package/umd/dnb-ui-extensions.min.js +1 -1
  683. package/umd/dnb-ui-lib.min.js +1 -1
  684. package/cjs/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +0 -1
  685. package/es/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +0 -1
  686. package/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +0 -1
  687. /package/cjs/extensions/forms/Iterate/ItemNo/{useIItemNo.d.ts → useIterateItemNo.d.ts} +0 -0
  688. /package/es/extensions/forms/Iterate/ItemNo/{useIItemNo.d.ts → useIterateItemNo.d.ts} +0 -0
  689. /package/extensions/forms/Iterate/ItemNo/{useIItemNo.d.ts → useIterateItemNo.d.ts} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"PhoneNumberDocs.js","names":["getFieldEventsWithTypes","stringProperties","PhoneNumberProperties","countries","doc","type","status","filterCountries","pattern","omitCountryCodeField","countryCodeFieldClassName","numberFieldClassName","countryCodePlaceholder","countryCodeLabel","numberMask","width","size","PhoneNumberSpecificEvents","onChange","onCountryCodeChange","onNumberChange","PhoneNumberGeneralEvents","optional"],"sources":["../../../../../../src/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { getFieldEventsWithTypes } from '../FieldDocs'\nimport { stringProperties } from '../String/StringDocs'\n\nexport const PhoneNumberProperties: PropertiesTableProps = {\n countries: {\n doc: 'List only a certain set of countries: `Scandinavia`, `Nordic`, `Europe` or `Prioritized`(all countries [sorted by priority](/uilib/extensions/forms/feature-fields/SelectCountry/#filter-or-prioritize-country-listing)). Defaults to `Prioritized`.',\n type: 'string',\n status: 'optional',\n },\n filterCountries: {\n doc: 'Use this prop to filter out certain countries. The function receives the country object and should return a boolean. Returning `false` will omit the country.',\n type: 'function',\n status: 'optional',\n },\n pattern: {\n doc: 'Validation based on regex pattern for the number field e.g. `pattern=\"^[49]+\"`.',\n type: 'string',\n status: 'optional',\n },\n omitCountryCodeField: {\n doc: 'If `true` is given, then everything related to country code is removed.',\n type: 'boolean',\n status: 'optional',\n },\n countryCodeFieldClassName: {\n doc: 'Class name for the country code component.',\n type: 'string',\n status: 'optional',\n },\n numberFieldClassName: {\n doc: 'Class name for the number component.',\n type: 'string',\n status: 'optional',\n },\n countryCodePlaceholder: {\n doc: 'Placeholder for the country code field.',\n type: 'string',\n status: 'optional',\n },\n countryCodeLabel: {\n doc: 'Label to show above / before the country code field.',\n type: 'string',\n status: 'optional',\n },\n numberMask: {\n doc: 'See property `mask` of the [InputMasked](/uilib/components/input-masked/properties) component.',\n type: 'Various',\n status: 'optional',\n },\n width: {\n doc: '`large` for predefined standard width, `stretch` for fill available width.',\n type: 'string | false',\n status: 'optional',\n },\n size: stringProperties.size,\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 PhoneNumberSpecificEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Callback on phone number and country code change.',\n type: '(value?: string, additionalArgs?: { countryCode?: string, phoneNumber?: string, iso?: string }) => void',\n status: 'optional',\n },\n onCountryCodeChange: {\n doc: 'Callback on country code change.',\n type: '(value?: string) => void',\n status: 'optional',\n },\n onNumberChange: {\n doc: 'Callback on phone number change.',\n type: '(value?: string) => void',\n status: 'optional',\n },\n}\n\nexport const PhoneNumberGeneralEvents = getFieldEventsWithTypes(\n { type: 'string', optional: true },\n { type: 'object' }\n)\n"],"mappings":"AACA,SAASA,uBAAuB,QAAQ,cAAc;AACtD,SAASC,gBAAgB,QAAQ,sBAAsB;AAEvD,OAAO,MAAMC,qBAA2C,GAAG;EACzDC,SAAS,EAAE;IACTC,GAAG,EAAE,sPAAsP;IAC3PC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,eAAe,EAAE;IACfH,GAAG,EAAE,+JAA+J;IACpKC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDE,OAAO,EAAE;IACPJ,GAAG,EAAE,iFAAiF;IACtFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,oBAAoB,EAAE;IACpBL,GAAG,EAAE,yEAAyE;IAC9EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,yBAAyB,EAAE;IACzBN,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,oBAAoB,EAAE;IACpBP,GAAG,EAAE,sCAAsC;IAC3CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,sBAAsB,EAAE;IACtBR,GAAG,EAAE,yCAAyC;IAC9CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,gBAAgB,EAAE;IAChBT,GAAG,EAAE,sDAAsD;IAC3DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,UAAU,EAAE;IACVV,GAAG,EAAE,gGAAgG;IACrGC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDS,KAAK,EAAE;IACLX,GAAG,EAAE,4EAA4E;IACjFC,IAAI,EAAE,gBAAgB;IACtBC,MAAM,EAAE;EACV,CAAC;EACDU,IAAI,EAAEf,gBAAgB,CAACe,IAAI;EAC3B,yCAAyC,EAAE;IACzCZ,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMW,yBAA+C,GAAG;EAC7DC,QAAQ,EAAE;IACRd,GAAG,EAAE,mDAAmD;IACxDC,IAAI,EAAE,yGAAyG;IAC/GC,MAAM,EAAE;EACV,CAAC;EACDa,mBAAmB,EAAE;IACnBf,GAAG,EAAE,kCAAkC;IACvCC,IAAI,EAAE,0BAA0B;IAChCC,MAAM,EAAE;EACV,CAAC;EACDc,cAAc,EAAE;IACdhB,GAAG,EAAE,kCAAkC;IACvCC,IAAI,EAAE,0BAA0B;IAChCC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMe,wBAAwB,GAAGrB,uBAAuB,CAC7D;EAAEK,IAAI,EAAE,QAAQ;EAAEiB,QAAQ,EAAE;AAAK,CAAC,EAClC;EAAEjB,IAAI,EAAE;AAAS,CACnB,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"PhoneNumberDocs.js","names":["getFieldEventsWithTypes","stringProperties","FieldProperties","PhoneNumberProperties","countries","doc","type","status","filterCountries","pattern","omitCountryCodeField","countryCodeFieldClassName","numberFieldClassName","countryCodePlaceholder","countryCodeLabel","numberMask","width","label","_objectSpread","size","PhoneNumberSpecificEvents","onChange","onCountryCodeChange","onNumberChange","PhoneNumberGeneralEvents","optional"],"sources":["../../../../../../src/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { getFieldEventsWithTypes } from '../FieldDocs'\nimport { stringProperties } from '../String/StringDocs'\nimport { FieldProperties } from '../../Field/FieldDocs'\n\nexport const PhoneNumberProperties: PropertiesTableProps = {\n countries: {\n doc: 'List only a certain set of countries: `Scandinavia`, `Nordic`, `Europe` or `Prioritized`(all countries [sorted by priority](/uilib/extensions/forms/feature-fields/SelectCountry/#filter-or-prioritize-country-listing)). Defaults to `Prioritized`.',\n type: 'string',\n status: 'optional',\n },\n filterCountries: {\n doc: 'Use this prop to filter out certain countries. The function receives the country object and should return a boolean. Returning `false` will omit the country.',\n type: 'function',\n status: 'optional',\n },\n pattern: {\n doc: 'Validation based on regex pattern for the number field e.g. `pattern=\"^[49]+\"`.',\n type: 'string',\n status: 'optional',\n },\n omitCountryCodeField: {\n doc: 'If `true` is given, then everything related to country code is removed.',\n type: 'boolean',\n status: 'optional',\n },\n countryCodeFieldClassName: {\n doc: 'Class name for the country code component.',\n type: 'string',\n status: 'optional',\n },\n numberFieldClassName: {\n doc: 'Class name for the number component.',\n type: 'string',\n status: 'optional',\n },\n countryCodePlaceholder: {\n doc: 'Placeholder for the country code field.',\n type: 'string',\n status: 'optional',\n },\n countryCodeLabel: {\n doc: 'Label to show above / before the country code field.',\n type: 'string',\n status: 'optional',\n },\n numberMask: {\n doc: 'See property `mask` of the [InputMasked](/uilib/components/input-masked/properties) component.',\n type: 'Various',\n status: 'optional',\n },\n width: {\n doc: '`large` for predefined standard width, `stretch` for fill available width.',\n type: 'string | false',\n status: 'optional',\n },\n label: {\n ...FieldProperties.label,\n doc: 'Field label to show above / before the phone number input field.',\n },\n size: stringProperties.size,\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 PhoneNumberSpecificEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Callback on phone number and country code change.',\n type: '(value?: string, additionalArgs?: { countryCode?: string, phoneNumber?: string, iso?: string }) => void',\n status: 'optional',\n },\n onCountryCodeChange: {\n doc: 'Callback on country code change.',\n type: '(value?: string) => void',\n status: 'optional',\n },\n onNumberChange: {\n doc: 'Callback on phone number change.',\n type: '(value?: string) => void',\n status: 'optional',\n },\n}\n\nexport const PhoneNumberGeneralEvents = getFieldEventsWithTypes(\n { type: 'string', optional: true },\n { type: 'object' }\n)\n"],"mappings":";;;AACA,SAASA,uBAAuB,QAAQ,cAAc;AACtD,SAASC,gBAAgB,QAAQ,sBAAsB;AACvD,SAASC,eAAe,QAAQ,uBAAuB;AAEvD,OAAO,MAAMC,qBAA2C,GAAG;EACzDC,SAAS,EAAE;IACTC,GAAG,EAAE,sPAAsP;IAC3PC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,eAAe,EAAE;IACfH,GAAG,EAAE,+JAA+J;IACpKC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDE,OAAO,EAAE;IACPJ,GAAG,EAAE,iFAAiF;IACtFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,oBAAoB,EAAE;IACpBL,GAAG,EAAE,yEAAyE;IAC9EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,yBAAyB,EAAE;IACzBN,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,oBAAoB,EAAE;IACpBP,GAAG,EAAE,sCAAsC;IAC3CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,sBAAsB,EAAE;IACtBR,GAAG,EAAE,yCAAyC;IAC9CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,gBAAgB,EAAE;IAChBT,GAAG,EAAE,sDAAsD;IAC3DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,UAAU,EAAE;IACVV,GAAG,EAAE,gGAAgG;IACrGC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDS,KAAK,EAAE;IACLX,GAAG,EAAE,4EAA4E;IACjFC,IAAI,EAAE,gBAAgB;IACtBC,MAAM,EAAE;EACV,CAAC;EACDU,KAAK,EAAAC,aAAA,CAAAA,aAAA,KACAhB,eAAe,CAACe,KAAK;IACxBZ,GAAG,EAAE;EAAkE,EACxE;EACDc,IAAI,EAAElB,gBAAgB,CAACkB,IAAI;EAC3B,yCAAyC,EAAE;IACzCd,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMa,yBAA+C,GAAG;EAC7DC,QAAQ,EAAE;IACRhB,GAAG,EAAE,mDAAmD;IACxDC,IAAI,EAAE,yGAAyG;IAC/GC,MAAM,EAAE;EACV,CAAC;EACDe,mBAAmB,EAAE;IACnBjB,GAAG,EAAE,kCAAkC;IACvCC,IAAI,EAAE,0BAA0B;IAChCC,MAAM,EAAE;EACV,CAAC;EACDgB,cAAc,EAAE;IACdlB,GAAG,EAAE,kCAAkC;IACvCC,IAAI,EAAE,0BAA0B;IAChCC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMiB,wBAAwB,GAAGxB,uBAAuB,CAC7D;EAAEM,IAAI,EAAE,QAAQ;EAAEmB,QAAQ,EAAE;AAAK,CAAC,EAClC;EAAEnB,IAAI,EAAE;AAAS,CACnB,CAAC","ignoreList":[]}
@@ -2,7 +2,7 @@ import { FieldProperties } from '../FieldDocs';
2
2
  import { stringProperties } from '../String/StringDocs';
3
3
  export const PostalCodeAndCityProperties = {
4
4
  countryCode: {
5
- doc: 'Defines which country the postal code and city is for, based on the [ISO 3166-1 alpha-2 code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) i.e. `NO`, `DE` etc. ' + 'Setting it to anything other than `NO` will remove the default norwegian postal code pattern. ' + 'You can also use the value of another field to define the countryCode, by using a path value i.e. `/myCountryCodePath`. ' + 'Defaults to `NO`',
5
+ doc: 'Defines which country the postal code and city is for, based on the [ISO 3166-1 alpha-2 code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) i.e. `NO`, `DE` etc. ' + 'Setting it to anything other than `NO` will remove the default norwegian postal code pattern. ' + 'You can also use the value of another field to define the countryCode, by using a path value i.e. `/myCountryCodePath`. ' + 'Defaults to `NO`.',
6
6
  type: ['Path', 'string'],
7
7
  status: 'optional'
8
8
  },
@@ -1 +1 @@
1
- {"version":3,"file":"PostalCodeAndCityDocs.js","names":["FieldProperties","stringProperties","PostalCodeAndCityProperties","countryCode","doc","type","status","postalCode","city","help","size"],"sources":["../../../../../../src/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { FieldProperties } from '../FieldDocs'\nimport { stringProperties } from '../String/StringDocs'\n\nexport const PostalCodeAndCityProperties: PropertiesTableProps = {\n countryCode: {\n doc:\n 'Defines which country the postal code and city is for, based on the [ISO 3166-1 alpha-2 code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) i.e. `NO`, `DE` etc. ' +\n 'Setting it to anything other than `NO` will remove the default norwegian postal code pattern. ' +\n 'You can also use the value of another field to define the countryCode, by using a path value i.e. `/myCountryCodePath`. ' +\n 'Defaults to `NO`',\n type: ['Path', 'string'],\n status: 'optional',\n },\n postalCode: {\n doc: 'Properties for the [Field.String](/uilib/extensions/forms/base-fields/String/) component for postal code.',\n type: 'object',\n status: 'required',\n },\n city: {\n doc: 'Properties for the [Field.String](/uilib/extensions/forms/base-fields/String/) component for city.',\n type: 'object',\n status: 'required',\n },\n help: FieldProperties.help,\n size: stringProperties.size,\n}\n"],"mappings":"AACA,SAASA,eAAe,QAAQ,cAAc;AAC9C,SAASC,gBAAgB,QAAQ,sBAAsB;AAEvD,OAAO,MAAMC,2BAAiD,GAAG;EAC/DC,WAAW,EAAE;IACXC,GAAG,EACD,uKAAuK,GACvK,gGAAgG,GAChG,0HAA0H,GAC1H,kBAAkB;IACpBC,IAAI,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC;IACxBC,MAAM,EAAE;EACV,CAAC;EACDC,UAAU,EAAE;IACVH,GAAG,EAAE,2GAA2G;IAChHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,IAAI,EAAE;IACJJ,GAAG,EAAE,oGAAoG;IACzGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,IAAI,EAAET,eAAe,CAACS,IAAI;EAC1BC,IAAI,EAAET,gBAAgB,CAACS;AACzB,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"PostalCodeAndCityDocs.js","names":["FieldProperties","stringProperties","PostalCodeAndCityProperties","countryCode","doc","type","status","postalCode","city","help","size"],"sources":["../../../../../../src/extensions/forms/Field/PostalCodeAndCity/PostalCodeAndCityDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { FieldProperties } from '../FieldDocs'\nimport { stringProperties } from '../String/StringDocs'\n\nexport const PostalCodeAndCityProperties: PropertiesTableProps = {\n countryCode: {\n doc:\n 'Defines which country the postal code and city is for, based on the [ISO 3166-1 alpha-2 code](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2) i.e. `NO`, `DE` etc. ' +\n 'Setting it to anything other than `NO` will remove the default norwegian postal code pattern. ' +\n 'You can also use the value of another field to define the countryCode, by using a path value i.e. `/myCountryCodePath`. ' +\n 'Defaults to `NO`.',\n type: ['Path', 'string'],\n status: 'optional',\n },\n postalCode: {\n doc: 'Properties for the [Field.String](/uilib/extensions/forms/base-fields/String/) component for postal code.',\n type: 'object',\n status: 'required',\n },\n city: {\n doc: 'Properties for the [Field.String](/uilib/extensions/forms/base-fields/String/) component for city.',\n type: 'object',\n status: 'required',\n },\n help: FieldProperties.help,\n size: stringProperties.size,\n}\n"],"mappings":"AACA,SAASA,eAAe,QAAQ,cAAc;AAC9C,SAASC,gBAAgB,QAAQ,sBAAsB;AAEvD,OAAO,MAAMC,2BAAiD,GAAG;EAC/DC,WAAW,EAAE;IACXC,GAAG,EACD,uKAAuK,GACvK,gGAAgG,GAChG,0HAA0H,GAC1H,mBAAmB;IACrBC,IAAI,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC;IACxBC,MAAM,EAAE;EACV,CAAC;EACDC,UAAU,EAAE;IACVH,GAAG,EAAE,2GAA2G;IAChHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,IAAI,EAAE;IACJJ,GAAG,EAAE,oGAAoG;IACzGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,IAAI,EAAET,eAAe,CAACS,IAAI;EAC1BC,IAAI,EAAET,gBAAgB,CAACS;AACzB,CAAC","ignoreList":[]}
@@ -85,7 +85,7 @@ declare function useFieldProvider(props?: Omit<FieldProviderProps, 'children'>):
85
85
  };
86
86
  getValueByPath: import("../../hooks/useDataValue").GetValueByPath<unknown>;
87
87
  getSourceValue: import("../../hooks/useDataValue").GetValueByPath<unknown>;
88
- setFieldEventListener: (path: string, type: "onSubmit" | "onBeforeSubmit" | "onSubmitCall" | "onSubmitRequest" | "onBeforeCommit" | "onPathChange" | "onMount", callback: (params?: {
88
+ setFieldEventListener: (path: string, type: "onSubmit" | "onBeforeSubmit" | "onSubmitCall" | "onSubmitRequest" | "onBeforeCommit" | "onPathChange" | "onMount" | "onSetFieldError", callback: (params?: {
89
89
  value: unknown;
90
90
  } | {
91
91
  preventSubmit: () => void;
@@ -107,7 +107,7 @@ declare function useFieldProvider(props?: Omit<FieldProviderProps, 'children'>):
107
107
  };
108
108
  getValueByPath: import("../../hooks/useDataValue").GetValueByPath<unknown>;
109
109
  getSourceValue: import("../../hooks/useDataValue").GetValueByPath<unknown>;
110
- setFieldEventListener: (path: string, type: "onSubmit" | "onBeforeSubmit" | "onSubmitCall" | "onSubmitRequest" | "onBeforeCommit" | "onPathChange" | "onMount", callback: (params?: {
110
+ setFieldEventListener: (path: string, type: "onSubmit" | "onBeforeSubmit" | "onSubmitCall" | "onSubmitRequest" | "onBeforeCommit" | "onPathChange" | "onMount" | "onSetFieldError", callback: (params?: {
111
111
  value: unknown;
112
112
  } | {
113
113
  preventSubmit: () => void;
@@ -129,7 +129,7 @@ declare function useFieldProvider(props?: Omit<FieldProviderProps, 'children'>):
129
129
  };
130
130
  getValueByPath: import("../../hooks/useDataValue").GetValueByPath<unknown>;
131
131
  getSourceValue: import("../../hooks/useDataValue").GetValueByPath<unknown>;
132
- setFieldEventListener: (path: string, type: "onSubmit" | "onBeforeSubmit" | "onSubmitCall" | "onSubmitRequest" | "onBeforeCommit" | "onPathChange" | "onMount", callback: (params?: {
132
+ setFieldEventListener: (path: string, type: "onSubmit" | "onBeforeSubmit" | "onSubmitCall" | "onSubmitRequest" | "onBeforeCommit" | "onPathChange" | "onMount" | "onSetFieldError", callback: (params?: {
133
133
  value: unknown;
134
134
  } | {
135
135
  preventSubmit: () => void;
@@ -50,7 +50,7 @@ export const SelectionProperties = {
50
50
  status: 'optional'
51
51
  },
52
52
  children: {
53
- doc: 'For providing Option components, and other children.',
53
+ doc: 'For providing [Field.Option](/uilib/extensions/forms/base-fields/Option/) components, and other children.',
54
54
  type: 'React.Node',
55
55
  status: 'optional'
56
56
  }
@@ -1 +1 @@
1
- {"version":3,"file":"SelectionDocs.js","names":["SelectionProperties","variant","doc","type","status","value","transformSelection","optionsLayout","width","data","dataPath","autocompleteProps","dropdownProps","size","children"],"sources":["../../../../../../src/extensions/forms/Field/Selection/SelectionDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const SelectionProperties: PropertiesTableProps = {\n variant: {\n doc: 'Choice of UI feature. Can be: `dropdown`, `autocomplete`, `button`, `radio`, `radio-list`.',\n type: 'string',\n status: 'optional',\n },\n value: {\n doc: 'Defines the `value`. When using variant `radio` or `button`, value has to be a `string`.',\n type: ['number', 'string'],\n status: 'optional',\n },\n transformSelection: {\n doc: 'Transform the displayed selection for Dropdown and Autocomplete variant. Use it to display a different value than the one in the data set. The first parameter is the props of the Option component or data item. You can return a React.Node that will be displayed in the selection.',\n type: 'function',\n status: 'optional',\n },\n optionsLayout: {\n doc: 'Layout for the list of options. Can be `horizontal` or `vertical`.',\n type: 'string',\n status: 'optional',\n },\n width: {\n doc: '`small`, `medium` or `large` for predefined standard widths, `stretch` for fill available width.',\n type: ['string', 'false'],\n status: 'optional',\n },\n data: {\n doc: 'Data to be used for the component. The object needs to have a `value` and a `title` property. Provide the Dropdown or Autocomplete data in the format documented here: [Dropdown](/uilib/components/dropdown) and [Autocomplete](/uilib/components/autocomplete) documentation.',\n type: 'array',\n status: 'optional',\n },\n dataPath: {\n doc: 'The path to the context data (Form.Handler). The context data object needs to have a `value` and a `title` property. The generated options will be placed above given JSX based children.',\n type: 'string',\n status: 'optional',\n },\n autocompleteProps: {\n doc: 'Forward any additional props (camelCase) to the [Autocomplete](/uilib/components/autocomplete/) component. `onType` will additionally provide the `value` parameter with `emptyValue` support in addition to the internal `dataContext`.',\n type: 'object',\n status: 'optional',\n },\n dropdownProps: {\n doc: 'Forward any additional props (camelCase) to the [Dropdown](/uilib/components/dropdown/) component.',\n type: 'object',\n status: 'optional',\n },\n size: {\n doc: 'The sizes you can choose is small (1.5rem), default (2rem), medium (2.5rem) and large (3rem) are supported component sizes. Defaults to default / null. Also, if you define a number like size=\"2\" then it will be forwarded as the input element attribute. Consider rather setting field sizes with [Form.Appearance](/uilib/extensions/forms/Form/Appearance/).',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'For providing Option components, and other children.',\n type: 'React.Node',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,mBAAyC,GAAG;EACvDC,OAAO,EAAE;IACPC,GAAG,EAAE,4FAA4F;IACjGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,KAAK,EAAE;IACLH,GAAG,EAAE,0FAA0F;IAC/FC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV,CAAC;EACDE,kBAAkB,EAAE;IAClBJ,GAAG,EAAE,wRAAwR;IAC7RC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDG,aAAa,EAAE;IACbL,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,KAAK,EAAE;IACLN,GAAG,EAAE,kGAAkG;IACvGC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDK,IAAI,EAAE;IACJP,GAAG,EAAE,iRAAiR;IACtRC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDM,QAAQ,EAAE;IACRR,GAAG,EAAE,2LAA2L;IAChMC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,iBAAiB,EAAE;IACjBT,GAAG,EAAE,0OAA0O;IAC/OC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,aAAa,EAAE;IACbV,GAAG,EAAE,oGAAoG;IACzGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDS,IAAI,EAAE;IACJX,GAAG,EAAE,oWAAoW;IACzWC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDU,QAAQ,EAAE;IACRZ,GAAG,EAAE,sDAAsD;IAC3DC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV;AACF,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"SelectionDocs.js","names":["SelectionProperties","variant","doc","type","status","value","transformSelection","optionsLayout","width","data","dataPath","autocompleteProps","dropdownProps","size","children"],"sources":["../../../../../../src/extensions/forms/Field/Selection/SelectionDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const SelectionProperties: PropertiesTableProps = {\n variant: {\n doc: 'Choice of UI feature. Can be: `dropdown`, `autocomplete`, `button`, `radio`, `radio-list`.',\n type: 'string',\n status: 'optional',\n },\n value: {\n doc: 'Defines the `value`. When using variant `radio` or `button`, value has to be a `string`.',\n type: ['number', 'string'],\n status: 'optional',\n },\n transformSelection: {\n doc: 'Transform the displayed selection for Dropdown and Autocomplete variant. Use it to display a different value than the one in the data set. The first parameter is the props of the Option component or data item. You can return a React.Node that will be displayed in the selection.',\n type: 'function',\n status: 'optional',\n },\n optionsLayout: {\n doc: 'Layout for the list of options. Can be `horizontal` or `vertical`.',\n type: 'string',\n status: 'optional',\n },\n width: {\n doc: '`small`, `medium` or `large` for predefined standard widths, `stretch` for fill available width.',\n type: ['string', 'false'],\n status: 'optional',\n },\n data: {\n doc: 'Data to be used for the component. The object needs to have a `value` and a `title` property. Provide the Dropdown or Autocomplete data in the format documented here: [Dropdown](/uilib/components/dropdown) and [Autocomplete](/uilib/components/autocomplete) documentation.',\n type: 'array',\n status: 'optional',\n },\n dataPath: {\n doc: 'The path to the context data (Form.Handler). The context data object needs to have a `value` and a `title` property. The generated options will be placed above given JSX based children.',\n type: 'string',\n status: 'optional',\n },\n autocompleteProps: {\n doc: 'Forward any additional props (camelCase) to the [Autocomplete](/uilib/components/autocomplete/) component. `onType` will additionally provide the `value` parameter with `emptyValue` support in addition to the internal `dataContext`.',\n type: 'object',\n status: 'optional',\n },\n dropdownProps: {\n doc: 'Forward any additional props (camelCase) to the [Dropdown](/uilib/components/dropdown/) component.',\n type: 'object',\n status: 'optional',\n },\n size: {\n doc: 'The sizes you can choose is small (1.5rem), default (2rem), medium (2.5rem) and large (3rem) are supported component sizes. Defaults to default / null. Also, if you define a number like size=\"2\" then it will be forwarded as the input element attribute. Consider rather setting field sizes with [Form.Appearance](/uilib/extensions/forms/Form/Appearance/).',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'For providing [Field.Option](/uilib/extensions/forms/base-fields/Option/) components, and other children.',\n type: 'React.Node',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,mBAAyC,GAAG;EACvDC,OAAO,EAAE;IACPC,GAAG,EAAE,4FAA4F;IACjGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,KAAK,EAAE;IACLH,GAAG,EAAE,0FAA0F;IAC/FC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV,CAAC;EACDE,kBAAkB,EAAE;IAClBJ,GAAG,EAAE,wRAAwR;IAC7RC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDG,aAAa,EAAE;IACbL,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,KAAK,EAAE;IACLN,GAAG,EAAE,kGAAkG;IACvGC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDK,IAAI,EAAE;IACJP,GAAG,EAAE,iRAAiR;IACtRC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDM,QAAQ,EAAE;IACRR,GAAG,EAAE,2LAA2L;IAChMC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,iBAAiB,EAAE;IACjBT,GAAG,EAAE,0OAA0O;IAC/OC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,aAAa,EAAE;IACbV,GAAG,EAAE,oGAAoG;IACzGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDS,IAAI,EAAE;IACJX,GAAG,EAAE,oWAAoW;IACzWC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDU,QAAQ,EAAE;IACRZ,GAAG,EAAE,2GAA2G;IAChHC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV;AACF,CAAC","ignoreList":[]}
@@ -9,12 +9,12 @@ export const stringProperties = {
9
9
  status: 'optional'
10
10
  },
11
11
  leftIcon: {
12
- doc: 'For icon at the left side of the text input.',
12
+ doc: 'For icon at the left side of the text input. Only one of `leftIcon` or `rightIcon` can be used at the same time.',
13
13
  type: 'string',
14
14
  status: 'optional'
15
15
  },
16
16
  rightIcon: {
17
- doc: 'For icon at the right side of the text input.',
17
+ doc: 'For icon at the right side of the text input. Only one of `leftIcon` or `rightIcon` can be used at the same time.',
18
18
  type: 'string',
19
19
  status: 'optional'
20
20
  },
@@ -24,7 +24,7 @@ export const stringProperties = {
24
24
  status: 'optional'
25
25
  },
26
26
  trim: {
27
- doc: 'When true, it will trim leading and trailing whitespaces on blur, triggering onChange if the value changes.',
27
+ doc: 'When true, it will trim leading and trailing whitespaces on blur, triggering `onChange` if the value changes.',
28
28
  type: 'boolean',
29
29
  status: 'optional'
30
30
  },
@@ -66,22 +66,22 @@ export const stringProperties = {
66
66
  clear: inputProperties.clear,
67
67
  keepPlaceholder: inputProperties.keep_placeholder,
68
68
  rows: {
69
- doc: 'For multiline, set how many rows of text can be shown by default. Defaults to 2.',
69
+ doc: 'To be used together with `multiline`. Set how many rows of text can be shown by default. Defaults to `2`.',
70
70
  type: 'number',
71
71
  status: 'optional'
72
72
  },
73
73
  autoresizeMaxRows: {
74
- doc: 'For multiline, set how many rows of text can be shown at max. Defaults to 6',
74
+ doc: 'To be used together with `multiline`. Set how many rows of text can be shown at max. Defaults to `6`.',
75
75
  type: 'number',
76
76
  status: 'optional'
77
77
  },
78
78
  characterCounter: {
79
- doc: "For multiline, use a number to define the displayed max length e.g. `40` or `{ max: 40, variant: 'down' }`.",
79
+ doc: "To be used together with `multiline`. Use a number to define the displayed max length e.g. `40` or `{ max: 40, variant: 'down' }`.",
80
80
  type: ['number', 'object'],
81
81
  status: 'optional'
82
82
  },
83
83
  autoresize: {
84
- doc: 'For multiline, set true to expand when writing longer texts. Defaults to true.',
84
+ doc: 'To be used together with `multiline`. Set true to expand when writing longer texts. Defaults to `true`.',
85
85
  type: 'boolean',
86
86
  status: 'optional'
87
87
  },
@@ -1 +1 @@
1
- {"version":3,"file":"StringDocs.js","names":["inputProperties","stringProperties","multiline","doc","type","status","leftIcon","rightIcon","capitalize","trim","inputMode","autoComplete","minLength","maxLength","pattern","width","size","_objectSpread","align","selectall","clear","keepPlaceholder","keep_placeholder","rows","autoresizeMaxRows","characterCounter","autoresize","inputClassName","innerRef","submitElement"],"sources":["../../../../../../src/extensions/forms/Field/String/StringDocs.ts"],"sourcesContent":["import { inputProperties } from '../../../../components/input/InputDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const stringProperties: PropertiesTableProps = {\n multiline: {\n doc: 'True to be able to write in multiple lines (switching from input-element to textarea-element).',\n type: 'boolean',\n status: 'optional',\n },\n leftIcon: {\n doc: 'For icon at the left side of the text input.',\n type: 'string',\n status: 'optional',\n },\n rightIcon: {\n doc: 'For icon at the right side of the text input.',\n type: 'string',\n status: 'optional',\n },\n capitalize: {\n doc: 'When set to true, it will capitalize the first letter of every word, transforming the rest to lowercase.',\n type: 'boolean',\n status: 'optional',\n },\n trim: {\n doc: 'When true, it will trim leading and trailing whitespaces on blur, triggering onChange if the value changes.',\n type: 'boolean',\n status: 'optional',\n },\n inputMode: {\n doc: 'Define an [inputmode](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/inputmode).',\n type: 'string',\n status: 'optional',\n },\n autoComplete: {\n doc: 'For HTML [autocomplete](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete) attributes.',\n type: ['on', 'string'],\n status: 'optional',\n },\n minLength: {\n doc: 'Validation for minimum length of the text (number of characters).',\n type: 'number',\n status: 'optional',\n },\n maxLength: {\n doc: 'Validation for maximum length of the text (number of characters).',\n type: 'number',\n status: 'optional',\n },\n pattern: {\n doc: 'Validation based on regex pattern.',\n type: 'string',\n status: 'optional',\n },\n width: {\n doc: '`false` for no width (use browser default), `small`, `medium` or `large` for predefined standard widths, `stretch` to fill available width.',\n type: ['string', 'false'],\n status: 'optional',\n },\n\n // - Input props\n size: {\n ...inputProperties.size,\n doc: `${inputProperties.size.doc} Consider rather setting field sizes with [Form.Appearance](/uilib/extensions/forms/Form/Appearance/).`,\n },\n align: inputProperties.align,\n selectall: inputProperties.selectall,\n clear: inputProperties.clear,\n keepPlaceholder: inputProperties.keep_placeholder,\n\n // - Textarea props\n rows: {\n doc: 'For multiline, set how many rows of text can be shown by default. Defaults to 2.',\n type: 'number',\n status: 'optional',\n },\n autoresizeMaxRows: {\n doc: 'For multiline, set how many rows of text can be shown at max. Defaults to 6',\n type: 'number',\n status: 'optional',\n },\n characterCounter: {\n doc: \"For multiline, use a number to define the displayed max length e.g. `40` or `{ max: 40, variant: 'down' }`.\",\n type: ['number', 'object'],\n status: 'optional',\n },\n autoresize: {\n doc: 'For multiline, set true to expand when writing longer texts. Defaults to true.',\n type: 'boolean',\n status: 'optional',\n },\n\n // - Additional props\n inputClassName: {\n doc: 'Class name set on the <input> DOM element.',\n type: 'string',\n status: 'optional',\n },\n innerRef: {\n doc: 'By providing a React.Ref we can get the internally used input element (DOM).',\n type: 'React.RefObject',\n status: 'optional',\n },\n submitElement: {\n doc: 'Accepts a React element which will show up like the \"submit button\" would do on type=\"search\".',\n type: 'React.Element',\n status: 'optional',\n },\n}\n"],"mappings":";;;AAAA,SAASA,eAAe,QAAQ,wCAAwC;AAGxE,OAAO,MAAMC,gBAAsC,GAAG;EACpDC,SAAS,EAAE;IACTC,GAAG,EAAE,gGAAgG;IACrGC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDC,QAAQ,EAAE;IACRH,GAAG,EAAE,8CAA8C;IACnDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,UAAU,EAAE;IACVL,GAAG,EAAE,0GAA0G;IAC/GC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,IAAI,EAAE;IACJN,GAAG,EAAE,6GAA6G;IAClHC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDK,SAAS,EAAE;IACTP,GAAG,EAAE,uGAAuG;IAC5GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,YAAY,EAAE;IACZR,GAAG,EAAE,gHAAgH;IACrHC,IAAI,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC;IACtBC,MAAM,EAAE;EACV,CAAC;EACDO,SAAS,EAAE;IACTT,GAAG,EAAE,mEAAmE;IACxEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAE;IACTV,GAAG,EAAE,mEAAmE;IACxEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDS,OAAO,EAAE;IACPX,GAAG,EAAE,oCAAoC;IACzCC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDU,KAAK,EAAE;IACLZ,GAAG,EAAE,6IAA6I;IAClJC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EAGDW,IAAI,EAAAC,aAAA,CAAAA,aAAA,KACCjB,eAAe,CAACgB,IAAI;IACvBb,GAAG,EAAE,GAAGH,eAAe,CAACgB,IAAI,CAACb,GAAG;EAAwG,EACzI;EACDe,KAAK,EAAElB,eAAe,CAACkB,KAAK;EAC5BC,SAAS,EAAEnB,eAAe,CAACmB,SAAS;EACpCC,KAAK,EAAEpB,eAAe,CAACoB,KAAK;EAC5BC,eAAe,EAAErB,eAAe,CAACsB,gBAAgB;EAGjDC,IAAI,EAAE;IACJpB,GAAG,EAAE,kFAAkF;IACvFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDmB,iBAAiB,EAAE;IACjBrB,GAAG,EAAE,6EAA6E;IAClFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDoB,gBAAgB,EAAE;IAChBtB,GAAG,EAAE,6GAA6G;IAClHC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV,CAAC;EACDqB,UAAU,EAAE;IACVvB,GAAG,EAAE,gFAAgF;IACrFC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EAGDsB,cAAc,EAAE;IACdxB,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDuB,QAAQ,EAAE;IACRzB,GAAG,EAAE,8EAA8E;IACnFC,IAAI,EAAE,iBAAiB;IACvBC,MAAM,EAAE;EACV,CAAC;EACDwB,aAAa,EAAE;IACb1B,GAAG,EAAE,gGAAgG;IACrGC,IAAI,EAAE,eAAe;IACrBC,MAAM,EAAE;EACV;AACF,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"StringDocs.js","names":["inputProperties","stringProperties","multiline","doc","type","status","leftIcon","rightIcon","capitalize","trim","inputMode","autoComplete","minLength","maxLength","pattern","width","size","_objectSpread","align","selectall","clear","keepPlaceholder","keep_placeholder","rows","autoresizeMaxRows","characterCounter","autoresize","inputClassName","innerRef","submitElement"],"sources":["../../../../../../src/extensions/forms/Field/String/StringDocs.ts"],"sourcesContent":["import { inputProperties } from '../../../../components/input/InputDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const stringProperties: PropertiesTableProps = {\n multiline: {\n doc: 'True to be able to write in multiple lines (switching from input-element to textarea-element).',\n type: 'boolean',\n status: 'optional',\n },\n leftIcon: {\n doc: 'For icon at the left side of the text input. Only one of `leftIcon` or `rightIcon` can be used at the same time.',\n type: 'string',\n status: 'optional',\n },\n rightIcon: {\n doc: 'For icon at the right side of the text input. Only one of `leftIcon` or `rightIcon` can be used at the same time.',\n type: 'string',\n status: 'optional',\n },\n capitalize: {\n doc: 'When set to true, it will capitalize the first letter of every word, transforming the rest to lowercase.',\n type: 'boolean',\n status: 'optional',\n },\n trim: {\n doc: 'When true, it will trim leading and trailing whitespaces on blur, triggering `onChange` if the value changes.',\n type: 'boolean',\n status: 'optional',\n },\n inputMode: {\n doc: 'Define an [inputmode](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/inputmode).',\n type: 'string',\n status: 'optional',\n },\n autoComplete: {\n doc: 'For HTML [autocomplete](https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete) attributes.',\n type: ['on', 'string'],\n status: 'optional',\n },\n minLength: {\n doc: 'Validation for minimum length of the text (number of characters).',\n type: 'number',\n status: 'optional',\n },\n maxLength: {\n doc: 'Validation for maximum length of the text (number of characters).',\n type: 'number',\n status: 'optional',\n },\n pattern: {\n doc: 'Validation based on regex pattern.',\n type: 'string',\n status: 'optional',\n },\n width: {\n doc: '`false` for no width (use browser default), `small`, `medium` or `large` for predefined standard widths, `stretch` to fill available width.',\n type: ['string', 'false'],\n status: 'optional',\n },\n\n // - Input props\n size: {\n ...inputProperties.size,\n doc: `${inputProperties.size.doc} Consider rather setting field sizes with [Form.Appearance](/uilib/extensions/forms/Form/Appearance/).`,\n },\n align: inputProperties.align,\n selectall: inputProperties.selectall,\n clear: inputProperties.clear,\n keepPlaceholder: inputProperties.keep_placeholder,\n\n // - Textarea props\n rows: {\n doc: 'To be used together with `multiline`. Set how many rows of text can be shown by default. Defaults to `2`.',\n type: 'number',\n status: 'optional',\n },\n autoresizeMaxRows: {\n doc: 'To be used together with `multiline`. Set how many rows of text can be shown at max. Defaults to `6`.',\n type: 'number',\n status: 'optional',\n },\n characterCounter: {\n doc: \"To be used together with `multiline`. Use a number to define the displayed max length e.g. `40` or `{ max: 40, variant: 'down' }`.\",\n type: ['number', 'object'],\n status: 'optional',\n },\n autoresize: {\n doc: 'To be used together with `multiline`. Set true to expand when writing longer texts. Defaults to `true`.',\n type: 'boolean',\n status: 'optional',\n },\n\n // - Additional props\n inputClassName: {\n doc: 'Class name set on the <input> DOM element.',\n type: 'string',\n status: 'optional',\n },\n innerRef: {\n doc: 'By providing a React.Ref we can get the internally used input element (DOM).',\n type: 'React.RefObject',\n status: 'optional',\n },\n submitElement: {\n doc: 'Accepts a React element which will show up like the \"submit button\" would do on type=\"search\".',\n type: 'React.Element',\n status: 'optional',\n },\n}\n"],"mappings":";;;AAAA,SAASA,eAAe,QAAQ,wCAAwC;AAGxE,OAAO,MAAMC,gBAAsC,GAAG;EACpDC,SAAS,EAAE;IACTC,GAAG,EAAE,gGAAgG;IACrGC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDC,QAAQ,EAAE;IACRH,GAAG,EAAE,kHAAkH;IACvHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,mHAAmH;IACxHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,UAAU,EAAE;IACVL,GAAG,EAAE,0GAA0G;IAC/GC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,IAAI,EAAE;IACJN,GAAG,EAAE,+GAA+G;IACpHC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDK,SAAS,EAAE;IACTP,GAAG,EAAE,uGAAuG;IAC5GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,YAAY,EAAE;IACZR,GAAG,EAAE,gHAAgH;IACrHC,IAAI,EAAE,CAAC,IAAI,EAAE,QAAQ,CAAC;IACtBC,MAAM,EAAE;EACV,CAAC;EACDO,SAAS,EAAE;IACTT,GAAG,EAAE,mEAAmE;IACxEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAE;IACTV,GAAG,EAAE,mEAAmE;IACxEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDS,OAAO,EAAE;IACPX,GAAG,EAAE,oCAAoC;IACzCC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDU,KAAK,EAAE;IACLZ,GAAG,EAAE,6IAA6I;IAClJC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EAGDW,IAAI,EAAAC,aAAA,CAAAA,aAAA,KACCjB,eAAe,CAACgB,IAAI;IACvBb,GAAG,EAAE,GAAGH,eAAe,CAACgB,IAAI,CAACb,GAAG;EAAwG,EACzI;EACDe,KAAK,EAAElB,eAAe,CAACkB,KAAK;EAC5BC,SAAS,EAAEnB,eAAe,CAACmB,SAAS;EACpCC,KAAK,EAAEpB,eAAe,CAACoB,KAAK;EAC5BC,eAAe,EAAErB,eAAe,CAACsB,gBAAgB;EAGjDC,IAAI,EAAE;IACJpB,GAAG,EAAE,2GAA2G;IAChHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDmB,iBAAiB,EAAE;IACjBrB,GAAG,EAAE,uGAAuG;IAC5GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDoB,gBAAgB,EAAE;IAChBtB,GAAG,EAAE,oIAAoI;IACzIC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV,CAAC;EACDqB,UAAU,EAAE;IACVvB,GAAG,EAAE,yGAAyG;IAC9GC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EAGDsB,cAAc,EAAE;IACdxB,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDuB,QAAQ,EAAE;IACRzB,GAAG,EAAE,8EAA8E;IACnFC,IAAI,EAAE,iBAAiB;IACvBC,MAAM,EAAE;EACV,CAAC;EACDwB,aAAa,EAAE;IACb1B,GAAG,EAAE,gGAAgG;IACrGC,IAAI,EAAE,eAAe;IACrBC,MAAM,EAAE;EACV;AACF,CAAC","ignoreList":[]}
@@ -13,7 +13,7 @@ import { useFieldProps } from '../../hooks';
13
13
  import { pickSpacingProps } from '../../../../components/flex/utils';
14
14
  import ToggleButtonGroupContext from '../../../../components/toggle-button/ToggleButtonGroupContext';
15
15
  import useTranslation from '../../hooks/useTranslation';
16
- import { useIterateItemNo } from '../../Iterate/ItemNo/useIItemNo';
16
+ import { useIterateItemNo } from '../../Iterate/ItemNo/useIterateItemNo';
17
17
  function Toggle(props) {
18
18
  const translations = useTranslation().ToggleField;
19
19
  const preparedProps = _objectSpread(_objectSpread({}, props), {}, {
@@ -1 +1 @@
1
- {"version":3,"file":"Toggle.js","names":["React","useCallback","useMemo","useRef","classnames","Checkbox","ToggleButton","ButtonRow","FieldBlock","useFieldProps","pickSpacingProps","ToggleButtonGroupContext","useTranslation","useIterateItemNo","Toggle","props","translations","ToggleField","preparedProps","_objectSpread","errorMessages","id","className","valueOn","valueOff","variant","disabled","textOn","textOff","value","size","hasError","htmlAttributes","handleChange","setDisplayValue","preventChangeRef","onClick","handleClick","args","preventDefault","_args$preventDefault","current","call","checked","event","handleCheckboxChange","handleToggleChange","cn","fieldBlockProps","forId","isOn","isOff","text","label","labelSuffix","required","labelSrOnly","labelWithItemNo","createElement","_extends","undefined","yes","no","status","onChange","on_change","role","asFieldset","bottom","Group","Provider","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Toggle/Toggle.tsx"],"sourcesContent":["import React, { useCallback, useMemo, useRef } from 'react'\nimport classnames from 'classnames'\nimport { Checkbox, ToggleButton } from '../../../../components'\nimport ButtonRow from '../../Form/ButtonRow'\nimport FieldBlock, { Props as FieldBlockProps } from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport { FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport ToggleButtonGroupContext from '../../../../components/toggle-button/ToggleButtonGroupContext'\nimport useTranslation from '../../hooks/useTranslation'\nimport { useIterateItemNo } from '../../Iterate/ItemNo/useIItemNo'\nimport type {\n CheckboxProps,\n OnChangeParams,\n OnClickParams,\n} from '../../../../components/Checkbox'\nimport type { ToggleButtonProps } from '../../../../components/ToggleButton'\n\nexport type ToggleProps = {\n valueOn: unknown\n valueOff: unknown\n variant?: 'checkbox' | 'checkbox-button' | 'button' | 'buttons'\n textOn?: string\n textOff?: string\n size?: ToggleButtonProps['size'] | CheckboxProps['size']\n\n /**\n * Checkbox props\n */\n onClick?: (\n value: unknown,\n params: { event: React.MouseEvent<HTMLInputElement> }\n ) => void\n}\n\nexport type Props = Omit<FieldProps<unknown>, 'layout' | 'layoutOptions'> &\n ToggleProps\n\nfunction Toggle(props: Props) {\n const translations = useTranslation().ToggleField\n\n const preparedProps: Props = {\n ...props,\n errorMessages: props.errorMessages,\n }\n\n const {\n id,\n className,\n valueOn,\n valueOff,\n variant,\n disabled,\n textOn,\n textOff,\n value,\n size,\n hasError,\n htmlAttributes,\n handleChange,\n setDisplayValue,\n } = useFieldProps(preparedProps)\n\n const preventChangeRef = useRef(false)\n\n const onClick = preparedProps?.onClick\n const handleClick = useCallback(\n (args: OnClickParams) => {\n const preventDefault = () => {\n preventChangeRef.current = true\n args.preventDefault?.()\n }\n\n if (preventChangeRef.current) {\n args.checked = !args.checked\n preventChangeRef.current = false\n }\n\n const event = {\n ...args,\n preventDefault,\n }\n onClick?.(args.checked ? valueOn : valueOff, event)\n },\n [onClick, valueOff, valueOn]\n )\n const handleCheckboxChange = useCallback(\n (args: OnChangeParams) => {\n handleChange?.(args.checked ? valueOn : valueOff, args)\n },\n [handleChange, valueOn, valueOff]\n )\n const handleToggleChange = useCallback(\n ({ value }) => {\n handleChange?.(value === 'on' ? valueOn : valueOff)\n },\n [handleChange, valueOn, valueOff]\n )\n\n const cn = classnames('dnb-forms-field-toggle', className)\n\n const fieldBlockProps: FieldBlockProps = {\n forId: id,\n className: cn,\n disabled,\n ...pickSpacingProps(props),\n }\n\n const isOn = value === valueOn\n const isOff = value === valueOff\n\n useMemo(() => {\n const text = isOn ? textOn : textOff\n if (text) {\n setDisplayValue(text)\n }\n }, [isOn, setDisplayValue, textOff, textOn])\n\n const { label, labelSuffix, required, labelSrOnly } = props\n const labelWithItemNo = useIterateItemNo({\n label,\n labelSuffix,\n required,\n })\n\n switch (variant) {\n default:\n case 'checkbox':\n return (\n <FieldBlock {...fieldBlockProps} label={undefined}>\n <Checkbox\n id={id}\n className={cn}\n label={\n labelWithItemNo ??\n (isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no)\n }\n labelSrOnly={labelSrOnly}\n checked={isOn}\n disabled={disabled}\n size={size !== 'small' ? size : undefined}\n status={hasError ? 'error' : undefined}\n onChange={handleCheckboxChange}\n onClick={handleClick}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n value={value ? 'true' : 'false'}\n size={size}\n on_change={handleCheckboxChange}\n role=\"checkbox\"\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'buttons':\n return (\n <FieldBlock {...fieldBlockProps} asFieldset>\n <ButtonRow bottom=\"x-small\">\n <ToggleButton.Group role=\"radiogroup\">\n <ToggleButtonGroupContext.Provider\n value={{\n value: isOn ? 'on' : isOff ? 'off' : null, // use \"null\" to reset the value\n onChange: handleToggleChange,\n status: hasError ? 'error' : undefined,\n disabled,\n size,\n }}\n >\n <ToggleButton\n text={textOn ?? translations.yes}\n value=\"on\"\n role=\"radio\"\n {...htmlAttributes}\n />\n <ToggleButton\n text={textOff ?? translations.no}\n value=\"off\"\n role=\"radio\"\n {...htmlAttributes}\n />\n </ToggleButtonGroupContext.Provider>\n </ToggleButton.Group>\n </ButtonRow>\n </FieldBlock>\n )\n case 'checkbox-button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n variant=\"checkbox\"\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n value={value ? 'true' : 'false'}\n size={size}\n on_change={handleCheckboxChange}\n role=\"checkbox\"\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n }\n}\n\nToggle._supportsSpacingProps = true\nexport default Toggle\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"Toggle.js","names":["React","useCallback","useMemo","useRef","classnames","Checkbox","ToggleButton","ButtonRow","FieldBlock","useFieldProps","pickSpacingProps","ToggleButtonGroupContext","useTranslation","useIterateItemNo","Toggle","props","translations","ToggleField","preparedProps","_objectSpread","errorMessages","id","className","valueOn","valueOff","variant","disabled","textOn","textOff","value","size","hasError","htmlAttributes","handleChange","setDisplayValue","preventChangeRef","onClick","handleClick","args","preventDefault","_args$preventDefault","current","call","checked","event","handleCheckboxChange","handleToggleChange","cn","fieldBlockProps","forId","isOn","isOff","text","label","labelSuffix","required","labelSrOnly","labelWithItemNo","createElement","_extends","undefined","yes","no","status","onChange","on_change","role","asFieldset","bottom","Group","Provider","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Field/Toggle/Toggle.tsx"],"sourcesContent":["import React, { useCallback, useMemo, useRef } from 'react'\nimport classnames from 'classnames'\nimport { Checkbox, ToggleButton } from '../../../../components'\nimport ButtonRow from '../../Form/ButtonRow'\nimport FieldBlock, { Props as FieldBlockProps } from '../../FieldBlock'\nimport { useFieldProps } from '../../hooks'\nimport { FieldProps } from '../../types'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport ToggleButtonGroupContext from '../../../../components/toggle-button/ToggleButtonGroupContext'\nimport useTranslation from '../../hooks/useTranslation'\nimport { useIterateItemNo } from '../../Iterate/ItemNo/useIterateItemNo'\nimport type {\n CheckboxProps,\n OnChangeParams,\n OnClickParams,\n} from '../../../../components/Checkbox'\nimport type { ToggleButtonProps } from '../../../../components/ToggleButton'\n\nexport type ToggleProps = {\n valueOn: unknown\n valueOff: unknown\n variant?: 'checkbox' | 'checkbox-button' | 'button' | 'buttons'\n textOn?: string\n textOff?: string\n size?: ToggleButtonProps['size'] | CheckboxProps['size']\n\n /**\n * Checkbox props\n */\n onClick?: (\n value: unknown,\n params: { event: React.MouseEvent<HTMLInputElement> }\n ) => void\n}\n\nexport type Props = Omit<FieldProps<unknown>, 'layout' | 'layoutOptions'> &\n ToggleProps\n\nfunction Toggle(props: Props) {\n const translations = useTranslation().ToggleField\n\n const preparedProps: Props = {\n ...props,\n errorMessages: props.errorMessages,\n }\n\n const {\n id,\n className,\n valueOn,\n valueOff,\n variant,\n disabled,\n textOn,\n textOff,\n value,\n size,\n hasError,\n htmlAttributes,\n handleChange,\n setDisplayValue,\n } = useFieldProps(preparedProps)\n\n const preventChangeRef = useRef(false)\n\n const onClick = preparedProps?.onClick\n const handleClick = useCallback(\n (args: OnClickParams) => {\n const preventDefault = () => {\n preventChangeRef.current = true\n args.preventDefault?.()\n }\n\n if (preventChangeRef.current) {\n args.checked = !args.checked\n preventChangeRef.current = false\n }\n\n const event = {\n ...args,\n preventDefault,\n }\n onClick?.(args.checked ? valueOn : valueOff, event)\n },\n [onClick, valueOff, valueOn]\n )\n const handleCheckboxChange = useCallback(\n (args: OnChangeParams) => {\n handleChange?.(args.checked ? valueOn : valueOff, args)\n },\n [handleChange, valueOn, valueOff]\n )\n const handleToggleChange = useCallback(\n ({ value }) => {\n handleChange?.(value === 'on' ? valueOn : valueOff)\n },\n [handleChange, valueOn, valueOff]\n )\n\n const cn = classnames('dnb-forms-field-toggle', className)\n\n const fieldBlockProps: FieldBlockProps = {\n forId: id,\n className: cn,\n disabled,\n ...pickSpacingProps(props),\n }\n\n const isOn = value === valueOn\n const isOff = value === valueOff\n\n useMemo(() => {\n const text = isOn ? textOn : textOff\n if (text) {\n setDisplayValue(text)\n }\n }, [isOn, setDisplayValue, textOff, textOn])\n\n const { label, labelSuffix, required, labelSrOnly } = props\n const labelWithItemNo = useIterateItemNo({\n label,\n labelSuffix,\n required,\n })\n\n switch (variant) {\n default:\n case 'checkbox':\n return (\n <FieldBlock {...fieldBlockProps} label={undefined}>\n <Checkbox\n id={id}\n className={cn}\n label={\n labelWithItemNo ??\n (isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no)\n }\n labelSrOnly={labelSrOnly}\n checked={isOn}\n disabled={disabled}\n size={size !== 'small' ? size : undefined}\n status={hasError ? 'error' : undefined}\n onChange={handleCheckboxChange}\n onClick={handleClick}\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n value={value ? 'true' : 'false'}\n size={size}\n on_change={handleCheckboxChange}\n role=\"checkbox\"\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n case 'buttons':\n return (\n <FieldBlock {...fieldBlockProps} asFieldset>\n <ButtonRow bottom=\"x-small\">\n <ToggleButton.Group role=\"radiogroup\">\n <ToggleButtonGroupContext.Provider\n value={{\n value: isOn ? 'on' : isOff ? 'off' : null, // use \"null\" to reset the value\n onChange: handleToggleChange,\n status: hasError ? 'error' : undefined,\n disabled,\n size,\n }}\n >\n <ToggleButton\n text={textOn ?? translations.yes}\n value=\"on\"\n role=\"radio\"\n {...htmlAttributes}\n />\n <ToggleButton\n text={textOff ?? translations.no}\n value=\"off\"\n role=\"radio\"\n {...htmlAttributes}\n />\n </ToggleButtonGroupContext.Provider>\n </ToggleButton.Group>\n </ButtonRow>\n </FieldBlock>\n )\n case 'checkbox-button':\n return (\n <FieldBlock {...fieldBlockProps}>\n <ToggleButton\n id={id}\n variant=\"checkbox\"\n text={\n isOn\n ? textOn ?? translations.yes\n : textOff ?? translations.no\n }\n checked={isOn}\n disabled={disabled}\n status={hasError ? 'error' : undefined}\n value={value ? 'true' : 'false'}\n size={size}\n on_change={handleCheckboxChange}\n role=\"checkbox\"\n {...htmlAttributes}\n />\n </FieldBlock>\n )\n }\n}\n\nToggle._supportsSpacingProps = true\nexport default Toggle\n"],"mappings":"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","ignoreList":[]}
@@ -3,7 +3,7 @@ import { UploadFile, UploadFileNative, UploadProps } from '../../../../component
3
3
  import { SpacingProps } from '../../../../shared/types';
4
4
  export type { UploadFile, UploadFileNative };
5
5
  export type UploadValue = Array<UploadFile | UploadFileNative>;
6
- export type Props = Omit<FieldProps<UploadValue, UploadValue | undefined>, 'name'> & SpacingProps & Pick<Partial<UploadProps>, 'title' | 'text' | 'acceptedFileTypes' | 'filesAmountLimit' | 'fileMaxSize' | 'onFileDelete' | 'onFileClick' | 'skeleton' | 'download' | 'allowDuplicates' | 'disableDragAndDrop'> & {
6
+ export type Props = Omit<FieldProps<UploadValue, UploadValue | undefined>, 'layout' | 'layoutOptions' | 'onBlurValidator' | 'onChangeValidator' | 'contentWidth' | 'labelSize' | 'labelDescriptionInline' | 'labelSrOnly' | 'labelSize' | 'labelSuffix'> & SpacingProps & Pick<Partial<UploadProps>, 'title' | 'text' | 'acceptedFileTypes' | 'filesAmountLimit' | 'fileMaxSize' | 'onFileDelete' | 'onFileClick' | 'skeleton' | 'download' | 'allowDuplicates' | 'disableDragAndDrop'> & {
7
7
  fileHandler?: (newFiles: UploadValue) => UploadValue | Promise<UploadValue>;
8
8
  width?: 'large' | 'stretch';
9
9
  };
@@ -3,7 +3,7 @@
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
5
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
6
- const _excluded = ["id", "className", "width", "value", "label", "labelDescription", "help", "htmlAttributes", "handleChange", "handleFocus", "handleBlur", "fileHandler"];
6
+ const _excluded = ["id", "className", "width", "value", "label", "labelDescription", "help", "htmlAttributes", "disabled", "handleChange", "handleFocus", "handleBlur", "fileHandler"];
7
7
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
8
8
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
9
9
  import React, { useCallback, useEffect, useMemo, useRef } from 'react';
@@ -66,6 +66,7 @@ function UploadComponent(props) {
66
66
  labelDescription,
67
67
  help,
68
68
  htmlAttributes,
69
+ disabled,
69
70
  handleChange,
70
71
  handleFocus,
71
72
  handleBlur,
@@ -162,6 +163,7 @@ function UploadComponent(props) {
162
163
  download: download,
163
164
  allowDuplicates: allowDuplicates,
164
165
  disableDragAndDrop: disableDragAndDrop,
166
+ disabled: disabled,
165
167
  fileMaxSize: fileMaxSize,
166
168
  skeleton: skeleton,
167
169
  onChange: changeHandler,
@@ -1 +1 @@
1
- {"version":3,"file":"Upload.js","names":["React","useCallback","useEffect","useMemo","useRef","classnames","FieldBlock","useFieldProps","useTranslation","useFormsTranslation","Upload","useUpload","pickSpacingProps","HelpButtonInline","HelpButtonInlineContent","useSharedTranslation","FormError","validateRequired","value","required","isChanged","error","hasError","some","file","errorMessage","hasFiles","length","undefined","UploadComponent","props","sharedTr","formsTr","errorMessages","errorRequired","fromInput","forEach","item","index","_item$file","name","preparedProps","_objectSpread","toInput","transformFiles","_useFieldProps","executeOnChangeRegardlessOfError","id","className","width","widthProp","label","labelDescription","help","htmlAttributes","handleChange","handleFocus","handleBlur","fileHandler","rest","_objectWithoutProperties","_excluded","title","text","acceptedFileTypes","filesAmountLimit","fileMaxSize","skeleton","onFileDelete","onFileClick","download","allowDuplicates","disableDragAndDrop","files","setFiles","filesRef","current","handleChangeAsync","_filesRef$current","existingFileIds","map","existingFiles","filter","includes","newFiles","newValidFiles","newFilesLoading","isLoading","incomingFiles","_incomingFiles$filter","incomingFileObj","foundIndex","findIndex","newFile","push","indexOfFirstNewFile","updatedFiles","slice","changeHandler","fieldBlockProps","forId","labelSrOnly","createElement","_extends","onChange","Fragment","contentId","left","roundedCorner","_supportsSpacingProps","Array","isArray","File","_lastModified","_item$file2","_type","_item$file3","lastModified","type"],"sources":["../../../../../../src/extensions/forms/Field/Upload/Upload.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useRef } from 'react'\nimport classnames from 'classnames'\nimport FieldBlock, {\n Props as FieldBlockProps,\n FieldBlockWidth,\n} from '../../FieldBlock'\nimport {\n useFieldProps,\n useTranslation as useFormsTranslation,\n} from '../../hooks'\nimport { FieldProps } from '../../types'\nimport Upload, {\n UploadFile,\n UploadFileNative,\n UploadProps,\n} from '../../../../components/Upload'\nimport useUpload from '../../../../components/upload/useUpload'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n} from '../../../../components/help-button/HelpButtonInline'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport { SpacingProps } from '../../../../shared/types'\nimport { FormError } from '../../utils'\n\nexport type { UploadFile, UploadFileNative }\nexport type UploadValue = Array<UploadFile | UploadFileNative>\nexport type Props = Omit<\n FieldProps<UploadValue, UploadValue | undefined>,\n 'name'\n> &\n SpacingProps &\n Pick<\n Partial<UploadProps>,\n | 'title'\n | 'text'\n | 'acceptedFileTypes'\n | 'filesAmountLimit'\n | 'fileMaxSize'\n | 'onFileDelete'\n | 'onFileClick'\n | 'skeleton'\n | 'download'\n | 'allowDuplicates'\n | 'disableDragAndDrop'\n > & {\n fileHandler?: (\n newFiles: UploadValue\n ) => UploadValue | Promise<UploadValue>\n width?: 'large' | 'stretch'\n }\n\nconst validateRequired = (\n value: UploadValue,\n { required, isChanged, error }\n) => {\n const hasError = value?.some((file) => file.errorMessage)\n if (hasError) {\n return new FormError('Upload.errorInvalidFiles')\n }\n\n const hasFiles = value?.length > 0\n if (required && ((!isChanged && !hasFiles) || !hasFiles)) {\n return error\n }\n\n return undefined\n}\n\nfunction UploadComponent(props: Props) {\n const sharedTr = useSharedTranslation().Upload\n const formsTr = useFormsTranslation().Upload\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': formsTr.errorRequired,\n }),\n [formsTr.errorRequired]\n )\n\n const fromInput = useCallback((value: UploadValue) => {\n value.forEach((item, index) => {\n if (!item) {\n return\n }\n\n value[index] = item\n\n // Store the name in the value, to support session storage (serialization)\n value[index]['name'] = item['name'] || item.file?.name\n })\n\n return value\n }, [])\n\n const preparedProps = {\n errorMessages,\n validateRequired,\n fromInput,\n toInput: transformFiles,\n ...props,\n }\n\n const {\n id,\n className,\n width: widthProp = 'stretch',\n value,\n label,\n labelDescription,\n help,\n htmlAttributes,\n handleChange,\n handleFocus,\n handleBlur,\n fileHandler,\n ...rest\n } = useFieldProps(preparedProps, {\n executeOnChangeRegardlessOfError: true,\n })\n\n // Upload props\n const {\n title = sharedTr.title,\n text = sharedTr.text,\n acceptedFileTypes = ['pdf', 'png', 'jpg', 'jpeg'],\n filesAmountLimit = 100,\n fileMaxSize = 5,\n skeleton,\n onFileDelete,\n onFileClick,\n download,\n allowDuplicates,\n disableDragAndDrop,\n } = rest\n\n const { files, setFiles } = useUpload(id)\n\n const filesRef = useRef<Array<UploadFile>>()\n\n useEffect(() => {\n filesRef.current = files\n }, [files])\n\n useEffect(() => {\n setFiles(value)\n }, [setFiles, value])\n\n const handleChangeAsync = useCallback(\n async (files: UploadValue) => {\n // Filter out existing files\n const existingFileIds =\n filesRef.current?.map((file) => file.id) || []\n const existingFiles = files.filter((file) =>\n existingFileIds.includes(file.id)\n )\n const newFiles = files.filter(\n (file) => !existingFileIds.includes(file.id)\n )\n const newValidFiles = newFiles.filter((file) => !file.errorMessage)\n\n if (newValidFiles.length > 0) {\n // Set loading\n const newFilesLoading = newFiles.map((file) => ({\n ...file,\n isLoading: !file.errorMessage,\n }))\n setFiles([...filesRef.current, ...newFilesLoading])\n\n const incomingFiles = await fileHandler(newValidFiles)\n\n if (!incomingFiles) {\n setFiles(existingFiles)\n handleChange(existingFiles)\n } else {\n // merge incoming files into existing order of newFiles.\n incomingFiles.forEach((file) => {\n const incomingFileObj = {\n ...file,\n isLoading: false,\n }\n const foundIndex = newFilesLoading.findIndex(\n (newFile) => newFile.isLoading\n )\n if (foundIndex >= 0) {\n newFilesLoading[foundIndex] = incomingFileObj\n } else {\n // if there's more files incoming than there's files loading (edge case), add them to end of array.\n newFilesLoading.push(incomingFileObj)\n }\n })\n\n const indexOfFirstNewFile = filesRef.current.findIndex(\n ({ id }) => id === newFiles[0].id\n )\n\n const updatedFiles = [\n ...filesRef.current.slice(0, indexOfFirstNewFile),\n ...(incomingFiles?.filter((file) => file != null) ?? []),\n ...filesRef.current.slice(\n indexOfFirstNewFile + incomingFiles.length\n ),\n ]\n setFiles(updatedFiles)\n handleChange(updatedFiles)\n }\n } else {\n handleChange(files)\n }\n },\n [setFiles, fileHandler, handleChange]\n )\n\n const changeHandler = useCallback(\n ({ files }: { files: UploadValue }) => {\n // Prevents the form-status from showing up\n handleBlur()\n handleFocus()\n\n if (fileHandler) {\n handleChangeAsync(files)\n } else {\n handleChange(files)\n }\n },\n [handleBlur, handleFocus, fileHandler, handleChangeAsync, handleChange]\n )\n\n const width = widthProp as FieldBlockWidth\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: `${id}-input`,\n labelSrOnly: true,\n className: classnames('dnb-forms-field-upload', className),\n width,\n help: undefined,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <Upload\n id={id}\n acceptedFileTypes={acceptedFileTypes}\n filesAmountLimit={filesAmountLimit}\n download={download}\n allowDuplicates={allowDuplicates}\n disableDragAndDrop={disableDragAndDrop}\n fileMaxSize={fileMaxSize}\n skeleton={skeleton}\n onChange={changeHandler}\n onFileDelete={onFileDelete}\n onFileClick={onFileClick}\n title={label ?? title}\n text={\n help ? (\n <>\n {labelDescription ?? text}\n <HelpButtonInline\n contentId={`${id}-help`}\n left={text ? 'x-small' : false}\n help={help}\n />\n </>\n ) : (\n labelDescription ?? text\n )\n }\n {...htmlAttributes}\n >\n {help && (\n <HelpButtonInlineContent\n contentId={`${id}-help`}\n help={help}\n roundedCorner={false}\n />\n )}\n </Upload>\n </FieldBlock>\n )\n}\n\nexport default UploadComponent\n\nUploadComponent._supportsSpacingProps = true\n\nexport function transformFiles(value: UploadValue) {\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return undefined\n }\n\n value.map((item) => {\n if (item?.file && !(item.file instanceof File)) {\n // To support session storage, we recreated the file blob.\n item['file'] = new File([], item['name'] || item?.file['name'], {\n lastModified: (item.file as File)?.lastModified ?? 0,\n type: (item.file as File)?.type ?? '',\n })\n }\n return item\n })\n }\n\n return value\n}\n"],"mappings":";;;;;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,SAAS,EAAEC,OAAO,EAAEC,MAAM,QAAQ,OAAO;AACtE,OAAOC,UAAU,MAAM,YAAY;AACnC,OAAOC,UAAU,MAGV,kBAAkB;AACzB,SACEC,aAAa,EACbC,cAAc,IAAIC,mBAAmB,QAChC,aAAa;AAEpB,OAAOC,MAAM,MAIN,+BAA+B;AACtC,OAAOC,SAAS,MAAM,yCAAyC;AAC/D,SAASC,gBAAgB,QAAQ,mCAAmC;AACpE,OAAOC,gBAAgB,IACrBC,uBAAuB,QAClB,qDAAqD;AAC5D,SAASN,cAAc,IAAIO,oBAAoB,QAAQ,oBAAoB;AAE3E,SAASC,SAAS,QAAQ,aAAa;AA6BvC,MAAMC,gBAAgB,GAAGA,CACvBC,KAAkB,EAClB;EAAEC,QAAQ;EAAEC,SAAS;EAAEC;AAAM,CAAC,KAC3B;EACH,MAAMC,QAAQ,GAAGJ,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEK,IAAI,CAAEC,IAAI,IAAKA,IAAI,CAACC,YAAY,CAAC;EACzD,IAAIH,QAAQ,EAAE;IACZ,OAAO,IAAIN,SAAS,CAAC,0BAA0B,CAAC;EAClD;EAEA,MAAMU,QAAQ,GAAG,CAAAR,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAES,MAAM,IAAG,CAAC;EAClC,IAAIR,QAAQ,KAAM,CAACC,SAAS,IAAI,CAACM,QAAQ,IAAK,CAACA,QAAQ,CAAC,EAAE;IACxD,OAAOL,KAAK;EACd;EAEA,OAAOO,SAAS;AAClB,CAAC;AAED,SAASC,eAAeA,CAACC,KAAY,EAAE;EACrC,MAAMC,QAAQ,GAAGhB,oBAAoB,CAAC,CAAC,CAACL,MAAM;EAC9C,MAAMsB,OAAO,GAAGvB,mBAAmB,CAAC,CAAC,CAACC,MAAM;EAE5C,MAAMuB,aAAa,GAAG9B,OAAO,CAC3B,OAAO;IACL,qBAAqB,EAAE6B,OAAO,CAACE;EACjC,CAAC,CAAC,EACF,CAACF,OAAO,CAACE,aAAa,CACxB,CAAC;EAED,MAAMC,SAAS,GAAGlC,WAAW,CAAEiB,KAAkB,IAAK;IACpDA,KAAK,CAACkB,OAAO,CAAC,CAACC,IAAI,EAAEC,KAAK,KAAK;MAAA,IAAAC,UAAA;MAC7B,IAAI,CAACF,IAAI,EAAE;QACT;MACF;MAEAnB,KAAK,CAACoB,KAAK,CAAC,GAAGD,IAAI;MAGnBnB,KAAK,CAACoB,KAAK,CAAC,CAAC,MAAM,CAAC,GAAGD,IAAI,CAAC,MAAM,CAAC,MAAAE,UAAA,GAAIF,IAAI,CAACb,IAAI,cAAAe,UAAA,uBAATA,UAAA,CAAWC,IAAI;IACxD,CAAC,CAAC;IAEF,OAAOtB,KAAK;EACd,CAAC,EAAE,EAAE,CAAC;EAEN,MAAMuB,aAAa,GAAAC,aAAA;IACjBT,aAAa;IACbhB,gBAAgB;IAChBkB,SAAS;IACTQ,OAAO,EAAEC;EAAc,GACpBd,KAAK,CACT;EAED,MAAAe,cAAA,GAcItC,aAAa,CAACkC,aAAa,EAAE;MAC/BK,gCAAgC,EAAE;IACpC,CAAC,CAAC;IAhBI;MACJC,EAAE;MACFC,SAAS;MACTC,KAAK,EAAEC,SAAS,GAAG,SAAS;MAC5BhC,KAAK;MACLiC,KAAK;MACLC,gBAAgB;MAChBC,IAAI;MACJC,cAAc;MACdC,YAAY;MACZC,WAAW;MACXC,UAAU;MACVC;IAEF,CAAC,GAAAb,cAAA;IADIc,IAAI,GAAAC,wBAAA,CAAAf,cAAA,EAAAgB,SAAA;EAMT,MAAM;IACJC,KAAK,GAAG/B,QAAQ,CAAC+B,KAAK;IACtBC,IAAI,GAAGhC,QAAQ,CAACgC,IAAI;IACpBC,iBAAiB,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,CAAC;IACjDC,gBAAgB,GAAG,GAAG;IACtBC,WAAW,GAAG,CAAC;IACfC,QAAQ;IACRC,YAAY;IACZC,WAAW;IACXC,QAAQ;IACRC,eAAe;IACfC;EACF,CAAC,GAAGb,IAAI;EAER,MAAM;IAAEc,KAAK;IAAEC;EAAS,CAAC,GAAG/D,SAAS,CAACoC,EAAE,CAAC;EAEzC,MAAM4B,QAAQ,GAAGvE,MAAM,CAAoB,CAAC;EAE5CF,SAAS,CAAC,MAAM;IACdyE,QAAQ,CAACC,OAAO,GAAGH,KAAK;EAC1B,CAAC,EAAE,CAACA,KAAK,CAAC,CAAC;EAEXvE,SAAS,CAAC,MAAM;IACdwE,QAAQ,CAACxD,KAAK,CAAC;EACjB,CAAC,EAAE,CAACwD,QAAQ,EAAExD,KAAK,CAAC,CAAC;EAErB,MAAM2D,iBAAiB,GAAG5E,WAAW,CACnC,MAAOwE,KAAkB,IAAK;IAAA,IAAAK,iBAAA;IAE5B,MAAMC,eAAe,GACnB,EAAAD,iBAAA,GAAAH,QAAQ,CAACC,OAAO,cAAAE,iBAAA,uBAAhBA,iBAAA,CAAkBE,GAAG,CAAExD,IAAI,IAAKA,IAAI,CAACuB,EAAE,CAAC,KAAI,EAAE;IAChD,MAAMkC,aAAa,GAAGR,KAAK,CAACS,MAAM,CAAE1D,IAAI,IACtCuD,eAAe,CAACI,QAAQ,CAAC3D,IAAI,CAACuB,EAAE,CAClC,CAAC;IACD,MAAMqC,QAAQ,GAAGX,KAAK,CAACS,MAAM,CAC1B1D,IAAI,IAAK,CAACuD,eAAe,CAACI,QAAQ,CAAC3D,IAAI,CAACuB,EAAE,CAC7C,CAAC;IACD,MAAMsC,aAAa,GAAGD,QAAQ,CAACF,MAAM,CAAE1D,IAAI,IAAK,CAACA,IAAI,CAACC,YAAY,CAAC;IAEnE,IAAI4D,aAAa,CAAC1D,MAAM,GAAG,CAAC,EAAE;MAE5B,MAAM2D,eAAe,GAAGF,QAAQ,CAACJ,GAAG,CAAExD,IAAI,IAAAkB,aAAA,CAAAA,aAAA,KACrClB,IAAI;QACP+D,SAAS,EAAE,CAAC/D,IAAI,CAACC;MAAY,EAC7B,CAAC;MACHiD,QAAQ,CAAC,CAAC,GAAGC,QAAQ,CAACC,OAAO,EAAE,GAAGU,eAAe,CAAC,CAAC;MAEnD,MAAME,aAAa,GAAG,MAAM9B,WAAW,CAAC2B,aAAa,CAAC;MAEtD,IAAI,CAACG,aAAa,EAAE;QAClBd,QAAQ,CAACO,aAAa,CAAC;QACvB1B,YAAY,CAAC0B,aAAa,CAAC;MAC7B,CAAC,MAAM;QAAA,IAAAQ,qBAAA;QAELD,aAAa,CAACpD,OAAO,CAAEZ,IAAI,IAAK;UAC9B,MAAMkE,eAAe,GAAAhD,aAAA,CAAAA,aAAA,KAChBlB,IAAI;YACP+D,SAAS,EAAE;UAAK,EACjB;UACD,MAAMI,UAAU,GAAGL,eAAe,CAACM,SAAS,CACzCC,OAAO,IAAKA,OAAO,CAACN,SACvB,CAAC;UACD,IAAII,UAAU,IAAI,CAAC,EAAE;YACnBL,eAAe,CAACK,UAAU,CAAC,GAAGD,eAAe;UAC/C,CAAC,MAAM;YAELJ,eAAe,CAACQ,IAAI,CAACJ,eAAe,CAAC;UACvC;QACF,CAAC,CAAC;QAEF,MAAMK,mBAAmB,GAAGpB,QAAQ,CAACC,OAAO,CAACgB,SAAS,CACpD,CAAC;UAAE7C;QAAG,CAAC,KAAKA,EAAE,KAAKqC,QAAQ,CAAC,CAAC,CAAC,CAACrC,EACjC,CAAC;QAED,MAAMiD,YAAY,GAAG,CACnB,GAAGrB,QAAQ,CAACC,OAAO,CAACqB,KAAK,CAAC,CAAC,EAAEF,mBAAmB,CAAC,EACjD,KAAAN,qBAAA,GAAID,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEN,MAAM,CAAE1D,IAAI,IAAKA,IAAI,IAAI,IAAI,CAAC,cAAAiE,qBAAA,cAAAA,qBAAA,GAAI,EAAE,CAAC,EACxD,GAAGd,QAAQ,CAACC,OAAO,CAACqB,KAAK,CACvBF,mBAAmB,GAAGP,aAAa,CAAC7D,MACtC,CAAC,CACF;QACD+C,QAAQ,CAACsB,YAAY,CAAC;QACtBzC,YAAY,CAACyC,YAAY,CAAC;MAC5B;IACF,CAAC,MAAM;MACLzC,YAAY,CAACkB,KAAK,CAAC;IACrB;EACF,CAAC,EACD,CAACC,QAAQ,EAAEhB,WAAW,EAAEH,YAAY,CACtC,CAAC;EAED,MAAM2C,aAAa,GAAGjG,WAAW,CAC/B,CAAC;IAAEwE;EAA8B,CAAC,KAAK;IAErChB,UAAU,CAAC,CAAC;IACZD,WAAW,CAAC,CAAC;IAEb,IAAIE,WAAW,EAAE;MACfmB,iBAAiB,CAACJ,KAAK,CAAC;IAC1B,CAAC,MAAM;MACLlB,YAAY,CAACkB,KAAK,CAAC;IACrB;EACF,CAAC,EACD,CAAChB,UAAU,EAAED,WAAW,EAAEE,WAAW,EAAEmB,iBAAiB,EAAEtB,YAAY,CACxE,CAAC;EAED,MAAMN,KAAK,GAAGC,SAA4B;EAC1C,MAAMiD,eAAgC,GAAAzD,aAAA;IACpCK,EAAE;IACFqD,KAAK,EAAE,GAAGrD,EAAE,QAAQ;IACpBsD,WAAW,EAAE,IAAI;IACjBrD,SAAS,EAAE3C,UAAU,CAAC,wBAAwB,EAAE2C,SAAS,CAAC;IAC1DC,KAAK;IACLI,IAAI,EAAEzB;EAAS,GACZhB,gBAAgB,CAACkB,KAAK,CAAC,CAC3B;EAED,OACE9B,KAAA,CAAAsG,aAAA,CAAChG,UAAU,EAAK6F,eAAe,EAC7BnG,KAAA,CAAAsG,aAAA,CAAC5F,MAAM,EAAA6F,QAAA;IACLxD,EAAE,EAAEA,EAAG;IACPiB,iBAAiB,EAAEA,iBAAkB;IACrCC,gBAAgB,EAAEA,gBAAiB;IACnCK,QAAQ,EAAEA,QAAS;IACnBC,eAAe,EAAEA,eAAgB;IACjCC,kBAAkB,EAAEA,kBAAmB;IACvCN,WAAW,EAAEA,WAAY;IACzBC,QAAQ,EAAEA,QAAS;IACnBqC,QAAQ,EAAEN,aAAc;IACxB9B,YAAY,EAAEA,YAAa;IAC3BC,WAAW,EAAEA,WAAY;IACzBP,KAAK,EAAEX,KAAK,aAALA,KAAK,cAALA,KAAK,GAAIW,KAAM;IACtBC,IAAI,EACFV,IAAI,GACFrD,KAAA,CAAAsG,aAAA,CAAAtG,KAAA,CAAAyG,QAAA,QACGrD,gBAAgB,aAAhBA,gBAAgB,cAAhBA,gBAAgB,GAAIW,IAAI,EACzB/D,KAAA,CAAAsG,aAAA,CAACzF,gBAAgB;MACf6F,SAAS,EAAE,GAAG3D,EAAE,OAAQ;MACxB4D,IAAI,EAAE5C,IAAI,GAAG,SAAS,GAAG,KAAM;MAC/BV,IAAI,EAAEA;IAAK,CACZ,CACD,CAAC,GAEHD,gBAAgB,aAAhBA,gBAAgB,cAAhBA,gBAAgB,GAAIW;EAEvB,GACGT,cAAc,GAEjBD,IAAI,IACHrD,KAAA,CAAAsG,aAAA,CAACxF,uBAAuB;IACtB4F,SAAS,EAAE,GAAG3D,EAAE,OAAQ;IACxBM,IAAI,EAAEA,IAAK;IACXuD,aAAa,EAAE;EAAM,CACtB,CAEG,CACE,CAAC;AAEjB;AAEA,eAAe/E,eAAe;AAE9BA,eAAe,CAACgF,qBAAqB,GAAG,IAAI;AAE5C,OAAO,SAASjE,cAAcA,CAAC1B,KAAkB,EAAE;EACjD,IAAI4F,KAAK,CAACC,OAAO,CAAC7F,KAAK,CAAC,EAAE;IACxB,IAAIA,KAAK,CAACS,MAAM,KAAK,CAAC,EAAE;MACtB,OAAOC,SAAS;IAClB;IAEAV,KAAK,CAAC8D,GAAG,CAAE3C,IAAI,IAAK;MAClB,IAAIA,IAAI,aAAJA,IAAI,eAAJA,IAAI,CAAEb,IAAI,IAAI,EAAEa,IAAI,CAACb,IAAI,YAAYwF,IAAI,CAAC,EAAE;QAAA,IAAAC,aAAA,EAAAC,WAAA,EAAAC,KAAA,EAAAC,WAAA;QAE9C/E,IAAI,CAAC,MAAM,CAAC,GAAG,IAAI2E,IAAI,CAAC,EAAE,EAAE3E,IAAI,CAAC,MAAM,CAAC,KAAIA,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEb,IAAI,CAAC,MAAM,CAAC,GAAE;UAC9D6F,YAAY,GAAAJ,aAAA,IAAAC,WAAA,GAAG7E,IAAI,CAACb,IAAI,cAAA0F,WAAA,uBAAVA,WAAA,CAAqBG,YAAY,cAAAJ,aAAA,cAAAA,aAAA,GAAI,CAAC;UACpDK,IAAI,GAAAH,KAAA,IAAAC,WAAA,GAAG/E,IAAI,CAACb,IAAI,cAAA4F,WAAA,uBAAVA,WAAA,CAAqBE,IAAI,cAAAH,KAAA,cAAAA,KAAA,GAAI;QACrC,CAAC,CAAC;MACJ;MACA,OAAO9E,IAAI;IACb,CAAC,CAAC;EACJ;EAEA,OAAOnB,KAAK;AACd","ignoreList":[]}
1
+ {"version":3,"file":"Upload.js","names":["React","useCallback","useEffect","useMemo","useRef","classnames","FieldBlock","useFieldProps","useTranslation","useFormsTranslation","Upload","useUpload","pickSpacingProps","HelpButtonInline","HelpButtonInlineContent","useSharedTranslation","FormError","validateRequired","value","required","isChanged","error","hasError","some","file","errorMessage","hasFiles","length","undefined","UploadComponent","props","sharedTr","formsTr","errorMessages","errorRequired","fromInput","forEach","item","index","_item$file","name","preparedProps","_objectSpread","toInput","transformFiles","_useFieldProps","executeOnChangeRegardlessOfError","id","className","width","widthProp","label","labelDescription","help","htmlAttributes","disabled","handleChange","handleFocus","handleBlur","fileHandler","rest","_objectWithoutProperties","_excluded","title","text","acceptedFileTypes","filesAmountLimit","fileMaxSize","skeleton","onFileDelete","onFileClick","download","allowDuplicates","disableDragAndDrop","files","setFiles","filesRef","current","handleChangeAsync","_filesRef$current","existingFileIds","map","existingFiles","filter","includes","newFiles","newValidFiles","newFilesLoading","isLoading","incomingFiles","_incomingFiles$filter","incomingFileObj","foundIndex","findIndex","newFile","push","indexOfFirstNewFile","updatedFiles","slice","changeHandler","fieldBlockProps","forId","labelSrOnly","createElement","_extends","onChange","Fragment","contentId","left","roundedCorner","_supportsSpacingProps","Array","isArray","File","_lastModified","_item$file2","_type","_item$file3","lastModified","type"],"sources":["../../../../../../src/extensions/forms/Field/Upload/Upload.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useRef } from 'react'\nimport classnames from 'classnames'\nimport FieldBlock, {\n Props as FieldBlockProps,\n FieldBlockWidth,\n} from '../../FieldBlock'\nimport {\n useFieldProps,\n useTranslation as useFormsTranslation,\n} from '../../hooks'\nimport { FieldProps } from '../../types'\nimport Upload, {\n UploadFile,\n UploadFileNative,\n UploadProps,\n} from '../../../../components/Upload'\nimport useUpload from '../../../../components/upload/useUpload'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport HelpButtonInline, {\n HelpButtonInlineContent,\n} from '../../../../components/help-button/HelpButtonInline'\nimport { useTranslation as useSharedTranslation } from '../../../../shared'\nimport { SpacingProps } from '../../../../shared/types'\nimport { FormError } from '../../utils'\n\nexport type { UploadFile, UploadFileNative }\nexport type UploadValue = Array<UploadFile | UploadFileNative>\nexport type Props = Omit<\n FieldProps<UploadValue, UploadValue | undefined>,\n | 'layout'\n | 'layoutOptions'\n | 'onBlurValidator'\n | 'onChangeValidator'\n | 'contentWidth'\n | 'labelSize'\n | 'labelDescriptionInline'\n | 'labelSrOnly'\n | 'labelSize'\n | 'labelSuffix'\n> &\n SpacingProps &\n Pick<\n Partial<UploadProps>,\n | 'title'\n | 'text'\n | 'acceptedFileTypes'\n | 'filesAmountLimit'\n | 'fileMaxSize'\n | 'onFileDelete'\n | 'onFileClick'\n | 'skeleton'\n | 'download'\n | 'allowDuplicates'\n | 'disableDragAndDrop'\n > & {\n fileHandler?: (\n newFiles: UploadValue\n ) => UploadValue | Promise<UploadValue>\n width?: 'large' | 'stretch'\n }\n\nconst validateRequired = (\n value: UploadValue,\n { required, isChanged, error }\n) => {\n const hasError = value?.some((file) => file.errorMessage)\n if (hasError) {\n return new FormError('Upload.errorInvalidFiles')\n }\n\n const hasFiles = value?.length > 0\n if (required && ((!isChanged && !hasFiles) || !hasFiles)) {\n return error\n }\n\n return undefined\n}\n\nfunction UploadComponent(props: Props) {\n const sharedTr = useSharedTranslation().Upload\n const formsTr = useFormsTranslation().Upload\n\n const errorMessages = useMemo(\n () => ({\n 'Field.errorRequired': formsTr.errorRequired,\n }),\n [formsTr.errorRequired]\n )\n\n const fromInput = useCallback((value: UploadValue) => {\n value.forEach((item, index) => {\n if (!item) {\n return\n }\n\n value[index] = item\n\n // Store the name in the value, to support session storage (serialization)\n value[index]['name'] = item['name'] || item.file?.name\n })\n\n return value\n }, [])\n\n const preparedProps = {\n errorMessages,\n validateRequired,\n fromInput,\n toInput: transformFiles,\n ...props,\n }\n\n const {\n id,\n className,\n width: widthProp = 'stretch',\n value,\n label,\n labelDescription,\n help,\n htmlAttributes,\n disabled,\n handleChange,\n handleFocus,\n handleBlur,\n fileHandler,\n ...rest\n } = useFieldProps(preparedProps, {\n executeOnChangeRegardlessOfError: true,\n })\n\n // Upload props\n const {\n title = sharedTr.title,\n text = sharedTr.text,\n acceptedFileTypes = ['pdf', 'png', 'jpg', 'jpeg'],\n filesAmountLimit = 100,\n fileMaxSize = 5,\n skeleton,\n onFileDelete,\n onFileClick,\n download,\n allowDuplicates,\n disableDragAndDrop,\n } = rest\n\n const { files, setFiles } = useUpload(id)\n\n const filesRef = useRef<Array<UploadFile>>()\n\n useEffect(() => {\n filesRef.current = files\n }, [files])\n\n useEffect(() => {\n setFiles(value)\n }, [setFiles, value])\n\n const handleChangeAsync = useCallback(\n async (files: UploadValue) => {\n // Filter out existing files\n const existingFileIds =\n filesRef.current?.map((file) => file.id) || []\n const existingFiles = files.filter((file) =>\n existingFileIds.includes(file.id)\n )\n const newFiles = files.filter(\n (file) => !existingFileIds.includes(file.id)\n )\n const newValidFiles = newFiles.filter((file) => !file.errorMessage)\n\n if (newValidFiles.length > 0) {\n // Set loading\n const newFilesLoading = newFiles.map((file) => ({\n ...file,\n isLoading: !file.errorMessage,\n }))\n setFiles([...filesRef.current, ...newFilesLoading])\n\n const incomingFiles = await fileHandler(newValidFiles)\n\n if (!incomingFiles) {\n setFiles(existingFiles)\n handleChange(existingFiles)\n } else {\n // merge incoming files into existing order of newFiles.\n incomingFiles.forEach((file) => {\n const incomingFileObj = {\n ...file,\n isLoading: false,\n }\n const foundIndex = newFilesLoading.findIndex(\n (newFile) => newFile.isLoading\n )\n if (foundIndex >= 0) {\n newFilesLoading[foundIndex] = incomingFileObj\n } else {\n // if there's more files incoming than there's files loading (edge case), add them to end of array.\n newFilesLoading.push(incomingFileObj)\n }\n })\n\n const indexOfFirstNewFile = filesRef.current.findIndex(\n ({ id }) => id === newFiles[0].id\n )\n\n const updatedFiles = [\n ...filesRef.current.slice(0, indexOfFirstNewFile),\n ...(incomingFiles?.filter((file) => file != null) ?? []),\n ...filesRef.current.slice(\n indexOfFirstNewFile + incomingFiles.length\n ),\n ]\n setFiles(updatedFiles)\n handleChange(updatedFiles)\n }\n } else {\n handleChange(files)\n }\n },\n [setFiles, fileHandler, handleChange]\n )\n\n const changeHandler = useCallback(\n ({ files }: { files: UploadValue }) => {\n // Prevents the form-status from showing up\n handleBlur()\n handleFocus()\n\n if (fileHandler) {\n handleChangeAsync(files)\n } else {\n handleChange(files)\n }\n },\n [handleBlur, handleFocus, fileHandler, handleChangeAsync, handleChange]\n )\n\n const width = widthProp as FieldBlockWidth\n const fieldBlockProps: FieldBlockProps = {\n id,\n forId: `${id}-input`,\n labelSrOnly: true,\n className: classnames('dnb-forms-field-upload', className),\n width,\n help: undefined,\n ...pickSpacingProps(props),\n }\n\n return (\n <FieldBlock {...fieldBlockProps}>\n <Upload\n id={id}\n acceptedFileTypes={acceptedFileTypes}\n filesAmountLimit={filesAmountLimit}\n download={download}\n allowDuplicates={allowDuplicates}\n disableDragAndDrop={disableDragAndDrop}\n disabled={disabled}\n fileMaxSize={fileMaxSize}\n skeleton={skeleton}\n onChange={changeHandler}\n onFileDelete={onFileDelete}\n onFileClick={onFileClick}\n title={label ?? title}\n text={\n help ? (\n <>\n {labelDescription ?? text}\n <HelpButtonInline\n contentId={`${id}-help`}\n left={text ? 'x-small' : false}\n help={help}\n />\n </>\n ) : (\n labelDescription ?? text\n )\n }\n {...htmlAttributes}\n >\n {help && (\n <HelpButtonInlineContent\n contentId={`${id}-help`}\n help={help}\n roundedCorner={false}\n />\n )}\n </Upload>\n </FieldBlock>\n )\n}\n\nexport default UploadComponent\n\nUploadComponent._supportsSpacingProps = true\n\nexport function transformFiles(value: UploadValue) {\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return undefined\n }\n\n value.map((item) => {\n if (item?.file && !(item.file instanceof File)) {\n // To support session storage, we recreated the file blob.\n item['file'] = new File([], item['name'] || item?.file['name'], {\n lastModified: (item.file as File)?.lastModified ?? 0,\n type: (item.file as File)?.type ?? '',\n })\n }\n return item\n })\n }\n\n return value\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"UploadDocs.js","names":["UploadEvents","UploadProperties","UploadFieldProperties","_objectSpread","fileHandler","doc","type","status","title","undefined","text","UploadFieldEvents"],"sources":["../../../../../../src/extensions/forms/Field/Upload/UploadDocs.ts"],"sourcesContent":["import {\n UploadEvents,\n UploadProperties,\n} from '../../../../components/upload/UploadDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const UploadFieldProperties: PropertiesTableProps = {\n fileHandler: {\n doc: 'File handler function that takes newly added files (`newFiles: UploadValue`) as a parameter and returns the processed files. The function can either be synchronous or asynchronous. It returns a promise (`Promise<UploadValue>`) containing the processed files when asynchronous.',\n type: 'function',\n status: 'optional',\n },\n ...UploadProperties,\n title: undefined,\n text: undefined,\n}\n\nexport const UploadFieldEvents: PropertiesTableProps = {\n ...UploadEvents,\n}\n"],"mappings":";;;AAAA,SACEA,YAAY,EACZC,gBAAgB,QACX,0CAA0C;AAGjD,OAAO,MAAMC,qBAA2C,GAAAC,aAAA,CAAAA,aAAA;EACtDC,WAAW,EAAE;IACXC,GAAG,EAAE,sRAAsR;IAC3RC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AAAC,GACEN,gBAAgB;EACnBO,KAAK,EAAEC,SAAS;EAChBC,IAAI,EAAED;AAAS,EAChB;AAED,OAAO,MAAME,iBAAuC,GAAAR,aAAA,KAC/CH,YAAY,CAChB","ignoreList":[]}
1
+ {"version":3,"file":"UploadDocs.js","names":["UploadEvents","UploadProperties","UploadFieldProperties","_objectSpread","fileHandler","doc","type","status","title","undefined","text","UploadFieldEvents"],"sources":["../../../../../../src/extensions/forms/Field/Upload/UploadDocs.ts"],"sourcesContent":["import {\n UploadEvents,\n UploadProperties,\n} from '../../../../components/upload/UploadDocs'\nimport { PropertiesTableProps } from '../../../../shared/types'\n\nexport const UploadFieldProperties: PropertiesTableProps = {\n fileHandler: {\n doc: 'File handler function that takes newly added files (`newFiles: UploadValue`) as a parameter and returns the processed files. The function can either be synchronous or asynchronous. It returns a promise (`Promise<UploadValue>`) containing the processed files when asynchronous.',\n type: 'function',\n status: 'optional',\n },\n ...UploadProperties,\n title: undefined, // hiding from docs as we rather want user to use the `label` prop,\n text: undefined, // hiding from docs as we rather want user to use the `labelDescription` prop,\n}\n\nexport const UploadFieldEvents: PropertiesTableProps = {\n ...UploadEvents,\n}\n"],"mappings":";;;AAAA,SACEA,YAAY,EACZC,gBAAgB,QACX,0CAA0C;AAGjD,OAAO,MAAMC,qBAA2C,GAAAC,aAAA,CAAAA,aAAA;EACtDC,WAAW,EAAE;IACXC,GAAG,EAAE,sRAAsR;IAC3RC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AAAC,GACEN,gBAAgB;EACnBO,KAAK,EAAEC,SAAS;EAChBC,IAAI,EAAED;AAAS,EAChB;AAED,OAAO,MAAME,iBAAuC,GAAAR,aAAA,KAC/CH,YAAY,CAChB","ignoreList":[]}
@@ -20,7 +20,7 @@ import SubmitIndicator from '../Form/SubmitIndicator/SubmitIndicator';
20
20
  import { createSharedState } from '../../../shared/helpers/useSharedState';
21
21
  import useTranslation from '../hooks/useTranslation';
22
22
  import { FormError } from '../utils';
23
- import { useIterateItemNo } from '../Iterate/ItemNo/useIItemNo';
23
+ import { useIterateItemNo } from '../Iterate/ItemNo/useIterateItemNo';
24
24
  export const states = ['error', 'info', 'warning'];
25
25
  function FieldBlock(props) {
26
26
  var _props$id;