@dnb/eufemia 10.44.0 → 10.45.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 (536) hide show
  1. package/CHANGELOG.md +29 -0
  2. package/cjs/components/checkbox/style/dnb-checkbox.scss +1 -1
  3. package/cjs/components/radio/style/dnb-radio.scss +1 -1
  4. package/cjs/components/table/TableStickyHeader.js.map +1 -1
  5. package/cjs/components/upload/Upload.js +2 -1
  6. package/cjs/components/upload/Upload.js.map +1 -1
  7. package/cjs/components/upload/UploadDocs.d.ts +1 -0
  8. package/cjs/components/upload/UploadDocs.js +17 -4
  9. package/cjs/components/upload/UploadDocs.js.map +1 -1
  10. package/cjs/components/upload/UploadInfo.js +57 -5
  11. package/cjs/components/upload/UploadInfo.js.map +1 -1
  12. package/cjs/components/upload/UploadVerify.d.ts +4 -2
  13. package/cjs/components/upload/UploadVerify.js +32 -5
  14. package/cjs/components/upload/UploadVerify.js.map +1 -1
  15. package/cjs/components/upload/style/dnb-upload.css +15 -0
  16. package/cjs/components/upload/style/dnb-upload.min.css +1 -1
  17. package/cjs/components/upload/style/dnb-upload.scss +17 -0
  18. package/cjs/components/upload/types.d.ts +7 -1
  19. package/cjs/components/upload/types.js.map +1 -1
  20. package/cjs/extensions/forms/DataContext/Context.d.ts +8 -3
  21. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  22. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +8 -0
  23. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  24. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +8 -0
  25. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  26. package/cjs/extensions/forms/DataContext/Provider/Provider.js +22 -7
  27. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  28. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -1
  29. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +29 -24
  30. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  31. package/cjs/extensions/forms/Field/Name/Name.js +2 -2
  32. package/cjs/extensions/forms/Field/Name/Name.js.map +1 -1
  33. package/cjs/extensions/forms/Field/Selection/Selection.d.ts +3 -0
  34. package/cjs/extensions/forms/Field/Selection/Selection.js +28 -20
  35. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  36. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +3 -3
  37. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  38. package/cjs/extensions/forms/Form/Element/Element.js +11 -9
  39. package/cjs/extensions/forms/Form/Element/Element.js.map +1 -1
  40. package/cjs/extensions/forms/Form/Isolation/Isolation.js +25 -7
  41. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  42. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +13 -5
  43. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  44. package/cjs/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +10 -13
  45. package/cjs/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -1
  46. package/cjs/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js +3 -3
  47. package/cjs/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js.map +1 -1
  48. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +2 -2
  49. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  50. package/cjs/extensions/forms/Iterate/Array/Array.js +7 -5
  51. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  52. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -3
  53. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +25 -19
  54. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  55. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +10 -0
  56. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  57. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +44 -14
  58. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  59. package/cjs/extensions/forms/Iterate/{IterateElementContext.d.ts → IterateItemContext.d.ts} +3 -3
  60. package/cjs/extensions/forms/Iterate/{IterateElementContext.js → IterateItemContext.js} +3 -3
  61. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -0
  62. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +3 -3
  63. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  64. package/cjs/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  65. package/cjs/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  66. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.d.ts +4 -0
  67. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js +42 -0
  68. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -0
  69. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +37 -0
  70. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +95 -0
  71. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -0
  72. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +11 -0
  73. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.js +12 -0
  74. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -0
  75. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.d.ts +3 -0
  76. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +42 -0
  77. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -0
  78. package/cjs/extensions/forms/Iterate/PushContainer/index.d.ts +2 -0
  79. package/cjs/extensions/forms/Iterate/PushContainer/index.js +27 -0
  80. package/cjs/extensions/forms/Iterate/PushContainer/index.js.map +1 -0
  81. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -4
  82. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  83. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +4 -0
  84. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +13 -5
  85. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  86. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  87. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  88. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +3 -3
  89. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  90. package/cjs/extensions/forms/Iterate/hooks/useItem.d.ts +1 -0
  91. package/cjs/extensions/forms/Iterate/hooks/useItem.js +15 -0
  92. package/cjs/extensions/forms/Iterate/hooks/useItem.js.map +1 -0
  93. package/cjs/extensions/forms/Iterate/index.d.ts +3 -1
  94. package/cjs/extensions/forms/Iterate/index.js +17 -3
  95. package/cjs/extensions/forms/Iterate/index.js.map +1 -1
  96. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +19 -0
  97. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js +81 -0
  98. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -0
  99. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.d.ts +2 -0
  100. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +15 -0
  101. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -0
  102. package/cjs/extensions/forms/Value/ArraySelection/index.d.ts +2 -0
  103. package/cjs/extensions/forms/Value/ArraySelection/index.js +27 -0
  104. package/cjs/extensions/forms/Value/ArraySelection/index.js.map +1 -0
  105. package/cjs/extensions/forms/Value/Selection/Selection.d.ts +9 -0
  106. package/cjs/extensions/forms/Value/Selection/Selection.js +58 -0
  107. package/cjs/extensions/forms/Value/Selection/Selection.js.map +1 -0
  108. package/cjs/extensions/forms/Value/Selection/SelectionDocs.d.ts +2 -0
  109. package/cjs/extensions/forms/Value/Selection/SelectionDocs.js +15 -0
  110. package/cjs/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -0
  111. package/cjs/extensions/forms/Value/Selection/index.d.ts +2 -0
  112. package/cjs/extensions/forms/Value/Selection/index.js +27 -0
  113. package/cjs/extensions/forms/Value/Selection/index.js.map +1 -0
  114. package/cjs/extensions/forms/Value/ValueDocs.js +6 -1
  115. package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
  116. package/cjs/extensions/forms/Value/index.d.ts +2 -0
  117. package/cjs/extensions/forms/Value/index.js +14 -0
  118. package/cjs/extensions/forms/Value/index.js.map +1 -1
  119. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +3 -3
  120. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  121. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +27 -11
  122. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  123. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +1 -0
  124. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  125. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +3 -0
  126. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -0
  127. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  128. package/cjs/extensions/forms/constants/locales/en-US.d.ts +3 -0
  129. package/cjs/extensions/forms/constants/locales/index.d.ts +6 -0
  130. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +3 -0
  131. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -0
  132. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  133. package/cjs/extensions/forms/hooks/useDataValue.d.ts +1 -0
  134. package/cjs/extensions/forms/hooks/useDataValue.js +11 -4
  135. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  136. package/cjs/extensions/forms/hooks/useExternalValue.js +4 -4
  137. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  138. package/cjs/extensions/forms/hooks/useFieldProps.js +11 -9
  139. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  140. package/cjs/extensions/forms/hooks/usePath.js +3 -3
  141. package/cjs/extensions/forms/hooks/usePath.js.map +1 -1
  142. package/cjs/extensions/forms/hooks/useValueProps.js +4 -1
  143. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  144. package/cjs/extensions/forms/types.d.ts +4 -0
  145. package/cjs/extensions/forms/types.js.map +1 -1
  146. package/cjs/shared/Eufemia.d.ts +1 -1
  147. package/cjs/shared/Eufemia.js +2 -2
  148. package/cjs/shared/Eufemia.js.map +1 -1
  149. package/cjs/shared/locales/en-GB.d.ts +1 -0
  150. package/cjs/shared/locales/en-GB.js +1 -0
  151. package/cjs/shared/locales/en-GB.js.map +1 -1
  152. package/cjs/shared/locales/en-US.d.ts +1 -0
  153. package/cjs/shared/locales/index.d.ts +2 -0
  154. package/cjs/shared/locales/nb-NO.d.ts +1 -0
  155. package/cjs/shared/locales/nb-NO.js +2 -1
  156. package/cjs/shared/locales/nb-NO.js.map +1 -1
  157. package/cjs/shared/useTheme.d.ts +4 -10
  158. package/cjs/shared/useTheme.js +7 -5
  159. package/cjs/shared/useTheme.js.map +1 -1
  160. package/cjs/style/core/scopes.scss +1 -1
  161. package/cjs/style/dnb-ui-basis.css +1 -1
  162. package/cjs/style/dnb-ui-basis.min.css +1 -1
  163. package/cjs/style/dnb-ui-body.css +1 -1
  164. package/cjs/style/dnb-ui-body.min.css +1 -1
  165. package/cjs/style/dnb-ui-components.css +15 -0
  166. package/cjs/style/dnb-ui-components.min.css +1 -1
  167. package/cjs/style/dnb-ui-core.css +1 -1
  168. package/cjs/style/dnb-ui-core.min.css +1 -1
  169. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +15 -0
  170. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  171. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +15 -0
  172. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  173. package/cjs/style/themes/theme-ui/ui-theme-components.css +15 -0
  174. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  175. package/components/checkbox/style/dnb-checkbox.scss +1 -1
  176. package/components/radio/style/dnb-radio.scss +1 -1
  177. package/components/table/TableStickyHeader.js.map +1 -1
  178. package/components/upload/Upload.js +2 -1
  179. package/components/upload/Upload.js.map +1 -1
  180. package/components/upload/UploadDocs.d.ts +1 -0
  181. package/components/upload/UploadDocs.js +15 -3
  182. package/components/upload/UploadDocs.js.map +1 -1
  183. package/components/upload/UploadInfo.js +57 -5
  184. package/components/upload/UploadInfo.js.map +1 -1
  185. package/components/upload/UploadVerify.d.ts +4 -2
  186. package/components/upload/UploadVerify.js +30 -5
  187. package/components/upload/UploadVerify.js.map +1 -1
  188. package/components/upload/style/dnb-upload.css +15 -0
  189. package/components/upload/style/dnb-upload.min.css +1 -1
  190. package/components/upload/style/dnb-upload.scss +17 -0
  191. package/components/upload/types.d.ts +7 -1
  192. package/components/upload/types.js.map +1 -1
  193. package/es/components/checkbox/style/dnb-checkbox.scss +1 -1
  194. package/es/components/radio/style/dnb-radio.scss +1 -1
  195. package/es/components/table/TableStickyHeader.js.map +1 -1
  196. package/es/components/upload/Upload.js +2 -1
  197. package/es/components/upload/Upload.js.map +1 -1
  198. package/es/components/upload/UploadDocs.d.ts +1 -0
  199. package/es/components/upload/UploadDocs.js +15 -3
  200. package/es/components/upload/UploadDocs.js.map +1 -1
  201. package/es/components/upload/UploadInfo.js +57 -5
  202. package/es/components/upload/UploadInfo.js.map +1 -1
  203. package/es/components/upload/UploadVerify.d.ts +4 -2
  204. package/es/components/upload/UploadVerify.js +30 -5
  205. package/es/components/upload/UploadVerify.js.map +1 -1
  206. package/es/components/upload/style/dnb-upload.css +15 -0
  207. package/es/components/upload/style/dnb-upload.min.css +1 -1
  208. package/es/components/upload/style/dnb-upload.scss +17 -0
  209. package/es/components/upload/types.d.ts +7 -1
  210. package/es/components/upload/types.js.map +1 -1
  211. package/es/extensions/forms/DataContext/Context.d.ts +8 -3
  212. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  213. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +8 -0
  214. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  215. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +9 -1
  216. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  217. package/es/extensions/forms/DataContext/Provider/Provider.js +22 -7
  218. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  219. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -1
  220. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +28 -24
  221. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  222. package/es/extensions/forms/Field/Name/Name.js +2 -2
  223. package/es/extensions/forms/Field/Name/Name.js.map +1 -1
  224. package/es/extensions/forms/Field/Selection/Selection.d.ts +3 -0
  225. package/es/extensions/forms/Field/Selection/Selection.js +22 -16
  226. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  227. package/es/extensions/forms/FieldBlock/FieldBlock.js +3 -3
  228. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  229. package/es/extensions/forms/Form/Element/Element.js +9 -9
  230. package/es/extensions/forms/Form/Element/Element.js.map +1 -1
  231. package/es/extensions/forms/Form/Isolation/Isolation.js +26 -8
  232. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  233. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +13 -5
  234. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  235. package/es/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +10 -11
  236. package/es/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -1
  237. package/es/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js +3 -3
  238. package/es/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js.map +1 -1
  239. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +2 -2
  240. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  241. package/es/extensions/forms/Iterate/Array/Array.js +7 -5
  242. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  243. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -3
  244. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +26 -20
  245. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  246. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +10 -0
  247. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  248. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +44 -14
  249. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  250. package/{extensions/forms/Iterate/IterateElementContext.d.ts → es/extensions/forms/Iterate/IterateItemContext.d.ts} +3 -3
  251. package/es/extensions/forms/Iterate/IterateItemContext.js +4 -0
  252. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -0
  253. package/es/extensions/forms/Iterate/PushButton/PushButton.js +3 -3
  254. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  255. package/es/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  256. package/es/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  257. package/es/extensions/forms/Iterate/PushContainer/OpenButton.d.ts +4 -0
  258. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js +32 -0
  259. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -0
  260. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +37 -0
  261. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +80 -0
  262. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -0
  263. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +11 -0
  264. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.js +6 -0
  265. package/es/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -0
  266. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.d.ts +3 -0
  267. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +34 -0
  268. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -0
  269. package/es/extensions/forms/Iterate/PushContainer/index.d.ts +2 -0
  270. package/es/extensions/forms/Iterate/PushContainer/index.js +3 -0
  271. package/es/extensions/forms/Iterate/PushContainer/index.js.map +1 -0
  272. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -4
  273. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  274. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +4 -0
  275. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +15 -6
  276. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  277. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  278. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  279. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +3 -3
  280. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  281. package/es/extensions/forms/Iterate/hooks/useItem.d.ts +1 -0
  282. package/es/extensions/forms/Iterate/hooks/useItem.js +9 -0
  283. package/es/extensions/forms/Iterate/hooks/useItem.js.map +1 -0
  284. package/es/extensions/forms/Iterate/index.d.ts +3 -1
  285. package/es/extensions/forms/Iterate/index.js +3 -1
  286. package/es/extensions/forms/Iterate/index.js.map +1 -1
  287. package/es/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +19 -0
  288. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js +66 -0
  289. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -0
  290. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.d.ts +2 -0
  291. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +8 -0
  292. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -0
  293. package/es/extensions/forms/Value/ArraySelection/index.d.ts +2 -0
  294. package/es/extensions/forms/Value/ArraySelection/index.js +3 -0
  295. package/es/extensions/forms/Value/ArraySelection/index.js.map +1 -0
  296. package/es/extensions/forms/Value/Selection/Selection.d.ts +9 -0
  297. package/es/extensions/forms/Value/Selection/Selection.js +48 -0
  298. package/es/extensions/forms/Value/Selection/Selection.js.map +1 -0
  299. package/es/extensions/forms/Value/Selection/SelectionDocs.d.ts +2 -0
  300. package/es/extensions/forms/Value/Selection/SelectionDocs.js +8 -0
  301. package/es/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -0
  302. package/es/extensions/forms/Value/Selection/index.d.ts +2 -0
  303. package/es/extensions/forms/Value/Selection/index.js +3 -0
  304. package/es/extensions/forms/Value/Selection/index.js.map +1 -0
  305. package/es/extensions/forms/Value/ValueDocs.js +6 -1
  306. package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
  307. package/es/extensions/forms/Value/index.d.ts +2 -0
  308. package/es/extensions/forms/Value/index.js +2 -0
  309. package/es/extensions/forms/Value/index.js.map +1 -1
  310. package/es/extensions/forms/ValueBlock/ValueBlock.js +3 -3
  311. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  312. package/es/extensions/forms/Wizard/Container/WizardContainer.js +16 -1
  313. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  314. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +1 -0
  315. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  316. package/es/extensions/forms/constants/locales/en-GB.d.ts +3 -0
  317. package/es/extensions/forms/constants/locales/en-GB.js +3 -0
  318. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  319. package/es/extensions/forms/constants/locales/en-US.d.ts +3 -0
  320. package/es/extensions/forms/constants/locales/index.d.ts +6 -0
  321. package/es/extensions/forms/constants/locales/nb-NO.d.ts +3 -0
  322. package/es/extensions/forms/constants/locales/nb-NO.js +3 -0
  323. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  324. package/es/extensions/forms/hooks/useDataValue.d.ts +1 -0
  325. package/es/extensions/forms/hooks/useDataValue.js +11 -4
  326. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  327. package/es/extensions/forms/hooks/useExternalValue.js +4 -4
  328. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  329. package/es/extensions/forms/hooks/useFieldProps.js +11 -9
  330. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  331. package/es/extensions/forms/hooks/usePath.js +2 -2
  332. package/es/extensions/forms/hooks/usePath.js.map +1 -1
  333. package/es/extensions/forms/hooks/useValueProps.js +4 -1
  334. package/es/extensions/forms/hooks/useValueProps.js.map +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/shared/locales/en-GB.d.ts +1 -0
  341. package/es/shared/locales/en-GB.js +1 -0
  342. package/es/shared/locales/en-GB.js.map +1 -1
  343. package/es/shared/locales/en-US.d.ts +1 -0
  344. package/es/shared/locales/index.d.ts +2 -0
  345. package/es/shared/locales/nb-NO.d.ts +1 -0
  346. package/es/shared/locales/nb-NO.js +2 -1
  347. package/es/shared/locales/nb-NO.js.map +1 -1
  348. package/es/shared/useTheme.d.ts +4 -10
  349. package/es/shared/useTheme.js +7 -5
  350. package/es/shared/useTheme.js.map +1 -1
  351. package/es/style/core/scopes.scss +1 -1
  352. package/es/style/dnb-ui-basis.css +1 -1
  353. package/es/style/dnb-ui-basis.min.css +1 -1
  354. package/es/style/dnb-ui-body.css +1 -1
  355. package/es/style/dnb-ui-body.min.css +1 -1
  356. package/es/style/dnb-ui-components.css +15 -0
  357. package/es/style/dnb-ui-components.min.css +1 -1
  358. package/es/style/dnb-ui-core.css +1 -1
  359. package/es/style/dnb-ui-core.min.css +1 -1
  360. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +15 -0
  361. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  362. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +15 -0
  363. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  364. package/es/style/themes/theme-ui/ui-theme-components.css +15 -0
  365. package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  366. package/esm/dnb-ui-basis.min.mjs +1 -1
  367. package/esm/dnb-ui-components.min.mjs +1 -1
  368. package/esm/dnb-ui-elements.min.mjs +1 -1
  369. package/esm/dnb-ui-extensions.min.mjs +5 -5
  370. package/esm/dnb-ui-lib.min.mjs +1 -1
  371. package/extensions/forms/DataContext/Context.d.ts +8 -3
  372. package/extensions/forms/DataContext/Context.js.map +1 -1
  373. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +8 -0
  374. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  375. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +9 -1
  376. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  377. package/extensions/forms/DataContext/Provider/Provider.js +22 -7
  378. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  379. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -1
  380. package/extensions/forms/Field/ArraySelection/ArraySelection.js +28 -24
  381. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  382. package/extensions/forms/Field/Name/Name.js +2 -2
  383. package/extensions/forms/Field/Name/Name.js.map +1 -1
  384. package/extensions/forms/Field/Selection/Selection.d.ts +3 -0
  385. package/extensions/forms/Field/Selection/Selection.js +27 -20
  386. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  387. package/extensions/forms/FieldBlock/FieldBlock.js +3 -3
  388. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  389. package/extensions/forms/Form/Element/Element.js +9 -9
  390. package/extensions/forms/Form/Element/Element.js.map +1 -1
  391. package/extensions/forms/Form/Isolation/Isolation.js +26 -8
  392. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  393. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +13 -5
  394. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  395. package/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +10 -11
  396. package/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -1
  397. package/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js +3 -3
  398. package/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.js.map +1 -1
  399. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +2 -2
  400. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  401. package/extensions/forms/Iterate/Array/Array.js +7 -5
  402. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  403. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -3
  404. package/extensions/forms/Iterate/EditContainer/EditContainer.js +26 -20
  405. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  406. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +10 -0
  407. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  408. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +44 -14
  409. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  410. package/{es/extensions/forms/Iterate/IterateElementContext.d.ts → extensions/forms/Iterate/IterateItemContext.d.ts} +3 -3
  411. package/extensions/forms/Iterate/IterateItemContext.js +4 -0
  412. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -0
  413. package/extensions/forms/Iterate/PushButton/PushButton.js +3 -3
  414. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  415. package/extensions/forms/Iterate/PushButton/PushButtonDocs.js +5 -0
  416. package/extensions/forms/Iterate/PushButton/PushButtonDocs.js.map +1 -1
  417. package/extensions/forms/Iterate/PushContainer/OpenButton.d.ts +4 -0
  418. package/extensions/forms/Iterate/PushContainer/OpenButton.js +32 -0
  419. package/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -0
  420. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +37 -0
  421. package/extensions/forms/Iterate/PushContainer/PushContainer.js +83 -0
  422. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -0
  423. package/extensions/forms/Iterate/PushContainer/PushContainerContext.d.ts +11 -0
  424. package/extensions/forms/Iterate/PushContainer/PushContainerContext.js +6 -0
  425. package/extensions/forms/Iterate/PushContainer/PushContainerContext.js.map +1 -0
  426. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.d.ts +3 -0
  427. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +34 -0
  428. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -0
  429. package/extensions/forms/Iterate/PushContainer/index.d.ts +2 -0
  430. package/extensions/forms/Iterate/PushContainer/index.js +3 -0
  431. package/extensions/forms/Iterate/PushContainer/index.js.map +1 -0
  432. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -4
  433. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  434. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +4 -0
  435. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +15 -6
  436. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  437. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +5 -0
  438. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  439. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +3 -3
  440. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  441. package/extensions/forms/Iterate/hooks/useItem.d.ts +1 -0
  442. package/extensions/forms/Iterate/hooks/useItem.js +9 -0
  443. package/extensions/forms/Iterate/hooks/useItem.js.map +1 -0
  444. package/extensions/forms/Iterate/index.d.ts +3 -1
  445. package/extensions/forms/Iterate/index.js +3 -1
  446. package/extensions/forms/Iterate/index.js.map +1 -1
  447. package/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +19 -0
  448. package/extensions/forms/Value/ArraySelection/ArraySelection.js +70 -0
  449. package/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -0
  450. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.d.ts +2 -0
  451. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +8 -0
  452. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -0
  453. package/extensions/forms/Value/ArraySelection/index.d.ts +2 -0
  454. package/extensions/forms/Value/ArraySelection/index.js +3 -0
  455. package/extensions/forms/Value/ArraySelection/index.js.map +1 -0
  456. package/extensions/forms/Value/Selection/Selection.d.ts +9 -0
  457. package/extensions/forms/Value/Selection/Selection.js +48 -0
  458. package/extensions/forms/Value/Selection/Selection.js.map +1 -0
  459. package/extensions/forms/Value/Selection/SelectionDocs.d.ts +2 -0
  460. package/extensions/forms/Value/Selection/SelectionDocs.js +8 -0
  461. package/extensions/forms/Value/Selection/SelectionDocs.js.map +1 -0
  462. package/extensions/forms/Value/Selection/index.d.ts +2 -0
  463. package/extensions/forms/Value/Selection/index.js +3 -0
  464. package/extensions/forms/Value/Selection/index.js.map +1 -0
  465. package/extensions/forms/Value/ValueDocs.js +6 -1
  466. package/extensions/forms/Value/ValueDocs.js.map +1 -1
  467. package/extensions/forms/Value/index.d.ts +2 -0
  468. package/extensions/forms/Value/index.js +2 -0
  469. package/extensions/forms/Value/index.js.map +1 -1
  470. package/extensions/forms/ValueBlock/ValueBlock.js +3 -3
  471. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  472. package/extensions/forms/Wizard/Container/WizardContainer.js +27 -11
  473. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  474. package/extensions/forms/Wizard/Context/WizardContext.d.ts +1 -0
  475. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  476. package/extensions/forms/constants/locales/en-GB.d.ts +3 -0
  477. package/extensions/forms/constants/locales/en-GB.js +3 -0
  478. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  479. package/extensions/forms/constants/locales/en-US.d.ts +3 -0
  480. package/extensions/forms/constants/locales/index.d.ts +6 -0
  481. package/extensions/forms/constants/locales/nb-NO.d.ts +3 -0
  482. package/extensions/forms/constants/locales/nb-NO.js +3 -0
  483. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  484. package/extensions/forms/hooks/useDataValue.d.ts +1 -0
  485. package/extensions/forms/hooks/useDataValue.js +11 -4
  486. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  487. package/extensions/forms/hooks/useExternalValue.js +4 -4
  488. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  489. package/extensions/forms/hooks/useFieldProps.js +11 -9
  490. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  491. package/extensions/forms/hooks/usePath.js +2 -2
  492. package/extensions/forms/hooks/usePath.js.map +1 -1
  493. package/extensions/forms/hooks/useValueProps.js +4 -1
  494. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  495. package/extensions/forms/types.d.ts +4 -0
  496. package/extensions/forms/types.js.map +1 -1
  497. package/package.json +1 -1
  498. package/shared/Eufemia.d.ts +1 -1
  499. package/shared/Eufemia.js +2 -2
  500. package/shared/Eufemia.js.map +1 -1
  501. package/shared/locales/en-GB.d.ts +1 -0
  502. package/shared/locales/en-GB.js +1 -0
  503. package/shared/locales/en-GB.js.map +1 -1
  504. package/shared/locales/en-US.d.ts +1 -0
  505. package/shared/locales/index.d.ts +2 -0
  506. package/shared/locales/nb-NO.d.ts +1 -0
  507. package/shared/locales/nb-NO.js +2 -1
  508. package/shared/locales/nb-NO.js.map +1 -1
  509. package/shared/useTheme.d.ts +4 -10
  510. package/shared/useTheme.js +7 -5
  511. package/shared/useTheme.js.map +1 -1
  512. package/style/core/scopes.scss +1 -1
  513. package/style/dnb-ui-basis.css +1 -1
  514. package/style/dnb-ui-basis.min.css +1 -1
  515. package/style/dnb-ui-body.css +1 -1
  516. package/style/dnb-ui-body.min.css +1 -1
  517. package/style/dnb-ui-components.css +15 -0
  518. package/style/dnb-ui-components.min.css +1 -1
  519. package/style/dnb-ui-core.css +1 -1
  520. package/style/dnb-ui-core.min.css +1 -1
  521. package/style/themes/theme-eiendom/eiendom-theme-components.css +15 -0
  522. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  523. package/style/themes/theme-sbanken/sbanken-theme-components.css +15 -0
  524. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +1 -1
  525. package/style/themes/theme-ui/ui-theme-components.css +15 -0
  526. package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  527. package/umd/dnb-ui-basis.min.js +1 -1
  528. package/umd/dnb-ui-components.min.js +1 -1
  529. package/umd/dnb-ui-elements.min.js +1 -1
  530. package/umd/dnb-ui-extensions.min.js +5 -5
  531. package/umd/dnb-ui-lib.min.js +1 -1
  532. package/cjs/extensions/forms/Iterate/IterateElementContext.js.map +0 -1
  533. package/es/extensions/forms/Iterate/IterateElementContext.js +0 -4
  534. package/es/extensions/forms/Iterate/IterateElementContext.js.map +0 -1
  535. package/extensions/forms/Iterate/IterateElementContext.js +0 -4
  536. package/extensions/forms/Iterate/IterateElementContext.js.map +0 -1
@@ -8,6 +8,7 @@ exports.default = void 0;
8
8
  var _react = _interopRequireWildcard(require("react"));
9
9
  var _jsonPointer = _interopRequireDefault(require("json-pointer"));
10
10
  var _componentHelper = require("../../../../shared/component-helper");
11
+ var _useDataValue = _interopRequireDefault(require("../../hooks/useDataValue"));
11
12
  var _DataContext = require("../../DataContext");
12
13
  var _SectionContext = _interopRequireDefault(require("../Section/SectionContext"));
13
14
  var _IsolationCommitButton = _interopRequireDefault(require("./IsolationCommitButton"));
@@ -35,6 +36,7 @@ function IsolationProvider(props) {
35
36
  const [, forceUpdate] = (0, _react.useReducer)(() => ({}), {});
36
37
  const internalDataRef = (0, _react.useRef)();
37
38
  const localDataRef = (0, _react.useRef)({});
39
+ const dataContextRef = (0, _react.useRef)(null);
38
40
  const outerContext = (0, _react.useContext)(_DataContext.Context);
39
41
  const {
40
42
  path: pathSection
@@ -43,6 +45,9 @@ function IsolationProvider(props) {
43
45
  handlePathChange: handlePathChangeOuter,
44
46
  data: dataOuter
45
47
  } = outerContext || {};
48
+ const {
49
+ moveValueToPath
50
+ } = (0, _useDataValue.default)();
46
51
  const onPathChangeHandler = (0, _react.useCallback)(async (path, value) => {
47
52
  if (localDataRef.current === _Provider.clearedData) {
48
53
  localDataRef.current = {};
@@ -56,20 +61,32 @@ function IsolationProvider(props) {
56
61
  const removeSectionPath = (0, _react.useCallback)(data => {
57
62
  return pathSection && _jsonPointer.default.has(data, pathSection) ? _jsonPointer.default.get(data, pathSection) : data;
58
63
  }, [pathSection]);
64
+ const getMountedData = (0, _react.useCallback)(data => {
65
+ var _dataContextRef$curre;
66
+ const mounterData = {};
67
+ (_dataContextRef$curre = dataContextRef.current) === null || _dataContextRef$curre === void 0 ? void 0 : _dataContextRef$curre.mountedFieldPathsRef.current.forEach(path => {
68
+ if (_jsonPointer.default.has(data, path)) {
69
+ _jsonPointer.default.set(mounterData, path, _jsonPointer.default.get(data, path));
70
+ }
71
+ });
72
+ return mounterData;
73
+ }, []);
74
+ (0, _react.useEffect)(() => {
75
+ localDataRef.current = getMountedData(internalDataRef.current);
76
+ }, [getMountedData]);
59
77
  (0, _react.useMemo)(() => {
60
78
  if (localDataRef.current === _Provider.clearedData) {
61
79
  return;
62
80
  }
63
81
  let localData = data !== null && data !== void 0 ? data : defaultData;
64
82
  if (localData && pathSection && !_jsonPointer.default.has(localDataRef.current, pathSection)) {
65
- const obj = {};
66
- _jsonPointer.default.set(obj, pathSection, localData);
67
- localData = obj;
83
+ localData = moveValueToPath(pathSection, localData);
68
84
  }
69
- internalDataRef.current = (0, _componentHelper.extendDeep)({}, dataOuter, localData || {}, localDataRef.current);
70
- }, [data, defaultData, dataOuter, pathSection]);
71
- const onCommit = (0, _react.useCallback)(async (mountedData, additionalArgs) => {
85
+ internalDataRef.current = Object.assign({}, localData || dataOuter || {}, localDataRef.current);
86
+ }, [data, defaultData, pathSection, dataOuter, moveValueToPath]);
87
+ const onCommit = (0, _react.useCallback)(async (data, additionalArgs) => {
72
88
  var _props$path;
89
+ const mountedData = getMountedData(data);
73
90
  const path = (_props$path = props.path) !== null && _props$path !== void 0 ? _props$path : '/';
74
91
  const outerData = props.path && _jsonPointer.default.has(dataOuter, path) ? _jsonPointer.default.get(dataOuter, path) : dataOuter;
75
92
  localDataRef.current = mountedData;
@@ -79,7 +96,7 @@ function IsolationProvider(props) {
79
96
  }
80
97
  handlePathChangeOuter === null || handlePathChangeOuter === void 0 ? void 0 : handlePathChangeOuter(path, (0, _componentHelper.extendDeep)({}, outerData, isolatedData));
81
98
  return await (onCommitProp === null || onCommitProp === void 0 ? void 0 : onCommitProp(removeSectionPath(isolatedData), additionalArgs));
82
- }, [props.path, dataOuter, transformOnCommitProp, handlePathChangeOuter, onCommitProp, removeSectionPath]);
99
+ }, [getMountedData, props.path, dataOuter, transformOnCommitProp, handlePathChangeOuter, onCommitProp, removeSectionPath]);
83
100
  const onClear = (0, _react.useCallback)(() => {
84
101
  localDataRef.current = _Provider.clearedData;
85
102
  internalDataRef.current = _Provider.clearedData;
@@ -95,6 +112,7 @@ function IsolationProvider(props) {
95
112
  isolate: true
96
113
  });
97
114
  return _react.default.createElement(_DataContext.Provider, providerProps, _react.default.createElement(_DataContext.Context.Consumer, null, dataContext => {
115
+ dataContextRef.current = dataContext;
98
116
  if (commitHandleRef) {
99
117
  commitHandleRef.current = dataContext === null || dataContext === void 0 ? void 0 : dataContext.handleSubmit;
100
118
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Isolation.js","names":["_react","_interopRequireWildcard","require","_jsonPointer","_interopRequireDefault","_componentHelper","_DataContext","_SectionContext","_IsolationCommitButton","_Provider","_structuredClone","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","IsolationProvider","props","children","onPathChange","onCommit","onCommitProp","onClear","onClearProp","transformOnCommit","transformOnCommitProp","commitHandleRef","data","defaultData","forceUpdate","useReducer","internalDataRef","useRef","localDataRef","outerContext","useContext","Context","path","pathSection","SectionContext","handlePathChange","handlePathChangeOuter","dataOuter","onPathChangeHandler","useCallback","current","clearedData","pointer","replace","removeSectionPath","useMemo","localData","extendDeep","mountedData","additionalArgs","_props$path","outerData","isolatedData","structuredClone","providerProps","isolate","createElement","Provider","Consumer","dataContext","handleSubmit","CommitButton","IsolationCommitButton","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/Isolation.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer, { JsonObject } from 'json-pointer'\nimport { extendDeep } from '../../../../shared/component-helper'\nimport { Context, Provider } from '../../DataContext'\nimport SectionContext from '../Section/SectionContext'\nimport IsolationCommitButton from './IsolationCommitButton'\nimport {\n clearedData,\n type Props as ProviderProps,\n} from '../../DataContext/Provider'\nimport type { OnCommit, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type IsolationProviderProps<Data> = {\n /**\n * Form.Isolation: Will be called when the isolated context is committed.\n */\n onCommit?: OnCommit<Data>\n /**\n * Form.Isolation: Will be called when the form is cleared via Form.clearData\n */\n onClear?: () => void\n /**\n * Form.Isolation: A function that will be called when the isolated context is committed.\n * It will receive the data from the isolated context and the data from the outer context.\n * You can use this to transform the data before it is committed.\n */\n transformOnCommit?: (isolatedData: Data, handlerData: Data) => Data\n /**\n * Used internally by the Form.Isolation component\n */\n path?: Path\n /**\n * Used internally by the Form.Isolation component\n */\n isolate?: boolean\n}\n\nexport type IsolationProps<Data> = Omit<\n ProviderProps<Data>,\n | 'onSubmit'\n | 'onSubmitRequest'\n | 'onSubmitComplete'\n | 'minimumAsyncBehaviorTime'\n | 'asyncSubmitTimeout'\n | 'scrollTopOnSubmit'\n | 'sessionStorageId'\n | 'filterSubmitData'\n | 'globalStatusId'\n> & {\n /**\n * A ref (function) that you can call in order to commit the data programmatically to the outer context.\n */\n commitHandleRef?: React.MutableRefObject<() => void>\n}\n\nfunction IsolationProvider<Data extends JsonObject>(\n props: IsolationProps<Data>\n) {\n const {\n children,\n onPathChange,\n onCommit: onCommitProp,\n onClear: onClearProp,\n transformOnCommit: transformOnCommitProp,\n commitHandleRef,\n data,\n defaultData,\n } = props\n\n const [, forceUpdate] = useReducer(() => ({}), {})\n const internalDataRef = useRef<Data>()\n const localDataRef = useRef<Partial<Data>>({})\n const outerContext = useContext(Context)\n const { path: pathSection } = useContext(SectionContext) || {}\n const { handlePathChange: handlePathChangeOuter, data: dataOuter } =\n outerContext || {}\n\n const onPathChangeHandler = useCallback(\n async (path: Path, value: unknown) => {\n if (localDataRef.current === clearedData) {\n localDataRef.current = {}\n }\n\n pointer.set(localDataRef.current, path, value)\n\n if (pathSection) {\n path = path.replace(pathSection, '')\n }\n\n return await onPathChange?.(path, value)\n },\n [onPathChange, pathSection]\n )\n\n const removeSectionPath = useCallback(\n (data: Data) => {\n return pathSection && pointer.has(data, pathSection)\n ? pointer.get(data, pathSection)\n : data\n },\n [pathSection]\n )\n\n // Update the isolated data with the outside context data\n useMemo(() => {\n if (localDataRef.current === clearedData) {\n return // stop here\n }\n\n let localData = data ?? defaultData\n\n if (\n localData &&\n pathSection &&\n !pointer.has(localDataRef.current, pathSection)\n ) {\n const obj = {} as Data\n pointer.set(obj, pathSection, localData)\n localData = obj\n }\n\n internalDataRef.current = extendDeep(\n {},\n dataOuter,\n localData || {},\n localDataRef.current\n ) as Data\n }, [data, defaultData, dataOuter, pathSection])\n\n const onCommit: IsolationProps<Data>['onCommit'] = useCallback(\n async (mountedData: Data, additionalArgs) => {\n const path = props.path ?? '/'\n const outerData =\n props.path && pointer.has(dataOuter, path)\n ? pointer.get(dataOuter, path)\n : dataOuter\n\n localDataRef.current = mountedData\n let isolatedData = structuredClone(mountedData) as Data\n\n if (typeof transformOnCommitProp === 'function') {\n isolatedData = transformOnCommitProp(isolatedData, outerData)\n }\n\n // Commit the internal data to the nested context data\n handlePathChangeOuter?.(\n path,\n extendDeep({}, outerData, isolatedData)\n )\n\n return await onCommitProp?.(\n removeSectionPath(isolatedData),\n additionalArgs\n )\n },\n [\n props.path,\n dataOuter,\n transformOnCommitProp,\n handlePathChangeOuter,\n onCommitProp,\n removeSectionPath,\n ]\n )\n\n const onClear = useCallback(() => {\n localDataRef.current = clearedData\n internalDataRef.current = clearedData as Data\n forceUpdate()\n onClearProp?.()\n }, [onClearProp])\n\n const providerProps: IsolationProps<Data> = {\n ...props,\n data: internalDataRef.current,\n defaultData: undefined,\n onPathChange: onPathChangeHandler,\n onCommit,\n onClear,\n isolate: true,\n }\n\n return (\n <Provider {...providerProps}>\n <Context.Consumer>\n {(dataContext) => {\n if (commitHandleRef) {\n commitHandleRef.current = dataContext?.handleSubmit\n }\n\n return children\n }}\n </Context.Consumer>\n </Provider>\n )\n}\n\nIsolationProvider.CommitButton = IsolationCommitButton\nIsolationProvider._supportsSpacingProps = undefined\n\nexport default IsolationProvider\n"],"mappings":"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"}
1
+ {"version":3,"file":"Isolation.js","names":["_react","_interopRequireWildcard","require","_jsonPointer","_interopRequireDefault","_componentHelper","_useDataValue","_DataContext","_SectionContext","_IsolationCommitButton","_Provider","_structuredClone","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","IsolationProvider","props","children","onPathChange","onCommit","onCommitProp","onClear","onClearProp","transformOnCommit","transformOnCommitProp","commitHandleRef","data","defaultData","forceUpdate","useReducer","internalDataRef","useRef","localDataRef","dataContextRef","outerContext","useContext","Context","path","pathSection","SectionContext","handlePathChange","handlePathChangeOuter","dataOuter","moveValueToPath","useDataValue","onPathChangeHandler","useCallback","current","clearedData","pointer","replace","removeSectionPath","getMountedData","_dataContextRef$curre","mounterData","mountedFieldPathsRef","useEffect","useMemo","localData","assign","additionalArgs","_props$path","mountedData","outerData","isolatedData","structuredClone","extendDeep","providerProps","isolate","createElement","Provider","Consumer","dataContext","handleSubmit","CommitButton","IsolationCommitButton","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/Isolation.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer, { JsonObject } from 'json-pointer'\nimport { extendDeep } from '../../../../shared/component-helper'\nimport useDataValue from '../../hooks/useDataValue'\nimport { Context, ContextState, Provider } from '../../DataContext'\nimport SectionContext from '../Section/SectionContext'\nimport IsolationCommitButton from './IsolationCommitButton'\nimport {\n clearedData,\n type Props as ProviderProps,\n} from '../../DataContext/Provider'\nimport type { OnCommit, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type IsolationProviderProps<Data> = {\n /**\n * Form.Isolation: Will be called when the isolated context is committed.\n */\n onCommit?: OnCommit<Data>\n /**\n * Form.Isolation: Will be called when the form is cleared via Form.clearData\n */\n onClear?: () => void\n /**\n * Form.Isolation: A function that will be called when the isolated context is committed.\n * It will receive the data from the isolated context and the data from the outer context.\n * You can use this to transform the data before it is committed.\n */\n transformOnCommit?: (isolatedData: Data, handlerData: Data) => Data\n /**\n * Used internally by the Form.Isolation component\n */\n path?: Path\n /**\n * Used internally by the Form.Isolation component\n */\n isolate?: boolean\n}\n\nexport type IsolationProps<Data> = Omit<\n ProviderProps<Data>,\n | 'onSubmit'\n | 'onSubmitRequest'\n | 'onSubmitComplete'\n | 'minimumAsyncBehaviorTime'\n | 'asyncSubmitTimeout'\n | 'scrollTopOnSubmit'\n | 'sessionStorageId'\n | 'filterSubmitData'\n | 'globalStatusId'\n> & {\n /**\n * A ref (function) that you can call in order to commit the data programmatically to the outer context.\n */\n commitHandleRef?: React.MutableRefObject<() => void>\n}\n\nfunction IsolationProvider<Data extends JsonObject>(\n props: IsolationProps<Data>\n) {\n const {\n children,\n onPathChange,\n onCommit: onCommitProp,\n onClear: onClearProp,\n transformOnCommit: transformOnCommitProp,\n commitHandleRef,\n data,\n defaultData,\n } = props\n\n const [, forceUpdate] = useReducer(() => ({}), {})\n const internalDataRef = useRef<Data>()\n const localDataRef = useRef<Partial<Data>>({})\n const dataContextRef = useRef<ContextState>(null)\n const outerContext = useContext(Context)\n const { path: pathSection } = useContext(SectionContext) || {}\n const { handlePathChange: handlePathChangeOuter, data: dataOuter } =\n outerContext || {}\n const { moveValueToPath } = useDataValue()\n\n const onPathChangeHandler = useCallback(\n async (path: Path, value: unknown) => {\n if (localDataRef.current === clearedData) {\n localDataRef.current = {}\n }\n\n pointer.set(localDataRef.current, path, value)\n\n if (pathSection) {\n path = path.replace(pathSection, '')\n }\n\n return await onPathChange?.(path, value)\n },\n [onPathChange, pathSection]\n )\n\n const removeSectionPath = useCallback(\n (data: Data) => {\n return pathSection && pointer.has(data, pathSection)\n ? pointer.get(data, pathSection)\n : data\n },\n [pathSection]\n )\n\n const getMountedData = useCallback((data: Data) => {\n const mounterData = {} as Data\n dataContextRef.current?.mountedFieldPathsRef.current.forEach(\n (path) => {\n if (pointer.has(data, path)) {\n pointer.set(mounterData, path, pointer.get(data, path))\n }\n }\n )\n return mounterData\n }, [])\n\n useEffect(() => {\n localDataRef.current = getMountedData(internalDataRef.current)\n }, [getMountedData])\n\n // Update the isolated data with the outside context data\n useMemo(() => {\n if (localDataRef.current === clearedData) {\n return // stop here\n }\n\n let localData = data ?? defaultData\n\n if (\n localData &&\n pathSection &&\n !pointer.has(localDataRef.current, pathSection)\n ) {\n localData = moveValueToPath<Data>(pathSection, localData)\n }\n\n internalDataRef.current = Object.assign(\n {},\n localData || dataOuter || {},\n localDataRef.current\n )\n }, [data, defaultData, pathSection, dataOuter, moveValueToPath])\n\n const onCommit: IsolationProps<Data>['onCommit'] = useCallback(\n async (data: Data, additionalArgs) => {\n const mountedData = getMountedData(data)\n const path = props.path ?? '/'\n const outerData =\n props.path && pointer.has(dataOuter, path)\n ? pointer.get(dataOuter, path)\n : dataOuter\n\n localDataRef.current = mountedData\n let isolatedData = structuredClone(mountedData) as Data\n\n if (typeof transformOnCommitProp === 'function') {\n isolatedData = transformOnCommitProp(isolatedData, outerData)\n }\n\n // Commit the internal data to the nested context data\n handlePathChangeOuter?.(\n path,\n extendDeep({}, outerData, isolatedData)\n )\n\n return await onCommitProp?.(\n removeSectionPath(isolatedData),\n additionalArgs\n )\n },\n [\n getMountedData,\n props.path,\n dataOuter,\n transformOnCommitProp,\n handlePathChangeOuter,\n onCommitProp,\n removeSectionPath,\n ]\n )\n\n const onClear = useCallback(() => {\n localDataRef.current = clearedData\n internalDataRef.current = clearedData as Data\n forceUpdate()\n onClearProp?.()\n }, [onClearProp])\n\n const providerProps: IsolationProps<Data> = {\n ...props,\n data: internalDataRef.current,\n defaultData: undefined,\n onPathChange: onPathChangeHandler,\n onCommit,\n onClear,\n isolate: true,\n }\n\n return (\n <Provider {...providerProps}>\n <Context.Consumer>\n {(dataContext) => {\n dataContextRef.current = dataContext\n\n if (commitHandleRef) {\n commitHandleRef.current = dataContext?.handleSubmit\n }\n\n return children\n }}\n </Context.Consumer>\n </Provider>\n )\n}\n\nIsolationProvider.CommitButton = IsolationCommitButton\nIsolationProvider._supportsSpacingProps = undefined\n\nexport default IsolationProvider\n"],"mappings":"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"}
@@ -26,27 +26,35 @@ function EditToolbarTools() {
26
26
  } = (0, _react.useContext)(_SectionContainerContext.default) || {};
27
27
  const {
28
28
  hasVisibleError,
29
- hasSubmitError
29
+ hasSubmitError,
30
+ hasError,
31
+ setShowBoundaryErrors
30
32
  } = (0, _react.useContext)(_FieldBoundaryContext.default) || {};
31
33
  const translation = (0, _useTranslation.default)().SectionEditContainer;
32
34
  const [showError, setShowError] = (0, _react.useState)(false);
33
35
  const cancelHandler = (0, _react.useCallback)(() => {
34
36
  if (hasSubmitError) {
35
37
  setShowError(true);
38
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
36
39
  } else {
37
40
  setShowError(false);
41
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
38
42
  restoreOriginalData();
39
43
  switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
40
44
  }
41
- }, [hasSubmitError, restoreOriginalData, switchContainerMode]);
45
+ }, [hasSubmitError, restoreOriginalData, setShowBoundaryErrors, switchContainerMode]);
42
46
  const doneHandler = (0, _react.useCallback)(() => {
43
- if (hasVisibleError) {
44
- setShowError(true);
47
+ if (hasError) {
48
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(true);
49
+ if (hasVisibleError) {
50
+ setShowError(true);
51
+ }
45
52
  } else {
46
53
  setShowError(false);
54
+ setShowBoundaryErrors === null || setShowBoundaryErrors === void 0 ? void 0 : setShowBoundaryErrors(false);
47
55
  switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
48
56
  }
49
- }, [hasVisibleError, switchContainerMode]);
57
+ }, [hasVisibleError, hasError, setShowBoundaryErrors, switchContainerMode]);
50
58
  return _react.default.createElement(_react.default.Fragment, null, _react.default.createElement(_components.FormStatus, {
51
59
  show: showError && hasVisibleError,
52
60
  no_animation: false
@@ -1 +1 @@
1
- {"version":3,"file":"EditToolbarTools.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_SectionContainerContext","_FieldBoundaryContext","_icons","_useContainerDataStore","_useEditContainerToolbar","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EditToolbarTools","useEditContainerToolbar","restoreOriginalData","useContainerDataStore","switchContainerMode","useContext","SectionContainerContext","hasVisibleError","hasSubmitError","FieldBoundaryContext","translation","useTranslation","SectionEditContainer","showError","setShowError","useState","cancelHandler","useCallback","doneHandler","createElement","Fragment","FormStatus","show","no_animation","errorInSection","Flex","Horizontal","gap","Button","variant","icon","check","icon_position","on_click","doneButton","close","cancelButton"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext, useState } from 'react'\nimport { Button, Flex, FormStatus } from '../../../../../components'\nimport useTranslation from '../../../hooks/useTranslation'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { check, close } from '../../../../../icons'\nimport useContainerDataStore from './useContainerDataStore'\nimport useEditContainerToolbar from './useEditContainerToolbar'\n\nexport default function EditToolbarTools() {\n useEditContainerToolbar()\n const { restoreOriginalData } = useContainerDataStore()\n\n const { switchContainerMode } = useContext(SectionContainerContext) || {}\n const { hasVisibleError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().SectionEditContainer\n\n const [showError, setShowError] = useState(false)\n\n const cancelHandler = useCallback(() => {\n if (hasSubmitError) {\n setShowError(true)\n } else {\n setShowError(false)\n restoreOriginalData()\n switchContainerMode?.('view')\n }\n }, [hasSubmitError, restoreOriginalData, switchContainerMode])\n const doneHandler = useCallback(() => {\n if (hasVisibleError) {\n setShowError(true)\n } else {\n setShowError(false)\n switchContainerMode?.('view')\n }\n }, [hasVisibleError, switchContainerMode])\n\n return (\n <>\n <FormStatus show={showError && hasVisibleError} no_animation={false}>\n {translation.errorInSection}\n </FormStatus>\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n >\n {translation.doneButton}\n </Button>\n\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancelButton}\n </Button>\n </Flex.Horizontal>\n </>\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"EditToolbarTools.js","names":["_react","_interopRequireWildcard","require","_components","_useTranslation","_interopRequireDefault","_SectionContainerContext","_FieldBoundaryContext","_icons","_useContainerDataStore","_useEditContainerToolbar","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","EditToolbarTools","useEditContainerToolbar","restoreOriginalData","useContainerDataStore","switchContainerMode","useContext","SectionContainerContext","hasVisibleError","hasSubmitError","hasError","setShowBoundaryErrors","FieldBoundaryContext","translation","useTranslation","SectionEditContainer","showError","setShowError","useState","cancelHandler","useCallback","doneHandler","createElement","Fragment","FormStatus","show","no_animation","errorInSection","Flex","Horizontal","gap","Button","variant","icon","check","icon_position","on_click","doneButton","close","cancelButton"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext, useState } from 'react'\nimport { Button, Flex, FormStatus } from '../../../../../components'\nimport useTranslation from '../../../hooks/useTranslation'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { check, close } from '../../../../../icons'\nimport useContainerDataStore from './useContainerDataStore'\nimport useEditContainerToolbar from './useEditContainerToolbar'\n\nexport default function EditToolbarTools() {\n useEditContainerToolbar()\n const { restoreOriginalData } = useContainerDataStore()\n\n const { switchContainerMode } = useContext(SectionContainerContext) || {}\n const {\n hasVisibleError,\n hasSubmitError,\n hasError,\n setShowBoundaryErrors,\n } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().SectionEditContainer\n\n const [showError, setShowError] = useState(false)\n\n const cancelHandler = useCallback(() => {\n if (hasSubmitError) {\n setShowError(true)\n setShowBoundaryErrors?.(true)\n } else {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n restoreOriginalData()\n switchContainerMode?.('view')\n }\n }, [\n hasSubmitError,\n restoreOriginalData,\n setShowBoundaryErrors,\n switchContainerMode,\n ])\n const doneHandler = useCallback(() => {\n if (hasError) {\n setShowBoundaryErrors?.(true)\n if (hasVisibleError) {\n setShowError(true)\n }\n } else {\n setShowError(false)\n setShowBoundaryErrors?.(false)\n switchContainerMode?.('view')\n }\n }, [\n hasVisibleError,\n hasError,\n setShowBoundaryErrors,\n switchContainerMode,\n ])\n\n return (\n <>\n <FormStatus show={showError && hasVisibleError} no_animation={false}>\n {translation.errorInSection}\n </FormStatus>\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n >\n {translation.doneButton}\n </Button>\n\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancelButton}\n </Button>\n </Flex.Horizontal>\n </>\n )\n}\n"],"mappings":"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"}
@@ -8,27 +8,23 @@ exports.default = useContainerDataStore;
8
8
  var _react = require("react");
9
9
  var _componentHelper = require("../../../../../shared/component-helper");
10
10
  var _Context = _interopRequireDefault(require("../../../DataContext/Context"));
11
+ var _SectionContext = _interopRequireDefault(require("../SectionContext"));
11
12
  var _SectionContainerContext = _interopRequireDefault(require("../containers/SectionContainerContext"));
12
13
  var _useDataValue = _interopRequireDefault(require("../../../hooks/useDataValue"));
13
- var _hooks = require("../../../hooks");
14
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
- 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; }
16
- 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; }
17
- 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; }
18
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
19
- 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); }
20
15
  function useContainerDataStore() {
21
16
  const valueBackupRef = (0, _react.useRef)();
22
17
  const {
23
- makePath
24
- } = (0, _hooks.usePath)();
25
- const {
26
- getData
18
+ getData,
19
+ moveValueToPath
27
20
  } = (0, _useDataValue.default)();
28
21
  const {
29
22
  data: dataFromContext,
30
23
  setData
31
24
  } = (0, _react.useContext)(_Context.default);
25
+ const {
26
+ path
27
+ } = (0, _react.useContext)(_SectionContext.default) || {};
32
28
  const {
33
29
  containerMode
34
30
  } = (0, _react.useContext)(_SectionContainerContext.default) || {};
@@ -41,12 +37,13 @@ function useContainerDataStore() {
41
37
  if (containerMode === 'view') {
42
38
  valueBackupRef.current = null;
43
39
  }
44
- }, [containerMode, getData, makePath]);
40
+ }, [containerMode, getData]);
45
41
  const restoreOriginalData = (0, _react.useCallback)(() => {
46
42
  if (valueBackupRef.current) {
47
- setData === null || setData === void 0 ? void 0 : setData((0, _componentHelper.extendDeep)(_objectSpread({}, dataFromContext), valueBackupRef.current));
43
+ const data = (0, _componentHelper.extendDeep)({}, dataFromContext, moveValueToPath(path, valueBackupRef.current));
44
+ setData === null || setData === void 0 ? void 0 : setData(data);
48
45
  }
49
- }, [dataFromContext, setData]);
46
+ }, [dataFromContext, moveValueToPath, path, setData]);
50
47
  return {
51
48
  restoreOriginalData
52
49
  };
@@ -1 +1 @@
1
- {"version":3,"file":"useContainerDataStore.js","names":["_react","require","_componentHelper","_Context","_interopRequireDefault","_SectionContainerContext","_useDataValue","_hooks","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","useContainerDataStore","valueBackupRef","useRef","makePath","usePath","getData","useDataValue","data","dataFromContext","setData","useContext","DataContext","containerMode","SectionContainerContext","useEffect","current","includeCurrentPath","restoreOriginalData","useCallback","extendDeep"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/useContainerDataStore.ts"],"sourcesContent":["import { useCallback, useContext, useEffect, useRef } from 'react'\nimport { extendDeep } from '../../../../../shared/component-helper'\nimport DataContext from '../../../DataContext/Context'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport useDataValue from '../../../hooks/useDataValue'\nimport { usePath } from '../../../hooks'\n\nexport default function useContainerDataStore() {\n const valueBackupRef = useRef<unknown>()\n\n const { makePath } = usePath()\n const { getData } = useDataValue()\n const { data: dataFromContext, setData } = useContext(DataContext)\n // const { path } = useContext(SectionContext) || {}\n const { containerMode } = useContext(SectionContainerContext) || {}\n\n useEffect(() => {\n // console.log('path', path)\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = getData('/', {\n includeCurrentPath: true,\n })\n // console.log('dataFromContext', dataFromContext)\n // console.log('valueBackupRef.current', valueBackupRef.current)\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [containerMode, getData, makePath])\n\n const restoreOriginalData = useCallback(() => {\n if (valueBackupRef.current) {\n setData?.(extendDeep({ ...dataFromContext }, valueBackupRef.current))\n }\n }, [dataFromContext, setData])\n\n return {\n restoreOriginalData,\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"useContainerDataStore.js","names":["_react","require","_componentHelper","_Context","_interopRequireDefault","_SectionContext","_SectionContainerContext","_useDataValue","obj","__esModule","default","useContainerDataStore","valueBackupRef","useRef","getData","moveValueToPath","useDataValue","data","dataFromContext","setData","useContext","DataContext","path","SectionContext","containerMode","SectionContainerContext","useEffect","current","includeCurrentPath","restoreOriginalData","useCallback","extendDeep"],"sources":["../../../../../../../src/extensions/forms/Form/Section/EditContainer/useContainerDataStore.ts"],"sourcesContent":["import { useCallback, useContext, useEffect, useRef } from 'react'\nimport { extendDeep } from '../../../../../shared/component-helper'\nimport DataContext from '../../../DataContext/Context'\nimport SectionContext from '../SectionContext'\nimport SectionContainerContext from '../containers/SectionContainerContext'\nimport useDataValue from '../../../hooks/useDataValue'\n\nexport default function useContainerDataStore() {\n const valueBackupRef = useRef<unknown>()\n\n const { getData, moveValueToPath } = useDataValue()\n const { data: dataFromContext, setData } = useContext(DataContext)\n const { path } = useContext(SectionContext) || {}\n const { containerMode } = useContext(SectionContainerContext) || {}\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = getData('/', {\n includeCurrentPath: true,\n })\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [containerMode, getData])\n\n const restoreOriginalData = useCallback(() => {\n if (valueBackupRef.current) {\n const data = extendDeep(\n {},\n dataFromContext,\n moveValueToPath(path, valueBackupRef.current)\n )\n setData?.(data)\n }\n }, [dataFromContext, moveValueToPath, path, setData])\n\n return {\n restoreOriginalData,\n }\n}\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,OAAA;AACA,IAAAC,gBAAA,GAAAD,OAAA;AACA,IAAAE,QAAA,GAAAC,sBAAA,CAAAH,OAAA;AACA,IAAAI,eAAA,GAAAD,sBAAA,CAAAH,OAAA;AACA,IAAAK,wBAAA,GAAAF,sBAAA,CAAAH,OAAA;AACA,IAAAM,aAAA,GAAAH,sBAAA,CAAAH,OAAA;AAAsD,SAAAG,uBAAAI,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAEvC,SAASG,qBAAqBA,CAAA,EAAG;EAC9C,MAAMC,cAAc,GAAG,IAAAC,aAAM,EAAU,CAAC;EAExC,MAAM;IAAEC,OAAO;IAAEC;EAAgB,CAAC,GAAG,IAAAC,qBAAY,EAAC,CAAC;EACnD,MAAM;IAAEC,IAAI,EAAEC,eAAe;IAAEC;EAAQ,CAAC,GAAG,IAAAC,iBAAU,EAACC,gBAAW,CAAC;EAClE,MAAM;IAAEC;EAAK,CAAC,GAAG,IAAAF,iBAAU,EAACG,uBAAc,CAAC,IAAI,CAAC,CAAC;EACjD,MAAM;IAAEC;EAAc,CAAC,GAAG,IAAAJ,iBAAU,EAACK,gCAAuB,CAAC,IAAI,CAAC,CAAC;EAEnE,IAAAC,gBAAS,EAAC,MAAM;IACd,IAAIF,aAAa,KAAK,MAAM,IAAI,CAACZ,cAAc,CAACe,OAAO,EAAE;MACvDf,cAAc,CAACe,OAAO,GAAGb,OAAO,CAAC,GAAG,EAAE;QACpCc,kBAAkB,EAAE;MACtB,CAAC,CAAC;IACJ;IACA,IAAIJ,aAAa,KAAK,MAAM,EAAE;MAC5BZ,cAAc,CAACe,OAAO,GAAG,IAAI;IAC/B;EACF,CAAC,EAAE,CAACH,aAAa,EAAEV,OAAO,CAAC,CAAC;EAE5B,MAAMe,mBAAmB,GAAG,IAAAC,kBAAW,EAAC,MAAM;IAC5C,IAAIlB,cAAc,CAACe,OAAO,EAAE;MAC1B,MAAMV,IAAI,GAAG,IAAAc,2BAAU,EACrB,CAAC,CAAC,EACFb,eAAe,EACfH,eAAe,CAACO,IAAI,EAAEV,cAAc,CAACe,OAAO,CAC9C,CAAC;MACDR,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAGF,IAAI,CAAC;IACjB;EACF,CAAC,EAAE,CAACC,eAAe,EAAEH,eAAe,EAAEO,IAAI,EAAEH,OAAO,CAAC,CAAC;EAErD,OAAO;IACLU;EACF,CAAC;AACH"}
@@ -6,17 +6,17 @@ Object.defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports.default = void 0;
8
8
  var _react = _interopRequireWildcard(require("react"));
9
- var _IterateElementContext = _interopRequireDefault(require("../IterateElementContext"));
9
+ var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
10
10
  var _EditContainer = require("../EditContainer");
11
11
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
12
  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); }
13
13
  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; }
14
14
  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); }
15
15
  function AnimatedContainer(props) {
16
- const iterateElementContext = (0, _react.useContext)(_IterateElementContext.default);
16
+ const iterateItemContext = (0, _react.useContext)(_IterateItemContext.default);
17
17
  const {
18
18
  isNew
19
- } = iterateElementContext !== null && iterateElementContext !== void 0 ? iterateElementContext : {};
19
+ } = iterateItemContext !== null && iterateItemContext !== void 0 ? iterateItemContext : {};
20
20
  return _react.default.createElement(_EditContainer.EditContainerWithoutToolbar, _extends({
21
21
  open: !isNew ? true : undefined
22
22
  }, props));
@@ -1 +1 @@
1
- {"version":3,"file":"AnimatedContainer.js","names":["_react","_interopRequireWildcard","require","_IterateElementContext","_interopRequireDefault","_EditContainer","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","AnimatedContainer","props","iterateElementContext","useContext","IterateElementContext","isNew","createElement","EditContainerWithoutToolbar","open","undefined","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport IterateElementContext from '../IterateElementContext'\nimport { EditContainerWithoutToolbar, AllProps } from '../EditContainer'\n\nfunction AnimatedContainer(props: AllProps) {\n const iterateElementContext = useContext(IterateElementContext)\n const { isNew } = iterateElementContext ?? {}\n\n return (\n <EditContainerWithoutToolbar\n open={!isNew ? true : undefined}\n {...props}\n />\n )\n}\n\nAnimatedContainer._supportsSpacingProps = true\nexport default AnimatedContainer\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,sBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,cAAA,GAAAH,OAAA;AAAwE,SAAAE,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,SAAAT,wBAAAK,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,SAAA,IAAAA,QAAA,GAAAT,MAAA,CAAAU,MAAA,GAAAV,MAAA,CAAAU,MAAA,CAAAC,IAAA,eAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,GAAAF,SAAA,CAAAD,CAAA,YAAAV,GAAA,IAAAa,MAAA,QAAAhB,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAU,MAAA,EAAAb,GAAA,KAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,gBAAAS,MAAA,YAAAH,QAAA,CAAAQ,KAAA,OAAAH,SAAA;AAExE,SAASI,iBAAiBA,CAACC,KAAe,EAAE;EAC1C,MAAMC,qBAAqB,GAAG,IAAAC,iBAAU,EAACC,8BAAqB,CAAC;EAC/D,MAAM;IAAEC;EAAM,CAAC,GAAGH,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAE7C,OACEvC,MAAA,CAAAQ,OAAA,CAAAmC,aAAA,CAACtC,cAAA,CAAAuC,2BAA2B,EAAAhB,QAAA;IAC1BiB,IAAI,EAAE,CAACH,KAAK,GAAG,IAAI,GAAGI;EAAU,GAC5BR,KAAK,CACV,CAAC;AAEN;AAEAD,iBAAiB,CAACU,qBAAqB,GAAG,IAAI;AAAA,IAAAC,QAAA,GAC/BX,iBAAiB;AAAAY,OAAA,CAAAzC,OAAA,GAAAwC,QAAA"}
1
+ {"version":3,"file":"AnimatedContainer.js","names":["_react","_interopRequireWildcard","require","_IterateItemContext","_interopRequireDefault","_EditContainer","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","AnimatedContainer","props","iterateItemContext","useContext","IterateItemContext","isNew","createElement","EditContainerWithoutToolbar","open","undefined","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/AnimatedContainer.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport IterateItemContext from '../IterateItemContext'\nimport { EditContainerWithoutToolbar, AllProps } from '../EditContainer'\n\nfunction AnimatedContainer(props: AllProps) {\n const iterateItemContext = useContext(IterateItemContext)\n const { isNew } = iterateItemContext ?? {}\n\n return (\n <EditContainerWithoutToolbar\n open={!isNew ? true : undefined}\n {...props}\n />\n )\n}\n\nAnimatedContainer._supportsSpacingProps = true\nexport default AnimatedContainer\n"],"mappings":";;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,mBAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,cAAA,GAAAH,OAAA;AAAwE,SAAAE,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,SAAAT,wBAAAK,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,SAAA,IAAAA,QAAA,GAAAT,MAAA,CAAAU,MAAA,GAAAV,MAAA,CAAAU,MAAA,CAAAC,IAAA,eAAAC,MAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAC,SAAA,CAAAC,MAAA,EAAAF,CAAA,UAAAG,MAAA,GAAAF,SAAA,CAAAD,CAAA,YAAAV,GAAA,IAAAa,MAAA,QAAAhB,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAU,MAAA,EAAAb,GAAA,KAAAS,MAAA,CAAAT,GAAA,IAAAa,MAAA,CAAAb,GAAA,gBAAAS,MAAA,YAAAH,QAAA,CAAAQ,KAAA,OAAAH,SAAA;AAExE,SAASI,iBAAiBA,CAACC,KAAe,EAAE;EAC1C,MAAMC,kBAAkB,GAAG,IAAAC,iBAAU,EAACC,2BAAkB,CAAC;EACzD,MAAM;IAAEC;EAAM,CAAC,GAAGH,kBAAkB,aAAlBA,kBAAkB,cAAlBA,kBAAkB,GAAI,CAAC,CAAC;EAE1C,OACEvC,MAAA,CAAAQ,OAAA,CAAAmC,aAAA,CAACtC,cAAA,CAAAuC,2BAA2B,EAAAhB,QAAA;IAC1BiB,IAAI,EAAE,CAACH,KAAK,GAAG,IAAI,GAAGI;EAAU,GAC5BR,KAAK,CACV,CAAC;AAEN;AAEAD,iBAAiB,CAACU,qBAAqB,GAAG,IAAI;AAAA,IAAAC,QAAA,GAC/BX,iBAAiB;AAAAY,OAAA,CAAAzC,OAAA,GAAAwC,QAAA"}
@@ -8,7 +8,7 @@ exports.default = void 0;
8
8
  var _react = _interopRequireWildcard(require("react"));
9
9
  var _classnames = _interopRequireDefault(require("classnames"));
10
10
  var _components = require("../../../../components");
11
- var _IterateElementContext = _interopRequireDefault(require("../IterateElementContext"));
11
+ var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
12
12
  var _ElementBlockContext = _interopRequireDefault(require("./ElementBlockContext"));
13
13
  var _FieldBoundaryContext = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryContext"));
14
14
  const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "openDelay", "variant"];
@@ -21,7 +21,7 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
21
21
  function ElementBlock(props) {
22
22
  const [, forceUpdate] = (0, _react.useReducer)(() => ({}), {});
23
23
  const contextRef = (0, _react.useRef)();
24
- contextRef.current = (0, _react.useContext)(_IterateElementContext.default) || {};
24
+ contextRef.current = (0, _react.useContext)(_IterateItemContext.default) || {};
25
25
  const {
26
26
  hasError,
27
27
  hasSubmitError
@@ -1 +1 @@
1
- {"version":3,"file":"ElementBlock.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateElementContext","_ElementBlockContext","_FieldBoundaryContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","ElementBlock","props","forceUpdate","useReducer","contextRef","useRef","current","useContext","IterateElementContext","hasError","hasSubmitError","FieldBoundaryContext","containerMode","handleRemove","switchContainerMode","isNew","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","openRef","isRemoving","setOpenState","useCallback","useEffect","setTimeout","handleAnimationEnd","state","preventFocusOnErrorOpening","_contextRef$current","_contextRef$current$e","_contextRef$current$e2","_contextRef$current$e3","elementRef","focus","window","requestAnimationFrame","_document$activeEleme","document","activeElement","closest","_contextRef$current2","elements","containerRef","querySelectorAll","e","_contextRef$current3","_contextRef$current3$","fulfillRemove","handleRemoveBlock","keepItems","createElement","Provider","value","HeightAnimation","classnames","duration","keepInDOM","Flex","Stack","element","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/ElementBlock.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport ElementBlockContext from './ElementBlockContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from '../Array/types'\n\nexport type ElementSectionProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ElementSectionProps\n\nfunction ElementBlock(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const contextRef = useRef<\n IterateElementContextState & {\n hasError?: boolean\n hasSubmitError?: boolean\n }\n >()\n contextRef.current = useContext(IterateElementContext) || {}\n\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasSubmitError = hasSubmitError\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasSubmitError) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { handleRemove, switchContainerMode, containerMode, isNew } =\n contextRef.current\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n // - Keep the block open if we have an error\n if (contextRef.current.hasSubmitError) {\n switchContainerMode?.('edit')\n }\n\n const preventFocusOnErrorOpening = !contextRef.current.hasSubmitError\n if (preventFocusOnErrorOpening) {\n if (state === 'opened') {\n contextRef.current?.elementRef?.current?.focus?.()\n } else {\n // Wait until the element is removed, then check if we can set focus\n window.requestAnimationFrame(() => {\n // try to focus on the second last element\n try {\n if (\n // But not when we focus is already inside our element\n !document.activeElement?.closest(\n '.dnb-forms-iterate__element'\n )\n ) {\n const elements =\n contextRef.current?.containerRef.current.querySelectorAll<HTMLDivElement>(\n '.dnb-forms-iterate__element'\n )\n elements[elements.length - 1].focus()\n }\n } catch (e) {\n /**/\n }\n })\n }\n }\n\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n contextRef.current?.fulfillRemove?.()\n }\n\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, switchContainerMode]\n )\n const handleRemoveBlock = useCallback(() => {\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, setOpenState])\n\n return (\n <ElementBlockContext.Provider value={{ handleRemoveBlock }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n contextRef.current.hasSubmitError &&\n 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ElementBlockContext.Provider>\n )\n}\n\nElementBlock._supportsSpacingProps = true\nexport default ElementBlock\n"],"mappings":"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"}
1
+ {"version":3,"file":"ElementBlock.js","names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_components","_IterateItemContext","_ElementBlockContext","_FieldBoundaryContext","_excluded","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","_extends","assign","bind","target","i","arguments","length","source","apply","_objectWithoutProperties","excluded","_objectWithoutPropertiesLoose","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","ElementBlock","props","forceUpdate","useReducer","contextRef","useRef","current","useContext","IterateItemContext","hasError","hasSubmitError","FieldBoundaryContext","containerMode","handleRemove","switchContainerMode","isNew","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","openRef","isRemoving","setOpenState","useCallback","useEffect","setTimeout","handleAnimationEnd","state","preventFocusOnErrorOpening","_contextRef$current","_contextRef$current$e","_contextRef$current$e2","_contextRef$current$e3","elementRef","focus","window","requestAnimationFrame","_document$activeEleme","document","activeElement","closest","_contextRef$current2","elements","containerRef","querySelectorAll","e","_contextRef$current3","_contextRef$current3$","fulfillRemove","handleRemoveBlock","keepItems","createElement","Provider","value","HeightAnimation","classnames","duration","keepInDOM","Flex","Stack","element","_supportsSpacingProps","_default","exports"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/ElementBlock.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ElementBlockContext from './ElementBlockContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from '../Array/types'\n\nexport type ElementSectionProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ElementSectionProps\n\nfunction ElementBlock(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const contextRef = useRef<\n IterateItemContextState & {\n hasError?: boolean\n hasSubmitError?: boolean\n }\n >()\n contextRef.current = useContext(IterateItemContext) || {}\n\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasSubmitError = hasSubmitError\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasSubmitError) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { handleRemove, switchContainerMode, containerMode, isNew } =\n contextRef.current\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n // - Keep the block open if we have an error\n if (contextRef.current.hasSubmitError) {\n switchContainerMode?.('edit')\n }\n\n const preventFocusOnErrorOpening = !contextRef.current.hasSubmitError\n if (preventFocusOnErrorOpening) {\n if (state === 'opened') {\n contextRef.current?.elementRef?.current?.focus?.()\n } else {\n // Wait until the element is removed, then check if we can set focus\n window.requestAnimationFrame(() => {\n // try to focus on the second last element\n try {\n if (\n // But not when we focus is already inside our element\n !document.activeElement?.closest(\n '.dnb-forms-iterate__element'\n )\n ) {\n const elements =\n contextRef.current?.containerRef.current.querySelectorAll<HTMLDivElement>(\n '.dnb-forms-iterate__element'\n )\n elements[elements.length - 1].focus()\n }\n } catch (e) {\n /**/\n }\n })\n }\n }\n\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n contextRef.current?.fulfillRemove?.()\n }\n\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, switchContainerMode]\n )\n const handleRemoveBlock = useCallback(() => {\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, setOpenState])\n\n return (\n <ElementBlockContext.Provider value={{ handleRemoveBlock }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n contextRef.current.hasSubmitError &&\n 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ElementBlockContext.Provider>\n )\n}\n\nElementBlock._supportsSpacingProps = true\nexport default ElementBlock\n"],"mappings":"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"}
@@ -13,12 +13,12 @@ var _componentHelper = require("../../../../shared/component-helper");
13
13
  var _components = require("../../../../components");
14
14
  var _utils = require("../../../../components/flex/utils");
15
15
  var _Container = require("../../../../components/flex/Container");
16
- var _IterateElementContext = _interopRequireDefault(require("../IterateElementContext"));
16
+ var _IterateItemContext = _interopRequireDefault(require("../IterateItemContext"));
17
17
  var _SummaryListContext = _interopRequireDefault(require("../../Value/SummaryList/SummaryListContext"));
18
18
  var _ValueBlockContext = _interopRequireDefault(require("../../ValueBlock/ValueBlockContext"));
19
19
  var _FieldBoundaryProvider = _interopRequireDefault(require("../../DataContext/FieldBoundary/FieldBoundaryProvider"));
20
- var _structuredClone = _interopRequireDefault(require("@ungap/structured-clone"));
21
20
  var _useDataValue = _interopRequireDefault(require("../../hooks/useDataValue"));
21
+ var _structuredClone = _interopRequireDefault(require("@ungap/structured-clone"));
22
22
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
23
23
  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); }
24
24
  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; }
@@ -101,7 +101,9 @@ function ArrayComponent(props) {
101
101
  }
102
102
  const isNew = isNewRef.current[id] || false;
103
103
  if (!modesRef.current[id]) {
104
- modesRef.current[id] = isNew ? 'edit' : 'view';
104
+ var _value$__containerMod;
105
+ modesRef.current[id] = (_value$__containerMod = value === null || value === void 0 ? void 0 : value['__containerMode']) !== null && _value$__containerMod !== void 0 ? _value$__containerMod : isNew ? 'edit' : 'view';
106
+ value === null || value === void 0 ? true : delete value['__containerMode'];
105
107
  }
106
108
  return {
107
109
  id,
@@ -185,7 +187,7 @@ function ArrayComponent(props) {
185
187
  });
186
188
  const content = Array.isArray(children) ? children.map(child => renderChildren(child)) : renderChildren(children);
187
189
  if (omitFlex) {
188
- return _react.default.createElement(_IterateElementContext.default.Provider, {
190
+ return _react.default.createElement(_IterateItemContext.default.Provider, {
189
191
  key: `element-${id}`,
190
192
  value: contextValue
191
193
  }, _react.default.createElement(_FieldBoundaryProvider.default, null, content));
@@ -195,7 +197,7 @@ function ArrayComponent(props) {
195
197
  tabIndex: -1,
196
198
  innerRef: elementRef,
197
199
  key: `element-${id}`
198
- }, _react.default.createElement(_IterateElementContext.default.Provider, {
200
+ }, _react.default.createElement(_IterateItemContext.default.Provider, {
199
201
  value: contextValue
200
202
  }, _react.default.createElement(_FieldBoundaryProvider.default, null, content)));
201
203
  }));