@dnb/eufemia 10.47.0 → 10.49.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 (591) hide show
  1. package/CHANGELOG.md +40 -0
  2. package/cjs/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  3. package/cjs/components/height-animation/HeightAnimationInstance.js +13 -6
  4. package/cjs/components/height-animation/HeightAnimationInstance.js.map +1 -1
  5. package/cjs/extensions/forms/DataContext/Context.d.ts +7 -4
  6. package/cjs/extensions/forms/DataContext/Context.js +1 -2
  7. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  8. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +7 -2
  9. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  10. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  11. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +25 -9
  12. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  13. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  14. package/cjs/extensions/forms/DataContext/Provider/Provider.js +28 -28
  15. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  16. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  17. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  18. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  19. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +32 -7
  20. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  21. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  22. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  23. package/cjs/extensions/forms/Form/Isolation/Isolation.js +7 -7
  24. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  25. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js +20 -1
  26. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  27. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  28. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  29. package/cjs/extensions/forms/Form/Section/Section.d.ts +7 -2
  30. package/cjs/extensions/forms/Form/Section/Section.js +3 -1
  31. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  32. package/cjs/extensions/forms/Form/Section/SectionDocs.js +6 -1
  33. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  34. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  35. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  36. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  37. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  38. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  39. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  40. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  41. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  42. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  43. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  44. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  45. package/cjs/extensions/forms/Iterate/Array/Array.js +75 -26
  46. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  47. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +15 -1
  48. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  49. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +20 -0
  50. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.js → Array/ArrayItemArea.js} +66 -49
  51. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  52. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  53. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlockContext.js → Array/ArrayItemAreaContext.js} +3 -3
  54. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  55. package/cjs/extensions/forms/Iterate/Array/types.d.ts +8 -5
  56. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  57. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  58. package/cjs/extensions/forms/Iterate/EditContainer/{EditToolbarTools.js → CancelButton.js} +30 -56
  59. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  60. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  61. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js +74 -0
  62. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  63. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  64. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +33 -12
  65. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  66. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  67. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  68. package/cjs/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  69. package/cjs/extensions/forms/Iterate/EditContainer/index.js +19 -1
  70. package/cjs/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  71. package/cjs/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  72. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  73. package/cjs/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  74. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +38 -15
  75. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  76. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js +18 -2
  77. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  78. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +7 -2
  79. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -24
  80. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  81. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  82. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  83. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +12 -14
  84. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  85. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  86. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -6
  87. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  88. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  89. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js +12 -0
  90. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  91. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  92. package/cjs/extensions/forms/Iterate/ViewContainer/{ViewToolbarTools.js → EditButton.js} +8 -11
  93. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  94. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  95. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js +19 -0
  96. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  97. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  98. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +25 -10
  99. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  100. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  101. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  102. package/cjs/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  103. package/cjs/extensions/forms/Iterate/ViewContainer/index.js +19 -1
  104. package/cjs/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  105. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  106. package/cjs/extensions/forms/Iterate/hooks/index.js +21 -0
  107. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -0
  108. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  109. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +93 -0
  110. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  111. package/cjs/extensions/forms/Tools/Log.d.ts +6 -0
  112. package/cjs/extensions/forms/Tools/Log.js +29 -0
  113. package/cjs/extensions/forms/Tools/Log.js.map +1 -0
  114. package/cjs/extensions/forms/Tools/index.d.ts +1 -0
  115. package/cjs/extensions/forms/Tools/index.js +7 -0
  116. package/cjs/extensions/forms/Tools/index.js.map +1 -1
  117. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  118. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  119. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  120. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  121. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  122. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  123. package/cjs/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  124. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  125. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  126. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  127. package/cjs/extensions/forms/constants/countries.js +10 -26
  128. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  129. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  130. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -2
  131. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  132. package/cjs/extensions/forms/constants/locales/en-US.d.ts +2 -1
  133. package/cjs/extensions/forms/constants/locales/index.d.ts +4 -2
  134. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  135. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -2
  136. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  137. package/cjs/extensions/forms/hooks/DataValueDocs.js +6 -1
  138. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  139. package/cjs/extensions/forms/hooks/useExternalValue.js +8 -6
  140. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  141. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  142. package/cjs/extensions/forms/hooks/useFieldProps.js +48 -27
  143. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  144. package/cjs/extensions/forms/hooks/usePath.d.ts +1 -0
  145. package/cjs/extensions/forms/hooks/usePath.js +5 -1
  146. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  147. package/cjs/extensions/forms/style/dnb-forms.css +3 -0
  148. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  149. package/cjs/extensions/forms/types.d.ts +4 -0
  150. package/cjs/extensions/forms/types.js.map +1 -1
  151. package/cjs/shared/Eufemia.d.ts +1 -1
  152. package/cjs/shared/Eufemia.js +2 -2
  153. package/cjs/shared/Eufemia.js.map +1 -1
  154. package/cjs/style/core/scopes.scss +1 -1
  155. package/cjs/style/dnb-ui-basis.css +1 -1
  156. package/cjs/style/dnb-ui-basis.min.css +1 -1
  157. package/cjs/style/dnb-ui-body.css +1 -1
  158. package/cjs/style/dnb-ui-body.min.css +1 -1
  159. package/cjs/style/dnb-ui-components.css +3 -0
  160. package/cjs/style/dnb-ui-components.min.css +1 -1
  161. package/cjs/style/dnb-ui-core.css +1 -1
  162. package/cjs/style/dnb-ui-core.min.css +1 -1
  163. package/cjs/style/dnb-ui-extensions.css +3 -0
  164. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  165. package/cjs/style/dnb-ui-forms.css +3 -0
  166. package/cjs/style/dnb-ui-forms.min.css +1 -1
  167. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  168. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  169. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  170. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  171. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  172. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  173. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  174. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  175. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  176. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  177. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  178. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  179. package/cjs/style/themes/theme-ui/ui-theme-components.css +6 -0
  180. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  181. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  182. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  183. package/cjs/style/themes/theme-ui/ui-theme-forms.css +3 -0
  184. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  185. package/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  186. package/components/height-animation/HeightAnimationInstance.js +13 -6
  187. package/components/height-animation/HeightAnimationInstance.js.map +1 -1
  188. package/es/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  189. package/es/components/height-animation/HeightAnimationInstance.js +13 -6
  190. package/es/components/height-animation/HeightAnimationInstance.js.map +1 -1
  191. package/es/extensions/forms/DataContext/Context.d.ts +7 -4
  192. package/es/extensions/forms/DataContext/Context.js +1 -2
  193. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  194. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +7 -2
  195. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  196. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  197. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +26 -9
  198. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  199. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  200. package/es/extensions/forms/DataContext/Provider/Provider.js +28 -26
  201. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  202. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  203. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  204. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  205. package/es/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  206. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  207. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  208. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  209. package/es/extensions/forms/Form/Isolation/Isolation.js +7 -7
  210. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  211. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  212. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  213. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  214. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  215. package/es/extensions/forms/Form/Section/Section.d.ts +7 -2
  216. package/es/extensions/forms/Form/Section/Section.js +3 -1
  217. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  218. package/es/extensions/forms/Form/Section/SectionDocs.js +6 -1
  219. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  220. package/es/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  221. package/es/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  222. package/es/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  223. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  224. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  225. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  226. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  227. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  228. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  229. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  230. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  231. package/es/extensions/forms/Iterate/Array/Array.js +76 -28
  232. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  233. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +15 -1
  234. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  235. package/es/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +20 -0
  236. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  237. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  238. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  239. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  240. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  241. package/es/extensions/forms/Iterate/Array/types.d.ts +8 -5
  242. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  243. package/es/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  244. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +87 -0
  245. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  246. package/es/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  247. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js +66 -0
  248. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  249. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  250. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  251. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  252. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  253. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  254. package/es/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  255. package/es/extensions/forms/Iterate/EditContainer/index.js +2 -0
  256. package/es/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  257. package/es/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  258. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  259. package/es/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  260. package/es/extensions/forms/Iterate/PushButton/PushButton.js +39 -16
  261. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  262. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js +19 -3
  263. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  264. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +7 -2
  265. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -23
  266. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  267. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  268. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  269. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +13 -15
  270. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  271. package/es/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  272. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +51 -7
  273. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  274. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  275. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  276. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  277. package/es/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  278. package/{extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → es/extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  279. package/es/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  280. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  281. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  282. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  283. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  284. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  285. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  286. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  287. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  288. package/es/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  289. package/es/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  290. package/es/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  291. package/es/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  292. package/es/extensions/forms/Iterate/hooks/index.js +3 -0
  293. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -0
  294. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  295. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +85 -0
  296. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  297. package/es/extensions/forms/Tools/Log.d.ts +6 -0
  298. package/es/extensions/forms/Tools/Log.js +22 -0
  299. package/es/extensions/forms/Tools/Log.js.map +1 -0
  300. package/es/extensions/forms/Tools/index.d.ts +1 -0
  301. package/es/extensions/forms/Tools/index.js +1 -0
  302. package/es/extensions/forms/Tools/index.js.map +1 -1
  303. package/es/extensions/forms/Wizard/Container/WizardContainer.js +17 -6
  304. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  305. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  306. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  307. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  308. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  309. package/es/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  310. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  311. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  312. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  313. package/es/extensions/forms/constants/countries.js +10 -26
  314. package/es/extensions/forms/constants/countries.js.map +1 -1
  315. package/es/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  316. package/es/extensions/forms/constants/locales/en-GB.js +3 -2
  317. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  318. package/es/extensions/forms/constants/locales/en-US.d.ts +2 -1
  319. package/es/extensions/forms/constants/locales/index.d.ts +4 -2
  320. package/es/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  321. package/es/extensions/forms/constants/locales/nb-NO.js +3 -2
  322. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  323. package/es/extensions/forms/hooks/DataValueDocs.js +6 -1
  324. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  325. package/es/extensions/forms/hooks/useExternalValue.js +8 -6
  326. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  327. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  328. package/es/extensions/forms/hooks/useFieldProps.js +48 -28
  329. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  330. package/es/extensions/forms/hooks/usePath.d.ts +1 -0
  331. package/es/extensions/forms/hooks/usePath.js +5 -1
  332. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  333. package/es/extensions/forms/style/dnb-forms.css +3 -0
  334. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  335. package/es/extensions/forms/types.d.ts +4 -0
  336. package/es/extensions/forms/types.js.map +1 -1
  337. package/es/shared/Eufemia.d.ts +1 -1
  338. package/es/shared/Eufemia.js +2 -2
  339. package/es/shared/Eufemia.js.map +1 -1
  340. package/es/style/core/scopes.scss +1 -1
  341. package/es/style/dnb-ui-basis.css +1 -1
  342. package/es/style/dnb-ui-basis.min.css +1 -1
  343. package/es/style/dnb-ui-body.css +1 -1
  344. package/es/style/dnb-ui-body.min.css +1 -1
  345. package/es/style/dnb-ui-components.css +3 -0
  346. package/es/style/dnb-ui-components.min.css +1 -1
  347. package/es/style/dnb-ui-core.css +1 -1
  348. package/es/style/dnb-ui-core.min.css +1 -1
  349. package/es/style/dnb-ui-extensions.css +3 -0
  350. package/es/style/dnb-ui-extensions.min.css +1 -1
  351. package/es/style/dnb-ui-forms.css +3 -0
  352. package/es/style/dnb-ui-forms.min.css +1 -1
  353. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  354. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  355. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  356. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  357. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  358. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  359. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  360. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  361. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  362. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  363. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  364. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  365. package/es/style/themes/theme-ui/ui-theme-components.css +6 -0
  366. package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  367. package/es/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  368. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  369. package/es/style/themes/theme-ui/ui-theme-forms.css +3 -0
  370. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  371. package/esm/dnb-ui-basis.min.mjs +1 -1
  372. package/esm/dnb-ui-components.min.mjs +1 -1
  373. package/esm/dnb-ui-elements.min.mjs +1 -1
  374. package/esm/dnb-ui-extensions.min.mjs +2 -2
  375. package/esm/dnb-ui-lib.min.mjs +1 -1
  376. package/extensions/forms/DataContext/Context.d.ts +7 -4
  377. package/extensions/forms/DataContext/Context.js +1 -2
  378. package/extensions/forms/DataContext/Context.js.map +1 -1
  379. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +7 -2
  380. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  381. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  382. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +25 -9
  383. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  384. package/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  385. package/extensions/forms/DataContext/Provider/Provider.js +28 -26
  386. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  387. package/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  388. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  389. package/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  390. package/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  391. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  392. package/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  393. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  394. package/extensions/forms/Form/Isolation/Isolation.js +7 -7
  395. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  396. package/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  397. package/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  398. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  399. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  400. package/extensions/forms/Form/Section/Section.d.ts +7 -2
  401. package/extensions/forms/Form/Section/Section.js +3 -1
  402. package/extensions/forms/Form/Section/Section.js.map +1 -1
  403. package/extensions/forms/Form/Section/SectionDocs.js +6 -1
  404. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  405. package/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  406. package/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  407. package/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  408. package/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  409. package/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  410. package/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  411. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  412. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  413. package/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  414. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  415. package/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  416. package/extensions/forms/Iterate/Array/Array.js +77 -28
  417. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  418. package/extensions/forms/Iterate/Array/ArrayDocs.js +15 -1
  419. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  420. package/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +20 -0
  421. package/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  422. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  423. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  424. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  425. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  426. package/extensions/forms/Iterate/Array/types.d.ts +8 -5
  427. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  428. package/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  429. package/extensions/forms/Iterate/EditContainer/CancelButton.js +88 -0
  430. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  431. package/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  432. package/extensions/forms/Iterate/EditContainer/DoneButton.js +66 -0
  433. package/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  434. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  435. package/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  436. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  437. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  438. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  439. package/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  440. package/extensions/forms/Iterate/EditContainer/index.js +2 -0
  441. package/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  442. package/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  443. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  444. package/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  445. package/extensions/forms/Iterate/PushButton/PushButton.js +39 -16
  446. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  447. package/extensions/forms/Iterate/PushContainer/OpenButton.js +19 -3
  448. package/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  449. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +7 -2
  450. package/extensions/forms/Iterate/PushContainer/PushContainer.js +80 -26
  451. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  452. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  453. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  454. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +13 -15
  455. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  456. package/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  457. package/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -7
  458. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  459. package/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  460. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  461. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  462. package/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  463. package/{es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  464. package/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  465. package/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  466. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  467. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  468. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  469. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  470. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  471. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  472. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  473. package/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  474. package/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  475. package/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  476. package/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  477. package/extensions/forms/Iterate/hooks/index.js +3 -0
  478. package/extensions/forms/Iterate/hooks/index.js.map +1 -0
  479. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  480. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +87 -0
  481. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  482. package/extensions/forms/Tools/Log.d.ts +6 -0
  483. package/extensions/forms/Tools/Log.js +22 -0
  484. package/extensions/forms/Tools/Log.js.map +1 -0
  485. package/extensions/forms/Tools/index.d.ts +1 -0
  486. package/extensions/forms/Tools/index.js +1 -0
  487. package/extensions/forms/Tools/index.js.map +1 -1
  488. package/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  489. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  490. package/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  491. package/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  492. package/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  493. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  494. package/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  495. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  496. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  497. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  498. package/extensions/forms/constants/countries.js +10 -26
  499. package/extensions/forms/constants/countries.js.map +1 -1
  500. package/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  501. package/extensions/forms/constants/locales/en-GB.js +3 -2
  502. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  503. package/extensions/forms/constants/locales/en-US.d.ts +2 -1
  504. package/extensions/forms/constants/locales/index.d.ts +4 -2
  505. package/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  506. package/extensions/forms/constants/locales/nb-NO.js +3 -2
  507. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  508. package/extensions/forms/hooks/DataValueDocs.js +6 -1
  509. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  510. package/extensions/forms/hooks/useExternalValue.js +8 -6
  511. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  512. package/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  513. package/extensions/forms/hooks/useFieldProps.js +48 -27
  514. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  515. package/extensions/forms/hooks/usePath.d.ts +1 -0
  516. package/extensions/forms/hooks/usePath.js +5 -1
  517. package/extensions/forms/hooks/usePath.js.map +1 -1
  518. package/extensions/forms/style/dnb-forms.css +3 -0
  519. package/extensions/forms/style/dnb-forms.min.css +1 -1
  520. package/extensions/forms/types.d.ts +4 -0
  521. package/extensions/forms/types.js.map +1 -1
  522. package/package.json +1 -1
  523. package/shared/Eufemia.d.ts +1 -1
  524. package/shared/Eufemia.js +2 -2
  525. package/shared/Eufemia.js.map +1 -1
  526. package/style/core/scopes.scss +1 -1
  527. package/style/dnb-ui-basis.css +1 -1
  528. package/style/dnb-ui-basis.min.css +1 -1
  529. package/style/dnb-ui-body.css +1 -1
  530. package/style/dnb-ui-body.min.css +1 -1
  531. package/style/dnb-ui-components.css +3 -0
  532. package/style/dnb-ui-components.min.css +1 -1
  533. package/style/dnb-ui-core.css +1 -1
  534. package/style/dnb-ui-core.min.css +1 -1
  535. package/style/dnb-ui-extensions.css +3 -0
  536. package/style/dnb-ui-extensions.min.css +1 -1
  537. package/style/dnb-ui-forms.css +3 -0
  538. package/style/dnb-ui-forms.min.css +1 -1
  539. package/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  540. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  541. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  542. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  543. package/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  544. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  545. package/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  546. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  547. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  548. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  549. package/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  550. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  551. package/style/themes/theme-ui/ui-theme-components.css +6 -0
  552. package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  553. package/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  554. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  555. package/style/themes/theme-ui/ui-theme-forms.css +3 -0
  556. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  557. package/umd/dnb-ui-basis.min.js +1 -1
  558. package/umd/dnb-ui-components.min.js +1 -1
  559. package/umd/dnb-ui-elements.min.js +1 -1
  560. package/umd/dnb-ui-extensions.min.js +3 -3
  561. package/umd/dnb-ui-lib.min.js +1 -1
  562. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +0 -20
  563. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  564. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  565. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  566. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  567. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  568. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  569. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  570. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +0 -20
  571. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  572. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  573. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  574. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  575. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  576. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  577. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -113
  578. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  579. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  580. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  581. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +0 -20
  582. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  583. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  584. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  585. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  586. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  587. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  588. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -114
  589. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  590. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  591. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
@@ -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
  }
@@ -3,19 +3,23 @@
3
3
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
4
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
5
5
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
- import React, { useMemo, useRef, useEffect, useReducer, createRef, useContext, Fragment } from 'react';
6
+ import React, { useMemo, useRef, useEffect, useReducer, createRef, useContext } from 'react';
7
7
  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, HeightAnimation } 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;
@@ -50,23 +54,35 @@ function ArrayComponent(props) {
50
54
  index: i
51
55
  }));
52
56
  }
53
- return _objectSpread(_objectSpread({}, props), {}, {
57
+ return _objectSpread(_objectSpread({
58
+ required: false
59
+ }, props), {}, {
54
60
  value: newValue
55
61
  });
56
62
  }
57
63
  }
58
- return props;
64
+ return _objectSpread({
65
+ required: false
66
+ }, props);
59
67
  }, [getValueByPath, props]);
60
68
  const {
61
69
  path,
62
70
  value: arrayValue,
71
+ error,
72
+ defaultValue,
63
73
  withoutFlex,
64
74
  emptyValue,
65
75
  placeholder,
76
+ containerMode,
77
+ animate,
66
78
  handleChange,
79
+ setChanged,
67
80
  onChange,
68
81
  children
69
82
  } = useFieldProps(preparedProps);
83
+ useMountEffect(() => {
84
+ setChanged(true);
85
+ });
70
86
  const idsRef = useRef([]);
71
87
  const isNewRef = useRef({});
72
88
  const modesRef = useRef({});
@@ -76,26 +92,38 @@ function ArrayComponent(props) {
76
92
  const hadPushRef = useRef();
77
93
  const innerRefs = useRef({});
78
94
  const omitFlex = withoutFlex !== null && withoutFlex !== void 0 ? withoutFlex : summaryListContext || valueBlockContext;
95
+ const {
96
+ handlePathChange
97
+ } = useContext(DataContext) || {};
98
+ useMountEffect(() => {
99
+ if (defaultValue) {
100
+ handlePathChange === null || handlePathChange === void 0 ? void 0 : handlePathChange(path, defaultValue);
101
+ }
102
+ });
79
103
  useEffect(() => {
80
104
  valueCountRef.current = arrayValue || [];
81
105
  }, [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;
106
+ const {
107
+ getNextContainerMode
108
+ } = useSwitchContainerMode();
109
+ const arrayItems = useMemo(() => {
110
+ const list = valueWhileClosingRef.current || arrayValue;
111
+ return (list !== null && list !== void 0 ? list : []).map((value, index) => {
112
+ var _valueCountRef$curren, _modesRef$current$id;
86
113
  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);
114
+ 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
115
  if (!idsRef.current[index]) {
89
116
  isNewRef.current[id] = hasNewItems;
90
117
  idsRef.current.push(id);
91
118
  }
92
119
  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'];
120
+ if (!((_modesRef$current$id = modesRef.current[id]) !== null && _modesRef$current$id !== void 0 && _modesRef$current$id.current)) {
121
+ var _getNextContainerMode;
122
+ modesRef.current[id] = {
123
+ current: containerMode !== null && containerMode !== void 0 ? containerMode : isNew ? (_getNextContainerMode = getNextContainerMode()) !== null && _getNextContainerMode !== void 0 ? _getNextContainerMode : 'edit' : 'auto'
124
+ };
97
125
  }
98
- return {
126
+ const itemContext = {
99
127
  id,
100
128
  path,
101
129
  value,
@@ -103,10 +131,16 @@ function ArrayComponent(props) {
103
131
  arrayValue,
104
132
  containerRef,
105
133
  isNew,
106
- containerMode: modesRef.current[id],
107
- switchContainerMode: mode => {
134
+ containerMode: modesRef.current[id].current,
135
+ previousContainerMode: modesRef.current[id].previous,
136
+ initialContainerMode: containerMode || 'auto',
137
+ modeOptions: modesRef.current[id].options,
138
+ switchContainerMode: function (mode) {
108
139
  var _isNewRef$current;
109
- modesRef.current[id] = mode;
140
+ let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
141
+ modesRef.current[id].previous = modesRef.current[id].current;
142
+ modesRef.current[id].current = mode;
143
+ modesRef.current[id].options = options;
110
144
  (_isNewRef$current = isNewRef.current) === null || _isNewRef$current === void 0 ? true : delete _isNewRef$current[id];
111
145
  forceUpdate();
112
146
  },
@@ -118,7 +152,7 @@ function ArrayComponent(props) {
118
152
  },
119
153
  handlePush: element => {
120
154
  hadPushRef.current = true;
121
- handleChange([...(arrayValue !== null && arrayValue !== void 0 ? arrayValue : []), element]);
155
+ handleChange([...(arrayValue || []), element]);
122
156
  },
123
157
  handleRemove: function () {
124
158
  let {
@@ -141,38 +175,40 @@ function ArrayComponent(props) {
141
175
  forceUpdate();
142
176
  },
143
177
  restoreOriginalValue: value => {
144
- const newArrayValue = structuredClone(arrayValue);
145
- newArrayValue[index] = value;
146
- handleChange(newArrayValue);
178
+ if (value) {
179
+ const newArrayValue = structuredClone(arrayValue);
180
+ newArrayValue[index] = value;
181
+ handleChange(newArrayValue);
182
+ }
147
183
  }
148
184
  };
185
+ return itemContext;
149
186
  });
150
187
  }, [salt, arrayValue, path, handleChange]);
151
188
  useMemo(() => {
152
- const last = elementData === null || elementData === void 0 ? void 0 : elementData[elementData.length - 1];
189
+ const last = arrayItems === null || arrayItems === void 0 ? void 0 : arrayItems[arrayItems.length - 1];
153
190
  if (last !== null && last !== void 0 && last.isNew && !hadPushRef.current) {
154
191
  onChange === null || onChange === void 0 ? void 0 : onChange(arrayValue);
155
192
  } else {
156
193
  hadPushRef.current = false;
157
194
  }
158
- }, [arrayValue, elementData, onChange]);
195
+ }, [arrayValue, arrayItems, onChange]);
159
196
  const flexProps = _objectSpread(_objectSpread(_objectSpread({
160
197
  className: classnames("dnb-forms-iterate dnb-forms-section", props === null || props === void 0 ? void 0 : props.className)
161
198
  }, pickFlexContainerProps(props)), pickSpacingProps(props)), {}, {
162
199
  innerRef: containerRef
163
200
  });
164
- 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 => {
201
+ const arrayElements = 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
202
  const {
167
203
  id,
168
204
  value,
169
205
  index
170
- } = elementProps;
206
+ } = itemProps;
171
207
  const elementRef = innerRefs.current[id] = innerRefs.current[id] || createRef();
172
208
  const renderChildren = elementChild => {
173
209
  return typeof elementChild === 'function' ? elementChild(value, index) : elementChild;
174
210
  };
175
- const contextValue = _objectSpread(_objectSpread({}, elementProps), {}, {
211
+ const contextValue = _objectSpread(_objectSpread({}, itemProps), {}, {
176
212
  elementRef
177
213
  });
178
214
  const content = Array.isArray(children) ? children.map(child => renderChildren(child)) : renderChildren(children);
@@ -190,7 +226,20 @@ function ArrayComponent(props) {
190
226
  }, React.createElement(IterateItemContext.Provider, {
191
227
  value: contextValue
192
228
  }, React.createElement(FieldBoundaryProvider, null, content)));
193
- }));
229
+ });
230
+ const content = omitFlex ? arrayElements : React.createElement(Flex.Stack, flexProps, arrayElements);
231
+ return React.createElement(React.Fragment, null, animate ? React.createElement(HeightAnimation, null, content) : content, React.createElement(FormStatus, {
232
+ top: 0,
233
+ bottom: 0,
234
+ show: Boolean(error),
235
+ no_animation: false,
236
+ shellSpace: {
237
+ top: true,
238
+ bottom: true
239
+ }
240
+ }, getMessage({
241
+ content: error
242
+ })));
194
243
  }
195
244
  ArrayComponent._supportsSpacingProps = true;
196
245
  export default ArrayComponent;
@@ -1 +1 @@
1
- {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","Fragment","classnames","pointer","useFieldProps","makeUniqueId","Flex","pickSpacingProps","pickFlexContainerProps","IterateItemContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","useDataValue","structuredClone","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","getValueByPath","preparedProps","path","countPath","countPathLimit","Infinity","countPathTransform","arrayValue","countValue","parseFloat","length","newValue","i","l","value","push","index","_objectSpread","withoutFlex","emptyValue","placeholder","handleChange","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","current","elementData","_ref","map","_valueCountRef$curren","id","hasNewItems","isNew","_value$__containerMod","containerMode","switchContainerMode","mode","_isNewRef$current","newArrayValue","set","handlePush","element","handleRemove","keepItems","arguments","undefined","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","last","flexProps","className","innerRef","WrapperElement","Stack","createElement","elementProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n Fragment,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\nimport useDataValue from '../../hooks/useDataValue'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n\n const { getValueByPath } = useDataValue()\n const preparedProps = useMemo(() => {\n const {\n path,\n countPath,\n countPathLimit = Infinity,\n countPathTransform,\n } = props\n\n if (countPath) {\n const arrayValue = getValueByPath(path)\n let countValue = parseFloat(getValueByPath(countPath))\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n if (arrayValue?.length !== countValue) {\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(countPathTransform?.({ value, index: i }))\n }\n\n return {\n ...props,\n value: newValue,\n }\n }\n }\n\n return props\n }, [getValueByPath, props])\n\n const {\n path,\n value: arrayValue,\n withoutFlex,\n emptyValue,\n placeholder,\n handleChange,\n onChange,\n children,\n } = useFieldProps(preparedProps)\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<Record<Identifier, ContainerMode>>({})\n const valueWhileClosingRef = useRef<Value>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const elementData = useMemo(() => {\n return ((valueWhileClosingRef.current || arrayValue) ?? []).map(\n (value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]) {\n modesRef.current[id] =\n value?.['__containerMode'] ?? (isNew ? 'edit' : 'view')\n delete value?.['__containerMode']\n }\n\n return {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id],\n switchContainerMode: (mode: ContainerMode) => {\n modesRef.current[id] = mode\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path: Path, value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element: unknown) => {\n hadPushRef.current = true\n handleChange([...(arrayValue ?? []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n },\n } as IterateItemContextState\n }\n )\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, path, handleChange])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = elementData?.[elementData.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, elementData, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames(\n 'dnb-forms-iterate',\n 'dnb-forms-section',\n props?.className\n ),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const WrapperElement = omitFlex ? Fragment : Flex.Stack\n\n return (\n <WrapperElement {...(omitFlex ? null : flexProps)}>\n {arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : elementData.map((elementProps) => {\n const { id, value, index } = elementProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...elementProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateItemContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateItemContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n </Flex.Item>\n )\n })}\n </WrapperElement>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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"}
1
+ {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","classnames","pointer","useFieldProps","makeUniqueId","Flex","FormStatus","HeightAnimation","pickSpacingProps","useMountEffect","pickFlexContainerProps","IterateItemContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","DataContext","useDataValue","useSwitchContainerMode","getMessage","structuredClone","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","getValueByPath","preparedProps","path","countPath","countPathLimit","Infinity","countPathTransform","arrayValue","countValue","parseFloat","length","newValue","i","l","value","push","index","_objectSpread","required","error","defaultValue","withoutFlex","emptyValue","placeholder","containerMode","animate","handleChange","setChanged","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","handlePathChange","current","getNextContainerMode","arrayItems","list","map","_valueCountRef$curren","_modesRef$current$id","id","hasNewItems","isNew","_getNextContainerMode","itemContext","previousContainerMode","previous","initialContainerMode","modeOptions","options","switchContainerMode","mode","_isNewRef$current","arguments","undefined","newArrayValue","set","handlePush","element","handleRemove","keepItems","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","last","flexProps","className","innerRef","arrayElements","itemProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","createElement","Provider","key","Item","tabIndex","Stack","Fragment","top","bottom","show","Boolean","no_animation","shellSpace","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex, FormStatus, HeightAnimation } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { useSwitchContainerMode } from '../hooks'\nimport { getMessage } from '../../FieldBlock'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n\n const { getValueByPath } = useDataValue()\n const preparedProps = useMemo(() => {\n const {\n path,\n countPath,\n countPathLimit = Infinity,\n countPathTransform,\n } = props\n\n if (countPath) {\n const arrayValue = getValueByPath(path)\n let countValue = parseFloat(getValueByPath(countPath))\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n if (arrayValue?.length !== countValue) {\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(countPathTransform?.({ value, index: i }))\n }\n\n return {\n required: false,\n ...props,\n value: newValue,\n }\n }\n }\n\n return { required: false, ...props }\n }, [getValueByPath, props])\n\n const {\n path,\n value: arrayValue,\n error,\n defaultValue,\n withoutFlex,\n emptyValue,\n placeholder,\n containerMode,\n animate,\n handleChange,\n setChanged,\n onChange,\n children,\n } = useFieldProps(preparedProps)\n\n useMountEffect(() => {\n // To ensure the validator is called when a new item is added\n setChanged(true)\n })\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<\n Record<\n Identifier,\n {\n current: ContainerMode\n previous?: ContainerMode\n options?: { omitFocusManagement?: boolean }\n }\n >\n >({})\n const valueWhileClosingRef = useRef<Value>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n // To support React.StrictMode, we inject the defaultValue into the data context this way.\n // The routine inside useFieldProps where updateDataValueDataContext is called, does not support React.StrictMode\n const { handlePathChange } = useContext(DataContext) || {}\n useMountEffect(() => {\n if (defaultValue) {\n handlePathChange?.(path, defaultValue)\n }\n })\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const { getNextContainerMode } = useSwitchContainerMode()\n\n const arrayItems = useMemo(() => {\n const list = valueWhileClosingRef.current || arrayValue\n return (list ?? []).map((value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue?.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]?.current) {\n modesRef.current[id] = {\n current:\n containerMode ??\n (isNew ? getNextContainerMode() ?? 'edit' : 'auto'),\n }\n }\n\n const itemContext: IterateItemContextState = {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id].current,\n previousContainerMode: modesRef.current[id].previous,\n initialContainerMode: containerMode || 'auto',\n modeOptions: modesRef.current[id].options,\n switchContainerMode: (mode, options = {}) => {\n modesRef.current[id].previous = modesRef.current[id].current\n modesRef.current[id].current = mode\n modesRef.current[id].options = options\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path, value) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element) => {\n hadPushRef.current = true\n handleChange([...(arrayValue || []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value) => {\n if (value) {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n }\n },\n }\n\n return itemContext\n })\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, path, handleChange])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = arrayItems?.[arrayItems.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, arrayItems, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames(\n 'dnb-forms-iterate',\n 'dnb-forms-section',\n props?.className\n ),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const arrayElements =\n arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : arrayItems.map((itemProps) => {\n const { id, value, index } = itemProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...itemProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateItemContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateItemContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n </Flex.Item>\n )\n })\n\n const content = omitFlex ? (\n arrayElements\n ) : (\n <Flex.Stack {...flexProps}>{arrayElements}</Flex.Stack>\n )\n\n return (\n <>\n {animate ? <HeightAnimation>{content}</HeightAnimation> : content}\n\n <FormStatus\n top={0}\n bottom={0}\n show={Boolean(error)}\n no_animation={false}\n shellSpace={{ top: true, bottom: true }}\n >\n {getMessage({ content: error })}\n </FormStatus>\n </>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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"}
@@ -1,3 +1,4 @@
1
+ import { dataValueProperties } from '../../hooks/DataValueDocs';
1
2
  export const ArrayProperties = {
2
3
  value: {
3
4
  doc: 'The data to iterate over. Alternative you can use the `path` prop.',
@@ -29,6 +30,11 @@ export const ArrayProperties = {
29
30
  type: 'boolean',
30
31
  status: 'optional'
31
32
  },
33
+ animate: {
34
+ doc: 'When `true` it will animate the height of the items.',
35
+ type: 'boolean',
36
+ status: 'optional'
37
+ },
32
38
  placeholder: {
33
39
  doc: 'Will be shown if the value or data context value is empty.',
34
40
  type: 'React.Node',
@@ -39,9 +45,17 @@ export const ArrayProperties = {
39
45
  type: 'unknown',
40
46
  status: 'optional'
41
47
  },
48
+ validator: dataValueProperties.validator,
49
+ validateInitially: dataValueProperties.validateInitially,
50
+ continuousValidation: dataValueProperties.continuousValidation,
51
+ containerMode: {
52
+ doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',
53
+ type: 'string',
54
+ status: 'optional'
55
+ },
42
56
  children: {
43
57
  doc: 'React.Node or a function so you can get the current value and index.',
44
- type: 'boolean',
58
+ type: ['React.ReactNode', 'function'],
45
59
  status: 'optional'
46
60
  },
47
61
  '[Flex.Stack](/uilib/layout/flex/stack/)': {
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayDocs.js","names":["ArrayProperties","value","doc","type","status","path","countPath","countPathTransform","countPathLimit","withoutFlex","placeholder","emptyValue","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: 'boolean',\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,cAAc,EAAE;IACdN,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,WAAW,EAAE;IACXP,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,QAAQ,EAAE;IACRV,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMS,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRZ,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"ArrayDocs.js","names":["dataValueProperties","ArrayProperties","value","doc","type","status","path","countPath","countPathTransform","countPathLimit","withoutFlex","animate","placeholder","emptyValue","validator","validateInitially","continuousValidation","containerMode","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { dataValueProperties } from '../../hooks/DataValueDocs'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n animate: {\n doc: 'When `true` it will animate the height of the items.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n validator: dataValueProperties.validator,\n validateInitially: dataValueProperties.validateInitially,\n continuousValidation: dataValueProperties.continuousValidation,\n containerMode: {\n doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: ['React.ReactNode', 'function'],\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AACA,SAASA,mBAAmB,QAAQ,2BAA2B;AAE/D,OAAO,MAAMC,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,cAAc,EAAE;IACdN,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,WAAW,EAAE;IACXP,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,OAAO,EAAE;IACPR,GAAG,EAAE,sDAAsD;IAC3DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDO,WAAW,EAAE;IACXT,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDQ,UAAU,EAAE;IACVV,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDS,SAAS,EAAEd,mBAAmB,CAACc,SAAS;EACxCC,iBAAiB,EAAEf,mBAAmB,CAACe,iBAAiB;EACxDC,oBAAoB,EAAEhB,mBAAmB,CAACgB,oBAAoB;EAC9DC,aAAa,EAAE;IACbd,GAAG,EAAE,0SAA0S;IAC/SC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDa,QAAQ,EAAE;IACRf,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,CAAC,iBAAiB,EAAE,UAAU,CAAC;IACrCC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMc,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRjB,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -0,0 +1,20 @@
1
+ import { Props as FlexContainerProps } from '../../../../components/flex/Container';
2
+ import { ContainerMode } from './types';
3
+ export type ArrayItemAreaProps = {
4
+ /**
5
+ * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline` or `basic`.
6
+ * Defaults to `outline`.
7
+ */
8
+ variant?: 'outline' | 'basic';
9
+ };
10
+ export type Props = {
11
+ mode: ContainerMode;
12
+ open?: boolean | undefined;
13
+ ariaLabel?: string;
14
+ openDelay?: number;
15
+ } & ArrayItemAreaProps;
16
+ declare function ArrayItemArea(props: Props & FlexContainerProps): import("react/jsx-runtime").JSX.Element;
17
+ declare namespace ArrayItemArea {
18
+ var _supportsSpacingProps: boolean;
19
+ }
20
+ export default ArrayItemArea;