@dnb/eufemia 10.47.0 → 10.48.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (561) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/cjs/extensions/forms/DataContext/Context.d.ts +1 -0
  3. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  4. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  5. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  6. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  7. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +12 -5
  8. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  9. package/cjs/extensions/forms/DataContext/Provider/Provider.js +1 -0
  10. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  11. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  12. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  13. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  14. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +32 -7
  15. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  16. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  17. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  18. package/cjs/extensions/forms/Form/Isolation/Isolation.js +2 -3
  19. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  20. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js +20 -1
  21. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  22. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  23. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  24. package/cjs/extensions/forms/Form/Section/Section.d.ts +7 -2
  25. package/cjs/extensions/forms/Form/Section/Section.js +3 -1
  26. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  27. package/cjs/extensions/forms/Form/Section/SectionDocs.js +6 -1
  28. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  29. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  30. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  31. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  32. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  33. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  34. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  35. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  36. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  37. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  38. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  39. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  40. package/cjs/extensions/forms/Iterate/Array/Array.js +67 -24
  41. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  42. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  43. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  44. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  45. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.js → Array/ArrayItemArea.js} +66 -49
  46. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  47. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  48. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlockContext.js → Array/ArrayItemAreaContext.js} +3 -3
  49. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  50. package/cjs/extensions/forms/Iterate/Array/types.d.ts +7 -5
  51. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  52. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  53. package/cjs/extensions/forms/Iterate/EditContainer/{EditToolbarTools.js → CancelButton.js} +30 -56
  54. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  55. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  56. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js +75 -0
  57. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  58. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  59. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +33 -12
  60. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  61. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  62. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  63. package/cjs/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  64. package/cjs/extensions/forms/Iterate/EditContainer/index.js +19 -1
  65. package/cjs/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  66. package/cjs/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  67. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  68. package/cjs/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  69. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  70. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  71. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  72. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -24
  73. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  74. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  75. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  76. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  77. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  78. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  79. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -6
  80. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  81. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  82. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js +12 -0
  83. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  84. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  85. package/cjs/extensions/forms/Iterate/ViewContainer/{ViewToolbarTools.js → EditButton.js} +8 -11
  86. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  87. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  88. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js +19 -0
  89. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  90. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  91. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +25 -10
  92. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  93. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  94. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  95. package/cjs/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  96. package/cjs/extensions/forms/Iterate/ViewContainer/index.js +19 -1
  97. package/cjs/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  98. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  99. package/cjs/extensions/forms/Iterate/hooks/index.js +21 -0
  100. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -0
  101. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  102. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +93 -0
  103. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  104. package/cjs/extensions/forms/Tools/Log.d.ts +6 -0
  105. package/cjs/extensions/forms/Tools/Log.js +29 -0
  106. package/cjs/extensions/forms/Tools/Log.js.map +1 -0
  107. package/cjs/extensions/forms/Tools/index.d.ts +1 -0
  108. package/cjs/extensions/forms/Tools/index.js +7 -0
  109. package/cjs/extensions/forms/Tools/index.js.map +1 -1
  110. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  111. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  112. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  113. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  114. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  115. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  116. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  117. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  118. package/cjs/extensions/forms/constants/countries.js +10 -26
  119. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  120. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  121. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -2
  122. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  123. package/cjs/extensions/forms/constants/locales/en-US.d.ts +2 -1
  124. package/cjs/extensions/forms/constants/locales/index.d.ts +4 -2
  125. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  126. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -2
  127. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  128. package/cjs/extensions/forms/hooks/DataValueDocs.js +6 -1
  129. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  130. package/cjs/extensions/forms/hooks/useExternalValue.js +8 -6
  131. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  132. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  133. package/cjs/extensions/forms/hooks/useFieldProps.js +29 -14
  134. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  135. package/cjs/extensions/forms/hooks/usePath.d.ts +1 -0
  136. package/cjs/extensions/forms/hooks/usePath.js +5 -1
  137. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  138. package/cjs/extensions/forms/style/dnb-forms.css +3 -0
  139. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  140. package/cjs/extensions/forms/types.d.ts +4 -0
  141. package/cjs/extensions/forms/types.js.map +1 -1
  142. package/cjs/shared/Eufemia.d.ts +1 -1
  143. package/cjs/shared/Eufemia.js +2 -2
  144. package/cjs/shared/Eufemia.js.map +1 -1
  145. package/cjs/style/core/scopes.scss +1 -1
  146. package/cjs/style/dnb-ui-basis.css +1 -1
  147. package/cjs/style/dnb-ui-basis.min.css +1 -1
  148. package/cjs/style/dnb-ui-body.css +1 -1
  149. package/cjs/style/dnb-ui-body.min.css +1 -1
  150. package/cjs/style/dnb-ui-components.css +3 -0
  151. package/cjs/style/dnb-ui-components.min.css +1 -1
  152. package/cjs/style/dnb-ui-core.css +1 -1
  153. package/cjs/style/dnb-ui-core.min.css +1 -1
  154. package/cjs/style/dnb-ui-extensions.css +3 -0
  155. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  156. package/cjs/style/dnb-ui-forms.css +3 -0
  157. package/cjs/style/dnb-ui-forms.min.css +1 -1
  158. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  159. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  160. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  161. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  162. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  163. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  164. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  165. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  166. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  167. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  168. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  169. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  170. package/cjs/style/themes/theme-ui/ui-theme-components.css +6 -0
  171. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  172. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  173. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  174. package/cjs/style/themes/theme-ui/ui-theme-forms.css +3 -0
  175. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  176. package/es/extensions/forms/DataContext/Context.d.ts +1 -0
  177. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  178. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  179. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  180. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  181. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +13 -5
  182. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  183. package/es/extensions/forms/DataContext/Provider/Provider.js +1 -0
  184. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  185. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  186. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  187. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  188. package/es/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  189. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  190. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  191. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  192. package/es/extensions/forms/Form/Isolation/Isolation.js +2 -3
  193. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  194. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  195. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  196. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  197. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  198. package/es/extensions/forms/Form/Section/Section.d.ts +7 -2
  199. package/es/extensions/forms/Form/Section/Section.js +3 -1
  200. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  201. package/es/extensions/forms/Form/Section/SectionDocs.js +6 -1
  202. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  203. package/es/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  204. package/es/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  205. package/es/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  206. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  207. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  208. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  209. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  210. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  211. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  212. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  213. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  214. package/es/extensions/forms/Iterate/Array/Array.js +67 -25
  215. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  216. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  217. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  218. package/es/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  219. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  220. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  221. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  222. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  223. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  224. package/es/extensions/forms/Iterate/Array/types.d.ts +7 -5
  225. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  226. package/es/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  227. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +87 -0
  228. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  229. package/es/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  230. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js +67 -0
  231. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  232. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  233. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  234. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  235. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  236. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  237. package/es/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  238. package/es/extensions/forms/Iterate/EditContainer/index.js +2 -0
  239. package/es/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  240. package/es/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  241. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  242. package/es/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  243. package/es/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  244. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  245. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  246. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -23
  247. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  248. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  249. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  250. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  251. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  252. package/es/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  253. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +51 -7
  254. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  255. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  256. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  257. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  258. package/es/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  259. package/{extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → es/extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  260. package/es/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  261. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  262. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  263. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  264. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  265. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  266. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  267. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  268. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  269. package/es/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  270. package/es/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  271. package/es/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  272. package/es/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  273. package/es/extensions/forms/Iterate/hooks/index.js +3 -0
  274. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -0
  275. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  276. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +85 -0
  277. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  278. package/es/extensions/forms/Tools/Log.d.ts +6 -0
  279. package/es/extensions/forms/Tools/Log.js +22 -0
  280. package/es/extensions/forms/Tools/Log.js.map +1 -0
  281. package/es/extensions/forms/Tools/index.d.ts +1 -0
  282. package/es/extensions/forms/Tools/index.js +1 -0
  283. package/es/extensions/forms/Tools/index.js.map +1 -1
  284. package/es/extensions/forms/Wizard/Container/WizardContainer.js +17 -6
  285. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  286. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  287. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  288. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  289. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  290. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  291. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  292. package/es/extensions/forms/constants/countries.js +10 -26
  293. package/es/extensions/forms/constants/countries.js.map +1 -1
  294. package/es/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  295. package/es/extensions/forms/constants/locales/en-GB.js +3 -2
  296. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  297. package/es/extensions/forms/constants/locales/en-US.d.ts +2 -1
  298. package/es/extensions/forms/constants/locales/index.d.ts +4 -2
  299. package/es/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  300. package/es/extensions/forms/constants/locales/nb-NO.js +3 -2
  301. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  302. package/es/extensions/forms/hooks/DataValueDocs.js +6 -1
  303. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  304. package/es/extensions/forms/hooks/useExternalValue.js +8 -6
  305. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  306. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  307. package/es/extensions/forms/hooks/useFieldProps.js +29 -15
  308. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  309. package/es/extensions/forms/hooks/usePath.d.ts +1 -0
  310. package/es/extensions/forms/hooks/usePath.js +5 -1
  311. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  312. package/es/extensions/forms/style/dnb-forms.css +3 -0
  313. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  314. package/es/extensions/forms/types.d.ts +4 -0
  315. package/es/extensions/forms/types.js.map +1 -1
  316. package/es/shared/Eufemia.d.ts +1 -1
  317. package/es/shared/Eufemia.js +2 -2
  318. package/es/shared/Eufemia.js.map +1 -1
  319. package/es/style/core/scopes.scss +1 -1
  320. package/es/style/dnb-ui-basis.css +1 -1
  321. package/es/style/dnb-ui-basis.min.css +1 -1
  322. package/es/style/dnb-ui-body.css +1 -1
  323. package/es/style/dnb-ui-body.min.css +1 -1
  324. package/es/style/dnb-ui-components.css +3 -0
  325. package/es/style/dnb-ui-components.min.css +1 -1
  326. package/es/style/dnb-ui-core.css +1 -1
  327. package/es/style/dnb-ui-core.min.css +1 -1
  328. package/es/style/dnb-ui-extensions.css +3 -0
  329. package/es/style/dnb-ui-extensions.min.css +1 -1
  330. package/es/style/dnb-ui-forms.css +3 -0
  331. package/es/style/dnb-ui-forms.min.css +1 -1
  332. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  333. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  334. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  335. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  336. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  337. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  338. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  339. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  340. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  341. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  342. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  343. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  344. package/es/style/themes/theme-ui/ui-theme-components.css +6 -0
  345. package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  346. package/es/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  347. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  348. package/es/style/themes/theme-ui/ui-theme-forms.css +3 -0
  349. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  350. package/esm/dnb-ui-basis.min.mjs +1 -1
  351. package/esm/dnb-ui-components.min.mjs +1 -1
  352. package/esm/dnb-ui-elements.min.mjs +1 -1
  353. package/esm/dnb-ui-extensions.min.mjs +2 -2
  354. package/esm/dnb-ui-lib.min.mjs +1 -1
  355. package/extensions/forms/DataContext/Context.d.ts +1 -0
  356. package/extensions/forms/DataContext/Context.js.map +1 -1
  357. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +3 -2
  358. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  359. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  360. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +12 -5
  361. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  362. package/extensions/forms/DataContext/Provider/Provider.js +1 -0
  363. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  364. package/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  365. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  366. package/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  367. package/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  368. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  369. package/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  370. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  371. package/extensions/forms/Form/Isolation/Isolation.js +2 -3
  372. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  373. package/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  374. package/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  375. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  376. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  377. package/extensions/forms/Form/Section/Section.d.ts +7 -2
  378. package/extensions/forms/Form/Section/Section.js +3 -1
  379. package/extensions/forms/Form/Section/Section.js.map +1 -1
  380. package/extensions/forms/Form/Section/SectionDocs.js +6 -1
  381. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  382. package/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  383. package/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  384. package/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  385. package/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  386. package/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  387. package/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  388. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  389. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  390. package/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  391. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  392. package/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  393. package/extensions/forms/Iterate/Array/Array.js +68 -25
  394. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  395. package/extensions/forms/Iterate/Array/ArrayDocs.js +9 -0
  396. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  397. package/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.d.ts → Array/ArrayItemArea.d.ts} +6 -6
  398. package/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  399. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  400. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  401. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  402. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  403. package/extensions/forms/Iterate/Array/types.d.ts +7 -5
  404. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  405. package/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  406. package/extensions/forms/Iterate/EditContainer/CancelButton.js +88 -0
  407. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  408. package/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  409. package/extensions/forms/Iterate/EditContainer/DoneButton.js +67 -0
  410. package/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  411. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  412. package/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  413. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  414. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  415. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  416. package/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  417. package/extensions/forms/Iterate/EditContainer/index.js +2 -0
  418. package/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  419. package/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  420. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  421. package/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  422. package/extensions/forms/Iterate/PushButton/PushButton.js +23 -12
  423. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  424. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +5 -1
  425. package/extensions/forms/Iterate/PushContainer/PushContainer.js +80 -26
  426. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  427. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  428. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  429. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +9 -9
  430. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  431. package/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  432. package/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -7
  433. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  434. package/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  435. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  436. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  437. package/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  438. package/{es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  439. package/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  440. package/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  441. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  442. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  443. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  444. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  445. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  446. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  447. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  448. package/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  449. package/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  450. package/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  451. package/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  452. package/extensions/forms/Iterate/hooks/index.js +3 -0
  453. package/extensions/forms/Iterate/hooks/index.js.map +1 -0
  454. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  455. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +87 -0
  456. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  457. package/extensions/forms/Tools/Log.d.ts +6 -0
  458. package/extensions/forms/Tools/Log.js +22 -0
  459. package/extensions/forms/Tools/Log.js.map +1 -0
  460. package/extensions/forms/Tools/index.d.ts +1 -0
  461. package/extensions/forms/Tools/index.js +1 -0
  462. package/extensions/forms/Tools/index.js.map +1 -1
  463. package/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  464. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  465. package/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  466. package/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  467. package/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  468. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  469. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  470. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  471. package/extensions/forms/constants/countries.js +10 -26
  472. package/extensions/forms/constants/countries.js.map +1 -1
  473. package/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  474. package/extensions/forms/constants/locales/en-GB.js +3 -2
  475. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  476. package/extensions/forms/constants/locales/en-US.d.ts +2 -1
  477. package/extensions/forms/constants/locales/index.d.ts +4 -2
  478. package/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  479. package/extensions/forms/constants/locales/nb-NO.js +3 -2
  480. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  481. package/extensions/forms/hooks/DataValueDocs.js +6 -1
  482. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  483. package/extensions/forms/hooks/useExternalValue.js +8 -6
  484. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  485. package/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  486. package/extensions/forms/hooks/useFieldProps.js +29 -14
  487. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  488. package/extensions/forms/hooks/usePath.d.ts +1 -0
  489. package/extensions/forms/hooks/usePath.js +5 -1
  490. package/extensions/forms/hooks/usePath.js.map +1 -1
  491. package/extensions/forms/style/dnb-forms.css +3 -0
  492. package/extensions/forms/style/dnb-forms.min.css +1 -1
  493. package/extensions/forms/types.d.ts +4 -0
  494. package/extensions/forms/types.js.map +1 -1
  495. package/package.json +1 -1
  496. package/shared/Eufemia.d.ts +1 -1
  497. package/shared/Eufemia.js +2 -2
  498. package/shared/Eufemia.js.map +1 -1
  499. package/style/core/scopes.scss +1 -1
  500. package/style/dnb-ui-basis.css +1 -1
  501. package/style/dnb-ui-basis.min.css +1 -1
  502. package/style/dnb-ui-body.css +1 -1
  503. package/style/dnb-ui-body.min.css +1 -1
  504. package/style/dnb-ui-components.css +3 -0
  505. package/style/dnb-ui-components.min.css +1 -1
  506. package/style/dnb-ui-core.css +1 -1
  507. package/style/dnb-ui-core.min.css +1 -1
  508. package/style/dnb-ui-extensions.css +3 -0
  509. package/style/dnb-ui-extensions.min.css +1 -1
  510. package/style/dnb-ui-forms.css +3 -0
  511. package/style/dnb-ui-forms.min.css +1 -1
  512. package/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  513. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  514. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  515. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  516. package/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  517. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  518. package/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  519. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  520. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  521. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  522. package/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  523. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  524. package/style/themes/theme-ui/ui-theme-components.css +6 -0
  525. package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  526. package/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  527. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  528. package/style/themes/theme-ui/ui-theme-forms.css +3 -0
  529. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  530. package/umd/dnb-ui-basis.min.js +1 -1
  531. package/umd/dnb-ui-components.min.js +1 -1
  532. package/umd/dnb-ui-elements.min.js +1 -1
  533. package/umd/dnb-ui-extensions.min.js +3 -3
  534. package/umd/dnb-ui-lib.min.js +1 -1
  535. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  536. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  537. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  538. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  539. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  540. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  541. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  542. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  543. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  544. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  545. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  546. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  547. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  548. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -113
  549. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  550. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  551. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  552. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  553. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  554. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  555. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  556. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  557. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  558. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -114
  559. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  560. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  561. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"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","Fragment","classnames","pointer","useFieldProps","makeUniqueId","Flex","FormStatus","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","error","defaultValue","withoutFlex","emptyValue","placeholder","containerMode","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","WrapperElement","Stack","createElement","itemProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","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 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, FormStatus } 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 ...props,\n value: newValue,\n }\n }\n }\n\n return 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 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 WrapperElement = omitFlex ? Fragment : Flex.Stack\n\n return (\n <>\n <WrapperElement {...(omitFlex ? null : flexProps)}>\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>\n {content}\n </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>\n {content}\n </FieldBoundaryProvider>\n </IterateItemContext.Provider>\n </Flex.Item>\n )\n })}\n </WrapperElement>\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 = false // disable flex support to avoid rerender, which could result in flickering\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.',
@@ -39,6 +40,14 @@ export const ArrayProperties = {
39
40
  type: 'unknown',
40
41
  status: 'optional'
41
42
  },
43
+ validator: dataValueProperties.validator,
44
+ validateInitially: dataValueProperties.validateInitially,
45
+ continuousValidation: dataValueProperties.continuousValidation,
46
+ containerMode: {
47
+ 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`.',
48
+ type: 'string',
49
+ status: 'optional'
50
+ },
42
51
  children: {
43
52
  doc: 'React.Node or a function so you can get the current value and index.',
44
53
  type: 'boolean',
@@ -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","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 placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n validator: dataValueProperties.validator,\n validateInitially: dataValueProperties.validateInitially,\n continuousValidation: dataValueProperties.continuousValidation,\n containerMode: {\n doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: 'boolean',\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AACA,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,WAAW,EAAE;IACXR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAEb,mBAAmB,CAACa,SAAS;EACxCC,iBAAiB,EAAEd,mBAAmB,CAACc,iBAAiB;EACxDC,oBAAoB,EAAEf,mBAAmB,CAACe,oBAAoB;EAC9DC,aAAa,EAAE;IACbb,GAAG,EAAE,0SAA0S;IAC/SC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDY,QAAQ,EAAE;IACRd,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,MAAMa,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRhB,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -1,6 +1,6 @@
1
1
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
2
- import { ContainerMode } from '../Array/types';
3
- export type ElementSectionProps = {
2
+ import { ContainerMode } from './types';
3
+ export type ArrayItemAreaProps = {
4
4
  /**
5
5
  * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.
6
6
  * Defaults to `outline`.
@@ -12,9 +12,9 @@ export type Props = {
12
12
  open?: boolean | undefined;
13
13
  ariaLabel?: string;
14
14
  openDelay?: number;
15
- } & ElementSectionProps;
16
- declare function ElementBlock(props: Props & FlexContainerProps): import("react/jsx-runtime").JSX.Element;
17
- declare namespace ElementBlock {
15
+ } & ArrayItemAreaProps;
16
+ declare function ArrayItemArea(props: Props & FlexContainerProps): import("react/jsx-runtime").JSX.Element;
17
+ declare namespace ArrayItemArea {
18
18
  var _supportsSpacingProps: boolean;
19
19
  }
20
- export default ElementBlock;
20
+ export default ArrayItemArea;
@@ -0,0 +1,137 @@
1
+ "use client";
2
+
3
+ import _extends from "@babel/runtime/helpers/esm/extends";
4
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
+ const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "openDelay", "variant"];
6
+ import React, { useCallback, useContext, useEffect, useReducer, useRef } from 'react';
7
+ import classnames from 'classnames';
8
+ import { Flex, HeightAnimation } from '../../../../components';
9
+ import IterateItemContext from '../IterateItemContext';
10
+ import ArrayItemAreaContext from './ArrayItemAreaContext';
11
+ import FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext';
12
+ function ArrayItemArea(props) {
13
+ const [, forceUpdate] = useReducer(() => ({}), {});
14
+ const {
15
+ mode,
16
+ open,
17
+ ariaLabel,
18
+ onAnimationEnd,
19
+ className,
20
+ children,
21
+ openDelay = 100,
22
+ variant = 'outline'
23
+ } = props,
24
+ restProps = _objectWithoutProperties(props, _excluded);
25
+ const localContextRef = useRef();
26
+ const {
27
+ hasError,
28
+ hasSubmitError
29
+ } = useContext(FieldBoundaryContext) || {};
30
+ localContextRef.current = useContext(IterateItemContext) || {};
31
+ const nextFocusElementRef = useRef();
32
+ const {
33
+ isNew,
34
+ value
35
+ } = localContextRef.current;
36
+ if (hasSubmitError || !value) {
37
+ localContextRef.current.containerMode = 'edit';
38
+ }
39
+ if (localContextRef.current.containerMode === 'auto') {
40
+ localContextRef.current.containerMode = 'view';
41
+ }
42
+ const determineMode = useCallback(() => {
43
+ const {
44
+ initialContainerMode,
45
+ switchContainerMode
46
+ } = localContextRef.current;
47
+ if (mode === 'edit' && !hasSubmitError && initialContainerMode === 'auto') {
48
+ if (hasError && !isNew) {
49
+ switchContainerMode('edit', {
50
+ omitFocusManagement: true
51
+ });
52
+ }
53
+ }
54
+ }, [hasError, hasSubmitError, isNew, mode]);
55
+ useEffect(() => {
56
+ determineMode();
57
+ }, [determineMode]);
58
+ const {
59
+ handleRemove,
60
+ index,
61
+ previousContainerMode,
62
+ containerMode
63
+ } = localContextRef.current;
64
+ const openRef = useRef(open !== null && open !== void 0 ? open : containerMode === mode && !isNew);
65
+ const isRemoving = useRef(false);
66
+ const setOpenState = useCallback(open => {
67
+ openRef.current = open;
68
+ forceUpdate();
69
+ }, []);
70
+ useEffect(() => {
71
+ if (!isRemoving.current) {
72
+ if (typeof open !== 'undefined') {
73
+ setOpenState(open);
74
+ } else {
75
+ if (openRef.current !== (containerMode === mode)) {
76
+ if (isNew) {
77
+ setTimeout(() => {
78
+ setOpenState(containerMode === mode);
79
+ }, openDelay);
80
+ } else {
81
+ setOpenState(containerMode === mode);
82
+ }
83
+ }
84
+ }
85
+ }
86
+ }, [containerMode, isNew, mode, open, openDelay, setOpenState]);
87
+ const setFocus = useCallback(state => {
88
+ var _localContextRef$curr;
89
+ if (((_localContextRef$curr = localContextRef.current.modeOptions) === null || _localContextRef$curr === void 0 ? void 0 : _localContextRef$curr.omitFocusManagement) !== true && !hasSubmitError && containerMode === mode && containerMode !== previousContainerMode) {
90
+ if (state === 'opened') {
91
+ var _localContextRef$curr2, _localContextRef$curr3, _localContextRef$curr4;
92
+ (_localContextRef$curr2 = localContextRef.current.elementRef) === null || _localContextRef$curr2 === void 0 ? void 0 : (_localContextRef$curr3 = _localContextRef$curr2.current) === null || _localContextRef$curr3 === void 0 ? void 0 : (_localContextRef$curr4 = _localContextRef$curr3.focus) === null || _localContextRef$curr4 === void 0 ? void 0 : _localContextRef$curr4.call(_localContextRef$curr3);
93
+ } else if (state === 'closed') {
94
+ var _nextFocusElementRef$, _nextFocusElementRef$2;
95
+ (_nextFocusElementRef$ = nextFocusElementRef.current) === null || _nextFocusElementRef$ === void 0 ? void 0 : (_nextFocusElementRef$2 = _nextFocusElementRef$.focus) === null || _nextFocusElementRef$2 === void 0 ? void 0 : _nextFocusElementRef$2.call(_nextFocusElementRef$);
96
+ }
97
+ }
98
+ }, [containerMode, hasSubmitError, mode, previousContainerMode]);
99
+ const handleAnimationEnd = useCallback(state => {
100
+ if (!openRef.current && isRemoving.current) {
101
+ var _localContextRef$curr5, _localContextRef$curr6;
102
+ isRemoving.current = false;
103
+ (_localContextRef$curr5 = (_localContextRef$curr6 = localContextRef.current).fulfillRemove) === null || _localContextRef$curr5 === void 0 ? void 0 : _localContextRef$curr5.call(_localContextRef$curr6);
104
+ }
105
+ setFocus(state);
106
+ onAnimationEnd === null || onAnimationEnd === void 0 ? void 0 : onAnimationEnd(state);
107
+ }, [onAnimationEnd, setFocus]);
108
+ const handleRemoveItem = useCallback(() => {
109
+ try {
110
+ nextFocusElementRef.current = Array.from(localContextRef.current.elementRef.current.parentElement.childNodes).at(index - 1);
111
+ } catch (e) {}
112
+ isRemoving.current = true;
113
+ handleRemove === null || handleRemove === void 0 ? void 0 : handleRemove({
114
+ keepItems: true
115
+ });
116
+ setOpenState(false);
117
+ }, [handleRemove, index, setOpenState]);
118
+ return React.createElement(ArrayItemAreaContext.Provider, {
119
+ value: {
120
+ handleRemoveItem
121
+ }
122
+ }, React.createElement(HeightAnimation, {
123
+ className: classnames('dnb-forms-section-block', className, variant && `dnb-forms-section-block--variant-${variant}`, isNew && 'dnb-forms-section-block--new', hasSubmitError && 'dnb-forms-section-block--error'),
124
+ open: openRef.current,
125
+ onAnimationEnd: handleAnimationEnd,
126
+ duration: 450,
127
+ keepInDOM: true
128
+ }, React.createElement(Flex.Stack, _extends({
129
+ className: "dnb-forms-section-block__inner"
130
+ }, restProps, {
131
+ element: "section",
132
+ "aria-label": ariaLabel
133
+ }), children)));
134
+ }
135
+ ArrayItemArea._supportsSpacingProps = true;
136
+ export default ArrayItemArea;
137
+ //# sourceMappingURL=ArrayItemArea.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ArrayItemArea.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Flex","HeightAnimation","IterateItemContext","ArrayItemAreaContext","FieldBoundaryContext","ArrayItemArea","props","forceUpdate","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","_objectWithoutProperties","_excluded","localContextRef","hasError","hasSubmitError","current","nextFocusElementRef","isNew","value","containerMode","determineMode","initialContainerMode","switchContainerMode","omitFocusManagement","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","modeOptions","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","call","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","duration","keepInDOM","Stack","_extends","element","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew, value } = localContextRef.current\n if (hasSubmitError || !value) {\n localContextRef.current.containerMode = 'edit'\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n const determineMode = useCallback(() => {\n const { initialContainerMode, switchContainerMode } =\n localContextRef.current\n if (\n mode === 'edit' &&\n !hasSubmitError &&\n initialContainerMode === 'auto'\n ) {\n // - Set the container mode to \"edit\" if we have an error\n if (hasError && !isNew) {\n switchContainerMode('edit', { omitFocusManagement: true })\n }\n }\n }, [hasError, hasSubmitError, isNew, mode])\n\n useEffect(() => {\n determineMode()\n }, [determineMode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider value={{ handleRemoveItem }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ type ArrayItemAreaContext = {
3
+ handleRemoveItem?: () => void;
4
+ };
5
+ declare const ArrayItemAreaContext: import("react").Context<ArrayItemAreaContext>;
6
+ export default ArrayItemAreaContext;
@@ -0,0 +1,6 @@
1
+ "use client";
2
+
3
+ import { createContext } from 'react';
4
+ const ArrayItemAreaContext = createContext(null);
5
+ export default ArrayItemAreaContext;
6
+ //# sourceMappingURL=ArrayItemAreaContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ArrayItemAreaContext.js","names":["createContext","ArrayItemAreaContext"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemAreaContext.ts"],"sourcesContent":["import { createContext } from 'react'\n\ntype ArrayItemAreaContext = {\n handleRemoveItem?: () => void\n}\n\nconst ArrayItemAreaContext = createContext<ArrayItemAreaContext>(null)\n\nexport default ArrayItemAreaContext\n"],"mappings":";;AAAA,SAASA,aAAa,QAAQ,OAAO;AAMrC,MAAMC,oBAAoB,GAAGD,aAAa,CAAuB,IAAI,CAAC;AAEtE,eAAeC,oBAAoB"}
@@ -1,18 +1,20 @@
1
1
  /// <reference types="react" />
2
- import { Path, UseFieldProps } from '../../types';
2
+ import { Path, UseFieldProps, Validator } from '../../types';
3
3
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
4
- export type ContainerMode = 'view' | 'edit';
4
+ export type ContainerMode = 'view' | 'edit' | 'auto';
5
5
  export type Value = Array<unknown | Record<string, unknown>>;
6
6
  export type ElementChild = React.ReactNode | ((value: any, index: number) => React.ReactNode);
7
- export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'emptyValue' | 'onChange'> & {
7
+ export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'defaultValue' | 'emptyValue' | 'onChange' | 'validateInitially' | 'continuousValidation'> & {
8
8
  children: ElementChild | Array<ElementChild>;
9
9
  path?: Path;
10
10
  countPath?: Path;
11
11
  countPathLimit?: number;
12
+ validator?: Validator<Value>;
13
+ withoutFlex?: boolean;
14
+ placeholder?: React.ReactNode;
15
+ containerMode?: ContainerMode;
12
16
  countPathTransform?: (params: {
13
17
  value: any;
14
18
  index: number;
15
19
  }) => any;
16
- withoutFlex?: boolean;
17
- placeholder?: React.ReactNode;
18
20
  };
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((value: any, index: number) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n 'value' | 'emptyValue' | 'onChange'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n countPath?: Path\n countPathLimit?: number\n countPathTransform?: (params: { value: any; index: number }) => any\n withoutFlex?: boolean\n placeholder?: React.ReactNode\n }\n"],"mappings":""}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps, Validator } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((value: any, index: number) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n countPath?: Path\n countPathLimit?: number\n validator?: Validator<Value>\n withoutFlex?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n countPathTransform?: (params: { value: any; index: number }) => any\n }\n"],"mappings":""}
@@ -0,0 +1,9 @@
1
+ import { ButtonProps } from '../../../../components/Button';
2
+ import { ContainerMode } from '../Array';
3
+ type Props = ButtonProps;
4
+ export default function EditToolbarTools(props: Props): import("react/jsx-runtime").JSX.Element;
5
+ export declare function useWasNew({ isNew, containerMode, }: {
6
+ isNew: boolean;
7
+ containerMode: ContainerMode;
8
+ }): unknown;
9
+ export {};
@@ -0,0 +1,88 @@
1
+ "use client";
2
+
3
+ import _extends from "@babel/runtime/helpers/esm/extends";
4
+ import React, { useCallback, useContext, useEffect, useRef } from 'react';
5
+ import { Button } from '../../../../components';
6
+ import useTranslation from '../../hooks/useTranslation';
7
+ import IterateItemContext from '../IterateItemContext';
8
+ import ToolbarContext from '../Toolbar/ToolbarContext';
9
+ import FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext';
10
+ import { close } from '../../../../icons';
11
+ import RemoveButton from '../RemoveButton';
12
+ export default function EditToolbarTools(props) {
13
+ const {
14
+ restoreOriginalValue,
15
+ switchContainerMode,
16
+ containerMode,
17
+ initialContainerMode,
18
+ arrayValue,
19
+ isNew,
20
+ index
21
+ } = useContext(IterateItemContext) || {};
22
+ const {
23
+ hasError,
24
+ hasVisibleError,
25
+ setShowBoundaryErrors
26
+ } = useContext(FieldBoundaryContext) || {};
27
+ const {
28
+ setShowError
29
+ } = useContext(ToolbarContext) || {};
30
+ const {
31
+ cancelButton,
32
+ removeButton
33
+ } = useTranslation().IterateEditContainer;
34
+ const valueBackupRef = useRef();
35
+ useEffect(() => {
36
+ if (containerMode === 'edit' && !valueBackupRef.current) {
37
+ valueBackupRef.current = arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue[index];
38
+ }
39
+ if (containerMode === 'view') {
40
+ valueBackupRef.current = null;
41
+ }
42
+ }, [arrayValue, containerMode, index]);
43
+ const cancelHandler = useCallback(() => {
44
+ if (hasError && initialContainerMode === 'auto') {
45
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
46
+ if (hasVisibleError) {
47
+ setShowError(true);
48
+ }
49
+ } else {
50
+ restoreOriginalValue === null || restoreOriginalValue === void 0 ? void 0 : restoreOriginalValue(valueBackupRef.current);
51
+ setShowError(false);
52
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
53
+ switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
54
+ }
55
+ }, [hasError, hasVisibleError, initialContainerMode, restoreOriginalValue, setShowBoundaryErrors, setShowError, switchContainerMode]);
56
+ const wasNew = useWasNew({
57
+ isNew,
58
+ containerMode
59
+ });
60
+ if (containerMode === 'edit' && (arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue.length) === 0) {
61
+ return React.createElement(React.Fragment, null);
62
+ }
63
+ if (wasNew) {
64
+ return React.createElement(RemoveButton, _extends({
65
+ text: removeButton
66
+ }, props));
67
+ }
68
+ return React.createElement(Button, _extends({
69
+ variant: "tertiary",
70
+ icon: close,
71
+ icon_position: "left",
72
+ on_click: cancelHandler
73
+ }, props), cancelButton);
74
+ }
75
+ export function useWasNew(_ref) {
76
+ let {
77
+ isNew,
78
+ containerMode
79
+ } = _ref;
80
+ const wasNewRef = useRef(isNew);
81
+ useEffect(() => {
82
+ if (containerMode === 'view') {
83
+ wasNewRef.current = false;
84
+ }
85
+ }, [isNew, containerMode]);
86
+ return wasNewRef.current;
87
+ }
88
+ //# sourceMappingURL=CancelButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CancelButton.js","names":["React","useCallback","useContext","useEffect","useRef","Button","useTranslation","IterateItemContext","ToolbarContext","FieldBoundaryContext","close","RemoveButton","EditToolbarTools","props","restoreOriginalValue","switchContainerMode","containerMode","initialContainerMode","arrayValue","isNew","index","hasError","hasVisibleError","setShowBoundaryErrors","setShowError","cancelButton","removeButton","IterateEditContainer","valueBackupRef","current","cancelHandler","wasNew","useWasNew","length","createElement","Fragment","_extends","text","variant","icon","icon_position","on_click","_ref","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/CancelButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { close } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport RemoveButton, { Props as RemoveButtonProps } from '../RemoveButton'\nimport { ContainerMode } from '../Array'\n\ntype Props = ButtonProps\n\nexport default function EditToolbarTools(props: Props) {\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n initialContainerMode,\n arrayValue,\n isNew,\n index,\n } = useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { cancelButton, removeButton } =\n useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(() => {\n if (hasError && initialContainerMode === 'auto') {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n restoreOriginalValue?.(valueBackupRef.current)\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n }\n }, [\n hasError,\n hasVisibleError,\n initialContainerMode,\n restoreOriginalValue,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n const wasNew = useWasNew({ isNew, containerMode })\n\n if (containerMode === 'edit' && arrayValue?.length === 0) {\n return <></>\n }\n\n if (wasNew) {\n return (\n <RemoveButton\n text={removeButton}\n {...(props as RemoveButtonProps)}\n />\n )\n }\n\n return (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n {...props}\n >\n {cancelButton}\n </Button>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import { ButtonProps } from '../../../../components/Button';
2
+ type Props = ButtonProps;
3
+ export default function DoneButton(props: Props): import("react/jsx-runtime").JSX.Element;
4
+ export {};
@@ -0,0 +1,67 @@
1
+ "use client";
2
+
3
+ import _extends from "@babel/runtime/helpers/esm/extends";
4
+ import React, { useCallback, useContext, useEffect, useRef } from 'react';
5
+ import { Button } from '../../../../components';
6
+ import useTranslation from '../../hooks/useTranslation';
7
+ import IterateItemContext from '../IterateItemContext';
8
+ import ToolbarContext from '../Toolbar/ToolbarContext';
9
+ import FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext';
10
+ import PushContainerContext from '../PushContainer/PushContainerContext';
11
+ import { check } from '../../../../icons';
12
+ export default function DoneButton(props) {
13
+ const {
14
+ switchContainerMode,
15
+ containerMode,
16
+ arrayValue,
17
+ index
18
+ } = useContext(IterateItemContext) || {};
19
+ const {
20
+ hasError,
21
+ hasVisibleError,
22
+ setShowBoundaryErrors
23
+ } = useContext(FieldBoundaryContext) || {};
24
+ const {
25
+ commitHandleRef
26
+ } = useContext(PushContainerContext) || {};
27
+ useContext(FieldBoundaryContext) || {};
28
+ const {
29
+ setShowError
30
+ } = useContext(ToolbarContext) || {};
31
+ const {
32
+ doneButton
33
+ } = useTranslation().IterateEditContainer;
34
+ const valueBackupRef = useRef();
35
+ useEffect(() => {
36
+ if (containerMode === 'edit' && !valueBackupRef.current) {
37
+ valueBackupRef.current = arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue[index];
38
+ }
39
+ if (containerMode === 'view') {
40
+ valueBackupRef.current = null;
41
+ }
42
+ }, [arrayValue, containerMode, index]);
43
+ const doneHandler = useCallback(() => {
44
+ if (hasError) {
45
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
46
+ if (hasVisibleError) {
47
+ setShowError(true);
48
+ }
49
+ } else {
50
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
51
+ setShowError(false);
52
+ if (commitHandleRef) {
53
+ var _commitHandleRef$curr;
54
+ (_commitHandleRef$curr = commitHandleRef.current) === null || _commitHandleRef$curr === void 0 ? void 0 : _commitHandleRef$curr.call(commitHandleRef);
55
+ } else {
56
+ switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
57
+ }
58
+ }
59
+ }, [commitHandleRef, hasError, hasVisibleError, setShowBoundaryErrors, setShowError, switchContainerMode]);
60
+ return React.createElement(Button, _extends({
61
+ variant: "tertiary",
62
+ icon: check,
63
+ icon_position: "left",
64
+ on_click: doneHandler
65
+ }, props), doneButton);
66
+ }
67
+ //# sourceMappingURL=DoneButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DoneButton.js","names":["React","useCallback","useContext","useEffect","useRef","Button","useTranslation","IterateItemContext","ToolbarContext","FieldBoundaryContext","PushContainerContext","check","DoneButton","props","switchContainerMode","containerMode","arrayValue","index","hasError","hasVisibleError","setShowBoundaryErrors","commitHandleRef","setShowError","doneButton","IterateEditContainer","valueBackupRef","current","doneHandler","_commitHandleRef$curr","call","createElement","_extends","variant","icon","icon_position","on_click"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/DoneButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport PushContainerContext from '../PushContainer/PushContainerContext'\nimport { check } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\n\ntype Props = ButtonProps\n\nexport default function DoneButton(props: Props) {\n const { switchContainerMode, containerMode, arrayValue, index } =\n useContext(IterateItemContext) || {}\n const { hasError, hasVisibleError, setShowBoundaryErrors } =\n useContext(FieldBoundaryContext) || {}\n const { commitHandleRef } = useContext(PushContainerContext) || {}\n useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n\n const { doneButton } = useTranslation().IterateEditContainer\n const valueBackupRef = useRef<unknown>()\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const doneHandler = useCallback(() => {\n if (hasError) {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowBoundaryErrors?.(false)\n setShowError(false)\n if (commitHandleRef) {\n commitHandleRef.current?.()\n } else {\n switchContainerMode?.('view')\n }\n }\n }, [\n commitHandleRef,\n hasError,\n hasVisibleError,\n setShowBoundaryErrors,\n setShowError,\n switchContainerMode,\n ])\n\n return (\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n {...props}\n >\n {doneButton}\n </Button>\n )\n}\n"],"mappings":";;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,EAAEC,SAAS,EAAEC,MAAM,QAAQ,OAAO;AACzE,SAASC,MAAM,QAAQ,wBAAwB;AAC/C,OAAOC,cAAc,MAAM,4BAA4B;AACvD,OAAOC,kBAAkB,MAAM,uBAAuB;AACtD,OAAOC,cAAc,MAAM,2BAA2B;AACtD,OAAOC,oBAAoB,MAAM,sDAAsD;AACvF,OAAOC,oBAAoB,MAAM,uCAAuC;AACxE,SAASC,KAAK,QAAQ,mBAAmB;AAKzC,eAAe,SAASC,UAAUA,CAACC,KAAY,EAAE;EAC/C,MAAM;IAAEC,mBAAmB;IAAEC,aAAa;IAAEC,UAAU;IAAEC;EAAM,CAAC,GAC7Df,UAAU,CAACK,kBAAkB,CAAC,IAAI,CAAC,CAAC;EACtC,MAAM;IAAEW,QAAQ;IAAEC,eAAe;IAAEC;EAAsB,CAAC,GACxDlB,UAAU,CAACO,oBAAoB,CAAC,IAAI,CAAC,CAAC;EACxC,MAAM;IAAEY;EAAgB,CAAC,GAAGnB,UAAU,CAACQ,oBAAoB,CAAC,IAAI,CAAC,CAAC;EAClER,UAAU,CAACO,oBAAoB,CAAC,IAAI,CAAC,CAAC;EACtC,MAAM;IAAEa;EAAa,CAAC,GAAGpB,UAAU,CAACM,cAAc,CAAC,IAAI,CAAC,CAAC;EAEzD,MAAM;IAAEe;EAAW,CAAC,GAAGjB,cAAc,CAAC,CAAC,CAACkB,oBAAoB;EAC5D,MAAMC,cAAc,GAAGrB,MAAM,CAAU,CAAC;EAExCD,SAAS,CAAC,MAAM;IACd,IAAIY,aAAa,KAAK,MAAM,IAAI,CAACU,cAAc,CAACC,OAAO,EAAE;MACvDD,cAAc,CAACC,OAAO,GAAGV,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAGC,KAAK,CAAC;IAC9C;IACA,IAAIF,aAAa,KAAK,MAAM,EAAE;MAC5BU,cAAc,CAACC,OAAO,GAAG,IAAI;IAC/B;EACF,CAAC,EAAE,CAACV,UAAU,EAAED,aAAa,EAAEE,KAAK,CAAC,CAAC;EAEtC,MAAMU,WAAW,GAAG1B,WAAW,CAAC,MAAM;IACpC,IAAIiB,QAAQ,EAAE;MACZE,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,IAAI,CAAC;MAC7B,IAAID,eAAe,EAAE;QACnBG,YAAY,CAAC,IAAI,CAAC;MACpB;IACF,CAAC,MAAM;MACLF,qBAAqB,aAArBA,qBAAqB,uBAArBA,qBAAqB,CAAG,KAAK,CAAC;MAC9BE,YAAY,CAAC,KAAK,CAAC;MACnB,IAAID,eAAe,EAAE;QAAA,IAAAO,qBAAA;QACnB,CAAAA,qBAAA,GAAAP,eAAe,CAACK,OAAO,cAAAE,qBAAA,uBAAvBA,qBAAA,CAAAC,IAAA,CAAAR,eAA0B,CAAC;MAC7B,CAAC,MAAM;QACLP,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;MAC/B;IACF;EACF,CAAC,EAAE,CACDO,eAAe,EACfH,QAAQ,EACRC,eAAe,EACfC,qBAAqB,EACrBE,YAAY,EACZR,mBAAmB,CACpB,CAAC;EAEF,OACEd,KAAA,CAAA8B,aAAA,CAACzB,MAAM,EAAA0B,QAAA;IACLC,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAEtB,KAAM;IACZuB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAER;EAAY,GAClBd,KAAK,GAERU,UACK,CAAC;AAEb"}
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { Props as FlexContainerProps } from '../../../../components/flex/Container';
3
- import { ElementSectionProps } from '../AnimatedContainer/ElementBlock';
3
+ import { ArrayItemAreaProps } from '../Array/ArrayItemArea';
4
4
  export type Props = {
5
5
  /**
6
6
  * The title of the EditContainer.
@@ -18,10 +18,16 @@ export type Props = {
18
18
  * An alternative toolbar to be shown in the EditContainer.
19
19
  */
20
20
  toolbar?: React.ReactNode;
21
+ /**
22
+ * The variant of the toolbar.
23
+ */
24
+ toolbarVariant?: 'minimumOneItem';
21
25
  };
22
- export type AllProps = Props & FlexContainerProps & ElementSectionProps;
26
+ export type AllProps = Props & FlexContainerProps & ArrayItemAreaProps;
23
27
  declare function EditContainer(props: AllProps): import("react/jsx-runtime").JSX.Element;
24
28
  declare namespace EditContainer {
29
+ var DoneButton: typeof import("./DoneButton").default;
30
+ var CancelButton: typeof import("./CancelButton").default;
25
31
  var _supportsSpacingProps: boolean;
26
32
  }
27
33
  export default EditContainer;