@dnb/eufemia 10.34.0 → 10.35.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 (984) hide show
  1. package/CHANGELOG.md +50 -0
  2. package/assets/images/sbanken/sbanken-compact-horizontal.svg +3 -0
  3. package/assets/images/sbanken/sbanken-compact.svg +3 -0
  4. package/assets/images/sbanken/sbanken.svg +3 -0
  5. package/cjs/components/accordion/Accordion.d.ts +0 -2
  6. package/cjs/components/accordion/Accordion.js +2 -3
  7. package/cjs/components/accordion/Accordion.js.map +1 -1
  8. package/cjs/components/accordion/AccordionGroup.js +2 -3
  9. package/cjs/components/accordion/AccordionGroup.js.map +1 -1
  10. package/cjs/components/anchor/Anchor.d.ts +3 -0
  11. package/cjs/components/anchor/Anchor.js +22 -15
  12. package/cjs/components/anchor/Anchor.js.map +1 -1
  13. package/cjs/components/autocomplete/Autocomplete.js +2 -4
  14. package/cjs/components/autocomplete/Autocomplete.js.map +1 -1
  15. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +1 -1
  16. package/cjs/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +1 -1
  17. package/cjs/components/button/Button.d.ts +0 -4
  18. package/cjs/components/button/Button.js +2 -5
  19. package/cjs/components/button/Button.js.map +1 -1
  20. package/cjs/components/date-picker/DatePicker.d.ts +0 -1
  21. package/cjs/components/date-picker/DatePicker.js +2 -5
  22. package/cjs/components/date-picker/DatePicker.js.map +1 -1
  23. package/cjs/components/dropdown/Dropdown.js +2 -5
  24. package/cjs/components/dropdown/Dropdown.js.map +1 -1
  25. package/cjs/components/form-row/FormRow.d.ts +0 -1
  26. package/cjs/components/form-row/FormRow.js +2 -5
  27. package/cjs/components/form-row/FormRow.js.map +1 -1
  28. package/cjs/components/form-set/FormSet.d.ts +0 -1
  29. package/cjs/components/form-set/FormSet.js +3 -4
  30. package/cjs/components/form-set/FormSet.js.map +1 -1
  31. package/cjs/components/form-status/FormStatus.d.ts +0 -1
  32. package/cjs/components/form-status/FormStatus.js +2 -5
  33. package/cjs/components/form-status/FormStatus.js.map +1 -1
  34. package/cjs/components/global-status/GlobalStatus.d.ts +0 -1
  35. package/cjs/components/global-status/GlobalStatus.js +2 -5
  36. package/cjs/components/global-status/GlobalStatus.js.map +1 -1
  37. package/cjs/components/global-status/GlobalStatusController.js.map +1 -1
  38. package/cjs/components/global-status/GlobalStatusProvider.js.map +1 -1
  39. package/cjs/components/help-button/HelpButton.js +3 -0
  40. package/cjs/components/help-button/HelpButton.js.map +1 -1
  41. package/cjs/components/help-button/HelpButtonInstance.js +3 -4
  42. package/cjs/components/help-button/HelpButtonInstance.js.map +1 -1
  43. package/cjs/components/help-button/style/dnb-help-button.css +4 -1
  44. package/cjs/components/help-button/style/dnb-help-button.min.css +1 -0
  45. package/cjs/components/help-button/style/dnb-help-button.scss +6 -0
  46. package/cjs/components/icon/Icon.js +2 -3
  47. package/cjs/components/icon/Icon.js.map +1 -1
  48. package/cjs/components/icon-primary/IconPrimary.js.map +1 -1
  49. package/cjs/components/input/Input.d.ts +0 -1
  50. package/cjs/components/input/Input.js +2 -5
  51. package/cjs/components/input/Input.js.map +1 -1
  52. package/cjs/components/input-masked/InputMasked.d.ts +0 -1
  53. package/cjs/components/input-masked/InputMasked.js.map +1 -1
  54. package/cjs/components/logo/Logo.d.ts +47 -43
  55. package/cjs/components/logo/Logo.js +77 -224
  56. package/cjs/components/logo/Logo.js.map +1 -1
  57. package/cjs/components/logo/LogoDocs.d.ts +2 -0
  58. package/cjs/components/logo/LogoDocs.js +50 -0
  59. package/cjs/components/logo/LogoDocs.js.map +1 -0
  60. package/cjs/components/logo/LogoSvg.d.ts +7 -0
  61. package/cjs/components/logo/LogoSvg.js +81 -0
  62. package/cjs/components/logo/LogoSvg.js.map +1 -0
  63. package/cjs/components/modal/Modal.d.ts +2 -1
  64. package/cjs/components/modal/Modal.js +26 -12
  65. package/cjs/components/modal/Modal.js.map +1 -1
  66. package/cjs/components/modal/types.d.ts +0 -4
  67. package/cjs/components/modal/types.js.map +1 -1
  68. package/cjs/components/number-format/NumberFormat.d.ts +4 -0
  69. package/cjs/components/number-format/NumberFormat.js +5 -5
  70. package/cjs/components/number-format/NumberFormat.js.map +1 -1
  71. package/cjs/components/number-format/style/dnb-number-format.css +3 -0
  72. package/cjs/components/number-format/style/dnb-number-format.min.css +1 -1
  73. package/cjs/components/number-format/style/dnb-number-format.scss +4 -0
  74. package/cjs/components/pagination/Pagination.d.ts +0 -3
  75. package/cjs/components/pagination/Pagination.js +2 -5
  76. package/cjs/components/pagination/Pagination.js.map +1 -1
  77. package/cjs/components/pagination/PaginationHelpers.js.map +1 -1
  78. package/cjs/components/pagination/PaginationInfinity.js.map +1 -1
  79. package/cjs/components/pagination/PaginationProvider.js.map +1 -1
  80. package/cjs/components/progress-indicator/ProgressIndicatorDocs.js +1 -1
  81. package/cjs/components/progress-indicator/ProgressIndicatorDocs.js.map +1 -1
  82. package/cjs/components/progress-indicator/types.d.ts +1 -1
  83. package/cjs/components/progress-indicator/types.js.map +1 -1
  84. package/cjs/components/radio/Radio.d.ts +0 -1
  85. package/cjs/components/radio/Radio.js +2 -5
  86. package/cjs/components/radio/Radio.js.map +1 -1
  87. package/cjs/components/radio/RadioGroup.d.ts +0 -1
  88. package/cjs/components/radio/RadioGroup.js +2 -5
  89. package/cjs/components/radio/RadioGroup.js.map +1 -1
  90. package/cjs/components/skeleton/Skeleton.d.ts +0 -1
  91. package/cjs/components/skeleton/Skeleton.js +2 -5
  92. package/cjs/components/skeleton/Skeleton.js.map +1 -1
  93. package/cjs/components/switch/Switch.d.ts +0 -1
  94. package/cjs/components/switch/Switch.js +2 -5
  95. package/cjs/components/switch/Switch.js.map +1 -1
  96. package/cjs/components/table/Table.d.ts +6 -0
  97. package/cjs/components/table/Table.js +15 -3
  98. package/cjs/components/table/Table.js.map +1 -1
  99. package/cjs/components/table/TableAccordion.d.ts +7 -11
  100. package/cjs/components/table/TableAccordion.js +32 -21
  101. package/cjs/components/table/TableAccordion.js.map +1 -1
  102. package/cjs/components/table/TableTr.js +24 -25
  103. package/cjs/components/table/TableTr.js.map +1 -1
  104. package/cjs/components/tabs/Tabs.d.ts +0 -1
  105. package/cjs/components/tabs/Tabs.js +1 -7
  106. package/cjs/components/tabs/Tabs.js.map +1 -1
  107. package/cjs/components/tabs/TabsCustomContent.d.ts +0 -1
  108. package/cjs/components/tabs/TabsCustomContent.js +5 -8
  109. package/cjs/components/tabs/TabsCustomContent.js.map +1 -1
  110. package/cjs/components/tabs/TabsDocs.js +1 -1
  111. package/cjs/components/tabs/TabsDocs.js.map +1 -1
  112. package/cjs/components/textarea/Textarea.d.ts +0 -1
  113. package/cjs/components/textarea/Textarea.js +2 -5
  114. package/cjs/components/textarea/Textarea.js.map +1 -1
  115. package/cjs/components/toggle-button/ToggleButton.d.ts +0 -1
  116. package/cjs/components/toggle-button/ToggleButton.js +2 -5
  117. package/cjs/components/toggle-button/ToggleButton.js.map +1 -1
  118. package/cjs/components/toggle-button/ToggleButtonGroup.d.ts +0 -1
  119. package/cjs/components/toggle-button/ToggleButtonGroup.js +2 -5
  120. package/cjs/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  121. package/cjs/extensions/forms/DataContext/Context.d.ts +2 -0
  122. package/cjs/extensions/forms/DataContext/Context.js +1 -0
  123. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  124. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +17 -1
  125. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  126. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +5 -3
  127. package/cjs/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  128. package/cjs/extensions/forms/DataContext/Provider/Provider.js +50 -4
  129. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  130. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -2
  131. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js +7 -1
  132. package/cjs/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  133. package/cjs/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  134. package/cjs/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  135. package/cjs/extensions/forms/Field/Number/style/dnb-number.css +10 -0
  136. package/cjs/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  137. package/cjs/extensions/forms/Field/Number/style/dnb-number.scss +11 -0
  138. package/cjs/extensions/forms/Field/Option/Option.d.ts +2 -2
  139. package/cjs/extensions/forms/Field/Option/Option.js.map +1 -1
  140. package/cjs/extensions/forms/Field/Password/Password.js +2 -1
  141. package/cjs/extensions/forms/Field/Password/Password.js.map +1 -1
  142. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js +6 -6
  143. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  144. package/cjs/extensions/forms/Field/Selection/Selection.js +7 -2
  145. package/cjs/extensions/forms/Field/Selection/Selection.js.map +1 -1
  146. package/cjs/extensions/forms/Field/Toggle/Toggle.d.ts +2 -2
  147. package/cjs/extensions/forms/Field/Toggle/Toggle.js +13 -1
  148. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  149. package/cjs/extensions/forms/Form/Appearance/Appearance.d.ts +3 -0
  150. package/cjs/extensions/forms/Form/Appearance/Appearance.js +1 -0
  151. package/cjs/extensions/forms/Form/Appearance/Appearance.js.map +1 -1
  152. package/cjs/extensions/forms/Form/FieldProps/FieldProps.d.ts +5 -1
  153. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js +20 -37
  154. package/cjs/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  155. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.d.ts +12 -0
  156. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js +44 -0
  157. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -0
  158. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainerDocs.d.ts +3 -0
  159. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js +27 -0
  160. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js.map +1 -0
  161. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.d.ts +1 -0
  162. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +67 -0
  163. package/cjs/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -0
  164. package/cjs/extensions/forms/Form/Section/EditContainer/index.d.ts +2 -0
  165. package/cjs/extensions/forms/Form/Section/EditContainer/index.js +27 -0
  166. package/cjs/extensions/forms/Form/Section/EditContainer/index.js.map +1 -0
  167. package/cjs/extensions/forms/Form/Section/EditContainer/useContainerDataStore.d.ts +3 -0
  168. package/cjs/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +54 -0
  169. package/cjs/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -0
  170. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +1 -0
  171. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +25 -0
  172. package/cjs/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +1 -0
  173. package/cjs/extensions/forms/Form/Section/Section.d.ts +9 -1
  174. package/cjs/extensions/forms/Form/Section/Section.js +10 -2
  175. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  176. package/cjs/extensions/forms/Form/Section/SectionContext.d.ts +1 -2
  177. package/cjs/extensions/forms/Form/Section/SectionContext.js.map +1 -1
  178. package/cjs/extensions/forms/Form/Section/SectionDocs.js +6 -1
  179. package/cjs/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  180. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainer.d.ts +12 -0
  181. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainer.js +43 -0
  182. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainer.js.map +1 -0
  183. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.d.ts +3 -0
  184. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js +27 -0
  185. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js.map +1 -0
  186. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.d.ts +1 -0
  187. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.js +34 -0
  188. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.js.map +1 -0
  189. package/cjs/extensions/forms/Form/Section/ViewContainer/index.d.ts +2 -0
  190. package/cjs/extensions/forms/Form/Section/ViewContainer/index.js +27 -0
  191. package/cjs/extensions/forms/Form/Section/ViewContainer/index.js.map +1 -0
  192. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.d.ts +19 -0
  193. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js +93 -0
  194. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -0
  195. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +8 -0
  196. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.js +12 -0
  197. package/cjs/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -0
  198. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +8 -0
  199. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js +33 -0
  200. package/cjs/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -0
  201. package/cjs/extensions/forms/Form/Section/containers/Toolbar.d.ts +7 -0
  202. package/cjs/extensions/forms/Form/Section/containers/Toolbar.js +35 -0
  203. package/cjs/extensions/forms/Form/Section/containers/Toolbar.js.map +1 -0
  204. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +45 -0
  205. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -0
  206. package/{extensions/forms/Iterate/style/dnb-form-iterate.scss → cjs/extensions/forms/Form/Section/style/dnb-form-section.scss} +4 -12
  207. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +8 -8
  208. package/cjs/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  209. package/cjs/extensions/forms/Iterate/Array/Array.js +1 -1
  210. package/cjs/extensions/forms/Iterate/Array/Array.js.map +1 -1
  211. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +1 -1
  212. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  213. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +17 -8
  214. package/cjs/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  215. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  216. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  217. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +1 -1
  218. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  219. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +1 -1
  220. package/cjs/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  221. package/cjs/extensions/forms/Iterate/style/dnb-iterate.css +6 -0
  222. package/cjs/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -0
  223. package/cjs/extensions/forms/Iterate/style/dnb-iterate.scss +12 -0
  224. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +1 -1
  225. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  226. package/cjs/extensions/forms/Wizard/Step/Step.js +1 -1
  227. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  228. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  229. package/cjs/extensions/forms/constants/locales/en-GB.js +3 -2
  230. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  231. package/cjs/extensions/forms/constants/locales/en-US.d.ts +2 -1
  232. package/cjs/extensions/forms/constants/locales/index.d.ts +4 -2
  233. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  234. package/cjs/extensions/forms/constants/locales/nb-NO.js +3 -2
  235. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  236. package/cjs/extensions/forms/hooks/useDataValue.d.ts +4 -0
  237. package/cjs/extensions/forms/hooks/useDataValue.js +30 -5
  238. package/cjs/extensions/forms/hooks/useDataValue.js.map +1 -1
  239. package/cjs/extensions/forms/hooks/useFieldProps.js +14 -9
  240. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  241. package/cjs/extensions/forms/hooks/useTranslation.js +6 -11
  242. package/cjs/extensions/forms/hooks/useTranslation.js.map +1 -1
  243. package/cjs/extensions/forms/style/dnb-forms.css +56 -44
  244. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  245. package/cjs/extensions/payment-card/PaymentCard.js +0 -2
  246. package/cjs/extensions/payment-card/PaymentCard.js.map +1 -1
  247. package/cjs/fragments/drawer-list/DrawerList.d.ts +0 -1
  248. package/cjs/fragments/drawer-list/DrawerList.js +6 -13
  249. package/cjs/fragments/drawer-list/DrawerList.js.map +1 -1
  250. package/cjs/fragments/drawer-list/DrawerListHelpers.d.ts +43 -46
  251. package/cjs/fragments/drawer-list/DrawerListHelpers.js +0 -2
  252. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  253. package/cjs/fragments/drawer-list/DrawerListPortal.js.map +1 -1
  254. package/cjs/fragments/drawer-list/DrawerListProvider.js.map +1 -1
  255. package/cjs/fragments/drawer-list/style/dnb-drawer-list.scss +4 -0
  256. package/cjs/fragments/text-counter/TextCounter.js +3 -2
  257. package/cjs/fragments/text-counter/TextCounter.js.map +1 -1
  258. package/cjs/shared/Context.d.ts +9 -5
  259. package/cjs/shared/Context.js +40 -35
  260. package/cjs/shared/Context.js.map +1 -1
  261. package/cjs/shared/Eufemia.d.ts +1 -1
  262. package/cjs/shared/Eufemia.js +2 -2
  263. package/cjs/shared/Eufemia.js.map +1 -1
  264. package/cjs/shared/Provider.d.ts +1 -1
  265. package/cjs/shared/Provider.js +49 -42
  266. package/cjs/shared/Provider.js.map +1 -1
  267. package/cjs/shared/Translation.d.ts +5 -5
  268. package/cjs/shared/Translation.js +6 -11
  269. package/cjs/shared/Translation.js.map +1 -1
  270. package/cjs/shared/index.d.ts +1 -0
  271. package/cjs/shared/index.js +26 -1
  272. package/cjs/shared/index.js.map +1 -1
  273. package/cjs/shared/locales/en-GB.d.ts +0 -3
  274. package/cjs/shared/locales/en-GB.js +0 -3
  275. package/cjs/shared/locales/en-GB.js.map +1 -1
  276. package/cjs/shared/locales/en-US.d.ts +0 -3
  277. package/cjs/shared/locales/index.d.ts +0 -6
  278. package/cjs/shared/locales/nb-NO.d.ts +0 -3
  279. package/cjs/shared/locales/nb-NO.js +0 -3
  280. package/cjs/shared/locales/nb-NO.js.map +1 -1
  281. package/cjs/shared/useTranslation.d.ts +5 -4
  282. package/cjs/shared/useTranslation.js +14 -12
  283. package/cjs/shared/useTranslation.js.map +1 -1
  284. package/cjs/style/core/scopes.scss +1 -1
  285. package/cjs/style/dnb-ui-basis.css +1 -1
  286. package/cjs/style/dnb-ui-basis.min.css +1 -1
  287. package/cjs/style/dnb-ui-body.css +1 -1
  288. package/cjs/style/dnb-ui-body.min.css +1 -1
  289. package/cjs/style/dnb-ui-components.css +67 -44
  290. package/cjs/style/dnb-ui-components.min.css +2 -2
  291. package/cjs/style/dnb-ui-core.css +1 -1
  292. package/cjs/style/dnb-ui-core.min.css +1 -1
  293. package/cjs/style/dnb-ui-extensions.css +56 -44
  294. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  295. package/cjs/style/dnb-ui-forms.css +56 -44
  296. package/cjs/style/dnb-ui-forms.min.css +1 -1
  297. package/cjs/style/dnb-ui-forms.scss +2 -1
  298. package/cjs/style/dnb-ui-fragments.css +4 -0
  299. package/cjs/style/dnb-ui-fragments.min.css +1 -1
  300. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.css +2 -2
  301. package/cjs/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  302. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +123 -88
  303. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +3 -3
  304. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +56 -44
  305. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  306. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +56 -44
  307. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  308. package/cjs/style/themes/theme-sbanken/globals.scss +3 -2
  309. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.css +2 -2
  310. package/cjs/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  311. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +124 -89
  312. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +3 -3
  313. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +56 -44
  314. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  315. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +56 -44
  316. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  317. package/cjs/style/themes/theme-ui/globals.scss +3 -2
  318. package/cjs/style/themes/theme-ui/ui-theme-basis.css +2 -2
  319. package/cjs/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  320. package/cjs/style/themes/theme-ui/ui-theme-components.css +123 -88
  321. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +3 -3
  322. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +56 -44
  323. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  324. package/cjs/style/themes/theme-ui/ui-theme-forms.css +56 -44
  325. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  326. package/components/accordion/Accordion.d.ts +0 -2
  327. package/components/accordion/Accordion.js +2 -3
  328. package/components/accordion/Accordion.js.map +1 -1
  329. package/components/accordion/AccordionGroup.js +2 -3
  330. package/components/accordion/AccordionGroup.js.map +1 -1
  331. package/components/anchor/Anchor.d.ts +3 -0
  332. package/components/anchor/Anchor.js +21 -15
  333. package/components/anchor/Anchor.js.map +1 -1
  334. package/components/autocomplete/Autocomplete.js +2 -4
  335. package/components/autocomplete/Autocomplete.js.map +1 -1
  336. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +1 -1
  337. package/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +1 -1
  338. package/components/button/Button.d.ts +0 -4
  339. package/components/button/Button.js +2 -5
  340. package/components/button/Button.js.map +1 -1
  341. package/components/date-picker/DatePicker.d.ts +0 -1
  342. package/components/date-picker/DatePicker.js +2 -5
  343. package/components/date-picker/DatePicker.js.map +1 -1
  344. package/components/dropdown/Dropdown.js +2 -5
  345. package/components/dropdown/Dropdown.js.map +1 -1
  346. package/components/form-row/FormRow.d.ts +0 -1
  347. package/components/form-row/FormRow.js +2 -5
  348. package/components/form-row/FormRow.js.map +1 -1
  349. package/components/form-set/FormSet.d.ts +0 -1
  350. package/components/form-set/FormSet.js +3 -4
  351. package/components/form-set/FormSet.js.map +1 -1
  352. package/components/form-status/FormStatus.d.ts +0 -1
  353. package/components/form-status/FormStatus.js +2 -5
  354. package/components/form-status/FormStatus.js.map +1 -1
  355. package/components/global-status/GlobalStatus.d.ts +0 -1
  356. package/components/global-status/GlobalStatus.js +2 -5
  357. package/components/global-status/GlobalStatus.js.map +1 -1
  358. package/components/global-status/GlobalStatusController.js.map +1 -1
  359. package/components/global-status/GlobalStatusProvider.js.map +1 -1
  360. package/components/help-button/HelpButton.js +3 -0
  361. package/components/help-button/HelpButton.js.map +1 -1
  362. package/components/help-button/HelpButtonInstance.js +3 -4
  363. package/components/help-button/HelpButtonInstance.js.map +1 -1
  364. package/components/help-button/style/dnb-help-button.css +4 -1
  365. package/components/help-button/style/dnb-help-button.min.css +1 -0
  366. package/components/help-button/style/dnb-help-button.scss +6 -0
  367. package/components/icon/Icon.js +2 -3
  368. package/components/icon/Icon.js.map +1 -1
  369. package/components/icon-primary/IconPrimary.js.map +1 -1
  370. package/components/input/Input.d.ts +0 -1
  371. package/components/input/Input.js +2 -5
  372. package/components/input/Input.js.map +1 -1
  373. package/components/input-masked/InputMasked.d.ts +0 -1
  374. package/components/input-masked/InputMasked.js.map +1 -1
  375. package/components/logo/Logo.d.ts +47 -43
  376. package/components/logo/Logo.js +75 -224
  377. package/components/logo/Logo.js.map +1 -1
  378. package/components/logo/LogoDocs.d.ts +2 -0
  379. package/components/logo/LogoDocs.js +43 -0
  380. package/components/logo/LogoDocs.js.map +1 -0
  381. package/components/logo/LogoSvg.d.ts +7 -0
  382. package/components/logo/LogoSvg.js +73 -0
  383. package/components/logo/LogoSvg.js.map +1 -0
  384. package/components/modal/Modal.d.ts +2 -1
  385. package/components/modal/Modal.js +26 -12
  386. package/components/modal/Modal.js.map +1 -1
  387. package/components/modal/types.d.ts +0 -4
  388. package/components/modal/types.js.map +1 -1
  389. package/components/number-format/NumberFormat.d.ts +4 -0
  390. package/components/number-format/NumberFormat.js +5 -5
  391. package/components/number-format/NumberFormat.js.map +1 -1
  392. package/components/number-format/style/dnb-number-format.css +3 -0
  393. package/components/number-format/style/dnb-number-format.min.css +1 -1
  394. package/components/number-format/style/dnb-number-format.scss +4 -0
  395. package/components/pagination/Pagination.d.ts +0 -3
  396. package/components/pagination/Pagination.js +2 -5
  397. package/components/pagination/Pagination.js.map +1 -1
  398. package/components/pagination/PaginationHelpers.js.map +1 -1
  399. package/components/pagination/PaginationInfinity.js.map +1 -1
  400. package/components/pagination/PaginationProvider.js.map +1 -1
  401. package/components/progress-indicator/ProgressIndicatorDocs.js +1 -1
  402. package/components/progress-indicator/ProgressIndicatorDocs.js.map +1 -1
  403. package/components/progress-indicator/types.d.ts +1 -1
  404. package/components/progress-indicator/types.js.map +1 -1
  405. package/components/radio/Radio.d.ts +0 -1
  406. package/components/radio/Radio.js +2 -5
  407. package/components/radio/Radio.js.map +1 -1
  408. package/components/radio/RadioGroup.d.ts +0 -1
  409. package/components/radio/RadioGroup.js +2 -5
  410. package/components/radio/RadioGroup.js.map +1 -1
  411. package/components/skeleton/Skeleton.d.ts +0 -1
  412. package/components/skeleton/Skeleton.js +2 -5
  413. package/components/skeleton/Skeleton.js.map +1 -1
  414. package/components/switch/Switch.d.ts +0 -1
  415. package/components/switch/Switch.js +2 -5
  416. package/components/switch/Switch.js.map +1 -1
  417. package/components/table/Table.d.ts +6 -0
  418. package/components/table/Table.js +13 -3
  419. package/components/table/Table.js.map +1 -1
  420. package/components/table/TableAccordion.d.ts +7 -11
  421. package/components/table/TableAccordion.js +29 -20
  422. package/components/table/TableAccordion.js.map +1 -1
  423. package/components/table/TableTr.js +25 -26
  424. package/components/table/TableTr.js.map +1 -1
  425. package/components/tabs/Tabs.d.ts +0 -1
  426. package/components/tabs/Tabs.js +1 -7
  427. package/components/tabs/Tabs.js.map +1 -1
  428. package/components/tabs/TabsCustomContent.d.ts +0 -1
  429. package/components/tabs/TabsCustomContent.js +5 -8
  430. package/components/tabs/TabsCustomContent.js.map +1 -1
  431. package/components/tabs/TabsDocs.js +1 -1
  432. package/components/tabs/TabsDocs.js.map +1 -1
  433. package/components/textarea/Textarea.d.ts +0 -1
  434. package/components/textarea/Textarea.js +2 -5
  435. package/components/textarea/Textarea.js.map +1 -1
  436. package/components/toggle-button/ToggleButton.d.ts +0 -1
  437. package/components/toggle-button/ToggleButton.js +2 -5
  438. package/components/toggle-button/ToggleButton.js.map +1 -1
  439. package/components/toggle-button/ToggleButtonGroup.d.ts +0 -1
  440. package/components/toggle-button/ToggleButtonGroup.js +2 -5
  441. package/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  442. package/es/components/accordion/Accordion.d.ts +0 -2
  443. package/es/components/accordion/Accordion.js +2 -3
  444. package/es/components/accordion/Accordion.js.map +1 -1
  445. package/es/components/accordion/AccordionGroup.js +2 -3
  446. package/es/components/accordion/AccordionGroup.js.map +1 -1
  447. package/es/components/anchor/Anchor.d.ts +3 -0
  448. package/es/components/anchor/Anchor.js +21 -15
  449. package/es/components/anchor/Anchor.js.map +1 -1
  450. package/es/components/autocomplete/Autocomplete.js +2 -4
  451. package/es/components/autocomplete/Autocomplete.js.map +1 -1
  452. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.css +1 -1
  453. package/es/components/autocomplete/style/themes/dnb-autocomplete-theme-sbanken.scss +1 -1
  454. package/es/components/button/Button.d.ts +0 -4
  455. package/es/components/button/Button.js +2 -5
  456. package/es/components/button/Button.js.map +1 -1
  457. package/es/components/date-picker/DatePicker.d.ts +0 -1
  458. package/es/components/date-picker/DatePicker.js +2 -5
  459. package/es/components/date-picker/DatePicker.js.map +1 -1
  460. package/es/components/dropdown/Dropdown.js +2 -5
  461. package/es/components/dropdown/Dropdown.js.map +1 -1
  462. package/es/components/form-row/FormRow.d.ts +0 -1
  463. package/es/components/form-row/FormRow.js +2 -5
  464. package/es/components/form-row/FormRow.js.map +1 -1
  465. package/es/components/form-set/FormSet.d.ts +0 -1
  466. package/es/components/form-set/FormSet.js +3 -4
  467. package/es/components/form-set/FormSet.js.map +1 -1
  468. package/es/components/form-status/FormStatus.d.ts +0 -1
  469. package/es/components/form-status/FormStatus.js +2 -5
  470. package/es/components/form-status/FormStatus.js.map +1 -1
  471. package/es/components/global-status/GlobalStatus.d.ts +0 -1
  472. package/es/components/global-status/GlobalStatus.js +2 -5
  473. package/es/components/global-status/GlobalStatus.js.map +1 -1
  474. package/es/components/global-status/GlobalStatusController.js.map +1 -1
  475. package/es/components/global-status/GlobalStatusProvider.js.map +1 -1
  476. package/es/components/help-button/HelpButton.js +3 -0
  477. package/es/components/help-button/HelpButton.js.map +1 -1
  478. package/es/components/help-button/HelpButtonInstance.js +3 -4
  479. package/es/components/help-button/HelpButtonInstance.js.map +1 -1
  480. package/es/components/help-button/style/dnb-help-button.css +4 -1
  481. package/es/components/help-button/style/dnb-help-button.min.css +1 -0
  482. package/es/components/help-button/style/dnb-help-button.scss +6 -0
  483. package/es/components/icon/Icon.js +2 -3
  484. package/es/components/icon/Icon.js.map +1 -1
  485. package/es/components/icon-primary/IconPrimary.js.map +1 -1
  486. package/es/components/input/Input.d.ts +0 -1
  487. package/es/components/input/Input.js +2 -5
  488. package/es/components/input/Input.js.map +1 -1
  489. package/es/components/input-masked/InputMasked.d.ts +0 -1
  490. package/es/components/input-masked/InputMasked.js.map +1 -1
  491. package/es/components/logo/Logo.d.ts +47 -43
  492. package/es/components/logo/Logo.js +75 -224
  493. package/es/components/logo/Logo.js.map +1 -1
  494. package/es/components/logo/LogoDocs.d.ts +2 -0
  495. package/es/components/logo/LogoDocs.js +43 -0
  496. package/es/components/logo/LogoDocs.js.map +1 -0
  497. package/es/components/logo/LogoSvg.d.ts +7 -0
  498. package/es/components/logo/LogoSvg.js +72 -0
  499. package/es/components/logo/LogoSvg.js.map +1 -0
  500. package/es/components/modal/Modal.d.ts +2 -1
  501. package/es/components/modal/Modal.js +26 -12
  502. package/es/components/modal/Modal.js.map +1 -1
  503. package/es/components/modal/types.d.ts +0 -4
  504. package/es/components/modal/types.js.map +1 -1
  505. package/es/components/number-format/NumberFormat.d.ts +4 -0
  506. package/es/components/number-format/NumberFormat.js +5 -5
  507. package/es/components/number-format/NumberFormat.js.map +1 -1
  508. package/es/components/number-format/style/dnb-number-format.css +3 -0
  509. package/es/components/number-format/style/dnb-number-format.min.css +1 -1
  510. package/es/components/number-format/style/dnb-number-format.scss +4 -0
  511. package/es/components/pagination/Pagination.d.ts +0 -3
  512. package/es/components/pagination/Pagination.js +2 -5
  513. package/es/components/pagination/Pagination.js.map +1 -1
  514. package/es/components/pagination/PaginationHelpers.js.map +1 -1
  515. package/es/components/pagination/PaginationInfinity.js.map +1 -1
  516. package/es/components/pagination/PaginationProvider.js.map +1 -1
  517. package/es/components/progress-indicator/ProgressIndicatorDocs.js +1 -1
  518. package/es/components/progress-indicator/ProgressIndicatorDocs.js.map +1 -1
  519. package/es/components/progress-indicator/types.d.ts +1 -1
  520. package/es/components/progress-indicator/types.js.map +1 -1
  521. package/es/components/radio/Radio.d.ts +0 -1
  522. package/es/components/radio/Radio.js +2 -5
  523. package/es/components/radio/Radio.js.map +1 -1
  524. package/es/components/radio/RadioGroup.d.ts +0 -1
  525. package/es/components/radio/RadioGroup.js +2 -5
  526. package/es/components/radio/RadioGroup.js.map +1 -1
  527. package/es/components/skeleton/Skeleton.d.ts +0 -1
  528. package/es/components/skeleton/Skeleton.js +2 -5
  529. package/es/components/skeleton/Skeleton.js.map +1 -1
  530. package/es/components/switch/Switch.d.ts +0 -1
  531. package/es/components/switch/Switch.js +2 -5
  532. package/es/components/switch/Switch.js.map +1 -1
  533. package/es/components/table/Table.d.ts +6 -0
  534. package/es/components/table/Table.js +13 -3
  535. package/es/components/table/Table.js.map +1 -1
  536. package/es/components/table/TableAccordion.d.ts +7 -11
  537. package/es/components/table/TableAccordion.js +29 -19
  538. package/es/components/table/TableAccordion.js.map +1 -1
  539. package/es/components/table/TableTr.js +25 -26
  540. package/es/components/table/TableTr.js.map +1 -1
  541. package/es/components/tabs/Tabs.d.ts +0 -1
  542. package/es/components/tabs/Tabs.js +1 -7
  543. package/es/components/tabs/Tabs.js.map +1 -1
  544. package/es/components/tabs/TabsCustomContent.d.ts +0 -1
  545. package/es/components/tabs/TabsCustomContent.js +5 -8
  546. package/es/components/tabs/TabsCustomContent.js.map +1 -1
  547. package/es/components/tabs/TabsDocs.js +1 -1
  548. package/es/components/tabs/TabsDocs.js.map +1 -1
  549. package/es/components/textarea/Textarea.d.ts +0 -1
  550. package/es/components/textarea/Textarea.js +2 -5
  551. package/es/components/textarea/Textarea.js.map +1 -1
  552. package/es/components/toggle-button/ToggleButton.d.ts +0 -1
  553. package/es/components/toggle-button/ToggleButton.js +2 -5
  554. package/es/components/toggle-button/ToggleButton.js.map +1 -1
  555. package/es/components/toggle-button/ToggleButtonGroup.d.ts +0 -1
  556. package/es/components/toggle-button/ToggleButtonGroup.js +2 -5
  557. package/es/components/toggle-button/ToggleButtonGroup.js.map +1 -1
  558. package/es/extensions/forms/DataContext/Context.d.ts +2 -0
  559. package/es/extensions/forms/DataContext/Context.js +1 -0
  560. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  561. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +17 -1
  562. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  563. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +5 -3
  564. package/es/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  565. package/es/extensions/forms/DataContext/Provider/Provider.js +46 -1
  566. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  567. package/es/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -2
  568. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js +8 -2
  569. package/es/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  570. package/es/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  571. package/es/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  572. package/es/extensions/forms/Field/Number/style/dnb-number.css +10 -0
  573. package/es/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  574. package/es/extensions/forms/Field/Number/style/dnb-number.scss +11 -0
  575. package/es/extensions/forms/Field/Option/Option.d.ts +2 -2
  576. package/es/extensions/forms/Field/Option/Option.js.map +1 -1
  577. package/es/extensions/forms/Field/Password/Password.js +2 -1
  578. package/es/extensions/forms/Field/Password/Password.js.map +1 -1
  579. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js +6 -6
  580. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  581. package/es/extensions/forms/Field/Selection/Selection.js +7 -2
  582. package/es/extensions/forms/Field/Selection/Selection.js.map +1 -1
  583. package/es/extensions/forms/Field/Toggle/Toggle.d.ts +2 -2
  584. package/es/extensions/forms/Field/Toggle/Toggle.js +14 -2
  585. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  586. package/es/extensions/forms/Form/Appearance/Appearance.d.ts +3 -0
  587. package/es/extensions/forms/Form/Appearance/Appearance.js +1 -0
  588. package/es/extensions/forms/Form/Appearance/Appearance.js.map +1 -1
  589. package/es/extensions/forms/Form/FieldProps/FieldProps.d.ts +5 -1
  590. package/es/extensions/forms/Form/FieldProps/FieldProps.js +19 -37
  591. package/es/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  592. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.d.ts +12 -0
  593. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js +33 -0
  594. package/es/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -0
  595. package/es/extensions/forms/Form/Section/EditContainer/EditContainerDocs.d.ts +3 -0
  596. package/es/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js +19 -0
  597. package/es/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js.map +1 -0
  598. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.d.ts +1 -0
  599. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +59 -0
  600. package/es/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -0
  601. package/es/extensions/forms/Form/Section/EditContainer/index.d.ts +2 -0
  602. package/es/extensions/forms/Form/Section/EditContainer/index.js +3 -0
  603. package/es/extensions/forms/Form/Section/EditContainer/index.js.map +1 -0
  604. package/es/extensions/forms/Form/Section/EditContainer/useContainerDataStore.d.ts +3 -0
  605. package/es/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +46 -0
  606. package/es/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -0
  607. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +1 -0
  608. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +19 -0
  609. package/es/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +1 -0
  610. package/es/extensions/forms/Form/Section/Section.d.ts +9 -1
  611. package/es/extensions/forms/Form/Section/Section.js +10 -2
  612. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  613. package/es/extensions/forms/Form/Section/SectionContext.d.ts +1 -2
  614. package/es/extensions/forms/Form/Section/SectionContext.js.map +1 -1
  615. package/es/extensions/forms/Form/Section/SectionDocs.js +6 -1
  616. package/es/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  617. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainer.d.ts +12 -0
  618. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainer.js +32 -0
  619. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainer.js.map +1 -0
  620. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.d.ts +3 -0
  621. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js +19 -0
  622. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js.map +1 -0
  623. package/es/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.d.ts +1 -0
  624. package/es/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.js +26 -0
  625. package/es/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.js.map +1 -0
  626. package/es/extensions/forms/Form/Section/ViewContainer/index.d.ts +2 -0
  627. package/es/extensions/forms/Form/Section/ViewContainer/index.js +3 -0
  628. package/es/extensions/forms/Form/Section/ViewContainer/index.js.map +1 -0
  629. package/es/extensions/forms/Form/Section/containers/SectionContainer.d.ts +19 -0
  630. package/es/extensions/forms/Form/Section/containers/SectionContainer.js +83 -0
  631. package/es/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -0
  632. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +8 -0
  633. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.js +4 -0
  634. package/es/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -0
  635. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +8 -0
  636. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js +24 -0
  637. package/es/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -0
  638. package/es/extensions/forms/Form/Section/containers/Toolbar.d.ts +7 -0
  639. package/es/extensions/forms/Form/Section/containers/Toolbar.js +27 -0
  640. package/es/extensions/forms/Form/Section/containers/Toolbar.js.map +1 -0
  641. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +45 -0
  642. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -0
  643. package/es/extensions/forms/{Iterate/style/dnb-form-iterate.scss → Form/Section/style/dnb-form-section.scss} +4 -12
  644. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +8 -8
  645. package/es/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  646. package/es/extensions/forms/Iterate/Array/Array.js +1 -1
  647. package/es/extensions/forms/Iterate/Array/Array.js.map +1 -1
  648. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +1 -1
  649. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  650. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +19 -10
  651. package/es/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  652. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  653. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  654. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +1 -1
  655. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  656. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +1 -1
  657. package/es/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  658. package/es/extensions/forms/Iterate/style/dnb-iterate.css +6 -0
  659. package/es/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -0
  660. package/es/extensions/forms/Iterate/style/dnb-iterate.scss +12 -0
  661. package/es/extensions/forms/Wizard/Container/WizardContainer.js +1 -1
  662. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  663. package/es/extensions/forms/Wizard/Step/Step.js +1 -1
  664. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  665. package/es/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  666. package/es/extensions/forms/constants/locales/en-GB.js +3 -2
  667. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  668. package/es/extensions/forms/constants/locales/en-US.d.ts +2 -1
  669. package/es/extensions/forms/constants/locales/index.d.ts +4 -2
  670. package/es/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  671. package/es/extensions/forms/constants/locales/nb-NO.js +3 -2
  672. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  673. package/es/extensions/forms/hooks/useDataValue.d.ts +4 -0
  674. package/es/extensions/forms/hooks/useDataValue.js +30 -5
  675. package/es/extensions/forms/hooks/useDataValue.js.map +1 -1
  676. package/es/extensions/forms/hooks/useFieldProps.js +14 -9
  677. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  678. package/es/extensions/forms/hooks/useTranslation.js +7 -12
  679. package/es/extensions/forms/hooks/useTranslation.js.map +1 -1
  680. package/es/extensions/forms/style/dnb-forms.css +56 -44
  681. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  682. package/es/extensions/payment-card/PaymentCard.js +0 -2
  683. package/es/extensions/payment-card/PaymentCard.js.map +1 -1
  684. package/es/fragments/drawer-list/DrawerList.d.ts +0 -1
  685. package/es/fragments/drawer-list/DrawerList.js +6 -13
  686. package/es/fragments/drawer-list/DrawerList.js.map +1 -1
  687. package/es/fragments/drawer-list/DrawerListHelpers.d.ts +43 -46
  688. package/es/fragments/drawer-list/DrawerListHelpers.js +0 -2
  689. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  690. package/es/fragments/drawer-list/DrawerListPortal.js.map +1 -1
  691. package/es/fragments/drawer-list/DrawerListProvider.js.map +1 -1
  692. package/es/fragments/drawer-list/style/dnb-drawer-list.scss +4 -0
  693. package/es/fragments/text-counter/TextCounter.js +3 -2
  694. package/es/fragments/text-counter/TextCounter.js.map +1 -1
  695. package/es/shared/Context.d.ts +9 -5
  696. package/es/shared/Context.js +39 -35
  697. package/es/shared/Context.js.map +1 -1
  698. package/es/shared/Eufemia.d.ts +1 -1
  699. package/es/shared/Eufemia.js +2 -2
  700. package/es/shared/Eufemia.js.map +1 -1
  701. package/es/shared/Provider.d.ts +1 -1
  702. package/es/shared/Provider.js +49 -41
  703. package/es/shared/Provider.js.map +1 -1
  704. package/es/shared/Translation.d.ts +5 -5
  705. package/es/shared/Translation.js +8 -10
  706. package/es/shared/Translation.js.map +1 -1
  707. package/es/shared/index.d.ts +1 -0
  708. package/es/shared/index.js +1 -0
  709. package/es/shared/index.js.map +1 -1
  710. package/es/shared/locales/en-GB.d.ts +0 -3
  711. package/es/shared/locales/en-GB.js +0 -3
  712. package/es/shared/locales/en-GB.js.map +1 -1
  713. package/es/shared/locales/en-US.d.ts +0 -3
  714. package/es/shared/locales/index.d.ts +0 -6
  715. package/es/shared/locales/nb-NO.d.ts +0 -3
  716. package/es/shared/locales/nb-NO.js +0 -3
  717. package/es/shared/locales/nb-NO.js.map +1 -1
  718. package/es/shared/useTranslation.d.ts +5 -4
  719. package/es/shared/useTranslation.js +13 -11
  720. package/es/shared/useTranslation.js.map +1 -1
  721. package/es/style/core/scopes.scss +1 -1
  722. package/es/style/dnb-ui-basis.css +1 -1
  723. package/es/style/dnb-ui-basis.min.css +1 -1
  724. package/es/style/dnb-ui-body.css +1 -1
  725. package/es/style/dnb-ui-body.min.css +1 -1
  726. package/es/style/dnb-ui-components.css +67 -44
  727. package/es/style/dnb-ui-components.min.css +2 -2
  728. package/es/style/dnb-ui-core.css +1 -1
  729. package/es/style/dnb-ui-core.min.css +1 -1
  730. package/es/style/dnb-ui-extensions.css +56 -44
  731. package/es/style/dnb-ui-extensions.min.css +1 -1
  732. package/es/style/dnb-ui-forms.css +56 -44
  733. package/es/style/dnb-ui-forms.min.css +1 -1
  734. package/es/style/dnb-ui-forms.scss +2 -1
  735. package/es/style/dnb-ui-fragments.css +4 -0
  736. package/es/style/dnb-ui-fragments.min.css +1 -1
  737. package/es/style/themes/theme-eiendom/eiendom-theme-basis.css +2 -2
  738. package/es/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  739. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +123 -88
  740. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +3 -3
  741. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +56 -44
  742. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  743. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +56 -44
  744. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  745. package/es/style/themes/theme-sbanken/globals.scss +3 -2
  746. package/es/style/themes/theme-sbanken/sbanken-theme-basis.css +2 -2
  747. package/es/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  748. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +124 -89
  749. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +3 -3
  750. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +56 -44
  751. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  752. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +56 -44
  753. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  754. package/es/style/themes/theme-ui/globals.scss +3 -2
  755. package/es/style/themes/theme-ui/ui-theme-basis.css +2 -2
  756. package/es/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  757. package/es/style/themes/theme-ui/ui-theme-components.css +123 -88
  758. package/es/style/themes/theme-ui/ui-theme-components.min.css +3 -3
  759. package/es/style/themes/theme-ui/ui-theme-extensions.css +56 -44
  760. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  761. package/es/style/themes/theme-ui/ui-theme-forms.css +56 -44
  762. package/es/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  763. package/esm/dnb-ui-basis.min.mjs +1 -1
  764. package/esm/dnb-ui-components.min.mjs +1 -1
  765. package/esm/dnb-ui-elements.min.mjs +1 -1
  766. package/esm/dnb-ui-extensions.min.mjs +5 -5
  767. package/esm/dnb-ui-lib.min.mjs +1 -1
  768. package/extensions/forms/DataContext/Context.d.ts +2 -0
  769. package/extensions/forms/DataContext/Context.js +1 -0
  770. package/extensions/forms/DataContext/Context.js.map +1 -1
  771. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.d.ts +17 -1
  772. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryContext.js.map +1 -1
  773. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js +5 -3
  774. package/extensions/forms/DataContext/FieldBoundary/FieldBoundaryProvider.js.map +1 -1
  775. package/extensions/forms/DataContext/Provider/Provider.js +50 -4
  776. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  777. package/extensions/forms/Field/ArraySelection/ArraySelection.d.ts +2 -2
  778. package/extensions/forms/Field/ArraySelection/ArraySelection.js +8 -2
  779. package/extensions/forms/Field/ArraySelection/ArraySelection.js.map +1 -1
  780. package/extensions/forms/Field/Boolean/Boolean.d.ts +2 -2
  781. package/extensions/forms/Field/Boolean/Boolean.js.map +1 -1
  782. package/extensions/forms/Field/Number/style/dnb-number.css +10 -0
  783. package/extensions/forms/Field/Number/style/dnb-number.min.css +1 -1
  784. package/extensions/forms/Field/Number/style/dnb-number.scss +11 -0
  785. package/extensions/forms/Field/Option/Option.d.ts +2 -2
  786. package/extensions/forms/Field/Option/Option.js.map +1 -1
  787. package/extensions/forms/Field/Password/Password.js +2 -1
  788. package/extensions/forms/Field/Password/Password.js.map +1 -1
  789. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js +6 -6
  790. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  791. package/extensions/forms/Field/Selection/Selection.js +7 -2
  792. package/extensions/forms/Field/Selection/Selection.js.map +1 -1
  793. package/extensions/forms/Field/Toggle/Toggle.d.ts +2 -2
  794. package/extensions/forms/Field/Toggle/Toggle.js +14 -2
  795. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  796. package/extensions/forms/Form/Appearance/Appearance.d.ts +3 -0
  797. package/extensions/forms/Form/Appearance/Appearance.js +1 -0
  798. package/extensions/forms/Form/Appearance/Appearance.js.map +1 -1
  799. package/extensions/forms/Form/FieldProps/FieldProps.d.ts +5 -1
  800. package/extensions/forms/Form/FieldProps/FieldProps.js +19 -37
  801. package/extensions/forms/Form/FieldProps/FieldProps.js.map +1 -1
  802. package/extensions/forms/Form/Section/EditContainer/EditContainer.d.ts +12 -0
  803. package/extensions/forms/Form/Section/EditContainer/EditContainer.js +33 -0
  804. package/extensions/forms/Form/Section/EditContainer/EditContainer.js.map +1 -0
  805. package/extensions/forms/Form/Section/EditContainer/EditContainerDocs.d.ts +3 -0
  806. package/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js +19 -0
  807. package/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js.map +1 -0
  808. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.d.ts +1 -0
  809. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js +59 -0
  810. package/extensions/forms/Form/Section/EditContainer/EditToolbarTools.js.map +1 -0
  811. package/extensions/forms/Form/Section/EditContainer/index.d.ts +2 -0
  812. package/extensions/forms/Form/Section/EditContainer/index.js +3 -0
  813. package/extensions/forms/Form/Section/EditContainer/index.js.map +1 -0
  814. package/extensions/forms/Form/Section/EditContainer/useContainerDataStore.d.ts +3 -0
  815. package/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js +46 -0
  816. package/extensions/forms/Form/Section/EditContainer/useContainerDataStore.js.map +1 -0
  817. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.d.ts +1 -0
  818. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js +19 -0
  819. package/extensions/forms/Form/Section/EditContainer/useEditContainerToolbar.js.map +1 -0
  820. package/extensions/forms/Form/Section/Section.d.ts +9 -1
  821. package/extensions/forms/Form/Section/Section.js +10 -2
  822. package/extensions/forms/Form/Section/Section.js.map +1 -1
  823. package/extensions/forms/Form/Section/SectionContext.d.ts +1 -2
  824. package/extensions/forms/Form/Section/SectionContext.js.map +1 -1
  825. package/extensions/forms/Form/Section/SectionDocs.js +6 -1
  826. package/extensions/forms/Form/Section/SectionDocs.js.map +1 -1
  827. package/extensions/forms/Form/Section/ViewContainer/ViewContainer.d.ts +12 -0
  828. package/extensions/forms/Form/Section/ViewContainer/ViewContainer.js +32 -0
  829. package/extensions/forms/Form/Section/ViewContainer/ViewContainer.js.map +1 -0
  830. package/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.d.ts +3 -0
  831. package/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js +19 -0
  832. package/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js.map +1 -0
  833. package/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.d.ts +1 -0
  834. package/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.js +26 -0
  835. package/extensions/forms/Form/Section/ViewContainer/ViewToolbarTools.js.map +1 -0
  836. package/extensions/forms/Form/Section/ViewContainer/index.d.ts +2 -0
  837. package/extensions/forms/Form/Section/ViewContainer/index.js +3 -0
  838. package/extensions/forms/Form/Section/ViewContainer/index.js.map +1 -0
  839. package/extensions/forms/Form/Section/containers/SectionContainer.d.ts +19 -0
  840. package/extensions/forms/Form/Section/containers/SectionContainer.js +83 -0
  841. package/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -0
  842. package/extensions/forms/Form/Section/containers/SectionContainerContext.d.ts +8 -0
  843. package/extensions/forms/Form/Section/containers/SectionContainerContext.js +4 -0
  844. package/extensions/forms/Form/Section/containers/SectionContainerContext.js.map +1 -0
  845. package/extensions/forms/Form/Section/containers/SectionContainerProvider.d.ts +8 -0
  846. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js +24 -0
  847. package/extensions/forms/Form/Section/containers/SectionContainerProvider.js.map +1 -0
  848. package/extensions/forms/Form/Section/containers/Toolbar.d.ts +7 -0
  849. package/extensions/forms/Form/Section/containers/Toolbar.js +27 -0
  850. package/extensions/forms/Form/Section/containers/Toolbar.js.map +1 -0
  851. package/extensions/forms/Form/Section/style/dnb-form-section.css +45 -0
  852. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -0
  853. package/{cjs/extensions/forms/Iterate/style/dnb-form-iterate.scss → extensions/forms/Form/Section/style/dnb-form-section.scss} +4 -12
  854. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js +8 -8
  855. package/extensions/forms/Iterate/AnimatedContainer/ElementBlock.js.map +1 -1
  856. package/extensions/forms/Iterate/Array/Array.js +1 -1
  857. package/extensions/forms/Iterate/Array/Array.js.map +1 -1
  858. package/extensions/forms/Iterate/EditContainer/EditContainer.js +1 -1
  859. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  860. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js +19 -10
  861. package/extensions/forms/Iterate/EditContainer/EditToolbarTools.js.map +1 -1
  862. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +1 -1
  863. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  864. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +1 -1
  865. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  866. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js +1 -1
  867. package/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.js.map +1 -1
  868. package/extensions/forms/Iterate/style/dnb-iterate.css +6 -0
  869. package/extensions/forms/Iterate/style/dnb-iterate.min.css +1 -0
  870. package/extensions/forms/Iterate/style/dnb-iterate.scss +12 -0
  871. package/extensions/forms/Wizard/Container/WizardContainer.js +1 -1
  872. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  873. package/extensions/forms/Wizard/Step/Step.js +1 -1
  874. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  875. package/extensions/forms/constants/locales/en-GB.d.ts +2 -1
  876. package/extensions/forms/constants/locales/en-GB.js +3 -2
  877. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  878. package/extensions/forms/constants/locales/en-US.d.ts +2 -1
  879. package/extensions/forms/constants/locales/index.d.ts +4 -2
  880. package/extensions/forms/constants/locales/nb-NO.d.ts +2 -1
  881. package/extensions/forms/constants/locales/nb-NO.js +3 -2
  882. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  883. package/extensions/forms/hooks/useDataValue.d.ts +4 -0
  884. package/extensions/forms/hooks/useDataValue.js +30 -5
  885. package/extensions/forms/hooks/useDataValue.js.map +1 -1
  886. package/extensions/forms/hooks/useFieldProps.js +14 -9
  887. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  888. package/extensions/forms/hooks/useTranslation.js +7 -12
  889. package/extensions/forms/hooks/useTranslation.js.map +1 -1
  890. package/extensions/forms/style/dnb-forms.css +56 -44
  891. package/extensions/forms/style/dnb-forms.min.css +1 -1
  892. package/extensions/payment-card/PaymentCard.js +0 -2
  893. package/extensions/payment-card/PaymentCard.js.map +1 -1
  894. package/fragments/drawer-list/DrawerList.d.ts +0 -1
  895. package/fragments/drawer-list/DrawerList.js +6 -13
  896. package/fragments/drawer-list/DrawerList.js.map +1 -1
  897. package/fragments/drawer-list/DrawerListHelpers.d.ts +43 -46
  898. package/fragments/drawer-list/DrawerListHelpers.js +0 -2
  899. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  900. package/fragments/drawer-list/DrawerListPortal.js.map +1 -1
  901. package/fragments/drawer-list/DrawerListProvider.js.map +1 -1
  902. package/fragments/drawer-list/style/dnb-drawer-list.scss +4 -0
  903. package/fragments/text-counter/TextCounter.js +3 -2
  904. package/fragments/text-counter/TextCounter.js.map +1 -1
  905. package/package.json +1 -1
  906. package/shared/Context.d.ts +9 -5
  907. package/shared/Context.js +40 -35
  908. package/shared/Context.js.map +1 -1
  909. package/shared/Eufemia.d.ts +1 -1
  910. package/shared/Eufemia.js +2 -2
  911. package/shared/Eufemia.js.map +1 -1
  912. package/shared/Provider.d.ts +1 -1
  913. package/shared/Provider.js +49 -41
  914. package/shared/Provider.js.map +1 -1
  915. package/shared/Translation.d.ts +5 -5
  916. package/shared/Translation.js +8 -10
  917. package/shared/Translation.js.map +1 -1
  918. package/shared/index.d.ts +1 -0
  919. package/shared/index.js +1 -0
  920. package/shared/index.js.map +1 -1
  921. package/shared/locales/en-GB.d.ts +0 -3
  922. package/shared/locales/en-GB.js +0 -3
  923. package/shared/locales/en-GB.js.map +1 -1
  924. package/shared/locales/en-US.d.ts +0 -3
  925. package/shared/locales/index.d.ts +0 -6
  926. package/shared/locales/nb-NO.d.ts +0 -3
  927. package/shared/locales/nb-NO.js +0 -3
  928. package/shared/locales/nb-NO.js.map +1 -1
  929. package/shared/useTranslation.d.ts +5 -4
  930. package/shared/useTranslation.js +13 -11
  931. package/shared/useTranslation.js.map +1 -1
  932. package/style/core/scopes.scss +1 -1
  933. package/style/dnb-ui-basis.css +1 -1
  934. package/style/dnb-ui-basis.min.css +1 -1
  935. package/style/dnb-ui-body.css +1 -1
  936. package/style/dnb-ui-body.min.css +1 -1
  937. package/style/dnb-ui-components.css +67 -44
  938. package/style/dnb-ui-components.min.css +2 -2
  939. package/style/dnb-ui-core.css +1 -1
  940. package/style/dnb-ui-core.min.css +1 -1
  941. package/style/dnb-ui-extensions.css +56 -44
  942. package/style/dnb-ui-extensions.min.css +1 -1
  943. package/style/dnb-ui-forms.css +56 -44
  944. package/style/dnb-ui-forms.min.css +1 -1
  945. package/style/dnb-ui-forms.scss +2 -1
  946. package/style/dnb-ui-fragments.css +4 -0
  947. package/style/dnb-ui-fragments.min.css +1 -1
  948. package/style/themes/theme-eiendom/eiendom-theme-basis.css +2 -2
  949. package/style/themes/theme-eiendom/eiendom-theme-basis.min.css +1 -1
  950. package/style/themes/theme-eiendom/eiendom-theme-components.css +123 -88
  951. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +3 -3
  952. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +56 -44
  953. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +1 -1
  954. package/style/themes/theme-eiendom/eiendom-theme-forms.css +56 -44
  955. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +1 -1
  956. package/style/themes/theme-sbanken/globals.scss +3 -2
  957. package/style/themes/theme-sbanken/sbanken-theme-basis.css +2 -2
  958. package/style/themes/theme-sbanken/sbanken-theme-basis.min.css +1 -1
  959. package/style/themes/theme-sbanken/sbanken-theme-components.css +124 -89
  960. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +3 -3
  961. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +56 -44
  962. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +1 -1
  963. package/style/themes/theme-sbanken/sbanken-theme-forms.css +56 -44
  964. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +1 -1
  965. package/style/themes/theme-ui/globals.scss +3 -2
  966. package/style/themes/theme-ui/ui-theme-basis.css +2 -2
  967. package/style/themes/theme-ui/ui-theme-basis.min.css +1 -1
  968. package/style/themes/theme-ui/ui-theme-components.css +123 -88
  969. package/style/themes/theme-ui/ui-theme-components.min.css +3 -3
  970. package/style/themes/theme-ui/ui-theme-extensions.css +56 -44
  971. package/style/themes/theme-ui/ui-theme-extensions.min.css +1 -1
  972. package/style/themes/theme-ui/ui-theme-forms.css +56 -44
  973. package/style/themes/theme-ui/ui-theme-forms.min.css +1 -1
  974. package/umd/dnb-ui-basis.min.js +1 -1
  975. package/umd/dnb-ui-components.min.js +1 -1
  976. package/umd/dnb-ui-elements.min.js +1 -1
  977. package/umd/dnb-ui-extensions.min.js +5 -5
  978. package/umd/dnb-ui-lib.min.js +1 -1
  979. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.css +0 -50
  980. package/cjs/extensions/forms/Iterate/style/dnb-form-iterate.min.css +0 -1
  981. package/es/extensions/forms/Iterate/style/dnb-form-iterate.css +0 -50
  982. package/es/extensions/forms/Iterate/style/dnb-form-iterate.min.css +0 -1
  983. package/extensions/forms/Iterate/style/dnb-form-iterate.css +0 -50
  984. package/extensions/forms/Iterate/style/dnb-form-iterate.min.css +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ElementBlock.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Flex","HeightAnimation","IterateElementContext","ElementBlockContext","FieldBoundaryContext","ElementBlock","props","forceUpdate","contextRef","current","hasError","hasErrorAndShowIt","containerMode","handleRemove","switchContainerMode","isNew","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","_objectWithoutProperties","_excluded","openRef","isRemoving","setOpenState","setTimeout","handleAnimationEnd","state","preventFocusOnErrorOpening","_contextRef$current","_contextRef$current$e","_contextRef$current$e2","_contextRef$current$e3","elementRef","focus","call","window","requestAnimationFrame","_document$activeEleme","document","activeElement","closest","_contextRef$current2","elements","containerRef","querySelectorAll","length","e","_contextRef$current3","_contextRef$current3$","fulfillRemove","handleRemoveBlock","keepItems","createElement","Provider","value","duration","keepInDOM","Stack","_extends","element","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/ElementBlock.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport ElementBlockContext from './ElementBlockContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from '../Array/types'\n\nexport type ElementSectionProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ElementSectionProps\n\nfunction ElementBlock(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const contextRef = useRef<\n IterateElementContextState & {\n hasError?: boolean\n hasErrorAndShowIt?: boolean\n }\n >()\n contextRef.current = useContext(IterateElementContext) || {}\n\n const { hasError, hasErrorAndShowIt } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasErrorAndShowIt = hasErrorAndShowIt\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasErrorAndShowIt) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { handleRemove, switchContainerMode, containerMode, isNew } =\n contextRef.current\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n // - Keep the block open if we have an error\n if (contextRef.current.hasErrorAndShowIt) {\n switchContainerMode('edit')\n }\n\n const preventFocusOnErrorOpening =\n !contextRef.current.hasErrorAndShowIt\n if (preventFocusOnErrorOpening) {\n if (state === 'opened') {\n contextRef.current?.elementRef?.current?.focus?.()\n } else {\n // Wait until the element is removed, then check if we can set focus\n window.requestAnimationFrame(() => {\n // try to focus on the second last element\n try {\n if (\n // But not when we focus is already inside our element\n !document.activeElement?.closest(\n '.dnb-forms-iterate__element'\n )\n ) {\n const elements =\n contextRef.current?.containerRef.current.querySelectorAll<HTMLDivElement>(\n '.dnb-forms-iterate__element'\n )\n elements[elements.length - 1].focus()\n }\n } catch (e) {\n /**/\n }\n })\n }\n }\n\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n contextRef.current?.fulfillRemove?.()\n }\n\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, switchContainerMode]\n )\n const handleRemoveBlock = useCallback(() => {\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, setOpenState])\n\n return (\n <ElementBlockContext.Provider value={{ handleRemoveBlock }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-iterate-block',\n variant && `dnb-forms-iterate-block--variant-${variant}`,\n isNew && 'dnb-forms-iterate-block--new',\n contextRef.current.hasErrorAndShowIt &&\n 'dnb-forms-iterate-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-iterate-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ElementBlockContext.Provider>\n )\n}\n\nElementBlock._supportsSpacingProps = true\nexport default ElementBlock\n"],"mappings":"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"}
1
+ {"version":3,"file":"ElementBlock.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Flex","HeightAnimation","IterateElementContext","ElementBlockContext","FieldBoundaryContext","ElementBlock","props","forceUpdate","contextRef","current","hasError","hasSubmitError","containerMode","handleRemove","switchContainerMode","isNew","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","_objectWithoutProperties","_excluded","openRef","isRemoving","setOpenState","setTimeout","handleAnimationEnd","state","preventFocusOnErrorOpening","_contextRef$current","_contextRef$current$e","_contextRef$current$e2","_contextRef$current$e3","elementRef","focus","call","window","requestAnimationFrame","_document$activeEleme","document","activeElement","closest","_contextRef$current2","elements","containerRef","querySelectorAll","length","e","_contextRef$current3","_contextRef$current3$","fulfillRemove","handleRemoveBlock","keepItems","createElement","Provider","value","duration","keepInDOM","Stack","_extends","element","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/AnimatedContainer/ElementBlock.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Flex, HeightAnimation } from '../../../../components'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport ElementBlockContext from './ElementBlockContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from '../Array/types'\n\nexport type ElementSectionProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ElementSectionProps\n\nfunction ElementBlock(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const contextRef = useRef<\n IterateElementContextState & {\n hasError?: boolean\n hasSubmitError?: boolean\n }\n >()\n contextRef.current = useContext(IterateElementContext) || {}\n\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n contextRef.current.hasError = hasError\n contextRef.current.hasSubmitError = hasSubmitError\n\n // - Set the container mode to \"edit\" if we have an error\n if (hasSubmitError) {\n contextRef.current.containerMode = 'edit'\n }\n\n const { handleRemove, switchContainerMode, containerMode, isNew } =\n contextRef.current\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n // - Keep the block open if we have an error\n if (contextRef.current.hasSubmitError) {\n switchContainerMode?.('edit')\n }\n\n const preventFocusOnErrorOpening = !contextRef.current.hasSubmitError\n if (preventFocusOnErrorOpening) {\n if (state === 'opened') {\n contextRef.current?.elementRef?.current?.focus?.()\n } else {\n // Wait until the element is removed, then check if we can set focus\n window.requestAnimationFrame(() => {\n // try to focus on the second last element\n try {\n if (\n // But not when we focus is already inside our element\n !document.activeElement?.closest(\n '.dnb-forms-iterate__element'\n )\n ) {\n const elements =\n contextRef.current?.containerRef.current.querySelectorAll<HTMLDivElement>(\n '.dnb-forms-iterate__element'\n )\n elements[elements.length - 1].focus()\n }\n } catch (e) {\n /**/\n }\n })\n }\n }\n\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n contextRef.current?.fulfillRemove?.()\n }\n\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, switchContainerMode]\n )\n const handleRemoveBlock = useCallback(() => {\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, setOpenState])\n\n return (\n <ElementBlockContext.Provider value={{ handleRemoveBlock }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n contextRef.current.hasSubmitError &&\n 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Flex.Stack\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n element=\"section\"\n aria-label={ariaLabel}\n >\n {children}\n </Flex.Stack>\n </HeightAnimation>\n </ElementBlockContext.Provider>\n )\n}\n\nElementBlock._supportsSpacingProps = true\nexport default ElementBlock\n"],"mappings":"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"}
@@ -155,7 +155,7 @@ function ArrayComponent(props) {
155
155
  }
156
156
  }, [arrayValue, elementData, onChange]);
157
157
  const flexProps = _objectSpread(_objectSpread(_objectSpread({
158
- className: classnames('dnb-forms-iterate', props === null || props === void 0 ? void 0 : props.className)
158
+ className: classnames("dnb-forms-iterate dnb-forms-section", props === null || props === void 0 ? void 0 : props.className)
159
159
  }, pickFlexContainerProps(props)), pickSpacingProps(props)), {}, {
160
160
  innerRef: containerRef
161
161
  });
@@ -1 +1 @@
1
- {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","Fragment","classnames","pointer","useFieldProps","makeUniqueId","Flex","pickSpacingProps","pickFlexContainerProps","IterateElementContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","structuredClone","useDataValue","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","getValue","preparedProps","path","countPath","countPathLimit","Infinity","countPathTransform","arrayValue","countValue","parseFloat","length","newValue","i","l","value","push","index","_objectSpread","withoutFlex","emptyValue","placeholder","handleChange","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","current","elementData","_ref","map","_valueCountRef$curren","id","hasNewItems","isNew","containerMode","switchContainerMode","mode","_isNewRef$current","newArrayValue","set","handlePush","element","handleRemove","keepItems","arguments","undefined","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","last","flexProps","className","innerRef","WrapperElement","Stack","createElement","elementProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n Fragment,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\nimport useDataValue from '../../hooks/useDataValue'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n\n const { getValue } = useDataValue()\n const preparedProps = useMemo(() => {\n const {\n path,\n countPath,\n countPathLimit = Infinity,\n countPathTransform,\n } = props\n\n if (countPath) {\n const arrayValue = getValue(path)\n let countValue = parseFloat(getValue(countPath))\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n if (arrayValue?.length !== countValue) {\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(countPathTransform?.({ value, index: i }))\n }\n\n return {\n ...props,\n value: newValue,\n }\n }\n }\n\n return props\n }, [getValue, props])\n\n const {\n path,\n value: arrayValue,\n withoutFlex,\n emptyValue,\n placeholder,\n handleChange,\n onChange,\n children,\n } = useFieldProps<Value, Props>(preparedProps)\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<Record<Identifier, ContainerMode>>({})\n const valueWhileClosingRef = useRef<Array<unknown>>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const elementData = useMemo(() => {\n return ((valueWhileClosingRef.current || arrayValue) ?? []).map(\n (value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]) {\n modesRef.current[id] = isNew ? 'edit' : 'view'\n }\n\n return {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id],\n switchContainerMode: (mode: ContainerMode) => {\n modesRef.current[id] = mode\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path: Path, value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element: unknown) => {\n hadPushRef.current = true\n handleChange([...(arrayValue ?? []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n },\n } as IterateElementContextState\n }\n )\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, path, handleChange])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = elementData?.[elementData.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, elementData, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames('dnb-forms-iterate', props?.className),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const WrapperElement = omitFlex ? Fragment : Flex.Stack\n\n return (\n <WrapperElement {...(omitFlex ? null : flexProps)}>\n {arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : elementData.map((elementProps) => {\n const { id, value, index } = elementProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...elementProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateElementContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateElementContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n </Flex.Item>\n )\n })}\n </WrapperElement>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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"}
1
+ {"version":3,"file":"Array.js","names":["React","useMemo","useRef","useEffect","useReducer","createRef","useContext","Fragment","classnames","pointer","useFieldProps","makeUniqueId","Flex","pickSpacingProps","pickFlexContainerProps","IterateElementContext","SummaryListContext","ValueBlockContext","FieldBoundaryProvider","structuredClone","useDataValue","ArrayComponent","props","_props$value","salt","forceUpdate","summaryListContext","valueBlockContext","getValue","preparedProps","path","countPath","countPathLimit","Infinity","countPathTransform","arrayValue","countValue","parseFloat","length","newValue","i","l","value","push","index","_objectSpread","withoutFlex","emptyValue","placeholder","handleChange","onChange","children","idsRef","isNewRef","modesRef","valueWhileClosingRef","valueCountRef","containerRef","hadPushRef","innerRefs","omitFlex","current","elementData","_ref","map","_valueCountRef$curren","id","hasNewItems","isNew","containerMode","switchContainerMode","mode","_isNewRef$current","newArrayValue","set","handlePush","element","handleRemove","keepItems","arguments","undefined","splice","fulfillRemove","_modesRef$current","_isNewRef$current2","findIndex","indexOf","restoreOriginalValue","last","flexProps","className","innerRef","WrapperElement","Stack","createElement","elementProps","elementRef","renderChildren","elementChild","contextValue","content","Array","isArray","child","Provider","key","Item","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/Array.tsx"],"sourcesContent":["import React, {\n useMemo,\n useRef,\n useEffect,\n useReducer,\n createRef,\n useContext,\n Fragment,\n} from 'react'\nimport classnames from 'classnames'\nimport pointer from 'json-pointer'\nimport { useFieldProps } from '../../hooks'\nimport { makeUniqueId } from '../../../../shared/component-helper'\nimport { Flex } from '../../../../components'\nimport { pickSpacingProps } from '../../../../components/flex/utils'\nimport {\n BasicProps as FlexContainerProps,\n Props as FlexContainerAllProps,\n pickFlexContainerProps,\n} from '../../../../components/flex/Container'\nimport IterateElementContext, {\n IterateElementContextState,\n} from '../IterateElementContext'\nimport SummaryListContext from '../../Value/SummaryList/SummaryListContext'\nimport ValueBlockContext from '../../ValueBlock/ValueBlockContext'\nimport FieldBoundaryProvider from '../../DataContext/FieldBoundary/FieldBoundaryProvider'\n\nimport type { ContainerMode, ElementChild, Props, Value } from './types'\nimport type { Identifier, Path } from '../../types'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\nimport useDataValue from '../../hooks/useDataValue'\n\nexport type * from './types'\n\nfunction ArrayComponent(props: Props) {\n const [salt, forceUpdate] = useReducer(() => ({}), {})\n\n const summaryListContext = useContext(SummaryListContext)\n const valueBlockContext = useContext(ValueBlockContext)\n\n const { getValue } = useDataValue()\n const preparedProps = useMemo(() => {\n const {\n path,\n countPath,\n countPathLimit = Infinity,\n countPathTransform,\n } = props\n\n if (countPath) {\n const arrayValue = getValue(path)\n let countValue = parseFloat(getValue(countPath))\n if (!(countValue >= 0)) {\n countValue = 0\n }\n if (countValue > countPathLimit) {\n countValue = countPathLimit\n }\n if (arrayValue?.length !== countValue) {\n const newValue = []\n for (let i = 0, l = countValue; i < l; i++) {\n const value = arrayValue?.[i]\n newValue.push(countPathTransform?.({ value, index: i }))\n }\n\n return {\n ...props,\n value: newValue,\n }\n }\n }\n\n return props\n }, [getValue, props])\n\n const {\n path,\n value: arrayValue,\n withoutFlex,\n emptyValue,\n placeholder,\n handleChange,\n onChange,\n children,\n } = useFieldProps<Value, Props>(preparedProps)\n\n const idsRef = useRef<Array<Identifier>>([])\n const isNewRef = useRef<Record<string, boolean>>({})\n const modesRef = useRef<Record<Identifier, ContainerMode>>({})\n const valueWhileClosingRef = useRef<Array<unknown>>()\n const valueCountRef = useRef(arrayValue)\n const containerRef = useRef<HTMLDivElement>()\n const hadPushRef = useRef<boolean>()\n const innerRefs = useRef<\n Record<string, React.RefObject<HTMLDivElement>>\n >({})\n\n const omitFlex = withoutFlex ?? (summaryListContext || valueBlockContext)\n\n useEffect(() => {\n // Update inside the useEffect, to support React.StrictMode\n valueCountRef.current = arrayValue || []\n }, [arrayValue])\n\n const elementData = useMemo(() => {\n return ((valueWhileClosingRef.current || arrayValue) ?? []).map(\n (value, index) => {\n const id = idsRef.current[index] || makeUniqueId()\n\n const hasNewItems =\n arrayValue.length > valueCountRef.current?.length\n\n if (!idsRef.current[index]) {\n isNewRef.current[id] = hasNewItems\n idsRef.current.push(id)\n }\n\n const isNew = isNewRef.current[id] || false\n if (!modesRef.current[id]) {\n modesRef.current[id] = isNew ? 'edit' : 'view'\n }\n\n return {\n id,\n path,\n value,\n index,\n arrayValue,\n containerRef,\n isNew,\n containerMode: modesRef.current[id],\n switchContainerMode: (mode: ContainerMode) => {\n modesRef.current[id] = mode\n delete isNewRef.current?.[id]\n forceUpdate()\n },\n handleChange: (path: Path, value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n\n // Make sure we have a new object reference,\n // else two new objects will be the same\n newArrayValue[index] = { ...newArrayValue[index] }\n\n pointer.set(newArrayValue, path, value)\n handleChange(newArrayValue)\n },\n handlePush: (element: unknown) => {\n hadPushRef.current = true\n handleChange([...(arrayValue ?? []), element])\n },\n handleRemove: ({ keepItems = false } = {}) => {\n if (keepItems) {\n // Add a backup as the array value while animating\n valueWhileClosingRef.current = arrayValue\n }\n\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue.splice(index, 1)\n handleChange(newArrayValue)\n },\n\n // - Called after animation end\n fulfillRemove: () => {\n valueWhileClosingRef.current = null\n delete modesRef.current?.[id]\n delete isNewRef.current?.[id]\n const findIndex = idsRef.current.indexOf(id)\n idsRef.current.splice(findIndex, 1)\n forceUpdate()\n },\n\n // - Called when cancel button press\n restoreOriginalValue: (value: unknown) => {\n const newArrayValue = structuredClone(arrayValue)\n newArrayValue[index] = value\n handleChange(newArrayValue)\n },\n } as IterateElementContextState\n }\n )\n\n // In order to update \"valueWhileClosingRef\" we need to have \"salt\" in the deps array\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [salt, arrayValue, path, handleChange])\n\n // - Call the onChange callback when a new element is added without calling \"handlePush\"\n useMemo(() => {\n const last = elementData?.[elementData.length - 1]\n if (last?.isNew && !hadPushRef.current) {\n onChange?.(arrayValue)\n } else {\n hadPushRef.current = false\n }\n }, [arrayValue, elementData, onChange])\n\n const flexProps: FlexContainerProps & {\n innerRef: FlexContainerAllProps['innerRef']\n } = {\n className: classnames(\n 'dnb-forms-iterate',\n 'dnb-forms-section',\n props?.className\n ),\n ...pickFlexContainerProps(props as FlexContainerProps),\n ...pickSpacingProps(props),\n innerRef: containerRef,\n }\n\n const WrapperElement = omitFlex ? Fragment : Flex.Stack\n\n return (\n <WrapperElement {...(omitFlex ? null : flexProps)}>\n {arrayValue === emptyValue || props?.value?.length === 0\n ? placeholder\n : elementData.map((elementProps) => {\n const { id, value, index } = elementProps\n const elementRef = (innerRefs.current[id] =\n innerRefs.current[id] || createRef<HTMLDivElement>())\n\n const renderChildren = (elementChild: ElementChild) => {\n return typeof elementChild === 'function'\n ? elementChild(value, index)\n : elementChild\n }\n\n const contextValue = {\n ...elementProps,\n elementRef,\n }\n\n const content = Array.isArray(children)\n ? children.map((child) => renderChildren(child))\n : renderChildren(children)\n\n if (omitFlex) {\n return (\n <IterateElementContext.Provider\n key={`element-${id}`}\n value={contextValue}\n >\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n )\n }\n\n return (\n <Flex.Item\n className=\"dnb-forms-iterate__element\"\n tabIndex={-1}\n innerRef={elementRef}\n key={`element-${id}`}\n >\n <IterateElementContext.Provider value={contextValue}>\n <FieldBoundaryProvider>{content}</FieldBoundaryProvider>\n </IterateElementContext.Provider>\n </Flex.Item>\n )\n })}\n </WrapperElement>\n )\n}\n\nArrayComponent._supportsSpacingProps = true\nexport default ArrayComponent\n"],"mappings":"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"}
@@ -42,7 +42,7 @@ export function EditContainerWithoutToolbar(props) {
42
42
  const ariaLabel = useMemo(() => convertJsxToString(blockTitle), [blockTitle]);
43
43
  return React.createElement(ElementBlock, _extends({
44
44
  mode: "edit",
45
- className: classnames('dnb-forms-iterate-edit-block', className),
45
+ className: classnames('dnb-forms-section-edit-block', className),
46
46
  ariaLabel: ariaLabel
47
47
  }, restProps), blockTitle && React.createElement(Lead, {
48
48
  size: "basis"
@@ -1 +1 @@
1
- {"version":3,"file":"EditContainer.js","names":["React","useContext","useEffect","useMemo","useRef","classnames","convertJsxToString","Lead","IterateElementContext","EditToolbarTools","ElementBlock","Toolbar","EditContainer","props","createElement","EditContainerWithoutToolbar","_extends","toolbar","_Toolbar","iterateElementContext","containerMode","isNew","_ref","children","className","title","titleWhenNew","restProps","_objectWithoutProperties","_excluded","wasNewRef","current","blockTitle","ariaLabel","mode","size","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useEffect, useMemo, useRef } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Lead } from '../../../../elements'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport IterateElementContext from '../IterateElementContext'\nimport EditToolbarTools from './EditToolbarTools'\nimport ElementBlock, {\n ElementSectionProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\n\nexport type Props = {\n /**\n * The title of the EditContainer.\n */\n title?: React.ReactNode\n\n /**\n * The title for a new item show within the EditContainer.\n */\n titleWhenNew?: React.ReactNode\n\n /**\n * If the EditContainer is open or not.\n * Used internally.\n */\n open?: boolean\n\n /**\n * The toolbar to be shown in the EditContainer.\n * Used internally.\n */\n toolbar?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementSectionProps\n\nexport default function EditContainer(props: AllProps) {\n return (\n <EditContainerWithoutToolbar\n toolbar={\n <Toolbar>\n <EditToolbarTools />\n </Toolbar>\n }\n {...props}\n />\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const iterateElementContext = useContext(IterateElementContext)\n const { containerMode, isNew } = iterateElementContext ?? {}\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n ...restProps\n } = props || {}\n\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n const blockTitle =\n wasNewRef.current && titleWhenNew ? titleWhenNew : title\n const ariaLabel = useMemo(\n () => convertJsxToString(blockTitle),\n [blockTitle]\n )\n\n return (\n <ElementBlock\n mode=\"edit\"\n className={classnames('dnb-forms-iterate-edit-block', className)}\n ariaLabel={ariaLabel}\n {...restProps}\n >\n {blockTitle && <Lead size=\"basis\">{blockTitle}</Lead>}\n {children}\n {toolbar}\n </ElementBlock>\n )\n}\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,SAAS,EAAEC,OAAO,EAAEC,MAAM,QAAQ,OAAO;AACrE,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,sBAAsB;AAE3C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,OAAOC,gBAAgB,MAAM,oBAAoB;AACjD,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AA4BhC,eAAe,SAASC,aAAaA,CAACC,KAAe,EAAE;EACrD,OACEb,KAAA,CAAAc,aAAA,CAACC,2BAA2B,EAAAC,QAAA;IAC1BC,OAAO,EAAAC,QAAA,KAAAA,QAAA,GACLlB,KAAA,CAAAc,aAAA,CAACH,OAAO,QACNX,KAAA,CAAAc,aAAA,CAACL,gBAAgB,MAAE,CACZ,CAAC;EACX,GACGI,KAAK,CACV,CAAC;AAEN;AAEA,OAAO,SAASE,2BAA2BA,CACzCF,KAAiE,EACjE;EACA,MAAMM,qBAAqB,GAAGlB,UAAU,CAACO,qBAAqB,CAAC;EAC/D,MAAM;IAAEY,aAAa;IAAEC;EAAM,CAAC,GAAGF,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAE5D,MAAAG,IAAA,GAOIT,KAAK,IAAI,CAAC,CAAC;IAPT;MACJU,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,YAAY;MACZT;IAEF,CAAC,GAAAK,IAAA;IADIK,SAAS,GAAAC,wBAAA,CAAAN,IAAA,EAAAO,SAAA;EAGd,MAAMC,SAAS,GAAG1B,MAAM,CAAUiB,KAAK,CAAC;EAExCnB,SAAS,CAAC,MAAM;IACd,IAAIkB,aAAa,KAAK,MAAM,EAAE;MAC5BU,SAAS,CAACC,OAAO,GAAG,KAAK;IAC3B;EACF,CAAC,EAAE,CAACV,KAAK,EAAED,aAAa,CAAC,CAAC;EAE1B,MAAMY,UAAU,GACdF,SAAS,CAACC,OAAO,IAAIL,YAAY,GAAGA,YAAY,GAAGD,KAAK;EAC1D,MAAMQ,SAAS,GAAG9B,OAAO,CACvB,MAAMG,kBAAkB,CAAC0B,UAAU,CAAC,EACpC,CAACA,UAAU,CACb,CAAC;EAED,OACEhC,KAAA,CAAAc,aAAA,CAACJ,YAAY,EAAAM,QAAA;IACXkB,IAAI,EAAC,MAAM;IACXV,SAAS,EAAEnB,UAAU,CAAC,8BAA8B,EAAEmB,SAAS,CAAE;IACjES,SAAS,EAAEA;EAAU,GACjBN,SAAS,GAEZK,UAAU,IAAIhC,KAAA,CAAAc,aAAA,CAACP,IAAI;IAAC4B,IAAI,EAAC;EAAO,GAAEH,UAAiB,CAAC,EACpDT,QAAQ,EACRN,OACW,CAAC;AAEnB;AAEAL,aAAa,CAACwB,qBAAqB,GAAG,IAAI;AAC1CrB,2BAA2B,CAACqB,qBAAqB,GAAG,IAAI"}
1
+ {"version":3,"file":"EditContainer.js","names":["React","useContext","useEffect","useMemo","useRef","classnames","convertJsxToString","Lead","IterateElementContext","EditToolbarTools","ElementBlock","Toolbar","EditContainer","props","createElement","EditContainerWithoutToolbar","_extends","toolbar","_Toolbar","iterateElementContext","containerMode","isNew","_ref","children","className","title","titleWhenNew","restProps","_objectWithoutProperties","_excluded","wasNewRef","current","blockTitle","ariaLabel","mode","size","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditContainer.tsx"],"sourcesContent":["import React, { useContext, useEffect, useMemo, useRef } from 'react'\nimport classnames from 'classnames'\nimport { convertJsxToString } from '../../../../shared/component-helper'\nimport { Lead } from '../../../../elements'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport IterateElementContext from '../IterateElementContext'\nimport EditToolbarTools from './EditToolbarTools'\nimport ElementBlock, {\n ElementSectionProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\n\nexport type Props = {\n /**\n * The title of the EditContainer.\n */\n title?: React.ReactNode\n\n /**\n * The title for a new item show within the EditContainer.\n */\n titleWhenNew?: React.ReactNode\n\n /**\n * If the EditContainer is open or not.\n * Used internally.\n */\n open?: boolean\n\n /**\n * The toolbar to be shown in the EditContainer.\n * Used internally.\n */\n toolbar?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementSectionProps\n\nexport default function EditContainer(props: AllProps) {\n return (\n <EditContainerWithoutToolbar\n toolbar={\n <Toolbar>\n <EditToolbarTools />\n </Toolbar>\n }\n {...props}\n />\n )\n}\n\nexport function EditContainerWithoutToolbar(\n props: Props & FlexContainerProps & { toolbar?: React.ReactNode }\n) {\n const iterateElementContext = useContext(IterateElementContext)\n const { containerMode, isNew } = iterateElementContext ?? {}\n\n const {\n children,\n className,\n title,\n titleWhenNew,\n toolbar,\n ...restProps\n } = props || {}\n\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n const blockTitle =\n wasNewRef.current && titleWhenNew ? titleWhenNew : title\n const ariaLabel = useMemo(\n () => convertJsxToString(blockTitle),\n [blockTitle]\n )\n\n return (\n <ElementBlock\n mode=\"edit\"\n className={classnames('dnb-forms-section-edit-block', className)}\n ariaLabel={ariaLabel}\n {...restProps}\n >\n {blockTitle && <Lead size=\"basis\">{blockTitle}</Lead>}\n {children}\n {toolbar}\n </ElementBlock>\n )\n}\n\nEditContainer._supportsSpacingProps = true\nEditContainerWithoutToolbar._supportsSpacingProps = true\n"],"mappings":";;;;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,EAAEC,SAAS,EAAEC,OAAO,EAAEC,MAAM,QAAQ,OAAO;AACrE,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,sBAAsB;AAE3C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,OAAOC,gBAAgB,MAAM,oBAAoB;AACjD,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AA4BhC,eAAe,SAASC,aAAaA,CAACC,KAAe,EAAE;EACrD,OACEb,KAAA,CAAAc,aAAA,CAACC,2BAA2B,EAAAC,QAAA;IAC1BC,OAAO,EAAAC,QAAA,KAAAA,QAAA,GACLlB,KAAA,CAAAc,aAAA,CAACH,OAAO,QACNX,KAAA,CAAAc,aAAA,CAACL,gBAAgB,MAAE,CACZ,CAAC;EACX,GACGI,KAAK,CACV,CAAC;AAEN;AAEA,OAAO,SAASE,2BAA2BA,CACzCF,KAAiE,EACjE;EACA,MAAMM,qBAAqB,GAAGlB,UAAU,CAACO,qBAAqB,CAAC;EAC/D,MAAM;IAAEY,aAAa;IAAEC;EAAM,CAAC,GAAGF,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAE5D,MAAAG,IAAA,GAOIT,KAAK,IAAI,CAAC,CAAC;IAPT;MACJU,QAAQ;MACRC,SAAS;MACTC,KAAK;MACLC,YAAY;MACZT;IAEF,CAAC,GAAAK,IAAA;IADIK,SAAS,GAAAC,wBAAA,CAAAN,IAAA,EAAAO,SAAA;EAGd,MAAMC,SAAS,GAAG1B,MAAM,CAAUiB,KAAK,CAAC;EAExCnB,SAAS,CAAC,MAAM;IACd,IAAIkB,aAAa,KAAK,MAAM,EAAE;MAC5BU,SAAS,CAACC,OAAO,GAAG,KAAK;IAC3B;EACF,CAAC,EAAE,CAACV,KAAK,EAAED,aAAa,CAAC,CAAC;EAE1B,MAAMY,UAAU,GACdF,SAAS,CAACC,OAAO,IAAIL,YAAY,GAAGA,YAAY,GAAGD,KAAK;EAC1D,MAAMQ,SAAS,GAAG9B,OAAO,CACvB,MAAMG,kBAAkB,CAAC0B,UAAU,CAAC,EACpC,CAACA,UAAU,CACb,CAAC;EAED,OACEhC,KAAA,CAAAc,aAAA,CAACJ,YAAY,EAAAM,QAAA;IACXkB,IAAI,EAAC,MAAM;IACXV,SAAS,EAAEnB,UAAU,CAAC,8BAA8B,EAAEmB,SAAS,CAAE;IACjES,SAAS,EAAEA;EAAU,GACjBN,SAAS,GAEZK,UAAU,IAAIhC,KAAA,CAAAc,aAAA,CAACP,IAAI;IAAC4B,IAAI,EAAC;EAAO,GAAEH,UAAiB,CAAC,EACpDT,QAAQ,EACRN,OACW,CAAC;AAEnB;AAEAL,aAAa,CAACwB,qBAAqB,GAAG,IAAI;AAC1CrB,2BAA2B,CAACqB,qBAAqB,GAAG,IAAI"}
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
 
3
3
  var _RemoveButton;
4
- import React, { useCallback, useContext, useEffect, useRef } from 'react';
5
- import { Button, Flex } from '../../../../components';
4
+ import React, { useCallback, useContext, useEffect, useRef, useState } from 'react';
5
+ import { Button, Flex, FormStatus } from '../../../../components';
6
6
  import useTranslation from '../../hooks/useTranslation';
7
7
  import IterateElementContext from '../IterateElementContext';
8
8
  import { check, close } from '../../../../icons';
@@ -18,14 +18,15 @@ export default function EditToolbarTools() {
18
18
  isNew
19
19
  } = useContext(IterateElementContext) || {};
20
20
  const {
21
- hasErrorAndShowIt
21
+ hasVisibleError
22
22
  } = useContext(FieldBoundaryContext) || {};
23
- const translation = useTranslation().Iterate;
23
+ const translation = useTranslation().Section;
24
24
  const valueBackupRef = useRef();
25
25
  const wasNew = useWasNew({
26
26
  isNew,
27
27
  containerMode
28
28
  });
29
+ const [showError, setShowError] = useState(false);
29
30
  useEffect(() => {
30
31
  if (containerMode === 'edit' && !valueBackupRef.current) {
31
32
  valueBackupRef.current = arrayValue === null || arrayValue === void 0 ? void 0 : arrayValue[index];
@@ -38,25 +39,33 @@ export default function EditToolbarTools() {
38
39
  if (valueBackupRef.current) {
39
40
  restoreOriginalValue === null || restoreOriginalValue === void 0 ? void 0 : restoreOriginalValue(valueBackupRef.current);
40
41
  }
42
+ setShowError(false);
41
43
  switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
42
44
  }, [restoreOriginalValue, switchContainerMode]);
43
45
  const doneHandler = useCallback(() => {
44
- switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
45
- }, [switchContainerMode]);
46
- return React.createElement(Flex.Horizontal, {
46
+ if (hasVisibleError) {
47
+ setShowError(true);
48
+ } else {
49
+ setShowError(false);
50
+ switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('view');
51
+ }
52
+ }, [hasVisibleError, switchContainerMode]);
53
+ return React.createElement(React.Fragment, null, React.createElement(FormStatus, {
54
+ show: showError && hasVisibleError,
55
+ no_animation: false
56
+ }, translation.errorInSection), React.createElement(Flex.Horizontal, {
47
57
  gap: "large"
48
58
  }, React.createElement(Button, {
49
59
  variant: "tertiary",
50
60
  icon: check,
51
61
  icon_position: "left",
52
- on_click: doneHandler,
53
- disabled: hasErrorAndShowIt
62
+ on_click: doneHandler
54
63
  }, translation.done), wasNew ? _RemoveButton || (_RemoveButton = React.createElement(RemoveButton, null)) : React.createElement(Button, {
55
64
  variant: "tertiary",
56
65
  icon: close,
57
66
  icon_position: "left",
58
67
  on_click: cancelHandler
59
- }, translation.cancel));
68
+ }, translation.cancel)));
60
69
  }
61
70
  export function useWasNew(_ref) {
62
71
  let {
@@ -1 +1 @@
1
- {"version":3,"file":"EditToolbarTools.js","names":["React","useCallback","useContext","useEffect","useRef","Button","Flex","useTranslation","IterateElementContext","check","close","RemoveButton","FieldBoundaryContext","EditToolbarTools","restoreOriginalValue","switchContainerMode","containerMode","arrayValue","index","isNew","hasErrorAndShowIt","translation","Iterate","valueBackupRef","wasNew","useWasNew","current","cancelHandler","doneHandler","createElement","Horizontal","gap","variant","icon","icon_position","on_click","disabled","done","_RemoveButton","cancel","_ref","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext, useEffect, useRef } from 'react'\nimport { Button, Flex } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateElementContext from '../IterateElementContext'\nimport { check, close } from '../../../../icons'\nimport RemoveButton from '../RemoveButton'\nimport { ContainerMode } from '../Array/types'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport default function EditToolbarTools() {\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n arrayValue,\n index,\n isNew,\n } = useContext(IterateElementContext) || {}\n const { hasErrorAndShowIt } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().Iterate\n const valueBackupRef = useRef<unknown>()\n const wasNew = useWasNew({ isNew, containerMode })\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(() => {\n if (valueBackupRef.current) {\n restoreOriginalValue?.(valueBackupRef.current)\n }\n switchContainerMode?.('view')\n }, [restoreOriginalValue, switchContainerMode])\n const doneHandler = useCallback(() => {\n switchContainerMode?.('view')\n }, [switchContainerMode])\n\n return (\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n disabled={hasErrorAndShowIt}\n >\n {translation.done}\n </Button>\n\n {wasNew ? (\n <RemoveButton />\n ) : (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancel}\n </Button>\n )}\n </Flex.Horizontal>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"EditToolbarTools.js","names":["React","useCallback","useContext","useEffect","useRef","useState","Button","Flex","FormStatus","useTranslation","IterateElementContext","check","close","RemoveButton","FieldBoundaryContext","EditToolbarTools","restoreOriginalValue","switchContainerMode","containerMode","arrayValue","index","isNew","hasVisibleError","translation","Section","valueBackupRef","wasNew","useWasNew","showError","setShowError","current","cancelHandler","doneHandler","createElement","Fragment","show","no_animation","errorInSection","Horizontal","gap","variant","icon","icon_position","on_click","done","_RemoveButton","cancel","_ref","wasNewRef"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/EditToolbarTools.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useRef,\n useState,\n} from 'react'\nimport { Button, Flex, FormStatus } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateElementContext from '../IterateElementContext'\nimport { check, close } from '../../../../icons'\nimport RemoveButton from '../RemoveButton'\nimport { ContainerMode } from '../Array/types'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport default function EditToolbarTools() {\n const {\n restoreOriginalValue,\n switchContainerMode,\n containerMode,\n arrayValue,\n index,\n isNew,\n } = useContext(IterateElementContext) || {}\n const { hasVisibleError } = useContext(FieldBoundaryContext) || {}\n\n const translation = useTranslation().Section\n const valueBackupRef = useRef<unknown>()\n const wasNew = useWasNew({ isNew, containerMode })\n const [showError, setShowError] = useState(false)\n\n useEffect(() => {\n if (containerMode === 'edit' && !valueBackupRef.current) {\n valueBackupRef.current = arrayValue?.[index]\n }\n if (containerMode === 'view') {\n valueBackupRef.current = null\n }\n }, [arrayValue, containerMode, index])\n\n const cancelHandler = useCallback(() => {\n if (valueBackupRef.current) {\n restoreOriginalValue?.(valueBackupRef.current)\n }\n setShowError(false)\n switchContainerMode?.('view')\n }, [restoreOriginalValue, switchContainerMode])\n const doneHandler = useCallback(() => {\n if (hasVisibleError) {\n setShowError(true)\n } else {\n setShowError(false)\n switchContainerMode?.('view')\n }\n }, [hasVisibleError, switchContainerMode])\n\n return (\n <>\n <FormStatus show={showError && hasVisibleError} no_animation={false}>\n {translation.errorInSection}\n </FormStatus>\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={check}\n icon_position=\"left\"\n on_click={doneHandler}\n >\n {translation.done}\n </Button>\n\n {wasNew ? (\n <RemoveButton />\n ) : (\n <Button\n variant=\"tertiary\"\n icon={close}\n icon_position=\"left\"\n on_click={cancelHandler}\n >\n {translation.cancel}\n </Button>\n )}\n </Flex.Horizontal>\n </>\n )\n}\n\nexport function useWasNew({\n isNew,\n containerMode,\n}: {\n isNew: boolean\n containerMode: ContainerMode\n}) {\n const wasNewRef = useRef<unknown>(isNew)\n\n useEffect(() => {\n if (containerMode === 'view') {\n wasNewRef.current = false\n }\n }, [isNew, containerMode])\n\n return wasNewRef.current\n}\n"],"mappings":";;;AAAA,OAAOA,KAAK,IACVC,WAAW,EACXC,UAAU,EACVC,SAAS,EACTC,MAAM,EACNC,QAAQ,QACH,OAAO;AACd,SAASC,MAAM,EAAEC,IAAI,EAAEC,UAAU,QAAQ,wBAAwB;AACjE,OAAOC,cAAc,MAAM,4BAA4B;AACvD,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,KAAK,EAAEC,KAAK,QAAQ,mBAAmB;AAChD,OAAOC,YAAY,MAAM,iBAAiB;AAE1C,OAAOC,oBAAoB,MAAM,sDAAsD;AAEvF,eAAe,SAASC,gBAAgBA,CAAA,EAAG;EACzC,MAAM;IACJC,oBAAoB;IACpBC,mBAAmB;IACnBC,aAAa;IACbC,UAAU;IACVC,KAAK;IACLC;EACF,CAAC,GAAGnB,UAAU,CAACQ,qBAAqB,CAAC,IAAI,CAAC,CAAC;EAC3C,MAAM;IAAEY;EAAgB,CAAC,GAAGpB,UAAU,CAACY,oBAAoB,CAAC,IAAI,CAAC,CAAC;EAElE,MAAMS,WAAW,GAAGd,cAAc,CAAC,CAAC,CAACe,OAAO;EAC5C,MAAMC,cAAc,GAAGrB,MAAM,CAAU,CAAC;EACxC,MAAMsB,MAAM,GAAGC,SAAS,CAAC;IAAEN,KAAK;IAAEH;EAAc,CAAC,CAAC;EAClD,MAAM,CAACU,SAAS,EAAEC,YAAY,CAAC,GAAGxB,QAAQ,CAAC,KAAK,CAAC;EAEjDF,SAAS,CAAC,MAAM;IACd,IAAIe,aAAa,KAAK,MAAM,IAAI,CAACO,cAAc,CAACK,OAAO,EAAE;MACvDL,cAAc,CAACK,OAAO,GAAGX,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAGC,KAAK,CAAC;IAC9C;IACA,IAAIF,aAAa,KAAK,MAAM,EAAE;MAC5BO,cAAc,CAACK,OAAO,GAAG,IAAI;IAC/B;EACF,CAAC,EAAE,CAACX,UAAU,EAAED,aAAa,EAAEE,KAAK,CAAC,CAAC;EAEtC,MAAMW,aAAa,GAAG9B,WAAW,CAAC,MAAM;IACtC,IAAIwB,cAAc,CAACK,OAAO,EAAE;MAC1Bd,oBAAoB,aAApBA,oBAAoB,uBAApBA,oBAAoB,CAAGS,cAAc,CAACK,OAAO,CAAC;IAChD;IACAD,YAAY,CAAC,KAAK,CAAC;IACnBZ,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;EAC/B,CAAC,EAAE,CAACD,oBAAoB,EAAEC,mBAAmB,CAAC,CAAC;EAC/C,MAAMe,WAAW,GAAG/B,WAAW,CAAC,MAAM;IACpC,IAAIqB,eAAe,EAAE;MACnBO,YAAY,CAAC,IAAI,CAAC;IACpB,CAAC,MAAM;MACLA,YAAY,CAAC,KAAK,CAAC;MACnBZ,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;IAC/B;EACF,CAAC,EAAE,CAACK,eAAe,EAAEL,mBAAmB,CAAC,CAAC;EAE1C,OACEjB,KAAA,CAAAiC,aAAA,CAAAjC,KAAA,CAAAkC,QAAA,QACElC,KAAA,CAAAiC,aAAA,CAACzB,UAAU;IAAC2B,IAAI,EAAEP,SAAS,IAAIN,eAAgB;IAACc,YAAY,EAAE;EAAM,GACjEb,WAAW,CAACc,cACH,CAAC,EACbrC,KAAA,CAAAiC,aAAA,CAAC1B,IAAI,CAAC+B,UAAU;IAACC,GAAG,EAAC;EAAO,GAC1BvC,KAAA,CAAAiC,aAAA,CAAC3B,MAAM;IACLkC,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAE9B,KAAM;IACZ+B,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEX;EAAY,GAErBT,WAAW,CAACqB,IACP,CAAC,EAERlB,MAAM,GAAAmB,aAAA,KAAAA,aAAA,GACL7C,KAAA,CAAAiC,aAAA,CAACpB,YAAY,MAAE,CAAC,IAEhBb,KAAA,CAAAiC,aAAA,CAAC3B,MAAM;IACLkC,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAE7B,KAAM;IACZ8B,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEZ;EAAc,GAEvBR,WAAW,CAACuB,MACP,CAEK,CACjB,CAAC;AAEP;AAEA,OAAO,SAASnB,SAASA,CAAAoB,IAAA,EAMtB;EAAA,IANuB;IACxB1B,KAAK;IACLH;EAIF,CAAC,GAAA6B,IAAA;EACC,MAAMC,SAAS,GAAG5C,MAAM,CAAUiB,KAAK,CAAC;EAExClB,SAAS,CAAC,MAAM;IACd,IAAIe,aAAa,KAAK,MAAM,EAAE;MAC5B8B,SAAS,CAAClB,OAAO,GAAG,KAAK;IAC3B;EACF,CAAC,EAAE,CAACT,KAAK,EAAEH,aAAa,CAAC,CAAC;EAE1B,OAAO8B,SAAS,CAAClB,OAAO;AAC1B"}
@@ -28,7 +28,7 @@ function RemoveButton(props) {
28
28
  text
29
29
  } = useFieldProps(restProps);
30
30
  const buttonProps = omitDataValueReadWriteProps(restProps);
31
- const translation = useTranslation().Iterate;
31
+ const translation = useTranslation().Section;
32
32
  const textContent = text || children || translation.remove;
33
33
  const elementBlockContext = useContext(ElementBlockContext);
34
34
  const {
@@ -1 +1 @@
1
- {"version":3,"file":"RemoveButton.js","names":["React","useCallback","useContext","classnames","Button","IterateElementContext","useFieldProps","useTranslation","ElementBlockContext","omitDataValueReadWriteProps","trash","RemoveButton","props","iterateElementContext","handleRemove","Error","className","restProps","_objectWithoutProperties","_excluded","children","text","buttonProps","translation","Iterate","textContent","remove","elementBlockContext","handleRemoveBlock","handleClick","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/RemoveButton/RemoveButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateElementContext from '../IterateElementContext'\nimport { useFieldProps, useTranslation } from '../../hooks'\nimport ElementBlockContext from '../AnimatedContainer/ElementBlockContext'\nimport {\n DataValueReadWriteComponentProps,\n omitDataValueReadWriteProps,\n} from '../../types'\nimport { trash } from '../../../../icons'\n\nexport type Props = ButtonProps &\n DataValueReadWriteComponentProps<unknown[]>\n\nfunction RemoveButton(props: Props) {\n const iterateElementContext = useContext(IterateElementContext)\n const { handleRemove } = iterateElementContext ?? {}\n\n if (!iterateElementContext) {\n throw new Error('RemoveButton must be inside an Iterate.Array')\n }\n\n const { className, ...restProps } = props\n const { children, text } = useFieldProps(restProps)\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const translation = useTranslation().Iterate\n const textContent = text || children || translation.remove\n\n const elementBlockContext = useContext(ElementBlockContext)\n const { handleRemoveBlock } = elementBlockContext ?? {}\n\n const handleClick = useCallback(() => {\n if (handleRemoveBlock) {\n handleRemoveBlock()\n } else {\n handleRemove()\n }\n }, [handleRemove, handleRemoveBlock])\n\n return (\n <Button\n className={classnames(\n 'dnb-forms-iterate-remove-element-button',\n className\n )}\n variant={textContent ? 'tertiary' : 'secondary'}\n icon={trash}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {textContent}\n </Button>\n )\n}\n\nRemoveButton._supportsSpacingProps = true\nexport default RemoveButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,QAAQ,wBAAwB;AAE/C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,aAAa,EAAEC,cAAc,QAAQ,aAAa;AAC3D,OAAOC,mBAAmB,MAAM,0CAA0C;AAC1E,SAEEC,2BAA2B,QACtB,aAAa;AACpB,SAASC,KAAK,QAAQ,mBAAmB;AAKzC,SAASC,YAAYA,CAACC,KAAY,EAAE;EAClC,MAAMC,qBAAqB,GAAGX,UAAU,CAACG,qBAAqB,CAAC;EAC/D,MAAM;IAAES;EAAa,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAEpD,IAAI,CAACA,qBAAqB,EAAE;IAC1B,MAAM,IAAIE,KAAK,CAAC,8CAA8C,CAAC;EACjE;EAEA,MAAM;MAAEC;IAAwB,CAAC,GAAGJ,KAAK;IAAnBK,SAAS,GAAAC,wBAAA,CAAKN,KAAK,EAAAO,SAAA;EACzC,MAAM;IAAEC,QAAQ;IAAEC;EAAK,CAAC,GAAGf,aAAa,CAACW,SAAS,CAAC;EACnD,MAAMK,WAAW,GAAGb,2BAA2B,CAACQ,SAAS,CAAC;EAC1D,MAAMM,WAAW,GAAGhB,cAAc,CAAC,CAAC,CAACiB,OAAO;EAC5C,MAAMC,WAAW,GAAGJ,IAAI,IAAID,QAAQ,IAAIG,WAAW,CAACG,MAAM;EAE1D,MAAMC,mBAAmB,GAAGzB,UAAU,CAACM,mBAAmB,CAAC;EAC3D,MAAM;IAAEoB;EAAkB,CAAC,GAAGD,mBAAmB,aAAnBA,mBAAmB,cAAnBA,mBAAmB,GAAI,CAAC,CAAC;EAEvD,MAAME,WAAW,GAAG5B,WAAW,CAAC,MAAM;IACpC,IAAI2B,iBAAiB,EAAE;MACrBA,iBAAiB,CAAC,CAAC;IACrB,CAAC,MAAM;MACLd,YAAY,CAAC,CAAC;IAChB;EACF,CAAC,EAAE,CAACA,YAAY,EAAEc,iBAAiB,CAAC,CAAC;EAErC,OACE5B,KAAA,CAAA8B,aAAA,CAAC1B,MAAM,EAAA2B,QAAA;IACLf,SAAS,EAAEb,UAAU,CACnB,yCAAyC,EACzCa,SACF,CAAE;IACFgB,OAAO,EAAEP,WAAW,GAAG,UAAU,GAAG,WAAY;IAChDQ,IAAI,EAAEvB,KAAM;IACZwB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEN;EAAY,GAClBP,WAAW,GAEdG,WACK,CAAC;AAEb;AAEAd,YAAY,CAACyB,qBAAqB,GAAG,IAAI;AACzC,eAAezB,YAAY"}
1
+ {"version":3,"file":"RemoveButton.js","names":["React","useCallback","useContext","classnames","Button","IterateElementContext","useFieldProps","useTranslation","ElementBlockContext","omitDataValueReadWriteProps","trash","RemoveButton","props","iterateElementContext","handleRemove","Error","className","restProps","_objectWithoutProperties","_excluded","children","text","buttonProps","translation","Section","textContent","remove","elementBlockContext","handleRemoveBlock","handleClick","createElement","_extends","variant","icon","icon_position","on_click","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/RemoveButton/RemoveButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button } from '../../../../components'\nimport { ButtonProps } from '../../../../components/Button'\nimport IterateElementContext from '../IterateElementContext'\nimport { useFieldProps, useTranslation } from '../../hooks'\nimport ElementBlockContext from '../AnimatedContainer/ElementBlockContext'\nimport {\n DataValueReadWriteComponentProps,\n omitDataValueReadWriteProps,\n} from '../../types'\nimport { trash } from '../../../../icons'\n\nexport type Props = ButtonProps &\n DataValueReadWriteComponentProps<unknown[]>\n\nfunction RemoveButton(props: Props) {\n const iterateElementContext = useContext(IterateElementContext)\n const { handleRemove } = iterateElementContext ?? {}\n\n if (!iterateElementContext) {\n throw new Error('RemoveButton must be inside an Iterate.Array')\n }\n\n const { className, ...restProps } = props\n const { children, text } = useFieldProps(restProps)\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const translation = useTranslation().Section\n const textContent = text || children || translation.remove\n\n const elementBlockContext = useContext(ElementBlockContext)\n const { handleRemoveBlock } = elementBlockContext ?? {}\n\n const handleClick = useCallback(() => {\n if (handleRemoveBlock) {\n handleRemoveBlock()\n } else {\n handleRemove()\n }\n }, [handleRemove, handleRemoveBlock])\n\n return (\n <Button\n className={classnames(\n 'dnb-forms-iterate-remove-element-button',\n className\n )}\n variant={textContent ? 'tertiary' : 'secondary'}\n icon={trash}\n icon_position=\"left\"\n on_click={handleClick}\n {...buttonProps}\n >\n {textContent}\n </Button>\n )\n}\n\nRemoveButton._supportsSpacingProps = true\nexport default RemoveButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,MAAM,QAAQ,wBAAwB;AAE/C,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,aAAa,EAAEC,cAAc,QAAQ,aAAa;AAC3D,OAAOC,mBAAmB,MAAM,0CAA0C;AAC1E,SAEEC,2BAA2B,QACtB,aAAa;AACpB,SAASC,KAAK,QAAQ,mBAAmB;AAKzC,SAASC,YAAYA,CAACC,KAAY,EAAE;EAClC,MAAMC,qBAAqB,GAAGX,UAAU,CAACG,qBAAqB,CAAC;EAC/D,MAAM;IAAES;EAAa,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAEpD,IAAI,CAACA,qBAAqB,EAAE;IAC1B,MAAM,IAAIE,KAAK,CAAC,8CAA8C,CAAC;EACjE;EAEA,MAAM;MAAEC;IAAwB,CAAC,GAAGJ,KAAK;IAAnBK,SAAS,GAAAC,wBAAA,CAAKN,KAAK,EAAAO,SAAA;EACzC,MAAM;IAAEC,QAAQ;IAAEC;EAAK,CAAC,GAAGf,aAAa,CAACW,SAAS,CAAC;EACnD,MAAMK,WAAW,GAAGb,2BAA2B,CAACQ,SAAS,CAAC;EAC1D,MAAMM,WAAW,GAAGhB,cAAc,CAAC,CAAC,CAACiB,OAAO;EAC5C,MAAMC,WAAW,GAAGJ,IAAI,IAAID,QAAQ,IAAIG,WAAW,CAACG,MAAM;EAE1D,MAAMC,mBAAmB,GAAGzB,UAAU,CAACM,mBAAmB,CAAC;EAC3D,MAAM;IAAEoB;EAAkB,CAAC,GAAGD,mBAAmB,aAAnBA,mBAAmB,cAAnBA,mBAAmB,GAAI,CAAC,CAAC;EAEvD,MAAME,WAAW,GAAG5B,WAAW,CAAC,MAAM;IACpC,IAAI2B,iBAAiB,EAAE;MACrBA,iBAAiB,CAAC,CAAC;IACrB,CAAC,MAAM;MACLd,YAAY,CAAC,CAAC;IAChB;EACF,CAAC,EAAE,CAACA,YAAY,EAAEc,iBAAiB,CAAC,CAAC;EAErC,OACE5B,KAAA,CAAA8B,aAAA,CAAC1B,MAAM,EAAA2B,QAAA;IACLf,SAAS,EAAEb,UAAU,CACnB,yCAAyC,EACzCa,SACF,CAAE;IACFgB,OAAO,EAAEP,WAAW,GAAG,UAAU,GAAG,WAAY;IAChDQ,IAAI,EAAEvB,KAAM;IACZwB,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEN;EAAY,GAClBP,WAAW,GAEdG,WACK,CAAC;AAEb;AAEAd,YAAY,CAACyB,qBAAqB,GAAG,IAAI;AACzC,eAAezB,YAAY"}
@@ -22,7 +22,7 @@ function ViewContainer(props) {
22
22
  return React.createElement(ElementBlock, _extends({
23
23
  mode: "view",
24
24
  ariaLabel: ariaLabel,
25
- className: classnames('dnb-forms-iterate-view-block', className)
25
+ className: classnames('dnb-forms-section-view-block', className)
26
26
  }, restProps), React.createElement(Flex.Stack, null, title && React.createElement(Lead, {
27
27
  size: "basis"
28
28
  }, title), children, _Toolbar || (_Toolbar = React.createElement(Toolbar, null, React.createElement(ViewToolbarTools, null)))));
@@ -1 +1 @@
1
- {"version":3,"file":"ViewContainer.js","names":["React","useMemo","classnames","convertJsxToString","Flex","Lead","ElementBlock","Toolbar","ViewToolbarTools","ViewContainer","props","_ref","children","className","title","restProps","_objectWithoutProperties","_excluded","ariaLabel","createElement","_extends","mode","Stack","size","_Toolbar","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { 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 ElementBlock, {\n ElementSectionProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\nimport ViewToolbarTools from './ViewToolbarTools'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementSectionProps\n\nfunction ViewContainer(props: AllProps) {\n const { children, className, title, ...restProps } = props || {}\n const ariaLabel = useMemo(() => convertJsxToString(title), [title])\n\n return (\n <ElementBlock\n mode=\"view\"\n ariaLabel={ariaLabel}\n className={classnames('dnb-forms-iterate-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {title && <Lead size=\"basis\">{title}</Lead>}\n {children}\n <Toolbar>\n <ViewToolbarTools />\n </Toolbar>\n </Flex.Stack>\n </ElementBlock>\n )\n}\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,OAAO,QAAQ,OAAO;AACtC,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,gBAAgB,MAAM,oBAAoB;AAWjD,SAASC,aAAaA,CAACC,KAAe,EAAE;EACtC,MAAAC,IAAA,GAAqDD,KAAK,IAAI,CAAC,CAAC;IAA1D;MAAEE,QAAQ;MAAEC,SAAS;MAAEC;IAAoB,CAAC,GAAAH,IAAA;IAAXI,SAAS,GAAAC,wBAAA,CAAAL,IAAA,EAAAM,SAAA;EAChD,MAAMC,SAAS,GAAGjB,OAAO,CAAC,MAAME,kBAAkB,CAACW,KAAK,CAAC,EAAE,CAACA,KAAK,CAAC,CAAC;EAEnE,OACEd,KAAA,CAAAmB,aAAA,CAACb,YAAY,EAAAc,QAAA;IACXC,IAAI,EAAC,MAAM;IACXH,SAAS,EAAEA,SAAU;IACrBL,SAAS,EAAEX,UAAU,CAAC,8BAA8B,EAAEW,SAAS;EAAE,GAC7DE,SAAS,GAEbf,KAAA,CAAAmB,aAAA,CAACf,IAAI,CAACkB,KAAK,QACRR,KAAK,IAAId,KAAA,CAAAmB,aAAA,CAACd,IAAI;IAACkB,IAAI,EAAC;EAAO,GAAET,KAAY,CAAC,EAC1CF,QAAQ,EAAAY,QAAA,KAAAA,QAAA,GACTxB,KAAA,CAAAmB,aAAA,CAACZ,OAAO,QACNP,KAAA,CAAAmB,aAAA,CAACX,gBAAgB,MAAE,CACZ,CAAC,CACA,CACA,CAAC;AAEnB;AAEAC,aAAa,CAACgB,qBAAqB,GAAG,IAAI;AAC1C,eAAehB,aAAa"}
1
+ {"version":3,"file":"ViewContainer.js","names":["React","useMemo","classnames","convertJsxToString","Flex","Lead","ElementBlock","Toolbar","ViewToolbarTools","ViewContainer","props","_ref","children","className","title","restProps","_objectWithoutProperties","_excluded","ariaLabel","createElement","_extends","mode","Stack","size","_Toolbar","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewContainer.tsx"],"sourcesContent":["import React, { 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 ElementBlock, {\n ElementSectionProps,\n} from '../AnimatedContainer/ElementBlock'\nimport Toolbar from '../Toolbar'\nimport ViewToolbarTools from './ViewToolbarTools'\n\nexport type Props = {\n /**\n * The title of the ViewContainer.\n */\n title?: React.ReactNode\n}\n\nexport type AllProps = Props & FlexContainerProps & ElementSectionProps\n\nfunction ViewContainer(props: AllProps) {\n const { children, className, title, ...restProps } = props || {}\n const ariaLabel = useMemo(() => convertJsxToString(title), [title])\n\n return (\n <ElementBlock\n mode=\"view\"\n ariaLabel={ariaLabel}\n className={classnames('dnb-forms-section-view-block', className)}\n {...restProps}\n >\n <Flex.Stack>\n {title && <Lead size=\"basis\">{title}</Lead>}\n {children}\n <Toolbar>\n <ViewToolbarTools />\n </Toolbar>\n </Flex.Stack>\n </ElementBlock>\n )\n}\n\nViewContainer._supportsSpacingProps = true\nexport default ViewContainer\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,OAAO,QAAQ,OAAO;AACtC,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,kBAAkB,QAAQ,qCAAqC;AACxE,SAASC,IAAI,QAAQ,wBAAwB;AAE7C,SAASC,IAAI,QAAQ,sBAAsB;AAC3C,OAAOC,YAAY,MAEZ,mCAAmC;AAC1C,OAAOC,OAAO,MAAM,YAAY;AAChC,OAAOC,gBAAgB,MAAM,oBAAoB;AAWjD,SAASC,aAAaA,CAACC,KAAe,EAAE;EACtC,MAAAC,IAAA,GAAqDD,KAAK,IAAI,CAAC,CAAC;IAA1D;MAAEE,QAAQ;MAAEC,SAAS;MAAEC;IAAoB,CAAC,GAAAH,IAAA;IAAXI,SAAS,GAAAC,wBAAA,CAAAL,IAAA,EAAAM,SAAA;EAChD,MAAMC,SAAS,GAAGjB,OAAO,CAAC,MAAME,kBAAkB,CAACW,KAAK,CAAC,EAAE,CAACA,KAAK,CAAC,CAAC;EAEnE,OACEd,KAAA,CAAAmB,aAAA,CAACb,YAAY,EAAAc,QAAA;IACXC,IAAI,EAAC,MAAM;IACXH,SAAS,EAAEA,SAAU;IACrBL,SAAS,EAAEX,UAAU,CAAC,8BAA8B,EAAEW,SAAS;EAAE,GAC7DE,SAAS,GAEbf,KAAA,CAAAmB,aAAA,CAACf,IAAI,CAACkB,KAAK,QACRR,KAAK,IAAId,KAAA,CAAAmB,aAAA,CAACd,IAAI;IAACkB,IAAI,EAAC;EAAO,GAAET,KAAY,CAAC,EAC1CF,QAAQ,EAAAY,QAAA,KAAAA,QAAA,GACTxB,KAAA,CAAAmB,aAAA,CAACZ,OAAO,QACNP,KAAA,CAAAmB,aAAA,CAACX,gBAAgB,MAAE,CACZ,CAAC,CACA,CACA,CAAC;AAEnB;AAEAC,aAAa,CAACgB,qBAAqB,GAAG,IAAI;AAC1C,eAAehB,aAAa"}
@@ -11,7 +11,7 @@ export default function ViewToolbarTools() {
11
11
  const {
12
12
  switchContainerMode
13
13
  } = iterateElementContext !== null && iterateElementContext !== void 0 ? iterateElementContext : {};
14
- const translation = useTranslation().Iterate;
14
+ const translation = useTranslation().Section;
15
15
  const editHandler = useCallback(() => {
16
16
  switchContainerMode === null || switchContainerMode === void 0 ? void 0 : switchContainerMode('edit');
17
17
  }, [switchContainerMode]);
@@ -1 +1 @@
1
- {"version":3,"file":"ViewToolbarTools.js","names":["React","useCallback","useContext","Button","Flex","RemoveButton","useTranslation","IterateElementContext","edit","ViewToolbarTools","iterateElementContext","switchContainerMode","translation","Iterate","editHandler","createElement","Horizontal","gap","variant","icon","icon_position","on_click","text","remove"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport { Button, Flex } from '../../../../components'\nimport RemoveButton from '../RemoveButton'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateElementContext from '../IterateElementContext'\nimport { edit } from '../../../../icons'\n\nexport default function ViewToolbarTools() {\n const iterateElementContext = useContext(IterateElementContext)\n const { switchContainerMode } = iterateElementContext ?? {}\n\n const translation = useTranslation().Iterate\n\n const editHandler = useCallback(() => {\n switchContainerMode?.('edit')\n }, [switchContainerMode])\n\n return (\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={edit}\n icon_position=\"left\"\n on_click={editHandler}\n >\n {translation.edit}\n </Button>\n\n <RemoveButton text={translation.remove} />\n </Flex.Horizontal>\n )\n}\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,SAASC,MAAM,EAAEC,IAAI,QAAQ,wBAAwB;AACrD,OAAOC,YAAY,MAAM,iBAAiB;AAC1C,OAAOC,cAAc,MAAM,4BAA4B;AACvD,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,IAAI,QAAQ,mBAAmB;AAExC,eAAe,SAASC,gBAAgBA,CAAA,EAAG;EACzC,MAAMC,qBAAqB,GAAGR,UAAU,CAACK,qBAAqB,CAAC;EAC/D,MAAM;IAAEI;EAAoB,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAE3D,MAAME,WAAW,GAAGN,cAAc,CAAC,CAAC,CAACO,OAAO;EAE5C,MAAMC,WAAW,GAAGb,WAAW,CAAC,MAAM;IACpCU,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;EAC/B,CAAC,EAAE,CAACA,mBAAmB,CAAC,CAAC;EAEzB,OACEX,KAAA,CAAAe,aAAA,CAACX,IAAI,CAACY,UAAU;IAACC,GAAG,EAAC;EAAO,GAC1BjB,KAAA,CAAAe,aAAA,CAACZ,MAAM;IACLe,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAEX,IAAK;IACXY,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEP;EAAY,GAErBF,WAAW,CAACJ,IACP,CAAC,EAETR,KAAA,CAAAe,aAAA,CAACV,YAAY;IAACiB,IAAI,EAAEV,WAAW,CAACW;EAAO,CAAE,CAC1B,CAAC;AAEtB"}
1
+ {"version":3,"file":"ViewToolbarTools.js","names":["React","useCallback","useContext","Button","Flex","RemoveButton","useTranslation","IterateElementContext","edit","ViewToolbarTools","iterateElementContext","switchContainerMode","translation","Section","editHandler","createElement","Horizontal","gap","variant","icon","icon_position","on_click","text","remove"],"sources":["../../../../../../src/extensions/forms/Iterate/ViewContainer/ViewToolbarTools.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport { Button, Flex } from '../../../../components'\nimport RemoveButton from '../RemoveButton'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateElementContext from '../IterateElementContext'\nimport { edit } from '../../../../icons'\n\nexport default function ViewToolbarTools() {\n const iterateElementContext = useContext(IterateElementContext)\n const { switchContainerMode } = iterateElementContext ?? {}\n\n const translation = useTranslation().Section\n\n const editHandler = useCallback(() => {\n switchContainerMode?.('edit')\n }, [switchContainerMode])\n\n return (\n <Flex.Horizontal gap=\"large\">\n <Button\n variant=\"tertiary\"\n icon={edit}\n icon_position=\"left\"\n on_click={editHandler}\n >\n {translation.edit}\n </Button>\n\n <RemoveButton text={translation.remove} />\n </Flex.Horizontal>\n )\n}\n"],"mappings":";;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,SAASC,MAAM,EAAEC,IAAI,QAAQ,wBAAwB;AACrD,OAAOC,YAAY,MAAM,iBAAiB;AAC1C,OAAOC,cAAc,MAAM,4BAA4B;AACvD,OAAOC,qBAAqB,MAAM,0BAA0B;AAC5D,SAASC,IAAI,QAAQ,mBAAmB;AAExC,eAAe,SAASC,gBAAgBA,CAAA,EAAG;EACzC,MAAMC,qBAAqB,GAAGR,UAAU,CAACK,qBAAqB,CAAC;EAC/D,MAAM;IAAEI;EAAoB,CAAC,GAAGD,qBAAqB,aAArBA,qBAAqB,cAArBA,qBAAqB,GAAI,CAAC,CAAC;EAE3D,MAAME,WAAW,GAAGN,cAAc,CAAC,CAAC,CAACO,OAAO;EAE5C,MAAMC,WAAW,GAAGb,WAAW,CAAC,MAAM;IACpCU,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAG,MAAM,CAAC;EAC/B,CAAC,EAAE,CAACA,mBAAmB,CAAC,CAAC;EAEzB,OACEX,KAAA,CAAAe,aAAA,CAACX,IAAI,CAACY,UAAU;IAACC,GAAG,EAAC;EAAO,GAC1BjB,KAAA,CAAAe,aAAA,CAACZ,MAAM;IACLe,OAAO,EAAC,UAAU;IAClBC,IAAI,EAAEX,IAAK;IACXY,aAAa,EAAC,MAAM;IACpBC,QAAQ,EAAEP;EAAY,GAErBF,WAAW,CAACJ,IACP,CAAC,EAETR,KAAA,CAAAe,aAAA,CAACV,YAAY;IAACiB,IAAI,EAAEV,WAAW,CAACW;EAAO,CAAE,CAC1B,CAAC;AAEtB"}
@@ -0,0 +1,6 @@
1
+ .dnb-forms-iterate__element {
2
+ outline: none;
3
+ }
4
+ .dnb-forms-iterate > .dnb-forms-iterate__element:has(.dnb-forms-iterate-block) {
5
+ margin-top: 0;
6
+ }
@@ -0,0 +1 @@
1
+ .dnb-forms-iterate__element{outline:none}.dnb-forms-iterate>.dnb-forms-iterate__element:has(.dnb-forms-iterate-block){margin-top:0}
@@ -0,0 +1,12 @@
1
+ // More styles are in "dnb-form-section.scss"
2
+
3
+ .dnb-forms-iterate {
4
+ &__element {
5
+ outline: none; // for JavaSCript focus
6
+ }
7
+
8
+ & > &__element:has(> &-block) {
9
+ // To make Animation not jump, we add "margin-bottom" in the inner element
10
+ margin-top: 0;
11
+ }
12
+ }
@@ -165,7 +165,7 @@ function WizardContainer(props) {
165
165
  useLayoutEffect(() => {
166
166
  var _updateTitlesRef$curr;
167
167
  (_updateTitlesRef$curr = updateTitlesRef.current) === null || _updateTitlesRef$curr === void 0 ? void 0 : _updateTitlesRef$curr.call(updateTitlesRef);
168
- }, [children]);
168
+ }, [titlesRef.current]);
169
169
  if (!hasContext) {
170
170
  warn('You may wrap Wizard.Container in Form.Handler');
171
171
  return React.createElement(Handler, null, React.createElement(WizardContainer, _extends({}, props, {
@@ -1 +1 @@
1
- {"version":3,"file":"WizardContainer.js","names":["React","useContext","useCallback","useRef","useReducer","useMemo","ReactDOM","classnames","Space","StepIndicator","convertJsxToString","warn","isAsync","useId","Step","WizardContext","DataContext","defaultContextState","Handler","useSharedState","useHandleLayoutEffect","useLayoutEffect","window","useEffect","WizardContainer","props","className","id","idProp","mode","initialActiveIndex","omitScrollManagement","omitFocusManagement","onStepChange","children","noAnimation","prerenderFieldProps","variant","sidebarId","rest","_objectWithoutProperties","_excluded","hasContext","setFormState","handleSubmitCall","setShowAllErrors","showAllErrors","setSubmitState","forceUpdate","activeIndexRef","errorOnStepRef","stepElementRef","sharedStateRef","current","undefined","callOnStepChange","index","setFocus","scrollToTop","isInteractionRef","handleLayoutEffect","handleStepChange","_ref","skipErrorCheck","skipStepChangeCall","skipStepChangeCallBeforeMounted","skipStepChangeCallFromHook","skipFieldValidation","enableAsyncBehaviour","onSubmit","_sharedStateRef$curre","_sharedStateRef$curre2","_sharedStateRef$curre3","data","call","result","Error","setActiveIndex","options","_objectSpread","handlePrevious","handleNext","handleChange","_ref2","current_step","setFormError","error","titlesRef","updateTitlesRef","prerenderFieldPropsRef","activeIndex","providerValue","_sharedStateRef$curre4","_sharedStateRef$curre5","extend","_updateTitlesRef$curr","createElement","_extends","Provider","value","DisplaySteps","IterateOverSteps","PrerenderFieldPropsOfOtherSteps","_ref3","sidebar_id","Sidebar","bottom","Object","values","no_animation","on_change","_ref4","incrementIndex","decrementIndex","childrenArray","Children","map","child","isValidElement","_child","_child2","step","type","_step","apply","active","title","key","clone","cloneElement","document","length","_ref5","hasRenderedRef","WizardPortal","PrerenderFieldPropsProvider","hidden","Fn","i","_ref6","createPortal","body","_ref7","setFieldProps","updateDataValue","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Wizard/Container/WizardContainer.tsx"],"sourcesContent":["import React, {\n useContext,\n useCallback,\n useRef,\n useReducer,\n useMemo,\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport classnames from 'classnames'\nimport { Space, StepIndicator } from '../../../../components'\nimport {\n convertJsxToString,\n warn,\n} from '../../../../shared/component-helper'\nimport { isAsync } from '../../../../shared/helpers/isAsync'\nimport useId from '../../../../shared/helpers/useId'\nimport Step, { Props as StepProps } from '../Step'\nimport WizardContext, {\n OnStepChange,\n SetActiveIndexOptions,\n StepIndex,\n WizardContextState,\n} from '../Context/WizardContext'\nimport DataContext, {\n defaultContextState,\n} from '../../DataContext/Context'\nimport Handler from '../../Form/Handler/Handler'\nimport {\n SharedStateReturn,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useHandleLayoutEffect from './useHandleLayoutEffect'\nimport { ComponentProps } from '../../types'\n\n// SSR warning fix: https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\nconst useLayoutEffect =\n typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect\n\nexport type Props = ComponentProps & {\n id?: string\n\n /**\n * The mode of the wizard.\n */\n mode?: 'static' | 'strict' | 'loose'\n\n /**\n * If set to `true`, the wizard will not scroll to the first step when the user clicks on the next button.\n */\n omitScrollManagement?: boolean\n\n /**\n * If set to `true`, the wizard will not focus on the next step when the user clicks on the next button.\n */\n omitFocusManagement?: boolean\n\n /**\n * The index of the first step to be rendered.\n */\n initialActiveIndex?: StepIndex\n\n /**\n * The callback function that will be called when the user clicks on the next button.\n */\n onStepChange?: OnStepChange\n\n /**\n * The sidebar variant.\n */\n variant?: 'sidebar' | 'drawer'\n sidebarId?: string\n\n /**\n * If set to `true`, the wizard will not animate the steps.\n */\n noAnimation?: boolean\n\n /**\n * If set to `true`, the wizard pre-render all steps so the props of each field is available in the data context.\n * Defaults to `true`.\n */\n prerenderFieldProps?: boolean\n\n /**\n * The children of the wizard container.\n */\n children: React.ReactNode\n\n /**\n * @deprecated Is enabled by default. You can disable it with \"omitScrollManagement\"\n */\n scrollTopOnStepChange?: boolean\n}\n\nfunction WizardContainer(props: Props) {\n const {\n className,\n id: idProp,\n mode = 'strict',\n initialActiveIndex = 0,\n omitScrollManagement,\n omitFocusManagement,\n onStepChange,\n children,\n noAnimation = true,\n prerenderFieldProps = true,\n variant = 'sidebar',\n sidebarId,\n ...rest\n } = props\n\n const {\n hasContext,\n setFormState,\n handleSubmitCall,\n setShowAllErrors,\n showAllErrors,\n setSubmitState,\n } = useContext(DataContext)\n\n const id = useId(idProp)\n const [, forceUpdate] = useReducer(() => ({}), {})\n const activeIndexRef = useRef<StepIndex>(initialActiveIndex)\n const errorOnStepRef = useRef<Record<StepIndex, boolean>>({})\n const stepElementRef = useRef<HTMLElement>()\n\n // - Handle shared state\n const sharedStateRef =\n useRef<\n SharedStateReturn<\n WizardContextState & { onStepChange?: OnStepChange }\n >\n >()\n sharedStateRef.current = useSharedState<WizardContextState>(\n hasContext && id ? id + '-wizard' : undefined\n )\n\n // Store the current state of showAllErrors\n errorOnStepRef.current[activeIndexRef.current] = showAllErrors\n\n const callOnStepChange = useCallback(\n async (index: StepIndex, mode: 'previous' | 'next') => {\n if (isAsync(onStepChange)) {\n return await onStepChange(index, mode)\n }\n\n return onStepChange?.(index, mode)\n },\n [onStepChange]\n )\n\n const { setFocus, scrollToTop, isInteractionRef } =\n useHandleLayoutEffect({ activeIndexRef, stepElementRef })\n\n const handleLayoutEffect = useCallback(() => {\n if (!omitFocusManagement) {\n setFocus()\n }\n if (!omitScrollManagement) {\n scrollToTop()\n }\n }, [omitScrollManagement, omitFocusManagement, setFocus, scrollToTop])\n\n const handleStepChange = useCallback(\n ({\n index,\n skipErrorCheck,\n skipStepChangeCall,\n skipStepChangeCallBeforeMounted,\n skipStepChangeCallFromHook,\n mode,\n }: {\n index: StepIndex\n mode: 'previous' | 'next'\n } & SetActiveIndexOptions) => {\n handleSubmitCall({\n skipErrorCheck,\n skipFieldValidation: skipErrorCheck,\n enableAsyncBehaviour: isAsync(onStepChange),\n onSubmit: async () => {\n if (!skipStepChangeCallFromHook) {\n sharedStateRef.current?.data?.onStepChange?.(index, mode)\n }\n\n const result =\n skipStepChangeCall ||\n (skipStepChangeCallBeforeMounted && !isInteractionRef.current)\n ? undefined\n : await callOnStepChange(index, mode)\n\n // Hide async indicator\n setFormState('abort')\n\n if (!skipErrorCheck) {\n // Set the showAllErrors to the step we got to\n setShowAllErrors(errorOnStepRef.current[index])\n }\n\n if (!(result instanceof Error)) {\n handleLayoutEffect()\n\n activeIndexRef.current = index\n forceUpdate()\n }\n\n return result\n },\n })\n },\n [\n callOnStepChange,\n handleLayoutEffect,\n handleSubmitCall,\n isInteractionRef,\n onStepChange,\n setFormState,\n setShowAllErrors,\n ]\n )\n\n const setActiveIndex = useCallback(\n (index: StepIndex, options?: SetActiveIndexOptions) => {\n if (index === activeIndexRef.current) {\n return\n }\n\n const mode = index > activeIndexRef.current ? 'next' : 'previous'\n\n handleStepChange({\n index,\n skipErrorCheck: mode === 'previous',\n mode,\n ...options,\n })\n },\n [handleStepChange]\n )\n\n const handlePrevious = useCallback(() => {\n setActiveIndex(activeIndexRef.current - 1)\n }, [setActiveIndex])\n\n const handleNext = useCallback(() => {\n setActiveIndex(activeIndexRef.current + 1)\n }, [setActiveIndex])\n\n const handleChange = useCallback(\n ({ current_step }) => {\n setActiveIndex(current_step, { skipErrorCheck: true })\n },\n [setActiveIndex]\n )\n\n const setFormError = useCallback(\n (error: Error) => {\n setSubmitState?.({ error })\n },\n [setSubmitState]\n )\n\n const titlesRef = useRef({})\n const updateTitlesRef = useRef<() => void>()\n const prerenderFieldPropsRef = useRef<\n Record<string, () => React.ReactElement>\n >({})\n\n const activeIndex = activeIndexRef.current\n const providerValue = useMemo(() => {\n return {\n id,\n activeIndex,\n stepElementRef,\n titlesRef,\n updateTitlesRef,\n activeIndexRef,\n prerenderFieldProps,\n prerenderFieldPropsRef,\n setActiveIndex,\n handlePrevious,\n handleNext,\n setFormError,\n }\n }, [\n activeIndex,\n handleNext,\n handlePrevious,\n id,\n prerenderFieldProps,\n setActiveIndex,\n setFormError,\n ])\n\n // - Handle shared state\n useLayoutEffect(() => {\n if (id && hasContext) {\n sharedStateRef.current?.extend?.(providerValue)\n }\n }, [id, providerValue]) // eslint-disable-line react-hooks/exhaustive-deps\n\n useLayoutEffect(() => {\n updateTitlesRef.current?.()\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [children])\n\n if (!hasContext) {\n warn('You may wrap Wizard.Container in Form.Handler')\n return (\n <Handler>\n <WizardContainer {...props} id={id} />\n </Handler>\n )\n }\n\n return (\n <WizardContext.Provider value={providerValue}>\n <Space\n className={classnames(\n 'dnb-forms-wizard-layout',\n `dnb-forms-wizard-layout--${variant}`,\n className\n )}\n {...rest}\n >\n <DisplaySteps\n mode={mode}\n variant={variant}\n noAnimation={noAnimation}\n handleChange={handleChange}\n sidebarId={sidebarId}\n />\n\n <div className=\"dnb-forms-wizard-layout__contents\">\n <IterateOverSteps>{children}</IterateOverSteps>\n </div>\n </Space>\n\n {prerenderFieldProps && (\n <PrerenderFieldPropsOfOtherSteps\n prerenderFieldPropsRef={prerenderFieldPropsRef}\n />\n )}\n </WizardContext.Provider>\n )\n}\n\nfunction DisplaySteps({\n mode,\n variant,\n noAnimation,\n handleChange,\n sidebarId,\n}) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n const { id, activeIndexRef, titlesRef, updateTitlesRef } =\n useContext(WizardContext) || {}\n updateTitlesRef.current = () => {\n forceUpdate()\n }\n\n const sidebar_id =\n variant === 'drawer' && !sidebarId ? undefined : sidebarId ?? id\n\n return (\n <aside className=\"dnb-forms-wizard-layout__indicator\">\n <StepIndicator.Sidebar sidebar_id={sidebar_id} />\n <StepIndicator\n bottom\n current_step={activeIndexRef.current}\n data={Object.values(titlesRef.current)}\n mode={mode}\n no_animation={noAnimation}\n on_change={handleChange}\n sidebar_id={sidebar_id}\n />\n </aside>\n )\n}\n\nfunction IterateOverSteps({ children }) {\n const {\n titlesRef,\n activeIndexRef,\n prerenderFieldProps,\n prerenderFieldPropsRef,\n } = useContext(WizardContext)\n\n titlesRef.current = {}\n let incrementIndex = -1\n let decrementIndex = -1\n\n const childrenArray = React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n let step = child\n\n if (child?.type !== Step && typeof child.type === 'function') {\n step = child.type.apply(child.type, [\n child.props,\n ]) as React.ReactElement\n\n if (step?.type === Step) {\n child = step\n }\n }\n\n if (child?.type === Step) {\n if (child.props.active === false) {\n return null\n }\n\n if (child.props.active === false) {\n decrementIndex--\n } else {\n incrementIndex++\n }\n const index =\n child.props.active === false ? decrementIndex : incrementIndex\n\n titlesRef.current[index] =\n child.props.title !== undefined\n ? convertJsxToString(child.props.title)\n : 'Title missing'\n const key = `${index}-${activeIndexRef.current}`\n const clone = (props) =>\n React.cloneElement(child as React.ReactElement<StepProps>, props)\n\n if (\n prerenderFieldProps &&\n typeof document !== 'undefined' &&\n index !== activeIndexRef.current &&\n typeof prerenderFieldPropsRef.current['step-' + index] ===\n 'undefined'\n ) {\n prerenderFieldPropsRef.current['step-' + index] = () =>\n clone({\n key,\n index,\n prerenderFieldProps: true,\n })\n }\n\n return clone({\n key,\n index,\n })\n }\n }\n\n return child\n })\n\n // Ensure we never have a higher index than the available children\n // else we get a white screen\n if (childrenArray.length === 0) {\n activeIndexRef.current = 0\n } else if (childrenArray.length < activeIndexRef.current + 1) {\n activeIndexRef.current = childrenArray.length - 1\n }\n\n return childrenArray\n}\n\nfunction PrerenderFieldPropsOfOtherSteps({\n prerenderFieldPropsRef,\n}: {\n prerenderFieldPropsRef: WizardContextState['prerenderFieldPropsRef']\n}) {\n const hasRenderedRef = useRef(true)\n if (!hasRenderedRef.current) {\n return null\n }\n hasRenderedRef.current = false\n\n return (\n <WizardPortal>\n <PrerenderFieldPropsProvider>\n <iframe title=\"Wizard Prerender\" hidden>\n {Object.values(prerenderFieldPropsRef.current).map((Fn, i) => (\n <Fn key={i} />\n ))}\n </iframe>\n </PrerenderFieldPropsProvider>\n </WizardPortal>\n )\n}\n\nfunction WizardPortal({ children }) {\n if (typeof document !== 'undefined') {\n return ReactDOM.createPortal(children, document.body)\n }\n}\n\nfunction PrerenderFieldPropsProvider({ children }) {\n const { data, setFieldProps, updateDataValue } = useContext(DataContext)\n\n return (\n <DataContext.Provider\n value={{\n ...defaultContextState,\n\n // Only update the props and the data value\n data,\n setFieldProps,\n updateDataValue,\n prerenderFieldProps: true,\n }}\n >\n <WizardContext.Provider value={{ prerenderFieldProps: true }}>\n {children}\n </WizardContext.Provider>\n </DataContext.Provider>\n )\n}\n\nWizardContainer._supportsSpacingProps = true\n\nexport default WizardContainer\n"],"mappings":"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"}
1
+ {"version":3,"file":"WizardContainer.js","names":["React","useContext","useCallback","useRef","useReducer","useMemo","ReactDOM","classnames","Space","StepIndicator","convertJsxToString","warn","isAsync","useId","Step","WizardContext","DataContext","defaultContextState","Handler","useSharedState","useHandleLayoutEffect","useLayoutEffect","window","useEffect","WizardContainer","props","className","id","idProp","mode","initialActiveIndex","omitScrollManagement","omitFocusManagement","onStepChange","children","noAnimation","prerenderFieldProps","variant","sidebarId","rest","_objectWithoutProperties","_excluded","hasContext","setFormState","handleSubmitCall","setShowAllErrors","showAllErrors","setSubmitState","forceUpdate","activeIndexRef","errorOnStepRef","stepElementRef","sharedStateRef","current","undefined","callOnStepChange","index","setFocus","scrollToTop","isInteractionRef","handleLayoutEffect","handleStepChange","_ref","skipErrorCheck","skipStepChangeCall","skipStepChangeCallBeforeMounted","skipStepChangeCallFromHook","skipFieldValidation","enableAsyncBehaviour","onSubmit","_sharedStateRef$curre","_sharedStateRef$curre2","_sharedStateRef$curre3","data","call","result","Error","setActiveIndex","options","_objectSpread","handlePrevious","handleNext","handleChange","_ref2","current_step","setFormError","error","titlesRef","updateTitlesRef","prerenderFieldPropsRef","activeIndex","providerValue","_sharedStateRef$curre4","_sharedStateRef$curre5","extend","_updateTitlesRef$curr","createElement","_extends","Provider","value","DisplaySteps","IterateOverSteps","PrerenderFieldPropsOfOtherSteps","_ref3","sidebar_id","Sidebar","bottom","Object","values","no_animation","on_change","_ref4","incrementIndex","decrementIndex","childrenArray","Children","map","child","isValidElement","_child","_child2","step","type","_step","apply","active","title","key","clone","cloneElement","document","length","_ref5","hasRenderedRef","WizardPortal","PrerenderFieldPropsProvider","hidden","Fn","i","_ref6","createPortal","body","_ref7","setFieldProps","updateDataValue","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Wizard/Container/WizardContainer.tsx"],"sourcesContent":["import React, {\n useContext,\n useCallback,\n useRef,\n useReducer,\n useMemo,\n} from 'react'\nimport ReactDOM from 'react-dom'\nimport classnames from 'classnames'\nimport { Space, StepIndicator } from '../../../../components'\nimport {\n convertJsxToString,\n warn,\n} from '../../../../shared/component-helper'\nimport { isAsync } from '../../../../shared/helpers/isAsync'\nimport useId from '../../../../shared/helpers/useId'\nimport Step, { Props as StepProps } from '../Step'\nimport WizardContext, {\n OnStepChange,\n SetActiveIndexOptions,\n StepIndex,\n WizardContextState,\n} from '../Context/WizardContext'\nimport DataContext, {\n defaultContextState,\n} from '../../DataContext/Context'\nimport Handler from '../../Form/Handler/Handler'\nimport {\n SharedStateReturn,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useHandleLayoutEffect from './useHandleLayoutEffect'\nimport { ComponentProps } from '../../types'\n\n// SSR warning fix: https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\nconst useLayoutEffect =\n typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect\n\nexport type Props = ComponentProps & {\n id?: string\n\n /**\n * The mode of the wizard.\n */\n mode?: 'static' | 'strict' | 'loose'\n\n /**\n * If set to `true`, the wizard will not scroll to the first step when the user clicks on the next button.\n */\n omitScrollManagement?: boolean\n\n /**\n * If set to `true`, the wizard will not focus on the next step when the user clicks on the next button.\n */\n omitFocusManagement?: boolean\n\n /**\n * The index of the first step to be rendered.\n */\n initialActiveIndex?: StepIndex\n\n /**\n * The callback function that will be called when the user clicks on the next button.\n */\n onStepChange?: OnStepChange\n\n /**\n * The sidebar variant.\n */\n variant?: 'sidebar' | 'drawer'\n sidebarId?: string\n\n /**\n * If set to `true`, the wizard will not animate the steps.\n */\n noAnimation?: boolean\n\n /**\n * If set to `true`, the wizard pre-render all steps so the props of each field is available in the data context.\n * Defaults to `true`.\n */\n prerenderFieldProps?: boolean\n\n /**\n * The children of the wizard container.\n */\n children: React.ReactNode\n\n /**\n * @deprecated Is enabled by default. You can disable it with \"omitScrollManagement\"\n */\n scrollTopOnStepChange?: boolean\n}\n\nfunction WizardContainer(props: Props) {\n const {\n className,\n id: idProp,\n mode = 'strict',\n initialActiveIndex = 0,\n omitScrollManagement,\n omitFocusManagement,\n onStepChange,\n children,\n noAnimation = true,\n prerenderFieldProps = true,\n variant = 'sidebar',\n sidebarId,\n ...rest\n } = props\n\n const {\n hasContext,\n setFormState,\n handleSubmitCall,\n setShowAllErrors,\n showAllErrors,\n setSubmitState,\n } = useContext(DataContext)\n\n const id = useId(idProp)\n const [, forceUpdate] = useReducer(() => ({}), {})\n const activeIndexRef = useRef<StepIndex>(initialActiveIndex)\n const errorOnStepRef = useRef<Record<StepIndex, boolean>>({})\n const stepElementRef = useRef<HTMLElement>()\n\n // - Handle shared state\n const sharedStateRef =\n useRef<\n SharedStateReturn<\n WizardContextState & { onStepChange?: OnStepChange }\n >\n >()\n sharedStateRef.current = useSharedState<WizardContextState>(\n hasContext && id ? id + '-wizard' : undefined\n )\n\n // Store the current state of showAllErrors\n errorOnStepRef.current[activeIndexRef.current] = showAllErrors\n\n const callOnStepChange = useCallback(\n async (index: StepIndex, mode: 'previous' | 'next') => {\n if (isAsync(onStepChange)) {\n return await onStepChange(index, mode)\n }\n\n return onStepChange?.(index, mode)\n },\n [onStepChange]\n )\n\n const { setFocus, scrollToTop, isInteractionRef } =\n useHandleLayoutEffect({ activeIndexRef, stepElementRef })\n\n const handleLayoutEffect = useCallback(() => {\n if (!omitFocusManagement) {\n setFocus()\n }\n if (!omitScrollManagement) {\n scrollToTop()\n }\n }, [omitScrollManagement, omitFocusManagement, setFocus, scrollToTop])\n\n const handleStepChange = useCallback(\n ({\n index,\n skipErrorCheck,\n skipStepChangeCall,\n skipStepChangeCallBeforeMounted,\n skipStepChangeCallFromHook,\n mode,\n }: {\n index: StepIndex\n mode: 'previous' | 'next'\n } & SetActiveIndexOptions) => {\n handleSubmitCall({\n skipErrorCheck,\n skipFieldValidation: skipErrorCheck,\n enableAsyncBehaviour: isAsync(onStepChange),\n onSubmit: async () => {\n if (!skipStepChangeCallFromHook) {\n sharedStateRef.current?.data?.onStepChange?.(index, mode)\n }\n\n const result =\n skipStepChangeCall ||\n (skipStepChangeCallBeforeMounted && !isInteractionRef.current)\n ? undefined\n : await callOnStepChange(index, mode)\n\n // Hide async indicator\n setFormState('abort')\n\n if (!skipErrorCheck) {\n // Set the showAllErrors to the step we got to\n setShowAllErrors(errorOnStepRef.current[index])\n }\n\n if (!(result instanceof Error)) {\n handleLayoutEffect()\n\n activeIndexRef.current = index\n forceUpdate()\n }\n\n return result\n },\n })\n },\n [\n callOnStepChange,\n handleLayoutEffect,\n handleSubmitCall,\n isInteractionRef,\n onStepChange,\n setFormState,\n setShowAllErrors,\n ]\n )\n\n const setActiveIndex = useCallback(\n (index: StepIndex, options?: SetActiveIndexOptions) => {\n if (index === activeIndexRef.current) {\n return\n }\n\n const mode = index > activeIndexRef.current ? 'next' : 'previous'\n\n handleStepChange({\n index,\n skipErrorCheck: mode === 'previous',\n mode,\n ...options,\n })\n },\n [handleStepChange]\n )\n\n const handlePrevious = useCallback(() => {\n setActiveIndex(activeIndexRef.current - 1)\n }, [setActiveIndex])\n\n const handleNext = useCallback(() => {\n setActiveIndex(activeIndexRef.current + 1)\n }, [setActiveIndex])\n\n const handleChange = useCallback(\n ({ current_step }) => {\n setActiveIndex(current_step, { skipErrorCheck: true })\n },\n [setActiveIndex]\n )\n\n const setFormError = useCallback(\n (error: Error) => {\n setSubmitState?.({ error })\n },\n [setSubmitState]\n )\n\n const titlesRef = useRef({})\n const updateTitlesRef = useRef<() => void>()\n const prerenderFieldPropsRef = useRef<\n Record<string, () => React.ReactElement>\n >({})\n\n const activeIndex = activeIndexRef.current\n const providerValue = useMemo(() => {\n return {\n id,\n activeIndex,\n stepElementRef,\n titlesRef,\n updateTitlesRef,\n activeIndexRef,\n prerenderFieldProps,\n prerenderFieldPropsRef,\n setActiveIndex,\n handlePrevious,\n handleNext,\n setFormError,\n }\n }, [\n activeIndex,\n handleNext,\n handlePrevious,\n id,\n prerenderFieldProps,\n setActiveIndex,\n setFormError,\n ])\n\n // - Handle shared state\n useLayoutEffect(() => {\n if (id && hasContext) {\n sharedStateRef.current?.extend?.(providerValue)\n }\n }, [id, providerValue]) // eslint-disable-line react-hooks/exhaustive-deps\n\n useLayoutEffect(() => {\n updateTitlesRef.current?.()\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [titlesRef.current])\n\n if (!hasContext) {\n warn('You may wrap Wizard.Container in Form.Handler')\n return (\n <Handler>\n <WizardContainer {...props} id={id} />\n </Handler>\n )\n }\n\n return (\n <WizardContext.Provider value={providerValue}>\n <Space\n className={classnames(\n 'dnb-forms-wizard-layout',\n `dnb-forms-wizard-layout--${variant}`,\n className\n )}\n {...rest}\n >\n <DisplaySteps\n mode={mode}\n variant={variant}\n noAnimation={noAnimation}\n handleChange={handleChange}\n sidebarId={sidebarId}\n />\n\n <div className=\"dnb-forms-wizard-layout__contents\">\n <IterateOverSteps>{children}</IterateOverSteps>\n </div>\n </Space>\n\n {prerenderFieldProps && (\n <PrerenderFieldPropsOfOtherSteps\n prerenderFieldPropsRef={prerenderFieldPropsRef}\n />\n )}\n </WizardContext.Provider>\n )\n}\n\nfunction DisplaySteps({\n mode,\n variant,\n noAnimation,\n handleChange,\n sidebarId,\n}) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n const { id, activeIndexRef, titlesRef, updateTitlesRef } =\n useContext(WizardContext) || {}\n updateTitlesRef.current = () => {\n forceUpdate()\n }\n\n const sidebar_id =\n variant === 'drawer' && !sidebarId ? undefined : sidebarId ?? id\n\n return (\n <aside className=\"dnb-forms-wizard-layout__indicator\">\n <StepIndicator.Sidebar sidebar_id={sidebar_id} />\n <StepIndicator\n bottom\n current_step={activeIndexRef.current}\n data={Object.values(titlesRef.current)}\n mode={mode}\n no_animation={noAnimation}\n on_change={handleChange}\n sidebar_id={sidebar_id}\n />\n </aside>\n )\n}\n\nfunction IterateOverSteps({ children }) {\n const {\n titlesRef,\n activeIndexRef,\n prerenderFieldProps,\n prerenderFieldPropsRef,\n } = useContext(WizardContext)\n\n titlesRef.current = {}\n let incrementIndex = -1\n let decrementIndex = -1\n\n const childrenArray = React.Children.map(children, (child) => {\n if (React.isValidElement(child)) {\n let step = child\n\n if (child?.type !== Step && typeof child.type === 'function') {\n step = child.type.apply(child.type, [\n child.props,\n ]) as React.ReactElement\n\n if (step?.type === Step) {\n child = step\n }\n }\n\n if (child?.type === Step) {\n if (child.props.active === false) {\n return null\n }\n\n if (child.props.active === false) {\n decrementIndex--\n } else {\n incrementIndex++\n }\n const index =\n child.props.active === false ? decrementIndex : incrementIndex\n\n titlesRef.current[index] =\n child.props.title !== undefined\n ? convertJsxToString(child.props.title)\n : 'Title missing'\n const key = `${index}-${activeIndexRef.current}`\n const clone = (props) =>\n React.cloneElement(child as React.ReactElement<StepProps>, props)\n\n if (\n prerenderFieldProps &&\n typeof document !== 'undefined' &&\n index !== activeIndexRef.current &&\n typeof prerenderFieldPropsRef.current['step-' + index] ===\n 'undefined'\n ) {\n prerenderFieldPropsRef.current['step-' + index] = () =>\n clone({\n key,\n index,\n prerenderFieldProps: true,\n })\n }\n\n return clone({\n key,\n index,\n })\n }\n }\n\n return child\n })\n\n // Ensure we never have a higher index than the available children\n // else we get a white screen\n if (childrenArray.length === 0) {\n activeIndexRef.current = 0\n } else if (childrenArray.length < activeIndexRef.current + 1) {\n activeIndexRef.current = childrenArray.length - 1\n }\n\n return childrenArray\n}\n\nfunction PrerenderFieldPropsOfOtherSteps({\n prerenderFieldPropsRef,\n}: {\n prerenderFieldPropsRef: WizardContextState['prerenderFieldPropsRef']\n}) {\n const hasRenderedRef = useRef(true)\n if (!hasRenderedRef.current) {\n return null\n }\n hasRenderedRef.current = false\n\n return (\n <WizardPortal>\n <PrerenderFieldPropsProvider>\n <iframe title=\"Wizard Prerender\" hidden>\n {Object.values(prerenderFieldPropsRef.current).map((Fn, i) => (\n <Fn key={i} />\n ))}\n </iframe>\n </PrerenderFieldPropsProvider>\n </WizardPortal>\n )\n}\n\nfunction WizardPortal({ children }) {\n if (typeof document !== 'undefined') {\n return ReactDOM.createPortal(children, document.body)\n }\n}\n\nfunction PrerenderFieldPropsProvider({ children }) {\n const { data, setFieldProps, updateDataValue } = useContext(DataContext)\n\n return (\n <DataContext.Provider\n value={{\n ...defaultContextState,\n\n // Only update the props and the data value\n data,\n setFieldProps,\n updateDataValue,\n prerenderFieldProps: true,\n }}\n >\n <WizardContext.Provider value={{ prerenderFieldProps: true }}>\n {children}\n </WizardContext.Provider>\n </DataContext.Provider>\n )\n}\n\nWizardContainer._supportsSpacingProps = true\n\nexport default WizardContainer\n"],"mappings":"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"}
@@ -45,7 +45,7 @@ function Step(props) {
45
45
  return children;
46
46
  }
47
47
  if (activeIndex !== index || active === false) {
48
- return null;
48
+ return React.createElement(React.Fragment, null);
49
49
  }
50
50
  const fieldProps = typeof required === 'boolean' ? {
51
51
  required