@dnb/eufemia 10.47.0 → 10.49.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (591) hide show
  1. package/CHANGELOG.md +40 -0
  2. package/cjs/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  3. package/cjs/components/height-animation/HeightAnimationInstance.js +13 -6
  4. package/cjs/components/height-animation/HeightAnimationInstance.js.map +1 -1
  5. package/cjs/extensions/forms/DataContext/Context.d.ts +7 -4
  6. package/cjs/extensions/forms/DataContext/Context.js +1 -2
  7. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  8. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +7 -2
  9. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  10. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  11. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +25 -9
  12. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  13. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  14. package/cjs/extensions/forms/DataContext/Provider/Provider.js +28 -28
  15. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  16. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  17. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  18. package/cjs/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  19. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +32 -7
  20. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  21. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  22. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  23. package/cjs/extensions/forms/Form/Isolation/Isolation.js +7 -7
  24. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  25. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js +20 -1
  26. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  27. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  28. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  29. package/cjs/extensions/forms/Form/Section/Section.d.ts +7 -2
  30. package/cjs/extensions/forms/Form/Section/Section.js +3 -1
  31. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  32. package/cjs/extensions/forms/Form/Section/SectionDocs.js +6 -1
  33. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  34. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  35. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  36. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  37. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  38. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  39. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  40. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  41. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  42. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  43. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  44. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  45. package/cjs/extensions/forms/Iterate/Array/Array.js +75 -26
  46. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  47. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +15 -1
  48. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  49. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +20 -0
  50. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlock.js → Array/ArrayItemArea.js} +66 -49
  51. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  52. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  53. package/cjs/extensions/forms/Iterate/{AnimatedContainer/ElementBlockContext.js → Array/ArrayItemAreaContext.js} +3 -3
  54. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  55. package/cjs/extensions/forms/Iterate/Array/types.d.ts +8 -5
  56. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  57. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  58. package/cjs/extensions/forms/Iterate/EditContainer/{EditToolbarTools.js → CancelButton.js} +30 -56
  59. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  60. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  61. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js +74 -0
  62. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  63. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  64. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +33 -12
  65. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  66. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  67. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  68. package/cjs/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  69. package/cjs/extensions/forms/Iterate/EditContainer/index.js +19 -1
  70. package/cjs/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  71. package/cjs/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  72. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  73. package/cjs/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  74. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +38 -15
  75. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  76. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js +18 -2
  77. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  78. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +7 -2
  79. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -24
  80. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  81. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  82. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  83. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +12 -14
  84. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  85. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  86. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -6
  87. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  88. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  89. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js +12 -0
  90. package/cjs/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  91. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  92. package/cjs/extensions/forms/Iterate/ViewContainer/{ViewToolbarTools.js → EditButton.js} +8 -11
  93. package/cjs/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  94. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  95. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js +19 -0
  96. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  97. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  98. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +25 -10
  99. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  100. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  101. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  102. package/cjs/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  103. package/cjs/extensions/forms/Iterate/ViewContainer/index.js +19 -1
  104. package/cjs/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  105. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  106. package/cjs/extensions/forms/Iterate/hooks/index.js +21 -0
  107. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -0
  108. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  109. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +93 -0
  110. package/cjs/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  111. package/cjs/extensions/forms/Tools/Log.d.ts +6 -0
  112. package/cjs/extensions/forms/Tools/Log.js +29 -0
  113. package/cjs/extensions/forms/Tools/Log.js.map +1 -0
  114. package/cjs/extensions/forms/Tools/index.d.ts +1 -0
  115. package/cjs/extensions/forms/Tools/index.js +7 -0
  116. package/cjs/extensions/forms/Tools/index.js.map +1 -1
  117. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  118. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  119. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  120. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  121. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  122. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  123. package/cjs/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  124. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  125. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  126. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  127. package/cjs/extensions/forms/constants/countries.js +10 -26
  128. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  129. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  130. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -2
  131. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  132. package/cjs/extensions/forms/constants/locales/en-US.d.ts +2 -1
  133. package/cjs/extensions/forms/constants/locales/index.d.ts +4 -2
  134. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  135. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -2
  136. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  137. package/cjs/extensions/forms/hooks/DataValueDocs.js +6 -1
  138. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  139. package/cjs/extensions/forms/hooks/useExternalValue.js +8 -6
  140. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  141. package/cjs/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  142. package/cjs/extensions/forms/hooks/useFieldProps.js +48 -27
  143. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  144. package/cjs/extensions/forms/hooks/usePath.d.ts +1 -0
  145. package/cjs/extensions/forms/hooks/usePath.js +5 -1
  146. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  147. package/cjs/extensions/forms/style/dnb-forms.css +3 -0
  148. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  149. package/cjs/extensions/forms/types.d.ts +4 -0
  150. package/cjs/extensions/forms/types.js.map +1 -1
  151. package/cjs/shared/Eufemia.d.ts +1 -1
  152. package/cjs/shared/Eufemia.js +2 -2
  153. package/cjs/shared/Eufemia.js.map +1 -1
  154. package/cjs/style/core/scopes.scss +1 -1
  155. package/cjs/style/dnb-ui-basis.css +1 -1
  156. package/cjs/style/dnb-ui-basis.min.css +1 -1
  157. package/cjs/style/dnb-ui-body.css +1 -1
  158. package/cjs/style/dnb-ui-body.min.css +1 -1
  159. package/cjs/style/dnb-ui-components.css +3 -0
  160. package/cjs/style/dnb-ui-components.min.css +1 -1
  161. package/cjs/style/dnb-ui-core.css +1 -1
  162. package/cjs/style/dnb-ui-core.min.css +1 -1
  163. package/cjs/style/dnb-ui-extensions.css +3 -0
  164. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  165. package/cjs/style/dnb-ui-forms.css +3 -0
  166. package/cjs/style/dnb-ui-forms.min.css +1 -1
  167. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  168. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  169. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  170. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  171. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  172. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  173. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  174. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  175. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  176. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  177. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  178. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  179. package/cjs/style/themes/theme-ui/ui-theme-components.css +6 -0
  180. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  181. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  182. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  183. package/cjs/style/themes/theme-ui/ui-theme-forms.css +3 -0
  184. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  185. package/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  186. package/components/height-animation/HeightAnimationInstance.js +13 -6
  187. package/components/height-animation/HeightAnimationInstance.js.map +1 -1
  188. package/es/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  189. package/es/components/height-animation/HeightAnimationInstance.js +13 -6
  190. package/es/components/height-animation/HeightAnimationInstance.js.map +1 -1
  191. package/es/extensions/forms/DataContext/Context.d.ts +7 -4
  192. package/es/extensions/forms/DataContext/Context.js +1 -2
  193. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  194. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +7 -2
  195. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  196. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  197. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +26 -9
  198. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  199. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  200. package/es/extensions/forms/DataContext/Provider/Provider.js +28 -26
  201. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  202. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  203. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  204. package/es/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  205. package/es/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  206. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  207. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  208. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  209. package/es/extensions/forms/Form/Isolation/Isolation.js +7 -7
  210. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  211. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  212. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  213. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  214. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  215. package/es/extensions/forms/Form/Section/Section.d.ts +7 -2
  216. package/es/extensions/forms/Form/Section/Section.js +3 -1
  217. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  218. package/es/extensions/forms/Form/Section/SectionDocs.js +6 -1
  219. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  220. package/es/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  221. package/es/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  222. package/es/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  223. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  224. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  225. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  226. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  227. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  228. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  229. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  230. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  231. package/es/extensions/forms/Iterate/Array/Array.js +76 -28
  232. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  233. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +15 -1
  234. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  235. package/es/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +20 -0
  236. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  237. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  238. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  239. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  240. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  241. package/es/extensions/forms/Iterate/Array/types.d.ts +8 -5
  242. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  243. package/es/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  244. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +87 -0
  245. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  246. package/es/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  247. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js +66 -0
  248. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  249. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  250. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  251. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  252. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  253. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  254. package/es/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  255. package/es/extensions/forms/Iterate/EditContainer/index.js +2 -0
  256. package/es/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  257. package/es/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  258. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  259. package/es/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  260. package/es/extensions/forms/Iterate/PushButton/PushButton.js +39 -16
  261. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  262. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js +19 -3
  263. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  264. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +7 -2
  265. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +78 -23
  266. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  267. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  268. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  269. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +13 -15
  270. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  271. package/es/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  272. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +51 -7
  273. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  274. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  275. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  276. package/es/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  277. package/es/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  278. package/{extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → es/extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  279. package/es/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  280. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  281. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  282. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  283. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  284. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  285. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  286. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  287. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  288. package/es/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  289. package/es/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  290. package/es/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  291. package/es/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  292. package/es/extensions/forms/Iterate/hooks/index.js +3 -0
  293. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -0
  294. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  295. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +85 -0
  296. package/es/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  297. package/es/extensions/forms/Tools/Log.d.ts +6 -0
  298. package/es/extensions/forms/Tools/Log.js +22 -0
  299. package/es/extensions/forms/Tools/Log.js.map +1 -0
  300. package/es/extensions/forms/Tools/index.d.ts +1 -0
  301. package/es/extensions/forms/Tools/index.js +1 -0
  302. package/es/extensions/forms/Tools/index.js.map +1 -1
  303. package/es/extensions/forms/Wizard/Container/WizardContainer.js +17 -6
  304. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  305. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  306. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  307. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  308. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  309. package/es/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  310. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  311. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  312. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  313. package/es/extensions/forms/constants/countries.js +10 -26
  314. package/es/extensions/forms/constants/countries.js.map +1 -1
  315. package/es/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  316. package/es/extensions/forms/constants/locales/en-GB.js +3 -2
  317. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  318. package/es/extensions/forms/constants/locales/en-US.d.ts +2 -1
  319. package/es/extensions/forms/constants/locales/index.d.ts +4 -2
  320. package/es/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  321. package/es/extensions/forms/constants/locales/nb-NO.js +3 -2
  322. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  323. package/es/extensions/forms/hooks/DataValueDocs.js +6 -1
  324. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  325. package/es/extensions/forms/hooks/useExternalValue.js +8 -6
  326. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  327. package/es/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  328. package/es/extensions/forms/hooks/useFieldProps.js +48 -28
  329. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  330. package/es/extensions/forms/hooks/usePath.d.ts +1 -0
  331. package/es/extensions/forms/hooks/usePath.js +5 -1
  332. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  333. package/es/extensions/forms/style/dnb-forms.css +3 -0
  334. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  335. package/es/extensions/forms/types.d.ts +4 -0
  336. package/es/extensions/forms/types.js.map +1 -1
  337. package/es/shared/Eufemia.d.ts +1 -1
  338. package/es/shared/Eufemia.js +2 -2
  339. package/es/shared/Eufemia.js.map +1 -1
  340. package/es/style/core/scopes.scss +1 -1
  341. package/es/style/dnb-ui-basis.css +1 -1
  342. package/es/style/dnb-ui-basis.min.css +1 -1
  343. package/es/style/dnb-ui-body.css +1 -1
  344. package/es/style/dnb-ui-body.min.css +1 -1
  345. package/es/style/dnb-ui-components.css +3 -0
  346. package/es/style/dnb-ui-components.min.css +1 -1
  347. package/es/style/dnb-ui-core.css +1 -1
  348. package/es/style/dnb-ui-core.min.css +1 -1
  349. package/es/style/dnb-ui-extensions.css +3 -0
  350. package/es/style/dnb-ui-extensions.min.css +1 -1
  351. package/es/style/dnb-ui-forms.css +3 -0
  352. package/es/style/dnb-ui-forms.min.css +1 -1
  353. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  354. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  355. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  356. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  357. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  358. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  359. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  360. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  361. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  362. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  363. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  364. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  365. package/es/style/themes/theme-ui/ui-theme-components.css +6 -0
  366. package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  367. package/es/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  368. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  369. package/es/style/themes/theme-ui/ui-theme-forms.css +3 -0
  370. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  371. package/esm/dnb-ui-basis.min.mjs +1 -1
  372. package/esm/dnb-ui-components.min.mjs +1 -1
  373. package/esm/dnb-ui-elements.min.mjs +1 -1
  374. package/esm/dnb-ui-extensions.min.mjs +2 -2
  375. package/esm/dnb-ui-lib.min.mjs +1 -1
  376. package/extensions/forms/DataContext/Context.d.ts +7 -4
  377. package/extensions/forms/DataContext/Context.js +1 -2
  378. package/extensions/forms/DataContext/Context.js.map +1 -1
  379. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +7 -2
  380. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  381. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.d.ts +8 -3
  382. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +25 -9
  383. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  384. package/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  385. package/extensions/forms/DataContext/Provider/Provider.js +28 -26
  386. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  387. package/extensions/forms/Field/SelectCountry/SelectCountry.js +1 -1
  388. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  389. package/extensions/forms/FieldBlock/FieldBlock.d.ts +5 -2
  390. package/extensions/forms/FieldBlock/FieldBlock.js +30 -7
  391. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  392. package/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  393. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  394. package/extensions/forms/Form/Isolation/Isolation.js +7 -7
  395. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  396. package/extensions/forms/Form/Section/EditContainer/EditContainer.js +22 -2
  397. package/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -1
  398. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +17 -11
  399. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  400. package/extensions/forms/Form/Section/Section.d.ts +7 -2
  401. package/extensions/forms/Form/Section/Section.js +3 -1
  402. package/extensions/forms/Form/Section/Section.js.map +1 -1
  403. package/extensions/forms/Form/Section/SectionDocs.js +6 -1
  404. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  405. package/extensions/forms/Form/Section/containers/SectionContainer.d.ts +3 -1
  406. package/extensions/forms/Form/Section/containers/SectionContainer.js +22 -20
  407. package/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  408. package/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +2 -0
  409. package/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -1
  410. package/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +1 -0
  411. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js +4 -1
  412. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -1
  413. package/extensions/forms/Form/Section/style/dnb-form-section.css +3 -0
  414. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  415. package/extensions/forms/Form/Section/style/dnb-form-section.scss +4 -0
  416. package/extensions/forms/Iterate/Array/Array.js +77 -28
  417. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  418. package/extensions/forms/Iterate/Array/ArrayDocs.js +15 -1
  419. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  420. package/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +20 -0
  421. package/extensions/forms/Iterate/Array/ArrayItemArea.js +137 -0
  422. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -0
  423. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +6 -0
  424. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js +6 -0
  425. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -0
  426. package/extensions/forms/Iterate/Array/types.d.ts +8 -5
  427. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  428. package/extensions/forms/Iterate/EditContainer/CancelButton.d.ts +9 -0
  429. package/extensions/forms/Iterate/EditContainer/CancelButton.js +88 -0
  430. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -0
  431. package/extensions/forms/Iterate/EditContainer/DoneButton.d.ts +4 -0
  432. package/extensions/forms/Iterate/EditContainer/DoneButton.js +66 -0
  433. package/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -0
  434. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +8 -2
  435. package/extensions/forms/Iterate/EditContainer/EditContainer.js +32 -11
  436. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  437. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +5 -0
  438. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  439. package/extensions/forms/Iterate/EditContainer/index.d.ts +2 -0
  440. package/extensions/forms/Iterate/EditContainer/index.js +2 -0
  441. package/extensions/forms/Iterate/EditContainer/index.js.map +1 -1
  442. package/extensions/forms/Iterate/IterateItemContext.d.ts +7 -1
  443. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  444. package/extensions/forms/Iterate/PushButton/PushButton.d.ts +7 -2
  445. package/extensions/forms/Iterate/PushButton/PushButton.js +39 -16
  446. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  447. package/extensions/forms/Iterate/PushContainer/OpenButton.js +19 -3
  448. package/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  449. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +7 -2
  450. package/extensions/forms/Iterate/PushContainer/PushContainer.js +80 -26
  451. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  452. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +10 -0
  453. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  454. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +13 -15
  455. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  456. package/extensions/forms/Iterate/Toolbar/Toolbar.d.ts +10 -2
  457. package/extensions/forms/Iterate/Toolbar/Toolbar.js +52 -7
  458. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  459. package/extensions/forms/Iterate/Toolbar/ToolbarContext.d.ts +6 -0
  460. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js +4 -0
  461. package/extensions/forms/Iterate/Toolbar/ToolbarContext.js.map +1 -0
  462. package/extensions/forms/Iterate/ViewContainer/EditButton.d.ts +1 -0
  463. package/{es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js → extensions/forms/Iterate/ViewContainer/EditButton.js} +8 -11
  464. package/extensions/forms/Iterate/ViewContainer/EditButton.js.map +1 -0
  465. package/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +1 -0
  466. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js +12 -0
  467. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -0
  468. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +8 -2
  469. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +24 -9
  470. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  471. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  472. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  473. package/extensions/forms/Iterate/ViewContainer/index.d.ts +2 -0
  474. package/extensions/forms/Iterate/ViewContainer/index.js +2 -0
  475. package/extensions/forms/Iterate/ViewContainer/index.js.map +1 -1
  476. package/extensions/forms/Iterate/hooks/index.d.ts +2 -0
  477. package/extensions/forms/Iterate/hooks/index.js +3 -0
  478. package/extensions/forms/Iterate/hooks/index.js.map +1 -0
  479. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.d.ts +17 -0
  480. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js +87 -0
  481. package/extensions/forms/Iterate/hooks/useSwitchContainerMode.js.map +1 -0
  482. package/extensions/forms/Tools/Log.d.ts +6 -0
  483. package/extensions/forms/Tools/Log.js +22 -0
  484. package/extensions/forms/Tools/Log.js.map +1 -0
  485. package/extensions/forms/Tools/index.d.ts +1 -0
  486. package/extensions/forms/Tools/index.js +1 -0
  487. package/extensions/forms/Tools/index.js.map +1 -1
  488. package/extensions/forms/Wizard/Container/WizardContainer.js +18 -6
  489. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  490. package/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  491. package/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  492. package/extensions/forms/Wizard/Context/WizardContext.d.ts +3 -1
  493. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  494. package/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  495. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  496. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +0 -2
  497. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  498. package/extensions/forms/constants/countries.js +10 -26
  499. package/extensions/forms/constants/countries.js.map +1 -1
  500. package/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  501. package/extensions/forms/constants/locales/en-GB.js +3 -2
  502. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  503. package/extensions/forms/constants/locales/en-US.d.ts +2 -1
  504. package/extensions/forms/constants/locales/index.d.ts +4 -2
  505. package/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  506. package/extensions/forms/constants/locales/nb-NO.js +3 -2
  507. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  508. package/extensions/forms/hooks/DataValueDocs.js +6 -1
  509. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  510. package/extensions/forms/hooks/useExternalValue.js +8 -6
  511. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  512. package/extensions/forms/hooks/useFieldProps.d.ts +1 -0
  513. package/extensions/forms/hooks/useFieldProps.js +48 -27
  514. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  515. package/extensions/forms/hooks/usePath.d.ts +1 -0
  516. package/extensions/forms/hooks/usePath.js +5 -1
  517. package/extensions/forms/hooks/usePath.js.map +1 -1
  518. package/extensions/forms/style/dnb-forms.css +3 -0
  519. package/extensions/forms/style/dnb-forms.min.css +1 -1
  520. package/extensions/forms/types.d.ts +4 -0
  521. package/extensions/forms/types.js.map +1 -1
  522. package/package.json +1 -1
  523. package/shared/Eufemia.d.ts +1 -1
  524. package/shared/Eufemia.js +2 -2
  525. package/shared/Eufemia.js.map +1 -1
  526. package/style/core/scopes.scss +1 -1
  527. package/style/dnb-ui-basis.css +1 -1
  528. package/style/dnb-ui-basis.min.css +1 -1
  529. package/style/dnb-ui-body.css +1 -1
  530. package/style/dnb-ui-body.min.css +1 -1
  531. package/style/dnb-ui-components.css +3 -0
  532. package/style/dnb-ui-components.min.css +1 -1
  533. package/style/dnb-ui-core.css +1 -1
  534. package/style/dnb-ui-core.min.css +1 -1
  535. package/style/dnb-ui-extensions.css +3 -0
  536. package/style/dnb-ui-extensions.min.css +1 -1
  537. package/style/dnb-ui-forms.css +3 -0
  538. package/style/dnb-ui-forms.min.css +1 -1
  539. package/style/themes/theme-eiendom/eiendom-theme-components.css +6 -0
  540. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  541. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -0
  542. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  543. package/style/themes/theme-eiendom/eiendom-theme-forms.css +3 -0
  544. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  545. package/style/themes/theme-sbanken/sbanken-theme-components.css +6 -0
  546. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  547. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -0
  548. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  549. package/style/themes/theme-sbanken/sbanken-theme-forms.css +3 -0
  550. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  551. package/style/themes/theme-ui/ui-theme-components.css +6 -0
  552. package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  553. package/style/themes/theme-ui/ui-theme-extensions.css +3 -0
  554. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  555. package/style/themes/theme-ui/ui-theme-forms.css +3 -0
  556. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  557. package/umd/dnb-ui-basis.min.js +1 -1
  558. package/umd/dnb-ui-components.min.js +1 -1
  559. package/umd/dnb-ui-elements.min.js +1 -1
  560. package/umd/dnb-ui-extensions.min.js +3 -3
  561. package/umd/dnb-ui-lib.min.js +1 -1
  562. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +0 -20
  563. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  564. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  565. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  566. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  567. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  568. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  569. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  570. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +0 -20
  571. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  572. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  573. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  574. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  575. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  576. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  577. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -113
  578. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  579. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  580. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
  581. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.d.ts +0 -20
  582. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +0 -120
  583. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +0 -1
  584. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.d.ts +0 -6
  585. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js +0 -6
  586. package/extensions/forms/Iterate/AnimatedContainer/ElementBlockContext.js.map +0 -1
  587. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.d.ts +0 -6
  588. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +0 -114
  589. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +0 -1
  590. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.d.ts +0 -1
  591. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"IterateItemContext.js","names":["_react","_interopRequireDefault","require","obj","__esModule","default","IterateItemContext","React","createContext","undefined","_default","exports"],"sources":["../../../../../src/extensions/forms/Iterate/IterateItemContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../types'\nimport { ContainerMode } from './Array/types'\n\nexport interface IterateItemContextState {\n id?: string\n index?: number\n value?: unknown\n isNew?: boolean\n path?: Path\n arrayValue?: Array<unknown>\n containerMode?: ContainerMode\n containerRef?: React.RefObject<HTMLDivElement>\n elementRef?: React.RefObject<HTMLDivElement>\n switchContainerMode?: (mode: ContainerMode) => void\n handleChange?: (path: Path, value: unknown) => void\n handleRemove?: ({ keepItems }?: { keepItems?: boolean }) => void\n handlePush?: (value: unknown) => void\n restoreOriginalValue?: (value: unknown) => void\n fulfillRemove?: () => void\n}\n\nconst IterateItemContext = React.createContext<\n IterateItemContextState | undefined\n>(undefined)\n\nexport default IterateItemContext\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAyB,SAAAD,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAsBzB,MAAMG,kBAAkB,GAAGC,cAAK,CAACC,aAAa,CAE5CC,SAAS,CAAC;AAAA,IAAAC,QAAA,GAEGJ,kBAAkB;AAAAK,OAAA,CAAAN,OAAA,GAAAK,QAAA"}
1
+ {"version":3,"file":"IterateItemContext.js","names":["_react","_interopRequireDefault","require","obj","__esModule","default","IterateItemContext","React","createContext","undefined","_default","exports"],"sources":["../../../../../src/extensions/forms/Iterate/IterateItemContext.ts"],"sourcesContent":["import React from 'react'\nimport { Path } from '../types'\nimport { ContainerMode } from './Array/types'\n\nexport type ModeOptions = {\n omitFocusManagement?: boolean\n}\n\nexport interface IterateItemContextState {\n id?: string\n index?: number\n value?: unknown\n isNew?: boolean\n path?: Path\n arrayValue?: Array<unknown>\n containerMode?: ContainerMode\n previousContainerMode?: ContainerMode\n initialContainerMode?: ContainerMode\n containerRef?: React.RefObject<HTMLDivElement>\n elementRef?: React.RefObject<HTMLDivElement>\n modeOptions?: ModeOptions\n switchContainerMode?: (\n mode: ContainerMode,\n options?: ModeOptions\n ) => void\n handleChange?: (path: Path, value: unknown) => void\n handleRemove?: ({ keepItems }?: { keepItems?: boolean }) => void\n handlePush?: (value: unknown) => void\n restoreOriginalValue?: (value: unknown) => void\n fulfillRemove?: () => void\n}\n\nconst IterateItemContext = React.createContext<\n IterateItemContextState | undefined\n>(undefined)\n\nexport default IterateItemContext\n"],"mappings":";;;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAyB,SAAAD,uBAAAE,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAgCzB,MAAMG,kBAAkB,GAAGC,cAAK,CAACC,aAAa,CAE5CC,SAAS,CAAC;AAAA,IAAAC,QAAA,GAEGJ,kBAAkB;AAAAK,OAAA,CAAAN,OAAA,GAAAK,QAAA"}
@@ -1,7 +1,12 @@
1
1
  import { ButtonProps } from '../../../../components/Button';
2
- import { DataValueReadWriteComponentProps } from '../../types';
3
- export type Props = ButtonProps & DataValueReadWriteComponentProps<unknown[]> & {
2
+ import { Path } from '../../types';
3
+ export type Props = ButtonProps & {
4
+ path?: Path;
4
5
  pushValue: unknown | ((value: unknown) => void);
6
+ /**
7
+ * Used internally
8
+ */
9
+ value?: unknown;
5
10
  };
6
11
  declare function PushButton(props: Props): import("react/jsx-runtime").JSX.Element;
7
12
  declare namespace PushButton {
@@ -9,10 +9,13 @@ var _react = _interopRequireWildcard(require("react"));
9
9
  var _classnames = _interopRequireDefault(require("classnames"));
10
10
  var _components = require("../../../../components");
11
11
  var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
12
- var _hooks = require("../../hooks");
12
+ var _hooks = require("../hooks");
13
13
  var _types = require("../../types");
14
14
  var _icons = require("../../../../icons");
15
- const _excluded = ["pushValue", "className"];
15
+ var _Context = _interopRequireDefault(require("../../DataContext/Context"));
16
+ var _useDataValue = _interopRequireDefault(require("../../hooks/useDataValue"));
17
+ var _componentHelper = require("../../../../shared/component-helper");
18
+ const _excluded = ["pushValue", "className", "path", "text", "children"];
16
19
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
20
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
18
21
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -20,39 +23,59 @@ function _extends() { _extends = Object.assign ? Object.assign.bind() : function
20
23
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
21
24
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
22
25
  function PushButton(props) {
26
+ const {
27
+ handlePathChange
28
+ } = (0, _react.useContext)(_Context.default) || {};
23
29
  const iterateItemContext = (0, _react.useContext)(_IterateItemContext.default);
24
30
  const {
25
31
  handlePush
26
32
  } = iterateItemContext !== null && iterateItemContext !== void 0 ? iterateItemContext : {};
27
33
  const {
28
34
  pushValue,
29
- className
35
+ className,
36
+ path,
37
+ text,
38
+ children
30
39
  } = props,
31
40
  restProps = _objectWithoutProperties(props, _excluded);
32
41
  const buttonProps = (0, _types.omitDataValueReadWriteProps)(restProps);
33
- const {
34
- value,
35
- handleChange,
36
- children
37
- } = (0, _hooks.useFieldProps)(restProps);
38
- if (value !== undefined && !Array.isArray(value)) {
42
+ const arrayValue = (0, _useDataValue.default)().getValueByPath(path);
43
+ if (arrayValue !== undefined && !Array.isArray(arrayValue)) {
39
44
  throw new Error('PushButton received a non-array value');
40
45
  }
41
- const handleClick = (0, _react.useCallback)(() => {
42
- const newValue = typeof pushValue === 'function' ? pushValue(value) : pushValue;
46
+ const {
47
+ setLastItemContainerMode
48
+ } = (0, _hooks.useSwitchContainerMode)({
49
+ path
50
+ });
51
+ const handleClick = (0, _react.useCallback)(async () => {
52
+ const newValue = typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue;
43
53
  if (handlePush) {
44
54
  handlePush(newValue);
45
- return;
55
+ } else {
56
+ await (handlePathChange === null || handlePathChange === void 0 ? void 0 : handlePathChange(path, [...(arrayValue !== null && arrayValue !== void 0 ? arrayValue : []), newValue]));
57
+ }
58
+ setTimeout(() => {
59
+ setLastItemContainerMode('view');
60
+ }, 100);
61
+ }, [handlePathChange, handlePush, path, pushValue, setLastItemContainerMode, arrayValue]);
62
+ const content = (0, _react.useMemo)(() => {
63
+ if (children || text) {
64
+ const str = (0, _componentHelper.convertJsxToString)(children || text);
65
+ if (str.includes('{nextItemNo}')) {
66
+ const nextItemNo = ((arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue.length) || 0) + 1;
67
+ return str.replace('{nextItemNo}', String(nextItemNo));
68
+ }
46
69
  }
47
- handleChange([...(value !== null && value !== void 0 ? value : []), newValue]);
48
- }, [value, pushValue, handlePush, handleChange]);
70
+ return children || text;
71
+ }, [arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue.length, children, text]);
49
72
  return _react.default.createElement(_components.Button, _extends({
50
73
  className: (0, _classnames.default)('dnb-forms-iterate-push-button', className),
51
74
  variant: "secondary",
52
75
  icon: _icons.add,
53
76
  icon_position: "left",
54
77
  on_click: handleClick
55
- }, buttonProps), children);
78
+ }, buttonProps), content);
56
79
  }
57
80
  PushButton._supportsSpacingProps = true;
58
81
  var _default = PushButton;
@@ -1 +1 @@
1
- {"version":3,"file":"PushButton.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateItemContext","_hooks","_types","_icons","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","PushButton","props","iterateItemContext","useContext","IterateItemContext","handlePush","pushValue","className","restProps","buttonProps","omitDataValueReadWriteProps","value","handleChange","children","useFieldProps","undefined","Array","isArray","Error","handleClick","useCallback","newValue","createElement","Button","classnames","variant","icon","add","icon_position","on_click","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateItemContext from '../IterateItemContext'\nimport { useFieldProps } from '../../hooks'\nimport {\n DataValueReadWriteComponentProps,\n omitDataValueReadWriteProps,\n} from '../../types'\nimport { add } from '../../../../icons'\n\nexport type Props = ButtonProps &\n DataValueReadWriteComponentProps<unknown[]> & {\n pushValue: unknown | ((value: unknown) => void)\n }\n\nfunction PushButton(props: Props) {\n const iterateItemContext = useContext(IterateItemContext)\n const { handlePush } = iterateItemContext ?? {}\n\n const { pushValue, className, ...restProps } = props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const { value, handleChange, children } = useFieldProps(restProps)\n\n if (value !== undefined && !Array.isArray(value)) {\n throw new Error('PushButton received a non-array value')\n }\n\n const handleClick = useCallback(() => {\n const newValue =\n typeof pushValue === 'function' ? pushValue(value) : pushValue\n\n if (handlePush) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n return // stop here\n }\n\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n handleChange([...(value ?? []), newValue])\n }, [value, pushValue, handlePush, handleChange])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-push-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {children}\n </Button>\n )\n}\n\nPushButton._supportsSpacingProps = true\nexport default PushButton\n"],"mappings":"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"}
1
+ {"version":3,"file":"PushButton.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateItemContext","_hooks","_types","_icons","_Context","_useDataValue","_componentHelper","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","PushButton","props","handlePathChange","useContext","DataContext","iterateItemContext","IterateItemContext","handlePush","pushValue","className","path","text","children","restProps","buttonProps","omitDataValueReadWriteProps","arrayValue","useDataValue","getValueByPath","undefined","Array","isArray","Error","setLastItemContainerMode","useSwitchContainerMode","handleClick","useCallback","newValue","setTimeout","content","useMemo","str","convertJsxToString","includes","nextItemNo","replace","String","createElement","Button","classnames","variant","icon","add","icon_position","on_click","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/PushButton/PushButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateItemContext from '../IterateItemContext'\nimport { useSwitchContainerMode } from '../hooks'\nimport { omitDataValueReadWriteProps, Path } from '../../types'\nimport { add } from '../../../../icons'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\nexport type Props = ButtonProps & {\n path?: Path\n pushValue: unknown | ((value: unknown) => void)\n\n /**\n * Used internally\n */\n value?: unknown\n}\n\nfunction PushButton(props: Props) {\n const { handlePathChange } = useContext(DataContext) || {}\n const iterateItemContext = useContext(IterateItemContext)\n const { handlePush } = iterateItemContext ?? {}\n\n const { pushValue, className, path, text, children, ...restProps } =\n props\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const arrayValue = useDataValue().getValueByPath(path)\n\n if (arrayValue !== undefined && !Array.isArray(arrayValue)) {\n throw new Error('PushButton received a non-array value')\n }\n\n const { setLastItemContainerMode } = useSwitchContainerMode({\n path,\n })\n\n const handleClick = useCallback(async () => {\n const newValue =\n typeof pushValue === 'function' ? pushValue(arrayValue) : pushValue\n\n if (handlePush) {\n // Inside an Iterate element - make the change through the Iterate component\n handlePush(newValue)\n } else {\n // If not inside an iterate, it could still manipulate a source data set through useFieldProps\n await handlePathChange?.(path, [...(arrayValue ?? []), newValue])\n }\n\n setTimeout(() => {\n setLastItemContainerMode('view')\n }, 100) // UX improvement because of the \"openDelay\"\n }, [\n handlePathChange,\n handlePush,\n path,\n pushValue,\n setLastItemContainerMode,\n arrayValue,\n ])\n\n const content = useMemo(() => {\n if (children || text) {\n const str = convertJsxToString(children || text)\n\n if (str.includes('{nextItemNo}')) {\n const nextItemNo = (arrayValue?.length || 0) + 1\n return str.replace('{nextItemNo}', String(nextItemNo))\n }\n }\n\n return children || text\n }, [arrayValue?.length, children, text])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-push-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {content}\n </Button>\n )\n}\n\nPushButton._supportsSpacingProps = true\nexport default PushButton\n"],"mappings":"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"}
@@ -10,7 +10,9 @@ var _classnames = _interopRequireDefault(require("classnames"));
10
10
  var _Button = _interopRequireDefault(require("../../../../components/Button"));
11
11
  var _icons = require("../../../../icons");
12
12
  var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
13
- const _excluded = ["className", "children"];
13
+ var _PushContainerContext = _interopRequireDefault(require("./PushContainerContext"));
14
+ var _componentHelper = require("../../../../shared/component-helper");
15
+ const _excluded = ["className", "text", "children"];
14
16
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
17
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
16
18
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -20,22 +22,36 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
20
22
  function OpenButton(props) {
21
23
  const {
22
24
  className,
25
+ text,
23
26
  children
24
27
  } = props,
25
28
  restProps = _objectWithoutProperties(props, _excluded);
26
29
  const {
27
30
  switchContainerMode
28
31
  } = (0, _react.useContext)(_IterateItemContext.default) || {};
32
+ const {
33
+ entries
34
+ } = (0, _react.useContext)(_PushContainerContext.default) || {};
29
35
  const handleClick = (0, _react.useCallback)(() => {
30
36
  switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('edit');
31
37
  }, [switchContainerMode]);
38
+ const content = (0, _react.useMemo)(() => {
39
+ if (children || text) {
40
+ const str = (0, _componentHelper.convertJsxToString)(children || text);
41
+ if (str.includes('{nextItemNo}')) {
42
+ const nextItemNo = ((entries === null || entries === void 0 ? void 0 : entries.length) || 0) + 1;
43
+ return str.replace('{nextItemNo}', String(nextItemNo));
44
+ }
45
+ }
46
+ return children || text;
47
+ }, [entries === null || entries === void 0 ? void 0 : entries.length, children, text]);
32
48
  return _react.default.createElement(_Button.default, _extends({
33
49
  className: (0, _classnames.default)('dnb-forms-iterate-open-button', className),
34
50
  variant: "secondary",
35
51
  icon: _icons.add,
36
52
  icon_position: "left",
37
53
  on_click: handleClick
38
- }, restProps), children);
54
+ }, restProps), content);
39
55
  }
40
56
  var _default = OpenButton;
41
57
  exports.default = _default;
@@ -1 +1 @@
1
- {"version":3,"file":"OpenButton.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_Button","_icons","_IterateItemContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","OpenButton","props","className","children","restProps","switchContainerMode","useContext","IterateItemContext","handleClick","useCallback","createElement","classnames","variant","icon","add","icon_position","on_click","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/OpenButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport Button, { ButtonProps } from '../../../../components/Button'\nimport { add } from '../../../../icons'\nimport IterateItemContext from '../IterateItemContext'\n\ntype Props = ButtonProps\n\nfunction OpenButton(props: Props) {\n const { className, children, ...restProps } = props\n const { switchContainerMode } = useContext(IterateItemContext) || {}\n\n const handleClick = useCallback(() => {\n switchContainerMode?.('edit')\n }, [switchContainerMode])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-open-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...restProps}\n >\n {children}\n </Button>\n )\n}\n\nexport default OpenButton\n"],"mappings":"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"}
1
+ {"version":3,"file":"OpenButton.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_Button","_icons","_IterateItemContext","_PushContainerContext","_componentHelper","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","OpenButton","props","className","text","children","restProps","switchContainerMode","useContext","IterateItemContext","entries","PushContainerContext","handleClick","useCallback","content","useMemo","str","convertJsxToString","includes","nextItemNo","replace","String","createElement","classnames","variant","icon","add","icon_position","on_click","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/OpenButton.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport Button, { ButtonProps } from '../../../../components/Button'\nimport { add } from '../../../../icons'\nimport IterateItemContext from '../IterateItemContext'\nimport PushContainerContext from './PushContainerContext'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\ntype Props = ButtonProps\n\nfunction OpenButton(props: Props) {\n const { className, text, children, ...restProps } = props\n const { switchContainerMode } = useContext(IterateItemContext) || {}\n const { entries } = useContext(PushContainerContext) || {}\n\n const handleClick = useCallback(() => {\n switchContainerMode?.('edit')\n }, [switchContainerMode])\n\n const content = useMemo(() => {\n if (children || text) {\n const str = convertJsxToString(children || text)\n\n if (str.includes('{nextItemNo}')) {\n const nextItemNo = (entries?.length || 0) + 1\n return str.replace('{nextItemNo}', String(nextItemNo))\n }\n }\n\n return children || text\n }, [entries?.length, children, text])\n\n return (\n <Button\n className={classnames('dnb-forms-iterate-open-button', className)}\n variant=\"secondary\"\n icon={add}\n icon_position=\"left\"\n on_click={handleClick}\n {...restProps}\n >\n {content}\n </Button>\n )\n}\n\nexport default OpenButton\n"],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  import React from 'react';
2
2
  import { Path } from '../../types';
3
3
  import { SpacingProps } from '../../../../shared/types';
4
+ import { ArrayItemAreaProps } from '../Array/ArrayItemArea';
4
5
  export type Props = {
5
6
  /**
6
7
  * The path to the array to add the new item to.
@@ -22,13 +23,17 @@ export type Props = {
22
23
  /**
23
24
  * Prefilled data to add to the fields.
24
25
  */
25
- data?: Record<string, unknown>;
26
+ data?: unknown | Record<string, unknown>;
27
+ /**
28
+ * A custom toolbar to be shown below the container.
29
+ */
30
+ toolbar?: React.ReactNode;
26
31
  /**
27
32
  * The container contents.
28
33
  */
29
34
  children: React.ReactNode;
30
35
  };
31
- export type AllProps = Props & SpacingProps;
36
+ export type AllProps = Props & SpacingProps & ArrayItemAreaProps;
32
37
  declare function PushContainer(props: AllProps): import("react/jsx-runtime").JSX.Element;
33
38
  declare namespace PushContainer {
34
39
  var OpenButton: typeof import("./OpenButton").default;
@@ -9,26 +9,32 @@ var _react = _interopRequireWildcard(require("react"));
9
9
  var _Isolation = _interopRequireDefault(require("../../Form/Isolation"));
10
10
  var _PushContainerContext = _interopRequireDefault(require("./PushContainerContext"));
11
11
  var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
12
+ var _Context = _interopRequireDefault(require("../../DataContext/Context"));
12
13
  var _useDataValue = _interopRequireDefault(require("../../hooks/useDataValue"));
13
- var _EditContainer = _interopRequireDefault(require("../EditContainer"));
14
+ var _EditContainer = _interopRequireWildcard(require("../EditContainer"));
14
15
  var _Array = _interopRequireDefault(require("../Array"));
15
16
  var _OpenButton = _interopRequireDefault(require("./OpenButton"));
16
17
  var _components = require("../../../../components");
17
- const _excluded = ["data", "path", "title", "children", "openButton", "showOpenButtonWhen"];
18
+ var _hooks = require("../hooks");
19
+ var _Toolbar = _interopRequireDefault(require("../Toolbar"));
20
+ var _hooks2 = require("../../hooks");
21
+ var _CancelButton;
22
+ const _excluded = ["data", "path", "title", "children", "openButton", "showOpenButtonWhen"],
23
+ _excluded2 = ["title", "openButton", "showOpenButton", "switchContainerModeRef", "children"];
18
24
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
25
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
20
26
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
21
- function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
22
27
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
23
28
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
24
29
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
25
30
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
26
31
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
32
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
27
33
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
28
34
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
29
35
  function PushContainer(props) {
30
36
  const {
31
- data = {},
37
+ data = null,
32
38
  path,
33
39
  title,
34
40
  children,
@@ -44,6 +50,11 @@ function PushContainer(props) {
44
50
  } = (0, _useDataValue.default)({
45
51
  path
46
52
  });
53
+ const {
54
+ setNextContainerMode
55
+ } = (0, _hooks.useSwitchContainerMode)({
56
+ path
57
+ });
47
58
  const showOpenButton = showOpenButtonWhen === null || showOpenButtonWhen === void 0 ? void 0 : showOpenButtonWhen(entries);
48
59
  const newItemContextProps = {
49
60
  path,
@@ -51,42 +62,85 @@ function PushContainer(props) {
51
62
  commitHandleRef,
52
63
  switchContainerMode: switchContainerModeRef.current
53
64
  };
65
+ const defaultData = (0, _react.useMemo)(() => {
66
+ return {
67
+ newItems: [data]
68
+ };
69
+ }, [data]);
54
70
  return _react.default.createElement(_Isolation.default, {
71
+ defaultData: defaultData,
72
+ emptyData: defaultData,
55
73
  commitHandleRef: commitHandleRef,
56
74
  transformOnCommit: _ref => {
57
75
  let {
58
- newItem
76
+ newItems
59
77
  } = _ref;
60
- return moveValueToPath(path, [...entries, _objectSpread(_objectSpread({}, newItem[0]), {}, {
61
- __containerMode: 'view'
62
- })]);
78
+ return moveValueToPath(path, [...entries, ...newItems]);
63
79
  },
64
80
  onCommit: (data, _ref2) => {
65
81
  var _switchContainerModeR;
66
82
  let {
67
83
  clearData
68
84
  } = _ref2;
69
- clearData();
85
+ setNextContainerMode('view');
70
86
  (_switchContainerModeR = switchContainerModeRef.current) === null || _switchContainerModeR === void 0 ? void 0 : _switchContainerModeR.call(switchContainerModeRef, 'view');
87
+ clearData();
71
88
  }
72
89
  }, _react.default.createElement(_PushContainerContext.default.Provider, {
73
90
  value: newItemContextProps
74
91
  }, _react.default.createElement(_Array.default, {
75
- value: [data],
76
- path: "/newItem"
77
- }, _react.default.createElement(_IterateItemContext.default.Consumer, null, _ref3 => {
78
- let {
79
- containerMode,
80
- switchContainerMode
81
- } = _ref3;
82
- switchContainerModeRef.current = switchContainerMode;
83
- return _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_EditContainer.default, _extends({
84
- open: !showOpenButton || containerMode === 'edit',
85
- title: title
86
- }, rest), children), openButton && typeof showOpenButton === 'boolean' && _react.default.createElement(_components.HeightAnimation, {
87
- open: showOpenButton && containerMode === 'view'
88
- }, openButton));
89
- }))));
92
+ path: "/newItems",
93
+ containerMode: showOpenButton ? 'view' : 'edit'
94
+ }, _react.default.createElement(NewContainer, _extends({
95
+ title: title,
96
+ openButton: openButton,
97
+ switchContainerModeRef: switchContainerModeRef,
98
+ showOpenButton: showOpenButton
99
+ }, rest), children))));
100
+ }
101
+ function NewContainer(_ref3) {
102
+ var _DoneButton;
103
+ let {
104
+ title,
105
+ openButton,
106
+ showOpenButton,
107
+ switchContainerModeRef,
108
+ children
109
+ } = _ref3,
110
+ rest = _objectWithoutProperties(_ref3, _excluded2);
111
+ const {
112
+ containerMode,
113
+ switchContainerMode
114
+ } = (0, _react.useContext)(_IterateItemContext.default) || {};
115
+ switchContainerModeRef.current = switchContainerMode;
116
+ const {
117
+ createButton
118
+ } = (0, _hooks2.useTranslation)().IteratePushContainer;
119
+ const {
120
+ clearData
121
+ } = (0, _react.useContext)(_Context.default) || {};
122
+ const restoreOriginalValue = (0, _react.useCallback)(() => {
123
+ clearData === null || clearData === void 0 ? void 0 : clearData();
124
+ }, [clearData]);
125
+ const toolbar = _react.default.createElement(_Toolbar.default, null, _react.default.createElement(_IterateItemContext.default.Consumer, null, context => {
126
+ const newItemContextProps = _objectSpread(_objectSpread({}, context), {}, {
127
+ restoreOriginalValue
128
+ });
129
+ return _react.default.createElement(_IterateItemContext.default.Provider, {
130
+ value: newItemContextProps
131
+ }, _react.default.createElement(_components.Flex.Horizontal, {
132
+ gap: "large"
133
+ }, _DoneButton || (_DoneButton = _react.default.createElement(_EditContainer.DoneButton, {
134
+ text: createButton
135
+ })), showOpenButton && (_CancelButton || (_CancelButton = _react.default.createElement(_EditContainer.CancelButton, null)))));
136
+ }));
137
+ return _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_EditContainer.default, _extends({
138
+ open: !showOpenButton || containerMode === 'edit',
139
+ title: title,
140
+ toolbar: toolbar
141
+ }, rest), children), openButton && typeof showOpenButton === 'boolean' && _react.default.createElement(_components.HeightAnimation, {
142
+ open: showOpenButton && containerMode === 'view'
143
+ }, openButton));
90
144
  }
91
145
  PushContainer.OpenButton = _OpenButton.default;
92
146
  PushContainer._supportsSpacingProps = true;
@@ -1 +1 @@
1
- {"version":3,"file":"PushContainer.js","names":["_react","_interopRequireWildcard","require","_Isolation","_interopRequireDefault","_PushContainerContext","_IterateItemContext","_useDataValue","_EditContainer","_Array","_OpenButton","_components","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","_objectSpread","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","PushContainer","props","data","path","title","children","openButton","showOpenButtonWhen","rest","commitHandleRef","useRef","switchContainerModeRef","entries","moveValueToPath","useDataValue","showOpenButton","newItemContextProps","switchContainerMode","current","createElement","transformOnCommit","_ref","newItem","__containerMode","onCommit","_ref2","_switchContainerModeR","clearData","Provider","Consumer","_ref3","containerMode","Fragment","open","HeightAnimation","OpenButton","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, { useRef } from 'react'\nimport Isolation from '../../Form/Isolation'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { HeightAnimation } from '../../../../components'\nimport { Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\n\nexport type Props = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields.\n */\n data?: Record<string, unknown>\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props & SpacingProps\n\nfunction PushContainer(props: AllProps) {\n const {\n data = {},\n path,\n title,\n children,\n openButton,\n showOpenButtonWhen,\n ...rest\n } = props\n\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const { value: entries = [], moveValueToPath } = useDataValue<\n Array<unknown>\n >({ path })\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n return (\n <Isolation\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ newItem }) => {\n return moveValueToPath(path, [\n ...entries,\n { ...newItem[0], __containerMode: 'view' },\n ])\n }}\n onCommit={(data, { clearData }) => {\n clearData()\n switchContainerModeRef.current?.('view')\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray value={[data]} path=\"/newItem\">\n <IterateItemContext.Consumer>\n {({ containerMode, switchContainerMode }) => {\n switchContainerModeRef.current = switchContainerMode\n\n return (\n <>\n <EditContainer\n open={!showOpenButton || containerMode === 'edit'}\n title={title}\n {...rest}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation\n open={showOpenButton && containerMode === 'view'}\n >\n {openButton}\n </HeightAnimation>\n )}\n </>\n )\n }}\n </IterateItemContext.Consumer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":"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"}
1
+ {"version":3,"file":"PushContainer.js","names":["_react","_interopRequireWildcard","require","_Isolation","_interopRequireDefault","_PushContainerContext","_IterateItemContext","_Context","_useDataValue","_EditContainer","_Array","_OpenButton","_components","_hooks","_Toolbar","_hooks2","_CancelButton","_excluded","_excluded2","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","TypeError","Number","_extends","assign","bind","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","PushContainer","props","data","path","title","children","openButton","showOpenButtonWhen","rest","commitHandleRef","useRef","switchContainerModeRef","entries","moveValueToPath","useDataValue","setNextContainerMode","useSwitchContainerMode","showOpenButton","newItemContextProps","switchContainerMode","current","defaultData","useMemo","newItems","createElement","emptyData","transformOnCommit","_ref","onCommit","_ref2","_switchContainerModeR","clearData","Provider","containerMode","NewContainer","_ref3","_DoneButton","useContext","IterateItemContext","createButton","useTranslation","IteratePushContainer","DataContext","restoreOriginalValue","useCallback","toolbar","Consumer","context","Flex","Horizontal","gap","DoneButton","text","CancelButton","Fragment","open","HeightAnimation","OpenButton","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo, useRef } from 'react'\nimport Isolation from '../../Form/Isolation'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer, { CancelButton, DoneButton } from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport { Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\nimport { useSwitchContainerMode } from '../hooks'\nimport Toolbar from '../Toolbar'\nimport { useTranslation } from '../../hooks'\nimport { ArrayItemAreaProps } from '../Array/ArrayItemArea'\n\nexport type Props = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields.\n */\n data?: unknown | Record<string, unknown>\n\n /**\n * A custom toolbar to be shown below the container.\n */\n toolbar?: React.ReactNode\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props & SpacingProps & ArrayItemAreaProps\n\nfunction PushContainer(props: AllProps) {\n const {\n data = null,\n path,\n title,\n children,\n openButton,\n showOpenButtonWhen,\n ...rest\n } = props\n\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const { value: entries = [], moveValueToPath } = useDataValue<\n Array<unknown>\n >({ path })\n\n const { setNextContainerMode } = useSwitchContainerMode({ path })\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n const defaultData = useMemo(() => {\n return { newItems: [data] }\n }, [data])\n\n return (\n <Isolation\n defaultData={defaultData}\n emptyData={defaultData}\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ newItems }) => {\n return moveValueToPath(path, [...entries, ...newItems])\n }}\n onCommit={(data, { clearData }) => {\n setNextContainerMode('view')\n switchContainerModeRef.current?.('view')\n clearData()\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray\n path=\"/newItems\"\n containerMode={showOpenButton ? 'view' : 'edit'}\n >\n <NewContainer\n title={title}\n openButton={openButton}\n switchContainerModeRef={switchContainerModeRef}\n showOpenButton={showOpenButton}\n {...rest}\n >\n {children}\n </NewContainer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nfunction NewContainer({\n title,\n openButton,\n showOpenButton,\n switchContainerModeRef,\n children,\n ...rest\n}) {\n const { containerMode, switchContainerMode } =\n useContext(IterateItemContext) || {}\n switchContainerModeRef.current = switchContainerMode\n const { createButton } = useTranslation().IteratePushContainer\n const { clearData } = useContext(DataContext) || {}\n const restoreOriginalValue = useCallback(() => {\n clearData?.()\n }, [clearData])\n\n const toolbar = (\n <Toolbar>\n <IterateItemContext.Consumer>\n {(context) => {\n const newItemContextProps = {\n ...context,\n restoreOriginalValue,\n }\n return (\n <IterateItemContext.Provider value={newItemContextProps}>\n <Flex.Horizontal gap=\"large\">\n <DoneButton text={createButton} />\n {showOpenButton && <CancelButton />}\n </Flex.Horizontal>\n </IterateItemContext.Provider>\n )\n }}\n </IterateItemContext.Consumer>\n </Toolbar>\n )\n\n return (\n <>\n <EditContainer\n open={!showOpenButton || containerMode === 'edit'}\n title={title}\n toolbar={toolbar}\n {...rest}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation open={showOpenButton && containerMode === 'view'}>\n {openButton}\n </HeightAnimation>\n )}\n </>\n )\n}\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,UAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,qBAAA,GAAAD,sBAAA,CAAAF,OAAA;AACA,IAAAI,mBAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,QAAA,GAAAH,sBAAA,CAAAF,OAAA;AACA,IAAAM,aAAA,GAAAJ,sBAAA,CAAAF,OAAA;AACA,IAAAO,cAAA,GAAAR,uBAAA,CAAAC,OAAA;AACA,IAAAQ,MAAA,GAAAN,sBAAA,CAAAF,OAAA;AACA,IAAAS,WAAA,GAAAP,sBAAA,CAAAF,OAAA;AACA,IAAAU,WAAA,GAAAV,OAAA;AAGA,IAAAW,MAAA,GAAAX,OAAA;AACA,IAAAY,QAAA,GAAAV,sBAAA,CAAAF,OAAA;AACA,IAAAa,OAAA,GAAAb,OAAA;AAA4C,IAAAc,aAAA;AAAA,MAAAC,SAAA;EAAAC,UAAA;AAAA,SAAAd,uBAAAe,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAAA,SAAAG,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,CAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAtB,wBAAAkB,GAAA,EAAAI,WAAA,SAAAA,WAAA,IAAAJ,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,oBAAAA,GAAA,wBAAAA,GAAA,4BAAAE,OAAA,EAAAF,GAAA,UAAAQ,KAAA,GAAAL,wBAAA,CAAAC,WAAA,OAAAI,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAT,GAAA,YAAAQ,KAAA,CAAAE,GAAA,CAAAV,GAAA,SAAAW,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAhB,GAAA,QAAAgB,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAnB,GAAA,EAAAgB,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAf,GAAA,EAAAgB,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAhB,GAAA,CAAAgB,GAAA,SAAAL,MAAA,CAAAT,OAAA,GAAAF,GAAA,MAAAQ,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAArB,GAAA,EAAAW,MAAA,YAAAA,MAAA;AAAA,SAAAW,QAAAC,MAAA,EAAAC,cAAA,QAAAC,IAAA,GAAAZ,MAAA,CAAAY,IAAA,CAAAF,MAAA,OAAAV,MAAA,CAAAa,qBAAA,QAAAC,OAAA,GAAAd,MAAA,CAAAa,qBAAA,CAAAH,MAAA,GAAAC,cAAA,KAAAG,OAAA,GAAAA,OAAA,CAAAC,MAAA,WAAAC,GAAA,WAAAhB,MAAA,CAAAE,wBAAA,CAAAQ,MAAA,EAAAM,GAAA,EAAAC,UAAA,OAAAL,IAAA,CAAAM,IAAA,CAAAC,KAAA,CAAAP,IAAA,EAAAE,OAAA,YAAAF,IAAA;AAAA,SAAAQ,cAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,WAAAF,SAAA,CAAAD,CAAA,IAAAC,SAAA,CAAAD,CAAA,QAAAA,CAAA,OAAAb,OAAA,CAAAT,MAAA,CAAAyB,MAAA,OAAAC,OAAA,WAAAvB,GAAA,IAAAwB,eAAA,CAAAN,MAAA,EAAAlB,GAAA,EAAAsB,MAAA,CAAAtB,GAAA,SAAAH,MAAA,CAAA4B,yBAAA,GAAA5B,MAAA,CAAA6B,gBAAA,CAAAR,MAAA,EAAArB,MAAA,CAAA4B,yBAAA,CAAAH,MAAA,KAAAhB,OAAA,CAAAT,MAAA,CAAAyB,MAAA,GAAAC,OAAA,WAAAvB,GAAA,IAAAH,MAAA,CAAAC,cAAA,CAAAoB,MAAA,EAAAlB,GAAA,EAAAH,MAAA,CAAAE,wBAAA,CAAAuB,MAAA,EAAAtB,GAAA,iBAAAkB,MAAA;AAAA,SAAAM,gBAAAxC,GAAA,EAAAgB,GAAA,EAAA2B,KAAA,IAAA3B,GAAA,GAAA4B,cAAA,CAAA5B,GAAA,OAAAA,GAAA,IAAAhB,GAAA,IAAAa,MAAA,CAAAC,cAAA,CAAAd,GAAA,EAAAgB,GAAA,IAAA2B,KAAA,EAAAA,KAAA,EAAAb,UAAA,QAAAe,YAAA,QAAAC,QAAA,oBAAA9C,GAAA,CAAAgB,GAAA,IAAA2B,KAAA,WAAA3C,GAAA;AAAA,SAAA4C,eAAAG,GAAA,QAAA/B,GAAA,GAAAgC,YAAA,CAAAD,GAAA,2BAAA/B,GAAA,gBAAAA,GAAA,GAAAiC,MAAA,CAAAjC,GAAA;AAAA,SAAAgC,aAAAE,KAAA,EAAAC,IAAA,eAAAD,KAAA,iBAAAA,KAAA,kBAAAA,KAAA,MAAAE,IAAA,GAAAF,KAAA,CAAAG,MAAA,CAAAC,WAAA,OAAAF,IAAA,KAAAG,SAAA,QAAAC,GAAA,GAAAJ,IAAA,CAAAjC,IAAA,CAAA+B,KAAA,EAAAC,IAAA,2BAAAK,GAAA,sBAAAA,GAAA,YAAAC,SAAA,4DAAAN,IAAA,gBAAAF,MAAA,GAAAS,MAAA,EAAAR,KAAA;AAAA,SAAAS,SAAA,IAAAA,QAAA,GAAA9C,MAAA,CAAA+C,MAAA,GAAA/C,MAAA,CAAA+C,MAAA,CAAAC,IAAA,eAAA3B,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,GAAAF,SAAA,CAAAD,CAAA,YAAAnB,GAAA,IAAAsB,MAAA,QAAAzB,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAmB,MAAA,EAAAtB,GAAA,KAAAkB,MAAA,CAAAlB,GAAA,IAAAsB,MAAA,CAAAtB,GAAA,gBAAAkB,MAAA,YAAAyB,QAAA,CAAA3B,KAAA,OAAAI,SAAA;AAAA,SAAA0B,yBAAAxB,MAAA,EAAAyB,QAAA,QAAAzB,MAAA,yBAAAJ,MAAA,GAAA8B,6BAAA,CAAA1B,MAAA,EAAAyB,QAAA,OAAA/C,GAAA,EAAAmB,CAAA,MAAAtB,MAAA,CAAAa,qBAAA,QAAAuC,gBAAA,GAAApD,MAAA,CAAAa,qBAAA,CAAAY,MAAA,QAAAH,CAAA,MAAAA,CAAA,GAAA8B,gBAAA,CAAA5B,MAAA,EAAAF,CAAA,MAAAnB,GAAA,GAAAiD,gBAAA,CAAA9B,CAAA,OAAA4B,QAAA,CAAAG,OAAA,CAAAlD,GAAA,uBAAAH,MAAA,CAAAI,SAAA,CAAAkD,oBAAA,CAAAhD,IAAA,CAAAmB,MAAA,EAAAtB,GAAA,aAAAkB,MAAA,CAAAlB,GAAA,IAAAsB,MAAA,CAAAtB,GAAA,cAAAkB,MAAA;AAAA,SAAA8B,8BAAA1B,MAAA,EAAAyB,QAAA,QAAAzB,MAAA,yBAAAJ,MAAA,WAAAkC,UAAA,GAAAvD,MAAA,CAAAY,IAAA,CAAAa,MAAA,OAAAtB,GAAA,EAAAmB,CAAA,OAAAA,CAAA,MAAAA,CAAA,GAAAiC,UAAA,CAAA/B,MAAA,EAAAF,CAAA,MAAAnB,GAAA,GAAAoD,UAAA,CAAAjC,CAAA,OAAA4B,QAAA,CAAAG,OAAA,CAAAlD,GAAA,kBAAAkB,MAAA,CAAAlB,GAAA,IAAAsB,MAAA,CAAAtB,GAAA,YAAAkB,MAAA;AA2C5C,SAASmC,aAAaA,CAACC,KAAe,EAAE;EACtC,MAAM;MACJC,IAAI,GAAG,IAAI;MACXC,IAAI;MACJC,KAAK;MACLC,QAAQ;MACRC,UAAU;MACVC;IAEF,CAAC,GAAGN,KAAK;IADJO,IAAI,GAAAf,wBAAA,CACLQ,KAAK,EAAAxE,SAAA;EAET,MAAMgF,eAAe,GAAG,IAAAC,aAAM,EAAa,CAAC;EAC5C,MAAMC,sBAAsB,GAAG,IAAAD,aAAM,EAAgC,CAAC;EACtE,MAAM;IAAEpC,KAAK,EAAEsC,OAAO,GAAG,EAAE;IAAEC;EAAgB,CAAC,GAAG,IAAAC,qBAAY,EAE3D;IAAEX;EAAK,CAAC,CAAC;EAEX,MAAM;IAAEY;EAAqB,CAAC,GAAG,IAAAC,6BAAsB,EAAC;IAAEb;EAAK,CAAC,CAAC;EAEjE,MAAMc,cAAc,GAAGV,kBAAkB,aAAlBA,kBAAkB,uBAAlBA,kBAAkB,CAAGK,OAAO,CAAC;EACpD,MAAMM,mBAAyC,GAAG;IAChDf,IAAI;IACJS,OAAO;IACPH,eAAe;IACfU,mBAAmB,EAAER,sBAAsB,CAACS;EAC9C,CAAC;EAED,MAAMC,WAAW,GAAG,IAAAC,cAAO,EAAC,MAAM;IAChC,OAAO;MAAEC,QAAQ,EAAE,CAACrB,IAAI;IAAE,CAAC;EAC7B,CAAC,EAAE,CAACA,IAAI,CAAC,CAAC;EAEV,OACE1F,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAAC7G,UAAA,CAAAkB,OAAS;IACRwF,WAAW,EAAEA,WAAY;IACzBI,SAAS,EAAEJ,WAAY;IACvBZ,eAAe,EAAEA,eAAgB;IACjCiB,iBAAiB,EAAEC,IAAA,IAAkB;MAAA,IAAjB;QAAEJ;MAAS,CAAC,GAAAI,IAAA;MAC9B,OAAOd,eAAe,CAACV,IAAI,EAAE,CAAC,GAAGS,OAAO,EAAE,GAAGW,QAAQ,CAAC,CAAC;IACzD,CAAE;IACFK,QAAQ,EAAEA,CAAC1B,IAAI,EAAA2B,KAAA,KAAoB;MAAA,IAAAC,qBAAA;MAAA,IAAlB;QAAEC;MAAU,CAAC,GAAAF,KAAA;MAC5Bd,oBAAoB,CAAC,MAAM,CAAC;MAC5B,CAAAe,qBAAA,GAAAnB,sBAAsB,CAACS,OAAO,cAAAU,qBAAA,uBAA9BA,qBAAA,CAAAhF,IAAA,CAAA6D,sBAAsB,EAAW,MAAM,CAAC;MACxCoB,SAAS,CAAC,CAAC;IACb;EAAE,GAEFvH,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAAC3G,qBAAA,CAAAgB,OAAoB,CAACmG,QAAQ;IAAC1D,KAAK,EAAE4C;EAAoB,GACxD1G,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAACtG,MAAA,CAAAW,OAAY;IACXsE,IAAI,EAAC,WAAW;IAChB8B,aAAa,EAAEhB,cAAc,GAAG,MAAM,GAAG;EAAO,GAEhDzG,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAACU,YAAY,EAAA5C,QAAA;IACXc,KAAK,EAAEA,KAAM;IACbE,UAAU,EAAEA,UAAW;IACvBK,sBAAsB,EAAEA,sBAAuB;IAC/CM,cAAc,EAAEA;EAAe,GAC3BT,IAAI,GAEPH,QACW,CACF,CACe,CACtB,CAAC;AAEhB;AAEA,SAAS6B,YAAYA,CAAAC,KAAA,EAOlB;EAAA,IAAAC,WAAA;EAAA,IAPmB;MACpBhC,KAAK;MACLE,UAAU;MACVW,cAAc;MACdN,sBAAsB;MACtBN;IAEF,CAAC,GAAA8B,KAAA;IADI3B,IAAI,GAAAf,wBAAA,CAAA0C,KAAA,EAAAzG,UAAA;EAEP,MAAM;IAAEuG,aAAa;IAAEd;EAAoB,CAAC,GAC1C,IAAAkB,iBAAU,EAACC,2BAAkB,CAAC,IAAI,CAAC,CAAC;EACtC3B,sBAAsB,CAACS,OAAO,GAAGD,mBAAmB;EACpD,MAAM;IAAEoB;EAAa,CAAC,GAAG,IAAAC,sBAAc,EAAC,CAAC,CAACC,oBAAoB;EAC9D,MAAM;IAAEV;EAAU,CAAC,GAAG,IAAAM,iBAAU,EAACK,gBAAW,CAAC,IAAI,CAAC,CAAC;EACnD,MAAMC,oBAAoB,GAAG,IAAAC,kBAAW,EAAC,MAAM;IAC7Cb,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAG,CAAC;EACf,CAAC,EAAE,CAACA,SAAS,CAAC,CAAC;EAEf,MAAMc,OAAO,GACXrI,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAAClG,QAAA,CAAAO,OAAO,QACNrB,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAAC1G,mBAAA,CAAAe,OAAkB,CAACiH,QAAQ,QACxBC,OAAO,IAAK;IACZ,MAAM7B,mBAAmB,GAAAtD,aAAA,CAAAA,aAAA,KACpBmF,OAAO;MACVJ;IAAoB,EACrB;IACD,OACEnI,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAAC1G,mBAAA,CAAAe,OAAkB,CAACmG,QAAQ;MAAC1D,KAAK,EAAE4C;IAAoB,GACtD1G,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAACpG,WAAA,CAAA4H,IAAI,CAACC,UAAU;MAACC,GAAG,EAAC;IAAO,GAAAd,WAAA,KAAAA,WAAA,GAC1B5H,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAACvG,cAAA,CAAAkI,UAAU;MAACC,IAAI,EAAEb;IAAa,CAAE,CAAC,GACjCtB,cAAc,KAAAzF,aAAA,KAAAA,aAAA,GAAIhB,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAACvG,cAAA,CAAAoI,YAAY,MAAE,CAAC,EACpB,CACU,CAAC;EAElC,CAC2B,CACtB,CACV;EAED,OACE7I,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAAAhH,MAAA,CAAAqB,OAAA,CAAAyH,QAAA,QACE9I,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAACvG,cAAA,CAAAY,OAAa,EAAAyD,QAAA;IACZiE,IAAI,EAAE,CAACtC,cAAc,IAAIgB,aAAa,KAAK,MAAO;IAClD7B,KAAK,EAAEA,KAAM;IACbyC,OAAO,EAAEA;EAAQ,GACbrC,IAAI,GAEPH,QACY,CAAC,EAEfC,UAAU,IAAI,OAAOW,cAAc,KAAK,SAAS,IAChDzG,MAAA,CAAAqB,OAAA,CAAA2F,aAAA,CAACpG,WAAA,CAAAoI,eAAe;IAACD,IAAI,EAAEtC,cAAc,IAAIgB,aAAa,KAAK;EAAO,GAC/D3B,UACc,CAEnB,CAAC;AAEP;AAEAN,aAAa,CAACyD,UAAU,GAAGA,mBAAU;AACrCzD,aAAa,CAAC0D,qBAAqB,GAAG,IAAI;AAAA,IAAAC,QAAA,GAE3B3D,aAAa;AAAA4D,OAAA,CAAA/H,OAAA,GAAA8H,QAAA"}
@@ -25,6 +25,16 @@ const PushContainerProperties = {
25
25
  type: 'function',
26
26
  status: 'optional'
27
27
  },
28
+ variant: {
29
+ doc: 'Defines the variant of the container. Can be `outline` or `basic`. Defaults to `outline`.',
30
+ type: 'string',
31
+ status: 'optional'
32
+ },
33
+ toolbar: {
34
+ doc: 'A custom toolbar to be shown below the container.',
35
+ type: 'React.Node',
36
+ status: 'optional'
37
+ },
28
38
  children: {
29
39
  doc: 'The container contents.',
30
40
  type: 'React.Node',
@@ -1 +1 @@
1
- {"version":3,"file":"PushContainerDocs.js","names":["PushContainerProperties","path","doc","type","status","title","openButton","showOpenButtonWhen","children","exports","PushContainerEvents"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainerDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const PushContainerProperties: PropertiesTableProps = {\n path: {\n doc: 'The path to the array to add the new item to.',\n type: 'string',\n status: 'required',\n },\n title: {\n doc: 'The title of the container.',\n type: 'React.Node',\n status: 'optional',\n },\n openButton: {\n doc: 'The button to open container.',\n type: 'React.Node',\n status: 'optional',\n },\n showOpenButtonWhen: {\n doc: 'Define when the \"open button\" should be shown. Should be a function that returns a boolean.',\n type: 'function',\n status: 'optional',\n },\n children: {\n doc: 'The container contents.',\n type: 'React.Node',\n status: 'required',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const PushContainerEvents: PropertiesTableProps = {}\n"],"mappings":";;;;;;AAEO,MAAMA,uBAA6C,GAAG;EAC3DC,IAAI,EAAE;IACJC,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,KAAK,EAAE;IACLH,GAAG,EAAE,6BAA6B;IAClCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDE,UAAU,EAAE;IACVJ,GAAG,EAAE,+BAA+B;IACpCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,6FAA6F;IAClGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,QAAQ,EAAE;IACRN,GAAG,EAAE,yBAAyB;IAC9BC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAAAK,OAAA,CAAAT,uBAAA,GAAAA,uBAAA;AAEM,MAAMU,mBAAyC,GAAG,CAAC,CAAC;AAAAD,OAAA,CAAAC,mBAAA,GAAAA,mBAAA"}
1
+ {"version":3,"file":"PushContainerDocs.js","names":["PushContainerProperties","path","doc","type","status","title","openButton","showOpenButtonWhen","variant","toolbar","children","exports","PushContainerEvents"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainerDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const PushContainerProperties: PropertiesTableProps = {\n path: {\n doc: 'The path to the array to add the new item to.',\n type: 'string',\n status: 'required',\n },\n title: {\n doc: 'The title of the container.',\n type: 'React.Node',\n status: 'optional',\n },\n openButton: {\n doc: 'The button to open container.',\n type: 'React.Node',\n status: 'optional',\n },\n showOpenButtonWhen: {\n doc: 'Define when the \"open button\" should be shown. Should be a function that returns a boolean.',\n type: 'function',\n status: 'optional',\n },\n variant: {\n doc: 'Defines the variant of the container. Can be `outline` or `basic`. Defaults to `outline`.',\n type: 'string',\n status: 'optional',\n },\n toolbar: {\n doc: 'A custom toolbar to be shown below the container.',\n type: 'React.Node',\n status: 'optional',\n },\n children: {\n doc: 'The container contents.',\n type: 'React.Node',\n status: 'required',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const PushContainerEvents: PropertiesTableProps = {}\n"],"mappings":";;;;;;AAEO,MAAMA,uBAA6C,GAAG;EAC3DC,IAAI,EAAE;IACJC,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,KAAK,EAAE;IACLH,GAAG,EAAE,6BAA6B;IAClCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDE,UAAU,EAAE;IACVJ,GAAG,EAAE,+BAA+B;IACpCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,6FAA6F;IAClGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,OAAO,EAAE;IACPN,GAAG,EAAE,2FAA2F;IAChGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,OAAO,EAAE;IACPP,GAAG,EAAE,mDAAmD;IACxDC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDM,QAAQ,EAAE;IACRR,GAAG,EAAE,yBAAyB;IAC9BC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAAAO,OAAA,CAAAX,uBAAA,GAAAA,uBAAA;AAEM,MAAMY,mBAAyC,GAAG,CAAC,CAAC;AAAAD,OAAA,CAAAC,mBAAA,GAAAA,mBAAA"}
@@ -10,10 +10,10 @@ var _classnames = _interopRequireDefault(require("classnames"));
10
10
  var _components = require("../../../../components");
11
11
  var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
12
12
  var _hooks = require("../../hooks");
13
- var _ElementBlockContext = _interopRequireDefault(require("../AnimatedContainer/ElementBlockContext"));
13
+ var _ArrayItemAreaContext = _interopRequireDefault(require("../Array/ArrayItemAreaContext"));
14
14
  var _types = require("../../types");
15
15
  var _icons = require("../../../../icons");
16
- const _excluded = ["className"];
16
+ const _excluded = ["text", "children", "className"];
17
17
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
18
18
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
19
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
@@ -24,32 +24,30 @@ function RemoveButton(props) {
24
24
  const iterateItemContext = (0, _react.useContext)(_IterateItemContext.default);
25
25
  const {
26
26
  handleRemove
27
- } = iterateItemContext !== null && iterateItemContext !== void 0 ? iterateItemContext : {};
27
+ } = iterateItemContext || {};
28
28
  if (!iterateItemContext) {
29
29
  throw new Error('RemoveButton must be inside an Iterate.Array');
30
30
  }
31
31
  const {
32
+ text,
33
+ children,
32
34
  className
33
35
  } = props,
34
36
  restProps = _objectWithoutProperties(props, _excluded);
35
- const {
36
- children,
37
- text
38
- } = (0, _hooks.useFieldProps)(restProps);
39
37
  const buttonProps = (0, _types.omitDataValueReadWriteProps)(restProps);
40
38
  const translation = (0, _hooks.useTranslation)().RemoveButton;
41
39
  const textContent = text || children || translation.text;
42
- const elementBlockContext = (0, _react.useContext)(_ElementBlockContext.default);
40
+ const elementBlockContext = (0, _react.useContext)(_ArrayItemAreaContext.default);
43
41
  const {
44
- handleRemoveBlock
45
- } = elementBlockContext !== null && elementBlockContext !== void 0 ? elementBlockContext : {};
42
+ handleRemoveItem
43
+ } = elementBlockContext || {};
46
44
  const handleClick = (0, _react.useCallback)(() => {
47
- if (handleRemoveBlock) {
48
- handleRemoveBlock();
45
+ if (handleRemoveItem) {
46
+ handleRemoveItem === null || handleRemoveItem === void 0 ? void 0 : handleRemoveItem();
49
47
  } else {
50
- handleRemove();
48
+ handleRemove === null || handleRemove === void 0 ? void 0 : handleRemove();
51
49
  }
52
- }, [handleRemove, handleRemoveBlock]);
50
+ }, [handleRemove, handleRemoveItem]);
53
51
  return _react.default.createElement(_components.Button, _extends({
54
52
  className: (0, _classnames.default)('dnb-forms-iterate-remove-element-button', className),
55
53
  variant: textContent ? 'tertiary' : 'secondary',