@dnb/eufemia 10.48.0 → 10.50.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 (573) hide show
  1. package/CHANGELOG.md +57 -0
  2. package/cjs/components/breadcrumb/BreadcrumbItem.d.ts +1 -1
  3. package/cjs/components/breadcrumb/BreadcrumbItem.js +3 -3
  4. package/cjs/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  5. package/cjs/components/breadcrumb/BreadcrumbMultiple.js +2 -2
  6. package/cjs/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  7. package/cjs/components/checkbox/CheckboxDocs.js +1 -1
  8. package/cjs/components/checkbox/CheckboxDocs.js.map +1 -1
  9. package/cjs/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  10. package/cjs/components/height-animation/HeightAnimationInstance.js +13 -6
  11. package/cjs/components/height-animation/HeightAnimationInstance.js.map +1 -1
  12. package/cjs/elements/ElementDocs.d.ts +2 -0
  13. package/cjs/elements/ElementDocs.js +35 -0
  14. package/cjs/elements/ElementDocs.js.map +1 -0
  15. package/cjs/elements/blockquote/BlockquoteDocs.d.ts +2 -0
  16. package/cjs/elements/blockquote/BlockquoteDocs.js +25 -0
  17. package/cjs/elements/blockquote/BlockquoteDocs.js.map +1 -0
  18. package/cjs/elements/hr/HrDocs.d.ts +2 -0
  19. package/cjs/elements/hr/HrDocs.js +25 -0
  20. package/cjs/elements/hr/HrDocs.js.map +1 -0
  21. package/cjs/elements/img/ImgDocs.d.ts +2 -0
  22. package/cjs/elements/img/ImgDocs.js +40 -0
  23. package/cjs/elements/img/ImgDocs.js.map +1 -0
  24. package/cjs/elements/lists/DlDocs.d.ts +2 -0
  25. package/cjs/elements/lists/DlDocs.js +21 -0
  26. package/cjs/elements/lists/DlDocs.js.map +1 -0
  27. package/cjs/elements/lists/OlDocs.d.ts +2 -0
  28. package/cjs/elements/lists/OlDocs.js +31 -0
  29. package/cjs/elements/lists/OlDocs.js.map +1 -0
  30. package/cjs/elements/lists/UlDocs.d.ts +2 -0
  31. package/cjs/elements/lists/UlDocs.js +31 -0
  32. package/cjs/elements/lists/UlDocs.js.map +1 -0
  33. package/cjs/elements/typography/IngressDocs.d.ts +2 -0
  34. package/cjs/elements/typography/IngressDocs.js +15 -0
  35. package/cjs/elements/typography/IngressDocs.js.map +1 -0
  36. package/cjs/elements/typography/LeadDocs.d.ts +2 -0
  37. package/cjs/elements/typography/LeadDocs.js +15 -0
  38. package/cjs/elements/typography/LeadDocs.js.map +1 -0
  39. package/cjs/elements/typography/PDocs.d.ts +2 -0
  40. package/cjs/elements/typography/PDocs.js +40 -0
  41. package/cjs/elements/typography/PDocs.js.map +1 -0
  42. package/cjs/extensions/forms/DataContext/Context.d.ts +21 -8
  43. package/cjs/extensions/forms/DataContext/Context.js +1 -2
  44. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  45. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +4 -0
  46. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  47. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +13 -4
  48. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  49. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  50. package/cjs/extensions/forms/DataContext/Provider/Provider.js +85 -49
  51. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  52. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  53. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  54. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +34 -5
  55. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  56. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -4
  57. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +6 -3
  58. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  59. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +1 -0
  60. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +65 -2
  61. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  62. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +10 -5
  63. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +59 -32
  64. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  65. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +5 -0
  66. package/cjs/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  67. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +1 -1
  68. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  69. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  70. package/cjs/extensions/forms/Form/Handler/Handler.js +3 -1
  71. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  72. package/cjs/extensions/forms/Form/Isolation/Isolation.js +15 -6
  73. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  74. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +0 -2
  75. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  76. package/cjs/extensions/forms/Form/Visibility/Visibility.js +9 -3
  77. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  78. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.d.ts +6 -0
  79. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.js +12 -0
  80. package/cjs/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -0
  81. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  82. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  83. package/cjs/extensions/forms/Form/Visibility/useVisibility.js +3 -3
  84. package/cjs/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  85. package/cjs/extensions/forms/Form/data-context/getData.d.ts +2 -1
  86. package/cjs/extensions/forms/Form/data-context/getData.js +6 -1
  87. package/cjs/extensions/forms/Form/data-context/getData.js.map +1 -1
  88. package/cjs/extensions/forms/Form/data-context/useData.d.ts +4 -1
  89. package/cjs/extensions/forms/Form/data-context/useData.js +32 -9
  90. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  91. package/cjs/extensions/forms/Iterate/Array/Array.js +40 -17
  92. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  93. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js +11 -1
  94. package/cjs/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  95. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +1 -1
  96. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  97. package/cjs/extensions/forms/Iterate/Array/types.d.ts +2 -0
  98. package/cjs/extensions/forms/Iterate/Array/types.js.map +1 -1
  99. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js +19 -7
  100. package/cjs/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  101. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js +0 -1
  102. package/cjs/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -1
  103. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +2 -2
  104. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  105. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js +29 -7
  106. package/cjs/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  107. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js +18 -2
  108. package/cjs/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  109. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +2 -1
  110. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +30 -10
  111. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  112. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  113. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  114. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +3 -5
  115. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  116. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -2
  117. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  118. package/cjs/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  119. package/cjs/extensions/forms/Iterate/hooks/index.js +7 -0
  120. package/cjs/extensions/forms/Iterate/hooks/index.js.map +1 -1
  121. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +15 -0
  122. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.js +50 -0
  123. package/cjs/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -0
  124. package/cjs/extensions/forms/Tools/Log.js +1 -1
  125. package/cjs/extensions/forms/Tools/Log.js.map +1 -1
  126. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +12 -0
  127. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js +27 -10
  128. package/cjs/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  129. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +10 -0
  130. package/cjs/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -1
  131. package/cjs/extensions/forms/Value/Number/Number.js +3 -2
  132. package/cjs/extensions/forms/Value/Number/Number.js.map +1 -1
  133. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +1 -0
  134. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.js +7 -23
  135. package/cjs/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -1
  136. package/cjs/extensions/forms/Value/SelectCountry/useCountry.d.ts +4 -0
  137. package/cjs/extensions/forms/Value/SelectCountry/useCountry.js +33 -0
  138. package/cjs/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -0
  139. package/cjs/extensions/forms/Value/Selection/Selection.js +2 -1
  140. package/cjs/extensions/forms/Value/Selection/Selection.js.map +1 -1
  141. package/cjs/extensions/forms/Value/ValueDocs.js +5 -0
  142. package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
  143. package/cjs/extensions/forms/ValueBlock/ValueBlock.js +8 -6
  144. package/cjs/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  145. package/cjs/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  146. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  147. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +4 -2
  148. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +40 -22
  149. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  150. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +10 -0
  151. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -1
  152. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +72 -70
  153. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -1
  154. package/cjs/extensions/forms/constants/countries.d.ts +1 -0
  155. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  156. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +5 -4
  157. package/cjs/extensions/forms/constants/locales/en-GB.js +8 -7
  158. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  159. package/cjs/extensions/forms/constants/locales/en-US.d.ts +5 -4
  160. package/cjs/extensions/forms/constants/locales/index.d.ts +10 -8
  161. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +5 -4
  162. package/cjs/extensions/forms/constants/locales/nb-NO.js +8 -7
  163. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  164. package/cjs/extensions/forms/hooks/DataValueDocs.js +1 -1
  165. package/cjs/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  166. package/cjs/extensions/forms/hooks/useFieldProps.js +156 -58
  167. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  168. package/cjs/extensions/forms/hooks/useValueProps.js +31 -8
  169. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  170. package/cjs/extensions/forms/types.d.ts +13 -6
  171. package/cjs/extensions/forms/types.js.map +1 -1
  172. package/cjs/shared/Eufemia.d.ts +1 -1
  173. package/cjs/shared/Eufemia.js +2 -2
  174. package/cjs/shared/Eufemia.js.map +1 -1
  175. package/cjs/shared/locales/en-GB.js.map +1 -1
  176. package/cjs/shared/locales/en-US.d.ts +1 -1
  177. package/cjs/shared/locales/en-US.js +2 -2
  178. package/cjs/shared/locales/en-US.js.map +1 -1
  179. package/cjs/style/core/scopes.scss +1 -1
  180. package/cjs/style/dnb-ui-basis.css +1 -1
  181. package/cjs/style/dnb-ui-basis.min.css +1 -1
  182. package/cjs/style/dnb-ui-body.css +1 -1
  183. package/cjs/style/dnb-ui-body.min.css +1 -1
  184. package/cjs/style/dnb-ui-core.css +1 -1
  185. package/cjs/style/dnb-ui-core.min.css +1 -1
  186. package/components/breadcrumb/BreadcrumbItem.d.ts +1 -1
  187. package/components/breadcrumb/BreadcrumbItem.js +3 -3
  188. package/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  189. package/components/breadcrumb/BreadcrumbMultiple.js +2 -2
  190. package/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  191. package/components/checkbox/CheckboxDocs.js +1 -1
  192. package/components/checkbox/CheckboxDocs.js.map +1 -1
  193. package/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  194. package/components/height-animation/HeightAnimationInstance.js +13 -6
  195. package/components/height-animation/HeightAnimationInstance.js.map +1 -1
  196. package/elements/ElementDocs.d.ts +2 -0
  197. package/elements/ElementDocs.js +28 -0
  198. package/elements/ElementDocs.js.map +1 -0
  199. package/elements/blockquote/BlockquoteDocs.d.ts +2 -0
  200. package/elements/blockquote/BlockquoteDocs.js +18 -0
  201. package/elements/blockquote/BlockquoteDocs.js.map +1 -0
  202. package/elements/hr/HrDocs.d.ts +2 -0
  203. package/elements/hr/HrDocs.js +18 -0
  204. package/elements/hr/HrDocs.js.map +1 -0
  205. package/elements/img/ImgDocs.d.ts +2 -0
  206. package/elements/img/ImgDocs.js +33 -0
  207. package/elements/img/ImgDocs.js.map +1 -0
  208. package/elements/lists/DlDocs.d.ts +2 -0
  209. package/elements/lists/DlDocs.js +12 -0
  210. package/elements/lists/DlDocs.js.map +1 -0
  211. package/elements/lists/OlDocs.d.ts +2 -0
  212. package/elements/lists/OlDocs.js +22 -0
  213. package/elements/lists/OlDocs.js.map +1 -0
  214. package/elements/lists/UlDocs.d.ts +2 -0
  215. package/elements/lists/UlDocs.js +22 -0
  216. package/elements/lists/UlDocs.js.map +1 -0
  217. package/elements/typography/IngressDocs.d.ts +2 -0
  218. package/elements/typography/IngressDocs.js +6 -0
  219. package/elements/typography/IngressDocs.js.map +1 -0
  220. package/elements/typography/LeadDocs.d.ts +2 -0
  221. package/elements/typography/LeadDocs.js +6 -0
  222. package/elements/typography/LeadDocs.js.map +1 -0
  223. package/elements/typography/PDocs.d.ts +2 -0
  224. package/elements/typography/PDocs.js +33 -0
  225. package/elements/typography/PDocs.js.map +1 -0
  226. package/es/components/breadcrumb/BreadcrumbItem.d.ts +1 -1
  227. package/es/components/breadcrumb/BreadcrumbItem.js +3 -3
  228. package/es/components/breadcrumb/BreadcrumbItem.js.map +1 -1
  229. package/es/components/breadcrumb/BreadcrumbMultiple.js +2 -2
  230. package/es/components/breadcrumb/BreadcrumbMultiple.js.map +1 -1
  231. package/es/components/checkbox/CheckboxDocs.js +1 -1
  232. package/es/components/checkbox/CheckboxDocs.js.map +1 -1
  233. package/es/components/height-animation/HeightAnimationInstance.d.ts +1 -0
  234. package/es/components/height-animation/HeightAnimationInstance.js +13 -6
  235. package/es/components/height-animation/HeightAnimationInstance.js.map +1 -1
  236. package/es/elements/ElementDocs.d.ts +2 -0
  237. package/es/elements/ElementDocs.js +28 -0
  238. package/es/elements/ElementDocs.js.map +1 -0
  239. package/es/elements/blockquote/BlockquoteDocs.d.ts +2 -0
  240. package/es/elements/blockquote/BlockquoteDocs.js +18 -0
  241. package/es/elements/blockquote/BlockquoteDocs.js.map +1 -0
  242. package/es/elements/hr/HrDocs.d.ts +2 -0
  243. package/es/elements/hr/HrDocs.js +18 -0
  244. package/es/elements/hr/HrDocs.js.map +1 -0
  245. package/es/elements/img/ImgDocs.d.ts +2 -0
  246. package/es/elements/img/ImgDocs.js +33 -0
  247. package/es/elements/img/ImgDocs.js.map +1 -0
  248. package/es/elements/lists/DlDocs.d.ts +2 -0
  249. package/es/elements/lists/DlDocs.js +12 -0
  250. package/es/elements/lists/DlDocs.js.map +1 -0
  251. package/es/elements/lists/OlDocs.d.ts +2 -0
  252. package/es/elements/lists/OlDocs.js +22 -0
  253. package/es/elements/lists/OlDocs.js.map +1 -0
  254. package/es/elements/lists/UlDocs.d.ts +2 -0
  255. package/es/elements/lists/UlDocs.js +22 -0
  256. package/es/elements/lists/UlDocs.js.map +1 -0
  257. package/es/elements/typography/IngressDocs.d.ts +2 -0
  258. package/es/elements/typography/IngressDocs.js +6 -0
  259. package/es/elements/typography/IngressDocs.js.map +1 -0
  260. package/es/elements/typography/LeadDocs.d.ts +2 -0
  261. package/es/elements/typography/LeadDocs.js +6 -0
  262. package/es/elements/typography/LeadDocs.js.map +1 -0
  263. package/es/elements/typography/PDocs.d.ts +2 -0
  264. package/es/elements/typography/PDocs.js +33 -0
  265. package/es/elements/typography/PDocs.js.map +1 -0
  266. package/es/extensions/forms/DataContext/Context.d.ts +21 -8
  267. package/es/extensions/forms/DataContext/Context.js +1 -2
  268. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  269. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +4 -0
  270. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  271. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +13 -4
  272. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  273. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  274. package/es/extensions/forms/DataContext/Provider/Provider.js +83 -47
  275. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  276. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  277. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  278. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +35 -6
  279. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  280. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -4
  281. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +7 -4
  282. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  283. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +1 -0
  284. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +63 -1
  285. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  286. package/es/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +10 -5
  287. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +50 -21
  288. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  289. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +5 -0
  290. package/es/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  291. package/es/extensions/forms/FieldBlock/FieldBlock.js +1 -1
  292. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  293. package/es/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  294. package/es/extensions/forms/Form/Handler/Handler.js +3 -1
  295. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  296. package/es/extensions/forms/Form/Isolation/Isolation.js +15 -6
  297. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  298. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +0 -2
  299. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  300. package/es/extensions/forms/Form/Visibility/Visibility.js +9 -3
  301. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  302. package/es/extensions/forms/Form/Visibility/VisibilityContext.d.ts +6 -0
  303. package/es/extensions/forms/Form/Visibility/VisibilityContext.js +6 -0
  304. package/es/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -0
  305. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  306. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  307. package/es/extensions/forms/Form/Visibility/useVisibility.js +3 -3
  308. package/es/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  309. package/es/extensions/forms/Form/data-context/getData.d.ts +2 -1
  310. package/es/extensions/forms/Form/data-context/getData.js +6 -1
  311. package/es/extensions/forms/Form/data-context/getData.js.map +1 -1
  312. package/es/extensions/forms/Form/data-context/useData.d.ts +4 -1
  313. package/es/extensions/forms/Form/data-context/useData.js +31 -9
  314. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  315. package/es/extensions/forms/Iterate/Array/Array.js +43 -20
  316. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  317. package/es/extensions/forms/Iterate/Array/ArrayDocs.js +11 -1
  318. package/es/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  319. package/es/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +1 -1
  320. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  321. package/es/extensions/forms/Iterate/Array/types.d.ts +2 -0
  322. package/es/extensions/forms/Iterate/Array/types.js.map +1 -1
  323. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js +15 -5
  324. package/es/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  325. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js +0 -1
  326. package/es/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -1
  327. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +2 -2
  328. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  329. package/es/extensions/forms/Iterate/PushButton/PushButton.js +31 -9
  330. package/es/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  331. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js +19 -3
  332. package/es/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  333. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +2 -1
  334. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +31 -11
  335. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  336. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  337. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  338. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -6
  339. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  340. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -2
  341. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  342. package/es/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  343. package/es/extensions/forms/Iterate/hooks/index.js +1 -0
  344. package/es/extensions/forms/Iterate/hooks/index.js.map +1 -1
  345. package/es/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +15 -0
  346. package/es/extensions/forms/Iterate/hooks/useArrayLimit.js +43 -0
  347. package/es/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -0
  348. package/es/extensions/forms/Tools/Log.js +1 -1
  349. package/es/extensions/forms/Tools/Log.js.map +1 -1
  350. package/es/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +12 -0
  351. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js +26 -9
  352. package/es/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  353. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +10 -0
  354. package/es/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -1
  355. package/es/extensions/forms/Value/Number/Number.js +3 -2
  356. package/es/extensions/forms/Value/Number/Number.js.map +1 -1
  357. package/es/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +1 -0
  358. package/es/extensions/forms/Value/SelectCountry/SelectCountry.js +7 -22
  359. package/es/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -1
  360. package/es/extensions/forms/Value/SelectCountry/useCountry.d.ts +4 -0
  361. package/es/extensions/forms/Value/SelectCountry/useCountry.js +27 -0
  362. package/es/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -0
  363. package/es/extensions/forms/Value/Selection/Selection.js +2 -1
  364. package/es/extensions/forms/Value/Selection/Selection.js.map +1 -1
  365. package/es/extensions/forms/Value/ValueDocs.js +5 -0
  366. package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
  367. package/es/extensions/forms/ValueBlock/ValueBlock.js +8 -6
  368. package/es/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  369. package/es/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  370. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  371. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +4 -2
  372. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +40 -22
  373. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  374. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +10 -0
  375. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -1
  376. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +72 -70
  377. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -1
  378. package/es/extensions/forms/constants/countries.d.ts +1 -0
  379. package/es/extensions/forms/constants/countries.js.map +1 -1
  380. package/es/extensions/forms/constants/locales/en-GB.d.ts +5 -4
  381. package/es/extensions/forms/constants/locales/en-GB.js +8 -7
  382. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  383. package/es/extensions/forms/constants/locales/en-US.d.ts +5 -4
  384. package/es/extensions/forms/constants/locales/index.d.ts +10 -8
  385. package/es/extensions/forms/constants/locales/nb-NO.d.ts +5 -4
  386. package/es/extensions/forms/constants/locales/nb-NO.js +8 -7
  387. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  388. package/es/extensions/forms/hooks/DataValueDocs.js +1 -1
  389. package/es/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  390. package/es/extensions/forms/hooks/useFieldProps.js +149 -54
  391. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  392. package/es/extensions/forms/hooks/useValueProps.js +32 -9
  393. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  394. package/es/extensions/forms/types.d.ts +13 -6
  395. package/es/extensions/forms/types.js.map +1 -1
  396. package/es/shared/Eufemia.d.ts +1 -1
  397. package/es/shared/Eufemia.js +2 -2
  398. package/es/shared/Eufemia.js.map +1 -1
  399. package/es/shared/locales/en-GB.js.map +1 -1
  400. package/es/shared/locales/en-US.d.ts +1 -1
  401. package/es/shared/locales/en-US.js +2 -2
  402. package/es/shared/locales/en-US.js.map +1 -1
  403. package/es/style/core/scopes.scss +1 -1
  404. package/es/style/dnb-ui-basis.css +1 -1
  405. package/es/style/dnb-ui-basis.min.css +1 -1
  406. package/es/style/dnb-ui-body.css +1 -1
  407. package/es/style/dnb-ui-body.min.css +1 -1
  408. package/es/style/dnb-ui-core.css +1 -1
  409. package/es/style/dnb-ui-core.min.css +1 -1
  410. package/esm/dnb-ui-basis.min.mjs +1 -1
  411. package/esm/dnb-ui-components.min.mjs +1 -1
  412. package/esm/dnb-ui-elements.min.mjs +1 -1
  413. package/esm/dnb-ui-extensions.min.mjs +3 -3
  414. package/esm/dnb-ui-lib.min.mjs +1 -1
  415. package/extensions/forms/DataContext/Context.d.ts +21 -8
  416. package/extensions/forms/DataContext/Context.js +1 -2
  417. package/extensions/forms/DataContext/Context.js.map +1 -1
  418. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +4 -0
  419. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  420. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +13 -4
  421. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  422. package/extensions/forms/DataContext/Provider/Provider.d.ts +0 -4
  423. package/extensions/forms/DataContext/Provider/Provider.js +85 -47
  424. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  425. package/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  426. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  427. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +35 -6
  428. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  429. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +5 -4
  430. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +7 -4
  431. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  432. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.d.ts +1 -0
  433. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +63 -1
  434. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  435. package/extensions/forms/Field/SelectCountry/SelectCountry.d.ts +10 -5
  436. package/extensions/forms/Field/SelectCountry/SelectCountry.js +59 -33
  437. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  438. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js +5 -0
  439. package/extensions/forms/Field/SelectCountry/SelectCountryDocs.js.map +1 -1
  440. package/extensions/forms/FieldBlock/FieldBlock.js +1 -1
  441. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  442. package/extensions/forms/Form/Handler/Handler.d.ts +1 -1
  443. package/extensions/forms/Form/Handler/Handler.js +3 -1
  444. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  445. package/extensions/forms/Form/Isolation/Isolation.js +15 -6
  446. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  447. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +0 -2
  448. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -1
  449. package/extensions/forms/Form/Visibility/Visibility.js +9 -3
  450. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  451. package/extensions/forms/Form/Visibility/VisibilityContext.d.ts +6 -0
  452. package/extensions/forms/Form/Visibility/VisibilityContext.js +6 -0
  453. package/extensions/forms/Form/Visibility/VisibilityContext.js.map +1 -0
  454. package/extensions/forms/Form/Visibility/VisibilityDocs.js +1 -1
  455. package/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  456. package/extensions/forms/Form/Visibility/useVisibility.js +3 -3
  457. package/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  458. package/extensions/forms/Form/data-context/getData.d.ts +2 -1
  459. package/extensions/forms/Form/data-context/getData.js +6 -1
  460. package/extensions/forms/Form/data-context/getData.js.map +1 -1
  461. package/extensions/forms/Form/data-context/useData.d.ts +4 -1
  462. package/extensions/forms/Form/data-context/useData.js +32 -9
  463. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  464. package/extensions/forms/Iterate/Array/Array.js +43 -20
  465. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  466. package/extensions/forms/Iterate/Array/ArrayDocs.js +11 -1
  467. package/extensions/forms/Iterate/Array/ArrayDocs.js.map +1 -1
  468. package/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +1 -1
  469. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  470. package/extensions/forms/Iterate/Array/types.d.ts +2 -0
  471. package/extensions/forms/Iterate/Array/types.js.map +1 -1
  472. package/extensions/forms/Iterate/EditContainer/CancelButton.js +18 -7
  473. package/extensions/forms/Iterate/EditContainer/CancelButton.js.map +1 -1
  474. package/extensions/forms/Iterate/EditContainer/DoneButton.js +0 -1
  475. package/extensions/forms/Iterate/EditContainer/DoneButton.js.map +1 -1
  476. package/extensions/forms/Iterate/EditContainer/EditContainer.js +2 -2
  477. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  478. package/extensions/forms/Iterate/PushButton/PushButton.js +31 -9
  479. package/extensions/forms/Iterate/PushButton/PushButton.js.map +1 -1
  480. package/extensions/forms/Iterate/PushContainer/OpenButton.js +19 -3
  481. package/extensions/forms/Iterate/PushContainer/OpenButton.js.map +1 -1
  482. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +2 -1
  483. package/extensions/forms/Iterate/PushContainer/PushContainer.js +31 -11
  484. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  485. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  486. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  487. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +4 -6
  488. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  489. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +2 -2
  490. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  491. package/extensions/forms/Iterate/hooks/index.d.ts +1 -0
  492. package/extensions/forms/Iterate/hooks/index.js +1 -0
  493. package/extensions/forms/Iterate/hooks/index.js.map +1 -1
  494. package/extensions/forms/Iterate/hooks/useArrayLimit.d.ts +15 -0
  495. package/extensions/forms/Iterate/hooks/useArrayLimit.js +44 -0
  496. package/extensions/forms/Iterate/hooks/useArrayLimit.js.map +1 -0
  497. package/extensions/forms/Tools/Log.js +1 -1
  498. package/extensions/forms/Tools/Log.js.map +1 -1
  499. package/extensions/forms/Value/ArraySelection/ArraySelection.d.ts +12 -0
  500. package/extensions/forms/Value/ArraySelection/ArraySelection.js +27 -10
  501. package/extensions/forms/Value/ArraySelection/ArraySelection.js.map +1 -1
  502. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js +10 -0
  503. package/extensions/forms/Value/ArraySelection/ArraySelectionDocs.js.map +1 -1
  504. package/extensions/forms/Value/Number/Number.js +3 -2
  505. package/extensions/forms/Value/Number/Number.js.map +1 -1
  506. package/extensions/forms/Value/SelectCountry/SelectCountry.d.ts +1 -0
  507. package/extensions/forms/Value/SelectCountry/SelectCountry.js +7 -22
  508. package/extensions/forms/Value/SelectCountry/SelectCountry.js.map +1 -1
  509. package/extensions/forms/Value/SelectCountry/useCountry.d.ts +4 -0
  510. package/extensions/forms/Value/SelectCountry/useCountry.js +27 -0
  511. package/extensions/forms/Value/SelectCountry/useCountry.js.map +1 -0
  512. package/extensions/forms/Value/Selection/Selection.js +2 -1
  513. package/extensions/forms/Value/Selection/Selection.js.map +1 -1
  514. package/extensions/forms/Value/ValueDocs.js +5 -0
  515. package/extensions/forms/Value/ValueDocs.js.map +1 -1
  516. package/extensions/forms/ValueBlock/ValueBlock.js +8 -6
  517. package/extensions/forms/ValueBlock/ValueBlock.js.map +1 -1
  518. package/extensions/forms/Wizard/Step/Step.d.ts +1 -1
  519. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  520. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.d.ts +4 -2
  521. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +40 -22
  522. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  523. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js +10 -0
  524. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeDocs.js.map +1 -1
  525. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js +72 -70
  526. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAgeTranslations.js.map +1 -1
  527. package/extensions/forms/constants/countries.d.ts +1 -0
  528. package/extensions/forms/constants/countries.js.map +1 -1
  529. package/extensions/forms/constants/locales/en-GB.d.ts +5 -4
  530. package/extensions/forms/constants/locales/en-GB.js +8 -7
  531. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  532. package/extensions/forms/constants/locales/en-US.d.ts +5 -4
  533. package/extensions/forms/constants/locales/index.d.ts +10 -8
  534. package/extensions/forms/constants/locales/nb-NO.d.ts +5 -4
  535. package/extensions/forms/constants/locales/nb-NO.js +8 -7
  536. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  537. package/extensions/forms/hooks/DataValueDocs.js +1 -1
  538. package/extensions/forms/hooks/DataValueDocs.js.map +1 -1
  539. package/extensions/forms/hooks/useFieldProps.js +154 -58
  540. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  541. package/extensions/forms/hooks/useValueProps.js +32 -9
  542. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  543. package/extensions/forms/types.d.ts +13 -6
  544. package/extensions/forms/types.js.map +1 -1
  545. package/package.json +1 -1
  546. package/shared/Eufemia.d.ts +1 -1
  547. package/shared/Eufemia.js +2 -2
  548. package/shared/Eufemia.js.map +1 -1
  549. package/shared/locales/en-GB.js.map +1 -1
  550. package/shared/locales/en-US.d.ts +1 -1
  551. package/shared/locales/en-US.js +2 -2
  552. package/shared/locales/en-US.js.map +1 -1
  553. package/style/core/scopes.scss +1 -1
  554. package/style/dnb-ui-basis.css +1 -1
  555. package/style/dnb-ui-basis.min.css +1 -1
  556. package/style/dnb-ui-body.css +1 -1
  557. package/style/dnb-ui-body.min.css +1 -1
  558. package/style/dnb-ui-core.css +1 -1
  559. package/style/dnb-ui-core.min.css +1 -1
  560. package/umd/dnb-ui-basis.min.js +1 -1
  561. package/umd/dnb-ui-components.min.js +1 -1
  562. package/umd/dnb-ui-elements.min.js +1 -1
  563. package/umd/dnb-ui-extensions.min.js +3 -3
  564. package/umd/dnb-ui-lib.min.js +1 -1
  565. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +0 -1
  566. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +0 -25
  567. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +0 -1
  568. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +0 -1
  569. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +0 -19
  570. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +0 -1
  571. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +0 -1
  572. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +0 -19
  573. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +0 -1
@@ -1,9 +1,10 @@
1
1
  import { SharedStateId } from '../../../../shared/helpers/useSharedState';
2
- import type { UseDataReturnGetValue, UseDataReturnFilterData } from './useData';
2
+ import type { UseDataReturnGetValue, UseDataReturnFilterData, UseDataReturnVisibleData } from './useData';
3
3
  type SetDataReturn<Data> = {
4
4
  data: Data;
5
5
  getValue: UseDataReturnGetValue<Data>;
6
6
  filterData: UseDataReturnFilterData<Data>;
7
+ reduceToVisibleFields: UseDataReturnVisibleData<Data>;
7
8
  };
8
9
  export default function getData<Data>(id: SharedStateId): SetDataReturn<Data>;
9
10
  export {};
@@ -8,6 +8,10 @@ export default function getData(id) {
8
8
  var _sharedAttachments$da, _sharedAttachments$da2;
9
9
  return (_sharedAttachments$da = sharedAttachments.data) === null || _sharedAttachments$da === void 0 ? void 0 : (_sharedAttachments$da2 = _sharedAttachments$da.filterDataHandler) === null || _sharedAttachments$da2 === void 0 ? void 0 : _sharedAttachments$da2.call(_sharedAttachments$da, data, filter);
10
10
  };
11
+ const reduceToVisibleFields = (data, options) => {
12
+ var _sharedAttachments$da3, _sharedAttachments$da4;
13
+ return (_sharedAttachments$da3 = sharedAttachments.data) === null || _sharedAttachments$da3 === void 0 ? void 0 : (_sharedAttachments$da4 = _sharedAttachments$da3.visibleDataHandler) === null || _sharedAttachments$da4 === void 0 ? void 0 : _sharedAttachments$da4.call(_sharedAttachments$da3, data, options);
14
+ };
11
15
  const getValue = path => {
12
16
  if (pointer.has(data, path)) {
13
17
  return pointer.get(data, path);
@@ -17,7 +21,8 @@ export default function getData(id) {
17
21
  return {
18
22
  data,
19
23
  getValue,
20
- filterData
24
+ filterData,
25
+ reduceToVisibleFields
21
26
  };
22
27
  }
23
28
  //# sourceMappingURL=getData.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"getData.js","names":["pointer","createSharedState","getData","id","sharedState","sharedAttachments","data","get","filterData","filter","_sharedAttachments$da","_sharedAttachments$da2","filterDataHandler","call","getValue","path","has","undefined"],"sources":["../../../../../../src/extensions/forms/Form/data-context/getData.tsx"],"sourcesContent":["import pointer from 'json-pointer'\nimport {\n SharedStateId,\n createSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport type { FilterDataHandler } from '../../DataContext/Context'\nimport type { Path } from '../../types'\nimport type {\n UseDataReturnGetValue,\n UseDataReturnFilterData,\n} from './useData'\n\ntype SharedAttachment<Data> = {\n filterDataHandler: FilterDataHandler<Data>\n}\n\ntype SetDataReturn<Data> = {\n data: Data\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n}\n\nexport default function getData<Data>(\n id: SharedStateId\n): SetDataReturn<Data> {\n const sharedState = createSharedState(id)\n const sharedAttachments = createSharedState<SharedAttachment<Data>>(\n id + '-attachments'\n )\n\n const data = sharedState.get() as Data\n\n const filterData: SetDataReturn<Data>['filterData'] = (filter) =>\n sharedAttachments.data?.filterDataHandler?.(data, filter)\n\n const getValue = (path: Path) => {\n if (pointer.has(data, path)) {\n return pointer.get(data, path)\n }\n\n return undefined\n }\n\n return {\n data,\n getValue,\n filterData,\n }\n}\n"],"mappings":"AAAA,OAAOA,OAAO,MAAM,cAAc;AAClC,SAEEC,iBAAiB,QACZ,2CAA2C;AAkBlD,eAAe,SAASC,OAAOA,CAC7BC,EAAiB,EACI;EACrB,MAAMC,WAAW,GAAGH,iBAAiB,CAACE,EAAE,CAAC;EACzC,MAAME,iBAAiB,GAAGJ,iBAAiB,CACzCE,EAAE,GAAG,cACP,CAAC;EAED,MAAMG,IAAI,GAAGF,WAAW,CAACG,GAAG,CAAC,CAAS;EAEtC,MAAMC,UAA6C,GAAIC,MAAM;IAAA,IAAAC,qBAAA,EAAAC,sBAAA;IAAA,QAAAD,qBAAA,GAC3DL,iBAAiB,CAACC,IAAI,cAAAI,qBAAA,wBAAAC,sBAAA,GAAtBD,qBAAA,CAAwBE,iBAAiB,cAAAD,sBAAA,uBAAzCA,sBAAA,CAAAE,IAAA,CAAAH,qBAAA,EAA4CJ,IAAI,EAAEG,MAAM,CAAC;EAAA;EAE3D,MAAMK,QAAQ,GAAIC,IAAU,IAAK;IAC/B,IAAIf,OAAO,CAACgB,GAAG,CAACV,IAAI,EAAES,IAAI,CAAC,EAAE;MAC3B,OAAOf,OAAO,CAACO,GAAG,CAACD,IAAI,EAAES,IAAI,CAAC;IAChC;IAEA,OAAOE,SAAS;EAClB,CAAC;EAED,OAAO;IACLX,IAAI;IACJQ,QAAQ;IACRN;EACF,CAAC;AACH"}
1
+ {"version":3,"file":"getData.js","names":["pointer","createSharedState","getData","id","sharedState","sharedAttachments","data","get","filterData","filter","_sharedAttachments$da","_sharedAttachments$da2","filterDataHandler","call","reduceToVisibleFields","options","_sharedAttachments$da3","_sharedAttachments$da4","visibleDataHandler","getValue","path","has","undefined"],"sources":["../../../../../../src/extensions/forms/Form/data-context/getData.tsx"],"sourcesContent":["import pointer from 'json-pointer'\nimport {\n SharedStateId,\n createSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport type {\n FilterDataHandler,\n VisibleDataHandler,\n} from '../../DataContext/Context'\nimport type { Path } from '../../types'\nimport type {\n UseDataReturnGetValue,\n UseDataReturnFilterData,\n UseDataReturnVisibleData,\n} from './useData'\n\ntype SharedAttachment<Data> = {\n filterDataHandler: FilterDataHandler<Data>\n visibleDataHandler?: VisibleDataHandler<Data>\n}\n\ntype SetDataReturn<Data> = {\n data: Data\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n reduceToVisibleFields: UseDataReturnVisibleData<Data>\n}\n\nexport default function getData<Data>(\n id: SharedStateId\n): SetDataReturn<Data> {\n const sharedState = createSharedState(id)\n const sharedAttachments = createSharedState<SharedAttachment<Data>>(\n id + '-attachments'\n )\n\n const data = sharedState.get() as Data\n\n const filterData: SetDataReturn<Data>['filterData'] = (filter) =>\n sharedAttachments.data?.filterDataHandler?.(data, filter)\n\n const reduceToVisibleFields: SetDataReturn<Data>['reduceToVisibleFields'] =\n (data, options) =>\n sharedAttachments.data?.visibleDataHandler?.(data, options)\n\n const getValue = (path: Path) => {\n if (pointer.has(data, path)) {\n return pointer.get(data, path)\n }\n\n return undefined\n }\n\n return {\n data,\n getValue,\n filterData,\n reduceToVisibleFields,\n }\n}\n"],"mappings":"AAAA,OAAOA,OAAO,MAAM,cAAc;AAClC,SAEEC,iBAAiB,QACZ,2CAA2C;AAwBlD,eAAe,SAASC,OAAOA,CAC7BC,EAAiB,EACI;EACrB,MAAMC,WAAW,GAAGH,iBAAiB,CAACE,EAAE,CAAC;EACzC,MAAME,iBAAiB,GAAGJ,iBAAiB,CACzCE,EAAE,GAAG,cACP,CAAC;EAED,MAAMG,IAAI,GAAGF,WAAW,CAACG,GAAG,CAAC,CAAS;EAEtC,MAAMC,UAA6C,GAAIC,MAAM;IAAA,IAAAC,qBAAA,EAAAC,sBAAA;IAAA,QAAAD,qBAAA,GAC3DL,iBAAiB,CAACC,IAAI,cAAAI,qBAAA,wBAAAC,sBAAA,GAAtBD,qBAAA,CAAwBE,iBAAiB,cAAAD,sBAAA,uBAAzCA,sBAAA,CAAAE,IAAA,CAAAH,qBAAA,EAA4CJ,IAAI,EAAEG,MAAM,CAAC;EAAA;EAE3D,MAAMK,qBAAmE,GACvEA,CAACR,IAAI,EAAES,OAAO;IAAA,IAAAC,sBAAA,EAAAC,sBAAA;IAAA,QAAAD,sBAAA,GACZX,iBAAiB,CAACC,IAAI,cAAAU,sBAAA,wBAAAC,sBAAA,GAAtBD,sBAAA,CAAwBE,kBAAkB,cAAAD,sBAAA,uBAA1CA,sBAAA,CAAAJ,IAAA,CAAAG,sBAAA,EAA6CV,IAAI,EAAES,OAAO,CAAC;EAAA;EAE/D,MAAMI,QAAQ,GAAIC,IAAU,IAAK;IAC/B,IAAIpB,OAAO,CAACqB,GAAG,CAACf,IAAI,EAAEc,IAAI,CAAC,EAAE;MAC3B,OAAOpB,OAAO,CAACO,GAAG,CAACD,IAAI,EAAEc,IAAI,CAAC;IAChC;IAEA,OAAOE,SAAS;EAClB,CAAC;EAED,OAAO;IACLhB,IAAI;IACJa,QAAQ;IACRX,UAAU;IACVM;EACF,CAAC;AACH"}
@@ -1,17 +1,20 @@
1
1
  import { SharedStateId } from '../../../../shared/helpers/useSharedState';
2
2
  import type { Path } from '../../types';
3
- import { FilterData } from '../../DataContext/Context';
3
+ import { FilterData, VisibleDataHandler } from '../../DataContext/Context';
4
4
  type PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}` ? Key extends keyof T ? Rest extends '' ? T[Key] : PathImpl<T[Key], Rest> : never : T[P & keyof T];
5
5
  type PathType<T, P extends string> = P extends `/${infer Rest}` ? PathImpl<T, Rest> : never;
6
6
  type UseDataReturnUpdate<Data> = <P extends Path>(path: P, value: ((value: PathType<Data, P>) => unknown) | unknown) => void;
7
7
  export type UseDataReturnGetValue<Data> = <P extends Path>(path: P) => PathType<Data, P>;
8
8
  export type UseDataReturnFilterData<Data> = (filterDataHandler: FilterData, data?: Data) => Partial<Data>;
9
+ export type UseDataReturnVisibleData<Data> = VisibleDataHandler<Data>;
9
10
  type UseDataReturn<Data> = {
10
11
  data: Data;
11
12
  set: (newData: Data) => void;
12
13
  update: UseDataReturnUpdate<Data>;
14
+ remove: (path: Path) => void;
13
15
  getValue: UseDataReturnGetValue<Data>;
14
16
  filterData: UseDataReturnFilterData<Data>;
17
+ reduceToVisibleFields: UseDataReturnVisibleData<Data>;
15
18
  };
16
19
  /**
17
20
  * Custom hook that provides form data management functionality.
@@ -25,15 +25,15 @@ export default function useData(id = undefined, initialData = undefined) {
25
25
  }
26
26
  const updateDataValue = context === null || context === void 0 ? void 0 : context.updateDataValue;
27
27
  const setData = context === null || context === void 0 ? void 0 : context.setData;
28
- const setHandler = useCallback(newData => {
28
+ const set = useCallback(newData => {
29
29
  if (id) {
30
30
  sharedDataRef.current.update(newData);
31
31
  } else {
32
32
  setData === null || setData === void 0 ? void 0 : setData(newData);
33
33
  }
34
34
  }, [id, setData]);
35
- const updateHandler = useCallback((path, value = undefined) => {
36
- const existingData = sharedDataRef.current.data || {};
35
+ const update = useCallback((path, value = undefined) => {
36
+ const existingData = structuredClone(sharedDataRef.current.data || {});
37
37
  const existingValue = pointer.has(existingData, path) ? pointer.get(existingData, path) : undefined;
38
38
  const newValue = typeof value === 'function' ? value(existingValue) : value;
39
39
  if (newValue !== existingValue) {
@@ -45,12 +45,32 @@ export default function useData(id = undefined, initialData = undefined) {
45
45
  }
46
46
  }
47
47
  }, [id, updateDataValue]);
48
- const filterData = useCallback((filter, data = sharedDataRef.current.data) => {
48
+ const remove = useCallback(path => {
49
+ const existingData = structuredClone(sharedDataRef.current.data || {});
50
+ if (pointer.has(existingData, path)) {
51
+ pointer.remove(existingData, path);
52
+ if (id) {
53
+ sharedDataRef.current.set(existingData);
54
+ } else {
55
+ updateDataValue(path, undefined);
56
+ }
57
+ }
58
+ }, [id, updateDataValue]);
59
+ const reduceToVisibleFields = useCallback((data, options = {}) => {
60
+ var _context$visibleDataH;
49
61
  if (id) {
50
62
  var _sharedAttachmentsRef, _sharedAttachmentsRef2;
51
- return (_sharedAttachmentsRef = sharedAttachmentsRef.current.data) === null || _sharedAttachmentsRef === void 0 ? void 0 : (_sharedAttachmentsRef2 = _sharedAttachmentsRef.filterDataHandler) === null || _sharedAttachmentsRef2 === void 0 ? void 0 : _sharedAttachmentsRef2.call(_sharedAttachmentsRef, data, filter);
63
+ return (_sharedAttachmentsRef = sharedAttachmentsRef.current.data) === null || _sharedAttachmentsRef === void 0 ? void 0 : (_sharedAttachmentsRef2 = _sharedAttachmentsRef.visibleDataHandler) === null || _sharedAttachmentsRef2 === void 0 ? void 0 : _sharedAttachmentsRef2.call(_sharedAttachmentsRef, data, options);
64
+ }
65
+ return context === null || context === void 0 ? void 0 : (_context$visibleDataH = context.visibleDataHandler) === null || _context$visibleDataH === void 0 ? void 0 : _context$visibleDataH.call(context, data, options);
66
+ }, [context, id]);
67
+ const filterData = useCallback((filter, data = sharedDataRef.current.data) => {
68
+ var _context$filterDataHa;
69
+ if (id) {
70
+ var _sharedAttachmentsRef3, _sharedAttachmentsRef4;
71
+ return (_sharedAttachmentsRef3 = sharedAttachmentsRef.current.data) === null || _sharedAttachmentsRef3 === void 0 ? void 0 : (_sharedAttachmentsRef4 = _sharedAttachmentsRef3.filterDataHandler) === null || _sharedAttachmentsRef4 === void 0 ? void 0 : _sharedAttachmentsRef4.call(_sharedAttachmentsRef3, data, filter);
52
72
  }
53
- return context === null || context === void 0 ? void 0 : context.filterDataHandler(data, filter);
73
+ return context === null || context === void 0 ? void 0 : (_context$filterDataHa = context.filterDataHandler) === null || _context$filterDataHa === void 0 ? void 0 : _context$filterDataHa.call(context, data, filter);
54
74
  }, [context, id]);
55
75
  const getValue = useCallback(path => {
56
76
  if (pointer.has(sharedDataRef.current.data, path)) {
@@ -68,10 +88,12 @@ export default function useData(id = undefined, initialData = undefined) {
68
88
  } = sharedDataRef.current;
69
89
  return useMemo(() => ({
70
90
  data,
71
- update: updateHandler,
72
- set: setHandler,
91
+ remove,
92
+ update,
93
+ set,
73
94
  getValue,
95
+ reduceToVisibleFields,
74
96
  filterData
75
- }), [data, getValue, setHandler, updateHandler, filterData]);
97
+ }), [data, remove, update, set, getValue, reduceToVisibleFields, filterData]);
76
98
  }
77
99
  //# sourceMappingURL=useData.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useData.js","names":["useCallback","useContext","useMemo","useReducer","useRef","pointer","useSharedState","useMountEffect","DataContext","useData","id","undefined","initialData","sharedDataRef","sharedAttachmentsRef","forceUpdate","current","rerenderUseDataHook","context","hasContext","Error","data","filterDataHandler","updateDataValue","setData","setHandler","newData","update","updateHandler","path","value","existingData","existingValue","has","get","newValue","set","extend","filterData","filter","_sharedAttachmentsRef","_sharedAttachmentsRef2","call","getValue","hadInitialData"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useData.tsx"],"sourcesContent":["import {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer from 'json-pointer'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport type { Path } from '../../types'\nimport DataContext, {\n FilterData,\n FilterDataHandler,\n} from '../../DataContext/Context'\n\ntype PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}`\n ? Key extends keyof T\n ? Rest extends ''\n ? T[Key]\n : PathImpl<T[Key], Rest>\n : never\n : T[P & keyof T]\n\ntype PathType<T, P extends string> = P extends `/${infer Rest}`\n ? PathImpl<T, Rest>\n : never\n\ntype UseDataReturnUpdate<Data> = <P extends Path>(\n path: P,\n value: ((value: PathType<Data, P>) => unknown) | unknown\n) => void\n\nexport type UseDataReturnGetValue<Data> = <P extends Path>(\n path: P\n) => PathType<Data, P>\n\nexport type UseDataReturnFilterData<Data> = (\n filterDataHandler: FilterData,\n data?: Data\n) => Partial<Data>\n\ntype UseDataReturn<Data> = {\n data: Data\n set: (newData: Data) => void\n update: UseDataReturnUpdate<Data>\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n}\n\ntype SharedAttachment<Data> = {\n rerenderUseDataHook: () => void\n filterDataHandler?: FilterDataHandler<Data>\n}\n\n/**\n * Custom hook that provides form data management functionality.\n *\n * @template Data - The type of data being managed.\n * @param {SharedStateId} id - The identifier for the data.\n * @param {Data} initialData - The initial data value (optional).\n * @returns {UseDataReturn<Data>} An object containing the data and data management functions.\n */\nexport default function useData<Data>(\n id: SharedStateId = undefined,\n initialData: Data = undefined\n): UseDataReturn<Data> {\n const sharedDataRef =\n useRef<ReturnType<typeof useSharedState<Data>>>(null)\n const sharedAttachmentsRef =\n useRef<ReturnType<typeof useSharedState<SharedAttachment<Data>>>>(null)\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n sharedDataRef.current = useSharedState<Data>(\n id,\n initialData,\n forceUpdate\n )\n\n sharedAttachmentsRef.current = useSharedState<SharedAttachment<Data>>(\n id + '-attachments',\n { rerenderUseDataHook: forceUpdate }\n )\n\n // If no id is provided, use the context data\n const context = useContext(DataContext)\n if (!id) {\n if (!context?.hasContext) {\n throw new Error(\n 'useData needs to run inside DataContext (Form.Handler) or have a valid id'\n )\n }\n\n if (context) {\n sharedDataRef.current.data = context.data\n sharedAttachmentsRef.current.data.filterDataHandler =\n context.filterDataHandler\n }\n }\n\n const updateDataValue = context?.updateDataValue\n const setData = context?.setData\n\n const setHandler = useCallback(\n (newData: Data) => {\n if (id) {\n sharedDataRef.current.update(newData)\n } else {\n setData?.(newData)\n }\n },\n [id, setData]\n )\n\n const updateHandler = useCallback<UseDataReturnUpdate<Data>>(\n (path, value = undefined) => {\n const existingData = sharedDataRef.current.data || ({} as Data)\n const existingValue = pointer.has(existingData, path)\n ? pointer.get(existingData, path)\n : undefined\n\n // get new value\n const newValue =\n typeof value === 'function' ? value(existingValue) : value\n\n if (newValue !== existingValue) {\n // update existing data\n pointer.set(existingData, path, newValue)\n\n // update provider\n if (id) {\n sharedDataRef.current.extend(existingData)\n } else {\n updateDataValue(path, newValue)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const filterData = useCallback<UseDataReturn<Data>['filterData']>(\n (filter, data = sharedDataRef.current.data) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.filterDataHandler?.(\n data,\n filter\n )\n }\n\n return context?.filterDataHandler(data, filter)\n },\n [context, id]\n )\n\n const getValue = useCallback<UseDataReturn<Data>['getValue']>((path) => {\n if (pointer.has(sharedDataRef.current.data, path)) {\n return pointer.get(sharedDataRef.current.data, path)\n }\n\n return undefined\n }, [])\n\n useMountEffect(() => {\n if (id && !sharedDataRef.current.hadInitialData && initialData) {\n sharedDataRef.current.extend(initialData)\n }\n })\n\n const { data } = sharedDataRef.current\n\n return useMemo(\n () => ({\n data,\n update: updateHandler,\n set: setHandler,\n getValue,\n filterData,\n }),\n [data, getValue, setHandler, updateHandler, filterData]\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"useData.js","names":["useCallback","useContext","useMemo","useReducer","useRef","pointer","useSharedState","useMountEffect","DataContext","useData","id","undefined","initialData","sharedDataRef","sharedAttachmentsRef","forceUpdate","current","rerenderUseDataHook","context","hasContext","Error","data","filterDataHandler","updateDataValue","setData","set","newData","update","path","value","existingData","structuredClone","existingValue","has","get","newValue","extend","remove","reduceToVisibleFields","options","_context$visibleDataH","_sharedAttachmentsRef","_sharedAttachmentsRef2","visibleDataHandler","call","filterData","filter","_context$filterDataHa","_sharedAttachmentsRef3","_sharedAttachmentsRef4","getValue","hadInitialData"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useData.tsx"],"sourcesContent":["import {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer from 'json-pointer'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport type { Path } from '../../types'\nimport DataContext, {\n FilterData,\n FilterDataHandler,\n VisibleDataHandler,\n} from '../../DataContext/Context'\n\ntype PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}`\n ? Key extends keyof T\n ? Rest extends ''\n ? T[Key]\n : PathImpl<T[Key], Rest>\n : never\n : T[P & keyof T]\n\ntype PathType<T, P extends string> = P extends `/${infer Rest}`\n ? PathImpl<T, Rest>\n : never\n\ntype UseDataReturnUpdate<Data> = <P extends Path>(\n path: P,\n value: ((value: PathType<Data, P>) => unknown) | unknown\n) => void\n\nexport type UseDataReturnGetValue<Data> = <P extends Path>(\n path: P\n) => PathType<Data, P>\n\nexport type UseDataReturnFilterData<Data> = (\n filterDataHandler: FilterData,\n data?: Data\n) => Partial<Data>\n\nexport type UseDataReturnVisibleData<Data> = VisibleDataHandler<Data>\n\ntype UseDataReturn<Data> = {\n data: Data\n set: (newData: Data) => void\n update: UseDataReturnUpdate<Data>\n remove: (path: Path) => void\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n reduceToVisibleFields: UseDataReturnVisibleData<Data>\n}\n\ntype SharedAttachment<Data> = {\n rerenderUseDataHook: () => void\n filterDataHandler?: FilterDataHandler<Data>\n visibleDataHandler?: VisibleDataHandler<Data>\n}\n\n/**\n * Custom hook that provides form data management functionality.\n *\n * @template Data - The type of data being managed.\n * @param {SharedStateId} id - The identifier for the data.\n * @param {Data} initialData - The initial data value (optional).\n * @returns {UseDataReturn<Data>} An object containing the data and data management functions.\n */\nexport default function useData<Data>(\n id: SharedStateId = undefined,\n initialData: Data = undefined\n): UseDataReturn<Data> {\n const sharedDataRef =\n useRef<ReturnType<typeof useSharedState<Data>>>(null)\n const sharedAttachmentsRef =\n useRef<ReturnType<typeof useSharedState<SharedAttachment<Data>>>>(null)\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n sharedDataRef.current = useSharedState<Data>(\n id,\n initialData,\n forceUpdate\n )\n\n sharedAttachmentsRef.current = useSharedState<SharedAttachment<Data>>(\n id + '-attachments',\n { rerenderUseDataHook: forceUpdate }\n )\n\n // If no id is provided, use the context data\n const context = useContext(DataContext)\n if (!id) {\n if (!context?.hasContext) {\n throw new Error(\n 'useData needs to run inside DataContext (Form.Handler) or have a valid id'\n )\n }\n\n if (context) {\n sharedDataRef.current.data = context.data\n sharedAttachmentsRef.current.data.filterDataHandler =\n context.filterDataHandler\n }\n }\n\n const updateDataValue = context?.updateDataValue\n const setData = context?.setData\n\n const set = useCallback(\n (newData: Data) => {\n if (id) {\n sharedDataRef.current.update(newData)\n } else {\n setData?.(newData)\n }\n },\n [id, setData]\n )\n\n const update = useCallback<UseDataReturnUpdate<Data>>(\n (path, value = undefined) => {\n const existingData = structuredClone(\n sharedDataRef.current.data || ({} as Data)\n )\n const existingValue = pointer.has(existingData, path)\n ? pointer.get(existingData, path)\n : undefined\n\n // Get new value\n const newValue =\n typeof value === 'function' ? value(existingValue) : value\n\n if (newValue !== existingValue) {\n // Update existing data\n pointer.set(existingData, path, newValue)\n\n // Update provider with new data\n if (id) {\n sharedDataRef.current.extend(existingData)\n } else {\n updateDataValue(path, newValue)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const remove = useCallback<UseDataReturn<Data>['remove']>(\n (path) => {\n const existingData = structuredClone(\n sharedDataRef.current.data || ({} as Data)\n )\n\n if (pointer.has(existingData, path)) {\n // Remove existing data\n pointer.remove(existingData, path)\n\n // Update provider with new data\n if (id) {\n sharedDataRef.current.set(existingData)\n } else {\n updateDataValue(path, undefined)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const reduceToVisibleFields = useCallback<\n UseDataReturn<Data>['reduceToVisibleFields']\n >(\n (data, options = {}) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.visibleDataHandler?.(\n data,\n options\n )\n }\n\n return context?.visibleDataHandler?.(data, options)\n },\n [context, id]\n )\n\n const filterData = useCallback<UseDataReturn<Data>['filterData']>(\n (filter, data = sharedDataRef.current.data) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.filterDataHandler?.(\n data,\n filter\n )\n }\n\n return context?.filterDataHandler?.(data, filter)\n },\n [context, id]\n )\n\n const getValue = useCallback<UseDataReturn<Data>['getValue']>((path) => {\n if (pointer.has(sharedDataRef.current.data, path)) {\n return pointer.get(sharedDataRef.current.data, path)\n }\n\n return undefined\n }, [])\n\n useMountEffect(() => {\n if (id && !sharedDataRef.current.hadInitialData && initialData) {\n sharedDataRef.current.extend(initialData)\n }\n })\n\n const { data } = sharedDataRef.current\n\n return useMemo(\n () => ({\n data,\n remove,\n update,\n set,\n getValue,\n reduceToVisibleFields,\n filterData,\n }),\n [\n data,\n remove,\n update,\n set,\n getValue,\n reduceToVisibleFields,\n filterData,\n ]\n )\n}\n"],"mappings":";;AAAA,SACEA,WAAW,EACXC,UAAU,EACVC,OAAO,EACPC,UAAU,EACVC,MAAM,QACD,OAAO;AACd,OAAOC,OAAO,MAAM,cAAc;AAClC,SAEEC,cAAc,QACT,2CAA2C;AAClD,OAAOC,cAAc,MAAM,2CAA2C;AAEtE,OAAOC,WAAW,MAIX,2BAA2B;AAsDlC,eAAe,SAASC,OAAOA,CAC7BC,EAAiB,GAAGC,SAAS,EAC7BC,WAAiB,GAAGD,SAAS,EACR;EACrB,MAAME,aAAa,GACjBT,MAAM,CAA0C,IAAI,CAAC;EACvD,MAAMU,oBAAoB,GACxBV,MAAM,CAA4D,IAAI,CAAC;EACzE,MAAM,GAAGW,WAAW,CAAC,GAAGZ,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAElDU,aAAa,CAACG,OAAO,GAAGV,cAAc,CACpCI,EAAE,EACFE,WAAW,EACXG,WACF,CAAC;EAEDD,oBAAoB,CAACE,OAAO,GAAGV,cAAc,CAC3CI,EAAE,GAAG,cAAc,EACnB;IAAEO,mBAAmB,EAAEF;EAAY,CACrC,CAAC;EAGD,MAAMG,OAAO,GAAGjB,UAAU,CAACO,WAAW,CAAC;EACvC,IAAI,CAACE,EAAE,EAAE;IACP,IAAI,EAACQ,OAAO,aAAPA,OAAO,eAAPA,OAAO,CAAEC,UAAU,GAAE;MACxB,MAAM,IAAIC,KAAK,CACb,2EACF,CAAC;IACH;IAEA,IAAIF,OAAO,EAAE;MACXL,aAAa,CAACG,OAAO,CAACK,IAAI,GAAGH,OAAO,CAACG,IAAI;MACzCP,oBAAoB,CAACE,OAAO,CAACK,IAAI,CAACC,iBAAiB,GACjDJ,OAAO,CAACI,iBAAiB;IAC7B;EACF;EAEA,MAAMC,eAAe,GAAGL,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEK,eAAe;EAChD,MAAMC,OAAO,GAAGN,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEM,OAAO;EAEhC,MAAMC,GAAG,GAAGzB,WAAW,CACpB0B,OAAa,IAAK;IACjB,IAAIhB,EAAE,EAAE;MACNG,aAAa,CAACG,OAAO,CAACW,MAAM,CAACD,OAAO,CAAC;IACvC,CAAC,MAAM;MACLF,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAGE,OAAO,CAAC;IACpB;EACF,CAAC,EACD,CAAChB,EAAE,EAAEc,OAAO,CACd,CAAC;EAED,MAAMG,MAAM,GAAG3B,WAAW,CACxB,CAAC4B,IAAI,EAAEC,KAAK,GAAGlB,SAAS,KAAK;IAC3B,MAAMmB,YAAY,GAAGC,eAAe,CAClClB,aAAa,CAACG,OAAO,CAACK,IAAI,IAAK,CAAC,CAClC,CAAC;IACD,MAAMW,aAAa,GAAG3B,OAAO,CAAC4B,GAAG,CAACH,YAAY,EAAEF,IAAI,CAAC,GACjDvB,OAAO,CAAC6B,GAAG,CAACJ,YAAY,EAAEF,IAAI,CAAC,GAC/BjB,SAAS;IAGb,MAAMwB,QAAQ,GACZ,OAAON,KAAK,KAAK,UAAU,GAAGA,KAAK,CAACG,aAAa,CAAC,GAAGH,KAAK;IAE5D,IAAIM,QAAQ,KAAKH,aAAa,EAAE;MAE9B3B,OAAO,CAACoB,GAAG,CAACK,YAAY,EAAEF,IAAI,EAAEO,QAAQ,CAAC;MAGzC,IAAIzB,EAAE,EAAE;QACNG,aAAa,CAACG,OAAO,CAACoB,MAAM,CAACN,YAAY,CAAC;MAC5C,CAAC,MAAM;QACLP,eAAe,CAACK,IAAI,EAAEO,QAAQ,CAAC;MACjC;IACF;EACF,CAAC,EACD,CAACzB,EAAE,EAAEa,eAAe,CACtB,CAAC;EAED,MAAMc,MAAM,GAAGrC,WAAW,CACvB4B,IAAI,IAAK;IACR,MAAME,YAAY,GAAGC,eAAe,CAClClB,aAAa,CAACG,OAAO,CAACK,IAAI,IAAK,CAAC,CAClC,CAAC;IAED,IAAIhB,OAAO,CAAC4B,GAAG,CAACH,YAAY,EAAEF,IAAI,CAAC,EAAE;MAEnCvB,OAAO,CAACgC,MAAM,CAACP,YAAY,EAAEF,IAAI,CAAC;MAGlC,IAAIlB,EAAE,EAAE;QACNG,aAAa,CAACG,OAAO,CAACS,GAAG,CAACK,YAAY,CAAC;MACzC,CAAC,MAAM;QACLP,eAAe,CAACK,IAAI,EAAEjB,SAAS,CAAC;MAClC;IACF;EACF,CAAC,EACD,CAACD,EAAE,EAAEa,eAAe,CACtB,CAAC;EAED,MAAMe,qBAAqB,GAAGtC,WAAW,CAGvC,CAACqB,IAAI,EAAEkB,OAAO,GAAG,CAAC,CAAC,KAAK;IAAA,IAAAC,qBAAA;IACtB,IAAI9B,EAAE,EAAE;MAAA,IAAA+B,qBAAA,EAAAC,sBAAA;MACN,QAAAD,qBAAA,GAAO3B,oBAAoB,CAACE,OAAO,CAACK,IAAI,cAAAoB,qBAAA,wBAAAC,sBAAA,GAAjCD,qBAAA,CAAmCE,kBAAkB,cAAAD,sBAAA,uBAArDA,sBAAA,CAAAE,IAAA,CAAAH,qBAAA,EACLpB,IAAI,EACJkB,OACF,CAAC;IACH;IAEA,OAAOrB,OAAO,aAAPA,OAAO,wBAAAsB,qBAAA,GAAPtB,OAAO,CAAEyB,kBAAkB,cAAAH,qBAAA,uBAA3BA,qBAAA,CAAAI,IAAA,CAAA1B,OAAO,EAAuBG,IAAI,EAAEkB,OAAO,CAAC;EACrD,CAAC,EACD,CAACrB,OAAO,EAAER,EAAE,CACd,CAAC;EAED,MAAMmC,UAAU,GAAG7C,WAAW,CAC5B,CAAC8C,MAAM,EAAEzB,IAAI,GAAGR,aAAa,CAACG,OAAO,CAACK,IAAI,KAAK;IAAA,IAAA0B,qBAAA;IAC7C,IAAIrC,EAAE,EAAE;MAAA,IAAAsC,sBAAA,EAAAC,sBAAA;MACN,QAAAD,sBAAA,GAAOlC,oBAAoB,CAACE,OAAO,CAACK,IAAI,cAAA2B,sBAAA,wBAAAC,sBAAA,GAAjCD,sBAAA,CAAmC1B,iBAAiB,cAAA2B,sBAAA,uBAApDA,sBAAA,CAAAL,IAAA,CAAAI,sBAAA,EACL3B,IAAI,EACJyB,MACF,CAAC;IACH;IAEA,OAAO5B,OAAO,aAAPA,OAAO,wBAAA6B,qBAAA,GAAP7B,OAAO,CAAEI,iBAAiB,cAAAyB,qBAAA,uBAA1BA,qBAAA,CAAAH,IAAA,CAAA1B,OAAO,EAAsBG,IAAI,EAAEyB,MAAM,CAAC;EACnD,CAAC,EACD,CAAC5B,OAAO,EAAER,EAAE,CACd,CAAC;EAED,MAAMwC,QAAQ,GAAGlD,WAAW,CAAmC4B,IAAI,IAAK;IACtE,IAAIvB,OAAO,CAAC4B,GAAG,CAACpB,aAAa,CAACG,OAAO,CAACK,IAAI,EAAEO,IAAI,CAAC,EAAE;MACjD,OAAOvB,OAAO,CAAC6B,GAAG,CAACrB,aAAa,CAACG,OAAO,CAACK,IAAI,EAAEO,IAAI,CAAC;IACtD;IAEA,OAAOjB,SAAS;EAClB,CAAC,EAAE,EAAE,CAAC;EAENJ,cAAc,CAAC,MAAM;IACnB,IAAIG,EAAE,IAAI,CAACG,aAAa,CAACG,OAAO,CAACmC,cAAc,IAAIvC,WAAW,EAAE;MAC9DC,aAAa,CAACG,OAAO,CAACoB,MAAM,CAACxB,WAAW,CAAC;IAC3C;EACF,CAAC,CAAC;EAEF,MAAM;IAAES;EAAK,CAAC,GAAGR,aAAa,CAACG,OAAO;EAEtC,OAAOd,OAAO,CACZ,OAAO;IACLmB,IAAI;IACJgB,MAAM;IACNV,MAAM;IACNF,GAAG;IACHyB,QAAQ;IACRZ,qBAAqB;IACrBO;EACF,CAAC,CAAC,EACF,CACExB,IAAI,EACJgB,MAAM,EACNV,MAAM,EACNF,GAAG,EACHyB,QAAQ,EACRZ,qBAAqB,EACrBO,UAAU,CAEd,CAAC;AACH"}
@@ -3,12 +3,12 @@
3
3
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
4
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
5
5
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
6
- import React, { useMemo, useRef, useEffect, useReducer, createRef, useContext, Fragment } from 'react';
6
+ import React, { useMemo, useRef, useEffect, useReducer, createRef, useContext } from 'react';
7
7
  import classnames from 'classnames';
8
8
  import pointer from 'json-pointer';
9
9
  import { useFieldProps } from '../../hooks';
10
10
  import { makeUniqueId } from '../../../../shared/component-helper';
11
- import { Flex, FormStatus } from '../../../../components';
11
+ import { Flex, FormStatus, HeightAnimation } from '../../../../components';
12
12
  import { pickSpacingProps } from '../../../../components/flex/utils';
13
13
  import useMountEffect from '../../../../shared/helpers/useMountEffect';
14
14
  import { pickFlexContainerProps } from '../../../../components/flex/Container';
@@ -18,7 +18,7 @@ import ValueBlockContext from '../../ValueBlock/ValueBlockContext';
18
18
  import FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider';
19
19
  import DataContext from '../../DataContext/Context';
20
20
  import useDataValue from '../../hooks/useDataValue';
21
- import { useSwitchContainerMode } from '../hooks';
21
+ import { useArrayLimit, useSwitchContainerMode } from '../hooks';
22
22
  import { getMessage } from '../../FieldBlock';
23
23
  import structuredClone from '@ungap/structured-clone';
24
24
  function ArrayComponent(props) {
@@ -26,6 +26,12 @@ function ArrayComponent(props) {
26
26
  const [salt, forceUpdate] = useReducer(() => ({}), {});
27
27
  const summaryListContext = useContext(SummaryListContext);
28
28
  const valueBlockContext = useContext(ValueBlockContext);
29
+ const {
30
+ setLimitProps,
31
+ error: limitWarning
32
+ } = useArrayLimit({
33
+ path: props.path
34
+ });
29
35
  const {
30
36
  getValueByPath
31
37
  } = useDataValue();
@@ -54,22 +60,28 @@ function ArrayComponent(props) {
54
60
  index: i
55
61
  }));
56
62
  }
57
- return _objectSpread(_objectSpread({}, props), {}, {
63
+ return _objectSpread(_objectSpread({
64
+ required: false
65
+ }, props), {}, {
58
66
  value: newValue
59
67
  });
60
68
  }
61
69
  }
62
- return props;
70
+ return _objectSpread({
71
+ required: false
72
+ }, props);
63
73
  }, [getValueByPath, props]);
64
74
  const {
65
75
  path,
66
76
  value: arrayValue,
77
+ limit,
67
78
  error,
68
79
  defaultValue,
69
80
  withoutFlex,
70
81
  emptyValue,
71
82
  placeholder,
72
83
  containerMode,
84
+ animate,
73
85
  handleChange,
74
86
  setChanged,
75
87
  onChange,
@@ -102,8 +114,10 @@ function ArrayComponent(props) {
102
114
  getNextContainerMode
103
115
  } = useSwitchContainerMode();
104
116
  const arrayItems = useMemo(() => {
105
- const list = valueWhileClosingRef.current || arrayValue;
106
- return (list !== null && list !== void 0 ? list : []).map((value, index) => {
117
+ var _ref;
118
+ const list = (_ref = valueWhileClosingRef.current || arrayValue) !== null && _ref !== void 0 ? _ref : [];
119
+ const limitedList = typeof limit === 'number' ? list.slice(0, limit) : list;
120
+ return limitedList.map((value, index) => {
107
121
  var _valueCountRef$curren, _modesRef$current$id;
108
122
  const id = idsRef.current[index] || makeUniqueId();
109
123
  const hasNewItems = (arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue.length) > ((_valueCountRef$curren = valueCountRef.current) === null || _valueCountRef$curren === void 0 ? void 0 : _valueCountRef$curren.length);
@@ -177,7 +191,16 @@ function ArrayComponent(props) {
177
191
  };
178
192
  return itemContext;
179
193
  });
180
- }, [salt, arrayValue, path, handleChange]);
194
+ }, [salt, arrayValue, limit, path, handleChange]);
195
+ const total = arrayItems.length;
196
+ useEffect(() => {
197
+ if (limit) {
198
+ setLimitProps({
199
+ limit,
200
+ total
201
+ });
202
+ }
203
+ }, [total, limit, setLimitProps]);
181
204
  useMemo(() => {
182
205
  const last = arrayItems === null || arrayItems === void 0 ? void 0 : arrayItems[arrayItems.length - 1];
183
206
  if (last !== null && last !== void 0 && last.isNew && !hadPushRef.current) {
@@ -191,8 +214,7 @@ function ArrayComponent(props) {
191
214
  }, pickFlexContainerProps(props)), pickSpacingProps(props)), {}, {
192
215
  innerRef: containerRef
193
216
  });
194
- const WrapperElement = omitFlex ? Fragment : Flex.Stack;
195
- return React.createElement(React.Fragment, null, React.createElement(WrapperElement, omitFlex ? null : flexProps, arrayValue === emptyValue || (props === null || props === void 0 ? void 0 : (_props$value = props.value) === null || _props$value === void 0 ? void 0 : _props$value.length) === 0 ? placeholder : arrayItems.map(itemProps => {
217
+ const arrayElements = arrayValue === emptyValue || (props === null || props === void 0 ? void 0 : (_props$value = props.value) === null || _props$value === void 0 ? void 0 : _props$value.length) === 0 ? placeholder : arrayItems.map(itemProps => {
196
218
  const {
197
219
  id,
198
220
  value,
@@ -220,19 +242,20 @@ function ArrayComponent(props) {
220
242
  }, React.createElement(IterateItemContext.Provider, {
221
243
  value: contextValue
222
244
  }, React.createElement(FieldBoundaryProvider, null, content)));
223
- })), React.createElement(FormStatus, {
224
- top: 0,
225
- bottom: 0,
226
- show: Boolean(error),
227
- no_animation: false,
245
+ });
246
+ const content = omitFlex ? arrayElements : React.createElement(Flex.Stack, flexProps, arrayElements);
247
+ return React.createElement(React.Fragment, null, animate ? React.createElement(HeightAnimation, null, content) : content, React.createElement(FormStatus, {
248
+ show: Boolean(error || limitWarning),
249
+ state: !error && limitWarning ? 'warning' : undefined,
228
250
  shellSpace: {
229
- top: true,
230
- bottom: true
231
- }
251
+ top: 0,
252
+ bottom: 'medium'
253
+ },
254
+ no_animation: false
232
255
  }, getMessage({
233
- content: error
256
+ content: error || limitWarning
234
257
  })));
235
258
  }
236
- ArrayComponent._supportsSpacingProps = false;
259
+ ArrayComponent._supportsSpacingProps = true;
237
260
  export default ArrayComponent;
238
261
  //# sourceMappingURL=Array.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","Fragment","classnames","pointer","useFieldProps","makeUniqueId","Flex","FormStatus","pickSpacingProps","useMountEffect","pickFlexContainerProps","IterateItemContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","DataContext","useDataValue","useSwitchContainerMode","getMessage","structuredClone","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","getValueByPath","preparedProps","path","countPath","countPathLimit","Infinity","countPathTransform","arrayValue","countValue","parseFloat","length","newValue","i","l","value","push","index","_objectSpread","error","defaultValue","withoutFlex","emptyValue","placeholder","containerMode","handleChange","setChanged","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","handlePathChange","current","getNextContainerMode","arrayItems","list","map","_valueCountRef$curren","_modesRef$current$id","id","hasNewItems","isNew","_getNextContainerMode","itemContext","previousContainerMode","previous","initialContainerMode","modeOptions","options","switchContainerMode","mode","_isNewRef$current","newArrayValue","set","handlePush","element","handleRemove","keepItems","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","last","flexProps","className","innerRef","WrapperElement","Stack","createElement","itemProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","top","bottom","show","Boolean","no_animation","shellSpace","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n Fragment,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex, FormStatus } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { useSwitchContainerMode } from '../hooks'\nimport { getMessage } from '../../FieldBlock'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n\n const { getValueByPath } = useDataValue()\n const preparedProps = useMemo(() => {\n const {\n path,\n countPath,\n countPathLimit = Infinity,\n countPathTransform,\n } = props\n\n if (countPath) {\n const arrayValue = getValueByPath(path)\n let countValue = parseFloat(getValueByPath(countPath))\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n if (arrayValue?.length !== countValue) {\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(countPathTransform?.({ value, index: i }))\n }\n\n return {\n ...props,\n value: newValue,\n }\n }\n }\n\n return props\n }, [getValueByPath, props])\n\n const {\n path,\n value: arrayValue,\n error,\n defaultValue,\n withoutFlex,\n emptyValue,\n placeholder,\n containerMode,\n handleChange,\n setChanged,\n onChange,\n children,\n } = useFieldProps(preparedProps)\n\n useMountEffect(() => {\n // To ensure the validator is called when a new item is added\n setChanged(true)\n })\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<\n Record<\n Identifier,\n {\n current: ContainerMode\n previous?: ContainerMode\n options?: { omitFocusManagement?: boolean }\n }\n >\n >({})\n const valueWhileClosingRef = useRef<Value>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n // To support React.StrictMode, we inject the defaultValue into the data context this way.\n // The routine inside useFieldProps where updateDataValueDataContext is called, does not support React.StrictMode\n const { handlePathChange } = useContext(DataContext) || {}\n useMountEffect(() => {\n if (defaultValue) {\n handlePathChange?.(path, defaultValue)\n }\n })\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const { getNextContainerMode } = useSwitchContainerMode()\n\n const arrayItems = useMemo(() => {\n const list = valueWhileClosingRef.current || arrayValue\n return (list ?? []).map((value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue?.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]?.current) {\n modesRef.current[id] = {\n current:\n containerMode ??\n (isNew ? getNextContainerMode() ?? 'edit' : 'auto'),\n }\n }\n\n const itemContext: IterateItemContextState = {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id].current,\n previousContainerMode: modesRef.current[id].previous,\n initialContainerMode: containerMode || 'auto',\n modeOptions: modesRef.current[id].options,\n switchContainerMode: (mode, options = {}) => {\n modesRef.current[id].previous = modesRef.current[id].current\n modesRef.current[id].current = mode\n modesRef.current[id].options = options\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path, value) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element) => {\n hadPushRef.current = true\n handleChange([...(arrayValue || []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value) => {\n if (value) {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n }\n },\n }\n\n return itemContext\n })\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, path, handleChange])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = arrayItems?.[arrayItems.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, arrayItems, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames(\n 'dnb-forms-iterate',\n 'dnb-forms-section',\n props?.className\n ),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const WrapperElement = omitFlex ? Fragment : Flex.Stack\n\n return (\n <>\n <WrapperElement {...(omitFlex ? null : flexProps)}>\n {arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : arrayItems.map((itemProps) => {\n const { id, value, index } = itemProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...itemProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateItemContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>\n {content}\n </FieldBoundaryProvider>\n </IterateItemContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateItemContext.Provider value={contextValue}>\n <FieldBoundaryProvider>\n {content}\n </FieldBoundaryProvider>\n </IterateItemContext.Provider>\n </Flex.Item>\n )\n })}\n </WrapperElement>\n\n <FormStatus\n top={0}\n bottom={0}\n show={Boolean(error)}\n no_animation={false}\n shellSpace={{ top: true, bottom: true }}\n >\n {getMessage({ content: error })}\n </FormStatus>\n </>\n )\n}\n\nArrayComponent._supportsSpacingProps = false // disable flex support to avoid rerender, which could result in flickering\nexport default ArrayComponent\n"],"mappings":"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"}
1
+ {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","classnames","pointer","useFieldProps","makeUniqueId","Flex","FormStatus","HeightAnimation","pickSpacingProps","useMountEffect","pickFlexContainerProps","IterateItemContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","DataContext","useDataValue","useArrayLimit","useSwitchContainerMode","getMessage","structuredClone","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","setLimitProps","error","limitWarning","path","getValueByPath","preparedProps","countPath","countPathLimit","Infinity","countPathTransform","arrayValue","countValue","parseFloat","length","newValue","i","l","value","push","index","_objectSpread","required","limit","defaultValue","withoutFlex","emptyValue","placeholder","containerMode","animate","handleChange","setChanged","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","handlePathChange","current","getNextContainerMode","arrayItems","_ref","list","limitedList","slice","map","_valueCountRef$curren","_modesRef$current$id","id","hasNewItems","isNew","_getNextContainerMode","itemContext","previousContainerMode","previous","initialContainerMode","modeOptions","options","switchContainerMode","mode","_isNewRef$current","newArrayValue","set","handlePush","element","handleRemove","keepItems","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","total","last","flexProps","className","innerRef","arrayElements","itemProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","createElement","Provider","key","Item","tabIndex","Stack","Fragment","show","Boolean","state","undefined","shellSpace","top","bottom","no_animation","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex, FormStatus, HeightAnimation } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport { useArrayLimit, useSwitchContainerMode } from '../hooks'\nimport { getMessage } from '../../FieldBlock'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n const { setLimitProps, error: limitWarning } = useArrayLimit({\n path: props.path,\n })\n\n const { getValueByPath } = useDataValue()\n const preparedProps = useMemo(() => {\n const {\n path,\n countPath,\n countPathLimit = Infinity,\n countPathTransform,\n } = props\n\n if (countPath) {\n const arrayValue = getValueByPath(path)\n let countValue = parseFloat(getValueByPath(countPath))\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n if (arrayValue?.length !== countValue) {\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(countPathTransform?.({ value, index: i }))\n }\n\n return {\n required: false,\n ...props,\n value: newValue,\n }\n }\n }\n\n return { required: false, ...props }\n }, [getValueByPath, props])\n\n const {\n path,\n value: arrayValue,\n limit,\n error,\n defaultValue,\n withoutFlex,\n emptyValue,\n placeholder,\n containerMode,\n animate,\n handleChange,\n setChanged,\n onChange,\n children,\n } = useFieldProps(preparedProps)\n\n useMountEffect(() => {\n // To ensure the validator is called when a new item is added\n setChanged(true)\n })\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<\n Record<\n Identifier,\n {\n current: ContainerMode\n previous?: ContainerMode\n options?: { omitFocusManagement?: boolean }\n }\n >\n >({})\n const valueWhileClosingRef = useRef<Value>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n // To support React.StrictMode, we inject the defaultValue into the data context this way.\n // The routine inside useFieldProps where updateDataValueDataContext is called, does not support React.StrictMode\n const { handlePathChange } = useContext(DataContext) || {}\n useMountEffect(() => {\n if (defaultValue) {\n handlePathChange?.(path, defaultValue)\n }\n })\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const { getNextContainerMode } = useSwitchContainerMode()\n\n const arrayItems = useMemo(() => {\n const list = (valueWhileClosingRef.current || arrayValue) ?? []\n const limitedList =\n typeof limit === 'number' ? list.slice(0, limit) : list\n\n return limitedList.map((value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue?.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]?.current) {\n modesRef.current[id] = {\n current:\n containerMode ??\n (isNew ? getNextContainerMode() ?? 'edit' : 'auto'),\n }\n }\n\n const itemContext: IterateItemContextState = {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id].current,\n previousContainerMode: modesRef.current[id].previous,\n initialContainerMode: containerMode || 'auto',\n modeOptions: modesRef.current[id].options,\n switchContainerMode: (mode, options = {}) => {\n modesRef.current[id].previous = modesRef.current[id].current\n modesRef.current[id].current = mode\n modesRef.current[id].options = options\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path, value) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element) => {\n hadPushRef.current = true\n handleChange([...(arrayValue || []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value) => {\n if (value) {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n }\n },\n }\n\n return itemContext\n })\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, limit, path, handleChange])\n\n const total = arrayItems.length\n useEffect(() => {\n if (limit) {\n setLimitProps({ limit, total })\n }\n }, [total, limit, setLimitProps])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = arrayItems?.[arrayItems.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, arrayItems, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames(\n 'dnb-forms-iterate',\n 'dnb-forms-section',\n props?.className\n ),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const arrayElements =\n arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : arrayItems.map((itemProps) => {\n const { id, value, index } = itemProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...itemProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateItemContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateItemContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateItemContext.Provider>\n </Flex.Item>\n )\n })\n\n const content = omitFlex ? (\n arrayElements\n ) : (\n <Flex.Stack {...flexProps}>{arrayElements}</Flex.Stack>\n )\n\n return (\n <>\n {animate ? <HeightAnimation>{content}</HeightAnimation> : content}\n\n <FormStatus\n show={Boolean(error || limitWarning)}\n state={!error && limitWarning ? 'warning' : undefined}\n shellSpace={{ top: 0, bottom: 'medium' }}\n no_animation={false}\n >\n {getMessage({ content: error || limitWarning })}\n </FormStatus>\n </>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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"}
@@ -10,6 +10,11 @@ export const ArrayProperties = {
10
10
  type: 'string',
11
11
  status: 'optional'
12
12
  },
13
+ limit: {
14
+ doc: 'Limit the number of rendered items to iterate over. Defaults to `undefined`.',
15
+ type: 'number',
16
+ status: 'optional'
17
+ },
13
18
  countPath: {
14
19
  doc: 'A path (JSON Pointer) to the array length.',
15
20
  type: 'string',
@@ -30,6 +35,11 @@ export const ArrayProperties = {
30
35
  type: 'boolean',
31
36
  status: 'optional'
32
37
  },
38
+ animate: {
39
+ doc: 'When `true` it will animate the height of the items.',
40
+ type: 'boolean',
41
+ status: 'optional'
42
+ },
33
43
  placeholder: {
34
44
  doc: 'Will be shown if the value or data context value is empty.',
35
45
  type: 'React.Node',
@@ -50,7 +60,7 @@ export const ArrayProperties = {
50
60
  },
51
61
  children: {
52
62
  doc: 'React.Node or a function so you can get the current value and index.',
53
- type: 'boolean',
63
+ type: ['React.ReactNode', 'function'],
54
64
  status: 'optional'
55
65
  },
56
66
  '[Flex.Stack](/uilib/layout/flex/stack/)': {
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayDocs.js","names":["dataValueProperties","ArrayProperties","value","doc","type","status","path","countPath","countPathTransform","countPathLimit","withoutFlex","placeholder","emptyValue","validator","validateInitially","continuousValidation","containerMode","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { dataValueProperties } from '../../hooks/DataValueDocs'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n validator: dataValueProperties.validator,\n validateInitially: dataValueProperties.validateInitially,\n continuousValidation: dataValueProperties.continuousValidation,\n containerMode: {\n doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: 'boolean',\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AACA,SAASA,mBAAmB,QAAQ,2BAA2B;AAE/D,OAAO,MAAMC,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,SAAS,EAAE;IACTJ,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,cAAc,EAAE;IACdN,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,WAAW,EAAE;IACXP,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDO,UAAU,EAAE;IACVT,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,SAAS,EAAEb,mBAAmB,CAACa,SAAS;EACxCC,iBAAiB,EAAEd,mBAAmB,CAACc,iBAAiB;EACxDC,oBAAoB,EAAEf,mBAAmB,CAACe,oBAAoB;EAC9DC,aAAa,EAAE;IACbb,GAAG,EAAE,0SAA0S;IAC/SC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDY,QAAQ,EAAE;IACRd,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMa,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRhB,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"ArrayDocs.js","names":["dataValueProperties","ArrayProperties","value","doc","type","status","path","limit","countPath","countPathTransform","countPathLimit","withoutFlex","animate","placeholder","emptyValue","validator","validateInitially","continuousValidation","containerMode","children","ArrayEvents","onChange"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { dataValueProperties } from '../../hooks/DataValueDocs'\n\nexport const ArrayProperties: PropertiesTableProps = {\n value: {\n doc: 'The data to iterate over. Alternative you can use the `path` prop.',\n type: 'array',\n status: 'optional',\n },\n path: {\n doc: 'A path (JSON Pointer) to the array to iterate over.',\n type: 'string',\n status: 'optional',\n },\n limit: {\n doc: 'Limit the number of rendered items to iterate over. Defaults to `undefined`.',\n type: 'number',\n status: 'optional',\n },\n countPath: {\n doc: 'A path (JSON Pointer) to the array length.',\n type: 'string',\n status: 'optional',\n },\n countPathTransform: {\n doc: 'Will transform the current value before it is displayed.',\n type: 'function',\n status: 'optional',\n },\n countPathLimit: {\n doc: 'Will limit the iterate amount by given \"countPathLimit\" value.',\n type: 'number',\n status: 'optional',\n },\n withoutFlex: {\n doc: 'When `true` it will omit the Flex.Stack wrapper so it can be used for tables and lists.',\n type: 'boolean',\n status: 'optional',\n },\n animate: {\n doc: 'When `true` it will animate the height of the items.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Will be shown if the value or data context value is empty.',\n type: 'React.Node',\n status: 'optional',\n },\n emptyValue: {\n doc: 'Will be used to compare the value in order to show the placeholder.',\n type: 'unknown',\n status: 'optional',\n },\n validator: dataValueProperties.validator,\n validateInitially: dataValueProperties.validateInitially,\n continuousValidation: dataValueProperties.continuousValidation,\n containerMode: {\n doc: 'Defines the container mode for all nested containers. Can be `view`, `edit` or `auto`. When using `auto`, it will automatically open if there is an error in the container. When a new item is added, the item before it will change to `view` mode, if it had no validation errors. Defaults to `auto`.',\n type: 'string',\n status: 'optional',\n },\n children: {\n doc: 'React.Node or a function so you can get the current value and index.',\n type: ['React.ReactNode', 'function'],\n status: 'optional',\n },\n '[Flex.Stack](/uilib/layout/flex/stack/)': {\n doc: 'All Flex.Stack properties.',\n type: 'Various',\n status: 'optional',\n },\n}\n\nexport const ArrayEvents: PropertiesTableProps = {\n onChange: {\n doc: 'Will be called when a value of a field was changed by the user, with the data set (including the changed value) as argument.',\n type: 'function',\n status: 'optional',\n },\n}\n"],"mappings":"AACA,SAASA,mBAAmB,QAAQ,2BAA2B;AAE/D,OAAO,MAAMC,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oEAAoE;IACzEC,IAAI,EAAE,OAAO;IACbC,MAAM,EAAE;EACV,CAAC;EACDC,IAAI,EAAE;IACJH,GAAG,EAAE,qDAAqD;IAC1DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDE,KAAK,EAAE;IACLJ,GAAG,EAAE,8EAA8E;IACnFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,SAAS,EAAE;IACTL,GAAG,EAAE,4CAA4C;IACjDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDI,kBAAkB,EAAE;IAClBN,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDK,cAAc,EAAE;IACdP,GAAG,EAAE,gEAAgE;IACrEC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,yFAAyF;IAC9FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDO,OAAO,EAAE;IACPT,GAAG,EAAE,sDAAsD;IAC3DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDQ,WAAW,EAAE;IACXV,GAAG,EAAE,4DAA4D;IACjEC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDS,UAAU,EAAE;IACVX,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDU,SAAS,EAAEf,mBAAmB,CAACe,SAAS;EACxCC,iBAAiB,EAAEhB,mBAAmB,CAACgB,iBAAiB;EACxDC,oBAAoB,EAAEjB,mBAAmB,CAACiB,oBAAoB;EAC9DC,aAAa,EAAE;IACbf,GAAG,EAAE,0SAA0S;IAC/SC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDc,QAAQ,EAAE;IACRhB,GAAG,EAAE,sEAAsE;IAC3EC,IAAI,EAAE,CAAC,iBAAiB,EAAE,UAAU,CAAC;IACrCC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,4BAA4B;IACjCC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMe,WAAiC,GAAG;EAC/CC,QAAQ,EAAE;IACRlB,GAAG,EAAE,8HAA8H;IACnIC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -2,7 +2,7 @@ import { Props as FlexContainerProps } from '../../../../components/flex/Contain
2
2
  import { ContainerMode } from './types';
3
3
  export type ArrayItemAreaProps = {
4
4
  /**
5
- * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.
5
+ * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline` or `basic`.
6
6
  * Defaults to `outline`.
7
7
  */
8
8
  variant?: 'outline' | 'basic';
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayItemArea.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Flex","HeightAnimation","IterateItemContext","ArrayItemAreaContext","FieldBoundaryContext","ArrayItemArea","props","forceUpdate","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","_objectWithoutProperties","_excluded","localContextRef","hasError","hasSubmitError","current","nextFocusElementRef","isNew","value","containerMode","determineMode","initialContainerMode","switchContainerMode","omitFocusManagement","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","modeOptions","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","call","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","duration","keepInDOM","Stack","_extends","element","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew, value } = localContextRef.current\n if (hasSubmitError || !value) {\n localContextRef.current.containerMode = 'edit'\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n const determineMode = useCallback(() => {\n const { initialContainerMode, switchContainerMode } =\n localContextRef.current\n if (\n mode === 'edit' &&\n !hasSubmitError &&\n initialContainerMode === 'auto'\n ) {\n // - Set the container mode to \"edit\" if we have an error\n if (hasError && !isNew) {\n switchContainerMode('edit', { omitFocusManagement: true })\n }\n }\n }, [hasError, hasSubmitError, isNew, mode])\n\n useEffect(() => {\n determineMode()\n }, [determineMode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider value={{ handleRemoveItem }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":"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"}
1
+ {"version":3,"file":"ArrayItemArea.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Flex","HeightAnimation","IterateItemContext","ArrayItemAreaContext","FieldBoundaryContext","ArrayItemArea","props","forceUpdate","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","_objectWithoutProperties","_excluded","localContextRef","hasError","hasSubmitError","current","nextFocusElementRef","isNew","value","containerMode","determineMode","initialContainerMode","switchContainerMode","omitFocusManagement","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","modeOptions","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","call","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","duration","keepInDOM","Stack","_extends","element","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline` or `basic`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew, value } = localContextRef.current\n if (hasSubmitError || !value) {\n localContextRef.current.containerMode = 'edit'\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n const determineMode = useCallback(() => {\n const { initialContainerMode, switchContainerMode } =\n localContextRef.current\n if (\n mode === 'edit' &&\n !hasSubmitError &&\n initialContainerMode === 'auto'\n ) {\n // - Set the container mode to \"edit\" if we have an error\n if (hasError && !isNew) {\n switchContainerMode('edit', { omitFocusManagement: true })\n }\n }\n }, [hasError, hasSubmitError, isNew, mode])\n\n useEffect(() => {\n determineMode()\n }, [determineMode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider value={{ handleRemoveItem }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":"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"}
@@ -7,10 +7,12 @@ export type ElementChild = React.ReactNode | ((value: any, index: number) => Rea
7
7
  export type Props = Omit<FlexContainerProps, keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>> & Pick<UseFieldProps<Value, undefined | Value>, 'value' | 'defaultValue' | 'emptyValue' | 'onChange' | 'validateInitially' | 'continuousValidation'> & {
8
8
  children: ElementChild | Array<ElementChild>;
9
9
  path?: Path;
10
+ limit?: number;
10
11
  countPath?: Path;
11
12
  countPathLimit?: number;
12
13
  validator?: Validator<Value>;
13
14
  withoutFlex?: boolean;
15
+ animate?: boolean;
14
16
  placeholder?: React.ReactNode;
15
17
  containerMode?: ContainerMode;
16
18
  countPathTransform?: (params: {
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps, Validator } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((value: any, index: number) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n countPath?: Path\n countPathLimit?: number\n validator?: Validator<Value>\n withoutFlex?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n countPathTransform?: (params: { value: any; index: number }) => any\n }\n"],"mappings":""}
1
+ {"version":3,"file":"types.js","names":[],"sources":["../../../../../../src/extensions/forms/Iterate/Array/types.ts"],"sourcesContent":["import { Path, UseFieldProps, Validator } from '../../types'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type Value = Array<unknown | Record<string, unknown>>\nexport type ElementChild =\n | React.ReactNode\n | ((value: any, index: number) => React.ReactNode)\nexport type Props = Omit<\n FlexContainerProps,\n keyof Omit<React.HTMLAttributes<HTMLDivElement>, 'className'>\n> &\n Pick<\n UseFieldProps<Value, undefined | Value>,\n | 'value'\n | 'defaultValue'\n | 'emptyValue'\n | 'onChange'\n | 'validateInitially'\n | 'continuousValidation'\n > & {\n children: ElementChild | Array<ElementChild>\n path?: Path\n limit?: number\n countPath?: Path\n countPathLimit?: number\n validator?: Validator<Value>\n withoutFlex?: boolean\n animate?: boolean\n placeholder?: React.ReactNode\n containerMode?: ContainerMode\n countPathTransform?: (params: { value: any; index: number }) => any\n }\n"],"mappings":""}