@dnb/eufemia 10.46.0 → 10.48.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 (894) hide show
  1. package/CHANGELOG.md +53 -0
  2. package/cjs/components/accordion/Accordion.d.ts +17 -1
  3. package/cjs/components/accordion/Accordion.js +4 -2
  4. package/cjs/components/accordion/Accordion.js.map +1 -1
  5. package/cjs/components/accordion/AccordionContext.d.ts +4 -0
  6. package/cjs/components/accordion/AccordionContext.js.map +1 -1
  7. package/cjs/components/accordion/AccordionDocs.js +6 -1
  8. package/cjs/components/accordion/AccordionDocs.js.map +1 -1
  9. package/cjs/components/accordion/AccordionGroup.js +5 -3
  10. package/cjs/components/accordion/AccordionGroup.js.map +1 -1
  11. package/cjs/components/accordion/AccordionProviderContext.d.ts +4 -0
  12. package/cjs/components/accordion/AccordionProviderContext.js.map +1 -1
  13. package/cjs/components/accordion/AccordionStore.js +2 -1
  14. package/cjs/components/accordion/AccordionStore.js.map +1 -1
  15. package/cjs/components/accordion/style/dnb-accordion.css +3 -3
  16. package/cjs/components/accordion/style/dnb-accordion.min.css +1 -1
  17. package/cjs/components/autocomplete/style/dnb-autocomplete.css +1 -1
  18. package/cjs/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  19. package/cjs/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  20. package/cjs/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  21. package/cjs/components/button/Button.d.ts +1 -1
  22. package/cjs/components/button/Button.js +5 -2
  23. package/cjs/components/button/Button.js.map +1 -1
  24. package/cjs/components/card/style/dnb-card.css +1 -1
  25. package/cjs/components/card/style/dnb-card.min.css +1 -1
  26. package/cjs/components/copy-on-click/CopyOnClick.d.ts +1 -1
  27. package/cjs/components/copy-on-click/CopyOnClick.js +5 -4
  28. package/cjs/components/copy-on-click/CopyOnClick.js.map +1 -1
  29. package/cjs/components/copy-on-click/CopyOnClickDocs.js +5 -0
  30. package/cjs/components/copy-on-click/CopyOnClickDocs.js.map +1 -1
  31. package/cjs/components/copy-on-click/types.d.ts +5 -0
  32. package/cjs/components/copy-on-click/types.js.map +1 -1
  33. package/cjs/components/drawer/style/dnb-drawer.css +3 -3
  34. package/cjs/components/drawer/style/dnb-drawer.min.css +1 -1
  35. package/cjs/components/dropdown/style/dnb-dropdown.css +1 -1
  36. package/cjs/components/dropdown/style/dnb-dropdown.min.css +1 -1
  37. package/cjs/components/flex/Container.js +9 -1
  38. package/cjs/components/flex/Container.js.map +1 -1
  39. package/cjs/components/flex/utils.d.ts +1 -1
  40. package/cjs/components/flex/utils.js +1 -1
  41. package/cjs/components/flex/utils.js.map +1 -1
  42. package/cjs/components/form-row/style/dnb-form-row.css +1 -1
  43. package/cjs/components/form-row/style/dnb-form-row.min.css +1 -1
  44. package/cjs/components/grid/style/dnb-grid.css +6 -6
  45. package/cjs/components/grid/style/dnb-grid.min.css +1 -1
  46. package/cjs/components/lib.d.ts +1 -1
  47. package/cjs/components/progress-indicator/ProgressIndicator.js +2 -2
  48. package/cjs/components/progress-indicator/ProgressIndicator.js.map +1 -1
  49. package/cjs/components/section/style/dnb-section.css +2 -2
  50. package/cjs/components/section/style/dnb-section.min.css +2 -2
  51. package/cjs/components/space/style/dnb-space.css +2 -2
  52. package/cjs/components/space/style/dnb-space.min.css +1 -1
  53. package/cjs/components/tabs/Tabs.js +2 -2
  54. package/cjs/components/tabs/Tabs.js.map +1 -1
  55. package/cjs/components/tag/Tag.js +2 -2
  56. package/cjs/components/tag/Tag.js.map +1 -1
  57. package/cjs/components/toggle-button/style/dnb-toggle-button.css +1 -1
  58. package/cjs/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  59. package/cjs/extensions/forms/DataContext/Context.d.ts +9 -5
  60. package/cjs/extensions/forms/DataContext/Context.js +0 -1
  61. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  62. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  63. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  64. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  65. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +12 -5
  66. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  67. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +6 -2
  68. package/cjs/extensions/forms/DataContext/Provider/Provider.js +36 -16
  69. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  70. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  71. package/cjs/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  72. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +21 -12
  73. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  74. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.d.ts +2 -0
  75. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +20 -0
  76. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -0
  77. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  78. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  79. package/cjs/extensions/forms/Field/Slider/Slider.js +7 -7
  80. package/cjs/extensions/forms/Field/Slider/Slider.js.map +1 -1
  81. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  82. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +35 -11
  83. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  84. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  85. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  86. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  87. package/cjs/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  88. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  89. package/cjs/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  90. package/cjs/extensions/forms/Form/Isolation/Isolation.js +2 -3
  91. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  92. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  93. package/cjs/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  94. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js +20 -1
  95. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  96. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  97. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  98. package/cjs/extensions/forms/Form/Section/Section.d.ts +7 -2
  99. package/cjs/extensions/forms/Form/Section/Section.js +3 -1
  100. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  101. package/cjs/extensions/forms/Form/Section/SectionDocs.js +6 -1
  102. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  103. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  104. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  105. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  106. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  107. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  108. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  109. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  110. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  111. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  112. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  113. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  114. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +9 -5
  115. package/cjs/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  116. package/cjs/extensions/forms/Iterate/Array/Array.js +71 -28
  117. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  118. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  119. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  120. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  121. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.js → Array/ArrayItemArea.js} +66 -49
  122. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  123. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  124. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlockContext.js → Array/ArrayItemAreaContext.js} +3 -3
  125. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  126. package/cjs/extensions/forms/Iterate/Array/types.d.ts +7 -5
  127. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  128. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  129. package/cjs/extensions/forms/Iterate/EditContainer/{EditToolbarTools.js → CancelButton.js} +30 -56
  130. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  131. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  132. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js +75 -0
  133. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  134. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  135. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +33 -12
  136. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  137. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  138. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  139. package/cjs/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  140. package/cjs/extensions/forms/Iterate/EditContainer/index.js +19 -1
  141. package/cjs/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  142. package/cjs/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  143. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  144. package/cjs/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  145. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  146. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  147. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  148. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -24
  149. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  150. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  151. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  152. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  153. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  154. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  155. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -6
  156. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  157. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  158. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js +12 -0
  159. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  160. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  161. package/cjs/extensions/forms/Iterate/ViewContainer/{ViewToolbarTools.js → EditButton.js} +8 -11
  162. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  163. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  164. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js +19 -0
  165. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  166. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  167. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +25 -10
  168. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  169. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  170. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  171. package/cjs/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  172. package/cjs/extensions/forms/Iterate/ViewContainer/index.js +19 -1
  173. package/cjs/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  174. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  175. package/cjs/extensions/forms/Iterate/hooks/index.js +21 -0
  176. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -0
  177. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  178. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +93 -0
  179. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  180. package/cjs/extensions/forms/Tools/Log.d.ts +6 -0
  181. package/cjs/extensions/forms/Tools/Log.js +29 -0
  182. package/cjs/extensions/forms/Tools/Log.js.map +1 -0
  183. package/cjs/extensions/forms/Tools/index.d.ts +1 -0
  184. package/cjs/extensions/forms/Tools/index.js +7 -0
  185. package/cjs/extensions/forms/Tools/index.js.map +1 -1
  186. package/cjs/extensions/forms/Value/Date/Date.d.ts +1 -1
  187. package/cjs/extensions/forms/Value/Date/Date.js +15 -5
  188. package/cjs/extensions/forms/Value/Date/Date.js.map +1 -1
  189. package/cjs/extensions/forms/Value/Date/DateDocs.js +1 -1
  190. package/cjs/extensions/forms/Value/Date/DateDocs.js.map +1 -1
  191. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.css +2 -2
  192. package/cjs/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  193. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +19 -7
  194. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  195. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  196. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  197. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  198. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  199. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
  200. package/cjs/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  201. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  202. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  203. package/cjs/extensions/forms/constants/countries.d.ts +5 -2
  204. package/cjs/extensions/forms/constants/countries.js +81 -25
  205. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  206. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  207. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -2
  208. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  209. package/cjs/extensions/forms/constants/locales/en-US.d.ts +2 -1
  210. package/cjs/extensions/forms/constants/locales/index.d.ts +4 -2
  211. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  212. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -2
  213. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  214. package/cjs/extensions/forms/hooks/DataValueDocs.js +10 -5
  215. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  216. package/cjs/extensions/forms/hooks/useDataValue.d.ts +2 -1
  217. package/cjs/extensions/forms/hooks/useDataValue.js +7 -7
  218. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  219. package/cjs/extensions/forms/hooks/useExternalValue.js +8 -6
  220. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  221. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +2 -1
  222. package/cjs/extensions/forms/hooks/useFieldProps.js +317 -121
  223. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  224. package/cjs/extensions/forms/hooks/usePath.d.ts +1 -0
  225. package/cjs/extensions/forms/hooks/usePath.js +5 -1
  226. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  227. package/cjs/extensions/forms/style/dnb-forms.css +13 -10
  228. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  229. package/cjs/extensions/forms/types.d.ts +32 -2
  230. package/cjs/extensions/forms/types.js.map +1 -1
  231. package/cjs/shared/Eufemia.d.ts +1 -1
  232. package/cjs/shared/Eufemia.js +2 -2
  233. package/cjs/shared/Eufemia.js.map +1 -1
  234. package/cjs/style/core/scopes.scss +1 -1
  235. package/cjs/style/core/utilities.scss +3 -6
  236. package/cjs/style/dnb-ui-basis.css +1 -1
  237. package/cjs/style/dnb-ui-basis.min.css +1 -1
  238. package/cjs/style/dnb-ui-body.css +1 -1
  239. package/cjs/style/dnb-ui-body.min.css +1 -1
  240. package/cjs/style/dnb-ui-components.css +37 -34
  241. package/cjs/style/dnb-ui-components.min.css +5 -5
  242. package/cjs/style/dnb-ui-core.css +1 -1
  243. package/cjs/style/dnb-ui-core.min.css +1 -1
  244. package/cjs/style/dnb-ui-elements.css +1 -1
  245. package/cjs/style/dnb-ui-elements.min.css +1 -1
  246. package/cjs/style/dnb-ui-extensions.css +13 -10
  247. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  248. package/cjs/style/dnb-ui-forms.css +13 -10
  249. package/cjs/style/dnb-ui-forms.min.css +1 -1
  250. package/cjs/style/dnb-ui-fragments.css +2 -2
  251. package/cjs/style/dnb-ui-fragments.min.css +1 -1
  252. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  253. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  254. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +51 -45
  255. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  256. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  257. package/cjs/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  258. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +13 -10
  259. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  260. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +13 -10
  261. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  262. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  263. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  264. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +51 -45
  265. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  266. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  267. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  268. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +13 -10
  269. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  270. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +13 -10
  271. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  272. package/cjs/style/themes/theme-ui/ui-theme-basis.css +1 -1
  273. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  274. package/cjs/style/themes/theme-ui/ui-theme-components.css +51 -45
  275. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  276. package/cjs/style/themes/theme-ui/ui-theme-elements.css +1 -1
  277. package/cjs/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  278. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +13 -10
  279. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  280. package/cjs/style/themes/theme-ui/ui-theme-forms.css +13 -10
  281. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  282. package/cjs/style/themes/theme-ui/ui-theme-tags.css +1 -1
  283. package/cjs/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  284. package/components/accordion/Accordion.d.ts +17 -1
  285. package/components/accordion/Accordion.js +4 -2
  286. package/components/accordion/Accordion.js.map +1 -1
  287. package/components/accordion/AccordionContext.d.ts +4 -0
  288. package/components/accordion/AccordionContext.js.map +1 -1
  289. package/components/accordion/AccordionDocs.js +6 -1
  290. package/components/accordion/AccordionDocs.js.map +1 -1
  291. package/components/accordion/AccordionGroup.js +5 -3
  292. package/components/accordion/AccordionGroup.js.map +1 -1
  293. package/components/accordion/AccordionProviderContext.d.ts +4 -0
  294. package/components/accordion/AccordionProviderContext.js.map +1 -1
  295. package/components/accordion/AccordionStore.js +2 -1
  296. package/components/accordion/AccordionStore.js.map +1 -1
  297. package/components/accordion/style/dnb-accordion.css +3 -3
  298. package/components/accordion/style/dnb-accordion.min.css +1 -1
  299. package/components/autocomplete/style/dnb-autocomplete.css +1 -1
  300. package/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  301. package/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  302. package/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  303. package/components/button/Button.d.ts +1 -1
  304. package/components/button/Button.js +5 -2
  305. package/components/button/Button.js.map +1 -1
  306. package/components/card/style/dnb-card.css +1 -1
  307. package/components/card/style/dnb-card.min.css +1 -1
  308. package/components/copy-on-click/CopyOnClick.d.ts +1 -1
  309. package/components/copy-on-click/CopyOnClick.js +5 -4
  310. package/components/copy-on-click/CopyOnClick.js.map +1 -1
  311. package/components/copy-on-click/CopyOnClickDocs.js +5 -0
  312. package/components/copy-on-click/CopyOnClickDocs.js.map +1 -1
  313. package/components/copy-on-click/types.d.ts +5 -0
  314. package/components/copy-on-click/types.js.map +1 -1
  315. package/components/drawer/style/dnb-drawer.css +3 -3
  316. package/components/drawer/style/dnb-drawer.min.css +1 -1
  317. package/components/dropdown/style/dnb-dropdown.css +1 -1
  318. package/components/dropdown/style/dnb-dropdown.min.css +1 -1
  319. package/components/flex/Container.js +10 -2
  320. package/components/flex/Container.js.map +1 -1
  321. package/components/flex/utils.d.ts +1 -1
  322. package/components/flex/utils.js +1 -1
  323. package/components/flex/utils.js.map +1 -1
  324. package/components/form-row/style/dnb-form-row.css +1 -1
  325. package/components/form-row/style/dnb-form-row.min.css +1 -1
  326. package/components/grid/style/dnb-grid.css +6 -6
  327. package/components/grid/style/dnb-grid.min.css +1 -1
  328. package/components/lib.d.ts +1 -1
  329. package/components/progress-indicator/ProgressIndicator.js +2 -2
  330. package/components/progress-indicator/ProgressIndicator.js.map +1 -1
  331. package/components/section/style/dnb-section.css +2 -2
  332. package/components/section/style/dnb-section.min.css +2 -2
  333. package/components/space/style/dnb-space.css +2 -2
  334. package/components/space/style/dnb-space.min.css +1 -1
  335. package/components/tabs/Tabs.js +2 -2
  336. package/components/tabs/Tabs.js.map +1 -1
  337. package/components/tag/Tag.js +2 -2
  338. package/components/tag/Tag.js.map +1 -1
  339. package/components/toggle-button/style/dnb-toggle-button.css +1 -1
  340. package/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  341. package/es/components/accordion/Accordion.d.ts +17 -1
  342. package/es/components/accordion/Accordion.js +4 -2
  343. package/es/components/accordion/Accordion.js.map +1 -1
  344. package/es/components/accordion/AccordionContext.d.ts +4 -0
  345. package/es/components/accordion/AccordionContext.js.map +1 -1
  346. package/es/components/accordion/AccordionDocs.js +6 -1
  347. package/es/components/accordion/AccordionDocs.js.map +1 -1
  348. package/es/components/accordion/AccordionGroup.js +5 -3
  349. package/es/components/accordion/AccordionGroup.js.map +1 -1
  350. package/es/components/accordion/AccordionProviderContext.d.ts +4 -0
  351. package/es/components/accordion/AccordionProviderContext.js.map +1 -1
  352. package/es/components/accordion/AccordionStore.js +2 -1
  353. package/es/components/accordion/AccordionStore.js.map +1 -1
  354. package/es/components/accordion/style/dnb-accordion.css +3 -3
  355. package/es/components/accordion/style/dnb-accordion.min.css +1 -1
  356. package/es/components/autocomplete/style/dnb-autocomplete.css +1 -1
  357. package/es/components/autocomplete/style/dnb-autocomplete.min.css +1 -1
  358. package/es/components/breadcrumb/style/dnb-breadcrumb.css +1 -1
  359. package/es/components/breadcrumb/style/dnb-breadcrumb.min.css +1 -1
  360. package/es/components/button/Button.d.ts +1 -1
  361. package/es/components/button/Button.js +5 -2
  362. package/es/components/button/Button.js.map +1 -1
  363. package/es/components/card/style/dnb-card.css +1 -1
  364. package/es/components/card/style/dnb-card.min.css +1 -1
  365. package/es/components/copy-on-click/CopyOnClick.d.ts +1 -1
  366. package/es/components/copy-on-click/CopyOnClick.js +5 -4
  367. package/es/components/copy-on-click/CopyOnClick.js.map +1 -1
  368. package/es/components/copy-on-click/CopyOnClickDocs.js +5 -0
  369. package/es/components/copy-on-click/CopyOnClickDocs.js.map +1 -1
  370. package/es/components/copy-on-click/types.d.ts +5 -0
  371. package/es/components/copy-on-click/types.js.map +1 -1
  372. package/es/components/drawer/style/dnb-drawer.css +3 -3
  373. package/es/components/drawer/style/dnb-drawer.min.css +1 -1
  374. package/es/components/dropdown/style/dnb-dropdown.css +1 -1
  375. package/es/components/dropdown/style/dnb-dropdown.min.css +1 -1
  376. package/es/components/flex/Container.js +10 -2
  377. package/es/components/flex/Container.js.map +1 -1
  378. package/es/components/flex/utils.d.ts +1 -1
  379. package/es/components/flex/utils.js +1 -1
  380. package/es/components/flex/utils.js.map +1 -1
  381. package/es/components/form-row/style/dnb-form-row.css +1 -1
  382. package/es/components/form-row/style/dnb-form-row.min.css +1 -1
  383. package/es/components/grid/style/dnb-grid.css +6 -6
  384. package/es/components/grid/style/dnb-grid.min.css +1 -1
  385. package/es/components/lib.d.ts +1 -1
  386. package/es/components/progress-indicator/ProgressIndicator.js +2 -2
  387. package/es/components/progress-indicator/ProgressIndicator.js.map +1 -1
  388. package/es/components/section/style/dnb-section.css +2 -2
  389. package/es/components/section/style/dnb-section.min.css +2 -2
  390. package/es/components/space/style/dnb-space.css +2 -2
  391. package/es/components/space/style/dnb-space.min.css +1 -1
  392. package/es/components/tabs/Tabs.js +2 -2
  393. package/es/components/tabs/Tabs.js.map +1 -1
  394. package/es/components/tag/Tag.js +2 -2
  395. package/es/components/tag/Tag.js.map +1 -1
  396. package/es/components/toggle-button/style/dnb-toggle-button.css +1 -1
  397. package/es/components/toggle-button/style/dnb-toggle-button.min.css +1 -1
  398. package/es/extensions/forms/DataContext/Context.d.ts +9 -5
  399. package/es/extensions/forms/DataContext/Context.js +0 -1
  400. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  401. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  402. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  403. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  404. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +13 -5
  405. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  406. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +6 -2
  407. package/es/extensions/forms/DataContext/Provider/Provider.js +36 -16
  408. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  409. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  410. package/es/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  411. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +21 -12
  412. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  413. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.d.ts +2 -0
  414. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +13 -0
  415. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -0
  416. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  417. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  418. package/es/extensions/forms/Field/Slider/Slider.js +7 -7
  419. package/es/extensions/forms/Field/Slider/Slider.js.map +1 -1
  420. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  421. package/es/extensions/forms/FieldBlock/FieldBlock.js +33 -11
  422. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  423. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  424. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  425. package/es/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  426. package/es/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  427. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  428. package/es/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  429. package/es/extensions/forms/Form/Isolation/Isolation.js +2 -3
  430. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  431. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  432. package/es/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  433. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  434. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  435. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  436. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  437. package/es/extensions/forms/Form/Section/Section.d.ts +7 -2
  438. package/es/extensions/forms/Form/Section/Section.js +3 -1
  439. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  440. package/es/extensions/forms/Form/Section/SectionDocs.js +6 -1
  441. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  442. package/es/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  443. package/es/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  444. package/es/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  445. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  446. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  447. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  448. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  449. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  450. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  451. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  452. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  453. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +9 -5
  454. package/es/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  455. package/es/extensions/forms/Iterate/Array/Array.js +71 -29
  456. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  457. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  458. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  459. package/es/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  460. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  461. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  462. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  463. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  464. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  465. package/es/extensions/forms/Iterate/Array/types.d.ts +7 -5
  466. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  467. package/es/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  468. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +87 -0
  469. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  470. package/es/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  471. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js +67 -0
  472. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  473. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  474. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  475. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  476. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  477. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  478. package/es/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  479. package/es/extensions/forms/Iterate/EditContainer/index.js +2 -0
  480. package/es/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  481. package/es/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  482. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  483. package/es/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  484. package/es/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  485. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  486. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  487. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -23
  488. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  489. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  490. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  491. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  492. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  493. package/es/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  494. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +51 -7
  495. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  496. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  497. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  498. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  499. package/es/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  500. package/{extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → es/extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  501. package/es/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  502. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  503. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  504. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  505. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  506. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  507. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  508. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  509. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  510. package/es/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  511. package/es/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  512. package/es/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  513. package/es/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  514. package/es/extensions/forms/Iterate/hooks/index.js +3 -0
  515. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -0
  516. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  517. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +85 -0
  518. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  519. package/es/extensions/forms/Tools/Log.d.ts +6 -0
  520. package/es/extensions/forms/Tools/Log.js +22 -0
  521. package/es/extensions/forms/Tools/Log.js.map +1 -0
  522. package/es/extensions/forms/Tools/index.d.ts +1 -0
  523. package/es/extensions/forms/Tools/index.js +1 -0
  524. package/es/extensions/forms/Tools/index.js.map +1 -1
  525. package/es/extensions/forms/Value/Date/Date.d.ts +1 -1
  526. package/es/extensions/forms/Value/Date/Date.js +15 -5
  527. package/es/extensions/forms/Value/Date/Date.js.map +1 -1
  528. package/es/extensions/forms/Value/Date/DateDocs.js +1 -1
  529. package/es/extensions/forms/Value/Date/DateDocs.js.map +1 -1
  530. package/es/extensions/forms/ValueBlock/style/dnb-value-block.css +2 -2
  531. package/es/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  532. package/es/extensions/forms/Wizard/Container/WizardContainer.js +18 -7
  533. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  534. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  535. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  536. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  537. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  538. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
  539. package/es/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  540. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  541. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  542. package/es/extensions/forms/constants/countries.d.ts +5 -2
  543. package/es/extensions/forms/constants/countries.js +81 -25
  544. package/es/extensions/forms/constants/countries.js.map +1 -1
  545. package/es/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  546. package/es/extensions/forms/constants/locales/en-GB.js +3 -2
  547. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  548. package/es/extensions/forms/constants/locales/en-US.d.ts +2 -1
  549. package/es/extensions/forms/constants/locales/index.d.ts +4 -2
  550. package/es/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  551. package/es/extensions/forms/constants/locales/nb-NO.js +3 -2
  552. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  553. package/es/extensions/forms/hooks/DataValueDocs.js +10 -5
  554. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  555. package/es/extensions/forms/hooks/useDataValue.d.ts +2 -1
  556. package/es/extensions/forms/hooks/useDataValue.js +7 -7
  557. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  558. package/es/extensions/forms/hooks/useExternalValue.js +8 -6
  559. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  560. package/es/extensions/forms/hooks/useFieldProps.d.ts +2 -1
  561. package/es/extensions/forms/hooks/useFieldProps.js +309 -119
  562. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  563. package/es/extensions/forms/hooks/usePath.d.ts +1 -0
  564. package/es/extensions/forms/hooks/usePath.js +5 -1
  565. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  566. package/es/extensions/forms/style/dnb-forms.css +13 -10
  567. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  568. package/es/extensions/forms/types.d.ts +32 -2
  569. package/es/extensions/forms/types.js.map +1 -1
  570. package/es/shared/Eufemia.d.ts +1 -1
  571. package/es/shared/Eufemia.js +2 -2
  572. package/es/shared/Eufemia.js.map +1 -1
  573. package/es/style/core/scopes.scss +1 -1
  574. package/es/style/core/utilities.scss +3 -6
  575. package/es/style/dnb-ui-basis.css +1 -1
  576. package/es/style/dnb-ui-basis.min.css +1 -1
  577. package/es/style/dnb-ui-body.css +1 -1
  578. package/es/style/dnb-ui-body.min.css +1 -1
  579. package/es/style/dnb-ui-components.css +37 -34
  580. package/es/style/dnb-ui-components.min.css +5 -5
  581. package/es/style/dnb-ui-core.css +1 -1
  582. package/es/style/dnb-ui-core.min.css +1 -1
  583. package/es/style/dnb-ui-elements.css +1 -1
  584. package/es/style/dnb-ui-elements.min.css +1 -1
  585. package/es/style/dnb-ui-extensions.css +13 -10
  586. package/es/style/dnb-ui-extensions.min.css +1 -1
  587. package/es/style/dnb-ui-forms.css +13 -10
  588. package/es/style/dnb-ui-forms.min.css +1 -1
  589. package/es/style/dnb-ui-fragments.css +2 -2
  590. package/es/style/dnb-ui-fragments.min.css +1 -1
  591. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  592. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  593. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +51 -45
  594. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  595. package/es/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  596. package/es/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  597. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +13 -10
  598. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  599. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +13 -10
  600. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  601. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  602. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  603. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +51 -45
  604. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  605. package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  606. package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  607. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +13 -10
  608. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  609. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +13 -10
  610. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  611. package/es/style/themes/theme-ui/ui-theme-basis.css +1 -1
  612. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  613. package/es/style/themes/theme-ui/ui-theme-components.css +51 -45
  614. package/es/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  615. package/es/style/themes/theme-ui/ui-theme-elements.css +1 -1
  616. package/es/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  617. package/es/style/themes/theme-ui/ui-theme-extensions.css +13 -10
  618. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  619. package/es/style/themes/theme-ui/ui-theme-forms.css +13 -10
  620. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  621. package/es/style/themes/theme-ui/ui-theme-tags.css +1 -1
  622. package/es/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  623. package/esm/dnb-ui-basis.min.mjs +1 -1
  624. package/esm/dnb-ui-components.min.mjs +1 -1
  625. package/esm/dnb-ui-elements.min.mjs +1 -1
  626. package/esm/dnb-ui-extensions.min.mjs +5 -5
  627. package/esm/dnb-ui-lib.min.mjs +1 -1
  628. package/extensions/forms/DataContext/Context.d.ts +9 -5
  629. package/extensions/forms/DataContext/Context.js +0 -1
  630. package/extensions/forms/DataContext/Context.js.map +1 -1
  631. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  632. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  633. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  634. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +12 -5
  635. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  636. package/extensions/forms/DataContext/Provider/Provider.d.ts +6 -2
  637. package/extensions/forms/DataContext/Provider/Provider.js +36 -16
  638. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  639. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.css +1 -1
  640. package/extensions/forms/Field/ArraySelection/style/dnb-array-selection.min.css +1 -1
  641. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +21 -12
  642. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  643. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.d.ts +2 -0
  644. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +13 -0
  645. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -0
  646. package/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  647. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  648. package/extensions/forms/Field/Slider/Slider.js +7 -7
  649. package/extensions/forms/Field/Slider/Slider.js.map +1 -1
  650. package/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  651. package/extensions/forms/FieldBlock/FieldBlock.js +33 -11
  652. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  653. package/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  654. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  655. package/extensions/forms/FieldBlock/style/dnb-field-block.css +3 -3
  656. package/extensions/forms/FieldBlock/style/dnb-field-block.min.css +1 -1
  657. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.css +1 -1
  658. package/extensions/forms/Form/ButtonRow/style/dnb-form-button-row.min.css +1 -1
  659. package/extensions/forms/Form/Isolation/Isolation.js +2 -3
  660. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  661. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.css +1 -1
  662. package/extensions/forms/Form/MainHeading/style/dnb-form-main-heading.min.css +1 -1
  663. package/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  664. package/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  665. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  666. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  667. package/extensions/forms/Form/Section/Section.d.ts +7 -2
  668. package/extensions/forms/Form/Section/Section.js +3 -1
  669. package/extensions/forms/Form/Section/Section.js.map +1 -1
  670. package/extensions/forms/Form/Section/SectionDocs.js +6 -1
  671. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  672. package/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  673. package/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  674. package/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  675. package/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  676. package/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  677. package/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  678. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  679. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  680. package/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  681. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  682. package/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  683. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js +9 -5
  684. package/extensions/forms/Form/SubmitIndicator/SubmitIndicator.js.map +1 -1
  685. package/extensions/forms/Iterate/Array/Array.js +72 -29
  686. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  687. package/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  688. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  689. package/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  690. package/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  691. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  692. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  693. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  694. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  695. package/extensions/forms/Iterate/Array/types.d.ts +7 -5
  696. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  697. package/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  698. package/extensions/forms/Iterate/EditContainer/CancelButton.js +88 -0
  699. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  700. package/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  701. package/extensions/forms/Iterate/EditContainer/DoneButton.js +67 -0
  702. package/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  703. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  704. package/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  705. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  706. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  707. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  708. package/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  709. package/extensions/forms/Iterate/EditContainer/index.js +2 -0
  710. package/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  711. package/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  712. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  713. package/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  714. package/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  715. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  716. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  717. package/extensions/forms/Iterate/PushContainer/PushContainer.js +80 -26
  718. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  719. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  720. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  721. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  722. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  723. package/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  724. package/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -7
  725. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  726. package/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  727. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  728. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  729. package/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  730. package/{es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  731. package/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  732. package/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  733. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  734. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  735. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  736. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  737. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  738. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  739. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  740. package/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  741. package/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  742. package/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  743. package/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  744. package/extensions/forms/Iterate/hooks/index.js +3 -0
  745. package/extensions/forms/Iterate/hooks/index.js.map +1 -0
  746. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  747. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +87 -0
  748. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  749. package/extensions/forms/Tools/Log.d.ts +6 -0
  750. package/extensions/forms/Tools/Log.js +22 -0
  751. package/extensions/forms/Tools/Log.js.map +1 -0
  752. package/extensions/forms/Tools/index.d.ts +1 -0
  753. package/extensions/forms/Tools/index.js +1 -0
  754. package/extensions/forms/Tools/index.js.map +1 -1
  755. package/extensions/forms/Value/Date/Date.d.ts +1 -1
  756. package/extensions/forms/Value/Date/Date.js +15 -5
  757. package/extensions/forms/Value/Date/Date.js.map +1 -1
  758. package/extensions/forms/Value/Date/DateDocs.js +1 -1
  759. package/extensions/forms/Value/Date/DateDocs.js.map +1 -1
  760. package/extensions/forms/ValueBlock/style/dnb-value-block.css +2 -2
  761. package/extensions/forms/ValueBlock/style/dnb-value-block.min.css +1 -1
  762. package/extensions/forms/Wizard/Container/WizardContainer.js +19 -7
  763. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  764. package/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  765. package/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  766. package/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  767. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  768. package/extensions/forms/Wizard/style/dnb-wizard-layout.css +2 -2
  769. package/extensions/forms/Wizard/style/dnb-wizard-layout.min.css +1 -1
  770. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  771. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  772. package/extensions/forms/constants/countries.d.ts +5 -2
  773. package/extensions/forms/constants/countries.js +81 -25
  774. package/extensions/forms/constants/countries.js.map +1 -1
  775. package/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  776. package/extensions/forms/constants/locales/en-GB.js +3 -2
  777. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  778. package/extensions/forms/constants/locales/en-US.d.ts +2 -1
  779. package/extensions/forms/constants/locales/index.d.ts +4 -2
  780. package/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  781. package/extensions/forms/constants/locales/nb-NO.js +3 -2
  782. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  783. package/extensions/forms/hooks/DataValueDocs.js +10 -5
  784. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  785. package/extensions/forms/hooks/useDataValue.d.ts +2 -1
  786. package/extensions/forms/hooks/useDataValue.js +7 -7
  787. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  788. package/extensions/forms/hooks/useExternalValue.js +8 -6
  789. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  790. package/extensions/forms/hooks/useFieldProps.d.ts +2 -1
  791. package/extensions/forms/hooks/useFieldProps.js +318 -122
  792. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  793. package/extensions/forms/hooks/usePath.d.ts +1 -0
  794. package/extensions/forms/hooks/usePath.js +5 -1
  795. package/extensions/forms/hooks/usePath.js.map +1 -1
  796. package/extensions/forms/style/dnb-forms.css +13 -10
  797. package/extensions/forms/style/dnb-forms.min.css +1 -1
  798. package/extensions/forms/types.d.ts +32 -2
  799. package/extensions/forms/types.js.map +1 -1
  800. package/package.json +1 -1
  801. package/shared/Eufemia.d.ts +1 -1
  802. package/shared/Eufemia.js +2 -2
  803. package/shared/Eufemia.js.map +1 -1
  804. package/style/core/scopes.scss +1 -1
  805. package/style/core/utilities.scss +3 -6
  806. package/style/dnb-ui-basis.css +1 -1
  807. package/style/dnb-ui-basis.min.css +1 -1
  808. package/style/dnb-ui-body.css +1 -1
  809. package/style/dnb-ui-body.min.css +1 -1
  810. package/style/dnb-ui-components.css +37 -34
  811. package/style/dnb-ui-components.min.css +5 -5
  812. package/style/dnb-ui-core.css +1 -1
  813. package/style/dnb-ui-core.min.css +1 -1
  814. package/style/dnb-ui-elements.css +1 -1
  815. package/style/dnb-ui-elements.min.css +1 -1
  816. package/style/dnb-ui-extensions.css +13 -10
  817. package/style/dnb-ui-extensions.min.css +1 -1
  818. package/style/dnb-ui-forms.css +13 -10
  819. package/style/dnb-ui-forms.min.css +1 -1
  820. package/style/dnb-ui-fragments.css +2 -2
  821. package/style/dnb-ui-fragments.min.css +1 -1
  822. package/style/themes/theme-eiendom/eiendom-theme-basis.css +1 -1
  823. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  824. package/style/themes/theme-eiendom/eiendom-theme-components.css +51 -45
  825. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +6 -6
  826. package/style/themes/theme-eiendom/eiendom-theme-elements.css +1 -1
  827. package/style/themes/theme-eiendom/eiendom-theme-elements.min.css +1 -1
  828. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +13 -10
  829. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  830. package/style/themes/theme-eiendom/eiendom-theme-forms.css +13 -10
  831. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  832. package/style/themes/theme-sbanken/sbanken-theme-basis.css +1 -1
  833. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  834. package/style/themes/theme-sbanken/sbanken-theme-components.css +51 -45
  835. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +7 -7
  836. package/style/themes/theme-sbanken/sbanken-theme-elements.css +1 -1
  837. package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +1 -1
  838. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +13 -10
  839. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  840. package/style/themes/theme-sbanken/sbanken-theme-forms.css +13 -10
  841. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  842. package/style/themes/theme-ui/ui-theme-basis.css +1 -1
  843. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  844. package/style/themes/theme-ui/ui-theme-components.css +51 -45
  845. package/style/themes/theme-ui/ui-theme-components.min.css +6 -6
  846. package/style/themes/theme-ui/ui-theme-elements.css +1 -1
  847. package/style/themes/theme-ui/ui-theme-elements.min.css +1 -1
  848. package/style/themes/theme-ui/ui-theme-extensions.css +13 -10
  849. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  850. package/style/themes/theme-ui/ui-theme-forms.css +13 -10
  851. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  852. package/style/themes/theme-ui/ui-theme-tags.css +1 -1
  853. package/style/themes/theme-ui/ui-theme-tags.min.css +1 -1
  854. package/umd/dnb-ui-basis.min.js +1 -1
  855. package/umd/dnb-ui-components.min.js +1 -1
  856. package/umd/dnb-ui-elements.min.js +1 -1
  857. package/umd/dnb-ui-extensions.min.js +5 -5
  858. package/umd/dnb-ui-lib.min.js +1 -1
  859. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  860. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  861. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  862. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  863. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  864. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  865. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  866. package/cjs/shared/helpers/useUnmountEffect.d.ts +0 -4
  867. package/cjs/shared/helpers/useUnmountEffect.js +0 -14
  868. package/cjs/shared/helpers/useUnmountEffect.js.map +0 -1
  869. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  870. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  871. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  872. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  873. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  874. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  875. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -113
  876. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  877. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  878. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  879. package/es/shared/helpers/useUnmountEffect.d.ts +0 -4
  880. package/es/shared/helpers/useUnmountEffect.js +0 -9
  881. package/es/shared/helpers/useUnmountEffect.js.map +0 -1
  882. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  883. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  884. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  885. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  886. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  887. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  888. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -114
  889. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  890. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  891. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  892. package/shared/helpers/useUnmountEffect.d.ts +0 -4
  893. package/shared/helpers/useUnmountEffect.js +0 -9
  894. package/shared/helpers/useUnmountEffect.js.map +0 -1
@@ -4,6 +4,7 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.ArrayProperties = exports.ArrayEvents = void 0;
7
+ var _DataValueDocs = require("../../hooks/DataValueDocs");
7
8
  const ArrayProperties = {
8
9
  value: {
9
10
  doc: 'The data to iterate over. Alternative you can use the `path` prop.',
@@ -45,6 +46,14 @@ const ArrayProperties = {
45
46
  type: 'unknown',
46
47
  status: 'optional'
47
48
  },
49
+ validator: _DataValueDocs.dataValueProperties.validator,
50
+ validateInitially: _DataValueDocs.dataValueProperties.validateInitially,
51
+ continuousValidation: _DataValueDocs.dataValueProperties.continuousValidation,
52
+ containerMode: {
53
+ doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',
54
+ type: 'string',
55
+ status: 'optional'
56
+ },
48
57
  children: {
49
58
  doc: 'React.Node or a function so you can get the current value and index.',
50
59
  type: 'boolean',
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayDocs.js","names":["ArrayProperties","value","doc","type","status","path","countPath","countPathTransform","countPathLimit","withoutFlex","placeholder","emptyValue","children","exports","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: 'boolean',\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":";;;;;;AAEO,MAAMA,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,cAAc,EAAE;IACdN,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,WAAW,EAAE;IACXP,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,QAAQ,EAAE;IACRV,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAAAS,OAAA,CAAAb,eAAA,GAAAA,eAAA;AAEM,MAAMc,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRb,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC;AAAAS,OAAA,CAAAC,WAAA,GAAAA,WAAA"}
1
+ {"version":3,"file":"ArrayDocs.js","names":["_DataValueDocs","require","ArrayProperties","value","doc","type","status","path","countPath","countPathTransform","countPathLimit","withoutFlex","placeholder","emptyValue","validator","dataValueProperties","validateInitially","continuousValidation","containerMode","children","exports","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { dataValueProperties } from '../../hooks/DataValueDocs'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n validator: dataValueProperties.validator,\n validateInitially: dataValueProperties.validateInitially,\n continuousValidation: dataValueProperties.continuousValidation,\n containerMode: {\n doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: 'boolean',\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":";;;;;;AACA,IAAAA,cAAA,GAAAC,OAAA;AAEO,MAAMC,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,cAAc,EAAE;IACdN,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,WAAW,EAAE;IACXP,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAEC,kCAAmB,CAACD,SAAS;EACxCE,iBAAiB,EAAED,kCAAmB,CAACC,iBAAiB;EACxDC,oBAAoB,EAAEF,kCAAmB,CAACE,oBAAoB;EAC9DC,aAAa,EAAE;IACbd,GAAG,EAAE,0SAA0S;IAC/SC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDa,QAAQ,EAAE;IACRf,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAAAc,OAAA,CAAAlB,eAAA,GAAAA,eAAA;AAEM,MAAMmB,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRlB,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC;AAAAc,OAAA,CAAAC,WAAA,GAAAA,WAAA"}
@@ -1,6 +1,6 @@
1
1
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
2
- import { ContainerMode } from '../Array/types';
3
- export type ElementSectionProps = {
2
+ import { ContainerMode } from './types';
3
+ export type ArrayItemAreaProps = {
4
4
  /**
5
5
  * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.
6
6
  * Defaults to `outline`.
@@ -12,9 +12,9 @@ export type Props = {
12
12
  open?: boolean | undefined;
13
13
  ariaLabel?: string;
14
14
  openDelay?: number;
15
- } & ElementSectionProps;
16
- declare function ElementBlock(props: Props & FlexContainerProps): import("react/jsx-runtime").JSX.Element;
17
- declare namespace ElementBlock {
15
+ } & ArrayItemAreaProps;
16
+ declare function ArrayItemArea(props: Props & FlexContainerProps): import("react/jsx-runtime").JSX.Element;
17
+ declare namespace ArrayItemArea {
18
18
  var _supportsSpacingProps: boolean;
19
19
  }
20
- export default ElementBlock;
20
+ export default ArrayItemArea;
@@ -9,7 +9,7 @@ var _react = _interopRequireWildcard(require("react"));
9
9
  var _classnames = _interopRequireDefault(require("classnames"));
10
10
  var _components = require("../../../../components");
11
11
  var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
12
- var _ElementBlockContext = _interopRequireDefault(require("./ElementBlockContext"));
12
+ var _ArrayItemAreaContext = _interopRequireDefault(require("./ArrayItemAreaContext"));
13
13
  var _FieldBoundaryContext = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryContext"));
14
14
  const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "openDelay", "variant"];
15
15
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
@@ -18,25 +18,8 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
18
18
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
19
19
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
20
20
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
21
- function ElementBlock(props) {
21
+ function ArrayItemArea(props) {
22
22
  const [, forceUpdate] = (0, _react.useReducer)(() => ({}), {});
23
- const contextRef = (0, _react.useRef)();
24
- contextRef.current = (0, _react.useContext)(_IterateItemContext.default) || {};
25
- const {
26
- hasError,
27
- hasSubmitError
28
- } = (0, _react.useContext)(_FieldBoundaryContext.default) || {};
29
- contextRef.current.hasError = hasError;
30
- contextRef.current.hasSubmitError = hasSubmitError;
31
- if (hasSubmitError) {
32
- contextRef.current.containerMode = 'edit';
33
- }
34
- const {
35
- handleRemove,
36
- switchContainerMode,
37
- containerMode,
38
- isNew
39
- } = contextRef.current;
40
23
  const {
41
24
  mode,
42
25
  open,
@@ -48,6 +31,45 @@ function ElementBlock(props) {
48
31
  variant = 'outline'
49
32
  } = props,
50
33
  restProps = _objectWithoutProperties(props, _excluded);
34
+ const localContextRef = (0, _react.useRef)();
35
+ const {
36
+ hasError,
37
+ hasSubmitError
38
+ } = (0, _react.useContext)(_FieldBoundaryContext.default) || {};
39
+ localContextRef.current = (0, _react.useContext)(_IterateItemContext.default) || {};
40
+ const nextFocusElementRef = (0, _react.useRef)();
41
+ const {
42
+ isNew,
43
+ value
44
+ } = localContextRef.current;
45
+ if (hasSubmitError || !value) {
46
+ localContextRef.current.containerMode = 'edit';
47
+ }
48
+ if (localContextRef.current.containerMode === 'auto') {
49
+ localContextRef.current.containerMode = 'view';
50
+ }
51
+ const determineMode = (0, _react.useCallback)(() => {
52
+ const {
53
+ initialContainerMode,
54
+ switchContainerMode
55
+ } = localContextRef.current;
56
+ if (mode === 'edit' && !hasSubmitError && initialContainerMode === 'auto') {
57
+ if (hasError && !isNew) {
58
+ switchContainerMode('edit', {
59
+ omitFocusManagement: true
60
+ });
61
+ }
62
+ }
63
+ }, [hasError, hasSubmitError, isNew, mode]);
64
+ (0, _react.useEffect)(() => {
65
+ determineMode();
66
+ }, [determineMode]);
67
+ const {
68
+ handleRemove,
69
+ index,
70
+ previousContainerMode,
71
+ containerMode
72
+ } = localContextRef.current;
51
73
  const openRef = (0, _react.useRef)(open !== null && open !== void 0 ? open : containerMode === mode && !isNew);
52
74
  const isRemoving = (0, _react.useRef)(false);
53
75
  const setOpenState = (0, _react.useCallback)(open => {
@@ -71,48 +93,43 @@ function ElementBlock(props) {
71
93
  }
72
94
  }
73
95
  }, [containerMode, isNew, mode, open, openDelay, setOpenState]);
74
- const handleAnimationEnd = (0, _react.useCallback)(state => {
75
- if (contextRef.current.hasSubmitError) {
76
- switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('edit');
77
- }
78
- const preventFocusOnErrorOpening = !contextRef.current.hasSubmitError;
79
- if (preventFocusOnErrorOpening) {
96
+ const setFocus = (0, _react.useCallback)(state => {
97
+ var _localContextRef$curr;
98
+ if (((_localContextRef$curr = localContextRef.current.modeOptions) === null || _localContextRef$curr === void 0 ? void 0 : _localContextRef$curr.omitFocusManagement) !== true && !hasSubmitError && containerMode === mode && containerMode !== previousContainerMode) {
80
99
  if (state === 'opened') {
81
- var _contextRef$current, _contextRef$current$e, _contextRef$current$e2, _contextRef$current$e3;
82
- (_contextRef$current = contextRef.current) === null || _contextRef$current === void 0 ? void 0 : (_contextRef$current$e = _contextRef$current.elementRef) === null || _contextRef$current$e === void 0 ? void 0 : (_contextRef$current$e2 = _contextRef$current$e.current) === null || _contextRef$current$e2 === void 0 ? void 0 : (_contextRef$current$e3 = _contextRef$current$e2.focus) === null || _contextRef$current$e3 === void 0 ? void 0 : _contextRef$current$e3.call(_contextRef$current$e2);
83
- } else {
84
- window.requestAnimationFrame(() => {
85
- try {
86
- var _document$activeEleme;
87
- if (!((_document$activeEleme = document.activeElement) !== null && _document$activeEleme !== void 0 && _document$activeEleme.closest('.dnb-forms-iterate__element'))) {
88
- var _contextRef$current2;
89
- const elements = (_contextRef$current2 = contextRef.current) === null || _contextRef$current2 === void 0 ? void 0 : _contextRef$current2.containerRef.current.querySelectorAll('.dnb-forms-iterate__element');
90
- elements[elements.length - 1].focus();
91
- }
92
- } catch (e) {}
93
- });
100
+ var _localContextRef$curr2, _localContextRef$curr3, _localContextRef$curr4;
101
+ (_localContextRef$curr2 = localContextRef.current.elementRef) === null || _localContextRef$curr2 === void 0 ? void 0 : (_localContextRef$curr3 = _localContextRef$curr2.current) === null || _localContextRef$curr3 === void 0 ? void 0 : (_localContextRef$curr4 = _localContextRef$curr3.focus) === null || _localContextRef$curr4 === void 0 ? void 0 : _localContextRef$curr4.call(_localContextRef$curr3);
102
+ } else if (state === 'closed') {
103
+ var _nextFocusElementRef$, _nextFocusElementRef$2;
104
+ (_nextFocusElementRef$ = nextFocusElementRef.current) === null || _nextFocusElementRef$ === void 0 ? void 0 : (_nextFocusElementRef$2 = _nextFocusElementRef$.focus) === null || _nextFocusElementRef$2 === void 0 ? void 0 : _nextFocusElementRef$2.call(_nextFocusElementRef$);
94
105
  }
95
106
  }
107
+ }, [containerMode, hasSubmitError, mode, previousContainerMode]);
108
+ const handleAnimationEnd = (0, _react.useCallback)(state => {
96
109
  if (!openRef.current && isRemoving.current) {
97
- var _contextRef$current3, _contextRef$current3$;
110
+ var _localContextRef$curr5, _localContextRef$curr6;
98
111
  isRemoving.current = false;
99
- (_contextRef$current3 = contextRef.current) === null || _contextRef$current3 === void 0 ? void 0 : (_contextRef$current3$ = _contextRef$current3.fulfillRemove) === null || _contextRef$current3$ === void 0 ? void 0 : _contextRef$current3$.call(_contextRef$current3);
112
+ (_localContextRef$curr5 = (_localContextRef$curr6 = localContextRef.current).fulfillRemove) === null || _localContextRef$curr5 === void 0 ? void 0 : _localContextRef$curr5.call(_localContextRef$curr6);
100
113
  }
114
+ setFocus(state);
101
115
  onAnimationEnd === null || onAnimationEnd === void 0 ? void 0 : onAnimationEnd(state);
102
- }, [onAnimationEnd, switchContainerMode]);
103
- const handleRemoveBlock = (0, _react.useCallback)(() => {
116
+ }, [onAnimationEnd, setFocus]);
117
+ const handleRemoveItem = (0, _react.useCallback)(() => {
118
+ try {
119
+ nextFocusElementRef.current = Array.from(localContextRef.current.elementRef.current.parentElement.childNodes).at(index - 1);
120
+ } catch (e) {}
104
121
  isRemoving.current = true;
105
122
  handleRemove === null || handleRemove === void 0 ? void 0 : handleRemove({
106
123
  keepItems: true
107
124
  });
108
125
  setOpenState(false);
109
- }, [handleRemove, setOpenState]);
110
- return _react.default.createElement(_ElementBlockContext.default.Provider, {
126
+ }, [handleRemove, index, setOpenState]);
127
+ return _react.default.createElement(_ArrayItemAreaContext.default.Provider, {
111
128
  value: {
112
- handleRemoveBlock
129
+ handleRemoveItem
113
130
  }
114
131
  }, _react.default.createElement(_components.HeightAnimation, {
115
- className: (0, _classnames.default)('dnb-forms-section-block', className, variant && `dnb-forms-section-block--variant-${variant}`, isNew && 'dnb-forms-section-block--new', contextRef.current.hasSubmitError && 'dnb-forms-section-block--error'),
132
+ className: (0, _classnames.default)('dnb-forms-section-block', className, variant && `dnb-forms-section-block--variant-${variant}`, isNew && 'dnb-forms-section-block--new', hasSubmitError && 'dnb-forms-section-block--error'),
116
133
  open: openRef.current,
117
134
  onAnimationEnd: handleAnimationEnd,
118
135
  duration: 450,
@@ -124,7 +141,7 @@ function ElementBlock(props) {
124
141
  "aria-label": ariaLabel
125
142
  }), children)));
126
143
  }
127
- ElementBlock._supportsSpacingProps = true;
128
- var _default = ElementBlock;
144
+ ArrayItemArea._supportsSpacingProps = true;
145
+ var _default = ArrayItemArea;
129
146
  exports.default = _default;
130
- //# sourceMappingURL=ElementBlock.js.map
147
+ //# sourceMappingURL=ArrayItemArea.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ArrayItemArea.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateItemContext","_ArrayItemAreaContext","_FieldBoundaryContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","ArrayItemArea","props","forceUpdate","useReducer","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","localContextRef","useRef","hasError","hasSubmitError","useContext","FieldBoundaryContext","current","IterateItemContext","nextFocusElementRef","isNew","value","containerMode","determineMode","useCallback","initialContainerMode","switchContainerMode","omitFocusManagement","useEffect","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","modeOptions","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","HeightAnimation","classnames","duration","keepInDOM","Flex","Stack","element","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew, value } = localContextRef.current\n if (hasSubmitError || !value) {\n localContextRef.current.containerMode = 'edit'\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n const determineMode = useCallback(() => {\n const { initialContainerMode, switchContainerMode } =\n localContextRef.current\n if (\n mode === 'edit' &&\n !hasSubmitError &&\n initialContainerMode === 'auto'\n ) {\n // - Set the container mode to \"edit\" if we have an error\n if (hasError && !isNew) {\n switchContainerMode('edit', { omitFocusManagement: true })\n }\n }\n }, [hasError, hasSubmitError, isNew, mode])\n\n useEffect(() => {\n determineMode()\n }, [determineMode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider value={{ handleRemoveItem }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ type ArrayItemAreaContext = {
3
+ handleRemoveItem?: () => void;
4
+ };
5
+ declare const ArrayItemAreaContext: import("react").Context<ArrayItemAreaContext>;
6
+ export default ArrayItemAreaContext;
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.default = void 0;
8
8
  var _react = require("react");
9
- const ElementBlockContext = (0, _react.createContext)(null);
10
- var _default = ElementBlockContext;
9
+ const ArrayItemAreaContext = (0, _react.createContext)(null);
10
+ var _default = ArrayItemAreaContext;
11
11
  exports.default = _default;
12
- //# sourceMappingURL=ElementBlockContext.js.map
12
+ //# sourceMappingURL=ArrayItemAreaContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ArrayItemAreaContext.js","names":["_react","require","ArrayItemAreaContext","createContext","_default","exports","default"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemAreaContext.ts"],"sourcesContent":["import { createContext } from 'react'\n\ntype ArrayItemAreaContext = {\n handleRemoveItem?: () => void\n}\n\nconst ArrayItemAreaContext = createContext<ArrayItemAreaContext>(null)\n\nexport default ArrayItemAreaContext\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AAMA,MAAMC,oBAAoB,GAAG,IAAAC,oBAAa,EAAuB,IAAI,CAAC;AAAA,IAAAC,QAAA,GAEvDF,oBAAoB;AAAAG,OAAA,CAAAC,OAAA,GAAAF,QAAA"}
@@ -1,18 +1,20 @@
1
1
  /// <reference types="react" />
2
- import { Path, UseFieldProps } from '../../types';
2
+ import { Path, UseFieldProps, Validator } from '../../types';
3
3
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
4
- export type ContainerMode = 'view' | 'edit';
4
+ export type ContainerMode = 'view' | 'edit' | 'auto';
5
5
  export type Value = Array<unknown | Record<string, unknown>>;
6
6
  export type ElementChild = React.ReactNode | ((value: any, index: number) => React.ReactNode);
7
- export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'emptyValue' | 'onChange'> & {
7
+ export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'defaultValue' | 'emptyValue' | 'onChange' | 'validateInitially' | 'continuousValidation'> & {
8
8
  children: ElementChild | Array<ElementChild>;
9
9
  path?: Path;
10
10
  countPath?: Path;
11
11
  countPathLimit?: number;
12
+ validator?: Validator<Value>;
13
+ withoutFlex?: boolean;
14
+ placeholder?: React.ReactNode;
15
+ containerMode?: ContainerMode;
12
16
  countPathTransform?: (params: {
13
17
  value: any;
14
18
  index: number;
15
19
  }) => any;
16
- withoutFlex?: boolean;
17
- placeholder?: React.ReactNode;
18
20
  };
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit'\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' | 'emptyValue' | 'onChange'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n countPath?: Path\n countPathLimit?: number\n countPathTransform?: (params: { value: any; index: number }) => any\n withoutFlex?: boolean\n placeholder?: React.ReactNode\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 countPath?: Path\n countPathLimit?: number\n validator?: Validator<Value>\n withoutFlex?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n countPathTransform?: (params: { value: any; index: number }) => any\n }\n"],"mappings":""}
@@ -0,0 +1,9 @@
1
+ import { ButtonProps } from '../../../../components/Button';
2
+ import { ContainerMode } from '../Array';
3
+ type Props = ButtonProps;
4
+ export default function EditToolbarTools(props: Props): import("react/jsx-runtime").JSX.Element;
5
+ export declare function useWasNew({ isNew, containerMode, }: {
6
+ isNew: boolean;
7
+ containerMode: ContainerMode;
8
+ }): unknown;
9
+ export {};
@@ -10,21 +10,23 @@ var _react = _interopRequireWildcard(require("react"));
10
10
  var _components = require("../../../../components");
11
11
  var _useTranslation = _interopRequireDefault(require("../../hooks/useTranslation"));
12
12
  var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
13
+ var _ToolbarContext = _interopRequireDefault(require("../Toolbar/ToolbarContext"));
14
+ var _FieldBoundaryContext = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryContext"));
13
15
  var _icons = require("../../../../icons");
14
16
  var _RemoveButton = _interopRequireDefault(require("../RemoveButton"));
15
- var _FieldBoundaryContext = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryContext"));
16
- var _PushContainerContext = _interopRequireDefault(require("../PushContainer/PushContainerContext"));
17
17
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18
18
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
19
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
20
- function EditToolbarTools() {
20
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
21
+ function EditToolbarTools(props) {
21
22
  const {
22
23
  restoreOriginalValue,
23
24
  switchContainerMode,
24
25
  containerMode,
26
+ initialContainerMode,
25
27
  arrayValue,
26
- index,
27
- isNew
28
+ isNew,
29
+ index
28
30
  } = (0, _react.useContext)(_IterateItemContext.default) || {};
29
31
  const {
30
32
  hasError,
@@ -32,24 +34,13 @@ function EditToolbarTools() {
32
34
  setShowBoundaryErrors
33
35
  } = (0, _react.useContext)(_FieldBoundaryContext.default) || {};
34
36
  const {
35
- entries,
36
- commitHandleRef
37
- } = (0, _react.useContext)(_PushContainerContext.default) || {};
37
+ setShowError
38
+ } = (0, _react.useContext)(_ToolbarContext.default) || {};
38
39
  const {
39
- doneButton,
40
40
  cancelButton,
41
- removeButton,
42
- errorInSection
41
+ removeButton
43
42
  } = (0, _useTranslation.default)().IterateEditContainer;
44
- const {
45
- createButton
46
- } = (0, _useTranslation.default)().IteratePushContainer;
47
43
  const valueBackupRef = (0, _react.useRef)();
48
- const wasNew = useWasNew({
49
- isNew,
50
- containerMode
51
- });
52
- const [showError, setShowError] = (0, _react.useState)(false);
53
44
  (0, _react.useEffect)(() => {
54
45
  if (containerMode === 'edit' && !valueBackupRef.current) {
55
46
  valueBackupRef.current = arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue[index];
@@ -59,53 +50,36 @@ function EditToolbarTools() {
59
50
  }
60
51
  }, [arrayValue, containerMode, index]);
61
52
  const cancelHandler = (0, _react.useCallback)(() => {
62
- if (valueBackupRef.current) {
63
- restoreOriginalValue === null || restoreOriginalValue === void 0 ? void 0 : restoreOriginalValue(valueBackupRef.current);
64
- }
65
- setShowError(false);
66
- setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
67
- switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
68
- }, [restoreOriginalValue, setShowBoundaryErrors, switchContainerMode]);
69
- const doneHandler = (0, _react.useCallback)(() => {
70
- if (hasError) {
53
+ if (hasError && initialContainerMode === 'auto') {
71
54
  setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
72
55
  if (hasVisibleError) {
73
56
  setShowError(true);
74
57
  }
75
58
  } else {
76
- setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
59
+ restoreOriginalValue === null || restoreOriginalValue === void 0 ? void 0 : restoreOriginalValue(valueBackupRef.current);
77
60
  setShowError(false);
78
- if (commitHandleRef) {
79
- var _commitHandleRef$curr;
80
- (_commitHandleRef$curr = commitHandleRef.current) === null || _commitHandleRef$curr === void 0 ? void 0 : _commitHandleRef$curr.call(commitHandleRef);
81
- } else {
82
- switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
83
- }
61
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
62
+ switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
84
63
  }
85
- }, [commitHandleRef, hasError, hasVisibleError, setShowBoundaryErrors, switchContainerMode]);
86
- return _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_components.FormStatus, {
87
- show: showError && hasVisibleError,
88
- no_animation: false
89
- }, errorInSection), _react.default.createElement(_components.Flex.Horizontal, {
90
- gap: "large"
91
- }, commitHandleRef ? _react.default.createElement(_components.Button, {
92
- variant: "tertiary",
93
- icon: _icons.check,
94
- icon_position: "left",
95
- on_click: doneHandler
96
- }, createButton) : _react.default.createElement(_components.Button, {
97
- variant: "tertiary",
98
- icon: _icons.check,
99
- icon_position: "left",
100
- on_click: doneHandler
101
- }, doneButton), (!entries || (entries === null || entries === void 0 ? void 0 : entries.length) > 0 && containerMode === 'edit') && (wasNew ? _react.default.createElement(_RemoveButton.default, {
102
- text: removeButton
103
- }) : _react.default.createElement(_components.Button, {
64
+ }, [hasError, hasVisibleError, initialContainerMode, restoreOriginalValue, setShowBoundaryErrors, setShowError, switchContainerMode]);
65
+ const wasNew = useWasNew({
66
+ isNew,
67
+ containerMode
68
+ });
69
+ if (containerMode === 'edit' && (arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue.length) === 0) {
70
+ return _react.default.createElement(_react.default.Fragment, null);
71
+ }
72
+ if (wasNew) {
73
+ return _react.default.createElement(_RemoveButton.default, _extends({
74
+ text: removeButton
75
+ }, props));
76
+ }
77
+ return _react.default.createElement(_components.Button, _extends({
104
78
  variant: "tertiary",
105
79
  icon: _icons.close,
106
80
  icon_position: "left",
107
81
  on_click: cancelHandler
108
- }, cancelButton))));
82
+ }, props), cancelButton);
109
83
  }
110
84
  function useWasNew(_ref) {
111
85
  let {
@@ -120,4 +94,4 @@ function useWasNew(_ref) {
120
94
  }, [isNew, containerMode]);
121
95
  return wasNewRef.current;
122
96
  }
123
- //# sourceMappingURL=EditToolbarTools.js.map
97
+ //# sourceMappingURL=CancelButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CancelButton.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_IterateItemContext","_ToolbarContext","_FieldBoundaryContext","_icons","_RemoveButton","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","EditToolbarTools","props","restoreOriginalValue","switchContainerMode","containerMode","initialContainerMode","arrayValue","isNew","index","useContext","IterateItemContext","hasError","hasVisibleError","setShowBoundaryErrors","FieldBoundaryContext","setShowError","ToolbarContext","cancelButton","removeButton","useTranslation","IterateEditContainer","valueBackupRef","useRef","useEffect","current","cancelHandler","useCallback","wasNew","useWasNew","createElement","Fragment","text","Button","variant","icon","close","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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"}
@@ -0,0 +1,4 @@
1
+ import { ButtonProps } from '../../../../components/Button';
2
+ type Props = ButtonProps;
3
+ export default function DoneButton(props: Props): import("react/jsx-runtime").JSX.Element;
4
+ export {};
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ "use client";
3
+
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = DoneButton;
8
+ var _react = _interopRequireWildcard(require("react"));
9
+ var _components = require("../../../../components");
10
+ var _useTranslation = _interopRequireDefault(require("../../hooks/useTranslation"));
11
+ var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
12
+ var _ToolbarContext = _interopRequireDefault(require("../Toolbar/ToolbarContext"));
13
+ var _FieldBoundaryContext = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryContext"));
14
+ var _PushContainerContext = _interopRequireDefault(require("../PushContainer/PushContainerContext"));
15
+ var _icons = require("../../../../icons");
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
18
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
19
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
20
+ function DoneButton(props) {
21
+ const {
22
+ switchContainerMode,
23
+ containerMode,
24
+ arrayValue,
25
+ index
26
+ } = (0, _react.useContext)(_IterateItemContext.default) || {};
27
+ const {
28
+ hasError,
29
+ hasVisibleError,
30
+ setShowBoundaryErrors
31
+ } = (0, _react.useContext)(_FieldBoundaryContext.default) || {};
32
+ const {
33
+ commitHandleRef
34
+ } = (0, _react.useContext)(_PushContainerContext.default) || {};
35
+ (0, _react.useContext)(_FieldBoundaryContext.default) || {};
36
+ const {
37
+ setShowError
38
+ } = (0, _react.useContext)(_ToolbarContext.default) || {};
39
+ const {
40
+ doneButton
41
+ } = (0, _useTranslation.default)().IterateEditContainer;
42
+ const valueBackupRef = (0, _react.useRef)();
43
+ (0, _react.useEffect)(() => {
44
+ if (containerMode === 'edit' && !valueBackupRef.current) {
45
+ valueBackupRef.current = arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue[index];
46
+ }
47
+ if (containerMode === 'view') {
48
+ valueBackupRef.current = null;
49
+ }
50
+ }, [arrayValue, containerMode, index]);
51
+ const doneHandler = (0, _react.useCallback)(() => {
52
+ if (hasError) {
53
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
54
+ if (hasVisibleError) {
55
+ setShowError(true);
56
+ }
57
+ } else {
58
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
59
+ setShowError(false);
60
+ if (commitHandleRef) {
61
+ var _commitHandleRef$curr;
62
+ (_commitHandleRef$curr = commitHandleRef.current) === null || _commitHandleRef$curr === void 0 ? void 0 : _commitHandleRef$curr.call(commitHandleRef);
63
+ } else {
64
+ switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
65
+ }
66
+ }
67
+ }, [commitHandleRef, hasError, hasVisibleError, setShowBoundaryErrors, setShowError, switchContainerMode]);
68
+ return _react.default.createElement(_components.Button, _extends({
69
+ variant: "tertiary",
70
+ icon: _icons.check,
71
+ icon_position: "left",
72
+ on_click: doneHandler
73
+ }, props), doneButton);
74
+ }
75
+ //# sourceMappingURL=DoneButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DoneButton.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_IterateItemContext","_ToolbarContext","_FieldBoundaryContext","_PushContainerContext","_icons","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","DoneButton","props","switchContainerMode","containerMode","arrayValue","index","useContext","IterateItemContext","hasError","hasVisibleError","setShowBoundaryErrors","FieldBoundaryContext","commitHandleRef","PushContainerContext","setShowError","ToolbarContext","doneButton","useTranslation","IterateEditContainer","valueBackupRef","useRef","useEffect","current","doneHandler","useCallback","_commitHandleRef$curr","createElement","Button","variant","icon","check","icon_position","on_click"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/DoneButton.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 PushContainerContext from '../PushContainer/PushContainerContext'\nimport { check } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\n\ntype Props = ButtonProps\n\nexport default function DoneButton(props: Props) {\n const { switchContainerMode, containerMode, arrayValue, index } =\n useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { commitHandleRef } = useContext(PushContainerContext) || {}\n useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { doneButton } = 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 doneHandler = useCallback(() => {\n if (hasError) {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowBoundaryErrors?.(false)\n setShowError(false)\n if (commitHandleRef) {\n commitHandleRef.current?.()\n } else {\n switchContainerMode?.('view')\n }\n }\n }, [\n commitHandleRef,\n hasError,\n hasVisibleError,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n return (\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n {...props}\n >\n {doneButton}\n </Button>\n )\n}\n"],"mappings":"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"}