@dnb/eufemia 10.47.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 (561) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/cjs/extensions/forms/DataContext/Context.d.ts +1 -0
  3. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  4. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  5. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  6. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  7. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +12 -5
  8. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  9. package/cjs/extensions/forms/DataContext/Provider/Provider.js +1 -0
  10. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  11. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  12. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  13. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  14. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +32 -7
  15. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  16. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  17. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  18. package/cjs/extensions/forms/Form/Isolation/Isolation.js +2 -3
  19. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  20. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js +20 -1
  21. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  22. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  23. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  24. package/cjs/extensions/forms/Form/Section/Section.d.ts +7 -2
  25. package/cjs/extensions/forms/Form/Section/Section.js +3 -1
  26. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  27. package/cjs/extensions/forms/Form/Section/SectionDocs.js +6 -1
  28. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  29. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  30. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  31. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  32. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  33. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  34. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  35. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  36. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  37. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  38. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  39. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  40. package/cjs/extensions/forms/Iterate/Array/Array.js +67 -24
  41. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  42. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  43. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  44. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  45. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.js → Array/ArrayItemArea.js} +66 -49
  46. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  47. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  48. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlockContext.js → Array/ArrayItemAreaContext.js} +3 -3
  49. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  50. package/cjs/extensions/forms/Iterate/Array/types.d.ts +7 -5
  51. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  52. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  53. package/cjs/extensions/forms/Iterate/EditContainer/{EditToolbarTools.js → CancelButton.js} +30 -56
  54. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  55. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  56. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js +75 -0
  57. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  58. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  59. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +33 -12
  60. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  61. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  62. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  63. package/cjs/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  64. package/cjs/extensions/forms/Iterate/EditContainer/index.js +19 -1
  65. package/cjs/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  66. package/cjs/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  67. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  68. package/cjs/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  69. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  70. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  71. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  72. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -24
  73. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  74. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  75. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  76. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  77. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  78. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  79. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -6
  80. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  81. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  82. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js +12 -0
  83. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  84. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  85. package/cjs/extensions/forms/Iterate/ViewContainer/{ViewToolbarTools.js → EditButton.js} +8 -11
  86. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  87. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  88. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js +19 -0
  89. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  90. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  91. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +25 -10
  92. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  93. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  94. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  95. package/cjs/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  96. package/cjs/extensions/forms/Iterate/ViewContainer/index.js +19 -1
  97. package/cjs/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  98. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  99. package/cjs/extensions/forms/Iterate/hooks/index.js +21 -0
  100. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -0
  101. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  102. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +93 -0
  103. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  104. package/cjs/extensions/forms/Tools/Log.d.ts +6 -0
  105. package/cjs/extensions/forms/Tools/Log.js +29 -0
  106. package/cjs/extensions/forms/Tools/Log.js.map +1 -0
  107. package/cjs/extensions/forms/Tools/index.d.ts +1 -0
  108. package/cjs/extensions/forms/Tools/index.js +7 -0
  109. package/cjs/extensions/forms/Tools/index.js.map +1 -1
  110. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  111. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  112. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  113. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  114. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  115. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  116. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  117. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  118. package/cjs/extensions/forms/constants/countries.js +10 -26
  119. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  120. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  121. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -2
  122. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  123. package/cjs/extensions/forms/constants/locales/en-US.d.ts +2 -1
  124. package/cjs/extensions/forms/constants/locales/index.d.ts +4 -2
  125. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  126. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -2
  127. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  128. package/cjs/extensions/forms/hooks/DataValueDocs.js +6 -1
  129. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  130. package/cjs/extensions/forms/hooks/useExternalValue.js +8 -6
  131. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  132. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  133. package/cjs/extensions/forms/hooks/useFieldProps.js +29 -14
  134. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  135. package/cjs/extensions/forms/hooks/usePath.d.ts +1 -0
  136. package/cjs/extensions/forms/hooks/usePath.js +5 -1
  137. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  138. package/cjs/extensions/forms/style/dnb-forms.css +3 -0
  139. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  140. package/cjs/extensions/forms/types.d.ts +4 -0
  141. package/cjs/extensions/forms/types.js.map +1 -1
  142. package/cjs/shared/Eufemia.d.ts +1 -1
  143. package/cjs/shared/Eufemia.js +2 -2
  144. package/cjs/shared/Eufemia.js.map +1 -1
  145. package/cjs/style/core/scopes.scss +1 -1
  146. package/cjs/style/dnb-ui-basis.css +1 -1
  147. package/cjs/style/dnb-ui-basis.min.css +1 -1
  148. package/cjs/style/dnb-ui-body.css +1 -1
  149. package/cjs/style/dnb-ui-body.min.css +1 -1
  150. package/cjs/style/dnb-ui-components.css +3 -0
  151. package/cjs/style/dnb-ui-components.min.css +1 -1
  152. package/cjs/style/dnb-ui-core.css +1 -1
  153. package/cjs/style/dnb-ui-core.min.css +1 -1
  154. package/cjs/style/dnb-ui-extensions.css +3 -0
  155. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  156. package/cjs/style/dnb-ui-forms.css +3 -0
  157. package/cjs/style/dnb-ui-forms.min.css +1 -1
  158. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  159. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  160. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  161. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  162. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  163. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  164. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  165. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  166. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  167. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  168. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  169. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  170. package/cjs/style/themes/theme-ui/ui-theme-components.css +6 -0
  171. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  172. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  173. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  174. package/cjs/style/themes/theme-ui/ui-theme-forms.css +3 -0
  175. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  176. package/es/extensions/forms/DataContext/Context.d.ts +1 -0
  177. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  178. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  179. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  180. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  181. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +13 -5
  182. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  183. package/es/extensions/forms/DataContext/Provider/Provider.js +1 -0
  184. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  185. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  186. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  187. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  188. package/es/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  189. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  190. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  191. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  192. package/es/extensions/forms/Form/Isolation/Isolation.js +2 -3
  193. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  194. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  195. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  196. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  197. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  198. package/es/extensions/forms/Form/Section/Section.d.ts +7 -2
  199. package/es/extensions/forms/Form/Section/Section.js +3 -1
  200. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  201. package/es/extensions/forms/Form/Section/SectionDocs.js +6 -1
  202. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  203. package/es/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  204. package/es/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  205. package/es/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  206. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  207. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  208. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  209. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  210. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  211. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  212. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  213. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  214. package/es/extensions/forms/Iterate/Array/Array.js +67 -25
  215. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  216. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  217. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  218. package/es/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  219. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  220. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  221. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  222. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  223. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  224. package/es/extensions/forms/Iterate/Array/types.d.ts +7 -5
  225. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  226. package/es/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  227. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +87 -0
  228. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  229. package/es/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  230. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js +67 -0
  231. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  232. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  233. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  234. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  235. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  236. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  237. package/es/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  238. package/es/extensions/forms/Iterate/EditContainer/index.js +2 -0
  239. package/es/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  240. package/es/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  241. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  242. package/es/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  243. package/es/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  244. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  245. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  246. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -23
  247. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  248. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  249. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  250. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  251. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  252. package/es/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  253. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +51 -7
  254. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  255. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  256. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  257. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  258. package/es/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  259. package/{extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → es/extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  260. package/es/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  261. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  262. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  263. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  264. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  265. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  266. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  267. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  268. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  269. package/es/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  270. package/es/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  271. package/es/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  272. package/es/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  273. package/es/extensions/forms/Iterate/hooks/index.js +3 -0
  274. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -0
  275. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  276. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +85 -0
  277. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  278. package/es/extensions/forms/Tools/Log.d.ts +6 -0
  279. package/es/extensions/forms/Tools/Log.js +22 -0
  280. package/es/extensions/forms/Tools/Log.js.map +1 -0
  281. package/es/extensions/forms/Tools/index.d.ts +1 -0
  282. package/es/extensions/forms/Tools/index.js +1 -0
  283. package/es/extensions/forms/Tools/index.js.map +1 -1
  284. package/es/extensions/forms/Wizard/Container/WizardContainer.js +17 -6
  285. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  286. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  287. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  288. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  289. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  290. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  291. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  292. package/es/extensions/forms/constants/countries.js +10 -26
  293. package/es/extensions/forms/constants/countries.js.map +1 -1
  294. package/es/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  295. package/es/extensions/forms/constants/locales/en-GB.js +3 -2
  296. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  297. package/es/extensions/forms/constants/locales/en-US.d.ts +2 -1
  298. package/es/extensions/forms/constants/locales/index.d.ts +4 -2
  299. package/es/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  300. package/es/extensions/forms/constants/locales/nb-NO.js +3 -2
  301. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  302. package/es/extensions/forms/hooks/DataValueDocs.js +6 -1
  303. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  304. package/es/extensions/forms/hooks/useExternalValue.js +8 -6
  305. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  306. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  307. package/es/extensions/forms/hooks/useFieldProps.js +29 -15
  308. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  309. package/es/extensions/forms/hooks/usePath.d.ts +1 -0
  310. package/es/extensions/forms/hooks/usePath.js +5 -1
  311. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  312. package/es/extensions/forms/style/dnb-forms.css +3 -0
  313. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  314. package/es/extensions/forms/types.d.ts +4 -0
  315. package/es/extensions/forms/types.js.map +1 -1
  316. package/es/shared/Eufemia.d.ts +1 -1
  317. package/es/shared/Eufemia.js +2 -2
  318. package/es/shared/Eufemia.js.map +1 -1
  319. package/es/style/core/scopes.scss +1 -1
  320. package/es/style/dnb-ui-basis.css +1 -1
  321. package/es/style/dnb-ui-basis.min.css +1 -1
  322. package/es/style/dnb-ui-body.css +1 -1
  323. package/es/style/dnb-ui-body.min.css +1 -1
  324. package/es/style/dnb-ui-components.css +3 -0
  325. package/es/style/dnb-ui-components.min.css +1 -1
  326. package/es/style/dnb-ui-core.css +1 -1
  327. package/es/style/dnb-ui-core.min.css +1 -1
  328. package/es/style/dnb-ui-extensions.css +3 -0
  329. package/es/style/dnb-ui-extensions.min.css +1 -1
  330. package/es/style/dnb-ui-forms.css +3 -0
  331. package/es/style/dnb-ui-forms.min.css +1 -1
  332. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  333. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  334. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  335. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  336. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  337. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  338. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  339. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  340. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  341. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  342. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  343. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  344. package/es/style/themes/theme-ui/ui-theme-components.css +6 -0
  345. package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  346. package/es/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  347. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  348. package/es/style/themes/theme-ui/ui-theme-forms.css +3 -0
  349. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  350. package/esm/dnb-ui-basis.min.mjs +1 -1
  351. package/esm/dnb-ui-components.min.mjs +1 -1
  352. package/esm/dnb-ui-elements.min.mjs +1 -1
  353. package/esm/dnb-ui-extensions.min.mjs +2 -2
  354. package/esm/dnb-ui-lib.min.mjs +1 -1
  355. package/extensions/forms/DataContext/Context.d.ts +1 -0
  356. package/extensions/forms/DataContext/Context.js.map +1 -1
  357. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  358. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  359. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  360. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +12 -5
  361. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  362. package/extensions/forms/DataContext/Provider/Provider.js +1 -0
  363. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  364. package/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  365. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  366. package/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  367. package/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  368. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  369. package/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  370. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  371. package/extensions/forms/Form/Isolation/Isolation.js +2 -3
  372. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  373. package/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  374. package/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  375. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  376. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  377. package/extensions/forms/Form/Section/Section.d.ts +7 -2
  378. package/extensions/forms/Form/Section/Section.js +3 -1
  379. package/extensions/forms/Form/Section/Section.js.map +1 -1
  380. package/extensions/forms/Form/Section/SectionDocs.js +6 -1
  381. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  382. package/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  383. package/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  384. package/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  385. package/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  386. package/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  387. package/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  388. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  389. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  390. package/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  391. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  392. package/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  393. package/extensions/forms/Iterate/Array/Array.js +68 -25
  394. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  395. package/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  396. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  397. package/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  398. package/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  399. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  400. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  401. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  402. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  403. package/extensions/forms/Iterate/Array/types.d.ts +7 -5
  404. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  405. package/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  406. package/extensions/forms/Iterate/EditContainer/CancelButton.js +88 -0
  407. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  408. package/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  409. package/extensions/forms/Iterate/EditContainer/DoneButton.js +67 -0
  410. package/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  411. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  412. package/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  413. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  414. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  415. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  416. package/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  417. package/extensions/forms/Iterate/EditContainer/index.js +2 -0
  418. package/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  419. package/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  420. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  421. package/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  422. package/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  423. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  424. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  425. package/extensions/forms/Iterate/PushContainer/PushContainer.js +80 -26
  426. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  427. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  428. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  429. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  430. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  431. package/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  432. package/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -7
  433. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  434. package/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  435. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  436. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  437. package/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  438. package/{es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  439. package/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  440. package/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  441. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  442. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  443. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  444. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  445. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  446. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  447. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  448. package/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  449. package/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  450. package/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  451. package/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  452. package/extensions/forms/Iterate/hooks/index.js +3 -0
  453. package/extensions/forms/Iterate/hooks/index.js.map +1 -0
  454. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  455. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +87 -0
  456. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  457. package/extensions/forms/Tools/Log.d.ts +6 -0
  458. package/extensions/forms/Tools/Log.js +22 -0
  459. package/extensions/forms/Tools/Log.js.map +1 -0
  460. package/extensions/forms/Tools/index.d.ts +1 -0
  461. package/extensions/forms/Tools/index.js +1 -0
  462. package/extensions/forms/Tools/index.js.map +1 -1
  463. package/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  464. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  465. package/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  466. package/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  467. package/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  468. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  469. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  470. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  471. package/extensions/forms/constants/countries.js +10 -26
  472. package/extensions/forms/constants/countries.js.map +1 -1
  473. package/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  474. package/extensions/forms/constants/locales/en-GB.js +3 -2
  475. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  476. package/extensions/forms/constants/locales/en-US.d.ts +2 -1
  477. package/extensions/forms/constants/locales/index.d.ts +4 -2
  478. package/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  479. package/extensions/forms/constants/locales/nb-NO.js +3 -2
  480. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  481. package/extensions/forms/hooks/DataValueDocs.js +6 -1
  482. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  483. package/extensions/forms/hooks/useExternalValue.js +8 -6
  484. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  485. package/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  486. package/extensions/forms/hooks/useFieldProps.js +29 -14
  487. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  488. package/extensions/forms/hooks/usePath.d.ts +1 -0
  489. package/extensions/forms/hooks/usePath.js +5 -1
  490. package/extensions/forms/hooks/usePath.js.map +1 -1
  491. package/extensions/forms/style/dnb-forms.css +3 -0
  492. package/extensions/forms/style/dnb-forms.min.css +1 -1
  493. package/extensions/forms/types.d.ts +4 -0
  494. package/extensions/forms/types.js.map +1 -1
  495. package/package.json +1 -1
  496. package/shared/Eufemia.d.ts +1 -1
  497. package/shared/Eufemia.js +2 -2
  498. package/shared/Eufemia.js.map +1 -1
  499. package/style/core/scopes.scss +1 -1
  500. package/style/dnb-ui-basis.css +1 -1
  501. package/style/dnb-ui-basis.min.css +1 -1
  502. package/style/dnb-ui-body.css +1 -1
  503. package/style/dnb-ui-body.min.css +1 -1
  504. package/style/dnb-ui-components.css +3 -0
  505. package/style/dnb-ui-components.min.css +1 -1
  506. package/style/dnb-ui-core.css +1 -1
  507. package/style/dnb-ui-core.min.css +1 -1
  508. package/style/dnb-ui-extensions.css +3 -0
  509. package/style/dnb-ui-extensions.min.css +1 -1
  510. package/style/dnb-ui-forms.css +3 -0
  511. package/style/dnb-ui-forms.min.css +1 -1
  512. package/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  513. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  514. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  515. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  516. package/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  517. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  518. package/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  519. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  520. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  521. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  522. package/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  523. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  524. package/style/themes/theme-ui/ui-theme-components.css +6 -0
  525. package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  526. package/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  527. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  528. package/style/themes/theme-ui/ui-theme-forms.css +3 -0
  529. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  530. package/umd/dnb-ui-basis.min.js +1 -1
  531. package/umd/dnb-ui-components.min.js +1 -1
  532. package/umd/dnb-ui-elements.min.js +1 -1
  533. package/umd/dnb-ui-extensions.min.js +3 -3
  534. package/umd/dnb-ui-lib.min.js +1 -1
  535. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  536. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  537. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  538. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  539. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  540. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  541. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  542. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  543. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  544. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  545. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  546. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  547. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  548. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -113
  549. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  550. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  551. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  552. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  553. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  554. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  555. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  556. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  557. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  558. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -114
  559. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  560. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  561. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"EditToolbarTools.js","names":["React","useCallback","useContext","useState","Button","Flex","FormStatus","useTranslation","SectionContainerContext","FieldBoundaryContext","check","close","useContainerDataStore","useEditContainerToolbar","EditToolbarTools","restoreOriginalData","switchContainerMode","hasVisibleError","hasSubmitError","hasError","setShowBoundaryErrors","translation","SectionEditContainer","showError","setShowError","cancelHandler","doneHandler","createElement","Fragment","show","no_animation","errorInSection","Horizontal","gap","variant","icon","icon_position","on_click","doneButton","cancelButton"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext, useState } from 'react'\nimport { Button, Flex, FormStatus } from '../../../../../components'\nimport useTranslation from '../../../hooks/useTranslation'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { check, close } from '../../../../../icons'\nimport useContainerDataStore from './useContainerDataStore'\nimport useEditContainerToolbar from './useEditContainerToolbar'\n\nexport default function EditToolbarTools() {\n useEditContainerToolbar()\n const { restoreOriginalData } = useContainerDataStore()\n\n const { switchContainerMode } = useContext(SectionContainerContext) || {}\n const {\n hasVisibleError,\n hasSubmitError,\n hasError,\n setShowBoundaryErrors,\n } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().SectionEditContainer\n\n const [showError, setShowError] = useState(false)\n\n const cancelHandler = useCallback(() => {\n if (hasSubmitError) {\n setShowError(true)\n setShowBoundaryErrors?.(true)\n } else {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n restoreOriginalData()\n switchContainerMode?.('view')\n }\n }, [\n hasSubmitError,\n restoreOriginalData,\n setShowBoundaryErrors,\n switchContainerMode,\n ])\n const doneHandler = useCallback(() => {\n if (hasError) {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n }\n }, [\n hasVisibleError,\n hasError,\n setShowBoundaryErrors,\n switchContainerMode,\n ])\n\n return (\n <>\n <FormStatus show={showError && hasVisibleError} no_animation={false}>\n {translation.errorInSection}\n </FormStatus>\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n >\n {translation.doneButton}\n </Button>\n\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancelButton}\n </Button>\n </Flex.Horizontal>\n </>\n )\n}\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,EAAEC,QAAQ,QAAQ,OAAO;AAChE,SAASC,MAAM,EAAEC,IAAI,EAAEC,UAAU,QAAQ,2BAA2B;AACpE,OAAOC,cAAc,MAAM,+BAA+B;AAC1D,OAAOC,uBAAuB,MAAM,uCAAuC;AAC3E,OAAOC,oBAAoB,MAAM,yDAAyD;AAC1F,SAASC,KAAK,EAAEC,KAAK,QAAQ,sBAAsB;AACnD,OAAOC,qBAAqB,MAAM,yBAAyB;AAC3D,OAAOC,uBAAuB,MAAM,2BAA2B;AAE/D,eAAe,SAASC,gBAAgBA,CAAA,EAAG;EACzCD,uBAAuB,CAAC,CAAC;EACzB,MAAM;IAAEE;EAAoB,CAAC,GAAGH,qBAAqB,CAAC,CAAC;EAEvD,MAAM;IAAEI;EAAoB,CAAC,GAAGd,UAAU,CAACM,uBAAuB,CAAC,IAAI,CAAC,CAAC;EACzE,MAAM;IACJS,eAAe;IACfC,cAAc;IACdC,QAAQ;IACRC;EACF,CAAC,GAAGlB,UAAU,CAACO,oBAAoB,CAAC,IAAI,CAAC,CAAC;EAE1C,MAAMY,WAAW,GAAGd,cAAc,CAAC,CAAC,CAACe,oBAAoB;EAEzD,MAAM,CAACC,SAAS,EAAEC,YAAY,CAAC,GAAGrB,QAAQ,CAAC,KAAK,CAAC;EAEjD,MAAMsB,aAAa,GAAGxB,WAAW,CAAC,MAAM;IACtC,IAAIiB,cAAc,EAAE;MAClBM,YAAY,CAAC,IAAI,CAAC;MAClBJ,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,IAAI,CAAC;IAC/B,CAAC,MAAM;MACLI,YAAY,CAAC,KAAK,CAAC;MACnBJ,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,KAAK,CAAC;MAC9BL,mBAAmB,CAAC,CAAC;MACrBC,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;IAC/B;EACF,CAAC,EAAE,CACDE,cAAc,EACdH,mBAAmB,EACnBK,qBAAqB,EACrBJ,mBAAmB,CACpB,CAAC;EACF,MAAMU,WAAW,GAAGzB,WAAW,CAAC,MAAM;IACpC,IAAIkB,QAAQ,EAAE;MACZC,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,IAAI,CAAC;MAC7B,IAAIH,eAAe,EAAE;QACnBO,YAAY,CAAC,IAAI,CAAC;MACpB;IACF,CAAC,MAAM;MACLA,YAAY,CAAC,KAAK,CAAC;MACnBJ,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,KAAK,CAAC;MAC9BJ,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;IAC/B;EACF,CAAC,EAAE,CACDC,eAAe,EACfE,QAAQ,EACRC,qBAAqB,EACrBJ,mBAAmB,CACpB,CAAC;EAEF,OACEhB,KAAA,CAAA2B,aAAA,CAAA3B,KAAA,CAAA4B,QAAA,QACE5B,KAAA,CAAA2B,aAAA,CAACrB,UAAU;IAACuB,IAAI,EAAEN,SAAS,IAAIN,eAAgB;IAACa,YAAY,EAAE;EAAM,GACjET,WAAW,CAACU,cACH,CAAC,EACb/B,KAAA,CAAA2B,aAAA,CAACtB,IAAI,CAAC2B,UAAU;IAACC,GAAG,EAAC;EAAO,GAC1BjC,KAAA,CAAA2B,aAAA,CAACvB,MAAM;IACL8B,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAEzB,KAAM;IACZ0B,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEX;EAAY,GAErBL,WAAW,CAACiB,UACP,CAAC,EAETtC,KAAA,CAAA2B,aAAA,CAACvB,MAAM;IACL8B,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAExB,KAAM;IACZyB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEZ;EAAc,GAEvBJ,WAAW,CAACkB,YACP,CACO,CACjB,CAAC;AAEP"}
1
+ {"version":3,"file":"EditToolbarTools.js","names":["React","useCallback","useContext","useState","Button","Flex","FormStatus","useTranslation","SectionContainerContext","FieldBoundaryContext","check","close","useContainerDataStore","useEditContainerToolbar","EditToolbarTools","restoreOriginalData","switchContainerMode","initialContainerMode","hasVisibleError","hasSubmitError","hasError","setShowBoundaryErrors","translation","SectionEditContainer","showError","setShowError","cancelHandler","Date","now","doneHandler","createElement","Fragment","Horizontal","gap","variant","icon","icon_position","on_click","doneButton","cancelButton","show","shellSpace","top","no_animation","errorInSection"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext, useState } from 'react'\nimport { Button, Flex, FormStatus } from '../../../../../components'\nimport useTranslation from '../../../hooks/useTranslation'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { check, close } from '../../../../../icons'\nimport useContainerDataStore from './useContainerDataStore'\nimport useEditContainerToolbar from './useEditContainerToolbar'\n\nexport default function EditToolbarTools() {\n useEditContainerToolbar()\n const { restoreOriginalData } = useContainerDataStore()\n\n const { switchContainerMode, initialContainerMode } =\n useContext(SectionContainerContext) || {}\n const {\n hasVisibleError,\n hasSubmitError,\n hasError,\n setShowBoundaryErrors,\n } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().SectionEditContainer\n\n const [showError, setShowError] = useState(false)\n\n const cancelHandler = useCallback(() => {\n if (hasSubmitError || (initialContainerMode === 'auto' && hasError)) {\n setShowBoundaryErrors?.(Date.now())\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n restoreOriginalData()\n switchContainerMode?.('view')\n }\n }, [\n hasSubmitError,\n initialContainerMode,\n hasError,\n setShowBoundaryErrors,\n hasVisibleError,\n restoreOriginalData,\n switchContainerMode,\n ])\n const doneHandler = useCallback(() => {\n if (hasError) {\n setShowBoundaryErrors?.(Date.now())\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n }\n }, [\n hasVisibleError,\n hasError,\n setShowBoundaryErrors,\n switchContainerMode,\n ])\n\n return (\n <>\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n >\n {translation.doneButton}\n </Button>\n\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancelButton}\n </Button>\n </Flex.Horizontal>\n\n <FormStatus\n show={showError && hasVisibleError}\n shellSpace={{ top: 'x-small' }}\n no_animation={false}\n >\n {translation.errorInSection}\n </FormStatus>\n </>\n )\n}\n"],"mappings":"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"}
@@ -21,8 +21,13 @@ export type SectionProps<overwriteProps = OverwritePropsDefaults> = {
21
21
  */
22
22
  required?: boolean;
23
23
  /**
24
- * Defines the container mode. Can be `view` or `edit`.
25
- * Defaults to `view`.
24
+ * If set to `true`, the whole section will be validated initially. All fields will then automatically get `validateInitially` and show their error messages. Can be useful in combination with `containerMode="auto"`.
25
+ */
26
+ validateInitially?: boolean;
27
+ /**
28
+ * Defines the container mode. Can be `view`, `edit` or `auto`.
29
+ * When set to `auto`, the mode will initially be "edit" if fields contain errors.
30
+ * Defaults to `auto`.
26
31
  */
27
32
  containerMode?: ContainerMode;
28
33
  /**
@@ -21,7 +21,8 @@ function SectionComponent(props) {
21
21
  required,
22
22
  data,
23
23
  defaultData,
24
- containerMode = 'view',
24
+ validateInitially,
25
+ containerMode = 'auto',
25
26
  onChange,
26
27
  errorPrioritization = ['contextSchema'],
27
28
  children
@@ -63,6 +64,7 @@ function SectionComponent(props) {
63
64
  props
64
65
  }
65
66
  }, React.createElement(SectionContainerProvider, {
67
+ validateInitially: validateInitially,
66
68
  containerMode: containerMode
67
69
  }, React.createElement(FieldPropsProvider, _extends({
68
70
  overwriteProps: _objectSpread(_objectSpread({}, overwriteProps), nestedProps === null || nestedProps === void 0 ? void 0 : (_nestedProps$overwrit = nestedProps.overwriteProps) === null || _nestedProps$overwrit === void 0 ? void 0 : _nestedProps$overwrit[path.substring(1)]),
@@ -1 +1 @@
1
- {"version":3,"file":"Section.js","names":["React","useCallback","useContext","useMemo","SectionContext","DataContext","Provider","FieldPropsProvider","SectionContainerProvider","ViewContainer","EditContainer","SectionComponent","props","_path$startsWith","_nestedProps$overwrit","path","overwriteProps","translations","required","data","defaultData","containerMode","onChange","errorPrioritization","children","startsWith","call","Error","hasContext","addOnChangeHandler","nestedPath","nestedProps","handleChange","_len","arguments","length","args","Array","_key","identifier","fieldProps","undefined","createElement","value","_extends","_objectSpread","substring","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/Section/Section.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport SectionContext, { SectionContextState } from './SectionContext'\nimport DataContext from '../../DataContext/Context'\nimport Provider from '../../DataContext/Provider/Provider'\nimport FieldPropsProvider from '../FieldProps'\nimport SectionContainerProvider from './containers/SectionContainerProvider'\nimport ViewContainer from './ViewContainer'\nimport EditContainer from './EditContainer'\n\nimport type { Props as DataContextProps } from '../../DataContext/Provider'\nimport type { ContainerMode } from './containers/SectionContainer'\nimport type {\n FieldBlockProps,\n Path,\n FieldProps,\n OnChange,\n} from '../../types'\n\nexport type OverwritePropsDefaults = {\n [key: Path]: (FieldProps & FieldBlockProps) | OverwritePropsDefaults\n}\nexport type SectionProps<overwriteProps = OverwritePropsDefaults> = {\n /**\n * Path to the section.\n * When defined, fields inside the section will get this path as a prefix of their own path.\n */\n path?: Path\n\n /**\n * Overwrite field props for the section.\n */\n overwriteProps?: overwriteProps | OverwritePropsDefaults\n\n /**\n * Makes all fields inside it required.\n */\n required?: boolean\n\n /**\n * Defines the container mode. Can be `view` or `edit`.\n * Defaults to `view`.\n */\n containerMode?: ContainerMode\n\n /**\n * Only for internal use and undocumented for now.\n * Prioritize error techniques for the section.\n * Can be `fieldSchema`, `sectionSchema` or `contextSchema.\n */\n errorPrioritization?: SectionContextState['errorPrioritization']\n} & Pick<\n DataContextProps<unknown>,\n 'data' | 'defaultData' | 'onChange' | 'translations'\n>\n\nexport type LocalProps = SectionProps & {\n children: React.ReactNode\n}\n\nfunction SectionComponent(props: LocalProps) {\n const {\n path,\n overwriteProps,\n translations,\n required,\n data,\n defaultData,\n containerMode = 'view',\n onChange,\n errorPrioritization = ['contextSchema'],\n children,\n } = props\n\n if (path && !path.startsWith?.('/')) {\n throw new Error(`path=\"${path}\" must start with a slash`)\n }\n\n const { hasContext, addOnChangeHandler } = useContext(DataContext)\n\n const { path: nestedPath, props: nestedProps } =\n useContext(SectionContext) || {}\n\n const handleChange = useCallback<OnChange>(\n (...args) => onChange?.(...args),\n [onChange]\n )\n addOnChangeHandler?.(handleChange)\n\n const identifier = useMemo(() => {\n return `${nestedPath && nestedPath !== '/' ? nestedPath : ''}${\n path || ''\n }`\n }, [path, nestedPath])\n const fieldProps = required ? { required: true } : undefined\n\n if (!hasContext) {\n return (\n <Provider data={data} defaultData={defaultData}>\n <SectionComponent {...props} />\n </Provider>\n )\n }\n\n return (\n <SectionContext.Provider\n value={{\n path: identifier,\n errorPrioritization,\n props,\n }}\n >\n <SectionContainerProvider containerMode={containerMode}>\n <FieldPropsProvider\n overwriteProps={{\n ...overwriteProps,\n ...(nestedProps?.overwriteProps?.[\n path.substring(1)\n ] as OverwritePropsDefaults),\n }}\n translations={translations}\n {...fieldProps}\n >\n {children}\n </FieldPropsProvider>\n </SectionContainerProvider>\n </SectionContext.Provider>\n )\n}\n\nSectionComponent.ViewContainer = ViewContainer\nSectionComponent.EditContainer = EditContainer\n\nSectionComponent._supportsSpacingProps = undefined\nexport default SectionComponent\n"],"mappings":"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"}
1
+ {"version":3,"file":"Section.js","names":["React","useCallback","useContext","useMemo","SectionContext","DataContext","Provider","FieldPropsProvider","SectionContainerProvider","ViewContainer","EditContainer","SectionComponent","props","_path$startsWith","_nestedProps$overwrit","path","overwriteProps","translations","required","data","defaultData","validateInitially","containerMode","onChange","errorPrioritization","children","startsWith","call","Error","hasContext","addOnChangeHandler","nestedPath","nestedProps","handleChange","_len","arguments","length","args","Array","_key","identifier","fieldProps","undefined","createElement","value","_extends","_objectSpread","substring","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/Section/Section.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport SectionContext, { SectionContextState } from './SectionContext'\nimport DataContext from '../../DataContext/Context'\nimport Provider from '../../DataContext/Provider/Provider'\nimport FieldPropsProvider from '../FieldProps'\nimport SectionContainerProvider from './containers/SectionContainerProvider'\nimport ViewContainer from './ViewContainer'\nimport EditContainer from './EditContainer'\n\nimport type { Props as DataContextProps } from '../../DataContext/Provider'\nimport type { ContainerMode } from './containers/SectionContainer'\nimport type {\n FieldBlockProps,\n Path,\n FieldProps,\n OnChange,\n} from '../../types'\n\nexport type OverwritePropsDefaults = {\n [key: Path]: (FieldProps & FieldBlockProps) | OverwritePropsDefaults\n}\nexport type SectionProps<overwriteProps = OverwritePropsDefaults> = {\n /**\n * Path to the section.\n * When defined, fields inside the section will get this path as a prefix of their own path.\n */\n path?: Path\n\n /**\n * Overwrite field props for the section.\n */\n overwriteProps?: overwriteProps | OverwritePropsDefaults\n\n /**\n * Makes all fields inside it required.\n */\n required?: boolean\n\n /**\n * If set to `true`, the whole section will be validated initially. All fields will then automatically get `validateInitially` and show their error messages. Can be useful in combination with `containerMode=\"auto\"`.\n */\n validateInitially?: boolean\n\n /**\n * Defines the container mode. Can be `view`, `edit` or `auto`.\n * When set to `auto`, the mode will initially be \"edit\" if fields contain errors.\n * Defaults to `auto`.\n */\n containerMode?: ContainerMode\n\n /**\n * Only for internal use and undocumented for now.\n * Prioritize error techniques for the section.\n * Can be `fieldSchema`, `sectionSchema` or `contextSchema.\n */\n errorPrioritization?: SectionContextState['errorPrioritization']\n} & Pick<\n DataContextProps<unknown>,\n 'data' | 'defaultData' | 'onChange' | 'translations'\n>\n\nexport type LocalProps = SectionProps & {\n children: React.ReactNode\n}\n\nfunction SectionComponent(props: LocalProps) {\n const {\n path,\n overwriteProps,\n translations,\n required,\n data,\n defaultData,\n validateInitially,\n containerMode = 'auto',\n onChange,\n errorPrioritization = ['contextSchema'],\n children,\n } = props\n\n if (path && !path.startsWith?.('/')) {\n throw new Error(`path=\"${path}\" must start with a slash`)\n }\n\n const { hasContext, addOnChangeHandler } = useContext(DataContext)\n\n const { path: nestedPath, props: nestedProps } =\n useContext(SectionContext) || {}\n\n const handleChange = useCallback<OnChange>(\n (...args) => onChange?.(...args),\n [onChange]\n )\n addOnChangeHandler?.(handleChange)\n\n const identifier = useMemo(() => {\n return `${nestedPath && nestedPath !== '/' ? nestedPath : ''}${\n path || ''\n }`\n }, [path, nestedPath])\n const fieldProps = required ? { required: true } : undefined\n\n if (!hasContext) {\n return (\n <Provider data={data} defaultData={defaultData}>\n <SectionComponent {...props} />\n </Provider>\n )\n }\n\n return (\n <SectionContext.Provider\n value={{\n path: identifier,\n errorPrioritization,\n props,\n }}\n >\n <SectionContainerProvider\n validateInitially={validateInitially}\n containerMode={containerMode}\n >\n <FieldPropsProvider\n overwriteProps={{\n ...overwriteProps,\n ...(nestedProps?.overwriteProps?.[\n path.substring(1)\n ] as OverwritePropsDefaults),\n }}\n translations={translations}\n {...fieldProps}\n >\n {children}\n </FieldPropsProvider>\n </SectionContainerProvider>\n </SectionContext.Provider>\n )\n}\n\nSectionComponent.ViewContainer = ViewContainer\nSectionComponent.EditContainer = EditContainer\n\nSectionComponent._supportsSpacingProps = undefined\nexport default SectionComponent\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAC/D,OAAOC,cAAc,MAA+B,kBAAkB;AACtE,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,QAAQ,MAAM,qCAAqC;AAC1D,OAAOC,kBAAkB,MAAM,eAAe;AAC9C,OAAOC,wBAAwB,MAAM,uCAAuC;AAC5E,OAAOC,aAAa,MAAM,iBAAiB;AAC3C,OAAOC,aAAa,MAAM,iBAAiB;AA0D3C,SAASC,gBAAgBA,CAACC,KAAiB,EAAE;EAAA,IAAAC,gBAAA,EAAAC,qBAAA;EAC3C,MAAM;IACJC,IAAI;IACJC,cAAc;IACdC,YAAY;IACZC,QAAQ;IACRC,IAAI;IACJC,WAAW;IACXC,iBAAiB;IACjBC,aAAa,GAAG,MAAM;IACtBC,QAAQ;IACRC,mBAAmB,GAAG,CAAC,eAAe,CAAC;IACvCC;EACF,CAAC,GAAGb,KAAK;EAET,IAAIG,IAAI,IAAI,GAAAF,gBAAA,GAACE,IAAI,CAACW,UAAU,cAAAb,gBAAA,eAAfA,gBAAA,CAAAc,IAAA,CAAAZ,IAAI,EAAc,GAAG,CAAC,GAAE;IACnC,MAAM,IAAIa,KAAK,CAAE,SAAQb,IAAK,2BAA0B,CAAC;EAC3D;EAEA,MAAM;IAAEc,UAAU;IAAEC;EAAmB,CAAC,GAAG5B,UAAU,CAACG,WAAW,CAAC;EAElE,MAAM;IAAEU,IAAI,EAAEgB,UAAU;IAAEnB,KAAK,EAAEoB;EAAY,CAAC,GAC5C9B,UAAU,CAACE,cAAc,CAAC,IAAI,CAAC,CAAC;EAElC,MAAM6B,YAAY,GAAGhC,WAAW,CAC9B;IAAA,SAAAiC,IAAA,GAAAC,SAAA,CAAAC,MAAA,EAAIC,IAAI,OAAAC,KAAA,CAAAJ,IAAA,GAAAK,IAAA,MAAAA,IAAA,GAAAL,IAAA,EAAAK,IAAA;MAAJF,IAAI,CAAAE,IAAA,IAAAJ,SAAA,CAAAI,IAAA;IAAA;IAAA,OAAKhB,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAG,GAAGc,IAAI,CAAC;EAAA,GAChC,CAACd,QAAQ,CACX,CAAC;EACDO,kBAAkB,aAAlBA,kBAAkB,uBAAlBA,kBAAkB,CAAGG,YAAY,CAAC;EAElC,MAAMO,UAAU,GAAGrC,OAAO,CAAC,MAAM;IAC/B,OAAQ,GAAE4B,UAAU,IAAIA,UAAU,KAAK,GAAG,GAAGA,UAAU,GAAG,EAAG,GAC3DhB,IAAI,IAAI,EACT,EAAC;EACJ,CAAC,EAAE,CAACA,IAAI,EAAEgB,UAAU,CAAC,CAAC;EACtB,MAAMU,UAAU,GAAGvB,QAAQ,GAAG;IAAEA,QAAQ,EAAE;EAAK,CAAC,GAAGwB,SAAS;EAE5D,IAAI,CAACb,UAAU,EAAE;IACf,OACE7B,KAAA,CAAA2C,aAAA,CAACrC,QAAQ;MAACa,IAAI,EAAEA,IAAK;MAACC,WAAW,EAAEA;IAAY,GAC7CpB,KAAA,CAAA2C,aAAA,CAAChC,gBAAgB,EAAKC,KAAQ,CACtB,CAAC;EAEf;EAEA,OACEZ,KAAA,CAAA2C,aAAA,CAACvC,cAAc,CAACE,QAAQ;IACtBsC,KAAK,EAAE;MACL7B,IAAI,EAAEyB,UAAU;MAChBhB,mBAAmB;MACnBZ;IACF;EAAE,GAEFZ,KAAA,CAAA2C,aAAA,CAACnC,wBAAwB;IACvBa,iBAAiB,EAAEA,iBAAkB;IACrCC,aAAa,EAAEA;EAAc,GAE7BtB,KAAA,CAAA2C,aAAA,CAACpC,kBAAkB,EAAAsC,QAAA;IACjB7B,cAAc,EAAA8B,aAAA,CAAAA,aAAA,KACT9B,cAAc,GACbgB,WAAW,aAAXA,WAAW,wBAAAlB,qBAAA,GAAXkB,WAAW,CAAEhB,cAAc,cAAAF,qBAAA,uBAA3BA,qBAAA,CACFC,IAAI,CAACgC,SAAS,CAAC,CAAC,CAAC,CAClB,CACD;IACF9B,YAAY,EAAEA;EAAa,GACvBwB,UAAU,GAEbhB,QACiB,CACI,CACH,CAAC;AAE9B;AAEAd,gBAAgB,CAACF,aAAa,GAAGA,aAAa;AAC9CE,gBAAgB,CAACD,aAAa,GAAGA,aAAa;AAE9CC,gBAAgB,CAACqC,qBAAqB,GAAGN,SAAS;AAClD,eAAe/B,gBAAgB"}
@@ -19,6 +19,11 @@ export const SectionProperties = {
19
19
  type: 'boolean',
20
20
  status: 'optional'
21
21
  },
22
+ validateInitially: {
23
+ doc: 'If set to `true`, the whole section will be validated initially. All fields will then automatically get `validateInitially` and show their error messages. Can be useful in combination with `containerMode="auto"`.',
24
+ type: 'boolean',
25
+ status: 'optional'
26
+ },
22
27
  defaultData: {
23
28
  doc: 'Provide default data to the section fields and values, in case the data context (Form.Handler) is not available.',
24
29
  type: 'object',
@@ -30,7 +35,7 @@ export const SectionProperties = {
30
35
  status: 'optional'
31
36
  },
32
37
  containerMode: {
33
- doc: 'Defines the container mode. Can be `view` or `edit`. Defaults to `view`.',
38
+ doc: 'Defines the container mode. Can be `view`, `edit` or `auto`. When set to `auto`, the mode will initially be "edit" if fields contain errors. Defaults to `auto`.',
34
39
  type: 'string',
35
40
  status: 'optional'
36
41
  },
@@ -1 +1 @@
1
- {"version":3,"file":"SectionDocs.js","names":["SectionProperties","path","doc","type","status","overwriteProps","translation","required","defaultData","data","containerMode","children","SectionEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Form/Section/SectionDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const SectionProperties: PropertiesTableProps = {\n path: {\n doc: 'A path to the section (JSON Pointer). When defined, fields inside the section will get this path as a prefix of their own path.',\n type: 'string',\n status: 'optional',\n },\n overwriteProps: {\n doc: 'Overwrite field props for the section.',\n type: 'object',\n status: 'optional',\n },\n translation: {\n doc: \"Provide a translation for the section (e.g. `{'nb-NO': { MySection: { MyField: { label: 'Custom' }}}}`).\",\n type: 'object',\n status: 'optional',\n },\n required: {\n doc: 'Makes all fields inside it required.',\n type: 'boolean',\n status: 'optional',\n },\n defaultData: {\n doc: 'Provide default data to the section fields and values, in case the data context (Form.Handler) is not available.',\n type: 'object',\n status: 'optional',\n },\n data: {\n doc: 'Provide data to the section fields and values, in case the data context (Form.Handler) is not available.',\n type: 'object',\n status: 'optional',\n },\n containerMode: {\n doc: 'Defines the container mode. Can be `view` or `edit`. Defaults to `view`.',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'All the fields and values inside the section.',\n type: 'React.Node',\n status: 'optional',\n },\n}\n\nexport const SectionEvents: 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":"AAEA,OAAO,MAAMA,iBAAuC,GAAG;EACrDC,IAAI,EAAE;IACJC,GAAG,EAAE,iIAAiI;IACtIC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,cAAc,EAAE;IACdH,GAAG,EAAE,wCAAwC;IAC7CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,WAAW,EAAE;IACXJ,GAAG,EAAE,0GAA0G;IAC/GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,QAAQ,EAAE;IACRL,GAAG,EAAE,sCAAsC;IAC3CC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,WAAW,EAAE;IACXN,GAAG,EAAE,kHAAkH;IACvHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,IAAI,EAAE;IACJP,GAAG,EAAE,0GAA0G;IAC/GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,aAAa,EAAE;IACbR,GAAG,EAAE,0EAA0E;IAC/EC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,QAAQ,EAAE;IACRT,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMQ,aAAmC,GAAG;EACjDC,QAAQ,EAAE;IACRX,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"SectionDocs.js","names":["SectionProperties","path","doc","type","status","overwriteProps","translation","required","validateInitially","defaultData","data","containerMode","children","SectionEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Form/Section/SectionDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const SectionProperties: PropertiesTableProps = {\n path: {\n doc: 'A path to the section (JSON Pointer). When defined, fields inside the section will get this path as a prefix of their own path.',\n type: 'string',\n status: 'optional',\n },\n overwriteProps: {\n doc: 'Overwrite field props for the section.',\n type: 'object',\n status: 'optional',\n },\n translation: {\n doc: \"Provide a translation for the section (e.g. `{'nb-NO': { MySection: { MyField: { label: 'Custom' }}}}`).\",\n type: 'object',\n status: 'optional',\n },\n required: {\n doc: 'Makes all fields inside it required.',\n type: 'boolean',\n status: 'optional',\n },\n validateInitially: {\n doc: 'If set to `true`, the whole section will be validated initially. All fields will then automatically get `validateInitially` and show their error messages. Can be useful in combination with `containerMode=\"auto\"`.',\n type: 'boolean',\n status: 'optional',\n },\n defaultData: {\n doc: 'Provide default data to the section fields and values, in case the data context (Form.Handler) is not available.',\n type: 'object',\n status: 'optional',\n },\n data: {\n doc: 'Provide data to the section fields and values, in case the data context (Form.Handler) is not available.',\n type: 'object',\n status: 'optional',\n },\n containerMode: {\n doc: 'Defines the container mode. Can be `view`, `edit` or `auto`. When set to `auto`, the mode will initially be \"edit\" if fields contain errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'All the fields and values inside the section.',\n type: 'React.Node',\n status: 'optional',\n },\n}\n\nexport const SectionEvents: 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":"AAEA,OAAO,MAAMA,iBAAuC,GAAG;EACrDC,IAAI,EAAE;IACJC,GAAG,EAAE,iIAAiI;IACtIC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,cAAc,EAAE;IACdH,GAAG,EAAE,wCAAwC;IAC7CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,WAAW,EAAE;IACXJ,GAAG,EAAE,0GAA0G;IAC/GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,QAAQ,EAAE;IACRL,GAAG,EAAE,sCAAsC;IAC3CC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,iBAAiB,EAAE;IACjBN,GAAG,EAAE,sNAAsN;IAC3NC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDK,WAAW,EAAE;IACXP,GAAG,EAAE,kHAAkH;IACvHC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,IAAI,EAAE;IACJR,GAAG,EAAE,0GAA0G;IAC/GC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,aAAa,EAAE;IACbT,GAAG,EAAE,kKAAkK;IACvKC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,QAAQ,EAAE;IACRV,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMS,aAAmC,GAAG;EACjDC,QAAQ,EAAE;IACRZ,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -1,5 +1,6 @@
1
+ import React from 'react';
1
2
  import { Props as FlexContainerProps } from '../../../../../components/flex/Container';
2
- export type ContainerMode = 'view' | 'edit';
3
+ export type ContainerMode = 'view' | 'edit' | 'auto';
3
4
  export type SectionContainerProps = {
4
5
  /**
5
6
  * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.
@@ -11,6 +12,7 @@ export type Props = {
11
12
  mode: ContainerMode;
12
13
  open?: boolean | undefined;
13
14
  ariaLabel?: string;
15
+ omitFocusManagementRef?: React.MutableRefObject<boolean>;
14
16
  } & SectionContainerProps;
15
17
  declare function SectionContainer(props: Props & FlexContainerProps): import("react/jsx-runtime").JSX.Element;
16
18
  declare namespace SectionContainer {
@@ -2,13 +2,26 @@
2
2
 
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
- const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "variant"];
5
+ const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "variant", "omitFocusManagementRef"];
6
6
  import React, { useCallback, useContext, useEffect, useReducer, useRef } from 'react';
7
7
  import classnames from 'classnames';
8
8
  import { Flex, HeightAnimation } from '../../../../../components';
9
9
  import SectionContainerContext from './SectionContainerContext';
10
10
  import FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext';
11
11
  function SectionContainer(props) {
12
+ const {
13
+ mode,
14
+ open,
15
+ ariaLabel,
16
+ onAnimationEnd,
17
+ className,
18
+ children,
19
+ variant = 'outline',
20
+ omitFocusManagementRef = {
21
+ current: undefined
22
+ }
23
+ } = props,
24
+ restProps = _objectWithoutProperties(props, _excluded);
12
25
  const [, forceUpdate] = useReducer(() => ({}), {});
13
26
  const containerRef = useRef();
14
27
  const contextRef = useRef();
@@ -23,19 +36,8 @@ function SectionContainer(props) {
23
36
  contextRef.current.containerMode = 'edit';
24
37
  }
25
38
  const {
26
- switchContainerMode,
27
39
  containerMode
28
40
  } = contextRef.current;
29
- const {
30
- mode,
31
- open,
32
- ariaLabel,
33
- onAnimationEnd,
34
- className,
35
- children,
36
- variant = 'outline'
37
- } = props,
38
- restProps = _objectWithoutProperties(props, _excluded);
39
41
  const openRef = useRef(open !== null && open !== void 0 ? open : containerMode === mode);
40
42
  const setOpenState = useCallback(open => {
41
43
  openRef.current = open;
@@ -50,21 +52,21 @@ function SectionContainer(props) {
50
52
  }
51
53
  }
52
54
  }, [containerMode, mode, open, setOpenState]);
53
- const handleAnimationEnd = useCallback(state => {
54
- if (contextRef.current.hasSubmitError) {
55
- switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('edit');
56
- }
55
+ const setFocus = useCallback(state => {
57
56
  if (state === 'opened') {
58
- const preventFocusOnErrorOpening = !contextRef.current.hasSubmitError;
59
- if (preventFocusOnErrorOpening) {
57
+ if (!omitFocusManagementRef.current && !contextRef.current.hasSubmitError) {
60
58
  var _containerRef$current, _containerRef$current2;
61
59
  containerRef === null || containerRef === void 0 ? void 0 : (_containerRef$current = containerRef.current) === null || _containerRef$current === void 0 ? void 0 : (_containerRef$current2 = _containerRef$current.focus) === null || _containerRef$current2 === void 0 ? void 0 : _containerRef$current2.call(_containerRef$current);
62
60
  }
61
+ omitFocusManagementRef.current = false;
63
62
  }
63
+ }, [omitFocusManagementRef]);
64
+ const handleAnimationEnd = useCallback(state => {
65
+ setFocus(state);
64
66
  onAnimationEnd === null || onAnimationEnd === void 0 ? void 0 : onAnimationEnd(state);
65
- }, [onAnimationEnd, switchContainerMode]);
67
+ }, [onAnimationEnd, setFocus]);
66
68
  return React.createElement(HeightAnimation, {
67
- className: classnames('dnb-forms-section-block', className, variant && `dnb-forms-section-block--variant-${variant}`, contextRef.current.hasSubmitError && 'dnb-forms-section-block--error'),
69
+ className: classnames('dnb-forms-section-block', className, variant && `dnb-forms-section-block--variant-${variant}`, omitFocusManagementRef.current && 'dnb-forms-section-block--no-animation', contextRef.current.hasSubmitError && 'dnb-forms-section-block--error'),
68
70
  open: openRef.current,
69
71
  onAnimationEnd: handleAnimationEnd,
70
72
  duration: 450,
@@ -1 +1 @@
1
- {"version":3,"file":"SectionContainer.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Flex","HeightAnimation","SectionContainerContext","FieldBoundaryContext","SectionContainer","props","forceUpdate","containerRef","contextRef","current","hasError","hasSubmitError","containerMode","switchContainerMode","mode","open","ariaLabel","onAnimationEnd","className","children","variant","restProps","_objectWithoutProperties","_excluded","openRef","setOpenState","handleAnimationEnd","state","preventFocusOnErrorOpening","_containerRef$current","_containerRef$current2","focus","call","createElement","duration","keepInDOM","Stack","_extends","element","innerRef","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainer.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 SectionContainerContext, {\n SectionContainerContextState,\n} from './SectionContainerContext'\nimport { Props as FlexContainerProps } from '../../../../../components/flex/Container'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport type ContainerMode = 'view' | 'edit'\nexport type SectionContainerProps = {\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} & SectionContainerProps\n\nfunction SectionContainer(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const containerRef = useRef<HTMLDivElement>()\n const contextRef = useRef<\n SectionContainerContextState & {\n hasError?: boolean\n hasSubmitError?: boolean\n }\n >()\n contextRef.current = useContext(SectionContainerContext) || {}\n\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasSubmitError = hasSubmitError\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasSubmitError) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { switchContainerMode, containerMode } = contextRef.current\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n variant = 'outline',\n ...restProps\n } = props\n\n const openRef = useRef(open ?? containerMode === mode)\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\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 setOpenState(containerMode === mode)\n }\n }\n }, [containerMode, mode, open, setOpenState])\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n // - Keep the block open if we have an error\n if (contextRef.current.hasSubmitError) {\n switchContainerMode?.('edit')\n }\n\n if (state === 'opened') {\n const preventFocusOnErrorOpening =\n !contextRef.current.hasSubmitError\n if (preventFocusOnErrorOpening) {\n containerRef?.current?.focus?.()\n }\n }\n\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, switchContainerMode]\n )\n\n return (\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n contextRef.current.hasSubmitError &&\n '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 innerRef={containerRef}\n tabIndex={-1}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n )\n}\n\nSectionContainer._supportsSpacingProps = true\nexport default SectionContainer\n"],"mappings":"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"}
1
+ {"version":3,"file":"SectionContainer.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Flex","HeightAnimation","SectionContainerContext","FieldBoundaryContext","SectionContainer","props","mode","open","ariaLabel","onAnimationEnd","className","children","variant","omitFocusManagementRef","current","undefined","restProps","_objectWithoutProperties","_excluded","forceUpdate","containerRef","contextRef","hasError","hasSubmitError","containerMode","openRef","setOpenState","setFocus","state","_containerRef$current","_containerRef$current2","focus","call","handleAnimationEnd","createElement","duration","keepInDOM","Stack","_extends","element","innerRef","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainer.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 SectionContainerContext, {\n SectionContainerContextState,\n} from './SectionContainerContext'\nimport { Props as FlexContainerProps } from '../../../../../components/flex/Container'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type SectionContainerProps = {\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 omitFocusManagementRef?: React.MutableRefObject<boolean>\n} & SectionContainerProps\n\nfunction SectionContainer(props: Props & FlexContainerProps) {\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n variant = 'outline',\n omitFocusManagementRef = { current: undefined },\n ...restProps\n } = props\n\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const containerRef = useRef<HTMLDivElement>()\n const contextRef = useRef<\n SectionContainerContextState & {\n hasError?: boolean\n hasSubmitError?: boolean\n }\n >()\n contextRef.current = useContext(SectionContainerContext) || {}\n\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasSubmitError = hasSubmitError\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasSubmitError) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { containerMode } = contextRef.current\n\n const openRef = useRef(open ?? containerMode === mode)\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\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 setOpenState(containerMode === mode)\n }\n }\n }, [containerMode, mode, open, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (state === 'opened') {\n if (\n !omitFocusManagementRef.current &&\n !contextRef.current.hasSubmitError\n ) {\n containerRef?.current?.focus?.()\n }\n omitFocusManagementRef.current = false\n }\n },\n [omitFocusManagementRef]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n return (\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n omitFocusManagementRef.current &&\n 'dnb-forms-section-block--no-animation',\n contextRef.current.hasSubmitError &&\n '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 innerRef={containerRef}\n tabIndex={-1}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n )\n}\n\nSectionContainer._supportsSpacingProps = true\nexport default SectionContainer\n"],"mappings":"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"}
@@ -1,7 +1,9 @@
1
1
  import React from 'react';
2
2
  import { ContainerMode } from './SectionContainer';
3
3
  export interface SectionContainerContextState {
4
+ validateInitially?: boolean;
4
5
  containerMode?: ContainerMode;
6
+ initialContainerMode?: ContainerMode;
5
7
  switchContainerMode?: (mode: ContainerMode) => void;
6
8
  }
7
9
  declare const SectionContainerContext: React.Context<SectionContainerContextState>;
@@ -1 +1 @@
1
- {"version":3,"file":"SectionContainerContext.js","names":["React","SectionContainerContext","createContext","undefined"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainerContext.ts"],"sourcesContent":["import React from 'react'\nimport { ContainerMode } from './SectionContainer'\n\nexport interface SectionContainerContextState {\n containerMode?: ContainerMode\n switchContainerMode?: (mode: ContainerMode) => void\n}\n\nconst SectionContainerContext = React.createContext<\n SectionContainerContextState | undefined\n>(undefined)\n\nexport default SectionContainerContext\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAQzB,MAAMC,uBAAuB,GAAGD,KAAK,CAACE,aAAa,CAEjDC,SAAS,CAAC;AAEZ,eAAeF,uBAAuB"}
1
+ {"version":3,"file":"SectionContainerContext.js","names":["React","SectionContainerContext","createContext","undefined"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainerContext.ts"],"sourcesContent":["import React from 'react'\nimport { ContainerMode } from './SectionContainer'\n\nexport interface SectionContainerContextState {\n validateInitially?: boolean\n containerMode?: ContainerMode\n initialContainerMode?: ContainerMode\n switchContainerMode?: (mode: ContainerMode) => void\n}\n\nconst SectionContainerContext = React.createContext<\n SectionContainerContextState | undefined\n>(undefined)\n\nexport default SectionContainerContext\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAUzB,MAAMC,uBAAuB,GAAGD,KAAK,CAACE,aAAa,CAEjDC,SAAS,CAAC;AAEZ,eAAeF,uBAAuB"}
@@ -1,6 +1,7 @@
1
1
  import React from 'react';
2
2
  import { ContainerMode } from './SectionContainer';
3
3
  export type Props = {
4
+ validateInitially?: boolean;
4
5
  containerMode?: ContainerMode;
5
6
  children: React.ReactNode;
6
7
  };
@@ -5,17 +5,20 @@ import SectionContainerContext from './SectionContainerContext';
5
5
  function SectionContainerProvider(props) {
6
6
  const [, forceUpdate] = useReducer(() => ({}), {});
7
7
  const {
8
+ validateInitially,
8
9
  containerMode,
9
10
  children
10
11
  } = props;
11
- const containerModeRef = useRef(containerMode);
12
+ const containerModeRef = useRef(containerMode === 'auto' ? 'view' : containerMode);
12
13
  const switchContainerMode = useCallback(mode => {
13
14
  containerModeRef.current = mode;
14
15
  forceUpdate();
15
16
  }, []);
16
17
  return React.createElement(SectionContainerContext.Provider, {
17
18
  value: {
19
+ validateInitially,
18
20
  containerMode: containerModeRef.current,
21
+ initialContainerMode: containerMode,
19
22
  switchContainerMode
20
23
  }
21
24
  }, children);
@@ -1 +1 @@
1
- {"version":3,"file":"SectionContainerProvider.js","names":["React","useCallback","useReducer","useRef","SectionContainerContext","SectionContainerProvider","props","forceUpdate","containerMode","children","containerModeRef","switchContainerMode","mode","current","createElement","Provider","value"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainerProvider.tsx"],"sourcesContent":["import React, { useCallback, useReducer, useRef } from 'react'\nimport SectionContainerContext from './SectionContainerContext'\nimport { ContainerMode } from './SectionContainer'\n\nexport type Props = {\n containerMode?: ContainerMode\n children: React.ReactNode\n}\n\nfunction SectionContainerProvider(props: Props) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const { containerMode, children } = props\n\n const containerModeRef = useRef<ContainerMode>(containerMode)\n\n const switchContainerMode = useCallback((mode: ContainerMode) => {\n containerModeRef.current = mode\n forceUpdate()\n }, [])\n\n return (\n <SectionContainerContext.Provider\n value={{\n containerMode: containerModeRef.current,\n switchContainerMode,\n }}\n >\n {children}\n </SectionContainerContext.Provider>\n )\n}\n\nexport default SectionContainerProvider\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,EAAEC,MAAM,QAAQ,OAAO;AAC9D,OAAOC,uBAAuB,MAAM,2BAA2B;AAQ/D,SAASC,wBAAwBA,CAACC,KAAY,EAAE;EAC9C,MAAM,GAAGC,WAAW,CAAC,GAAGL,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAElD,MAAM;IAAEM,aAAa;IAAEC;EAAS,CAAC,GAAGH,KAAK;EAEzC,MAAMI,gBAAgB,GAAGP,MAAM,CAAgBK,aAAa,CAAC;EAE7D,MAAMG,mBAAmB,GAAGV,WAAW,CAAEW,IAAmB,IAAK;IAC/DF,gBAAgB,CAACG,OAAO,GAAGD,IAAI;IAC/BL,WAAW,CAAC,CAAC;EACf,CAAC,EAAE,EAAE,CAAC;EAEN,OACEP,KAAA,CAAAc,aAAA,CAACV,uBAAuB,CAACW,QAAQ;IAC/BC,KAAK,EAAE;MACLR,aAAa,EAAEE,gBAAgB,CAACG,OAAO;MACvCF;IACF;EAAE,GAEDF,QAC+B,CAAC;AAEvC;AAEA,eAAeJ,wBAAwB"}
1
+ {"version":3,"file":"SectionContainerProvider.js","names":["React","useCallback","useReducer","useRef","SectionContainerContext","SectionContainerProvider","props","forceUpdate","validateInitially","containerMode","children","containerModeRef","switchContainerMode","mode","current","createElement","Provider","value","initialContainerMode"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainerProvider.tsx"],"sourcesContent":["import React, { useCallback, useReducer, useRef } from 'react'\nimport SectionContainerContext from './SectionContainerContext'\nimport { ContainerMode } from './SectionContainer'\n\nexport type Props = {\n validateInitially?: boolean\n containerMode?: ContainerMode\n children: React.ReactNode\n}\n\nfunction SectionContainerProvider(props: Props) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const { validateInitially, containerMode, children } = props\n\n const containerModeRef = useRef<ContainerMode>(\n containerMode === 'auto' ? 'view' : containerMode\n )\n\n const switchContainerMode = useCallback((mode: ContainerMode) => {\n containerModeRef.current = mode\n forceUpdate()\n }, [])\n\n return (\n <SectionContainerContext.Provider\n value={{\n validateInitially,\n containerMode: containerModeRef.current,\n initialContainerMode: containerMode,\n switchContainerMode,\n }}\n >\n {children}\n </SectionContainerContext.Provider>\n )\n}\n\nexport default SectionContainerProvider\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,EAAEC,MAAM,QAAQ,OAAO;AAC9D,OAAOC,uBAAuB,MAAM,2BAA2B;AAS/D,SAASC,wBAAwBA,CAACC,KAAY,EAAE;EAC9C,MAAM,GAAGC,WAAW,CAAC,GAAGL,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAElD,MAAM;IAAEM,iBAAiB;IAAEC,aAAa;IAAEC;EAAS,CAAC,GAAGJ,KAAK;EAE5D,MAAMK,gBAAgB,GAAGR,MAAM,CAC7BM,aAAa,KAAK,MAAM,GAAG,MAAM,GAAGA,aACtC,CAAC;EAED,MAAMG,mBAAmB,GAAGX,WAAW,CAAEY,IAAmB,IAAK;IAC/DF,gBAAgB,CAACG,OAAO,GAAGD,IAAI;IAC/BN,WAAW,CAAC,CAAC;EACf,CAAC,EAAE,EAAE,CAAC;EAEN,OACEP,KAAA,CAAAe,aAAA,CAACX,uBAAuB,CAACY,QAAQ;IAC/BC,KAAK,EAAE;MACLT,iBAAiB;MACjBC,aAAa,EAAEE,gBAAgB,CAACG,OAAO;MACvCI,oBAAoB,EAAET,aAAa;MACnCG;IACF;EAAE,GAEDF,QAC+B,CAAC;AAEvC;AAEA,eAAeL,wBAAwB"}
@@ -37,6 +37,9 @@
37
37
  .dnb-forms-section-block__inner .dnb-dl .dnb-dd {
38
38
  margin-bottom: 0;
39
39
  }
40
+ .dnb-forms-section-block--no-animation .dnb-forms-section-block__inner {
41
+ transform: translateY(0);
42
+ }
40
43
  .dnb-forms-section-block.dnb-height-animation--is-visible .dnb-forms-section-block__inner {
41
44
  transform: translateY(-0.5rem);
42
45
  }
@@ -1 +1 @@
1
- .dnb-forms-section-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-section-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-section-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-section-block__inner{flex:1;margin-bottom:var(--space);outline:none;padding:var(--padding,1rem);transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-section-block--variant-basic .dnb-forms-section-block__inner,.dnb-forms-section-block__inner:not([class*=dnb-flex-container--spacing]){--padding:0}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing]{border-radius:.375rem}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-small{--space:var(--spacing-small)}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-medium{--space:var(--spacing-medium)}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-large{--space:var(--spacing-large)}.dnb-forms-section-block--variant-outline .dnb-forms-section-block__inner[class*=dnb-flex-container--spacing]{box-shadow:inset 0 0 0 2px var(--block-outline-color)}.dnb-forms-section-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-section-block.dnb-height-animation--is-visible .dnb-forms-section-block__inner{transform:translateY(-.5rem)}.dnb-forms-section-block.dnb-height-animation--parallax .dnb-forms-section-block__inner{transform:translateY(0)}
1
+ .dnb-forms-section-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-section-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-section-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-section-block__inner{flex:1;margin-bottom:var(--space);outline:none;padding:var(--padding,1rem);transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-section-block--variant-basic .dnb-forms-section-block__inner,.dnb-forms-section-block__inner:not([class*=dnb-flex-container--spacing]){--padding:0}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing]{border-radius:.375rem}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-small{--space:var(--spacing-small)}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-medium{--space:var(--spacing-medium)}.dnb-forms-section-block__inner[class*=dnb-flex-container--spacing].dnb-flex-container--spacing-large{--space:var(--spacing-large)}.dnb-forms-section-block--variant-outline .dnb-forms-section-block__inner[class*=dnb-flex-container--spacing]{box-shadow:inset 0 0 0 2px var(--block-outline-color)}.dnb-forms-section-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-section-block--no-animation .dnb-forms-section-block__inner{transform:translateY(0)}.dnb-forms-section-block.dnb-height-animation--is-visible .dnb-forms-section-block__inner{transform:translateY(-.5rem)}.dnb-forms-section-block.dnb-height-animation--parallax .dnb-forms-section-block__inner{transform:translateY(0)}
@@ -53,6 +53,10 @@
53
53
  }
54
54
  }
55
55
 
56
+ &--no-animation &__inner {
57
+ transform: translateY(0);
58
+ }
59
+
56
60
  &.dnb-height-animation--is-visible &__inner {
57
61
  transform: translateY(-0.5rem);
58
62
  }
@@ -8,14 +8,18 @@ import classnames from 'classnames';
8
8
  import pointer from 'json-pointer';
9
9
  import { useFieldProps } from '../../hooks';
10
10
  import { makeUniqueId } from '../../../../shared/component-helper';
11
- import { Flex } from '../../../../components';
11
+ import { Flex, FormStatus } from '../../../../components';
12
12
  import { pickSpacingProps } from '../../../../components/flex/utils';
13
+ import useMountEffect from '../../../../shared/helpers/useMountEffect';
13
14
  import { pickFlexContainerProps } from '../../../../components/flex/Container';
14
15
  import IterateItemContext from '../IterateItemContext';
15
16
  import SummaryListContext from '../../Value/SummaryList/SummaryListContext';
16
17
  import ValueBlockContext from '../../ValueBlock/ValueBlockContext';
17
18
  import FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider';
19
+ import DataContext from '../../DataContext/Context';
18
20
  import useDataValue from '../../hooks/useDataValue';
21
+ import { useSwitchContainerMode } from '../hooks';
22
+ import { getMessage } from '../../FieldBlock';
19
23
  import structuredClone from '@ungap/structured-clone';
20
24
  function ArrayComponent(props) {
21
25
  var _props$value;
@@ -60,13 +64,20 @@ function ArrayComponent(props) {
60
64
  const {
61
65
  path,
62
66
  value: arrayValue,
67
+ error,
68
+ defaultValue,
63
69
  withoutFlex,
64
70
  emptyValue,
65
71
  placeholder,
72
+ containerMode,
66
73
  handleChange,
74
+ setChanged,
67
75
  onChange,
68
76
  children
69
77
  } = useFieldProps(preparedProps);
78
+ useMountEffect(() => {
79
+ setChanged(true);
80
+ });
70
81
  const idsRef = useRef([]);
71
82
  const isNewRef = useRef({});
72
83
  const modesRef = useRef({});
@@ -76,26 +87,38 @@ function ArrayComponent(props) {
76
87
  const hadPushRef = useRef();
77
88
  const innerRefs = useRef({});
78
89
  const omitFlex = withoutFlex !== null && withoutFlex !== void 0 ? withoutFlex : summaryListContext || valueBlockContext;
90
+ const {
91
+ handlePathChange
92
+ } = useContext(DataContext) || {};
93
+ useMountEffect(() => {
94
+ if (defaultValue) {
95
+ handlePathChange === null || handlePathChange === void 0 ? void 0 : handlePathChange(path, defaultValue);
96
+ }
97
+ });
79
98
  useEffect(() => {
80
99
  valueCountRef.current = arrayValue || [];
81
100
  }, [arrayValue]);
82
- const elementData = useMemo(() => {
83
- var _ref;
84
- return ((_ref = valueWhileClosingRef.current || arrayValue) !== null && _ref !== void 0 ? _ref : []).map((value, index) => {
85
- var _valueCountRef$curren;
101
+ const {
102
+ getNextContainerMode
103
+ } = useSwitchContainerMode();
104
+ const arrayItems = useMemo(() => {
105
+ const list = valueWhileClosingRef.current || arrayValue;
106
+ return (list !== null && list !== void 0 ? list : []).map((value, index) => {
107
+ var _valueCountRef$curren, _modesRef$current$id;
86
108
  const id = idsRef.current[index] || makeUniqueId();
87
- const hasNewItems = arrayValue.length > ((_valueCountRef$curren = valueCountRef.current) === null || _valueCountRef$curren === void 0 ? void 0 : _valueCountRef$curren.length);
109
+ const hasNewItems = (arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue.length) > ((_valueCountRef$curren = valueCountRef.current) === null || _valueCountRef$curren === void 0 ? void 0 : _valueCountRef$curren.length);
88
110
  if (!idsRef.current[index]) {
89
111
  isNewRef.current[id] = hasNewItems;
90
112
  idsRef.current.push(id);
91
113
  }
92
114
  const isNew = isNewRef.current[id] || false;
93
- if (!modesRef.current[id]) {
94
- var _value$__containerMod;
95
- modesRef.current[id] = (_value$__containerMod = value === null || value === void 0 ? void 0 : value['__containerMode']) !== null && _value$__containerMod !== void 0 ? _value$__containerMod : isNew ? 'edit' : 'view';
96
- value === null || value === void 0 ? true : delete value['__containerMode'];
115
+ if (!((_modesRef$current$id = modesRef.current[id]) !== null && _modesRef$current$id !== void 0 && _modesRef$current$id.current)) {
116
+ var _getNextContainerMode;
117
+ modesRef.current[id] = {
118
+ current: containerMode !== null && containerMode !== void 0 ? containerMode : isNew ? (_getNextContainerMode = getNextContainerMode()) !== null && _getNextContainerMode !== void 0 ? _getNextContainerMode : 'edit' : 'auto'
119
+ };
97
120
  }
98
- return {
121
+ const itemContext = {
99
122
  id,
100
123
  path,
101
124
  value,
@@ -103,10 +126,16 @@ function ArrayComponent(props) {
103
126
  arrayValue,
104
127
  containerRef,
105
128
  isNew,
106
- containerMode: modesRef.current[id],
107
- switchContainerMode: mode => {
129
+ containerMode: modesRef.current[id].current,
130
+ previousContainerMode: modesRef.current[id].previous,
131
+ initialContainerMode: containerMode || 'auto',
132
+ modeOptions: modesRef.current[id].options,
133
+ switchContainerMode: function (mode) {
108
134
  var _isNewRef$current;
109
- modesRef.current[id] = mode;
135
+ let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
136
+ modesRef.current[id].previous = modesRef.current[id].current;
137
+ modesRef.current[id].current = mode;
138
+ modesRef.current[id].options = options;
110
139
  (_isNewRef$current = isNewRef.current) === null || _isNewRef$current === void 0 ? true : delete _isNewRef$current[id];
111
140
  forceUpdate();
112
141
  },
@@ -118,7 +147,7 @@ function ArrayComponent(props) {
118
147
  },
119
148
  handlePush: element => {
120
149
  hadPushRef.current = true;
121
- handleChange([...(arrayValue !== null && arrayValue !== void 0 ? arrayValue : []), element]);
150
+ handleChange([...(arrayValue || []), element]);
122
151
  },
123
152
  handleRemove: function () {
124
153
  let {
@@ -141,38 +170,41 @@ function ArrayComponent(props) {
141
170
  forceUpdate();
142
171
  },
143
172
  restoreOriginalValue: value => {
144
- const newArrayValue = structuredClone(arrayValue);
145
- newArrayValue[index] = value;
146
- handleChange(newArrayValue);
173
+ if (value) {
174
+ const newArrayValue = structuredClone(arrayValue);
175
+ newArrayValue[index] = value;
176
+ handleChange(newArrayValue);
177
+ }
147
178
  }
148
179
  };
180
+ return itemContext;
149
181
  });
150
182
  }, [salt, arrayValue, path, handleChange]);
151
183
  useMemo(() => {
152
- const last = elementData === null || elementData === void 0 ? void 0 : elementData[elementData.length - 1];
184
+ const last = arrayItems === null || arrayItems === void 0 ? void 0 : arrayItems[arrayItems.length - 1];
153
185
  if (last !== null && last !== void 0 && last.isNew && !hadPushRef.current) {
154
186
  onChange === null || onChange === void 0 ? void 0 : onChange(arrayValue);
155
187
  } else {
156
188
  hadPushRef.current = false;
157
189
  }
158
- }, [arrayValue, elementData, onChange]);
190
+ }, [arrayValue, arrayItems, onChange]);
159
191
  const flexProps = _objectSpread(_objectSpread(_objectSpread({
160
192
  className: classnames("dnb-forms-iterate dnb-forms-section", props === null || props === void 0 ? void 0 : props.className)
161
193
  }, pickFlexContainerProps(props)), pickSpacingProps(props)), {}, {
162
194
  innerRef: containerRef
163
195
  });
164
196
  const WrapperElement = omitFlex ? Fragment : Flex.Stack;
165
- return React.createElement(WrapperElement, omitFlex ? null : flexProps, arrayValue === emptyValue || (props === null || props === void 0 ? void 0 : (_props$value = props.value) === null || _props$value === void 0 ? void 0 : _props$value.length) === 0 ? placeholder : elementData.map(elementProps => {
197
+ return React.createElement(React.Fragment, null, React.createElement(WrapperElement, omitFlex ? null : flexProps, arrayValue === emptyValue || (props === null || props === void 0 ? void 0 : (_props$value = props.value) === null || _props$value === void 0 ? void 0 : _props$value.length) === 0 ? placeholder : arrayItems.map(itemProps => {
166
198
  const {
167
199
  id,
168
200
  value,
169
201
  index
170
- } = elementProps;
202
+ } = itemProps;
171
203
  const elementRef = innerRefs.current[id] = innerRefs.current[id] || createRef();
172
204
  const renderChildren = elementChild => {
173
205
  return typeof elementChild === 'function' ? elementChild(value, index) : elementChild;
174
206
  };
175
- const contextValue = _objectSpread(_objectSpread({}, elementProps), {}, {
207
+ const contextValue = _objectSpread(_objectSpread({}, itemProps), {}, {
176
208
  elementRef
177
209
  });
178
210
  const content = Array.isArray(children) ? children.map(child => renderChildren(child)) : renderChildren(children);
@@ -190,8 +222,19 @@ function ArrayComponent(props) {
190
222
  }, React.createElement(IterateItemContext.Provider, {
191
223
  value: contextValue
192
224
  }, React.createElement(FieldBoundaryProvider, null, content)));
193
- }));
225
+ })), React.createElement(FormStatus, {
226
+ top: 0,
227
+ bottom: 0,
228
+ show: Boolean(error),
229
+ no_animation: false,
230
+ shellSpace: {
231
+ top: true,
232
+ bottom: true
233
+ }
234
+ }, getMessage({
235
+ content: error
236
+ })));
194
237
  }
195
- ArrayComponent._supportsSpacingProps = true;
238
+ ArrayComponent._supportsSpacingProps = false;
196
239
  export default ArrayComponent;
197
240
  //# sourceMappingURL=Array.js.map