@dnb/eufemia 10.51.2 → 10.52.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 (588) hide show
  1. package/CHANGELOG.md +44 -0
  2. package/cjs/components/autocomplete/Autocomplete.js +4 -0
  3. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  4. package/cjs/components/avatar/style/themes/dnb-avatar-theme-sbanken.css +2 -2
  5. package/cjs/components/avatar/style/themes/dnb-avatar-theme-sbanken.min.css +1 -1
  6. package/cjs/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -2
  7. package/cjs/components/dialog/style/themes/dnb-dialog-theme-sbanken.css +6 -0
  8. package/cjs/components/dialog/style/themes/dnb-dialog-theme-sbanken.min.css +1 -1
  9. package/cjs/components/dialog/style/themes/dnb-dialog-theme-sbanken.scss +7 -0
  10. package/cjs/components/form-status/FormStatus.d.ts +5 -0
  11. package/cjs/components/icon/Icon.d.ts +2 -1
  12. package/cjs/components/icon/Icon.js.map +1 -1
  13. package/cjs/components/logo/Logo.js.map +1 -1
  14. package/cjs/components/number-format/NumberUtils.d.ts +14 -0
  15. package/cjs/components/number-format/NumberUtils.js +7 -8
  16. package/cjs/components/number-format/NumberUtils.js.map +1 -1
  17. package/cjs/components/skeleton/style/dnb-skeleton.css +3 -1
  18. package/cjs/components/skeleton/style/dnb-skeleton.min.css +1 -1
  19. package/cjs/components/skeleton/style/dnb-skeleton.scss +4 -2
  20. package/cjs/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +21 -2
  21. package/cjs/extensions/forms/DataContext/Context.d.ts +5 -0
  22. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  23. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +12 -1
  24. package/cjs/extensions/forms/DataContext/Provider/Provider.js +86 -77
  25. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  26. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +6 -1
  27. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +112 -23
  28. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  29. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +5 -0
  30. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  31. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +3 -1
  32. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +28 -16
  33. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  34. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.d.ts +2 -0
  35. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +25 -0
  36. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -0
  37. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -3
  38. package/cjs/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  39. package/cjs/extensions/forms/Form/Isolation/Isolation.d.ts +4 -0
  40. package/cjs/extensions/forms/Form/Isolation/Isolation.js +26 -0
  41. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  42. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js +5 -0
  43. package/cjs/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  44. package/cjs/extensions/forms/Form/Snapshot/Snapshot.d.ts +12 -0
  45. package/cjs/extensions/forms/Form/Snapshot/Snapshot.js +45 -0
  46. package/cjs/extensions/forms/Form/Snapshot/Snapshot.js.map +1 -0
  47. package/cjs/extensions/forms/Form/Snapshot/SnapshotContext.d.ts +12 -0
  48. package/cjs/extensions/forms/Form/Snapshot/SnapshotContext.js +12 -0
  49. package/cjs/extensions/forms/Form/Snapshot/SnapshotContext.js.map +1 -0
  50. package/cjs/extensions/forms/Form/Snapshot/SnapshotDocs.d.ts +3 -0
  51. package/cjs/extensions/forms/Form/Snapshot/SnapshotDocs.js +17 -0
  52. package/cjs/extensions/forms/Form/Snapshot/SnapshotDocs.js.map +1 -0
  53. package/cjs/extensions/forms/Form/Snapshot/index.d.ts +2 -0
  54. package/cjs/extensions/forms/Form/Snapshot/index.js +27 -0
  55. package/cjs/extensions/forms/Form/Snapshot/index.js.map +1 -0
  56. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +1 -1
  57. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  58. package/cjs/extensions/forms/Form/Visibility/Visibility.d.ts +10 -2
  59. package/cjs/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  60. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js +10 -10
  61. package/cjs/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  62. package/cjs/extensions/forms/Form/Visibility/useVisibility.js +26 -14
  63. package/cjs/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  64. package/cjs/extensions/forms/Form/data-context/clearData.js +2 -5
  65. package/cjs/extensions/forms/Form/data-context/clearData.js.map +1 -1
  66. package/cjs/extensions/forms/Form/data-context/getData.js.map +1 -1
  67. package/cjs/extensions/forms/Form/data-context/useData.js +3 -2
  68. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  69. package/cjs/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  70. package/cjs/extensions/forms/Form/index.d.ts +2 -0
  71. package/cjs/extensions/forms/Form/index.js +14 -0
  72. package/cjs/extensions/forms/Form/index.js.map +1 -1
  73. package/cjs/extensions/forms/Iterate/Array/Array.js +3 -1
  74. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  75. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js +30 -17
  76. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  77. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +5 -6
  78. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  79. package/cjs/extensions/forms/Iterate/ItemNo/ItemNo.d.ts +9 -0
  80. package/cjs/extensions/forms/Iterate/ItemNo/ItemNo.js +33 -0
  81. package/cjs/extensions/forms/Iterate/ItemNo/ItemNo.js.map +1 -0
  82. package/cjs/extensions/forms/Iterate/ItemNo/index.d.ts +2 -0
  83. package/cjs/extensions/forms/Iterate/ItemNo/index.js +27 -0
  84. package/cjs/extensions/forms/Iterate/ItemNo/index.js.map +1 -0
  85. package/cjs/extensions/forms/Iterate/IterateItemContext.d.ts +1 -0
  86. package/cjs/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  87. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +18 -2
  88. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +44 -18
  89. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  90. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +24 -1
  91. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  92. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +5 -6
  93. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  94. package/cjs/extensions/forms/Iterate/index.d.ts +1 -0
  95. package/cjs/extensions/forms/Iterate/index.js +7 -0
  96. package/cjs/extensions/forms/Iterate/index.js.map +1 -1
  97. package/cjs/extensions/forms/Tools/Log.d.ts +7 -2
  98. package/cjs/extensions/forms/Tools/Log.js +36 -4
  99. package/cjs/extensions/forms/Tools/Log.js.map +1 -1
  100. package/cjs/extensions/forms/Value/Provider/useValueProvider.d.ts +1 -0
  101. package/cjs/extensions/forms/Value/SummaryList/SummaryList.d.ts +4 -2
  102. package/cjs/extensions/forms/Value/SummaryList/SummaryList.js +3 -1
  103. package/cjs/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  104. package/cjs/extensions/forms/Value/SummaryList/SummaryListDocs.js +5 -0
  105. package/cjs/extensions/forms/Value/SummaryList/SummaryListDocs.js.map +1 -1
  106. package/cjs/extensions/forms/Value/ValueDocs.js +5 -0
  107. package/cjs/extensions/forms/Value/ValueDocs.js.map +1 -1
  108. package/cjs/extensions/forms/Wizard/Buttons/Buttons.js +2 -2
  109. package/cjs/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  110. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +78 -31
  111. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  112. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  113. package/cjs/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  114. package/cjs/extensions/forms/Wizard/Container/useHandleLayoutEffect.d.ts +1 -2
  115. package/cjs/extensions/forms/Wizard/Container/useHandleLayoutEffect.js +0 -7
  116. package/cjs/extensions/forms/Wizard/Container/useHandleLayoutEffect.js.map +1 -1
  117. package/cjs/extensions/forms/Wizard/Container/useStepAnimation.d.ts +2 -1
  118. package/cjs/extensions/forms/Wizard/Container/useStepAnimation.js +11 -6
  119. package/cjs/extensions/forms/Wizard/Container/useStepAnimation.js.map +1 -1
  120. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +14 -3
  121. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  122. package/cjs/extensions/forms/Wizard/Step/Step.js +4 -4
  123. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  124. package/cjs/extensions/forms/Wizard/hooks/useStep.js +4 -4
  125. package/cjs/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  126. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +6 -1
  127. package/cjs/extensions/forms/constants/locales/en-GB.js +9 -4
  128. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  129. package/cjs/extensions/forms/constants/locales/en-US.d.ts +6 -1
  130. package/cjs/extensions/forms/constants/locales/en-US.js +2 -1
  131. package/cjs/extensions/forms/constants/locales/en-US.js.map +1 -1
  132. package/cjs/extensions/forms/constants/locales/index.d.ts +12 -2
  133. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +6 -1
  134. package/cjs/extensions/forms/constants/locales/nb-NO.js +9 -4
  135. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  136. package/cjs/extensions/forms/hooks/useDataContext.d.ts +6 -0
  137. package/cjs/extensions/forms/hooks/useDataContext.js +31 -0
  138. package/cjs/extensions/forms/hooks/useDataContext.js.map +1 -0
  139. package/cjs/extensions/forms/hooks/useExternalValue.js +12 -6
  140. package/cjs/extensions/forms/hooks/useExternalValue.js.map +1 -1
  141. package/cjs/extensions/forms/hooks/useFieldProps.js +82 -43
  142. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  143. package/cjs/extensions/forms/hooks/useSnapshot.d.ts +9 -0
  144. package/cjs/extensions/forms/hooks/useSnapshot.js +87 -0
  145. package/cjs/extensions/forms/hooks/useSnapshot.js.map +1 -0
  146. package/cjs/extensions/forms/hooks/useValueProps.js +6 -1
  147. package/cjs/extensions/forms/hooks/useValueProps.js.map +1 -1
  148. package/cjs/extensions/forms/types.d.ts +4 -0
  149. package/cjs/extensions/forms/types.js.map +1 -1
  150. package/cjs/extensions/payment-card/style/dnb-payment-card.css +3 -2
  151. package/cjs/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
  152. package/cjs/shared/Eufemia.d.ts +1 -1
  153. package/cjs/shared/Eufemia.js +2 -2
  154. package/cjs/shared/Eufemia.js.map +1 -1
  155. package/cjs/shared/component-helper.js +1 -1
  156. package/cjs/shared/component-helper.js.map +1 -1
  157. package/cjs/style/core/scopes.scss +1 -1
  158. package/cjs/style/dnb-ui-basis.css +1 -1
  159. package/cjs/style/dnb-ui-basis.min.css +1 -1
  160. package/cjs/style/dnb-ui-body.css +1 -1
  161. package/cjs/style/dnb-ui-body.min.css +1 -1
  162. package/cjs/style/dnb-ui-components.css +3 -1
  163. package/cjs/style/dnb-ui-components.min.css +1 -1
  164. package/cjs/style/dnb-ui-core.css +1 -1
  165. package/cjs/style/dnb-ui-core.min.css +1 -1
  166. package/cjs/style/dnb-ui-extensions.css +3 -2
  167. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  168. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +3 -1
  169. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  170. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -2
  171. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  172. package/cjs/style/themes/theme-eiendom/properties.d.ts +1 -0
  173. package/cjs/style/themes/theme-eiendom/properties.js +3 -2
  174. package/cjs/style/themes/theme-eiendom/properties.js.map +1 -1
  175. package/cjs/style/themes/theme-sbanken/properties.d.ts +1 -0
  176. package/cjs/style/themes/theme-sbanken/properties.js +3 -2
  177. package/cjs/style/themes/theme-sbanken/properties.js.map +1 -1
  178. package/cjs/style/themes/theme-sbanken/properties.scss +9 -8
  179. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +20 -4
  180. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +3 -1
  181. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +11 -3
  182. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  183. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.css +17 -2
  184. package/cjs/style/themes/theme-sbanken/sbanken-theme-elements.min.css +3 -1
  185. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -2
  186. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  187. package/cjs/style/themes/theme-ui/properties.d.ts +1 -0
  188. package/cjs/style/themes/theme-ui/properties.js +3 -2
  189. package/cjs/style/themes/theme-ui/properties.js.map +1 -1
  190. package/cjs/style/themes/theme-ui/ui-theme-components.css +3 -1
  191. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  192. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +3 -2
  193. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  194. package/components/autocomplete/Autocomplete.js +4 -0
  195. package/components/autocomplete/Autocomplete.js.map +1 -1
  196. package/components/avatar/style/themes/dnb-avatar-theme-sbanken.css +2 -2
  197. package/components/avatar/style/themes/dnb-avatar-theme-sbanken.min.css +1 -1
  198. package/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -2
  199. package/components/dialog/style/themes/dnb-dialog-theme-sbanken.css +6 -0
  200. package/components/dialog/style/themes/dnb-dialog-theme-sbanken.min.css +1 -1
  201. package/components/dialog/style/themes/dnb-dialog-theme-sbanken.scss +7 -0
  202. package/components/form-status/FormStatus.d.ts +5 -0
  203. package/components/icon/Icon.d.ts +2 -1
  204. package/components/icon/Icon.js.map +1 -1
  205. package/components/logo/Logo.js.map +1 -1
  206. package/components/number-format/NumberUtils.d.ts +14 -0
  207. package/components/number-format/NumberUtils.js +7 -8
  208. package/components/number-format/NumberUtils.js.map +1 -1
  209. package/components/skeleton/style/dnb-skeleton.css +3 -1
  210. package/components/skeleton/style/dnb-skeleton.min.css +1 -1
  211. package/components/skeleton/style/dnb-skeleton.scss +4 -2
  212. package/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +21 -2
  213. package/es/components/autocomplete/Autocomplete.js +4 -0
  214. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  215. package/es/components/avatar/style/themes/dnb-avatar-theme-sbanken.css +2 -2
  216. package/es/components/avatar/style/themes/dnb-avatar-theme-sbanken.min.css +1 -1
  217. package/es/components/avatar/style/themes/dnb-avatar-theme-sbanken.scss +2 -2
  218. package/es/components/dialog/style/themes/dnb-dialog-theme-sbanken.css +6 -0
  219. package/es/components/dialog/style/themes/dnb-dialog-theme-sbanken.min.css +1 -1
  220. package/es/components/dialog/style/themes/dnb-dialog-theme-sbanken.scss +7 -0
  221. package/es/components/form-status/FormStatus.d.ts +5 -0
  222. package/es/components/icon/Icon.d.ts +2 -1
  223. package/es/components/icon/Icon.js.map +1 -1
  224. package/es/components/logo/Logo.js.map +1 -1
  225. package/es/components/number-format/NumberUtils.d.ts +14 -0
  226. package/es/components/number-format/NumberUtils.js +7 -8
  227. package/es/components/number-format/NumberUtils.js.map +1 -1
  228. package/es/components/skeleton/style/dnb-skeleton.css +3 -1
  229. package/es/components/skeleton/style/dnb-skeleton.min.css +1 -1
  230. package/es/components/skeleton/style/dnb-skeleton.scss +4 -2
  231. package/es/elements/typography/style/themes/dnb-typography-theme-sbanken.scss +21 -2
  232. package/es/extensions/forms/DataContext/Context.d.ts +5 -0
  233. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  234. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +12 -1
  235. package/es/extensions/forms/DataContext/Provider/Provider.js +84 -75
  236. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  237. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +6 -1
  238. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +109 -23
  239. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  240. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +5 -0
  241. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  242. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +3 -1
  243. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +28 -16
  244. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  245. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.d.ts +2 -0
  246. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +18 -0
  247. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -0
  248. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -3
  249. package/es/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  250. package/es/extensions/forms/Form/Isolation/Isolation.d.ts +4 -0
  251. package/es/extensions/forms/Form/Isolation/Isolation.js +28 -3
  252. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  253. package/es/extensions/forms/Form/Isolation/IsolationDocs.js +5 -0
  254. package/es/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  255. package/es/extensions/forms/Form/Snapshot/Snapshot.d.ts +12 -0
  256. package/es/extensions/forms/Form/Snapshot/Snapshot.js +36 -0
  257. package/es/extensions/forms/Form/Snapshot/Snapshot.js.map +1 -0
  258. package/es/extensions/forms/Form/Snapshot/SnapshotContext.d.ts +12 -0
  259. package/es/extensions/forms/Form/Snapshot/SnapshotContext.js +6 -0
  260. package/es/extensions/forms/Form/Snapshot/SnapshotContext.js.map +1 -0
  261. package/es/extensions/forms/Form/Snapshot/SnapshotDocs.d.ts +3 -0
  262. package/es/extensions/forms/Form/Snapshot/SnapshotDocs.js +9 -0
  263. package/es/extensions/forms/Form/Snapshot/SnapshotDocs.js.map +1 -0
  264. package/es/extensions/forms/Form/Snapshot/index.d.ts +2 -0
  265. package/es/extensions/forms/Form/Snapshot/index.js +3 -0
  266. package/es/extensions/forms/Form/Snapshot/index.js.map +1 -0
  267. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +1 -1
  268. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  269. package/es/extensions/forms/Form/Visibility/Visibility.d.ts +10 -2
  270. package/es/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  271. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js +10 -10
  272. package/es/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  273. package/es/extensions/forms/Form/Visibility/useVisibility.js +26 -14
  274. package/es/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  275. package/es/extensions/forms/Form/data-context/clearData.js +2 -5
  276. package/es/extensions/forms/Form/data-context/clearData.js.map +1 -1
  277. package/es/extensions/forms/Form/data-context/getData.js.map +1 -1
  278. package/es/extensions/forms/Form/data-context/useData.js +1 -0
  279. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  280. package/es/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  281. package/es/extensions/forms/Form/index.d.ts +2 -0
  282. package/es/extensions/forms/Form/index.js +2 -0
  283. package/es/extensions/forms/Form/index.js.map +1 -1
  284. package/es/extensions/forms/Iterate/Array/Array.js +3 -1
  285. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  286. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +31 -18
  287. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  288. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +5 -6
  289. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  290. package/es/extensions/forms/Iterate/ItemNo/ItemNo.d.ts +9 -0
  291. package/es/extensions/forms/Iterate/ItemNo/ItemNo.js +22 -0
  292. package/es/extensions/forms/Iterate/ItemNo/ItemNo.js.map +1 -0
  293. package/es/extensions/forms/Iterate/ItemNo/index.d.ts +2 -0
  294. package/es/extensions/forms/Iterate/ItemNo/index.js +3 -0
  295. package/es/extensions/forms/Iterate/ItemNo/index.js.map +1 -0
  296. package/es/extensions/forms/Iterate/IterateItemContext.d.ts +1 -0
  297. package/es/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  298. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +18 -2
  299. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +43 -16
  300. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  301. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +24 -1
  302. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  303. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +5 -6
  304. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  305. package/es/extensions/forms/Iterate/index.d.ts +1 -0
  306. package/es/extensions/forms/Iterate/index.js +1 -0
  307. package/es/extensions/forms/Iterate/index.js.map +1 -1
  308. package/es/extensions/forms/Tools/Log.d.ts +7 -2
  309. package/es/extensions/forms/Tools/Log.js +26 -3
  310. package/es/extensions/forms/Tools/Log.js.map +1 -1
  311. package/es/extensions/forms/Value/Provider/useValueProvider.d.ts +1 -0
  312. package/es/extensions/forms/Value/SummaryList/SummaryList.d.ts +4 -2
  313. package/es/extensions/forms/Value/SummaryList/SummaryList.js +3 -1
  314. package/es/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  315. package/es/extensions/forms/Value/SummaryList/SummaryListDocs.js +5 -0
  316. package/es/extensions/forms/Value/SummaryList/SummaryListDocs.js.map +1 -1
  317. package/es/extensions/forms/Value/ValueDocs.js +5 -0
  318. package/es/extensions/forms/Value/ValueDocs.js.map +1 -1
  319. package/es/extensions/forms/Wizard/Buttons/Buttons.js +2 -2
  320. package/es/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  321. package/es/extensions/forms/Wizard/Container/WizardContainer.js +67 -23
  322. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  323. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  324. package/es/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  325. package/es/extensions/forms/Wizard/Container/useHandleLayoutEffect.d.ts +1 -2
  326. package/es/extensions/forms/Wizard/Container/useHandleLayoutEffect.js +0 -6
  327. package/es/extensions/forms/Wizard/Container/useHandleLayoutEffect.js.map +1 -1
  328. package/es/extensions/forms/Wizard/Container/useStepAnimation.d.ts +2 -1
  329. package/es/extensions/forms/Wizard/Container/useStepAnimation.js +12 -7
  330. package/es/extensions/forms/Wizard/Container/useStepAnimation.js.map +1 -1
  331. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +14 -3
  332. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  333. package/es/extensions/forms/Wizard/Step/Step.js +4 -4
  334. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  335. package/es/extensions/forms/Wizard/hooks/useStep.js +4 -4
  336. package/es/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  337. package/es/extensions/forms/constants/locales/en-GB.d.ts +6 -1
  338. package/es/extensions/forms/constants/locales/en-GB.js +9 -4
  339. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  340. package/es/extensions/forms/constants/locales/en-US.d.ts +6 -1
  341. package/es/extensions/forms/constants/locales/en-US.js +2 -1
  342. package/es/extensions/forms/constants/locales/en-US.js.map +1 -1
  343. package/es/extensions/forms/constants/locales/index.d.ts +12 -2
  344. package/es/extensions/forms/constants/locales/nb-NO.d.ts +6 -1
  345. package/es/extensions/forms/constants/locales/nb-NO.js +9 -4
  346. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  347. package/es/extensions/forms/hooks/useDataContext.d.ts +6 -0
  348. package/es/extensions/forms/hooks/useDataContext.js +24 -0
  349. package/es/extensions/forms/hooks/useDataContext.js.map +1 -0
  350. package/es/extensions/forms/hooks/useExternalValue.js +12 -6
  351. package/es/extensions/forms/hooks/useExternalValue.js.map +1 -1
  352. package/es/extensions/forms/hooks/useFieldProps.js +83 -44
  353. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  354. package/es/extensions/forms/hooks/useSnapshot.d.ts +9 -0
  355. package/es/extensions/forms/hooks/useSnapshot.js +73 -0
  356. package/es/extensions/forms/hooks/useSnapshot.js.map +1 -0
  357. package/es/extensions/forms/hooks/useValueProps.js +6 -1
  358. package/es/extensions/forms/hooks/useValueProps.js.map +1 -1
  359. package/es/extensions/forms/types.d.ts +4 -0
  360. package/es/extensions/forms/types.js.map +1 -1
  361. package/es/extensions/payment-card/style/dnb-payment-card.css +3 -2
  362. package/es/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
  363. package/es/shared/Eufemia.d.ts +1 -1
  364. package/es/shared/Eufemia.js +2 -2
  365. package/es/shared/Eufemia.js.map +1 -1
  366. package/es/shared/component-helper.js +1 -1
  367. package/es/shared/component-helper.js.map +1 -1
  368. package/es/style/core/scopes.scss +1 -1
  369. package/es/style/dnb-ui-basis.css +1 -1
  370. package/es/style/dnb-ui-basis.min.css +1 -1
  371. package/es/style/dnb-ui-body.css +1 -1
  372. package/es/style/dnb-ui-body.min.css +1 -1
  373. package/es/style/dnb-ui-components.css +3 -1
  374. package/es/style/dnb-ui-components.min.css +1 -1
  375. package/es/style/dnb-ui-core.css +1 -1
  376. package/es/style/dnb-ui-core.min.css +1 -1
  377. package/es/style/dnb-ui-extensions.css +3 -2
  378. package/es/style/dnb-ui-extensions.min.css +1 -1
  379. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +3 -1
  380. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  381. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -2
  382. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  383. package/es/style/themes/theme-eiendom/properties.d.ts +1 -0
  384. package/es/style/themes/theme-eiendom/properties.js +3 -2
  385. package/es/style/themes/theme-eiendom/properties.js.map +1 -1
  386. package/es/style/themes/theme-sbanken/properties.d.ts +1 -0
  387. package/es/style/themes/theme-sbanken/properties.js +3 -2
  388. package/es/style/themes/theme-sbanken/properties.js.map +1 -1
  389. package/es/style/themes/theme-sbanken/properties.scss +9 -8
  390. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +20 -4
  391. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +3 -1
  392. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +11 -3
  393. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  394. package/es/style/themes/theme-sbanken/sbanken-theme-elements.css +17 -2
  395. package/es/style/themes/theme-sbanken/sbanken-theme-elements.min.css +3 -1
  396. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -2
  397. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  398. package/es/style/themes/theme-ui/properties.d.ts +1 -0
  399. package/es/style/themes/theme-ui/properties.js +3 -2
  400. package/es/style/themes/theme-ui/properties.js.map +1 -1
  401. package/es/style/themes/theme-ui/ui-theme-components.css +3 -1
  402. package/es/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  403. package/es/style/themes/theme-ui/ui-theme-extensions.css +3 -2
  404. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  405. package/esm/dnb-ui-basis.min.mjs +1 -1
  406. package/esm/dnb-ui-components.min.mjs +1 -1
  407. package/esm/dnb-ui-elements.min.mjs +1 -1
  408. package/esm/dnb-ui-extensions.min.mjs +2 -2
  409. package/esm/dnb-ui-lib.min.mjs +1 -1
  410. package/extensions/forms/DataContext/Context.d.ts +5 -0
  411. package/extensions/forms/DataContext/Context.js.map +1 -1
  412. package/extensions/forms/DataContext/Provider/Provider.d.ts +12 -1
  413. package/extensions/forms/DataContext/Provider/Provider.js +86 -77
  414. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  415. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.d.ts +6 -1
  416. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js +109 -23
  417. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumber.js.map +1 -1
  418. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +5 -0
  419. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  420. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.d.ts +3 -1
  421. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js +28 -16
  422. package/extensions/forms/Field/OrganizationNumber/OrganizationNumber.js.map +1 -1
  423. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.d.ts +2 -0
  424. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +18 -0
  425. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -0
  426. package/extensions/forms/Field/SelectCountry/SelectCountry.js +4 -3
  427. package/extensions/forms/Field/SelectCountry/SelectCountry.js.map +1 -1
  428. package/extensions/forms/Form/Isolation/Isolation.d.ts +4 -0
  429. package/extensions/forms/Form/Isolation/Isolation.js +29 -3
  430. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  431. package/extensions/forms/Form/Isolation/IsolationDocs.js +5 -0
  432. package/extensions/forms/Form/Isolation/IsolationDocs.js.map +1 -1
  433. package/extensions/forms/Form/Snapshot/Snapshot.d.ts +12 -0
  434. package/extensions/forms/Form/Snapshot/Snapshot.js +36 -0
  435. package/extensions/forms/Form/Snapshot/Snapshot.js.map +1 -0
  436. package/extensions/forms/Form/Snapshot/SnapshotContext.d.ts +12 -0
  437. package/extensions/forms/Form/Snapshot/SnapshotContext.js +6 -0
  438. package/extensions/forms/Form/Snapshot/SnapshotContext.js.map +1 -0
  439. package/extensions/forms/Form/Snapshot/SnapshotDocs.d.ts +3 -0
  440. package/extensions/forms/Form/Snapshot/SnapshotDocs.js +9 -0
  441. package/extensions/forms/Form/Snapshot/SnapshotDocs.js.map +1 -0
  442. package/extensions/forms/Form/Snapshot/index.d.ts +2 -0
  443. package/extensions/forms/Form/Snapshot/index.js +3 -0
  444. package/extensions/forms/Form/Snapshot/index.js.map +1 -0
  445. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +1 -1
  446. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  447. package/extensions/forms/Form/Visibility/Visibility.d.ts +10 -2
  448. package/extensions/forms/Form/Visibility/Visibility.js.map +1 -1
  449. package/extensions/forms/Form/Visibility/VisibilityDocs.js +10 -10
  450. package/extensions/forms/Form/Visibility/VisibilityDocs.js.map +1 -1
  451. package/extensions/forms/Form/Visibility/useVisibility.js +26 -14
  452. package/extensions/forms/Form/Visibility/useVisibility.js.map +1 -1
  453. package/extensions/forms/Form/data-context/clearData.js +2 -5
  454. package/extensions/forms/Form/data-context/clearData.js.map +1 -1
  455. package/extensions/forms/Form/data-context/getData.js.map +1 -1
  456. package/extensions/forms/Form/data-context/useData.js +1 -0
  457. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  458. package/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  459. package/extensions/forms/Form/index.d.ts +2 -0
  460. package/extensions/forms/Form/index.js +2 -0
  461. package/extensions/forms/Form/index.js.map +1 -1
  462. package/extensions/forms/Iterate/Array/Array.js +3 -1
  463. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  464. package/extensions/forms/Iterate/Array/ArrayItemArea.js +31 -18
  465. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  466. package/extensions/forms/Iterate/EditContainer/EditContainer.js +5 -6
  467. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  468. package/extensions/forms/Iterate/ItemNo/ItemNo.d.ts +9 -0
  469. package/extensions/forms/Iterate/ItemNo/ItemNo.js +23 -0
  470. package/extensions/forms/Iterate/ItemNo/ItemNo.js.map +1 -0
  471. package/extensions/forms/Iterate/ItemNo/index.d.ts +2 -0
  472. package/extensions/forms/Iterate/ItemNo/index.js +3 -0
  473. package/extensions/forms/Iterate/ItemNo/index.js.map +1 -0
  474. package/extensions/forms/Iterate/IterateItemContext.d.ts +1 -0
  475. package/extensions/forms/Iterate/IterateItemContext.js.map +1 -1
  476. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +18 -2
  477. package/extensions/forms/Iterate/PushContainer/PushContainer.js +44 -18
  478. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  479. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +24 -1
  480. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  481. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +5 -6
  482. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  483. package/extensions/forms/Iterate/index.d.ts +1 -0
  484. package/extensions/forms/Iterate/index.js +1 -0
  485. package/extensions/forms/Iterate/index.js.map +1 -1
  486. package/extensions/forms/Tools/Log.d.ts +7 -2
  487. package/extensions/forms/Tools/Log.js +30 -3
  488. package/extensions/forms/Tools/Log.js.map +1 -1
  489. package/extensions/forms/Value/Provider/useValueProvider.d.ts +1 -0
  490. package/extensions/forms/Value/SummaryList/SummaryList.d.ts +4 -2
  491. package/extensions/forms/Value/SummaryList/SummaryList.js +3 -1
  492. package/extensions/forms/Value/SummaryList/SummaryList.js.map +1 -1
  493. package/extensions/forms/Value/SummaryList/SummaryListDocs.js +5 -0
  494. package/extensions/forms/Value/SummaryList/SummaryListDocs.js.map +1 -1
  495. package/extensions/forms/Value/ValueDocs.js +5 -0
  496. package/extensions/forms/Value/ValueDocs.js.map +1 -1
  497. package/extensions/forms/Wizard/Buttons/Buttons.js +2 -2
  498. package/extensions/forms/Wizard/Buttons/Buttons.js.map +1 -1
  499. package/extensions/forms/Wizard/Container/WizardContainer.js +78 -31
  500. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  501. package/extensions/forms/Wizard/Container/WizardContainerDocs.js +1 -1
  502. package/extensions/forms/Wizard/Container/WizardContainerDocs.js.map +1 -1
  503. package/extensions/forms/Wizard/Container/useHandleLayoutEffect.d.ts +1 -2
  504. package/extensions/forms/Wizard/Container/useHandleLayoutEffect.js +0 -6
  505. package/extensions/forms/Wizard/Container/useHandleLayoutEffect.js.map +1 -1
  506. package/extensions/forms/Wizard/Container/useStepAnimation.d.ts +2 -1
  507. package/extensions/forms/Wizard/Container/useStepAnimation.js +12 -7
  508. package/extensions/forms/Wizard/Container/useStepAnimation.js.map +1 -1
  509. package/extensions/forms/Wizard/Context/WizardContext.d.ts +14 -3
  510. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  511. package/extensions/forms/Wizard/Step/Step.js +4 -4
  512. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  513. package/extensions/forms/Wizard/hooks/useStep.js +4 -4
  514. package/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  515. package/extensions/forms/constants/locales/en-GB.d.ts +6 -1
  516. package/extensions/forms/constants/locales/en-GB.js +9 -4
  517. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  518. package/extensions/forms/constants/locales/en-US.d.ts +6 -1
  519. package/extensions/forms/constants/locales/en-US.js +2 -1
  520. package/extensions/forms/constants/locales/en-US.js.map +1 -1
  521. package/extensions/forms/constants/locales/index.d.ts +12 -2
  522. package/extensions/forms/constants/locales/nb-NO.d.ts +6 -1
  523. package/extensions/forms/constants/locales/nb-NO.js +9 -4
  524. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  525. package/extensions/forms/hooks/useDataContext.d.ts +6 -0
  526. package/extensions/forms/hooks/useDataContext.js +25 -0
  527. package/extensions/forms/hooks/useDataContext.js.map +1 -0
  528. package/extensions/forms/hooks/useExternalValue.js +12 -6
  529. package/extensions/forms/hooks/useExternalValue.js.map +1 -1
  530. package/extensions/forms/hooks/useFieldProps.js +83 -44
  531. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  532. package/extensions/forms/hooks/useSnapshot.d.ts +9 -0
  533. package/extensions/forms/hooks/useSnapshot.js +81 -0
  534. package/extensions/forms/hooks/useSnapshot.js.map +1 -0
  535. package/extensions/forms/hooks/useValueProps.js +6 -1
  536. package/extensions/forms/hooks/useValueProps.js.map +1 -1
  537. package/extensions/forms/types.d.ts +4 -0
  538. package/extensions/forms/types.js.map +1 -1
  539. package/extensions/payment-card/style/dnb-payment-card.css +3 -2
  540. package/extensions/payment-card/style/dnb-payment-card.min.css +1 -1
  541. package/package.json +1 -1
  542. package/shared/Eufemia.d.ts +1 -1
  543. package/shared/Eufemia.js +2 -2
  544. package/shared/Eufemia.js.map +1 -1
  545. package/shared/component-helper.js +1 -1
  546. package/shared/component-helper.js.map +1 -1
  547. package/style/core/scopes.scss +1 -1
  548. package/style/dnb-ui-basis.css +1 -1
  549. package/style/dnb-ui-basis.min.css +1 -1
  550. package/style/dnb-ui-body.css +1 -1
  551. package/style/dnb-ui-body.min.css +1 -1
  552. package/style/dnb-ui-components.css +3 -1
  553. package/style/dnb-ui-components.min.css +1 -1
  554. package/style/dnb-ui-core.css +1 -1
  555. package/style/dnb-ui-core.min.css +1 -1
  556. package/style/dnb-ui-extensions.css +3 -2
  557. package/style/dnb-ui-extensions.min.css +1 -1
  558. package/style/themes/theme-eiendom/eiendom-theme-components.css +3 -1
  559. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +1 -1
  560. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +3 -2
  561. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  562. package/style/themes/theme-eiendom/properties.d.ts +1 -0
  563. package/style/themes/theme-eiendom/properties.js +3 -2
  564. package/style/themes/theme-eiendom/properties.js.map +1 -1
  565. package/style/themes/theme-sbanken/properties.d.ts +1 -0
  566. package/style/themes/theme-sbanken/properties.js +3 -2
  567. package/style/themes/theme-sbanken/properties.js.map +1 -1
  568. package/style/themes/theme-sbanken/properties.scss +9 -8
  569. package/style/themes/theme-sbanken/sbanken-theme-basis.css +20 -4
  570. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +3 -1
  571. package/style/themes/theme-sbanken/sbanken-theme-components.css +11 -3
  572. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  573. package/style/themes/theme-sbanken/sbanken-theme-elements.css +17 -2
  574. package/style/themes/theme-sbanken/sbanken-theme-elements.min.css +3 -1
  575. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +3 -2
  576. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  577. package/style/themes/theme-ui/properties.d.ts +1 -0
  578. package/style/themes/theme-ui/properties.js +3 -2
  579. package/style/themes/theme-ui/properties.js.map +1 -1
  580. package/style/themes/theme-ui/ui-theme-components.css +3 -1
  581. package/style/themes/theme-ui/ui-theme-components.min.css +1 -1
  582. package/style/themes/theme-ui/ui-theme-extensions.css +3 -2
  583. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  584. package/umd/dnb-ui-basis.min.js +1 -1
  585. package/umd/dnb-ui-components.min.js +1 -1
  586. package/umd/dnb-ui-elements.min.js +1 -1
  587. package/umd/dnb-ui-extensions.min.js +2 -2
  588. package/umd/dnb-ui-lib.min.js +1 -1
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import { Path } from '../../types';
2
+ import { OnCommit, Path } from '../../types';
3
3
  import { SpacingProps } from '../../../../shared/types';
4
4
  import { ArrayItemAreaProps } from '../Array/ArrayItemArea';
5
5
  export type Props = {
@@ -21,13 +21,29 @@ export type Props = {
21
21
  */
22
22
  showOpenButtonWhen?: (list: unknown[]) => boolean;
23
23
  /**
24
- * Prefilled data to add to the fields.
24
+ * Prefilled data to add to the fields. The data will be put into this path: "/pushContainerItems/0".
25
25
  */
26
26
  data?: unknown | Record<string, unknown>;
27
+ /**
28
+ * Prefilled data to add to the fields. The data will be put into this path: "/pushContainerItems/0".
29
+ */
30
+ defaultData?: unknown | Record<string, unknown>;
31
+ /**
32
+ * Provide additional data that will be put into the root of the isolated data context (parallel to "/pushContainerItems/0").
33
+ */
34
+ isolatedData?: Record<string, unknown>;
35
+ /**
36
+ * Prevent the form from being submitted when there are fields with errors inside the PushContainer.
37
+ */
38
+ bubbleValidation?: boolean;
27
39
  /**
28
40
  * A custom toolbar to be shown below the container.
29
41
  */
30
42
  toolbar?: React.ReactNode;
43
+ /**
44
+ * Will be called when the user clicks on the "Done" button.
45
+ */
46
+ onCommit?: OnCommit;
31
47
  /**
32
48
  * The container contents.
33
49
  */
@@ -1,9 +1,9 @@
1
1
  "use client";
2
2
 
3
- import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
5
5
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
6
- const _excluded = ["data", "path", "title", "children", "openButton", "showOpenButtonWhen"],
6
+ const _excluded = ["data", "defaultData", "isolatedData", "bubbleValidation", "path", "title", "children", "openButton", "showOpenButtonWhen", "onCommit"],
7
7
  _excluded2 = ["title", "openButton", "showOpenButton", "switchContainerModeRef", "cancelHandler", "children"];
8
8
  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; }
9
9
  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; }
@@ -20,14 +20,19 @@ import { Flex, HeightAnimation } from '../../../../components';
20
20
  import { useArrayLimit, useSwitchContainerMode } from '../hooks';
21
21
  import Toolbar from '../Toolbar';
22
22
  import { useTranslation } from '../../hooks';
23
+ import { clearedData } from '../../DataContext/Provider';
23
24
  function PushContainer(props) {
24
25
  const {
25
- data = null,
26
+ data: dataProp,
27
+ defaultData: defaultDataProp,
28
+ isolatedData,
29
+ bubbleValidation,
26
30
  path,
27
31
  title,
28
32
  children,
29
33
  openButton,
30
- showOpenButtonWhen
34
+ showOpenButtonWhen,
35
+ onCommit
31
36
  } = props,
32
37
  rest = _objectWithoutProperties(props, _excluded);
33
38
  const commitHandleRef = useRef();
@@ -61,24 +66,45 @@ function PushContainer(props) {
61
66
  commitHandleRef,
62
67
  switchContainerMode: switchContainerModeRef.current
63
68
  };
69
+ const data = useMemo(() => {
70
+ if (defaultDataProp) {
71
+ return;
72
+ }
73
+ return _objectSpread(_objectSpread({}, isolatedData), {}, {
74
+ pushContainerItems: [dataProp !== null && dataProp !== void 0 ? dataProp : clearedData]
75
+ });
76
+ }, [dataProp, defaultDataProp, isolatedData]);
64
77
  const defaultData = useMemo(() => {
65
- return {
66
- newItems: [data]
67
- };
68
- }, [data]);
78
+ return _objectSpread(_objectSpread({}, !dataProp ? isolatedData : null), {}, {
79
+ pushContainerItems: [defaultDataProp !== null && defaultDataProp !== void 0 ? defaultDataProp : clearedData]
80
+ });
81
+ }, [dataProp, defaultDataProp, isolatedData]);
82
+ const emptyData = useCallback(data => {
83
+ var _data$pushContainerIt;
84
+ const firstItem = (_data$pushContainerIt = data.pushContainerItems) === null || _data$pushContainerIt === void 0 ? void 0 : _data$pushContainerIt[0];
85
+ if (firstItem === null || typeof firstItem !== 'object') {
86
+ return _objectSpread(_objectSpread({}, isolatedData), {}, {
87
+ pushContainerItems: [null]
88
+ });
89
+ }
90
+ return defaultData;
91
+ }, [defaultData, isolatedData]);
69
92
  return React.createElement(Isolation, {
93
+ data: data,
70
94
  defaultData: defaultData,
71
- emptyData: defaultData,
95
+ emptyData: emptyData,
96
+ bubbleValidation: bubbleValidation,
72
97
  commitHandleRef: commitHandleRef,
73
98
  transformOnCommit: ({
74
- newItems
99
+ pushContainerItems
75
100
  }) => {
76
- return moveValueToPath(path, [...entries, ...newItems]);
101
+ return moveValueToPath(path, [...entries, ...pushContainerItems]);
77
102
  },
78
- onCommit: (data, {
79
- clearData,
80
- preventCommit
81
- }) => {
103
+ onCommit: (data, options) => {
104
+ const {
105
+ clearData,
106
+ preventCommit
107
+ } = options;
82
108
  if (hasReachedLimit) {
83
109
  preventCommit();
84
110
  setShowStatus(true);
@@ -88,11 +114,12 @@ function PushContainer(props) {
88
114
  (_switchContainerModeR = switchContainerModeRef.current) === null || _switchContainerModeR === void 0 ? void 0 : _switchContainerModeR.call(switchContainerModeRef, 'view');
89
115
  clearData();
90
116
  }
117
+ onCommit === null || onCommit === void 0 ? void 0 : onCommit(data, options);
91
118
  }
92
119
  }, React.createElement(PushContainerContext.Provider, {
93
120
  value: newItemContextProps
94
121
  }, React.createElement(IterateArray, {
95
- path: "/newItems",
122
+ path: "/pushContainerItems",
96
123
  containerMode: showOpenButton ? 'view' : 'edit'
97
124
  }, React.createElement(NewContainer, _extends({
98
125
  title: title,
@@ -1 +1 @@
1
- {"version":3,"file":"PushContainer.js","names":["React","useCallback","useContext","useMemo","useRef","Isolation","PushContainerContext","IterateItemContext","DataContext","useDataValue","EditContainer","CancelButton","DoneButton","IterateArray","OpenButton","Flex","HeightAnimation","useArrayLimit","useSwitchContainerMode","Toolbar","useTranslation","PushContainer","props","data","path","title","children","openButton","showOpenButtonWhen","rest","_objectWithoutProperties","_excluded","commitHandleRef","switchContainerModeRef","value","entries","moveValueToPath","setNextContainerMode","hasReachedLimit","setShowStatus","cancelHandler","showOpenButton","newItemContextProps","switchContainerMode","current","defaultData","newItems","createElement","emptyData","transformOnCommit","onCommit","clearData","preventCommit","_switchContainerModeR","call","Provider","containerMode","NewContainer","_extends","_ref","_DoneButton","_CancelButton","_excluded2","createButton","IteratePushContainer","restoreOriginalValue","toolbar","Consumer","context","_objectSpread","Horizontal","gap","text","onClick","Fragment","open","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo, useRef } from 'react'\nimport Isolation from '../../Form/Isolation'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer, { CancelButton, DoneButton } from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport { Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\nimport { useArrayLimit, useSwitchContainerMode } from '../hooks'\nimport Toolbar from '../Toolbar'\nimport { useTranslation } from '../../hooks'\nimport { ArrayItemAreaProps } from '../Array/ArrayItemArea'\n\nexport type Props = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields.\n */\n data?: unknown | Record<string, unknown>\n\n /**\n * A custom toolbar to be shown below the container.\n */\n toolbar?: React.ReactNode\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props & SpacingProps & ArrayItemAreaProps\n\nfunction PushContainer(props: AllProps) {\n const {\n data = null,\n path,\n title,\n children,\n openButton,\n showOpenButtonWhen,\n ...rest\n } = props\n\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const { value: entries = [], moveValueToPath } = useDataValue<\n Array<unknown>\n >({ path })\n\n const { setNextContainerMode } = useSwitchContainerMode({ path })\n const { hasReachedLimit, setShowStatus } = useArrayLimit({\n path,\n })\n const cancelHandler = useCallback(() => {\n if (hasReachedLimit) {\n setShowStatus(false)\n }\n }, [hasReachedLimit, setShowStatus])\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n const defaultData = useMemo(() => {\n return { newItems: [data] }\n }, [data])\n\n return (\n <Isolation\n defaultData={defaultData}\n emptyData={defaultData}\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ newItems }) => {\n return moveValueToPath(path, [...entries, ...newItems])\n }}\n onCommit={(data, { clearData, preventCommit }) => {\n if (hasReachedLimit) {\n preventCommit()\n setShowStatus(true)\n } else {\n setNextContainerMode('view')\n switchContainerModeRef.current?.('view')\n clearData()\n }\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray\n path=\"/newItems\"\n containerMode={showOpenButton ? 'view' : 'edit'}\n >\n <NewContainer\n title={title}\n openButton={openButton}\n switchContainerModeRef={switchContainerModeRef}\n showOpenButton={showOpenButton}\n cancelHandler={cancelHandler}\n {...rest}\n >\n {children}\n </NewContainer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nfunction NewContainer({\n title,\n openButton,\n showOpenButton,\n switchContainerModeRef,\n cancelHandler,\n children,\n ...rest\n}) {\n const { containerMode, switchContainerMode } =\n useContext(IterateItemContext) || {}\n switchContainerModeRef.current = switchContainerMode\n const { createButton } = useTranslation().IteratePushContainer\n const { clearData } = useContext(DataContext) || {}\n const restoreOriginalValue = useCallback(() => {\n clearData?.()\n }, [clearData])\n\n const toolbar = (\n <Toolbar>\n <IterateItemContext.Consumer>\n {(context) => {\n const newItemContextProps = {\n ...context,\n restoreOriginalValue,\n }\n return (\n <IterateItemContext.Provider value={newItemContextProps}>\n <Flex.Horizontal gap=\"large\">\n <DoneButton text={createButton} />\n {showOpenButton && (\n <CancelButton onClick={cancelHandler} />\n )}\n </Flex.Horizontal>\n </IterateItemContext.Provider>\n )\n }}\n </IterateItemContext.Consumer>\n </Toolbar>\n )\n\n return (\n <>\n <EditContainer\n open={!showOpenButton || containerMode === 'edit'}\n title={title}\n toolbar={toolbar}\n {...rest}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation open={showOpenButton && containerMode === 'view'}>\n {openButton}\n </HeightAnimation>\n )}\n </>\n )\n}\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":"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"}
1
+ {"version":3,"file":"PushContainer.js","names":["React","useCallback","useContext","useMemo","useRef","Isolation","PushContainerContext","IterateItemContext","DataContext","useDataValue","EditContainer","CancelButton","DoneButton","IterateArray","OpenButton","Flex","HeightAnimation","useArrayLimit","useSwitchContainerMode","Toolbar","useTranslation","clearedData","PushContainer","props","data","dataProp","defaultData","defaultDataProp","isolatedData","bubbleValidation","path","title","children","openButton","showOpenButtonWhen","onCommit","rest","_objectWithoutProperties","_excluded","commitHandleRef","switchContainerModeRef","value","entries","moveValueToPath","setNextContainerMode","hasReachedLimit","setShowStatus","cancelHandler","showOpenButton","newItemContextProps","switchContainerMode","current","_objectSpread","pushContainerItems","emptyData","_data$pushContainerIt","firstItem","createElement","transformOnCommit","options","clearData","preventCommit","_switchContainerModeR","call","Provider","containerMode","NewContainer","_extends","_ref","_DoneButton","_CancelButton","_excluded2","createButton","IteratePushContainer","restoreOriginalValue","toolbar","Consumer","context","Horizontal","gap","text","onClick","Fragment","open","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainer.tsx"],"sourcesContent":["import React, { useCallback, useContext, useMemo, useRef } from 'react'\nimport Isolation from '../../Form/Isolation'\nimport PushContainerContext from './PushContainerContext'\nimport IterateItemContext from '../IterateItemContext'\nimport DataContext from '../../DataContext/Context'\nimport useDataValue from '../../hooks/useDataValue'\nimport EditContainer, { CancelButton, DoneButton } from '../EditContainer'\nimport IterateArray, { ContainerMode } from '../Array'\nimport OpenButton from './OpenButton'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport { OnCommit, Path } from '../../types'\nimport { SpacingProps } from '../../../../shared/types'\nimport { useArrayLimit, useSwitchContainerMode } from '../hooks'\nimport Toolbar from '../Toolbar'\nimport { useTranslation } from '../../hooks'\nimport { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport { clearedData } from '../../DataContext/Provider'\n\nexport type Props = {\n /**\n * The path to the array to add the new item to.\n */\n path: Path\n\n /**\n * The title of the container.\n */\n title?: React.ReactNode\n\n /**\n * The button to open container.\n */\n openButton?: React.ReactNode\n\n /**\n * Define when the \"open button\" should be shown.\n * Should be a function that returns a boolean.\n */\n showOpenButtonWhen?: (list: unknown[]) => boolean\n\n /**\n * Prefilled data to add to the fields. The data will be put into this path: \"/pushContainerItems/0\".\n */\n data?: unknown | Record<string, unknown>\n\n /**\n * Prefilled data to add to the fields. The data will be put into this path: \"/pushContainerItems/0\".\n */\n defaultData?: unknown | Record<string, unknown>\n\n /**\n * Provide additional data that will be put into the root of the isolated data context (parallel to \"/pushContainerItems/0\").\n */\n isolatedData?: Record<string, unknown>\n\n /**\n * Prevent the form from being submitted when there are fields with errors inside the PushContainer.\n */\n bubbleValidation?: boolean\n\n /**\n * A custom toolbar to be shown below the container.\n */\n toolbar?: React.ReactNode\n\n /**\n * Will be called when the user clicks on the \"Done\" button.\n */\n onCommit?: OnCommit\n\n /**\n * The container contents.\n */\n children: React.ReactNode\n}\n\nexport type AllProps = Props & SpacingProps & ArrayItemAreaProps\n\nfunction PushContainer(props: AllProps) {\n const {\n data: dataProp,\n defaultData: defaultDataProp,\n isolatedData,\n bubbleValidation,\n path,\n title,\n children,\n openButton,\n showOpenButtonWhen,\n onCommit,\n ...rest\n } = props\n\n const commitHandleRef = useRef<() => void>()\n const switchContainerModeRef = useRef<(mode: ContainerMode) => void>()\n const { value: entries = [], moveValueToPath } = useDataValue<\n Array<unknown>\n >({ path })\n\n const { setNextContainerMode } = useSwitchContainerMode({ path })\n const { hasReachedLimit, setShowStatus } = useArrayLimit({\n path,\n })\n const cancelHandler = useCallback(() => {\n if (hasReachedLimit) {\n setShowStatus(false)\n }\n }, [hasReachedLimit, setShowStatus])\n\n const showOpenButton = showOpenButtonWhen?.(entries)\n const newItemContextProps: PushContainerContext = {\n path,\n entries,\n commitHandleRef,\n switchContainerMode: switchContainerModeRef.current,\n }\n\n const data = useMemo(() => {\n if (defaultDataProp) {\n return // don't return a fallback, because we want to use the defaultData\n }\n return {\n ...isolatedData,\n pushContainerItems: [dataProp ?? clearedData],\n }\n }, [dataProp, defaultDataProp, isolatedData])\n\n const defaultData = useMemo(() => {\n return {\n ...(!dataProp ? isolatedData : null),\n pushContainerItems: [defaultDataProp ?? clearedData],\n }\n }, [dataProp, defaultDataProp, isolatedData])\n\n const emptyData = useCallback(\n (data: { pushContainerItems: unknown[] }) => {\n const firstItem = data.pushContainerItems?.[0]\n if (firstItem === null || typeof firstItem !== 'object') {\n return {\n ...isolatedData,\n pushContainerItems: [null],\n }\n }\n return defaultData\n },\n [defaultData, isolatedData]\n )\n\n return (\n <Isolation\n data={data}\n defaultData={defaultData}\n emptyData={emptyData}\n bubbleValidation={bubbleValidation}\n commitHandleRef={commitHandleRef}\n transformOnCommit={({ pushContainerItems }) => {\n return moveValueToPath(path, [...entries, ...pushContainerItems])\n }}\n onCommit={(data, options) => {\n const { clearData, preventCommit } = options\n if (hasReachedLimit) {\n preventCommit()\n setShowStatus(true)\n } else {\n setNextContainerMode('view')\n switchContainerModeRef.current?.('view')\n clearData()\n }\n onCommit?.(data, options)\n }}\n >\n <PushContainerContext.Provider value={newItemContextProps}>\n <IterateArray\n path=\"/pushContainerItems\"\n containerMode={showOpenButton ? 'view' : 'edit'}\n >\n <NewContainer\n title={title}\n openButton={openButton}\n switchContainerModeRef={switchContainerModeRef}\n showOpenButton={showOpenButton}\n cancelHandler={cancelHandler}\n {...rest}\n >\n {children}\n </NewContainer>\n </IterateArray>\n </PushContainerContext.Provider>\n </Isolation>\n )\n}\n\nfunction NewContainer({\n title,\n openButton,\n showOpenButton,\n switchContainerModeRef,\n cancelHandler,\n children,\n ...rest\n}) {\n const { containerMode, switchContainerMode } =\n useContext(IterateItemContext) || {}\n switchContainerModeRef.current = switchContainerMode\n const { createButton } = useTranslation().IteratePushContainer\n const { clearData } = useContext(DataContext) || {}\n const restoreOriginalValue = useCallback(() => {\n clearData?.()\n }, [clearData])\n\n const toolbar = (\n <Toolbar>\n <IterateItemContext.Consumer>\n {(context) => {\n const newItemContextProps = {\n ...context,\n restoreOriginalValue,\n }\n return (\n <IterateItemContext.Provider value={newItemContextProps}>\n <Flex.Horizontal gap=\"large\">\n <DoneButton text={createButton} />\n {showOpenButton && (\n <CancelButton onClick={cancelHandler} />\n )}\n </Flex.Horizontal>\n </IterateItemContext.Provider>\n )\n }}\n </IterateItemContext.Consumer>\n </Toolbar>\n )\n\n return (\n <>\n <EditContainer\n open={!showOpenButton || containerMode === 'edit'}\n title={title}\n toolbar={toolbar}\n {...rest}\n >\n {children}\n </EditContainer>\n\n {openButton && typeof showOpenButton === 'boolean' && (\n <HeightAnimation open={showOpenButton && containerMode === 'view'}>\n {openButton}\n </HeightAnimation>\n )}\n </>\n )\n}\n\nPushContainer.OpenButton = OpenButton\nPushContainer._supportsSpacingProps = true\n\nexport default PushContainer\n"],"mappings":"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"}
@@ -1,3 +1,4 @@
1
+ import { IsolationEvents } from '../../Form/Isolation/IsolationDocs';
1
2
  export const PushContainerProperties = {
2
3
  path: {
3
4
  doc: 'The path to the array to add the new item to.',
@@ -9,6 +10,26 @@ export const PushContainerProperties = {
9
10
  type: 'React.Node',
10
11
  status: 'optional'
11
12
  },
13
+ data: {
14
+ doc: 'Prefilled data to be used by fields. The data will be put into this path: `/pushContainerItems/0`. Use `defaultData` when possible.',
15
+ type: ['object', 'array'],
16
+ status: 'optional'
17
+ },
18
+ defaultData: {
19
+ doc: 'Prefilled data to be used by fields. The data will be put into this path: `/pushContainerItems/0`',
20
+ type: ['object', 'array'],
21
+ status: 'optional'
22
+ },
23
+ isolatedData: {
24
+ doc: 'Provide additional data that will be put into the root of the isolated data context (parallel to `/pushContainerItems/0`).',
25
+ type: 'object',
26
+ status: 'optional'
27
+ },
28
+ bubbleValidation: {
29
+ doc: 'Prevent the form from being submitted when there are fields with errors inside the PushContainer.',
30
+ type: 'boolean',
31
+ status: 'optional'
32
+ },
12
33
  openButton: {
13
34
  doc: 'The button to open container.',
14
35
  type: 'React.Node',
@@ -40,5 +61,7 @@ export const PushContainerProperties = {
40
61
  status: 'optional'
41
62
  }
42
63
  };
43
- export const PushContainerEvents = {};
64
+ export const PushContainerEvents = {
65
+ onCommit: IsolationEvents.onCommit
66
+ };
44
67
  //# sourceMappingURL=PushContainerDocs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"PushContainerDocs.js","names":["PushContainerProperties","path","doc","type","status","title","openButton","showOpenButtonWhen","variant","toolbar","children","PushContainerEvents"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainerDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const PushContainerProperties: PropertiesTableProps = {\n path: {\n doc: 'The path to the array to add the new item to.',\n type: 'string',\n status: 'required',\n },\n title: {\n doc: 'The title of the container.',\n type: 'React.Node',\n status: 'optional',\n },\n openButton: {\n doc: 'The button to open container.',\n type: 'React.Node',\n status: 'optional',\n },\n showOpenButtonWhen: {\n doc: 'Define when the \"open button\" should be shown. Should be a function that returns a boolean.',\n type: 'function',\n status: 'optional',\n },\n variant: {\n doc: 'Defines the variant of the container. Can be `outline` or `basic`. Defaults to `outline`.',\n type: 'string',\n status: 'optional',\n },\n toolbar: {\n doc: 'A custom toolbar to be shown below the container.',\n type: 'React.Node',\n status: 'optional',\n },\n children: {\n doc: 'The container contents.',\n type: 'React.Node',\n status: 'required',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const PushContainerEvents: PropertiesTableProps = {}\n"],"mappings":"AAEA,OAAO,MAAMA,uBAA6C,GAAG;EAC3DC,IAAI,EAAE;IACJC,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,KAAK,EAAE;IACLH,GAAG,EAAE,6BAA6B;IAClCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDE,UAAU,EAAE;IACVJ,GAAG,EAAE,+BAA+B;IACpCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDG,kBAAkB,EAAE;IAClBL,GAAG,EAAE,6FAA6F;IAClGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,OAAO,EAAE;IACPN,GAAG,EAAE,2FAA2F;IAChGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,OAAO,EAAE;IACPP,GAAG,EAAE,mDAAmD;IACxDC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDM,QAAQ,EAAE;IACRR,GAAG,EAAE,yBAAyB;IAC9BC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMO,mBAAyC,GAAG,CAAC,CAAC"}
1
+ {"version":3,"file":"PushContainerDocs.js","names":["IsolationEvents","PushContainerProperties","path","doc","type","status","title","data","defaultData","isolatedData","bubbleValidation","openButton","showOpenButtonWhen","variant","toolbar","children","PushContainerEvents","onCommit"],"sources":["../../../../../../src/extensions/forms/Iterate/PushContainer/PushContainerDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\nimport { IsolationEvents } from '../../Form/Isolation/IsolationDocs'\n\nexport const PushContainerProperties: PropertiesTableProps = {\n path: {\n doc: 'The path to the array to add the new item to.',\n type: 'string',\n status: 'required',\n },\n title: {\n doc: 'The title of the container.',\n type: 'React.Node',\n status: 'optional',\n },\n data: {\n doc: 'Prefilled data to be used by fields. The data will be put into this path: `/pushContainerItems/0`. Use `defaultData` when possible.',\n type: ['object', 'array'],\n status: 'optional',\n },\n defaultData: {\n doc: 'Prefilled data to be used by fields. The data will be put into this path: `/pushContainerItems/0`',\n type: ['object', 'array'],\n status: 'optional',\n },\n isolatedData: {\n doc: 'Provide additional data that will be put into the root of the isolated data context (parallel to `/pushContainerItems/0`).',\n type: 'object',\n status: 'optional',\n },\n bubbleValidation: {\n doc: 'Prevent the form from being submitted when there are fields with errors inside the PushContainer.',\n type: 'boolean',\n status: 'optional',\n },\n openButton: {\n doc: 'The button to open container.',\n type: 'React.Node',\n status: 'optional',\n },\n showOpenButtonWhen: {\n doc: 'Define when the \"open button\" should be shown. Should be a function that returns a boolean.',\n type: 'function',\n status: 'optional',\n },\n variant: {\n doc: 'Defines the variant of the container. Can be `outline` or `basic`. Defaults to `outline`.',\n type: 'string',\n status: 'optional',\n },\n toolbar: {\n doc: 'A custom toolbar to be shown below the container.',\n type: 'React.Node',\n status: 'optional',\n },\n children: {\n doc: 'The container contents.',\n type: 'React.Node',\n status: 'required',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const PushContainerEvents: PropertiesTableProps = {\n onCommit: IsolationEvents.onCommit,\n}\n"],"mappings":"AACA,SAASA,eAAe,QAAQ,oCAAoC;AAEpE,OAAO,MAAMC,uBAA6C,GAAG;EAC3DC,IAAI,EAAE;IACJC,GAAG,EAAE,+CAA+C;IACpDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,KAAK,EAAE;IACLH,GAAG,EAAE,6BAA6B;IAClCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDE,IAAI,EAAE;IACJJ,GAAG,EAAE,qIAAqI;IAC1IC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDG,WAAW,EAAE;IACXL,GAAG,EAAE,mGAAmG;IACxGC,IAAI,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC;IACzBC,MAAM,EAAE;EACV,CAAC;EACDI,YAAY,EAAE;IACZN,GAAG,EAAE,4HAA4H;IACjIC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDK,gBAAgB,EAAE;IAChBP,GAAG,EAAE,mGAAmG;IACxGC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,UAAU,EAAE;IACVR,GAAG,EAAE,+BAA+B;IACpCC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDO,kBAAkB,EAAE;IAClBT,GAAG,EAAE,6FAA6F;IAClGC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDQ,OAAO,EAAE;IACPV,GAAG,EAAE,2FAA2F;IAChGC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDS,OAAO,EAAE;IACPX,GAAG,EAAE,mDAAmD;IACxDC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACDU,QAAQ,EAAE;IACRZ,GAAG,EAAE,yBAAyB;IAC9BC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMW,mBAAyC,GAAG;EACvDC,QAAQ,EAAEjB,eAAe,CAACiB;AAC5B,CAAC"}
@@ -14,6 +14,7 @@ import IterateItemContext from '../IterateItemContext';
14
14
  import Toolbar from '../Toolbar';
15
15
  import EditButton from './EditButton';
16
16
  import RemoveButton from './RemoveButton';
17
+ import { replaceItemNo } from '../ItemNo';
17
18
  function ViewContainer(props) {
18
19
  var _toolbarElement;
19
20
  const _ref = props || {},
@@ -29,11 +30,9 @@ function ViewContainer(props) {
29
30
  index,
30
31
  arrayValue
31
32
  } = useContext(IterateItemContext);
32
- let itemTitle = title;
33
- let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle]);
34
- if (ariaLabel.includes('{itemN')) {
35
- itemTitle = ariaLabel = ariaLabel.replace(/\{itemN(r|o)\}/g, String(index + 1));
36
- }
33
+ const itemTitle = useMemo(() => {
34
+ return replaceItemNo(title, index);
35
+ }, [index, title]);
37
36
  let toolbarElement = toolbar;
38
37
  if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {
39
38
  toolbarElement = _Toolbar || (_Toolbar = React.createElement(Toolbar, null, React.createElement(EditButton, null)));
@@ -43,7 +42,7 @@ function ViewContainer(props) {
43
42
  });
44
43
  return React.createElement(ArrayItemArea, _extends({
45
44
  mode: "view",
46
- ariaLabel: ariaLabel,
45
+ ariaLabel: convertJsxToString(itemTitle),
47
46
  className: classnames('dnb-forms-section-view-block', className)
48
47
  }, restProps), React.createElement(Flex.Stack, null, itemTitle && React.createElement(Lead, {
49
48
  size: "basis"
@@ -1 +1 @@
1
- {"version":3,"file":"ViewContainer.js","names":["React","useContext","useMemo","classnames","convertJsxToString","Flex","Lead","ArrayItemArea","IterateItemContext","Toolbar","EditButton","RemoveButton","ViewContainer","props","_toolbarElement","_ref","children","className","title","toolbar","toolbarVariant","restProps","_objectWithoutProperties","_excluded","index","arrayValue","itemTitle","ariaLabel","includes","replace","String","toolbarElement","length","_Toolbar","createElement","hasToolbar","Children","toArray","some","child","_extends","mode","Stack","size","_Toolbar2","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { Lead } from '../../../../elements'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport IterateItemContext from '../IterateItemContext'\nimport Toolbar from '../Toolbar'\nimport EditButton from './EditButton'\nimport RemoveButton from './RemoveButton'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n /**\n * An alternative toolbar to be shown in the ViewContainer.\n */\n toolbar?: React.ReactNode\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: 'minimumOneItem'\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nfunction ViewContainer(props: AllProps) {\n const {\n children,\n className,\n title,\n toolbar,\n toolbarVariant,\n ...restProps\n } = props || {}\n const { index, arrayValue } = useContext(IterateItemContext)\n\n let itemTitle = title\n let ariaLabel = useMemo(() => convertJsxToString(itemTitle), [itemTitle])\n if (ariaLabel.includes('{itemN')) {\n /**\n * {itemNr} is deprecated, and can be removed in v11 in favor of {itemNo}\n * So in v11 we can use '{itemNo}' instead of a regex\n */\n itemTitle = ariaLabel = ariaLabel.replace(\n /\\{itemN(r|o)\\}/g,\n String(index + 1)\n )\n }\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = (\n <Toolbar>\n <EditButton />\n </Toolbar>\n )\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <ArrayItemArea\n mode=\"view\"\n ariaLabel={ariaLabel}\n className={classnames('dnb-forms-section-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {hasToolbar\n ? null\n : toolbarElement ?? (\n <Toolbar>\n <EditButton />\n <RemoveButton />\n </Toolbar>\n )}\n </Flex.Stack>\n </ArrayItemArea>\n )\n}\n\nViewContainer.EditButton = EditButton\nViewContainer.RemoveButton = RemoveButton\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,aAAa,MAA8B,wBAAwB;AAC1E,OAAOC,kBAAkB,MAAM,uBAAuB;AACtD,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,UAAU,MAAM,cAAc;AACrC,OAAOC,YAAY,MAAM,gBAAgB;AAmBzC,SAASC,aAAaA,CAACC,KAAe,EAAE;EAAA,IAAAC,eAAA;EACtC,MAAAC,IAAA,GAOIF,KAAK,IAAI,CAAC,CAAC;IAPT;MACJG,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,OAAO;MACPC;IAEF,CAAC,GAAAL,IAAA;IADIM,SAAS,GAAAC,wBAAA,CAAAP,IAAA,EAAAQ,SAAA;EAEd,MAAM;IAAEC,KAAK;IAAEC;EAAW,CAAC,GAAGxB,UAAU,CAACO,kBAAkB,CAAC;EAE5D,IAAIkB,SAAS,GAAGR,KAAK;EACrB,IAAIS,SAAS,GAAGzB,OAAO,CAAC,MAAME,kBAAkB,CAACsB,SAAS,CAAC,EAAE,CAACA,SAAS,CAAC,CAAC;EACzE,IAAIC,SAAS,CAACC,QAAQ,CAAC,QAAQ,CAAC,EAAE;IAKhCF,SAAS,GAAGC,SAAS,GAAGA,SAAS,CAACE,OAAO,CACvC,iBAAiB,EACjBC,MAAM,CAACN,KAAK,GAAG,CAAC,CAClB,CAAC;EACH;EAEA,IAAIO,cAAc,GAAGZ,OAAO;EAC5B,IAAIC,cAAc,KAAK,gBAAgB,IAAIK,UAAU,CAACO,MAAM,IAAI,CAAC,EAAE;IACjED,cAAc,GAAAE,QAAA,KAAAA,QAAA,GACZjC,KAAA,CAAAkC,aAAA,CAACzB,OAAO,QACNT,KAAA,CAAAkC,aAAA,CAACxB,UAAU,MAAE,CACN,CAAC,CACX;EACH;EAEA,MAAMyB,UAAU,GACd,CAACJ,cAAc,IACf/B,KAAK,CAACoC,QAAQ,CAACC,OAAO,CAACrB,QAAQ,CAAC,CAACsB,IAAI,CAAEC,KAAK,IAAK;IAC/C,OAAO,CAAAA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,MAAM,CAAC,MAAK9B,OAAO;EACpC,CAAC,CAAC;EAEJ,OACET,KAAA,CAAAkC,aAAA,CAAC3B,aAAa,EAAAiC,QAAA;IACZC,IAAI,EAAC,MAAM;IACXd,SAAS,EAAEA,SAAU;IACrBV,SAAS,EAAEd,UAAU,CAAC,8BAA8B,EAAEc,SAAS;EAAE,GAC7DI,SAAS,GAEbrB,KAAA,CAAAkC,aAAA,CAAC7B,IAAI,CAACqC,KAAK,QACRhB,SAAS,IAAI1B,KAAA,CAAAkC,aAAA,CAAC5B,IAAI;IAACqC,IAAI,EAAC;EAAO,GAAEjB,SAAgB,CAAC,EAClDV,QAAQ,EACRmB,UAAU,GACP,IAAI,IAAArB,eAAA,GACJiB,cAAc,cAAAjB,eAAA,cAAAA,eAAA,GAAA8B,SAAA,KAAAA,SAAA,GACZ5C,KAAA,CAAAkC,aAAA,CAACzB,OAAO,QACNT,KAAA,CAAAkC,aAAA,CAACxB,UAAU,MAAE,CAAC,EACdV,KAAA,CAAAkC,aAAA,CAACvB,YAAY,MAAE,CACR,CAAC,CAEN,CACC,CAAC;AAEpB;AAEAC,aAAa,CAACF,UAAU,GAAGA,UAAU;AACrCE,aAAa,CAACD,YAAY,GAAGA,YAAY;AAEzCC,aAAa,CAACiC,qBAAqB,GAAG,IAAI;AAC1C,eAAejC,aAAa"}
1
+ {"version":3,"file":"ViewContainer.js","names":["React","useContext","useMemo","classnames","convertJsxToString","Flex","Lead","ArrayItemArea","IterateItemContext","Toolbar","EditButton","RemoveButton","replaceItemNo","ViewContainer","props","_toolbarElement","_ref","children","className","title","toolbar","toolbarVariant","restProps","_objectWithoutProperties","_excluded","index","arrayValue","itemTitle","toolbarElement","length","_Toolbar","createElement","hasToolbar","Children","toArray","some","child","_extends","mode","ariaLabel","Stack","size","_Toolbar2","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { useContext, useMemo } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { Lead } from '../../../../elements'\nimport ArrayItemArea, { ArrayItemAreaProps } from '../Array/ArrayItemArea'\nimport IterateItemContext from '../IterateItemContext'\nimport Toolbar from '../Toolbar'\nimport EditButton from './EditButton'\nimport RemoveButton from './RemoveButton'\nimport { replaceItemNo } from '../ItemNo'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n /**\n * An alternative toolbar to be shown in the ViewContainer.\n */\n toolbar?: React.ReactNode\n /**\n * The variant of the toolbar.\n */\n toolbarVariant?: 'minimumOneItem'\n}\n\nexport type AllProps = Props & FlexContainerProps & ArrayItemAreaProps\n\nfunction ViewContainer(props: AllProps) {\n const {\n children,\n className,\n title,\n toolbar,\n toolbarVariant,\n ...restProps\n } = props || {}\n const { index, arrayValue } = useContext(IterateItemContext)\n const itemTitle = useMemo(() => {\n return replaceItemNo(title, index)\n }, [index, title])\n\n let toolbarElement = toolbar\n if (toolbarVariant === 'minimumOneItem' && arrayValue.length <= 1) {\n toolbarElement = (\n <Toolbar>\n <EditButton />\n </Toolbar>\n )\n }\n\n const hasToolbar =\n !toolbarElement &&\n React.Children.toArray(children).some((child) => {\n return child?.['type'] === Toolbar\n })\n\n return (\n <ArrayItemArea\n mode=\"view\"\n ariaLabel={convertJsxToString(itemTitle)}\n className={classnames('dnb-forms-section-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {itemTitle && <Lead size=\"basis\">{itemTitle}</Lead>}\n {children}\n {hasToolbar\n ? null\n : toolbarElement ?? (\n <Toolbar>\n <EditButton />\n <RemoveButton />\n </Toolbar>\n )}\n </Flex.Stack>\n </ArrayItemArea>\n )\n}\n\nViewContainer.EditButton = EditButton\nViewContainer.RemoveButton = RemoveButton\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAClD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,aAAa,MAA8B,wBAAwB;AAC1E,OAAOC,kBAAkB,MAAM,uBAAuB;AACtD,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,UAAU,MAAM,cAAc;AACrC,OAAOC,YAAY,MAAM,gBAAgB;AACzC,SAASC,aAAa,QAAQ,WAAW;AAmBzC,SAASC,aAAaA,CAACC,KAAe,EAAE;EAAA,IAAAC,eAAA;EACtC,MAAAC,IAAA,GAOIF,KAAK,IAAI,CAAC,CAAC;IAPT;MACJG,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,OAAO;MACPC;IAEF,CAAC,GAAAL,IAAA;IADIM,SAAS,GAAAC,wBAAA,CAAAP,IAAA,EAAAQ,SAAA;EAEd,MAAM;IAAEC,KAAK;IAAEC;EAAW,CAAC,GAAGzB,UAAU,CAACO,kBAAkB,CAAC;EAC5D,MAAMmB,SAAS,GAAGzB,OAAO,CAAC,MAAM;IAC9B,OAAOU,aAAa,CAACO,KAAK,EAAEM,KAAK,CAAC;EACpC,CAAC,EAAE,CAACA,KAAK,EAAEN,KAAK,CAAC,CAAC;EAElB,IAAIS,cAAc,GAAGR,OAAO;EAC5B,IAAIC,cAAc,KAAK,gBAAgB,IAAIK,UAAU,CAACG,MAAM,IAAI,CAAC,EAAE;IACjED,cAAc,GAAAE,QAAA,KAAAA,QAAA,GACZ9B,KAAA,CAAA+B,aAAA,CAACtB,OAAO,QACNT,KAAA,CAAA+B,aAAA,CAACrB,UAAU,MAAE,CACN,CAAC,CACX;EACH;EAEA,MAAMsB,UAAU,GACd,CAACJ,cAAc,IACf5B,KAAK,CAACiC,QAAQ,CAACC,OAAO,CAACjB,QAAQ,CAAC,CAACkB,IAAI,CAAEC,KAAK,IAAK;IAC/C,OAAO,CAAAA,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAG,MAAM,CAAC,MAAK3B,OAAO;EACpC,CAAC,CAAC;EAEJ,OACET,KAAA,CAAA+B,aAAA,CAACxB,aAAa,EAAA8B,QAAA;IACZC,IAAI,EAAC,MAAM;IACXC,SAAS,EAAEnC,kBAAkB,CAACuB,SAAS,CAAE;IACzCT,SAAS,EAAEf,UAAU,CAAC,8BAA8B,EAAEe,SAAS;EAAE,GAC7DI,SAAS,GAEbtB,KAAA,CAAA+B,aAAA,CAAC1B,IAAI,CAACmC,KAAK,QACRb,SAAS,IAAI3B,KAAA,CAAA+B,aAAA,CAACzB,IAAI;IAACmC,IAAI,EAAC;EAAO,GAAEd,SAAgB,CAAC,EAClDV,QAAQ,EACRe,UAAU,GACP,IAAI,IAAAjB,eAAA,GACJa,cAAc,cAAAb,eAAA,cAAAA,eAAA,GAAA2B,SAAA,KAAAA,SAAA,GACZ1C,KAAA,CAAA+B,aAAA,CAACtB,OAAO,QACNT,KAAA,CAAA+B,aAAA,CAACrB,UAAU,MAAE,CAAC,EACdV,KAAA,CAAA+B,aAAA,CAACpB,YAAY,MAAE,CACR,CAAC,CAEN,CACC,CAAC;AAEpB;AAEAE,aAAa,CAACH,UAAU,GAAGA,UAAU;AACrCG,aAAa,CAACF,YAAY,GAAGA,YAAY;AAEzCE,aAAa,CAAC8B,qBAAqB,GAAG,IAAI;AAC1C,eAAe9B,aAAa"}
@@ -8,6 +8,7 @@ export { default as EditContainer } from './EditContainer';
8
8
  export { default as ViewContainer } from './ViewContainer';
9
9
  export { default as AnimatedContainer } from './AnimatedContainer';
10
10
  export { default as Toolbar } from './Toolbar';
11
+ export { default as ItemNo } from './ItemNo';
11
12
  export { useCount, count, Count } from './Count';
12
13
  export { default as useItem } from './hooks/useItem';
13
14
  export { default as IterateItemContext } from './IterateItemContext';
@@ -8,6 +8,7 @@ export { default as EditContainer } from './EditContainer';
8
8
  export { default as ViewContainer } from './ViewContainer';
9
9
  export { default as AnimatedContainer } from './AnimatedContainer';
10
10
  export { default as Toolbar } from './Toolbar';
11
+ export { default as ItemNo } from './ItemNo';
11
12
  export { useCount, count, Count } from './Count';
12
13
  export { default as useItem } from './hooks/useItem';
13
14
  export { default as IterateItemContext } from './IterateItemContext';
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["PushButton","RemoveButton","default","Array","PushContainer","EditContainer","ViewContainer","AnimatedContainer","Toolbar","useCount","count","Count","useItem","IterateItemContext","ArrayPushButton","ArrayRemoveElementButton"],"sources":["../../../../../src/extensions/forms/Iterate/index.ts"],"sourcesContent":["import PushButton from './PushButton'\nimport RemoveButton from './RemoveButton'\n\nexport { default as Array } from './Array'\nexport { default as PushButton } from './PushButton'\nexport { default as PushContainer } from './PushContainer'\nexport { default as RemoveButton } from './RemoveButton'\nexport { default as EditContainer } from './EditContainer'\nexport { default as ViewContainer } from './ViewContainer'\nexport { default as AnimatedContainer } from './AnimatedContainer'\nexport { default as Toolbar } from './Toolbar'\nexport { useCount, count, Count } from './Count'\nexport { default as useItem } from './hooks/useItem'\nexport { default as IterateItemContext } from './IterateItemContext'\n\n/**\n * Deprecated and will be removed in v11\n *\n * @deprecated use \"PushButton\" instead\n */\nexport const ArrayPushButton = PushButton\n\n/**\n * Deprecated and will be removed in v11\n *\n * @deprecated use \"RemoveButton\" instead\n */\nexport const ArrayRemoveElementButton = RemoveButton\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,cAAc;AACrC,OAAOC,YAAY,MAAM,gBAAgB;AAEzC,SAASC,OAAO,IAAIC,KAAK,QAAQ,SAAS;AAC1C,SAASD,OAAO,IAAIF,UAAU,QAAQ,cAAc;AACpD,SAASE,OAAO,IAAIE,aAAa,QAAQ,iBAAiB;AAC1D,SAASF,OAAO,IAAID,YAAY,QAAQ,gBAAgB;AACxD,SAASC,OAAO,IAAIG,aAAa,QAAQ,iBAAiB;AAC1D,SAASH,OAAO,IAAII,aAAa,QAAQ,iBAAiB;AAC1D,SAASJ,OAAO,IAAIK,iBAAiB,QAAQ,qBAAqB;AAClE,SAASL,OAAO,IAAIM,OAAO,QAAQ,WAAW;AAC9C,SAASC,QAAQ,EAAEC,KAAK,EAAEC,KAAK,QAAQ,SAAS;AAChD,SAAST,OAAO,IAAIU,OAAO,QAAQ,iBAAiB;AACpD,SAASV,OAAO,IAAIW,kBAAkB,QAAQ,sBAAsB;AAOpE,OAAO,MAAMC,eAAe,GAAGd,UAAU;AAOzC,OAAO,MAAMe,wBAAwB,GAAGd,YAAY"}
1
+ {"version":3,"file":"index.js","names":["PushButton","RemoveButton","default","Array","PushContainer","EditContainer","ViewContainer","AnimatedContainer","Toolbar","ItemNo","useCount","count","Count","useItem","IterateItemContext","ArrayPushButton","ArrayRemoveElementButton"],"sources":["../../../../../src/extensions/forms/Iterate/index.ts"],"sourcesContent":["import PushButton from './PushButton'\nimport RemoveButton from './RemoveButton'\n\nexport { default as Array } from './Array'\nexport { default as PushButton } from './PushButton'\nexport { default as PushContainer } from './PushContainer'\nexport { default as RemoveButton } from './RemoveButton'\nexport { default as EditContainer } from './EditContainer'\nexport { default as ViewContainer } from './ViewContainer'\nexport { default as AnimatedContainer } from './AnimatedContainer'\nexport { default as Toolbar } from './Toolbar'\nexport { default as ItemNo } from './ItemNo'\nexport { useCount, count, Count } from './Count'\nexport { default as useItem } from './hooks/useItem'\nexport { default as IterateItemContext } from './IterateItemContext'\n\n/**\n * Deprecated and will be removed in v11\n *\n * @deprecated use \"PushButton\" instead\n */\nexport const ArrayPushButton = PushButton\n\n/**\n * Deprecated and will be removed in v11\n *\n * @deprecated use \"RemoveButton\" instead\n */\nexport const ArrayRemoveElementButton = RemoveButton\n"],"mappings":"AAAA,OAAOA,UAAU,MAAM,cAAc;AACrC,OAAOC,YAAY,MAAM,gBAAgB;AAEzC,SAASC,OAAO,IAAIC,KAAK,QAAQ,SAAS;AAC1C,SAASD,OAAO,IAAIF,UAAU,QAAQ,cAAc;AACpD,SAASE,OAAO,IAAIE,aAAa,QAAQ,iBAAiB;AAC1D,SAASF,OAAO,IAAID,YAAY,QAAQ,gBAAgB;AACxD,SAASC,OAAO,IAAIG,aAAa,QAAQ,iBAAiB;AAC1D,SAASH,OAAO,IAAII,aAAa,QAAQ,iBAAiB;AAC1D,SAASJ,OAAO,IAAIK,iBAAiB,QAAQ,qBAAqB;AAClE,SAASL,OAAO,IAAIM,OAAO,QAAQ,WAAW;AAC9C,SAASN,OAAO,IAAIO,MAAM,QAAQ,UAAU;AAC5C,SAASC,QAAQ,EAAEC,KAAK,EAAEC,KAAK,QAAQ,SAAS;AAChD,SAASV,OAAO,IAAIW,OAAO,QAAQ,iBAAiB;AACpD,SAASX,OAAO,IAAIY,kBAAkB,QAAQ,sBAAsB;AAOpE,OAAO,MAAMC,eAAe,GAAGf,UAAU;AAOzC,OAAO,MAAMgB,wBAAwB,GAAGf,YAAY"}
@@ -1,5 +1,10 @@
1
- import { SectionProps } from '../../../components/Section';
2
- declare function Log(props: SectionProps): import("react/jsx-runtime").JSX.Element;
1
+ import React from 'react';
2
+ import { SectionAllProps } from '../../../components/Section';
3
+ declare function Log({ placeholder, label, data: logData, ...props }: Omit<SectionAllProps, 'data' | 'label'> & {
4
+ data?: unknown;
5
+ label?: React.ReactNode;
6
+ placeholder?: React.ReactNode;
7
+ }): import("react/jsx-runtime").JSX.Element;
3
8
  declare namespace Log {
4
9
  var _supportsSpacingProps: boolean;
5
10
  }
@@ -1,10 +1,22 @@
1
1
  "use client";
2
2
 
3
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
3
4
  import _extends from "@babel/runtime/helpers/esm/extends";
4
- import { useContext } from 'react';
5
+ import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
6
+ const _excluded = ["placeholder", "label", "data"];
7
+ 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; }
8
+ 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; }
9
+ import React, { useContext } from 'react';
5
10
  import DataContext from '../DataContext/Context';
6
11
  import Section from '../../../components/Section';
7
- function Log(props) {
12
+ import { FormLabel } from '../../../components';
13
+ function Log(_ref) {
14
+ let {
15
+ placeholder,
16
+ label,
17
+ data: logData
18
+ } = _ref,
19
+ props = _objectWithoutProperties(_ref, _excluded);
8
20
  const {
9
21
  data
10
22
  } = useContext(DataContext);
@@ -15,7 +27,18 @@ function Log(props) {
15
27
  maxWidth: '80vw'
16
28
  },
17
29
  innerSpace: true
18
- }, props), React.createElement("pre", null, JSON.stringify(data, null, 2), ' '));
30
+ }, props), label && React.createElement(FormLabel, {
31
+ bottom: true
32
+ }, label), React.createElement("pre", null, placeholder && Object.keys((logData !== null && logData !== void 0 ? logData : data) || {}).length === 0 ? placeholder : JSON.stringify(replaceUndefinedValues(logData !== null && logData !== void 0 ? logData : data), null, 2), ' '));
33
+ }
34
+ function replaceUndefinedValues(value, replaceWith = 'undefined') {
35
+ if (typeof value === 'undefined') {
36
+ return replaceWith;
37
+ } else if (typeof value === 'object' && value !== replaceWith) {
38
+ return _objectSpread(_objectSpread({}, value), Object.fromEntries(Object.entries(value).map(([k, v]) => [k, replaceUndefinedValues(v)])));
39
+ } else {
40
+ return value;
41
+ }
19
42
  }
20
43
  Log._supportsSpacingProps = true;
21
44
  export default Log;
@@ -1 +1 @@
1
- {"version":3,"file":"Log.js","names":["useContext","DataContext","Section","Log","props","data","React","createElement","_extends","element","backgroundColor","style","maxWidth","innerSpace","JSON","stringify","_supportsSpacingProps"],"sources":["../../../../../src/extensions/forms/Tools/Log.tsx"],"sourcesContent":["import { useContext } from 'react'\nimport DataContext from '../DataContext/Context'\nimport Section, { SectionProps } from '../../../components/Section'\n\nfunction Log(props: SectionProps) {\n const { data } = useContext(DataContext)\n\n return (\n <Section\n element=\"output\"\n backgroundColor=\"sand-yellow\"\n style={{ maxWidth: '80vw' }}\n innerSpace\n {...props}\n >\n <pre>\n {JSON.stringify(data, null, 2)}\n {' ' /* Ensure one line of spacing */}\n </pre>\n </Section>\n )\n}\n\nLog._supportsSpacingProps = true\nexport default Log\n"],"mappings":";;;AAAA,SAASA,UAAU,QAAQ,OAAO;AAClC,OAAOC,WAAW,MAAM,wBAAwB;AAChD,OAAOC,OAAO,MAAwB,6BAA6B;AAEnE,SAASC,GAAGA,CAACC,KAAmB,EAAE;EAChC,MAAM;IAAEC;EAAK,CAAC,GAAGL,UAAU,CAACC,WAAW,CAAC;EAExC,OACEK,KAAA,CAAAC,aAAA,CAACL,OAAO,EAAAM,QAAA;IACNC,OAAO,EAAC,QAAQ;IAChBC,eAAe,EAAC,aAAa;IAC7BC,KAAK,EAAE;MAAEC,QAAQ,EAAE;IAAO,CAAE;IAC5BC,UAAU;EAAA,GACNT,KAAK,GAETE,KAAA,CAAAC,aAAA,cACGO,IAAI,CAACC,SAAS,CAACV,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,EAC7B,GACE,CACE,CAAC;AAEd;AAEAF,GAAG,CAACa,qBAAqB,GAAG,IAAI;AAChC,eAAeb,GAAG"}
1
+ {"version":3,"file":"Log.js","names":["React","useContext","DataContext","Section","FormLabel","Log","_ref","placeholder","label","data","logData","props","_objectWithoutProperties","_excluded","createElement","_extends","element","backgroundColor","style","maxWidth","innerSpace","bottom","Object","keys","length","JSON","stringify","replaceUndefinedValues","value","replaceWith","_objectSpread","fromEntries","entries","map","k","v","_supportsSpacingProps"],"sources":["../../../../../src/extensions/forms/Tools/Log.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport DataContext from '../DataContext/Context'\nimport Section, { SectionAllProps } from '../../../components/Section'\nimport { FormLabel } from '../../../components'\n\nfunction Log({\n placeholder,\n label,\n data: logData,\n ...props\n}: Omit<SectionAllProps, 'data' | 'label'> & {\n data?: unknown\n label?: React.ReactNode\n placeholder?: React.ReactNode\n}) {\n const { data } = useContext(DataContext)\n\n return (\n <Section\n element=\"output\"\n backgroundColor=\"sand-yellow\"\n style={{ maxWidth: '80vw' }}\n innerSpace\n {...props}\n >\n {label && <FormLabel bottom>{label}</FormLabel>}\n <pre>\n {placeholder && Object.keys((logData ?? data) || {}).length === 0\n ? placeholder\n : JSON.stringify(\n replaceUndefinedValues(logData ?? data),\n null,\n 2\n )}\n {' ' /* Ensure one line of spacing */}\n </pre>\n </Section>\n )\n}\n\n/**\n * Replaces undefined values in an object with a specified replacement value.\n * @param value - The value to check for undefined values.\n * @param replaceWith - The value to replace undefined values with. Default is null.\n * @returns The object with undefined values replaced.\n */\nfunction replaceUndefinedValues(\n value: unknown,\n replaceWith = 'undefined' as unknown\n): unknown {\n if (typeof value === 'undefined') {\n return replaceWith\n } else if (typeof value === 'object' && value !== replaceWith) {\n return {\n ...value,\n ...Object.fromEntries(\n Object.entries(value).map(([k, v]) => [\n k,\n replaceUndefinedValues(v),\n ])\n ),\n }\n } else {\n return value\n }\n}\n\nLog._supportsSpacingProps = true\nexport default Log\n"],"mappings":";;;;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,OAAOC,WAAW,MAAM,wBAAwB;AAChD,OAAOC,OAAO,MAA2B,6BAA6B;AACtE,SAASC,SAAS,QAAQ,qBAAqB;AAE/C,SAASC,GAAGA,CAAAC,IAAA,EAST;EAAA,IATU;MACXC,WAAW;MACXC,KAAK;MACLC,IAAI,EAAEC;IAMR,CAAC,GAAAJ,IAAA;IALIK,KAAK,GAAAC,wBAAA,CAAAN,IAAA,EAAAO,SAAA;EAMR,MAAM;IAAEJ;EAAK,CAAC,GAAGR,UAAU,CAACC,WAAW,CAAC;EAExC,OACEF,KAAA,CAAAc,aAAA,CAACX,OAAO,EAAAY,QAAA;IACNC,OAAO,EAAC,QAAQ;IAChBC,eAAe,EAAC,aAAa;IAC7BC,KAAK,EAAE;MAAEC,QAAQ,EAAE;IAAO,CAAE;IAC5BC,UAAU;EAAA,GACNT,KAAK,GAERH,KAAK,IAAIR,KAAA,CAAAc,aAAA,CAACV,SAAS;IAACiB,MAAM;EAAA,GAAEb,KAAiB,CAAC,EAC/CR,KAAA,CAAAc,aAAA,cACGP,WAAW,IAAIe,MAAM,CAACC,IAAI,CAAC,CAACb,OAAO,aAAPA,OAAO,cAAPA,OAAO,GAAID,IAAI,KAAK,CAAC,CAAC,CAAC,CAACe,MAAM,KAAK,CAAC,GAC7DjB,WAAW,GACXkB,IAAI,CAACC,SAAS,CACZC,sBAAsB,CAACjB,OAAO,aAAPA,OAAO,cAAPA,OAAO,GAAID,IAAI,CAAC,EACvC,IAAI,EACJ,CACF,CAAC,EACJ,GACE,CACE,CAAC;AAEd;AAQA,SAASkB,sBAAsBA,CAC7BC,KAAc,EACdC,WAAW,GAAG,WAAsB,EAC3B;EACT,IAAI,OAAOD,KAAK,KAAK,WAAW,EAAE;IAChC,OAAOC,WAAW;EACpB,CAAC,MAAM,IAAI,OAAOD,KAAK,KAAK,QAAQ,IAAIA,KAAK,KAAKC,WAAW,EAAE;IAC7D,OAAAC,aAAA,CAAAA,aAAA,KACKF,KAAK,GACLN,MAAM,CAACS,WAAW,CACnBT,MAAM,CAACU,OAAO,CAACJ,KAAK,CAAC,CAACK,GAAG,CAAC,CAAC,CAACC,CAAC,EAAEC,CAAC,CAAC,KAAK,CACpCD,CAAC,EACDP,sBAAsB,CAACQ,CAAC,CAAC,CAC1B,CACH,CAAC;EAEL,CAAC,MAAM;IACL,OAAOP,KAAK;EACd;AACF;AAEAvB,GAAG,CAAC+B,qBAAqB,GAAG,IAAI;AAChC,eAAe/B,GAAG"}
@@ -22,6 +22,7 @@ declare function useValueProvider(props?: Omit<ValueProviderProps, 'children'>):
22
22
  toInput?: (external: unknown) => unknown;
23
23
  fromExternal?: (external: unknown) => unknown;
24
24
  itemPath?: string;
25
+ transformLabel?: (label: import("react").ReactNode, convertJsxToString: (label: import("react").ReactNode) => string) => import("react").ReactNode;
25
26
  inheritVisibility?: boolean;
26
27
  inheritLabel?: boolean;
27
28
  showEmpty?: boolean;
@@ -1,7 +1,9 @@
1
1
  import { DlAllProps } from '../../../../elements/Dl';
2
+ import { ValueProps } from '../../types';
2
3
  export type Props = Omit<DlAllProps, 'label'> & {
3
- inheritVisibility?: boolean;
4
- inheritLabel?: boolean;
4
+ transformLabel?: ValueProps['transformLabel'];
5
+ inheritVisibility?: ValueProps['inheritVisibility'];
6
+ inheritLabel?: ValueProps['inheritLabel'];
5
7
  };
6
8
  declare function SummaryList(props: Props): import("react/jsx-runtime").JSX.Element;
7
9
  declare namespace SummaryList {
@@ -1,6 +1,6 @@
1
1
  import _extends from "@babel/runtime/helpers/esm/extends";
2
2
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
3
- const _excluded = ["className", "children", "layout", "inheritVisibility", "inheritLabel"];
3
+ const _excluded = ["className", "children", "layout", "transformLabel", "inheritVisibility", "inheritLabel"];
4
4
  import React from 'react';
5
5
  import classnames from 'classnames';
6
6
  import { removeUndefinedProps } from '../../../../shared/component-helper';
@@ -12,11 +12,13 @@ function SummaryList(props) {
12
12
  className,
13
13
  children,
14
14
  layout,
15
+ transformLabel,
15
16
  inheritVisibility,
16
17
  inheritLabel
17
18
  } = props,
18
19
  rest = _objectWithoutProperties(props, _excluded);
19
20
  const valueProviderProps = removeUndefinedProps({
21
+ transformLabel,
20
22
  inheritVisibility,
21
23
  inheritLabel
22
24
  });
@@ -1 +1 @@
1
- {"version":3,"file":"SummaryList.js","names":["React","classnames","removeUndefinedProps","SummaryListContext","Dl","ValueProvider","SummaryList","props","className","children","layout","inheritVisibility","inheritLabel","rest","_objectWithoutProperties","_excluded","valueProviderProps","createElement","Provider","value","_extends","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Value/SummaryList/SummaryList.tsx"],"sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\nimport { removeUndefinedProps } from '../../../../shared/component-helper'\nimport SummaryListContext from './SummaryListContext'\nimport Dl, { DlAllProps } from '../../../../elements/Dl'\nimport ValueProvider from '../Provider/ValueProvider'\n\nexport type Props = Omit<DlAllProps, 'label'> & {\n inheritVisibility?: boolean\n inheritLabel?: boolean\n}\n\nfunction SummaryList(props: Props) {\n const {\n className,\n children,\n layout,\n inheritVisibility,\n inheritLabel,\n ...rest\n } = props\n\n const valueProviderProps = removeUndefinedProps({\n inheritVisibility,\n inheritLabel,\n })\n\n return (\n <SummaryListContext.Provider value={{ layout }}>\n <Dl\n className={classnames('dnb-forms-summary-list', className)}\n layout={layout}\n {...rest}\n >\n <ValueProvider {...valueProviderProps}>{children}</ValueProvider>\n </Dl>\n </SummaryListContext.Provider>\n )\n}\n\nSummaryList._supportsSpacingProps = true\n\nexport default SummaryList\n"],"mappings":";;;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,oBAAoB,QAAQ,qCAAqC;AAC1E,OAAOC,kBAAkB,MAAM,sBAAsB;AACrD,OAAOC,EAAE,MAAsB,yBAAyB;AACxD,OAAOC,aAAa,MAAM,2BAA2B;AAOrD,SAASC,WAAWA,CAACC,KAAY,EAAE;EACjC,MAAM;MACJC,SAAS;MACTC,QAAQ;MACRC,MAAM;MACNC,iBAAiB;MACjBC;IAEF,CAAC,GAAGL,KAAK;IADJM,IAAI,GAAAC,wBAAA,CACLP,KAAK,EAAAQ,SAAA;EAET,MAAMC,kBAAkB,GAAGd,oBAAoB,CAAC;IAC9CS,iBAAiB;IACjBC;EACF,CAAC,CAAC;EAEF,OACEZ,KAAA,CAAAiB,aAAA,CAACd,kBAAkB,CAACe,QAAQ;IAACC,KAAK,EAAE;MAAET;IAAO;EAAE,GAC7CV,KAAA,CAAAiB,aAAA,CAACb,EAAE,EAAAgB,QAAA;IACDZ,SAAS,EAAEP,UAAU,CAAC,wBAAwB,EAAEO,SAAS,CAAE;IAC3DE,MAAM,EAAEA;EAAO,GACXG,IAAI,GAERb,KAAA,CAAAiB,aAAA,CAACZ,aAAa,EAAKW,kBAAkB,EAAGP,QAAwB,CAC9D,CACuB,CAAC;AAElC;AAEAH,WAAW,CAACe,qBAAqB,GAAG,IAAI;AAExC,eAAef,WAAW"}
1
+ {"version":3,"file":"SummaryList.js","names":["React","classnames","removeUndefinedProps","SummaryListContext","Dl","ValueProvider","SummaryList","props","className","children","layout","transformLabel","inheritVisibility","inheritLabel","rest","_objectWithoutProperties","_excluded","valueProviderProps","createElement","Provider","value","_extends","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Value/SummaryList/SummaryList.tsx"],"sourcesContent":["import React from 'react'\nimport classnames from 'classnames'\nimport { removeUndefinedProps } from '../../../../shared/component-helper'\nimport SummaryListContext from './SummaryListContext'\nimport Dl, { DlAllProps } from '../../../../elements/Dl'\nimport ValueProvider from '../Provider/ValueProvider'\nimport { ValueProps } from '../../types'\n\nexport type Props = Omit<DlAllProps, 'label'> & {\n transformLabel?: ValueProps['transformLabel']\n inheritVisibility?: ValueProps['inheritVisibility']\n inheritLabel?: ValueProps['inheritLabel']\n}\n\nfunction SummaryList(props: Props) {\n const {\n className,\n children,\n layout,\n transformLabel,\n inheritVisibility,\n inheritLabel,\n ...rest\n } = props\n\n const valueProviderProps = removeUndefinedProps({\n transformLabel,\n inheritVisibility,\n inheritLabel,\n })\n\n return (\n <SummaryListContext.Provider value={{ layout }}>\n <Dl\n className={classnames('dnb-forms-summary-list', className)}\n layout={layout}\n {...rest}\n >\n <ValueProvider {...valueProviderProps}>{children}</ValueProvider>\n </Dl>\n </SummaryListContext.Provider>\n )\n}\n\nSummaryList._supportsSpacingProps = true\n\nexport default SummaryList\n"],"mappings":";;;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,oBAAoB,QAAQ,qCAAqC;AAC1E,OAAOC,kBAAkB,MAAM,sBAAsB;AACrD,OAAOC,EAAE,MAAsB,yBAAyB;AACxD,OAAOC,aAAa,MAAM,2BAA2B;AASrD,SAASC,WAAWA,CAACC,KAAY,EAAE;EACjC,MAAM;MACJC,SAAS;MACTC,QAAQ;MACRC,MAAM;MACNC,cAAc;MACdC,iBAAiB;MACjBC;IAEF,CAAC,GAAGN,KAAK;IADJO,IAAI,GAAAC,wBAAA,CACLR,KAAK,EAAAS,SAAA;EAET,MAAMC,kBAAkB,GAAGf,oBAAoB,CAAC;IAC9CS,cAAc;IACdC,iBAAiB;IACjBC;EACF,CAAC,CAAC;EAEF,OACEb,KAAA,CAAAkB,aAAA,CAACf,kBAAkB,CAACgB,QAAQ;IAACC,KAAK,EAAE;MAAEV;IAAO;EAAE,GAC7CV,KAAA,CAAAkB,aAAA,CAACd,EAAE,EAAAiB,QAAA;IACDb,SAAS,EAAEP,UAAU,CAAC,wBAAwB,EAAEO,SAAS,CAAE;IAC3DE,MAAM,EAAEA;EAAO,GACXI,IAAI,GAERd,KAAA,CAAAkB,aAAA,CAACb,aAAa,EAAKY,kBAAkB,EAAGR,QAAwB,CAC9D,CACuB,CAAC;AAElC;AAEAH,WAAW,CAACgB,qBAAqB,GAAG,IAAI;AAExC,eAAehB,WAAW"}
@@ -4,6 +4,11 @@ export const SummaryListProperties = {
4
4
  type: 'string',
5
5
  status: 'optional'
6
6
  },
7
+ transformLabel: {
8
+ doc: 'Transforms the label before it gets displayed. Receives the label as the first parameter. The second parameter is a object containing the `convertJsxToString` function.',
9
+ type: 'function',
10
+ status: 'optional'
11
+ },
7
12
  inheritVisibility: {
8
13
  doc: 'Use this property to propagate the `inheritVisibility` property to all nested values.',
9
14
  type: 'boolean',
@@ -1 +1 @@
1
- {"version":3,"file":"SummaryListDocs.js","names":["SummaryListProperties","layout","doc","type","status","inheritVisibility","inheritLabel","children","StepEvents"],"sources":["../../../../../../src/extensions/forms/Value/SummaryList/SummaryListDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const SummaryListProperties: PropertiesTableProps = {\n layout: {\n doc: 'Use `grid`, `horizontal` or `vertical`.',\n type: 'string',\n status: 'optional',\n },\n inheritVisibility: {\n doc: 'Use this property to propagate the `inheritVisibility` property to all nested values.',\n type: 'boolean',\n status: 'optional',\n },\n inheritLabel: {\n doc: 'Use this property to propagate the `inheritLabel` property to all nested values.',\n type: 'boolean',\n status: 'optional',\n },\n children: {\n doc: 'Contents.',\n type: 'React.Node',\n status: 'required',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const StepEvents: PropertiesTableProps = {}\n"],"mappings":"AAEA,OAAO,MAAMA,qBAA2C,GAAG;EACzDC,MAAM,EAAE;IACNC,GAAG,EAAE,yCAAyC;IAC9CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,iBAAiB,EAAE;IACjBH,GAAG,EAAE,uFAAuF;IAC5FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDE,YAAY,EAAE;IACZJ,GAAG,EAAE,kFAAkF;IACvFC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDG,QAAQ,EAAE;IACRL,GAAG,EAAE,WAAW;IAChBC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMI,UAAgC,GAAG,CAAC,CAAC"}
1
+ {"version":3,"file":"SummaryListDocs.js","names":["SummaryListProperties","layout","doc","type","status","transformLabel","inheritVisibility","inheritLabel","children","StepEvents"],"sources":["../../../../../../src/extensions/forms/Value/SummaryList/SummaryListDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../../shared/types'\n\nexport const SummaryListProperties: PropertiesTableProps = {\n layout: {\n doc: 'Use `grid`, `horizontal` or `vertical`.',\n type: 'string',\n status: 'optional',\n },\n transformLabel: {\n doc: 'Transforms the label before it gets displayed. Receives the label as the first parameter. The second parameter is a object containing the `convertJsxToString` function.',\n type: 'function',\n status: 'optional',\n },\n inheritVisibility: {\n doc: 'Use this property to propagate the `inheritVisibility` property to all nested values.',\n type: 'boolean',\n status: 'optional',\n },\n inheritLabel: {\n doc: 'Use this property to propagate the `inheritLabel` property to all nested values.',\n type: 'boolean',\n status: 'optional',\n },\n children: {\n doc: 'Contents.',\n type: 'React.Node',\n status: 'required',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n\nexport const StepEvents: PropertiesTableProps = {}\n"],"mappings":"AAEA,OAAO,MAAMA,qBAA2C,GAAG;EACzDC,MAAM,EAAE;IACNC,GAAG,EAAE,yCAAyC;IAC9CC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDC,cAAc,EAAE;IACdH,GAAG,EAAE,0KAA0K;IAC/KC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDE,iBAAiB,EAAE;IACjBJ,GAAG,EAAE,uFAAuF;IAC5FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDG,YAAY,EAAE;IACZL,GAAG,EAAE,kFAAkF;IACvFC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,QAAQ,EAAE;IACRN,GAAG,EAAE,WAAW;IAChBC,IAAI,EAAE,YAAY;IAClBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC;AAED,OAAO,MAAMK,UAAgC,GAAG,CAAC,CAAC"}
@@ -14,6 +14,11 @@ export const ValueProperties = {
14
14
  type: 'string',
15
15
  status: 'optional'
16
16
  },
17
+ transformLabel: {
18
+ doc: 'Transforms the label before it gets displayed. Receives the label as the first parameter. The second parameter is a object containing the `convertJsxToString` function.',
19
+ type: 'function',
20
+ status: 'optional'
21
+ },
17
22
  inheritLabel: {
18
23
  doc: 'Use `true` to inherit the label from a visible (rendered) field with the same path.',
19
24
  type: 'boolean',
@@ -1 +1 @@
1
- {"version":3,"file":"ValueDocs.js","names":["ValueProperties","value","doc","type","status","defaultValue","label","inheritLabel","inheritVisibility","showEmpty","placeholder","path","inline","maxWidth","transformIn"],"sources":["../../../../../src/extensions/forms/Value/ValueDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../shared/types'\n\nexport const ValueProperties: PropertiesTableProps = {\n value: {\n doc: 'Value for the value component. Will take precedence over the path value given in the data context.',\n type: '{valueType}',\n status: 'optional',\n },\n defaultValue: {\n doc: 'Default value for the value component. Will not take precedence over the path value given in the data context.',\n type: '{valueType}',\n status: 'optional',\n },\n label: {\n doc: 'Field label to show above the displayed value.',\n type: 'string',\n status: 'optional',\n },\n inheritLabel: {\n doc: 'Use `true` to inherit the label from a visible (rendered) field with the same path.',\n type: 'boolean',\n status: 'optional',\n },\n inheritVisibility: {\n doc: 'Use `true` to inherit the visibility from a field with the same path. You can find more info in the [Value section](/uilib/extensions/forms/Value/#inherit-visibility-from-fields-based-on-path).',\n type: 'boolean',\n status: 'optional',\n },\n showEmpty: {\n doc: 'Shows the value even if it is empty.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Text showing in place of the value if no value is given.',\n type: 'string',\n status: 'optional',\n },\n path: {\n doc: 'JSON Pointer for where the data for this input is located in the source dataset.',\n type: 'string',\n status: 'optional',\n },\n inline: {\n doc: 'For showing the value inline (not as a block element).',\n type: 'boolean',\n status: 'optional',\n },\n maxWidth: {\n doc: 'Use `auto` for no max-width (use browser default), `small`, `medium` or `large` for predefined standard max widths. Defaults to `large`.',\n type: 'string',\n status: 'optional',\n },\n transformIn: {\n doc: 'Transforms the `value` before its displayed in the value component.',\n type: 'function',\n status: 'optional',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oGAAoG;IACzGC,IAAI,EAAE,aAAa;IACnBC,MAAM,EAAE;EACV,CAAC;EACDC,YAAY,EAAE;IACZH,GAAG,EAAE,gHAAgH;IACrHC,IAAI,EAAE,aAAa;IACnBC,MAAM,EAAE;EACV,CAAC;EACDE,KAAK,EAAE;IACLJ,GAAG,EAAE,gDAAgD;IACrDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,YAAY,EAAE;IACZL,GAAG,EAAE,qFAAqF;IAC1FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDI,iBAAiB,EAAE;IACjBN,GAAG,EAAE,mMAAmM;IACxMC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDK,SAAS,EAAE;IACTP,GAAG,EAAE,sCAAsC;IAC3CC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,WAAW,EAAE;IACXR,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDO,IAAI,EAAE;IACJT,GAAG,EAAE,kFAAkF;IACvFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,MAAM,EAAE;IACNV,GAAG,EAAE,wDAAwD;IAC7DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDS,QAAQ,EAAE;IACRX,GAAG,EAAE,0IAA0I;IAC/IC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDU,WAAW,EAAE;IACXZ,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC"}
1
+ {"version":3,"file":"ValueDocs.js","names":["ValueProperties","value","doc","type","status","defaultValue","label","transformLabel","inheritLabel","inheritVisibility","showEmpty","placeholder","path","inline","maxWidth","transformIn"],"sources":["../../../../../src/extensions/forms/Value/ValueDocs.ts"],"sourcesContent":["import { PropertiesTableProps } from '../../../shared/types'\n\nexport const ValueProperties: PropertiesTableProps = {\n value: {\n doc: 'Value for the value component. Will take precedence over the path value given in the data context.',\n type: '{valueType}',\n status: 'optional',\n },\n defaultValue: {\n doc: 'Default value for the value component. Will not take precedence over the path value given in the data context.',\n type: '{valueType}',\n status: 'optional',\n },\n label: {\n doc: 'Field label to show above the displayed value.',\n type: 'string',\n status: 'optional',\n },\n transformLabel: {\n doc: 'Transforms the label before it gets displayed. Receives the label as the first parameter. The second parameter is a object containing the `convertJsxToString` function.',\n type: 'function',\n status: 'optional',\n },\n inheritLabel: {\n doc: 'Use `true` to inherit the label from a visible (rendered) field with the same path.',\n type: 'boolean',\n status: 'optional',\n },\n inheritVisibility: {\n doc: 'Use `true` to inherit the visibility from a field with the same path. You can find more info in the [Value section](/uilib/extensions/forms/Value/#inherit-visibility-from-fields-based-on-path).',\n type: 'boolean',\n status: 'optional',\n },\n showEmpty: {\n doc: 'Shows the value even if it is empty.',\n type: 'boolean',\n status: 'optional',\n },\n placeholder: {\n doc: 'Text showing in place of the value if no value is given.',\n type: 'string',\n status: 'optional',\n },\n path: {\n doc: 'JSON Pointer for where the data for this input is located in the source dataset.',\n type: 'string',\n status: 'optional',\n },\n inline: {\n doc: 'For showing the value inline (not as a block element).',\n type: 'boolean',\n status: 'optional',\n },\n maxWidth: {\n doc: 'Use `auto` for no max-width (use browser default), `small`, `medium` or `large` for predefined standard max widths. Defaults to `large`.',\n type: 'string',\n status: 'optional',\n },\n transformIn: {\n doc: 'Transforms the `value` before its displayed in the value component.',\n type: 'function',\n status: 'optional',\n },\n '[Space](/uilib/layout/space/properties)': {\n doc: 'Spacing properties like `top` or `bottom` are supported.',\n type: ['string', 'object'],\n status: 'optional',\n },\n}\n"],"mappings":"AAEA,OAAO,MAAMA,eAAqC,GAAG;EACnDC,KAAK,EAAE;IACLC,GAAG,EAAE,oGAAoG;IACzGC,IAAI,EAAE,aAAa;IACnBC,MAAM,EAAE;EACV,CAAC;EACDC,YAAY,EAAE;IACZH,GAAG,EAAE,gHAAgH;IACrHC,IAAI,EAAE,aAAa;IACnBC,MAAM,EAAE;EACV,CAAC;EACDE,KAAK,EAAE;IACLJ,GAAG,EAAE,gDAAgD;IACrDC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDG,cAAc,EAAE;IACdL,GAAG,EAAE,0KAA0K;IAC/KC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACDI,YAAY,EAAE;IACZN,GAAG,EAAE,qFAAqF;IAC1FC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDK,iBAAiB,EAAE;IACjBP,GAAG,EAAE,mMAAmM;IACxMC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDM,SAAS,EAAE;IACTR,GAAG,EAAE,sCAAsC;IAC3CC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDO,WAAW,EAAE;IACXT,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDQ,IAAI,EAAE;IACJV,GAAG,EAAE,kFAAkF;IACvFC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDS,MAAM,EAAE;IACNX,GAAG,EAAE,wDAAwD;IAC7DC,IAAI,EAAE,SAAS;IACfC,MAAM,EAAE;EACV,CAAC;EACDU,QAAQ,EAAE;IACRZ,GAAG,EAAE,0IAA0I;IAC/IC,IAAI,EAAE,QAAQ;IACdC,MAAM,EAAE;EACV,CAAC;EACDW,WAAW,EAAE;IACXb,GAAG,EAAE,qEAAqE;IAC1EC,IAAI,EAAE,UAAU;IAChBC,MAAM,EAAE;EACV,CAAC;EACD,yCAAyC,EAAE;IACzCF,GAAG,EAAE,0DAA0D;IAC/DC,IAAI,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC;IAC1BC,MAAM,EAAE;EACV;AACF,CAAC"}
@@ -14,9 +14,9 @@ function Buttons(props) {
14
14
  } = props;
15
15
  const {
16
16
  activeIndex,
17
- titlesRef
17
+ stepsRef
18
18
  } = useContext(WizardContext) || {};
19
- const totalSteps = Object.keys((titlesRef === null || titlesRef === void 0 ? void 0 : titlesRef.current) || {}).length || 0;
19
+ const totalSteps = Object.keys((stepsRef === null || stepsRef === void 0 ? void 0 : stepsRef.current) || {}).length || 0;
20
20
  const showPreviousButton = activeIndex > 0;
21
21
  const showNextButton = activeIndex < totalSteps - 1;
22
22
  if (!showPreviousButton && !showNextButton) {
@@ -1 +1 @@
1
- {"version":3,"file":"Buttons.js","names":["React","useContext","classnames","ButtonRow","NextButton","PreviousButton","WizardContext","Buttons","props","className","activeIndex","titlesRef","totalSteps","Object","keys","current","length","showPreviousButton","showNextButton","createElement","_extends","_PreviousButton","_NextButton","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Wizard/Buttons/Buttons.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport classnames from 'classnames'\nimport { ComponentProps } from '../../types'\nimport ButtonRow from '../../Form/ButtonRow'\nimport NextButton from '../NextButton'\nimport PreviousButton from '../PreviousButton'\nimport WizardContext from '../Context'\n\nexport type Props = ComponentProps & {\n children?: string\n}\n\nfunction Buttons(props: Props) {\n const { className } = props\n const { activeIndex, titlesRef } = useContext(WizardContext) || {}\n\n const totalSteps = Object.keys(titlesRef?.current || {}).length || 0\n const showPreviousButton = activeIndex > 0\n const showNextButton = activeIndex < totalSteps - 1\n\n if (!showPreviousButton && !showNextButton) {\n return null\n }\n\n return (\n <ButtonRow\n className={classnames('dnb-forms-buttons', className)}\n {...props}\n >\n {showPreviousButton && <PreviousButton />}\n {showNextButton && <NextButton />}\n </ButtonRow>\n )\n}\n\nButtons._supportsSpacingProps = true\nexport default Buttons\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,OAAOC,UAAU,MAAM,YAAY;AAEnC,OAAOC,SAAS,MAAM,sBAAsB;AAC5C,OAAOC,UAAU,MAAM,eAAe;AACtC,OAAOC,cAAc,MAAM,mBAAmB;AAC9C,OAAOC,aAAa,MAAM,YAAY;AAMtC,SAASC,OAAOA,CAACC,KAAY,EAAE;EAC7B,MAAM;IAAEC;EAAU,CAAC,GAAGD,KAAK;EAC3B,MAAM;IAAEE,WAAW;IAAEC;EAAU,CAAC,GAAGV,UAAU,CAACK,aAAa,CAAC,IAAI,CAAC,CAAC;EAElE,MAAMM,UAAU,GAAGC,MAAM,CAACC,IAAI,CAAC,CAAAH,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEI,OAAO,KAAI,CAAC,CAAC,CAAC,CAACC,MAAM,IAAI,CAAC;EACpE,MAAMC,kBAAkB,GAAGP,WAAW,GAAG,CAAC;EAC1C,MAAMQ,cAAc,GAAGR,WAAW,GAAGE,UAAU,GAAG,CAAC;EAEnD,IAAI,CAACK,kBAAkB,IAAI,CAACC,cAAc,EAAE;IAC1C,OAAO,IAAI;EACb;EAEA,OACElB,KAAA,CAAAmB,aAAA,CAAChB,SAAS,EAAAiB,QAAA;IACRX,SAAS,EAAEP,UAAU,CAAC,mBAAmB,EAAEO,SAAS;EAAE,GAClDD,KAAK,GAERS,kBAAkB,KAAAI,eAAA,KAAAA,eAAA,GAAIrB,KAAA,CAAAmB,aAAA,CAACd,cAAc,MAAE,CAAC,IACxCa,cAAc,KAAAI,WAAA,KAAAA,WAAA,GAAItB,KAAA,CAAAmB,aAAA,CAACf,UAAU,MAAE,CAAC,EACxB,CAAC;AAEhB;AAEAG,OAAO,CAACgB,qBAAqB,GAAG,IAAI;AACpC,eAAehB,OAAO"}
1
+ {"version":3,"file":"Buttons.js","names":["React","useContext","classnames","ButtonRow","NextButton","PreviousButton","WizardContext","Buttons","props","className","activeIndex","stepsRef","totalSteps","Object","keys","current","length","showPreviousButton","showNextButton","createElement","_extends","_PreviousButton","_NextButton","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Wizard/Buttons/Buttons.tsx"],"sourcesContent":["import React, { useContext } from 'react'\nimport classnames from 'classnames'\nimport { ComponentProps } from '../../types'\nimport ButtonRow from '../../Form/ButtonRow'\nimport NextButton from '../NextButton'\nimport PreviousButton from '../PreviousButton'\nimport WizardContext from '../Context'\n\nexport type Props = ComponentProps & {\n children?: string\n}\n\nfunction Buttons(props: Props) {\n const { className } = props\n const { activeIndex, stepsRef } = useContext(WizardContext) || {}\n\n const totalSteps = Object.keys(stepsRef?.current || {}).length || 0\n const showPreviousButton = activeIndex > 0\n const showNextButton = activeIndex < totalSteps - 1\n\n if (!showPreviousButton && !showNextButton) {\n return null\n }\n\n return (\n <ButtonRow\n className={classnames('dnb-forms-buttons', className)}\n {...props}\n >\n {showPreviousButton && <PreviousButton />}\n {showNextButton && <NextButton />}\n </ButtonRow>\n )\n}\n\nButtons._supportsSpacingProps = true\nexport default Buttons\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,OAAOC,UAAU,MAAM,YAAY;AAEnC,OAAOC,SAAS,MAAM,sBAAsB;AAC5C,OAAOC,UAAU,MAAM,eAAe;AACtC,OAAOC,cAAc,MAAM,mBAAmB;AAC9C,OAAOC,aAAa,MAAM,YAAY;AAMtC,SAASC,OAAOA,CAACC,KAAY,EAAE;EAC7B,MAAM;IAAEC;EAAU,CAAC,GAAGD,KAAK;EAC3B,MAAM;IAAEE,WAAW;IAAEC;EAAS,CAAC,GAAGV,UAAU,CAACK,aAAa,CAAC,IAAI,CAAC,CAAC;EAEjE,MAAMM,UAAU,GAAGC,MAAM,CAACC,IAAI,CAAC,CAAAH,QAAQ,aAARA,QAAQ,uBAARA,QAAQ,CAAEI,OAAO,KAAI,CAAC,CAAC,CAAC,CAACC,MAAM,IAAI,CAAC;EACnE,MAAMC,kBAAkB,GAAGP,WAAW,GAAG,CAAC;EAC1C,MAAMQ,cAAc,GAAGR,WAAW,GAAGE,UAAU,GAAG,CAAC;EAEnD,IAAI,CAACK,kBAAkB,IAAI,CAACC,cAAc,EAAE;IAC1C,OAAO,IAAI;EACb;EAEA,OACElB,KAAA,CAAAmB,aAAA,CAAChB,SAAS,EAAAiB,QAAA;IACRX,SAAS,EAAEP,UAAU,CAAC,mBAAmB,EAAEO,SAAS;EAAE,GAClDD,KAAK,GAERS,kBAAkB,KAAAI,eAAA,KAAAA,eAAA,GAAIrB,KAAA,CAAAmB,aAAA,CAACd,cAAc,MAAE,CAAC,IACxCa,cAAc,KAAAI,WAAA,KAAAA,WAAA,GAAItB,KAAA,CAAAmB,aAAA,CAACf,UAAU,MAAE,CAAC,EACxB,CAAC;AAEhB;AAEAG,OAAO,CAACgB,qBAAqB,GAAG,IAAI;AACpC,eAAehB,OAAO"}