@dnb/eufemia 10.49.0 → 10.51.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1240) hide show
  1. package/CHANGELOG.md +75 -0
  2. package/cjs/components/accordion/style/dnb-accordion.css +3 -3
  3. package/cjs/components/accordion/style/dnb-accordion.min.css +1 -1
  4. package/cjs/components/autocomplete/style/dnb-autocomplete.css +1 -1
  5. package/cjs/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  6. package/cjs/components/breadcrumb/BreadcrumbItem.d.ts +1 -1
  7. package/cjs/components/breadcrumb/BreadcrumbItem.js +3 -3
  8. package/cjs/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  9. package/cjs/components/breadcrumb/BreadcrumbMultiple.js +2 -2
  10. package/cjs/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  11. package/cjs/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  12. package/cjs/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  13. package/cjs/components/button/Button.d.ts +2 -2
  14. package/cjs/components/card/style/dnb-card.css +1 -1
  15. package/cjs/components/card/style/dnb-card.min.css +1 -1
  16. package/cjs/components/checkbox/CheckboxDocs.js +1 -1
  17. package/cjs/components/checkbox/CheckboxDocs.js.map +1 -1
  18. package/cjs/components/date-picker/DatePicker.d.ts +13 -4
  19. package/cjs/components/drawer/style/dnb-drawer.css +3 -3
  20. package/cjs/components/drawer/style/dnb-drawer.min.css +1 -1
  21. package/cjs/components/dropdown/style/dnb-dropdown.css +1 -1
  22. package/cjs/components/dropdown/style/dnb-dropdown.min.css +1 -1
  23. package/cjs/components/form-row/style/dnb-form-row.css +1 -1
  24. package/cjs/components/form-row/style/dnb-form-row.min.css +1 -1
  25. package/cjs/components/form-status/FormStatus.d.ts +1 -1
  26. package/cjs/components/grid/style/dnb-grid.css +6 -6
  27. package/cjs/components/grid/style/dnb-grid.min.css +1 -1
  28. package/cjs/components/input-masked/InputMasked.d.ts +1 -1
  29. package/cjs/components/input-masked/InputMaskedDocs.js +1 -1
  30. package/cjs/components/input-masked/InputMaskedDocs.js.map +1 -1
  31. package/cjs/components/number-format/NumberFormat.d.ts +14 -28
  32. package/cjs/components/number-format/NumberFormat.js +6 -2
  33. package/cjs/components/number-format/NumberFormat.js.map +1 -1
  34. package/cjs/components/number-format/NumberFormatDocs.d.ts +3 -0
  35. package/cjs/components/number-format/NumberFormatDocs.js +161 -0
  36. package/cjs/components/number-format/NumberFormatDocs.js.map +1 -0
  37. package/cjs/components/number-format/NumberUtils.d.ts +21 -1
  38. package/cjs/components/number-format/NumberUtils.js +33 -8
  39. package/cjs/components/number-format/NumberUtils.js.map +1 -1
  40. package/cjs/components/pagination/Pagination.d.ts +1 -1
  41. package/cjs/components/section/style/dnb-section.css +2 -2
  42. package/cjs/components/section/style/dnb-section.min.css +2 -2
  43. package/cjs/components/space/style/dnb-space.css +2 -2
  44. package/cjs/components/space/style/dnb-space.min.css +1 -1
  45. package/cjs/components/switch/Switch.d.ts +100 -91
  46. package/cjs/components/switch/Switch.js +167 -239
  47. package/cjs/components/switch/Switch.js.map +1 -1
  48. package/cjs/components/switch/SwitchDocs.d.ts +3 -0
  49. package/cjs/components/switch/SwitchDocs.js +93 -0
  50. package/cjs/components/switch/SwitchDocs.js.map +1 -0
  51. package/cjs/components/tabs/style/dnb-tabs.css +1 -0
  52. package/cjs/components/tabs/style/dnb-tabs.min.css +1 -1
  53. package/cjs/components/tabs/style/dnb-tabs.scss +1 -0
  54. package/cjs/components/toggle-button/style/dnb-toggle-button.css +1 -1
  55. package/cjs/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  56. package/cjs/elements/ElementDocs.d.ts +2 -0
  57. package/cjs/elements/ElementDocs.js +35 -0
  58. package/cjs/elements/ElementDocs.js.map +1 -0
  59. package/cjs/elements/blockquote/BlockquoteDocs.d.ts +2 -0
  60. package/cjs/elements/blockquote/BlockquoteDocs.js +25 -0
  61. package/cjs/elements/blockquote/BlockquoteDocs.js.map +1 -0
  62. package/cjs/elements/hr/HrDocs.d.ts +2 -0
  63. package/cjs/elements/hr/HrDocs.js +25 -0
  64. package/cjs/elements/hr/HrDocs.js.map +1 -0
  65. package/cjs/elements/img/ImgDocs.d.ts +2 -0
  66. package/cjs/elements/img/ImgDocs.js +40 -0
  67. package/cjs/elements/img/ImgDocs.js.map +1 -0
  68. package/cjs/elements/lists/DlDocs.d.ts +2 -0
  69. package/cjs/elements/lists/DlDocs.js +21 -0
  70. package/cjs/elements/lists/DlDocs.js.map +1 -0
  71. package/cjs/elements/lists/OlDocs.d.ts +2 -0
  72. package/cjs/elements/lists/OlDocs.js +31 -0
  73. package/cjs/elements/lists/OlDocs.js.map +1 -0
  74. package/cjs/elements/lists/UlDocs.d.ts +2 -0
  75. package/cjs/elements/lists/UlDocs.js +31 -0
  76. package/cjs/elements/lists/UlDocs.js.map +1 -0
  77. package/cjs/elements/typography/IngressDocs.d.ts +2 -0
  78. package/cjs/elements/typography/IngressDocs.js +15 -0
  79. package/cjs/elements/typography/IngressDocs.js.map +1 -0
  80. package/cjs/elements/typography/LeadDocs.d.ts +2 -0
  81. package/cjs/elements/typography/LeadDocs.js +15 -0
  82. package/cjs/elements/typography/LeadDocs.js.map +1 -0
  83. package/cjs/elements/typography/PDocs.d.ts +2 -0
  84. package/cjs/elements/typography/PDocs.js +40 -0
  85. package/cjs/elements/typography/PDocs.js.map +1 -0
  86. package/cjs/extensions/forms/DataContext/At/At.js +1 -1
  87. package/cjs/extensions/forms/DataContext/At/At.js.map +1 -1
  88. package/cjs/extensions/forms/DataContext/Context.d.ts +37 -15
  89. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  90. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  91. package/cjs/extensions/forms/DataContext/Provider/Provider.js +160 -78
  92. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  93. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  94. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  95. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  96. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  97. package/cjs/extensions/forms/Field/Date/Date.d.ts +6 -0
  98. package/cjs/extensions/forms/Field/Date/Date.js +20 -4
  99. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  100. package/{extensions/forms/Form/FieldProps/FieldPropsDocs.d.ts → cjs/extensions/forms/Field/Date/DateDocs.d.ts} +1 -1
  101. package/cjs/extensions/forms/Field/Date/DateDocs.js +20 -0
  102. package/cjs/extensions/forms/Field/Date/DateDocs.js.map +1 -0
  103. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js +1 -1
  104. package/cjs/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  105. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +34 -5
  106. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  107. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -4
  108. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +6 -3
  109. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  110. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +1 -0
  111. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +65 -2
  112. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  113. package/{es/extensions/forms/Form/FieldProps/FieldProps.d.ts → cjs/extensions/forms/Field/Provider/FieldProvider.d.ts} +5 -7
  114. package/cjs/extensions/forms/Field/Provider/FieldProvider.js +33 -0
  115. package/cjs/extensions/forms/Field/Provider/FieldProvider.js.map +1 -0
  116. package/cjs/extensions/forms/{Form/FieldProps/FieldPropsContext.d.ts → Field/Provider/FieldProviderContext.d.ts} +3 -3
  117. package/cjs/extensions/forms/{Form/FieldProps/FieldPropsContext.js → Field/Provider/FieldProviderContext.js} +3 -3
  118. package/cjs/extensions/forms/Field/Provider/FieldProviderContext.js.map +1 -0
  119. package/cjs/extensions/forms/Field/Provider/FieldProviderDocs.d.ts +2 -0
  120. package/cjs/extensions/forms/{Form/FieldProps/FieldPropsDocs.js → Field/Provider/FieldProviderDocs.js} +4 -4
  121. package/cjs/extensions/forms/Field/Provider/FieldProviderDocs.js.map +1 -0
  122. package/cjs/extensions/forms/Field/Provider/index.d.ts +2 -0
  123. package/cjs/extensions/forms/{Form/FieldProps → Field/Provider}/index.js +5 -5
  124. package/cjs/extensions/forms/Field/Provider/index.js.map +1 -0
  125. package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +121 -0
  126. package/cjs/extensions/forms/{Form/FieldProps/FieldProps.js → Field/Provider/useFieldProvider.js} +34 -34
  127. package/cjs/extensions/forms/Field/Provider/useFieldProvider.js.map +1 -0
  128. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +10 -5
  129. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +59 -32
  130. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  131. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +5 -0
  132. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  133. package/cjs/extensions/forms/Field/index.d.ts +1 -0
  134. package/cjs/extensions/forms/Field/index.js +7 -0
  135. package/cjs/extensions/forms/Field/index.js.map +1 -1
  136. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +13 -2
  137. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  138. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  139. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  140. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  141. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  142. package/cjs/extensions/forms/Form/Element/Element.js +4 -4
  143. package/cjs/extensions/forms/Form/Element/Element.js.map +1 -1
  144. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +2 -2
  145. package/cjs/extensions/forms/Form/Handler/Handler.js +3 -1
  146. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  147. package/cjs/extensions/forms/Form/Isolation/Isolation.d.ts +2 -2
  148. package/cjs/extensions/forms/Form/Isolation/Isolation.js +11 -3
  149. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  150. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  151. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  152. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +0 -2
  153. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  154. package/cjs/extensions/forms/Form/Section/Section.d.ts +2 -1
  155. package/cjs/extensions/forms/Form/Section/Section.js +2 -2
  156. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  157. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.d.ts +25 -0
  158. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +153 -0
  159. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -0
  160. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.d.ts +2 -0
  161. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.js +30 -0
  162. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.js.map +1 -0
  163. package/cjs/extensions/forms/Form/SubmitConfirmation/index.d.ts +2 -0
  164. package/cjs/extensions/forms/Form/SubmitConfirmation/index.js +27 -0
  165. package/cjs/extensions/forms/Form/SubmitConfirmation/index.js.map +1 -0
  166. package/cjs/extensions/forms/Form/Visibility/Visibility.js +10 -4
  167. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  168. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.d.ts +7 -0
  169. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.js +12 -0
  170. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -0
  171. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  172. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  173. package/cjs/extensions/forms/Form/Visibility/useVisibility.js +4 -4
  174. package/cjs/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  175. package/cjs/extensions/forms/Form/data-context/getData.d.ts +2 -1
  176. package/cjs/extensions/forms/Form/data-context/getData.js +7 -2
  177. package/cjs/extensions/forms/Form/data-context/getData.js.map +1 -1
  178. package/cjs/extensions/forms/Form/data-context/useData.d.ts +7 -3
  179. package/cjs/extensions/forms/Form/data-context/useData.js +40 -19
  180. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  181. package/{es/extensions/forms/Form/data-context/useError.d.ts → cjs/extensions/forms/Form/data-context/useValidation.d.ts} +3 -1
  182. package/cjs/extensions/forms/Form/data-context/useValidation.js +60 -0
  183. package/cjs/extensions/forms/Form/data-context/useValidation.js.map +1 -0
  184. package/cjs/extensions/forms/Form/index.d.ts +13 -2
  185. package/cjs/extensions/forms/Form/index.js +19 -9
  186. package/cjs/extensions/forms/Form/index.js.map +1 -1
  187. package/cjs/extensions/forms/Iterate/Array/Array.js +32 -23
  188. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  189. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +5 -0
  190. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  191. package/cjs/extensions/forms/Iterate/Array/types.d.ts +1 -0
  192. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  193. package/cjs/extensions/forms/Iterate/Count/Count.js +1 -1
  194. package/cjs/extensions/forms/Iterate/Count/Count.js.map +1 -1
  195. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js +19 -7
  196. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  197. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +2 -2
  198. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  199. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +11 -1
  200. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  201. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +30 -10
  202. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  203. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -2
  204. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  205. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  206. package/cjs/extensions/forms/Iterate/hooks/index.js +7 -0
  207. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -1
  208. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +15 -0
  209. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.js +50 -0
  210. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -0
  211. package/cjs/extensions/forms/Tools/GenerateSchema.d.ts +1 -1
  212. package/cjs/extensions/forms/Tools/GenerateSchema.js +1 -1
  213. package/cjs/extensions/forms/Tools/GenerateSchema.js.map +1 -1
  214. package/cjs/extensions/forms/Tools/ListAllProps.d.ts +1 -1
  215. package/cjs/extensions/forms/Tools/ListAllProps.js +1 -1
  216. package/cjs/extensions/forms/Tools/ListAllProps.js.map +1 -1
  217. package/cjs/extensions/forms/Tools/Log.js +1 -1
  218. package/cjs/extensions/forms/Tools/Log.js.map +1 -1
  219. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +12 -0
  220. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js +27 -10
  221. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  222. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +10 -0
  223. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -1
  224. package/cjs/extensions/forms/Value/Currency/CurrencyDocs.d.ts +2 -0
  225. package/cjs/extensions/forms/Value/Currency/CurrencyDocs.js +28 -0
  226. package/cjs/extensions/forms/Value/Currency/CurrencyDocs.js.map +1 -0
  227. package/cjs/extensions/forms/Value/Date/Date.js +25 -16
  228. package/cjs/extensions/forms/Value/Date/Date.js.map +1 -1
  229. package/cjs/extensions/forms/Value/Number/Number.js +3 -2
  230. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  231. package/cjs/extensions/forms/Value/Number/NumberDocs.js +9 -2
  232. package/cjs/extensions/forms/Value/Number/NumberDocs.js.map +1 -1
  233. package/cjs/extensions/forms/Value/Provider/ValueProvider.d.ts +13 -0
  234. package/cjs/extensions/forms/Value/Provider/ValueProvider.js +27 -0
  235. package/cjs/extensions/forms/Value/Provider/ValueProvider.js.map +1 -0
  236. package/cjs/extensions/forms/Value/Provider/ValueProviderContext.d.ts +9 -0
  237. package/cjs/extensions/forms/Value/Provider/ValueProviderContext.js +15 -0
  238. package/cjs/extensions/forms/Value/Provider/ValueProviderContext.js.map +1 -0
  239. package/cjs/extensions/forms/Value/Provider/ValueProviderDocs.d.ts +3 -0
  240. package/cjs/extensions/forms/Value/Provider/ValueProviderDocs.js +23 -0
  241. package/cjs/extensions/forms/Value/Provider/ValueProviderDocs.js.map +1 -0
  242. package/cjs/extensions/forms/Value/Provider/index.d.ts +2 -0
  243. package/cjs/extensions/forms/Value/Provider/index.js +27 -0
  244. package/cjs/extensions/forms/Value/Provider/index.js.map +1 -0
  245. package/cjs/extensions/forms/Value/Provider/useValueProvider.d.ts +31 -0
  246. package/cjs/extensions/forms/Value/Provider/useValueProvider.js +50 -0
  247. package/cjs/extensions/forms/Value/Provider/useValueProvider.js.map +1 -0
  248. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +1 -0
  249. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.js +7 -23
  250. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -1
  251. package/cjs/extensions/forms/Value/SelectCountry/useCountry.d.ts +4 -0
  252. package/cjs/extensions/forms/Value/SelectCountry/useCountry.js +33 -0
  253. package/cjs/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -0
  254. package/cjs/extensions/forms/Value/Selection/Selection.js +2 -1
  255. package/cjs/extensions/forms/Value/Selection/Selection.js.map +1 -1
  256. package/cjs/extensions/forms/Value/SummaryList/SummaryList.d.ts +4 -1
  257. package/cjs/extensions/forms/Value/SummaryList/SummaryList.js +11 -3
  258. package/cjs/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  259. package/cjs/extensions/forms/Value/SummaryList/SummaryListDocs.d.ts +3 -0
  260. package/cjs/extensions/forms/Value/SummaryList/SummaryListDocs.js +37 -0
  261. package/cjs/extensions/forms/Value/SummaryList/SummaryListDocs.js.map +1 -0
  262. package/cjs/extensions/forms/Value/ValueDocs.js +5 -0
  263. package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
  264. package/cjs/extensions/forms/Value/index.d.ts +3 -2
  265. package/cjs/extensions/forms/Value/index.js +9 -2
  266. package/cjs/extensions/forms/Value/index.js.map +1 -1
  267. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +8 -6
  268. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  269. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.css +2 -2
  270. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  271. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +2 -1
  272. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  273. package/cjs/extensions/forms/Wizard/Step/Step.js +2 -2
  274. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  275. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -5
  276. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  277. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.scss +0 -4
  278. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +2 -1
  279. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +35 -19
  280. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  281. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +5 -0
  282. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -1
  283. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +0 -2
  284. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +70 -70
  285. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -1
  286. package/cjs/extensions/forms/constants/countries.d.ts +1 -0
  287. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  288. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +5 -4
  289. package/cjs/extensions/forms/constants/locales/en-GB.js +8 -7
  290. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  291. package/cjs/extensions/forms/constants/locales/en-US.d.ts +5 -4
  292. package/cjs/extensions/forms/constants/locales/index.d.ts +10 -8
  293. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +5 -4
  294. package/cjs/extensions/forms/constants/locales/nb-NO.js +8 -7
  295. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  296. package/cjs/extensions/forms/hooks/DataValueDocs.js +1 -1
  297. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  298. package/cjs/extensions/forms/hooks/useDataValue.d.ts +1 -1
  299. package/cjs/extensions/forms/hooks/useDataValue.js +1 -1
  300. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  301. package/cjs/extensions/forms/hooks/useExternalValue.js +1 -1
  302. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  303. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +2 -1
  304. package/cjs/extensions/forms/hooks/useFieldProps.js +234 -87
  305. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  306. package/cjs/extensions/forms/hooks/usePath.js +7 -4
  307. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  308. package/cjs/extensions/forms/hooks/useValueProps.d.ts +1 -1
  309. package/cjs/extensions/forms/hooks/useValueProps.js +37 -9
  310. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  311. package/cjs/extensions/forms/style/dnb-forms.css +10 -21
  312. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  313. package/cjs/extensions/forms/types.d.ts +19 -8
  314. package/cjs/extensions/forms/types.js.map +1 -1
  315. package/cjs/extensions/forms/utils/ajv.d.ts +2 -1
  316. package/cjs/extensions/forms/utils/ajv.js +1 -1
  317. package/cjs/extensions/forms/utils/ajv.js.map +1 -1
  318. package/cjs/extensions/forms/utils/index.d.ts +1 -0
  319. package/cjs/extensions/forms/utils/index.js +12 -0
  320. package/cjs/extensions/forms/utils/index.js.map +1 -1
  321. package/cjs/extensions/forms/utils/json-pointer/export.d.ts +1 -0
  322. package/cjs/extensions/forms/utils/json-pointer/export.js +17 -0
  323. package/cjs/extensions/forms/utils/json-pointer/export.js.map +1 -0
  324. package/cjs/extensions/forms/utils/json-pointer/json-pointer.d.ts +43 -0
  325. package/cjs/extensions/forms/utils/json-pointer/json-pointer.js +139 -0
  326. package/cjs/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -0
  327. package/cjs/extensions/forms/utils/json-pointer.d.ts +3 -0
  328. package/cjs/extensions/forms/utils/json-pointer.js +24 -0
  329. package/cjs/extensions/forms/utils/json-pointer.js.map +1 -0
  330. package/cjs/shared/Context.d.ts +2 -0
  331. package/cjs/shared/Context.js +1 -1
  332. package/cjs/shared/Context.js.map +1 -1
  333. package/cjs/shared/Eufemia.d.ts +1 -1
  334. package/cjs/shared/Eufemia.js +2 -2
  335. package/cjs/shared/Eufemia.js.map +1 -1
  336. package/cjs/shared/MediaQueryUtils.d.ts +0 -1
  337. package/cjs/shared/MediaQueryUtils.js +17 -14
  338. package/cjs/shared/MediaQueryUtils.js.map +1 -1
  339. package/cjs/shared/helpers/extendPropsWithContext.js +3 -3
  340. package/cjs/shared/helpers/extendPropsWithContext.js.map +1 -1
  341. package/cjs/shared/helpers/withSnakeCaseProps.js.map +1 -1
  342. package/cjs/shared/locales/en-GB.js.map +1 -1
  343. package/cjs/shared/locales/en-US.d.ts +1 -1
  344. package/cjs/shared/locales/en-US.js +2 -2
  345. package/cjs/shared/locales/en-US.js.map +1 -1
  346. package/cjs/style/core/scopes.scss +1 -1
  347. package/cjs/style/core/utilities.scss +10 -5
  348. package/cjs/style/dnb-ui-basis.css +1 -1
  349. package/cjs/style/dnb-ui-basis.min.css +1 -1
  350. package/cjs/style/dnb-ui-body.css +1 -1
  351. package/cjs/style/dnb-ui-body.min.css +1 -1
  352. package/cjs/style/dnb-ui-components.css +35 -45
  353. package/cjs/style/dnb-ui-components.min.css +5 -5
  354. package/cjs/style/dnb-ui-core.css +1 -1
  355. package/cjs/style/dnb-ui-core.min.css +1 -1
  356. package/cjs/style/dnb-ui-elements.css +1 -1
  357. package/cjs/style/dnb-ui-elements.min.css +1 -1
  358. package/cjs/style/dnb-ui-extensions.css +10 -21
  359. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  360. package/cjs/style/dnb-ui-forms.css +10 -21
  361. package/cjs/style/dnb-ui-forms.min.css +1 -1
  362. package/cjs/style/dnb-ui-forms.scss +0 -1
  363. package/cjs/style/dnb-ui-fragments.css +2 -2
  364. package/cjs/style/dnb-ui-fragments.min.css +1 -1
  365. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  366. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  367. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +46 -67
  368. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  369. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  370. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  371. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +10 -21
  372. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  373. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +10 -21
  374. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  375. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  376. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  377. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +46 -67
  378. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  379. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  380. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  381. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +10 -21
  382. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  383. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +10 -21
  384. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  385. package/cjs/style/themes/theme-ui/ui-theme-basis.css +1 -1
  386. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  387. package/cjs/style/themes/theme-ui/ui-theme-components.css +46 -67
  388. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  389. package/cjs/style/themes/theme-ui/ui-theme-elements.css +1 -1
  390. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  391. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +10 -21
  392. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  393. package/cjs/style/themes/theme-ui/ui-theme-forms.css +10 -21
  394. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  395. package/cjs/style/themes/theme-ui/ui-theme-tags.css +1 -1
  396. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  397. package/components/accordion/style/dnb-accordion.css +3 -3
  398. package/components/accordion/style/dnb-accordion.min.css +1 -1
  399. package/components/autocomplete/style/dnb-autocomplete.css +1 -1
  400. package/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  401. package/components/breadcrumb/BreadcrumbItem.d.ts +1 -1
  402. package/components/breadcrumb/BreadcrumbItem.js +3 -3
  403. package/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  404. package/components/breadcrumb/BreadcrumbMultiple.js +2 -2
  405. package/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  406. package/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  407. package/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  408. package/components/button/Button.d.ts +2 -2
  409. package/components/card/style/dnb-card.css +1 -1
  410. package/components/card/style/dnb-card.min.css +1 -1
  411. package/components/checkbox/CheckboxDocs.js +1 -1
  412. package/components/checkbox/CheckboxDocs.js.map +1 -1
  413. package/components/date-picker/DatePicker.d.ts +13 -4
  414. package/components/drawer/style/dnb-drawer.css +3 -3
  415. package/components/drawer/style/dnb-drawer.min.css +1 -1
  416. package/components/dropdown/style/dnb-dropdown.css +1 -1
  417. package/components/dropdown/style/dnb-dropdown.min.css +1 -1
  418. package/components/form-row/style/dnb-form-row.css +1 -1
  419. package/components/form-row/style/dnb-form-row.min.css +1 -1
  420. package/components/form-status/FormStatus.d.ts +1 -1
  421. package/components/grid/style/dnb-grid.css +6 -6
  422. package/components/grid/style/dnb-grid.min.css +1 -1
  423. package/components/input-masked/InputMasked.d.ts +1 -1
  424. package/components/input-masked/InputMaskedDocs.js +1 -1
  425. package/components/input-masked/InputMaskedDocs.js.map +1 -1
  426. package/components/number-format/NumberFormat.d.ts +14 -28
  427. package/components/number-format/NumberFormat.js +6 -2
  428. package/components/number-format/NumberFormat.js.map +1 -1
  429. package/components/number-format/NumberFormatDocs.d.ts +3 -0
  430. package/components/number-format/NumberFormatDocs.js +153 -0
  431. package/components/number-format/NumberFormatDocs.js.map +1 -0
  432. package/components/number-format/NumberUtils.d.ts +21 -1
  433. package/components/number-format/NumberUtils.js +32 -8
  434. package/components/number-format/NumberUtils.js.map +1 -1
  435. package/components/pagination/Pagination.d.ts +1 -1
  436. package/components/section/style/dnb-section.css +2 -2
  437. package/components/section/style/dnb-section.min.css +2 -2
  438. package/components/space/style/dnb-space.css +2 -2
  439. package/components/space/style/dnb-space.min.css +1 -1
  440. package/components/switch/Switch.d.ts +100 -91
  441. package/components/switch/Switch.js +165 -238
  442. package/components/switch/Switch.js.map +1 -1
  443. package/components/switch/SwitchDocs.d.ts +3 -0
  444. package/components/switch/SwitchDocs.js +85 -0
  445. package/components/switch/SwitchDocs.js.map +1 -0
  446. package/components/tabs/style/dnb-tabs.css +1 -0
  447. package/components/tabs/style/dnb-tabs.min.css +1 -1
  448. package/components/tabs/style/dnb-tabs.scss +1 -0
  449. package/components/toggle-button/style/dnb-toggle-button.css +1 -1
  450. package/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  451. package/elements/ElementDocs.d.ts +2 -0
  452. package/elements/ElementDocs.js +28 -0
  453. package/elements/ElementDocs.js.map +1 -0
  454. package/elements/blockquote/BlockquoteDocs.d.ts +2 -0
  455. package/elements/blockquote/BlockquoteDocs.js +18 -0
  456. package/elements/blockquote/BlockquoteDocs.js.map +1 -0
  457. package/elements/hr/HrDocs.d.ts +2 -0
  458. package/elements/hr/HrDocs.js +18 -0
  459. package/elements/hr/HrDocs.js.map +1 -0
  460. package/elements/img/ImgDocs.d.ts +2 -0
  461. package/elements/img/ImgDocs.js +33 -0
  462. package/elements/img/ImgDocs.js.map +1 -0
  463. package/elements/lists/DlDocs.d.ts +2 -0
  464. package/elements/lists/DlDocs.js +12 -0
  465. package/elements/lists/DlDocs.js.map +1 -0
  466. package/elements/lists/OlDocs.d.ts +2 -0
  467. package/elements/lists/OlDocs.js +22 -0
  468. package/elements/lists/OlDocs.js.map +1 -0
  469. package/elements/lists/UlDocs.d.ts +2 -0
  470. package/elements/lists/UlDocs.js +22 -0
  471. package/elements/lists/UlDocs.js.map +1 -0
  472. package/elements/typography/IngressDocs.d.ts +2 -0
  473. package/elements/typography/IngressDocs.js +6 -0
  474. package/elements/typography/IngressDocs.js.map +1 -0
  475. package/elements/typography/LeadDocs.d.ts +2 -0
  476. package/elements/typography/LeadDocs.js +6 -0
  477. package/elements/typography/LeadDocs.js.map +1 -0
  478. package/elements/typography/PDocs.d.ts +2 -0
  479. package/elements/typography/PDocs.js +33 -0
  480. package/elements/typography/PDocs.js.map +1 -0
  481. package/es/components/accordion/style/dnb-accordion.css +3 -3
  482. package/es/components/accordion/style/dnb-accordion.min.css +1 -1
  483. package/es/components/autocomplete/style/dnb-autocomplete.css +1 -1
  484. package/es/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  485. package/es/components/breadcrumb/BreadcrumbItem.d.ts +1 -1
  486. package/es/components/breadcrumb/BreadcrumbItem.js +3 -3
  487. package/es/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  488. package/es/components/breadcrumb/BreadcrumbMultiple.js +2 -2
  489. package/es/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  490. package/es/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  491. package/es/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  492. package/es/components/button/Button.d.ts +2 -2
  493. package/es/components/card/style/dnb-card.css +1 -1
  494. package/es/components/card/style/dnb-card.min.css +1 -1
  495. package/es/components/checkbox/CheckboxDocs.js +1 -1
  496. package/es/components/checkbox/CheckboxDocs.js.map +1 -1
  497. package/es/components/date-picker/DatePicker.d.ts +13 -4
  498. package/es/components/drawer/style/dnb-drawer.css +3 -3
  499. package/es/components/drawer/style/dnb-drawer.min.css +1 -1
  500. package/es/components/dropdown/style/dnb-dropdown.css +1 -1
  501. package/es/components/dropdown/style/dnb-dropdown.min.css +1 -1
  502. package/es/components/form-row/style/dnb-form-row.css +1 -1
  503. package/es/components/form-row/style/dnb-form-row.min.css +1 -1
  504. package/es/components/form-status/FormStatus.d.ts +1 -1
  505. package/es/components/grid/style/dnb-grid.css +6 -6
  506. package/es/components/grid/style/dnb-grid.min.css +1 -1
  507. package/es/components/input-masked/InputMasked.d.ts +1 -1
  508. package/es/components/input-masked/InputMaskedDocs.js +1 -1
  509. package/es/components/input-masked/InputMaskedDocs.js.map +1 -1
  510. package/es/components/number-format/NumberFormat.d.ts +14 -28
  511. package/es/components/number-format/NumberFormat.js +6 -2
  512. package/es/components/number-format/NumberFormat.js.map +1 -1
  513. package/es/components/number-format/NumberFormatDocs.d.ts +3 -0
  514. package/es/components/number-format/NumberFormatDocs.js +150 -0
  515. package/es/components/number-format/NumberFormatDocs.js.map +1 -0
  516. package/es/components/number-format/NumberUtils.d.ts +21 -1
  517. package/es/components/number-format/NumberUtils.js +31 -7
  518. package/es/components/number-format/NumberUtils.js.map +1 -1
  519. package/es/components/pagination/Pagination.d.ts +1 -1
  520. package/es/components/section/style/dnb-section.css +2 -2
  521. package/es/components/section/style/dnb-section.min.css +2 -2
  522. package/es/components/space/style/dnb-space.css +2 -2
  523. package/es/components/space/style/dnb-space.min.css +1 -1
  524. package/es/components/switch/Switch.d.ts +100 -91
  525. package/es/components/switch/Switch.js +164 -238
  526. package/es/components/switch/Switch.js.map +1 -1
  527. package/es/components/switch/SwitchDocs.d.ts +3 -0
  528. package/es/components/switch/SwitchDocs.js +85 -0
  529. package/es/components/switch/SwitchDocs.js.map +1 -0
  530. package/es/components/tabs/style/dnb-tabs.css +1 -0
  531. package/es/components/tabs/style/dnb-tabs.min.css +1 -1
  532. package/es/components/tabs/style/dnb-tabs.scss +1 -0
  533. package/es/components/toggle-button/style/dnb-toggle-button.css +1 -1
  534. package/es/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  535. package/es/elements/ElementDocs.d.ts +2 -0
  536. package/es/elements/ElementDocs.js +28 -0
  537. package/es/elements/ElementDocs.js.map +1 -0
  538. package/es/elements/blockquote/BlockquoteDocs.d.ts +2 -0
  539. package/es/elements/blockquote/BlockquoteDocs.js +18 -0
  540. package/es/elements/blockquote/BlockquoteDocs.js.map +1 -0
  541. package/es/elements/hr/HrDocs.d.ts +2 -0
  542. package/es/elements/hr/HrDocs.js +18 -0
  543. package/es/elements/hr/HrDocs.js.map +1 -0
  544. package/es/elements/img/ImgDocs.d.ts +2 -0
  545. package/es/elements/img/ImgDocs.js +33 -0
  546. package/es/elements/img/ImgDocs.js.map +1 -0
  547. package/es/elements/lists/DlDocs.d.ts +2 -0
  548. package/es/elements/lists/DlDocs.js +12 -0
  549. package/es/elements/lists/DlDocs.js.map +1 -0
  550. package/es/elements/lists/OlDocs.d.ts +2 -0
  551. package/es/elements/lists/OlDocs.js +22 -0
  552. package/es/elements/lists/OlDocs.js.map +1 -0
  553. package/es/elements/lists/UlDocs.d.ts +2 -0
  554. package/es/elements/lists/UlDocs.js +22 -0
  555. package/es/elements/lists/UlDocs.js.map +1 -0
  556. package/es/elements/typography/IngressDocs.d.ts +2 -0
  557. package/es/elements/typography/IngressDocs.js +6 -0
  558. package/es/elements/typography/IngressDocs.js.map +1 -0
  559. package/es/elements/typography/LeadDocs.d.ts +2 -0
  560. package/es/elements/typography/LeadDocs.js +6 -0
  561. package/es/elements/typography/LeadDocs.js.map +1 -0
  562. package/es/elements/typography/PDocs.d.ts +2 -0
  563. package/es/elements/typography/PDocs.js +33 -0
  564. package/es/elements/typography/PDocs.js.map +1 -0
  565. package/es/extensions/forms/DataContext/At/At.js +1 -1
  566. package/es/extensions/forms/DataContext/At/At.js.map +1 -1
  567. package/es/extensions/forms/DataContext/Context.d.ts +37 -15
  568. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  569. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  570. package/es/extensions/forms/DataContext/Provider/Provider.js +153 -76
  571. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  572. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  573. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  574. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  575. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  576. package/es/extensions/forms/Field/Date/Date.d.ts +6 -0
  577. package/es/extensions/forms/Field/Date/Date.js +20 -4
  578. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  579. package/{cjs/extensions/forms/Form/FieldProps/FieldPropsDocs.d.ts → es/extensions/forms/Field/Date/DateDocs.d.ts} +1 -1
  580. package/es/extensions/forms/Field/Date/DateDocs.js +13 -0
  581. package/es/extensions/forms/Field/Date/DateDocs.js.map +1 -0
  582. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js +1 -1
  583. package/es/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  584. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +35 -6
  585. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  586. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -4
  587. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +7 -4
  588. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  589. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +1 -0
  590. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +63 -1
  591. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  592. package/{extensions/forms/Form/FieldProps/FieldProps.d.ts → es/extensions/forms/Field/Provider/FieldProvider.d.ts} +5 -7
  593. package/es/extensions/forms/Field/Provider/FieldProvider.js +24 -0
  594. package/es/extensions/forms/Field/Provider/FieldProvider.js.map +1 -0
  595. package/{extensions/forms/Form/FieldProps/FieldPropsContext.d.ts → es/extensions/forms/Field/Provider/FieldProviderContext.d.ts} +3 -3
  596. package/es/extensions/forms/Field/Provider/FieldProviderContext.js +7 -0
  597. package/es/extensions/forms/Field/Provider/FieldProviderContext.js.map +1 -0
  598. package/es/extensions/forms/Field/Provider/FieldProviderDocs.d.ts +2 -0
  599. package/{extensions/forms/Form/FieldProps/FieldPropsDocs.js → es/extensions/forms/Field/Provider/FieldProviderDocs.js} +2 -2
  600. package/es/extensions/forms/Field/Provider/FieldProviderDocs.js.map +1 -0
  601. package/es/extensions/forms/Field/Provider/index.d.ts +2 -0
  602. package/es/extensions/forms/Field/Provider/index.js +3 -0
  603. package/es/extensions/forms/Field/Provider/index.js.map +1 -0
  604. package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +121 -0
  605. package/es/extensions/forms/{Form/FieldProps/FieldProps.js → Field/Provider/useFieldProvider.js} +34 -32
  606. package/es/extensions/forms/Field/Provider/useFieldProvider.js.map +1 -0
  607. package/es/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +10 -5
  608. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +50 -21
  609. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  610. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +5 -0
  611. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  612. package/es/extensions/forms/Field/index.d.ts +1 -0
  613. package/es/extensions/forms/Field/index.js +1 -0
  614. package/es/extensions/forms/Field/index.js.map +1 -1
  615. package/es/extensions/forms/FieldBlock/FieldBlock.js +13 -2
  616. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  617. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  618. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  619. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  620. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  621. package/es/extensions/forms/Form/Element/Element.js +4 -4
  622. package/es/extensions/forms/Form/Element/Element.js.map +1 -1
  623. package/es/extensions/forms/Form/Handler/Handler.d.ts +2 -2
  624. package/es/extensions/forms/Form/Handler/Handler.js +3 -1
  625. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  626. package/es/extensions/forms/Form/Isolation/Isolation.d.ts +2 -2
  627. package/es/extensions/forms/Form/Isolation/Isolation.js +11 -3
  628. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  629. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  630. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  631. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +0 -2
  632. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  633. package/es/extensions/forms/Form/Section/Section.d.ts +2 -1
  634. package/es/extensions/forms/Form/Section/Section.js +1 -1
  635. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  636. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.d.ts +25 -0
  637. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +140 -0
  638. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -0
  639. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.d.ts +2 -0
  640. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.js +23 -0
  641. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.js.map +1 -0
  642. package/es/extensions/forms/Form/SubmitConfirmation/index.d.ts +2 -0
  643. package/es/extensions/forms/Form/SubmitConfirmation/index.js +3 -0
  644. package/es/extensions/forms/Form/SubmitConfirmation/index.js.map +1 -0
  645. package/es/extensions/forms/Form/Visibility/Visibility.js +10 -4
  646. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  647. package/es/extensions/forms/Form/Visibility/VisibilityContext.d.ts +7 -0
  648. package/es/extensions/forms/Form/Visibility/VisibilityContext.js +6 -0
  649. package/es/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -0
  650. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  651. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  652. package/es/extensions/forms/Form/Visibility/useVisibility.js +4 -4
  653. package/es/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  654. package/es/extensions/forms/Form/data-context/getData.d.ts +2 -1
  655. package/es/extensions/forms/Form/data-context/getData.js +7 -2
  656. package/es/extensions/forms/Form/data-context/getData.js.map +1 -1
  657. package/es/extensions/forms/Form/data-context/useData.d.ts +7 -3
  658. package/es/extensions/forms/Form/data-context/useData.js +39 -19
  659. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  660. package/{extensions/forms/Form/data-context/useError.d.ts → es/extensions/forms/Form/data-context/useValidation.d.ts} +3 -1
  661. package/es/extensions/forms/Form/data-context/useValidation.js +52 -0
  662. package/es/extensions/forms/Form/data-context/useValidation.js.map +1 -0
  663. package/es/extensions/forms/Form/index.d.ts +13 -2
  664. package/es/extensions/forms/Form/index.js +5 -2
  665. package/es/extensions/forms/Form/index.js.map +1 -1
  666. package/es/extensions/forms/Iterate/Array/Array.js +33 -24
  667. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  668. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +5 -0
  669. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  670. package/es/extensions/forms/Iterate/Array/types.d.ts +1 -0
  671. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  672. package/es/extensions/forms/Iterate/Count/Count.js +1 -1
  673. package/es/extensions/forms/Iterate/Count/Count.js.map +1 -1
  674. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +15 -5
  675. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  676. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +2 -2
  677. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  678. package/es/extensions/forms/Iterate/PushButton/PushButton.js +12 -2
  679. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  680. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +31 -11
  681. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  682. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -2
  683. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  684. package/es/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  685. package/es/extensions/forms/Iterate/hooks/index.js +1 -0
  686. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -1
  687. package/es/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +15 -0
  688. package/es/extensions/forms/Iterate/hooks/useArrayLimit.js +43 -0
  689. package/es/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -0
  690. package/es/extensions/forms/Tools/GenerateSchema.d.ts +1 -1
  691. package/es/extensions/forms/Tools/GenerateSchema.js +1 -1
  692. package/es/extensions/forms/Tools/GenerateSchema.js.map +1 -1
  693. package/es/extensions/forms/Tools/ListAllProps.d.ts +1 -1
  694. package/es/extensions/forms/Tools/ListAllProps.js +1 -1
  695. package/es/extensions/forms/Tools/ListAllProps.js.map +1 -1
  696. package/es/extensions/forms/Tools/Log.js +1 -1
  697. package/es/extensions/forms/Tools/Log.js.map +1 -1
  698. package/es/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +12 -0
  699. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js +26 -9
  700. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  701. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +10 -0
  702. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -1
  703. package/es/extensions/forms/Value/Currency/CurrencyDocs.d.ts +2 -0
  704. package/es/extensions/forms/Value/Currency/CurrencyDocs.js +19 -0
  705. package/es/extensions/forms/Value/Currency/CurrencyDocs.js.map +1 -0
  706. package/es/extensions/forms/Value/Date/Date.js +25 -16
  707. package/es/extensions/forms/Value/Date/Date.js.map +1 -1
  708. package/es/extensions/forms/Value/Number/Number.js +3 -2
  709. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  710. package/es/extensions/forms/Value/Number/NumberDocs.js +7 -2
  711. package/es/extensions/forms/Value/Number/NumberDocs.js.map +1 -1
  712. package/es/extensions/forms/Value/Provider/ValueProvider.d.ts +13 -0
  713. package/es/extensions/forms/Value/Provider/ValueProvider.js +18 -0
  714. package/es/extensions/forms/Value/Provider/ValueProvider.js.map +1 -0
  715. package/es/extensions/forms/Value/Provider/ValueProviderContext.d.ts +9 -0
  716. package/es/extensions/forms/Value/Provider/ValueProviderContext.js +7 -0
  717. package/es/extensions/forms/Value/Provider/ValueProviderContext.js.map +1 -0
  718. package/es/extensions/forms/Value/Provider/ValueProviderDocs.d.ts +3 -0
  719. package/es/extensions/forms/Value/Provider/ValueProviderDocs.js +13 -0
  720. package/es/extensions/forms/Value/Provider/ValueProviderDocs.js.map +1 -0
  721. package/es/extensions/forms/Value/Provider/index.d.ts +2 -0
  722. package/es/extensions/forms/Value/Provider/index.js +3 -0
  723. package/es/extensions/forms/Value/Provider/index.js.map +1 -0
  724. package/es/extensions/forms/Value/Provider/useValueProvider.d.ts +31 -0
  725. package/es/extensions/forms/Value/Provider/useValueProvider.js +40 -0
  726. package/es/extensions/forms/Value/Provider/useValueProvider.js.map +1 -0
  727. package/es/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +1 -0
  728. package/es/extensions/forms/Value/SelectCountry/SelectCountry.js +7 -22
  729. package/es/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -1
  730. package/es/extensions/forms/Value/SelectCountry/useCountry.d.ts +4 -0
  731. package/es/extensions/forms/Value/SelectCountry/useCountry.js +27 -0
  732. package/es/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -0
  733. package/es/extensions/forms/Value/Selection/Selection.js +2 -1
  734. package/es/extensions/forms/Value/Selection/Selection.js.map +1 -1
  735. package/es/extensions/forms/Value/SummaryList/SummaryList.d.ts +4 -1
  736. package/es/extensions/forms/Value/SummaryList/SummaryList.js +11 -3
  737. package/es/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  738. package/es/extensions/forms/Value/SummaryList/SummaryListDocs.d.ts +3 -0
  739. package/es/extensions/forms/Value/SummaryList/SummaryListDocs.js +29 -0
  740. package/es/extensions/forms/Value/SummaryList/SummaryListDocs.js.map +1 -0
  741. package/es/extensions/forms/Value/ValueDocs.js +5 -0
  742. package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
  743. package/es/extensions/forms/Value/index.d.ts +3 -2
  744. package/es/extensions/forms/Value/index.js +3 -2
  745. package/es/extensions/forms/Value/index.js.map +1 -1
  746. package/es/extensions/forms/ValueBlock/ValueBlock.js +8 -6
  747. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  748. package/es/extensions/forms/ValueBlock/style/dnb-value-block.css +2 -2
  749. package/es/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  750. package/es/extensions/forms/Wizard/Container/WizardContainer.js +2 -1
  751. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  752. package/es/extensions/forms/Wizard/Step/Step.js +2 -2
  753. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  754. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -5
  755. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  756. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.scss +0 -4
  757. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +2 -1
  758. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +35 -19
  759. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  760. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +5 -0
  761. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -1
  762. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +0 -2
  763. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +70 -70
  764. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -1
  765. package/es/extensions/forms/constants/countries.d.ts +1 -0
  766. package/es/extensions/forms/constants/countries.js.map +1 -1
  767. package/es/extensions/forms/constants/locales/en-GB.d.ts +5 -4
  768. package/es/extensions/forms/constants/locales/en-GB.js +8 -7
  769. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  770. package/es/extensions/forms/constants/locales/en-US.d.ts +5 -4
  771. package/es/extensions/forms/constants/locales/index.d.ts +10 -8
  772. package/es/extensions/forms/constants/locales/nb-NO.d.ts +5 -4
  773. package/es/extensions/forms/constants/locales/nb-NO.js +8 -7
  774. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  775. package/es/extensions/forms/hooks/DataValueDocs.js +1 -1
  776. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  777. package/es/extensions/forms/hooks/useDataValue.d.ts +1 -1
  778. package/es/extensions/forms/hooks/useDataValue.js +1 -1
  779. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  780. package/es/extensions/forms/hooks/useExternalValue.js +1 -1
  781. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  782. package/es/extensions/forms/hooks/useFieldProps.d.ts +2 -1
  783. package/es/extensions/forms/hooks/useFieldProps.js +227 -83
  784. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  785. package/es/extensions/forms/hooks/usePath.js +7 -4
  786. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  787. package/es/extensions/forms/hooks/useValueProps.d.ts +1 -1
  788. package/es/extensions/forms/hooks/useValueProps.js +38 -10
  789. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  790. package/es/extensions/forms/style/dnb-forms.css +10 -21
  791. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  792. package/es/extensions/forms/types.d.ts +19 -8
  793. package/es/extensions/forms/types.js.map +1 -1
  794. package/es/extensions/forms/utils/ajv.d.ts +2 -1
  795. package/es/extensions/forms/utils/ajv.js +1 -1
  796. package/es/extensions/forms/utils/ajv.js.map +1 -1
  797. package/es/extensions/forms/utils/index.d.ts +1 -0
  798. package/es/extensions/forms/utils/index.js +1 -0
  799. package/es/extensions/forms/utils/index.js.map +1 -1
  800. package/es/extensions/forms/utils/json-pointer/export.d.ts +1 -0
  801. package/es/extensions/forms/utils/json-pointer/export.js +1 -0
  802. package/es/extensions/forms/utils/json-pointer/export.js.map +1 -0
  803. package/es/extensions/forms/utils/json-pointer/json-pointer.d.ts +43 -0
  804. package/es/extensions/forms/utils/json-pointer/json-pointer.js +122 -0
  805. package/es/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -0
  806. package/es/extensions/forms/utils/json-pointer.d.ts +3 -0
  807. package/es/extensions/forms/utils/json-pointer.js +4 -0
  808. package/es/extensions/forms/utils/json-pointer.js.map +1 -0
  809. package/es/shared/Context.d.ts +2 -0
  810. package/es/shared/Context.js +1 -1
  811. package/es/shared/Context.js.map +1 -1
  812. package/es/shared/Eufemia.d.ts +1 -1
  813. package/es/shared/Eufemia.js +2 -2
  814. package/es/shared/Eufemia.js.map +1 -1
  815. package/es/shared/MediaQueryUtils.d.ts +0 -1
  816. package/es/shared/MediaQueryUtils.js +17 -14
  817. package/es/shared/MediaQueryUtils.js.map +1 -1
  818. package/es/shared/helpers/extendPropsWithContext.js +3 -3
  819. package/es/shared/helpers/extendPropsWithContext.js.map +1 -1
  820. package/es/shared/helpers/withSnakeCaseProps.js.map +1 -1
  821. package/es/shared/locales/en-GB.js.map +1 -1
  822. package/es/shared/locales/en-US.d.ts +1 -1
  823. package/es/shared/locales/en-US.js +2 -2
  824. package/es/shared/locales/en-US.js.map +1 -1
  825. package/es/style/core/scopes.scss +1 -1
  826. package/es/style/core/utilities.scss +10 -5
  827. package/es/style/dnb-ui-basis.css +1 -1
  828. package/es/style/dnb-ui-basis.min.css +1 -1
  829. package/es/style/dnb-ui-body.css +1 -1
  830. package/es/style/dnb-ui-body.min.css +1 -1
  831. package/es/style/dnb-ui-components.css +35 -45
  832. package/es/style/dnb-ui-components.min.css +5 -5
  833. package/es/style/dnb-ui-core.css +1 -1
  834. package/es/style/dnb-ui-core.min.css +1 -1
  835. package/es/style/dnb-ui-elements.css +1 -1
  836. package/es/style/dnb-ui-elements.min.css +1 -1
  837. package/es/style/dnb-ui-extensions.css +10 -21
  838. package/es/style/dnb-ui-extensions.min.css +1 -1
  839. package/es/style/dnb-ui-forms.css +10 -21
  840. package/es/style/dnb-ui-forms.min.css +1 -1
  841. package/es/style/dnb-ui-forms.scss +0 -1
  842. package/es/style/dnb-ui-fragments.css +2 -2
  843. package/es/style/dnb-ui-fragments.min.css +1 -1
  844. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  845. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  846. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +46 -67
  847. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  848. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  849. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  850. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +10 -21
  851. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  852. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +10 -21
  853. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  854. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  855. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  856. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +46 -67
  857. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  858. package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  859. package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  860. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +10 -21
  861. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  862. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +10 -21
  863. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  864. package/es/style/themes/theme-ui/ui-theme-basis.css +1 -1
  865. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  866. package/es/style/themes/theme-ui/ui-theme-components.css +46 -67
  867. package/es/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  868. package/es/style/themes/theme-ui/ui-theme-elements.css +1 -1
  869. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  870. package/es/style/themes/theme-ui/ui-theme-extensions.css +10 -21
  871. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  872. package/es/style/themes/theme-ui/ui-theme-forms.css +10 -21
  873. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  874. package/es/style/themes/theme-ui/ui-theme-tags.css +1 -1
  875. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  876. package/esm/dnb-ui-basis.min.mjs +1 -1
  877. package/esm/dnb-ui-components.min.mjs +1 -1
  878. package/esm/dnb-ui-elements.min.mjs +1 -1
  879. package/esm/dnb-ui-extensions.min.mjs +5 -5
  880. package/esm/dnb-ui-lib.min.mjs +1 -1
  881. package/extensions/forms/DataContext/At/At.js +1 -1
  882. package/extensions/forms/DataContext/At/At.js.map +1 -1
  883. package/extensions/forms/DataContext/Context.d.ts +37 -15
  884. package/extensions/forms/DataContext/Context.js.map +1 -1
  885. package/extensions/forms/DataContext/Provider/Provider.d.ts +1 -1
  886. package/extensions/forms/DataContext/Provider/Provider.js +159 -77
  887. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  888. package/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  889. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  890. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  891. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  892. package/extensions/forms/Field/Date/Date.d.ts +6 -0
  893. package/extensions/forms/Field/Date/Date.js +20 -4
  894. package/extensions/forms/Field/Date/Date.js.map +1 -1
  895. package/{es/extensions/forms/Form/FieldProps/FieldPropsDocs.d.ts → extensions/forms/Field/Date/DateDocs.d.ts} +1 -1
  896. package/extensions/forms/Field/Date/DateDocs.js +13 -0
  897. package/extensions/forms/Field/Date/DateDocs.js.map +1 -0
  898. package/extensions/forms/Field/Indeterminate/useDependencePaths.js +1 -1
  899. package/extensions/forms/Field/Indeterminate/useDependencePaths.js.map +1 -1
  900. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +35 -6
  901. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  902. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -4
  903. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +7 -4
  904. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  905. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +1 -0
  906. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +63 -1
  907. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  908. package/{cjs/extensions/forms/Form/FieldProps/FieldProps.d.ts → extensions/forms/Field/Provider/FieldProvider.d.ts} +5 -7
  909. package/extensions/forms/Field/Provider/FieldProvider.js +24 -0
  910. package/extensions/forms/Field/Provider/FieldProvider.js.map +1 -0
  911. package/{es/extensions/forms/Form/FieldProps/FieldPropsContext.d.ts → extensions/forms/Field/Provider/FieldProviderContext.d.ts} +3 -3
  912. package/extensions/forms/Field/Provider/FieldProviderContext.js +7 -0
  913. package/extensions/forms/Field/Provider/FieldProviderContext.js.map +1 -0
  914. package/extensions/forms/Field/Provider/FieldProviderDocs.d.ts +2 -0
  915. package/{es/extensions/forms/Form/FieldProps/FieldPropsDocs.js → extensions/forms/Field/Provider/FieldProviderDocs.js} +2 -2
  916. package/extensions/forms/Field/Provider/FieldProviderDocs.js.map +1 -0
  917. package/extensions/forms/Field/Provider/index.d.ts +2 -0
  918. package/extensions/forms/Field/Provider/index.js +3 -0
  919. package/extensions/forms/Field/Provider/index.js.map +1 -0
  920. package/extensions/forms/Field/Provider/useFieldProvider.d.ts +121 -0
  921. package/extensions/forms/{Form/FieldProps/FieldProps.js → Field/Provider/useFieldProvider.js} +34 -32
  922. package/extensions/forms/Field/Provider/useFieldProvider.js.map +1 -0
  923. package/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +10 -5
  924. package/extensions/forms/Field/SelectCountry/SelectCountry.js +59 -33
  925. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  926. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +5 -0
  927. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  928. package/extensions/forms/Field/index.d.ts +1 -0
  929. package/extensions/forms/Field/index.js +1 -0
  930. package/extensions/forms/Field/index.js.map +1 -1
  931. package/extensions/forms/FieldBlock/FieldBlock.js +13 -2
  932. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  933. package/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  934. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  935. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  936. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  937. package/extensions/forms/Form/Element/Element.js +4 -4
  938. package/extensions/forms/Form/Element/Element.js.map +1 -1
  939. package/extensions/forms/Form/Handler/Handler.d.ts +2 -2
  940. package/extensions/forms/Form/Handler/Handler.js +3 -1
  941. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  942. package/extensions/forms/Form/Isolation/Isolation.d.ts +2 -2
  943. package/extensions/forms/Form/Isolation/Isolation.js +11 -3
  944. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  945. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  946. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  947. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +0 -2
  948. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  949. package/extensions/forms/Form/Section/Section.d.ts +2 -1
  950. package/extensions/forms/Form/Section/Section.js +1 -1
  951. package/extensions/forms/Form/Section/Section.js.map +1 -1
  952. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.d.ts +25 -0
  953. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +142 -0
  954. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -0
  955. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.d.ts +2 -0
  956. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.js +23 -0
  957. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmationDocs.js.map +1 -0
  958. package/extensions/forms/Form/SubmitConfirmation/index.d.ts +2 -0
  959. package/extensions/forms/Form/SubmitConfirmation/index.js +3 -0
  960. package/extensions/forms/Form/SubmitConfirmation/index.js.map +1 -0
  961. package/extensions/forms/Form/Visibility/Visibility.js +10 -4
  962. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  963. package/extensions/forms/Form/Visibility/VisibilityContext.d.ts +7 -0
  964. package/extensions/forms/Form/Visibility/VisibilityContext.js +6 -0
  965. package/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -0
  966. package/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  967. package/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  968. package/extensions/forms/Form/Visibility/useVisibility.js +4 -4
  969. package/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  970. package/extensions/forms/Form/data-context/getData.d.ts +2 -1
  971. package/extensions/forms/Form/data-context/getData.js +7 -2
  972. package/extensions/forms/Form/data-context/getData.js.map +1 -1
  973. package/extensions/forms/Form/data-context/useData.d.ts +7 -3
  974. package/extensions/forms/Form/data-context/useData.js +40 -19
  975. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  976. package/{cjs/extensions/forms/Form/data-context/useError.d.ts → extensions/forms/Form/data-context/useValidation.d.ts} +3 -1
  977. package/extensions/forms/Form/data-context/useValidation.js +54 -0
  978. package/extensions/forms/Form/data-context/useValidation.js.map +1 -0
  979. package/extensions/forms/Form/index.d.ts +13 -2
  980. package/extensions/forms/Form/index.js +5 -2
  981. package/extensions/forms/Form/index.js.map +1 -1
  982. package/extensions/forms/Iterate/Array/Array.js +33 -24
  983. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  984. package/extensions/forms/Iterate/Array/ArrayDocs.js +5 -0
  985. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  986. package/extensions/forms/Iterate/Array/types.d.ts +1 -0
  987. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  988. package/extensions/forms/Iterate/Count/Count.js +1 -1
  989. package/extensions/forms/Iterate/Count/Count.js.map +1 -1
  990. package/extensions/forms/Iterate/EditContainer/CancelButton.js +18 -7
  991. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  992. package/extensions/forms/Iterate/EditContainer/EditContainer.js +2 -2
  993. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  994. package/extensions/forms/Iterate/PushButton/PushButton.js +12 -2
  995. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  996. package/extensions/forms/Iterate/PushContainer/PushContainer.js +31 -11
  997. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  998. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -2
  999. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  1000. package/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  1001. package/extensions/forms/Iterate/hooks/index.js +1 -0
  1002. package/extensions/forms/Iterate/hooks/index.js.map +1 -1
  1003. package/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +15 -0
  1004. package/extensions/forms/Iterate/hooks/useArrayLimit.js +44 -0
  1005. package/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -0
  1006. package/extensions/forms/Tools/GenerateSchema.d.ts +1 -1
  1007. package/extensions/forms/Tools/GenerateSchema.js +1 -1
  1008. package/extensions/forms/Tools/GenerateSchema.js.map +1 -1
  1009. package/extensions/forms/Tools/ListAllProps.d.ts +1 -1
  1010. package/extensions/forms/Tools/ListAllProps.js +1 -1
  1011. package/extensions/forms/Tools/ListAllProps.js.map +1 -1
  1012. package/extensions/forms/Tools/Log.js +1 -1
  1013. package/extensions/forms/Tools/Log.js.map +1 -1
  1014. package/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +12 -0
  1015. package/extensions/forms/Value/ArraySelection/ArraySelection.js +27 -10
  1016. package/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  1017. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +10 -0
  1018. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -1
  1019. package/extensions/forms/Value/Currency/CurrencyDocs.d.ts +2 -0
  1020. package/extensions/forms/Value/Currency/CurrencyDocs.js +19 -0
  1021. package/extensions/forms/Value/Currency/CurrencyDocs.js.map +1 -0
  1022. package/extensions/forms/Value/Date/Date.js +25 -16
  1023. package/extensions/forms/Value/Date/Date.js.map +1 -1
  1024. package/extensions/forms/Value/Number/Number.js +3 -2
  1025. package/extensions/forms/Value/Number/Number.js.map +1 -1
  1026. package/extensions/forms/Value/Number/NumberDocs.js +7 -2
  1027. package/extensions/forms/Value/Number/NumberDocs.js.map +1 -1
  1028. package/extensions/forms/Value/Provider/ValueProvider.d.ts +13 -0
  1029. package/extensions/forms/Value/Provider/ValueProvider.js +18 -0
  1030. package/extensions/forms/Value/Provider/ValueProvider.js.map +1 -0
  1031. package/extensions/forms/Value/Provider/ValueProviderContext.d.ts +9 -0
  1032. package/extensions/forms/Value/Provider/ValueProviderContext.js +7 -0
  1033. package/extensions/forms/Value/Provider/ValueProviderContext.js.map +1 -0
  1034. package/extensions/forms/Value/Provider/ValueProviderDocs.d.ts +3 -0
  1035. package/extensions/forms/Value/Provider/ValueProviderDocs.js +13 -0
  1036. package/extensions/forms/Value/Provider/ValueProviderDocs.js.map +1 -0
  1037. package/extensions/forms/Value/Provider/index.d.ts +2 -0
  1038. package/extensions/forms/Value/Provider/index.js +3 -0
  1039. package/extensions/forms/Value/Provider/index.js.map +1 -0
  1040. package/extensions/forms/Value/Provider/useValueProvider.d.ts +31 -0
  1041. package/extensions/forms/Value/Provider/useValueProvider.js +40 -0
  1042. package/extensions/forms/Value/Provider/useValueProvider.js.map +1 -0
  1043. package/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +1 -0
  1044. package/extensions/forms/Value/SelectCountry/SelectCountry.js +7 -22
  1045. package/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -1
  1046. package/extensions/forms/Value/SelectCountry/useCountry.d.ts +4 -0
  1047. package/extensions/forms/Value/SelectCountry/useCountry.js +27 -0
  1048. package/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -0
  1049. package/extensions/forms/Value/Selection/Selection.js +2 -1
  1050. package/extensions/forms/Value/Selection/Selection.js.map +1 -1
  1051. package/extensions/forms/Value/SummaryList/SummaryList.d.ts +4 -1
  1052. package/extensions/forms/Value/SummaryList/SummaryList.js +11 -3
  1053. package/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  1054. package/extensions/forms/Value/SummaryList/SummaryListDocs.d.ts +3 -0
  1055. package/extensions/forms/Value/SummaryList/SummaryListDocs.js +29 -0
  1056. package/extensions/forms/Value/SummaryList/SummaryListDocs.js.map +1 -0
  1057. package/extensions/forms/Value/ValueDocs.js +5 -0
  1058. package/extensions/forms/Value/ValueDocs.js.map +1 -1
  1059. package/extensions/forms/Value/index.d.ts +3 -2
  1060. package/extensions/forms/Value/index.js +3 -2
  1061. package/extensions/forms/Value/index.js.map +1 -1
  1062. package/extensions/forms/ValueBlock/ValueBlock.js +8 -6
  1063. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  1064. package/extensions/forms/ValueBlock/style/dnb-value-block.css +2 -2
  1065. package/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  1066. package/extensions/forms/Wizard/Container/WizardContainer.js +2 -1
  1067. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  1068. package/extensions/forms/Wizard/Step/Step.js +2 -2
  1069. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  1070. package/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -5
  1071. package/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  1072. package/extensions/forms/Wizard/style/dnb-wizard-layout.scss +0 -4
  1073. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +2 -1
  1074. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +35 -19
  1075. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  1076. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +5 -0
  1077. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -1
  1078. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.d.ts +0 -2
  1079. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +70 -70
  1080. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -1
  1081. package/extensions/forms/constants/countries.d.ts +1 -0
  1082. package/extensions/forms/constants/countries.js.map +1 -1
  1083. package/extensions/forms/constants/locales/en-GB.d.ts +5 -4
  1084. package/extensions/forms/constants/locales/en-GB.js +8 -7
  1085. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  1086. package/extensions/forms/constants/locales/en-US.d.ts +5 -4
  1087. package/extensions/forms/constants/locales/index.d.ts +10 -8
  1088. package/extensions/forms/constants/locales/nb-NO.d.ts +5 -4
  1089. package/extensions/forms/constants/locales/nb-NO.js +8 -7
  1090. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  1091. package/extensions/forms/hooks/DataValueDocs.js +1 -1
  1092. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  1093. package/extensions/forms/hooks/useDataValue.d.ts +1 -1
  1094. package/extensions/forms/hooks/useDataValue.js +1 -1
  1095. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  1096. package/extensions/forms/hooks/useExternalValue.js +1 -1
  1097. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  1098. package/extensions/forms/hooks/useFieldProps.d.ts +2 -1
  1099. package/extensions/forms/hooks/useFieldProps.js +232 -87
  1100. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  1101. package/extensions/forms/hooks/usePath.js +7 -4
  1102. package/extensions/forms/hooks/usePath.js.map +1 -1
  1103. package/extensions/forms/hooks/useValueProps.d.ts +1 -1
  1104. package/extensions/forms/hooks/useValueProps.js +38 -10
  1105. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  1106. package/extensions/forms/style/dnb-forms.css +10 -21
  1107. package/extensions/forms/style/dnb-forms.min.css +1 -1
  1108. package/extensions/forms/types.d.ts +19 -8
  1109. package/extensions/forms/types.js.map +1 -1
  1110. package/extensions/forms/utils/ajv.d.ts +2 -1
  1111. package/extensions/forms/utils/ajv.js +1 -1
  1112. package/extensions/forms/utils/ajv.js.map +1 -1
  1113. package/extensions/forms/utils/index.d.ts +1 -0
  1114. package/extensions/forms/utils/index.js +1 -0
  1115. package/extensions/forms/utils/index.js.map +1 -1
  1116. package/extensions/forms/utils/json-pointer/export.d.ts +1 -0
  1117. package/extensions/forms/utils/json-pointer/export.js +1 -0
  1118. package/extensions/forms/utils/json-pointer/export.js.map +1 -0
  1119. package/extensions/forms/utils/json-pointer/json-pointer.d.ts +43 -0
  1120. package/extensions/forms/utils/json-pointer/json-pointer.js +124 -0
  1121. package/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -0
  1122. package/extensions/forms/utils/json-pointer.d.ts +3 -0
  1123. package/extensions/forms/utils/json-pointer.js +4 -0
  1124. package/extensions/forms/utils/json-pointer.js.map +1 -0
  1125. package/package.json +1 -2
  1126. package/shared/Context.d.ts +2 -0
  1127. package/shared/Context.js +1 -1
  1128. package/shared/Context.js.map +1 -1
  1129. package/shared/Eufemia.d.ts +1 -1
  1130. package/shared/Eufemia.js +2 -2
  1131. package/shared/Eufemia.js.map +1 -1
  1132. package/shared/MediaQueryUtils.d.ts +0 -1
  1133. package/shared/MediaQueryUtils.js +17 -14
  1134. package/shared/MediaQueryUtils.js.map +1 -1
  1135. package/shared/helpers/extendPropsWithContext.js +3 -3
  1136. package/shared/helpers/extendPropsWithContext.js.map +1 -1
  1137. package/shared/helpers/withSnakeCaseProps.js.map +1 -1
  1138. package/shared/locales/en-GB.js.map +1 -1
  1139. package/shared/locales/en-US.d.ts +1 -1
  1140. package/shared/locales/en-US.js +2 -2
  1141. package/shared/locales/en-US.js.map +1 -1
  1142. package/style/core/scopes.scss +1 -1
  1143. package/style/core/utilities.scss +10 -5
  1144. package/style/dnb-ui-basis.css +1 -1
  1145. package/style/dnb-ui-basis.min.css +1 -1
  1146. package/style/dnb-ui-body.css +1 -1
  1147. package/style/dnb-ui-body.min.css +1 -1
  1148. package/style/dnb-ui-components.css +35 -45
  1149. package/style/dnb-ui-components.min.css +5 -5
  1150. package/style/dnb-ui-core.css +1 -1
  1151. package/style/dnb-ui-core.min.css +1 -1
  1152. package/style/dnb-ui-elements.css +1 -1
  1153. package/style/dnb-ui-elements.min.css +1 -1
  1154. package/style/dnb-ui-extensions.css +10 -21
  1155. package/style/dnb-ui-extensions.min.css +1 -1
  1156. package/style/dnb-ui-forms.css +10 -21
  1157. package/style/dnb-ui-forms.min.css +1 -1
  1158. package/style/dnb-ui-forms.scss +0 -1
  1159. package/style/dnb-ui-fragments.css +2 -2
  1160. package/style/dnb-ui-fragments.min.css +1 -1
  1161. package/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  1162. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  1163. package/style/themes/theme-eiendom/eiendom-theme-components.css +46 -67
  1164. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  1165. package/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  1166. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  1167. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +10 -21
  1168. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  1169. package/style/themes/theme-eiendom/eiendom-theme-forms.css +10 -21
  1170. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  1171. package/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  1172. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  1173. package/style/themes/theme-sbanken/sbanken-theme-components.css +46 -67
  1174. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  1175. package/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  1176. package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  1177. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +10 -21
  1178. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  1179. package/style/themes/theme-sbanken/sbanken-theme-forms.css +10 -21
  1180. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  1181. package/style/themes/theme-ui/ui-theme-basis.css +1 -1
  1182. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  1183. package/style/themes/theme-ui/ui-theme-components.css +46 -67
  1184. package/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  1185. package/style/themes/theme-ui/ui-theme-elements.css +1 -1
  1186. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  1187. package/style/themes/theme-ui/ui-theme-extensions.css +10 -21
  1188. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  1189. package/style/themes/theme-ui/ui-theme-forms.css +10 -21
  1190. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  1191. package/style/themes/theme-ui/ui-theme-tags.css +1 -1
  1192. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  1193. package/umd/dnb-ui-basis.min.js +1 -1
  1194. package/umd/dnb-ui-components.min.js +1 -1
  1195. package/umd/dnb-ui-elements.min.js +1 -1
  1196. package/umd/dnb-ui-extensions.min.js +5 -5
  1197. package/umd/dnb-ui-lib.min.js +1 -1
  1198. package/cjs/extensions/forms/Form/Element/style/dnb-form-element.css +0 -7
  1199. package/cjs/extensions/forms/Form/Element/style/dnb-form-element.min.css +0 -1
  1200. package/cjs/extensions/forms/Form/Element/style/dnb-form-element.scss +0 -9
  1201. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js.map +0 -1
  1202. package/cjs/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +0 -1
  1203. package/cjs/extensions/forms/Form/FieldProps/FieldPropsDocs.js.map +0 -1
  1204. package/cjs/extensions/forms/Form/FieldProps/index.d.ts +0 -2
  1205. package/cjs/extensions/forms/Form/FieldProps/index.js.map +0 -1
  1206. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +0 -1
  1207. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +0 -25
  1208. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +0 -1
  1209. package/cjs/extensions/forms/Form/data-context/useError.js +0 -33
  1210. package/cjs/extensions/forms/Form/data-context/useError.js.map +0 -1
  1211. package/es/extensions/forms/Form/Element/style/dnb-form-element.css +0 -7
  1212. package/es/extensions/forms/Form/Element/style/dnb-form-element.min.css +0 -1
  1213. package/es/extensions/forms/Form/Element/style/dnb-form-element.scss +0 -9
  1214. package/es/extensions/forms/Form/FieldProps/FieldProps.js.map +0 -1
  1215. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.js +0 -7
  1216. package/es/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +0 -1
  1217. package/es/extensions/forms/Form/FieldProps/FieldPropsDocs.js.map +0 -1
  1218. package/es/extensions/forms/Form/FieldProps/index.d.ts +0 -2
  1219. package/es/extensions/forms/Form/FieldProps/index.js +0 -3
  1220. package/es/extensions/forms/Form/FieldProps/index.js.map +0 -1
  1221. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +0 -1
  1222. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +0 -19
  1223. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +0 -1
  1224. package/es/extensions/forms/Form/data-context/useError.js +0 -26
  1225. package/es/extensions/forms/Form/data-context/useError.js.map +0 -1
  1226. package/extensions/forms/Form/Element/style/dnb-form-element.css +0 -7
  1227. package/extensions/forms/Form/Element/style/dnb-form-element.min.css +0 -1
  1228. package/extensions/forms/Form/Element/style/dnb-form-element.scss +0 -9
  1229. package/extensions/forms/Form/FieldProps/FieldProps.js.map +0 -1
  1230. package/extensions/forms/Form/FieldProps/FieldPropsContext.js +0 -7
  1231. package/extensions/forms/Form/FieldProps/FieldPropsContext.js.map +0 -1
  1232. package/extensions/forms/Form/FieldProps/FieldPropsDocs.js.map +0 -1
  1233. package/extensions/forms/Form/FieldProps/index.d.ts +0 -2
  1234. package/extensions/forms/Form/FieldProps/index.js +0 -3
  1235. package/extensions/forms/Form/FieldProps/index.js.map +0 -1
  1236. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +0 -1
  1237. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +0 -19
  1238. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +0 -1
  1239. package/extensions/forms/Form/data-context/useError.js +0 -27
  1240. package/extensions/forms/Form/data-context/useError.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps, Validator } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((value: any, index: number) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n countPath?: Path\n countPathLimit?: number\n validator?: Validator<Value>\n withoutFlex?: boolean\n animate?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n countPathTransform?: (params: { value: any; index: number }) => any\n }\n"],"mappings":""}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps, Validator } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((value: any, index: number) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n limit?: number\n countPath?: Path\n countPathLimit?: number\n validator?: Validator<Value>\n withoutFlex?: boolean\n animate?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n countPathTransform?: (params: { value: any; index: number }) => any\n }\n"],"mappings":""}
@@ -1,5 +1,5 @@
1
1
  import { useCallback } from 'react';
2
- import pointer from 'json-pointer';
2
+ import pointer from '../../utils/json-pointer';
3
3
  import { useData, getData } from '../../Form';
4
4
  export function Count(props) {
5
5
  const {
@@ -1 +1 @@
1
- {"version":3,"file":"Count.js","names":["useCallback","pointer","useData","getData","Count","props","data","id","countData","_ref","path","filter","has","value","get","Array","isArray","length","Object","entries","keys","NaN","count","useCount","arguments","undefined"],"sources":["../../../../../../src/extensions/forms/Iterate/Count/Count.tsx"],"sourcesContent":["import { useCallback } from 'react'\nimport pointer from 'json-pointer'\nimport { Identifier, Path } from '../../types'\nimport { useData, getData } from '../../Form'\n\nexport type Props = {\n /**\n * The path (JSON Pointer) to the array or object to count.\n */\n path: Path\n\n /**\n * A Form.Handler or DataContext `id` for when called outside of the context.\n */\n id?: Identifier\n\n /**\n * A filter function to filter the data before counting.\n */\n filter?: (item: unknown) => boolean\n}\n\nexport function Count(props: Props) {\n const { data } = useData(props.id)\n return countData(data, props)\n}\n\nfunction countData(data: unknown, { path, filter }: Props) {\n if (pointer.has(data, path)) {\n const value = pointer.get(data, path)\n if (Array.isArray(value)) {\n return filter ? value.filter(filter).length : value.length\n } else if (typeof value === 'object' && value) {\n return filter\n ? Object.entries(value).filter(filter).length\n : Object.keys(value).length\n }\n }\n\n return NaN\n}\n\nexport function count(props: Props) {\n const { data } = getData(props.id)\n return countData(data, props)\n}\n\nexport function useCount(id: Identifier = undefined) {\n const { data } = useData(id)\n\n const count = useCallback(\n (path: Props['path'], filter?: Props['filter']) => {\n return countData(data, { path, filter })\n },\n [data]\n )\n\n return { count }\n}\n"],"mappings":"AAAA,SAASA,WAAW,QAAQ,OAAO;AACnC,OAAOC,OAAO,MAAM,cAAc;AAElC,SAASC,OAAO,EAAEC,OAAO,QAAQ,YAAY;AAmB7C,OAAO,SAASC,KAAKA,CAACC,KAAY,EAAE;EAClC,MAAM;IAAEC;EAAK,CAAC,GAAGJ,OAAO,CAACG,KAAK,CAACE,EAAE,CAAC;EAClC,OAAOC,SAAS,CAACF,IAAI,EAAED,KAAK,CAAC;AAC/B;AAEA,SAASG,SAASA,CAACF,IAAa,EAAAG,IAAA,EAA2B;EAAA,IAAzB;IAAEC,IAAI;IAAEC;EAAc,CAAC,GAAAF,IAAA;EACvD,IAAIR,OAAO,CAACW,GAAG,CAACN,IAAI,EAAEI,IAAI,CAAC,EAAE;IAC3B,MAAMG,KAAK,GAAGZ,OAAO,CAACa,GAAG,CAACR,IAAI,EAAEI,IAAI,CAAC;IACrC,IAAIK,KAAK,CAACC,OAAO,CAACH,KAAK,CAAC,EAAE;MACxB,OAAOF,MAAM,GAAGE,KAAK,CAACF,MAAM,CAACA,MAAM,CAAC,CAACM,MAAM,GAAGJ,KAAK,CAACI,MAAM;IAC5D,CAAC,MAAM,IAAI,OAAOJ,KAAK,KAAK,QAAQ,IAAIA,KAAK,EAAE;MAC7C,OAAOF,MAAM,GACTO,MAAM,CAACC,OAAO,CAACN,KAAK,CAAC,CAACF,MAAM,CAACA,MAAM,CAAC,CAACM,MAAM,GAC3CC,MAAM,CAACE,IAAI,CAACP,KAAK,CAAC,CAACI,MAAM;IAC/B;EACF;EAEA,OAAOI,GAAG;AACZ;AAEA,OAAO,SAASC,KAAKA,CAACjB,KAAY,EAAE;EAClC,MAAM;IAAEC;EAAK,CAAC,GAAGH,OAAO,CAACE,KAAK,CAACE,EAAE,CAAC;EAClC,OAAOC,SAAS,CAACF,IAAI,EAAED,KAAK,CAAC;AAC/B;AAEA,OAAO,SAASkB,QAAQA,CAAA,EAA6B;EAAA,IAA5BhB,EAAc,GAAAiB,SAAA,CAAAP,MAAA,QAAAO,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAGC,SAAS;EACjD,MAAM;IAAEnB;EAAK,CAAC,GAAGJ,OAAO,CAACK,EAAE,CAAC;EAE5B,MAAMe,KAAK,GAAGtB,WAAW,CACvB,CAACU,IAAmB,EAAEC,MAAwB,KAAK;IACjD,OAAOH,SAAS,CAACF,IAAI,EAAE;MAAEI,IAAI;MAAEC;IAAO,CAAC,CAAC;EAC1C,CAAC,EACD,CAACL,IAAI,CACP,CAAC;EAED,OAAO;IAAEgB;EAAM,CAAC;AAClB"}
1
+ {"version":3,"file":"Count.js","names":["useCallback","pointer","useData","getData","Count","props","data","id","countData","_ref","path","filter","has","value","get","Array","isArray","length","Object","entries","keys","NaN","count","useCount","arguments","undefined"],"sources":["../../../../../../src/extensions/forms/Iterate/Count/Count.tsx"],"sourcesContent":["import { useCallback } from 'react'\nimport pointer from '../../utils/json-pointer'\nimport { Identifier, Path } from '../../types'\nimport { useData, getData } from '../../Form'\n\nexport type Props = {\n /**\n * The path (JSON Pointer) to the array or object to count.\n */\n path: Path\n\n /**\n * A Form.Handler or DataContext `id` for when called outside of the context.\n */\n id?: Identifier\n\n /**\n * A filter function to filter the data before counting.\n */\n filter?: (item: unknown) => boolean\n}\n\nexport function Count(props: Props) {\n const { data } = useData(props.id)\n return countData(data, props)\n}\n\nfunction countData(data: unknown, { path, filter }: Props) {\n if (pointer.has(data, path)) {\n const value = pointer.get(data, path)\n if (Array.isArray(value)) {\n return filter ? value.filter(filter).length : value.length\n } else if (typeof value === 'object' && value) {\n return filter\n ? Object.entries(value).filter(filter).length\n : Object.keys(value).length\n }\n }\n\n return NaN\n}\n\nexport function count(props: Props) {\n const { data } = getData(props.id)\n return countData(data, props)\n}\n\nexport function useCount(id: Identifier = undefined) {\n const { data } = useData(id)\n\n const count = useCallback(\n (path: Props['path'], filter?: Props['filter']) => {\n return countData(data, { path, filter })\n },\n [data]\n )\n\n return { count }\n}\n"],"mappings":"AAAA,SAASA,WAAW,QAAQ,OAAO;AACnC,OAAOC,OAAO,MAAM,0BAA0B;AAE9C,SAASC,OAAO,EAAEC,OAAO,QAAQ,YAAY;AAmB7C,OAAO,SAASC,KAAKA,CAACC,KAAY,EAAE;EAClC,MAAM;IAAEC;EAAK,CAAC,GAAGJ,OAAO,CAACG,KAAK,CAACE,EAAE,CAAC;EAClC,OAAOC,SAAS,CAACF,IAAI,EAAED,KAAK,CAAC;AAC/B;AAEA,SAASG,SAASA,CAACF,IAAa,EAAAG,IAAA,EAA2B;EAAA,IAAzB;IAAEC,IAAI;IAAEC;EAAc,CAAC,GAAAF,IAAA;EACvD,IAAIR,OAAO,CAACW,GAAG,CAACN,IAAI,EAAEI,IAAI,CAAC,EAAE;IAC3B,MAAMG,KAAK,GAAGZ,OAAO,CAACa,GAAG,CAACR,IAAI,EAAEI,IAAI,CAAC;IACrC,IAAIK,KAAK,CAACC,OAAO,CAACH,KAAK,CAAC,EAAE;MACxB,OAAOF,MAAM,GAAGE,KAAK,CAACF,MAAM,CAACA,MAAM,CAAC,CAACM,MAAM,GAAGJ,KAAK,CAACI,MAAM;IAC5D,CAAC,MAAM,IAAI,OAAOJ,KAAK,KAAK,QAAQ,IAAIA,KAAK,EAAE;MAC7C,OAAOF,MAAM,GACTO,MAAM,CAACC,OAAO,CAACN,KAAK,CAAC,CAACF,MAAM,CAACA,MAAM,CAAC,CAACM,MAAM,GAC3CC,MAAM,CAACE,IAAI,CAACP,KAAK,CAAC,CAACI,MAAM;IAC/B;EACF;EAEA,OAAOI,GAAG;AACZ;AAEA,OAAO,SAASC,KAAKA,CAACjB,KAAY,EAAE;EAClC,MAAM;IAAEC;EAAK,CAAC,GAAGH,OAAO,CAACE,KAAK,CAACE,EAAE,CAAC;EAClC,OAAOC,SAAS,CAACF,IAAI,EAAED,KAAK,CAAC;AAC/B;AAEA,OAAO,SAASkB,QAAQA,CAAA,EAA6B;EAAA,IAA5BhB,EAAc,GAAAiB,SAAA,CAAAP,MAAA,QAAAO,SAAA,QAAAC,SAAA,GAAAD,SAAA,MAAGC,SAAS;EACjD,MAAM;IAAEnB;EAAK,CAAC,GAAGJ,OAAO,CAACK,EAAE,CAAC;EAE5B,MAAMe,KAAK,GAAGtB,WAAW,CACvB,CAACU,IAAmB,EAAEC,MAAwB,KAAK;IACjD,OAAOH,SAAS,CAACF,IAAI,EAAE;MAAEI,IAAI;MAAEC;IAAO,CAAC,CAAC;EAC1C,CAAC,EACD,CAACL,IAAI,CACP,CAAC;EAED,OAAO;IAAEgB;EAAM,CAAC;AAClB"}
@@ -1,6 +1,8 @@
1
1
  "use client";
2
2
 
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
+ const _excluded = ["onClick"];
4
6
  import React, { useCallback, useContext, useEffect, useRef } from 'react';
5
7
  import { Button } from '../../../../components';
6
8
  import useTranslation from '../../hooks/useTranslation';
@@ -10,6 +12,10 @@ import FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryC
10
12
  import { close } from '../../../../icons';
11
13
  import RemoveButton from '../RemoveButton';
12
14
  export default function EditToolbarTools(props) {
15
+ const {
16
+ onClick
17
+ } = props,
18
+ rest = _objectWithoutProperties(props, _excluded);
13
19
  const {
14
20
  restoreOriginalValue,
15
21
  switchContainerMode,
@@ -40,7 +46,11 @@ export default function EditToolbarTools(props) {
40
46
  valueBackupRef.current = null;
41
47
  }
42
48
  }, [arrayValue, containerMode, index]);
43
- const cancelHandler = useCallback(() => {
49
+ const cancelHandler = useCallback(_ref => {
50
+ let {
51
+ event
52
+ } = _ref;
53
+ onClick === null || onClick === void 0 ? void 0 : onClick(event);
44
54
  if (hasError && initialContainerMode === 'auto') {
45
55
  setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
46
56
  if (hasVisibleError) {
@@ -52,7 +62,7 @@ export default function EditToolbarTools(props) {
52
62
  setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
53
63
  switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
54
64
  }
55
- }, [hasError, hasVisibleError, initialContainerMode, restoreOriginalValue, setShowBoundaryErrors, setShowError, switchContainerMode]);
65
+ }, [hasError, hasVisibleError, initialContainerMode, onClick, restoreOriginalValue, setShowBoundaryErrors, setShowError, switchContainerMode]);
56
66
  const wasNew = useWasNew({
57
67
  isNew,
58
68
  containerMode
@@ -62,21 +72,22 @@ export default function EditToolbarTools(props) {
62
72
  }
63
73
  if (wasNew) {
64
74
  return React.createElement(RemoveButton, _extends({
65
- text: removeButton
66
- }, props));
75
+ text: removeButton,
76
+ onClick: onClick
77
+ }, rest));
67
78
  }
68
79
  return React.createElement(Button, _extends({
69
80
  variant: "tertiary",
70
81
  icon: close,
71
82
  icon_position: "left",
72
83
  on_click: cancelHandler
73
- }, props), cancelButton);
84
+ }, rest), cancelButton);
74
85
  }
75
- export function useWasNew(_ref) {
86
+ export function useWasNew(_ref2) {
76
87
  let {
77
88
  isNew,
78
89
  containerMode
79
- } = _ref;
90
+ } = _ref2;
80
91
  const wasNewRef = useRef(isNew);
81
92
  useEffect(() => {
82
93
  if (containerMode === 'view') {
@@ -1 +1 @@
1
- {"version":3,"file":"CancelButton.js","names":["React","useCallback","useContext","useEffect","useRef","Button","useTranslation","IterateItemContext","ToolbarContext","FieldBoundaryContext","close","RemoveButton","EditToolbarTools","props","restoreOriginalValue","switchContainerMode","containerMode","initialContainerMode","arrayValue","isNew","index","hasError","hasVisibleError","setShowBoundaryErrors","setShowError","cancelButton","removeButton","IterateEditContainer","valueBackupRef","current","cancelHandler","wasNew","useWasNew","length","createElement","Fragment","_extends","text","variant","icon","icon_position","on_click","_ref","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/CancelButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { close } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport RemoveButton, { Props as RemoveButtonProps } from '../RemoveButton'\nimport { ContainerMode } from '../Array'\n\ntype Props = ButtonProps\n\nexport default function EditToolbarTools(props: Props) {\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n initialContainerMode,\n arrayValue,\n isNew,\n index,\n } = useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { cancelButton, removeButton } =\n useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(() => {\n if (hasError && initialContainerMode === 'auto') {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n restoreOriginalValue?.(valueBackupRef.current)\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n }\n }, [\n hasError,\n hasVisibleError,\n initialContainerMode,\n restoreOriginalValue,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n const wasNew = useWasNew({ isNew, containerMode })\n\n if (containerMode === 'edit' && arrayValue?.length === 0) {\n return <></>\n }\n\n if (wasNew) {\n return (\n <RemoveButton\n text={removeButton}\n {...(props as RemoveButtonProps)}\n />\n )\n }\n\n return (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n {...props}\n >\n {cancelButton}\n </Button>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"CancelButton.js","names":["React","useCallback","useContext","useEffect","useRef","Button","useTranslation","IterateItemContext","ToolbarContext","FieldBoundaryContext","close","RemoveButton","EditToolbarTools","props","onClick","rest","_objectWithoutProperties","_excluded","restoreOriginalValue","switchContainerMode","containerMode","initialContainerMode","arrayValue","isNew","index","hasError","hasVisibleError","setShowBoundaryErrors","setShowError","cancelButton","removeButton","IterateEditContainer","valueBackupRef","current","cancelHandler","_ref","event","wasNew","useWasNew","length","createElement","Fragment","_extends","text","variant","icon","icon_position","on_click","_ref2","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/CancelButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { close } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport RemoveButton, { Props as RemoveButtonProps } from '../RemoveButton'\nimport { ContainerMode } from '../Array'\n\ntype Props = ButtonProps\n\nexport default function EditToolbarTools(props: Props) {\n const { onClick, ...rest } = props\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n initialContainerMode,\n arrayValue,\n isNew,\n index,\n } = useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { cancelButton, removeButton } =\n useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(\n ({ event }: { event: React.MouseEvent<HTMLButtonElement> }) => {\n onClick?.(event)\n if (hasError && initialContainerMode === 'auto') {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n restoreOriginalValue?.(valueBackupRef.current)\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n }\n },\n [\n hasError,\n hasVisibleError,\n initialContainerMode,\n onClick,\n restoreOriginalValue,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ]\n )\n\n const wasNew = useWasNew({ isNew, containerMode })\n\n if (containerMode === 'edit' && arrayValue?.length === 0) {\n return <></>\n }\n\n if (wasNew) {\n return (\n <RemoveButton\n text={removeButton}\n onClick={onClick}\n {...(rest as RemoveButtonProps)}\n />\n )\n }\n\n return (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n {...rest}\n >\n {cancelButton}\n </Button>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}
@@ -59,8 +59,8 @@ export function EditContainerWithoutToolbar(props) {
59
59
  });
60
60
  let itemTitle = wasNew && titleWhenNew ? titleWhenNew : title;
61
61
  let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle]);
62
- if (ariaLabel.includes('{itemNr}')) {
63
- itemTitle = ariaLabel = ariaLabel.replace('{itemNr}', index + 1);
62
+ if (ariaLabel.includes('{itemN')) {
63
+ itemTitle = ariaLabel = ariaLabel.replace(/\{itemN(r|o)\}/g, String(index + 1));
64
64
  }
65
65
  useSwitchContainerMode({
66
66
  path
@@ -1 +1 @@
1
- {"version":3,"file":"EditContainer.js","names":["React","useContext","useMemo","classnames","convertJsxToString","Lead","IterateItemContext","ArrayItemArea","Toolbar","useSwitchContainerMode","DoneButton","CancelButton","useWasNew","EditContainer","props","_toolbarElement","toolbar","toolbarVariant","children","rest","_objectWithoutProperties","_excluded","arrayValue","toolbarElement","length","createElement","Fragment","hasToolbar","Children","toArray","some","child","EditContainerWithoutToolbar","_extends","_Toolbar","containerMode","isNew","index","path","_ref","className","title","titleWhenNew","restProps","_excluded2","wasNew","itemTitle","ariaLabel","includes","replace","mode","size","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Lead } from '../../../../elements'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport IterateItemContext from '../IterateItemContext'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport Toolbar from '../Toolbar'\nimport { useSwitchContainerMode } from '../hooks'\nimport DoneButton from './DoneButton'\nimport CancelButton, { useWasNew } from './CancelButton'\n\nexport type Props = {\n /**\n * The title of the EditContainer.\n */\n title?: React.ReactNode\n\n /**\n * The title for a new item show within the EditContainer.\n */\n titleWhenNew?: React.ReactNode\n\n /**\n * If the EditContainer is open or not.\n */\n open?: boolean\n\n /**\n * An alternative toolbar to be shown in the EditContainer.\n */\n toolbar?: React.ReactNode\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: 'minimumOneItem'\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nexport default function EditContainer(props: AllProps) {\n const { toolbar, toolbarVariant, children, ...rest } = props\n const { arrayValue } = useContext(IterateItemContext)\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = <></>\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <EditContainerWithoutToolbar\n toolbar={\n hasToolbar\n ? null\n : toolbarElement ?? (\n <Toolbar>\n <DoneButton />\n <CancelButton />\n </Toolbar>\n )\n }\n {...rest}\n >\n {children}\n </EditContainerWithoutToolbar>\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const { containerMode, isNew, index, path } =\n useContext(IterateItemContext)\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n ...restProps\n } = props || {}\n\n const wasNew = useWasNew({ isNew, containerMode })\n let itemTitle = wasNew && titleWhenNew ? titleWhenNew : title\n let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle])\n if (ariaLabel.includes('{itemNr}')) {\n itemTitle = ariaLabel = ariaLabel.replace('{itemNr}', index + 1)\n }\n\n useSwitchContainerMode({ path })\n\n return (\n <ArrayItemArea\n mode=\"edit\"\n className={classnames('dnb-forms-section-edit-block', className)}\n ariaLabel={ariaLabel}\n {...restProps}\n >\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {toolbar}\n </ArrayItemArea>\n )\n}\n\nEditContainer.DoneButton = DoneButton\nEditContainer.CancelButton = CancelButton\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":"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"}
1
+ {"version":3,"file":"EditContainer.js","names":["React","useContext","useMemo","classnames","convertJsxToString","Lead","IterateItemContext","ArrayItemArea","Toolbar","useSwitchContainerMode","DoneButton","CancelButton","useWasNew","EditContainer","props","_toolbarElement","toolbar","toolbarVariant","children","rest","_objectWithoutProperties","_excluded","arrayValue","toolbarElement","length","createElement","Fragment","hasToolbar","Children","toArray","some","child","EditContainerWithoutToolbar","_extends","_Toolbar","containerMode","isNew","index","path","_ref","className","title","titleWhenNew","restProps","_excluded2","wasNew","itemTitle","ariaLabel","includes","replace","String","mode","size","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Lead } from '../../../../elements'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport IterateItemContext from '../IterateItemContext'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport Toolbar from '../Toolbar'\nimport { useSwitchContainerMode } from '../hooks'\nimport DoneButton from './DoneButton'\nimport CancelButton, { useWasNew } from './CancelButton'\n\nexport type Props = {\n /**\n * The title of the EditContainer.\n */\n title?: React.ReactNode\n\n /**\n * The title for a new item show within the EditContainer.\n */\n titleWhenNew?: React.ReactNode\n\n /**\n * If the EditContainer is open or not.\n */\n open?: boolean\n\n /**\n * An alternative toolbar to be shown in the EditContainer.\n */\n toolbar?: React.ReactNode\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: 'minimumOneItem'\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nexport default function EditContainer(props: AllProps) {\n const { toolbar, toolbarVariant, children, ...rest } = props\n const { arrayValue } = useContext(IterateItemContext)\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = <></>\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <EditContainerWithoutToolbar\n toolbar={\n hasToolbar\n ? null\n : toolbarElement ?? (\n <Toolbar>\n <DoneButton />\n <CancelButton />\n </Toolbar>\n )\n }\n {...rest}\n >\n {children}\n </EditContainerWithoutToolbar>\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const { containerMode, isNew, index, path } =\n useContext(IterateItemContext)\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n ...restProps\n } = props || {}\n\n const wasNew = useWasNew({ isNew, containerMode })\n let itemTitle = wasNew && titleWhenNew ? titleWhenNew : title\n let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle])\n if (ariaLabel.includes('{itemN')) {\n /**\n * {itemNr} is deprecated, and can be removed in v11 in favor of {itemNo}\n * So in v11 we can use '{itemNo}' instead of a regex\n */\n itemTitle = ariaLabel = ariaLabel.replace(\n /\\{itemN(r|o)\\}/g,\n String(index + 1)\n )\n }\n\n useSwitchContainerMode({ path })\n\n return (\n <ArrayItemArea\n mode=\"edit\"\n className={classnames('dnb-forms-section-edit-block', className)}\n ariaLabel={ariaLabel}\n {...restProps}\n >\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {toolbar}\n </ArrayItemArea>\n )\n}\n\nEditContainer.DoneButton = DoneButton\nEditContainer.CancelButton = CancelButton\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":"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"}
@@ -7,7 +7,7 @@ import React, { useCallback, useContext, useMemo } from 'react';
7
7
  import classnames from 'classnames';
8
8
  import { Button } from '../../../../components';
9
9
  import IterateItemContext from '../IterateItemContext';
10
- import { useSwitchContainerMode } from '../hooks';
10
+ import { useArrayLimit, useSwitchContainerMode } from '../hooks';
11
11
  import { omitDataValueReadWriteProps } from '../../types';
12
12
  import { add } from '../../../../icons';
13
13
  import DataContext from '../../DataContext/Context';
@@ -31,6 +31,12 @@ function PushButton(props) {
31
31
  restProps = _objectWithoutProperties(props, _excluded);
32
32
  const buttonProps = omitDataValueReadWriteProps(restProps);
33
33
  const arrayValue = useDataValue().getValueByPath(path);
34
+ const {
35
+ hasReachedLimit,
36
+ setShowStatus
37
+ } = useArrayLimit({
38
+ path
39
+ });
34
40
  if (arrayValue !== undefined && !Array.isArray(arrayValue)) {
35
41
  throw new Error('PushButton received a non-array value');
36
42
  }
@@ -40,6 +46,10 @@ function PushButton(props) {
40
46
  path
41
47
  });
42
48
  const handleClick = useCallback(async () => {
49
+ if (hasReachedLimit) {
50
+ setShowStatus(true);
51
+ return;
52
+ }
43
53
  const newValue = typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue;
44
54
  if (handlePush) {
45
55
  handlePush(newValue);
@@ -49,7 +59,7 @@ function PushButton(props) {
49
59
  setTimeout(() => {
50
60
  setLastItemContainerMode('view');
51
61
  }, 100);
52
- }, [handlePathChange, handlePush, path, pushValue, setLastItemContainerMode, arrayValue]);
62
+ }, [arrayValue, handlePathChange, handlePush, hasReachedLimit, path, pushValue, setLastItemContainerMode, setShowStatus]);
53
63
  const content = useMemo(() => {
54
64
  if (children || text) {
55
65
  const str = convertJsxToString(children || text);
@@ -1 +1 @@
1
- {"version":3,"file":"PushButton.js","names":["React","useCallback","useContext","useMemo","classnames","Button","IterateItemContext","useSwitchContainerMode","omitDataValueReadWriteProps","add","DataContext","useDataValue","convertJsxToString","PushButton","props","handlePathChange","iterateItemContext","handlePush","pushValue","className","path","text","children","restProps","_objectWithoutProperties","_excluded","buttonProps","arrayValue","getValueByPath","undefined","Array","isArray","Error","setLastItemContainerMode","handleClick","newValue","setTimeout","content","str","includes","nextItemNo","length","replace","String","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateItemContext from '../IterateItemContext'\nimport { useSwitchContainerMode } from '../hooks'\nimport { omitDataValueReadWriteProps, Path } from '../../types'\nimport { add } from '../../../../icons'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\nexport type Props = ButtonProps & {\n path?: Path\n pushValue: unknown | ((value: unknown) => void)\n\n /**\n * Used internally\n */\n value?: unknown\n}\n\nfunction PushButton(props: Props) {\n const { handlePathChange } = useContext(DataContext) || {}\n const iterateItemContext = useContext(IterateItemContext)\n const { handlePush } = iterateItemContext ?? {}\n\n const { pushValue, className, path, text, children, ...restProps } =\n props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const arrayValue = useDataValue().getValueByPath(path)\n\n if (arrayValue !== undefined && !Array.isArray(arrayValue)) {\n throw new Error('PushButton received a non-array value')\n }\n\n const { setLastItemContainerMode } = useSwitchContainerMode({\n path,\n })\n\n const handleClick = useCallback(async () => {\n const newValue =\n typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue\n\n if (handlePush) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n } else {\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n await handlePathChange?.(path, [...(arrayValue ?? []), newValue])\n }\n\n setTimeout(() => {\n setLastItemContainerMode('view')\n }, 100) // UX improvement because of the \"openDelay\"\n }, [\n handlePathChange,\n handlePush,\n path,\n pushValue,\n setLastItemContainerMode,\n arrayValue,\n ])\n\n const content = useMemo(() => {\n if (children || text) {\n const str = convertJsxToString(children || text)\n\n if (str.includes('{nextItemNo}')) {\n const nextItemNo = (arrayValue?.length || 0) + 1\n return str.replace('{nextItemNo}', String(nextItemNo))\n }\n }\n\n return children || text\n }, [arrayValue?.length, children, text])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-push-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {content}\n </Button>\n )\n}\n\nPushButton._supportsSpacingProps = true\nexport default PushButton\n"],"mappings":"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"}
1
+ {"version":3,"file":"PushButton.js","names":["React","useCallback","useContext","useMemo","classnames","Button","IterateItemContext","useArrayLimit","useSwitchContainerMode","omitDataValueReadWriteProps","add","DataContext","useDataValue","convertJsxToString","PushButton","props","handlePathChange","iterateItemContext","handlePush","pushValue","className","path","text","children","restProps","_objectWithoutProperties","_excluded","buttonProps","arrayValue","getValueByPath","hasReachedLimit","setShowStatus","undefined","Array","isArray","Error","setLastItemContainerMode","handleClick","newValue","setTimeout","content","str","includes","nextItemNo","length","replace","String","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateItemContext from '../IterateItemContext'\nimport { useArrayLimit, useSwitchContainerMode } from '../hooks'\nimport { omitDataValueReadWriteProps, Path } from '../../types'\nimport { add } from '../../../../icons'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\nexport type Props = ButtonProps & {\n path?: Path\n pushValue: unknown | ((value: unknown) => void)\n\n /**\n * Used internally\n */\n value?: unknown\n}\n\nfunction PushButton(props: Props) {\n const { handlePathChange } = useContext(DataContext) || {}\n const iterateItemContext = useContext(IterateItemContext)\n const { handlePush } = iterateItemContext ?? {}\n\n const { pushValue, className, path, text, children, ...restProps } =\n props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const arrayValue = useDataValue().getValueByPath(path)\n const { hasReachedLimit, setShowStatus } = useArrayLimit({\n path,\n })\n\n if (arrayValue !== undefined && !Array.isArray(arrayValue)) {\n throw new Error('PushButton received a non-array value')\n }\n\n const { setLastItemContainerMode } = useSwitchContainerMode({\n path,\n })\n\n const handleClick = useCallback(async () => {\n if (hasReachedLimit) {\n setShowStatus(true)\n return // stop here\n }\n\n const newValue =\n typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue\n\n if (handlePush) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n } else {\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n await handlePathChange?.(path, [...(arrayValue ?? []), newValue])\n }\n\n setTimeout(() => {\n setLastItemContainerMode('view')\n }, 100) // UX improvement because of the \"openDelay\"\n }, [\n arrayValue,\n handlePathChange,\n handlePush,\n hasReachedLimit,\n path,\n pushValue,\n setLastItemContainerMode,\n setShowStatus,\n ])\n\n const content = useMemo(() => {\n if (children || text) {\n const str = convertJsxToString(children || text)\n\n if (str.includes('{nextItemNo}')) {\n const nextItemNo = (arrayValue?.length || 0) + 1\n return str.replace('{nextItemNo}', String(nextItemNo))\n }\n }\n\n return children || text\n }, [arrayValue?.length, children, text])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-push-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {content}\n </Button>\n )\n}\n\nPushButton._supportsSpacingProps = true\nexport default PushButton\n"],"mappings":"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"}
@@ -3,9 +3,8 @@
3
3
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
4
  import _extends from "@babel/runtime/helpers/esm/extends";
5
5
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
6
- var _CancelButton;
7
6
  const _excluded = ["data", "path", "title", "children", "openButton", "showOpenButtonWhen"],
8
- _excluded2 = ["title", "openButton", "showOpenButton", "switchContainerModeRef", "children"];
7
+ _excluded2 = ["title", "openButton", "showOpenButton", "switchContainerModeRef", "cancelHandler", "children"];
9
8
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
10
9
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
11
10
  import React, { useCallback, useContext, useMemo, useRef } from 'react';
@@ -18,7 +17,7 @@ import EditContainer, { CancelButton, DoneButton } from '../EditContainer';
18
17
  import IterateArray from '../Array';
19
18
  import OpenButton from './OpenButton';
20
19
  import { Flex, HeightAnimation } from '../../../../components';
21
- import { useSwitchContainerMode } from '../hooks';
20
+ import { useArrayLimit, useSwitchContainerMode } from '../hooks';
22
21
  import Toolbar from '../Toolbar';
23
22
  import { useTranslation } from '../../hooks';
24
23
  function PushContainer(props) {
@@ -44,6 +43,17 @@ function PushContainer(props) {
44
43
  } = useSwitchContainerMode({
45
44
  path
46
45
  });
46
+ const {
47
+ hasReachedLimit,
48
+ setShowStatus
49
+ } = useArrayLimit({
50
+ path
51
+ });
52
+ const cancelHandler = useCallback(() => {
53
+ if (hasReachedLimit) {
54
+ setShowStatus(false);
55
+ }
56
+ }, [hasReachedLimit, setShowStatus]);
47
57
  const showOpenButton = showOpenButtonWhen === null || showOpenButtonWhen === void 0 ? void 0 : showOpenButtonWhen(entries);
48
58
  const newItemContextProps = {
49
59
  path,
@@ -67,13 +77,19 @@ function PushContainer(props) {
67
77
  return moveValueToPath(path, [...entries, ...newItems]);
68
78
  },
69
79
  onCommit: (data, _ref2) => {
70
- var _switchContainerModeR;
71
80
  let {
72
- clearData
81
+ clearData,
82
+ preventCommit
73
83
  } = _ref2;
74
- setNextContainerMode('view');
75
- (_switchContainerModeR = switchContainerModeRef.current) === null || _switchContainerModeR === void 0 ? void 0 : _switchContainerModeR.call(switchContainerModeRef, 'view');
76
- clearData();
84
+ if (hasReachedLimit) {
85
+ preventCommit();
86
+ setShowStatus(true);
87
+ } else {
88
+ var _switchContainerModeR;
89
+ setNextContainerMode('view');
90
+ (_switchContainerModeR = switchContainerModeRef.current) === null || _switchContainerModeR === void 0 ? void 0 : _switchContainerModeR.call(switchContainerModeRef, 'view');
91
+ clearData();
92
+ }
77
93
  }
78
94
  }, React.createElement(PushContainerContext.Provider, {
79
95
  value: newItemContextProps
@@ -84,16 +100,18 @@ function PushContainer(props) {
84
100
  title: title,
85
101
  openButton: openButton,
86
102
  switchContainerModeRef: switchContainerModeRef,
87
- showOpenButton: showOpenButton
103
+ showOpenButton: showOpenButton,
104
+ cancelHandler: cancelHandler
88
105
  }, rest), children))));
89
106
  }
90
107
  function NewContainer(_ref3) {
91
- var _DoneButton;
108
+ var _DoneButton, _CancelButton;
92
109
  let {
93
110
  title,
94
111
  openButton,
95
112
  showOpenButton,
96
113
  switchContainerModeRef,
114
+ cancelHandler,
97
115
  children
98
116
  } = _ref3,
99
117
  rest = _objectWithoutProperties(_ref3, _excluded2);
@@ -121,7 +139,9 @@ function NewContainer(_ref3) {
121
139
  gap: "large"
122
140
  }, _DoneButton || (_DoneButton = React.createElement(DoneButton, {
123
141
  text: createButton
124
- })), showOpenButton && (_CancelButton || (_CancelButton = React.createElement(CancelButton, null)))));
142
+ })), showOpenButton && (_CancelButton || (_CancelButton = React.createElement(CancelButton, {
143
+ onClick: cancelHandler
144
+ })))));
125
145
  }));
126
146
  return React.createElement(React.Fragment, null, React.createElement(EditContainer, _extends({
127
147
  open: !showOpenButton || containerMode === 'edit',
@@ -1 +1 @@
1
- {"version":3,"file":"PushContainer.js","names":["React","useCallback","useContext","useMemo","useRef","Isolation","PushContainerContext","IterateItemContext","DataContext","useDataValue","EditContainer","CancelButton","DoneButton","IterateArray","OpenButton","Flex","HeightAnimation","useSwitchContainerMode","Toolbar","useTranslation","PushContainer","props","data","path","title","children","openButton","showOpenButtonWhen","rest","_objectWithoutProperties","_excluded","commitHandleRef","switchContainerModeRef","value","entries","moveValueToPath","setNextContainerMode","showOpenButton","newItemContextProps","switchContainerMode","current","defaultData","newItems","createElement","emptyData","transformOnCommit","_ref","onCommit","_ref2","_switchContainerModeR","clearData","call","Provider","containerMode","NewContainer","_extends","_ref3","_DoneButton","_excluded2","createButton","IteratePushContainer","restoreOriginalValue","toolbar","Consumer","context","_objectSpread","Horizontal","gap","text","_CancelButton","Fragment","open","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo, useRef } from 'react'\nimport Isolation from '../../Form/Isolation'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer, { CancelButton, DoneButton } from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport { Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\nimport { useSwitchContainerMode } from '../hooks'\nimport Toolbar from '../Toolbar'\nimport { useTranslation } from '../../hooks'\nimport { ArrayItemAreaProps } from '../Array/ArrayItemArea'\n\nexport type Props = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields.\n */\n data?: unknown | Record<string, unknown>\n\n /**\n * A custom toolbar to be shown below the container.\n */\n toolbar?: React.ReactNode\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props & SpacingProps & ArrayItemAreaProps\n\nfunction PushContainer(props: AllProps) {\n const {\n data = null,\n path,\n title,\n children,\n openButton,\n showOpenButtonWhen,\n ...rest\n } = props\n\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const { value: entries = [], moveValueToPath } = useDataValue<\n Array<unknown>\n >({ path })\n\n const { setNextContainerMode } = useSwitchContainerMode({ path })\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n const defaultData = useMemo(() => {\n return { newItems: [data] }\n }, [data])\n\n return (\n <Isolation\n defaultData={defaultData}\n emptyData={defaultData}\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ newItems }) => {\n return moveValueToPath(path, [...entries, ...newItems])\n }}\n onCommit={(data, { clearData }) => {\n setNextContainerMode('view')\n switchContainerModeRef.current?.('view')\n clearData()\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray\n path=\"/newItems\"\n containerMode={showOpenButton ? 'view' : 'edit'}\n >\n <NewContainer\n title={title}\n openButton={openButton}\n switchContainerModeRef={switchContainerModeRef}\n showOpenButton={showOpenButton}\n {...rest}\n >\n {children}\n </NewContainer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nfunction NewContainer({\n title,\n openButton,\n showOpenButton,\n switchContainerModeRef,\n children,\n ...rest\n}) {\n const { containerMode, switchContainerMode } =\n useContext(IterateItemContext) || {}\n switchContainerModeRef.current = switchContainerMode\n const { createButton } = useTranslation().IteratePushContainer\n const { clearData } = useContext(DataContext) || {}\n const restoreOriginalValue = useCallback(() => {\n clearData?.()\n }, [clearData])\n\n const toolbar = (\n <Toolbar>\n <IterateItemContext.Consumer>\n {(context) => {\n const newItemContextProps = {\n ...context,\n restoreOriginalValue,\n }\n return (\n <IterateItemContext.Provider value={newItemContextProps}>\n <Flex.Horizontal gap=\"large\">\n <DoneButton text={createButton} />\n {showOpenButton && <CancelButton />}\n </Flex.Horizontal>\n </IterateItemContext.Provider>\n )\n }}\n </IterateItemContext.Consumer>\n </Toolbar>\n )\n\n return (\n <>\n <EditContainer\n open={!showOpenButton || containerMode === 'edit'}\n title={title}\n toolbar={toolbar}\n {...rest}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation open={showOpenButton && containerMode === 'view'}>\n {openButton}\n </HeightAnimation>\n )}\n </>\n )\n}\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":"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"}
1
+ {"version":3,"file":"PushContainer.js","names":["React","useCallback","useContext","useMemo","useRef","Isolation","PushContainerContext","IterateItemContext","DataContext","useDataValue","EditContainer","CancelButton","DoneButton","IterateArray","OpenButton","Flex","HeightAnimation","useArrayLimit","useSwitchContainerMode","Toolbar","useTranslation","PushContainer","props","data","path","title","children","openButton","showOpenButtonWhen","rest","_objectWithoutProperties","_excluded","commitHandleRef","switchContainerModeRef","value","entries","moveValueToPath","setNextContainerMode","hasReachedLimit","setShowStatus","cancelHandler","showOpenButton","newItemContextProps","switchContainerMode","current","defaultData","newItems","createElement","emptyData","transformOnCommit","_ref","onCommit","_ref2","clearData","preventCommit","_switchContainerModeR","call","Provider","containerMode","NewContainer","_extends","_ref3","_DoneButton","_CancelButton","_excluded2","createButton","IteratePushContainer","restoreOriginalValue","toolbar","Consumer","context","_objectSpread","Horizontal","gap","text","onClick","Fragment","open","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo, useRef } from 'react'\nimport Isolation from '../../Form/Isolation'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer, { CancelButton, DoneButton } from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport { Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\nimport { useArrayLimit, useSwitchContainerMode } from '../hooks'\nimport Toolbar from '../Toolbar'\nimport { useTranslation } from '../../hooks'\nimport { ArrayItemAreaProps } from '../Array/ArrayItemArea'\n\nexport type Props = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields.\n */\n data?: unknown | Record<string, unknown>\n\n /**\n * A custom toolbar to be shown below the container.\n */\n toolbar?: React.ReactNode\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props & SpacingProps & ArrayItemAreaProps\n\nfunction PushContainer(props: AllProps) {\n const {\n data = null,\n path,\n title,\n children,\n openButton,\n showOpenButtonWhen,\n ...rest\n } = props\n\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const { value: entries = [], moveValueToPath } = useDataValue<\n Array<unknown>\n >({ path })\n\n const { setNextContainerMode } = useSwitchContainerMode({ path })\n const { hasReachedLimit, setShowStatus } = useArrayLimit({\n path,\n })\n const cancelHandler = useCallback(() => {\n if (hasReachedLimit) {\n setShowStatus(false)\n }\n }, [hasReachedLimit, setShowStatus])\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n const defaultData = useMemo(() => {\n return { newItems: [data] }\n }, [data])\n\n return (\n <Isolation\n defaultData={defaultData}\n emptyData={defaultData}\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ newItems }) => {\n return moveValueToPath(path, [...entries, ...newItems])\n }}\n onCommit={(data, { clearData, preventCommit }) => {\n if (hasReachedLimit) {\n preventCommit()\n setShowStatus(true)\n } else {\n setNextContainerMode('view')\n switchContainerModeRef.current?.('view')\n clearData()\n }\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray\n path=\"/newItems\"\n containerMode={showOpenButton ? 'view' : 'edit'}\n >\n <NewContainer\n title={title}\n openButton={openButton}\n switchContainerModeRef={switchContainerModeRef}\n showOpenButton={showOpenButton}\n cancelHandler={cancelHandler}\n {...rest}\n >\n {children}\n </NewContainer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nfunction NewContainer({\n title,\n openButton,\n showOpenButton,\n switchContainerModeRef,\n cancelHandler,\n children,\n ...rest\n}) {\n const { containerMode, switchContainerMode } =\n useContext(IterateItemContext) || {}\n switchContainerModeRef.current = switchContainerMode\n const { createButton } = useTranslation().IteratePushContainer\n const { clearData } = useContext(DataContext) || {}\n const restoreOriginalValue = useCallback(() => {\n clearData?.()\n }, [clearData])\n\n const toolbar = (\n <Toolbar>\n <IterateItemContext.Consumer>\n {(context) => {\n const newItemContextProps = {\n ...context,\n restoreOriginalValue,\n }\n return (\n <IterateItemContext.Provider value={newItemContextProps}>\n <Flex.Horizontal gap=\"large\">\n <DoneButton text={createButton} />\n {showOpenButton && (\n <CancelButton onClick={cancelHandler} />\n )}\n </Flex.Horizontal>\n </IterateItemContext.Provider>\n )\n }}\n </IterateItemContext.Consumer>\n </Toolbar>\n )\n\n return (\n <>\n <EditContainer\n open={!showOpenButton || containerMode === 'edit'}\n title={title}\n toolbar={toolbar}\n {...rest}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation open={showOpenButton && containerMode === 'view'}>\n {openButton}\n </HeightAnimation>\n )}\n </>\n )\n}\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":"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"}
@@ -31,8 +31,8 @@ function ViewContainer(props) {
31
31
  } = useContext(IterateItemContext);
32
32
  let itemTitle = title;
33
33
  let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle]);
34
- if (ariaLabel.includes('{itemNr}')) {
35
- itemTitle = ariaLabel = ariaLabel.replace('{itemNr}', index + 1);
34
+ if (ariaLabel.includes('{itemN')) {
35
+ itemTitle = ariaLabel = ariaLabel.replace(/\{itemN(r|o)\}/g, String(index + 1));
36
36
  }
37
37
  let toolbarElement = toolbar;
38
38
  if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {
@@ -1 +1 @@
1
- {"version":3,"file":"ViewContainer.js","names":["React","useContext","useMemo","classnames","convertJsxToString","Flex","Lead","ArrayItemArea","IterateItemContext","Toolbar","EditButton","RemoveButton","ViewContainer","props","_toolbarElement","_ref","children","className","title","toolbar","toolbarVariant","restProps","_objectWithoutProperties","_excluded","index","arrayValue","itemTitle","ariaLabel","includes","replace","toolbarElement","length","_Toolbar","createElement","hasToolbar","Children","toArray","some","child","_extends","mode","Stack","size","_Toolbar2","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { Lead } from '../../../../elements'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport IterateItemContext from '../IterateItemContext'\nimport Toolbar from '../Toolbar'\nimport EditButton from './EditButton'\nimport RemoveButton from './RemoveButton'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n /**\n * An alternative toolbar to be shown in the ViewContainer.\n */\n toolbar?: React.ReactNode\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: 'minimumOneItem'\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nfunction ViewContainer(props: AllProps) {\n const {\n children,\n className,\n title,\n toolbar,\n toolbarVariant,\n ...restProps\n } = props || {}\n const { index, arrayValue } = useContext(IterateItemContext)\n\n let itemTitle = title\n let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle])\n if (ariaLabel.includes('{itemNr}')) {\n itemTitle = ariaLabel = ariaLabel.replace('{itemNr}', index + 1)\n }\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = (\n <Toolbar>\n <EditButton />\n </Toolbar>\n )\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <ArrayItemArea\n mode=\"view\"\n ariaLabel={ariaLabel}\n className={classnames('dnb-forms-section-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {hasToolbar\n ? null\n : toolbarElement ?? (\n <Toolbar>\n <EditButton />\n <RemoveButton />\n </Toolbar>\n )}\n </Flex.Stack>\n </ArrayItemArea>\n )\n}\n\nViewContainer.EditButton = EditButton\nViewContainer.RemoveButton = RemoveButton\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,aAAa,MAA8B,wBAAwB;AAC1E,OAAOC,kBAAkB,MAAM,uBAAuB;AACtD,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,UAAU,MAAM,cAAc;AACrC,OAAOC,YAAY,MAAM,gBAAgB;AAmBzC,SAASC,aAAaA,CAACC,KAAe,EAAE;EAAA,IAAAC,eAAA;EACtC,MAAAC,IAAA,GAOIF,KAAK,IAAI,CAAC,CAAC;IAPT;MACJG,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,OAAO;MACPC;IAEF,CAAC,GAAAL,IAAA;IADIM,SAAS,GAAAC,wBAAA,CAAAP,IAAA,EAAAQ,SAAA;EAEd,MAAM;IAAEC,KAAK;IAAEC;EAAW,CAAC,GAAGxB,UAAU,CAACO,kBAAkB,CAAC;EAE5D,IAAIkB,SAAS,GAAGR,KAAK;EACrB,IAAIS,SAAS,GAAGzB,OAAO,CAAC,MAAME,kBAAkB,CAACsB,SAAS,CAAC,EAAE,CAACA,SAAS,CAAC,CAAC;EACzE,IAAIC,SAAS,CAACC,QAAQ,CAAC,UAAU,CAAC,EAAE;IAClCF,SAAS,GAAGC,SAAS,GAAGA,SAAS,CAACE,OAAO,CAAC,UAAU,EAAEL,KAAK,GAAG,CAAC,CAAC;EAClE;EAEA,IAAIM,cAAc,GAAGX,OAAO;EAC5B,IAAIC,cAAc,KAAK,gBAAgB,IAAIK,UAAU,CAACM,MAAM,IAAI,CAAC,EAAE;IACjED,cAAc,GAAAE,QAAA,KAAAA,QAAA,GACZhC,KAAA,CAAAiC,aAAA,CAACxB,OAAO,QACNT,KAAA,CAAAiC,aAAA,CAACvB,UAAU,MAAE,CACN,CAAC,CACX;EACH;EAEA,MAAMwB,UAAU,GACd,CAACJ,cAAc,IACf9B,KAAK,CAACmC,QAAQ,CAACC,OAAO,CAACpB,QAAQ,CAAC,CAACqB,IAAI,CAAEC,KAAK,IAAK;IAC/C,OAAO,CAAAA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,MAAM,CAAC,MAAK7B,OAAO;EACpC,CAAC,CAAC;EAEJ,OACET,KAAA,CAAAiC,aAAA,CAAC1B,aAAa,EAAAgC,QAAA;IACZC,IAAI,EAAC,MAAM;IACXb,SAAS,EAAEA,SAAU;IACrBV,SAAS,EAAEd,UAAU,CAAC,8BAA8B,EAAEc,SAAS;EAAE,GAC7DI,SAAS,GAEbrB,KAAA,CAAAiC,aAAA,CAAC5B,IAAI,CAACoC,KAAK,QACRf,SAAS,IAAI1B,KAAA,CAAAiC,aAAA,CAAC3B,IAAI;IAACoC,IAAI,EAAC;EAAO,GAAEhB,SAAgB,CAAC,EAClDV,QAAQ,EACRkB,UAAU,GACP,IAAI,IAAApB,eAAA,GACJgB,cAAc,cAAAhB,eAAA,cAAAA,eAAA,GAAA6B,SAAA,KAAAA,SAAA,GACZ3C,KAAA,CAAAiC,aAAA,CAACxB,OAAO,QACNT,KAAA,CAAAiC,aAAA,CAACvB,UAAU,MAAE,CAAC,EACdV,KAAA,CAAAiC,aAAA,CAACtB,YAAY,MAAE,CACR,CAAC,CAEN,CACC,CAAC;AAEpB;AAEAC,aAAa,CAACF,UAAU,GAAGA,UAAU;AACrCE,aAAa,CAACD,YAAY,GAAGA,YAAY;AAEzCC,aAAa,CAACgC,qBAAqB,GAAG,IAAI;AAC1C,eAAehC,aAAa"}
1
+ {"version":3,"file":"ViewContainer.js","names":["React","useContext","useMemo","classnames","convertJsxToString","Flex","Lead","ArrayItemArea","IterateItemContext","Toolbar","EditButton","RemoveButton","ViewContainer","props","_toolbarElement","_ref","children","className","title","toolbar","toolbarVariant","restProps","_objectWithoutProperties","_excluded","index","arrayValue","itemTitle","ariaLabel","includes","replace","String","toolbarElement","length","_Toolbar","createElement","hasToolbar","Children","toArray","some","child","_extends","mode","Stack","size","_Toolbar2","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { Lead } from '../../../../elements'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport IterateItemContext from '../IterateItemContext'\nimport Toolbar from '../Toolbar'\nimport EditButton from './EditButton'\nimport RemoveButton from './RemoveButton'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n /**\n * An alternative toolbar to be shown in the ViewContainer.\n */\n toolbar?: React.ReactNode\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: 'minimumOneItem'\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nfunction ViewContainer(props: AllProps) {\n const {\n children,\n className,\n title,\n toolbar,\n toolbarVariant,\n ...restProps\n } = props || {}\n const { index, arrayValue } = useContext(IterateItemContext)\n\n let itemTitle = title\n let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle])\n if (ariaLabel.includes('{itemN')) {\n /**\n * {itemNr} is deprecated, and can be removed in v11 in favor of {itemNo}\n * So in v11 we can use '{itemNo}' instead of a regex\n */\n itemTitle = ariaLabel = ariaLabel.replace(\n /\\{itemN(r|o)\\}/g,\n String(index + 1)\n )\n }\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = (\n <Toolbar>\n <EditButton />\n </Toolbar>\n )\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <ArrayItemArea\n mode=\"view\"\n ariaLabel={ariaLabel}\n className={classnames('dnb-forms-section-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {hasToolbar\n ? null\n : toolbarElement ?? (\n <Toolbar>\n <EditButton />\n <RemoveButton />\n </Toolbar>\n )}\n </Flex.Stack>\n </ArrayItemArea>\n )\n}\n\nViewContainer.EditButton = EditButton\nViewContainer.RemoveButton = RemoveButton\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,aAAa,MAA8B,wBAAwB;AAC1E,OAAOC,kBAAkB,MAAM,uBAAuB;AACtD,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,UAAU,MAAM,cAAc;AACrC,OAAOC,YAAY,MAAM,gBAAgB;AAmBzC,SAASC,aAAaA,CAACC,KAAe,EAAE;EAAA,IAAAC,eAAA;EACtC,MAAAC,IAAA,GAOIF,KAAK,IAAI,CAAC,CAAC;IAPT;MACJG,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,OAAO;MACPC;IAEF,CAAC,GAAAL,IAAA;IADIM,SAAS,GAAAC,wBAAA,CAAAP,IAAA,EAAAQ,SAAA;EAEd,MAAM;IAAEC,KAAK;IAAEC;EAAW,CAAC,GAAGxB,UAAU,CAACO,kBAAkB,CAAC;EAE5D,IAAIkB,SAAS,GAAGR,KAAK;EACrB,IAAIS,SAAS,GAAGzB,OAAO,CAAC,MAAME,kBAAkB,CAACsB,SAAS,CAAC,EAAE,CAACA,SAAS,CAAC,CAAC;EACzE,IAAIC,SAAS,CAACC,QAAQ,CAAC,QAAQ,CAAC,EAAE;IAKhCF,SAAS,GAAGC,SAAS,GAAGA,SAAS,CAACE,OAAO,CACvC,iBAAiB,EACjBC,MAAM,CAACN,KAAK,GAAG,CAAC,CAClB,CAAC;EACH;EAEA,IAAIO,cAAc,GAAGZ,OAAO;EAC5B,IAAIC,cAAc,KAAK,gBAAgB,IAAIK,UAAU,CAACO,MAAM,IAAI,CAAC,EAAE;IACjED,cAAc,GAAAE,QAAA,KAAAA,QAAA,GACZjC,KAAA,CAAAkC,aAAA,CAACzB,OAAO,QACNT,KAAA,CAAAkC,aAAA,CAACxB,UAAU,MAAE,CACN,CAAC,CACX;EACH;EAEA,MAAMyB,UAAU,GACd,CAACJ,cAAc,IACf/B,KAAK,CAACoC,QAAQ,CAACC,OAAO,CAACrB,QAAQ,CAAC,CAACsB,IAAI,CAAEC,KAAK,IAAK;IAC/C,OAAO,CAAAA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,MAAM,CAAC,MAAK9B,OAAO;EACpC,CAAC,CAAC;EAEJ,OACET,KAAA,CAAAkC,aAAA,CAAC3B,aAAa,EAAAiC,QAAA;IACZC,IAAI,EAAC,MAAM;IACXd,SAAS,EAAEA,SAAU;IACrBV,SAAS,EAAEd,UAAU,CAAC,8BAA8B,EAAEc,SAAS;EAAE,GAC7DI,SAAS,GAEbrB,KAAA,CAAAkC,aAAA,CAAC7B,IAAI,CAACqC,KAAK,QACRhB,SAAS,IAAI1B,KAAA,CAAAkC,aAAA,CAAC5B,IAAI;IAACqC,IAAI,EAAC;EAAO,GAAEjB,SAAgB,CAAC,EAClDV,QAAQ,EACRmB,UAAU,GACP,IAAI,IAAArB,eAAA,GACJiB,cAAc,cAAAjB,eAAA,cAAAA,eAAA,GAAA8B,SAAA,KAAAA,SAAA,GACZ5C,KAAA,CAAAkC,aAAA,CAACzB,OAAO,QACNT,KAAA,CAAAkC,aAAA,CAACxB,UAAU,MAAE,CAAC,EACdV,KAAA,CAAAkC,aAAA,CAACvB,YAAY,MAAE,CACR,CAAC,CAEN,CACC,CAAC;AAEpB;AAEAC,aAAa,CAACF,UAAU,GAAGA,UAAU;AACrCE,aAAa,CAACD,YAAY,GAAGA,YAAY;AAEzCC,aAAa,CAACiC,qBAAqB,GAAG,IAAI;AAC1C,eAAejC,aAAa"}
@@ -1,2 +1,3 @@
1
1
  export { default as useItem } from './useItem';
2
2
  export { default as useSwitchContainerMode } from './useSwitchContainerMode';
3
+ export { default as useArrayLimit } from './useArrayLimit';
@@ -1,3 +1,4 @@
1
1
  export { default as useItem } from './useItem';
2
2
  export { default as useSwitchContainerMode } from './useSwitchContainerMode';
3
+ export { default as useArrayLimit } from './useArrayLimit';
3
4
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["default","useItem","useSwitchContainerMode"],"sources":["../../../../../../src/extensions/forms/Iterate/hooks/index.ts"],"sourcesContent":["export { default as useItem } from './useItem'\nexport { default as useSwitchContainerMode } from './useSwitchContainerMode'\n"],"mappings":"AAAA,SAASA,OAAO,IAAIC,OAAO,QAAQ,WAAW;AAC9C,SAASD,OAAO,IAAIE,sBAAsB,QAAQ,0BAA0B"}
1
+ {"version":3,"file":"index.js","names":["default","useItem","useSwitchContainerMode","useArrayLimit"],"sources":["../../../../../../src/extensions/forms/Iterate/hooks/index.ts"],"sourcesContent":["export { default as useItem } from './useItem'\nexport { default as useSwitchContainerMode } from './useSwitchContainerMode'\nexport { default as useArrayLimit } from './useArrayLimit'\n"],"mappings":"AAAA,SAASA,OAAO,IAAIC,OAAO,QAAQ,WAAW;AAC9C,SAASD,OAAO,IAAIE,sBAAsB,QAAQ,0BAA0B;AAC5E,SAASF,OAAO,IAAIG,aAAa,QAAQ,iBAAiB"}
@@ -0,0 +1,15 @@
1
+ import { Path } from '../../types';
2
+ type SharedState = {
3
+ show?: boolean;
4
+ limit?: number;
5
+ total?: number;
6
+ };
7
+ export default function useArrayLimit({ path }: {
8
+ path: Path;
9
+ }): {
10
+ setShowStatus: (show: boolean) => void;
11
+ setLimitProps: (props: Omit<SharedState, 'show'>) => void;
12
+ error: Error;
13
+ hasReachedLimit: boolean;
14
+ };
15
+ export {};
@@ -0,0 +1,44 @@
1
+ import { useCallback } from 'react';
2
+ import { useTranslation } from '../../hooks';
3
+ import { useSharedState } from '../../../../shared/helpers/useSharedState';
4
+ export default function useArrayLimit(_ref) {
5
+ let {
6
+ path
7
+ } = _ref;
8
+ const sharedState = useSharedState(path + '-iterate-limit');
9
+ const {
10
+ set,
11
+ update,
12
+ extend,
13
+ data
14
+ } = sharedState || {};
15
+ const {
16
+ limit,
17
+ total,
18
+ show
19
+ } = data || {};
20
+ const setLimitProps = useCallback(props => {
21
+ if (props.total !== total) {
22
+ update(props);
23
+ } else {
24
+ set(props);
25
+ }
26
+ }, [set, total, update]);
27
+ const setShowStatus = useCallback(show => {
28
+ extend({
29
+ show
30
+ });
31
+ }, [extend]);
32
+ const hasReachedLimit = typeof limit === 'number' && total >= limit;
33
+ const {
34
+ itemsLimitReached
35
+ } = useTranslation().IteratePushContainer;
36
+ const error = show ? new Error(itemsLimitReached.replace('{limit}', String(limit))) : undefined;
37
+ return {
38
+ setShowStatus,
39
+ setLimitProps,
40
+ error,
41
+ hasReachedLimit
42
+ };
43
+ }
44
+ //# sourceMappingURL=useArrayLimit.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useArrayLimit.js","names":["useCallback","useTranslation","useSharedState","useArrayLimit","_ref","path","sharedState","set","update","extend","data","limit","total","show","setLimitProps","props","setShowStatus","hasReachedLimit","itemsLimitReached","IteratePushContainer","error","Error","replace","String","undefined"],"sources":["../../../../../../src/extensions/forms/Iterate/hooks/useArrayLimit.tsx"],"sourcesContent":["import { useCallback } from 'react'\nimport { useTranslation } from '../../hooks'\nimport { Path } from '../../types'\nimport { useSharedState } from '../../../../shared/helpers/useSharedState'\n\ntype SharedState = {\n show?: boolean\n limit?: number\n total?: number\n}\n\nexport default function useArrayLimit({ path }: { path: Path }) {\n const sharedState = useSharedState<SharedState>(path + '-iterate-limit')\n const { set, update, extend, data } = sharedState || {}\n const { limit, total, show } = data || {}\n\n const setLimitProps = useCallback(\n (props: Omit<SharedState, 'show'>) => {\n if (props.total !== total) {\n update(props)\n } else {\n set(props)\n }\n },\n [set, total, update]\n )\n\n const setShowStatus = useCallback(\n (show: boolean) => {\n extend({ show })\n },\n [extend]\n )\n\n const hasReachedLimit = typeof limit === 'number' && total >= limit\n const { itemsLimitReached } = useTranslation().IteratePushContainer\n const error = show\n ? new Error(itemsLimitReached.replace('{limit}', String(limit)))\n : undefined\n\n return { setShowStatus, setLimitProps, error, hasReachedLimit }\n}\n"],"mappings":"AAAA,SAASA,WAAW,QAAQ,OAAO;AACnC,SAASC,cAAc,QAAQ,aAAa;AAE5C,SAASC,cAAc,QAAQ,2CAA2C;AAQ1E,eAAe,SAASC,aAAaA,CAAAC,IAAA,EAA2B;EAAA,IAA1B;IAAEC;EAAqB,CAAC,GAAAD,IAAA;EAC5D,MAAME,WAAW,GAAGJ,cAAc,CAAcG,IAAI,GAAG,gBAAgB,CAAC;EACxE,MAAM;IAAEE,GAAG;IAAEC,MAAM;IAAEC,MAAM;IAAEC;EAAK,CAAC,GAAGJ,WAAW,IAAI,CAAC,CAAC;EACvD,MAAM;IAAEK,KAAK;IAAEC,KAAK;IAAEC;EAAK,CAAC,GAAGH,IAAI,IAAI,CAAC,CAAC;EAEzC,MAAMI,aAAa,GAAGd,WAAW,CAC9Be,KAAgC,IAAK;IACpC,IAAIA,KAAK,CAACH,KAAK,KAAKA,KAAK,EAAE;MACzBJ,MAAM,CAACO,KAAK,CAAC;IACf,CAAC,MAAM;MACLR,GAAG,CAACQ,KAAK,CAAC;IACZ;EACF,CAAC,EACD,CAACR,GAAG,EAAEK,KAAK,EAAEJ,MAAM,CACrB,CAAC;EAED,MAAMQ,aAAa,GAAGhB,WAAW,CAC9Ba,IAAa,IAAK;IACjBJ,MAAM,CAAC;MAAEI;IAAK,CAAC,CAAC;EAClB,CAAC,EACD,CAACJ,MAAM,CACT,CAAC;EAED,MAAMQ,eAAe,GAAG,OAAON,KAAK,KAAK,QAAQ,IAAIC,KAAK,IAAID,KAAK;EACnE,MAAM;IAAEO;EAAkB,CAAC,GAAGjB,cAAc,CAAC,CAAC,CAACkB,oBAAoB;EACnE,MAAMC,KAAK,GAAGP,IAAI,GACd,IAAIQ,KAAK,CAACH,iBAAiB,CAACI,OAAO,CAAC,SAAS,EAAEC,MAAM,CAACZ,KAAK,CAAC,CAAC,CAAC,GAC9Da,SAAS;EAEb,OAAO;IAAER,aAAa;IAAEF,aAAa;IAAEM,KAAK;IAAEH;EAAgB,CAAC;AACjE"}
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { JsonObject } from 'json-pointer';
2
+ import { JsonObject } from '../utils/json-pointer';
3
3
  import { FilterData } from '../DataContext/Context';
4
4
  import { JSONSchema } from '../types';
5
5
  export type GenerateSchemaReturn = {
@@ -4,7 +4,7 @@ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
4
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
5
5
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
6
  import { useCallback, useContext, useRef } from 'react';
7
- import pointer from 'json-pointer';
7
+ import pointer from '../utils/json-pointer';
8
8
  import DataContext from '../DataContext/Context';
9
9
  export const schemaParams = ['minLength', 'maxLength', 'pattern', 'description', 'min', 'max', 'multipleOf', 'exclusiveMinimum', 'exclusiveMaximum'];
10
10
  export default function GenerateSchema(props) {