@dnb/eufemia 10.57.1 → 10.59.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 (540) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/cjs/components/date-picker/DatePickerContext.d.ts +1 -1
  3. package/cjs/components/date-picker/DatePickerContext.js.map +1 -1
  4. package/cjs/components/date-picker/DatePickerFooter.js +5 -5
  5. package/cjs/components/date-picker/DatePickerFooter.js.map +1 -1
  6. package/cjs/components/date-picker/DatePickerProvider.js +2 -2
  7. package/cjs/components/date-picker/DatePickerProvider.js.map +1 -1
  8. package/cjs/components/date-picker/hooks/useDates.d.ts +1 -1
  9. package/cjs/components/date-picker/hooks/useDates.js +94 -23
  10. package/cjs/components/date-picker/hooks/useDates.js.map +1 -1
  11. package/cjs/components/dialog/parts/DialogAction.js +18 -16
  12. package/cjs/components/dialog/parts/DialogAction.js.map +1 -1
  13. package/cjs/components/form-label/FormLabel.js +13 -10
  14. package/cjs/components/form-label/FormLabel.js.map +1 -1
  15. package/cjs/components/number-format/NumberUtils.js +15 -15
  16. package/cjs/components/number-format/NumberUtils.js.map +1 -1
  17. package/cjs/components/upload/UploadFileListCell.js +2 -1
  18. package/cjs/components/upload/UploadFileListCell.js.map +1 -1
  19. package/cjs/extensions/forms/DataContext/Context.d.ts +8 -5
  20. package/cjs/extensions/forms/DataContext/Context.js +0 -1
  21. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  22. package/cjs/extensions/forms/DataContext/Provider/Provider.d.ts +4 -3
  23. package/cjs/extensions/forms/DataContext/Provider/Provider.js +2 -2
  24. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  25. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  26. package/cjs/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  27. package/cjs/extensions/forms/Field/Date/Date.js +2 -2
  28. package/cjs/extensions/forms/Field/Date/Date.js.map +1 -1
  29. package/cjs/extensions/forms/Field/Provider/FieldProvider.d.ts +3 -2
  30. package/cjs/extensions/forms/Field/Provider/FieldProvider.js.map +1 -1
  31. package/cjs/extensions/forms/Field/Upload/Upload.js +11 -3
  32. package/cjs/extensions/forms/Field/Upload/Upload.js.map +1 -1
  33. package/cjs/extensions/forms/Form/Element/Element.d.ts +2 -2
  34. package/cjs/extensions/forms/Form/Element/Element.js +50 -11
  35. package/cjs/extensions/forms/Form/Element/Element.js.map +1 -1
  36. package/cjs/extensions/forms/Form/Handler/Handler.d.ts +7 -3
  37. package/cjs/extensions/forms/Form/Handler/Handler.js +23 -97
  38. package/cjs/extensions/forms/Form/Handler/Handler.js.map +1 -1
  39. package/cjs/extensions/forms/Form/Isolation/Isolation.d.ts +3 -3
  40. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  41. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js +1 -1
  42. package/cjs/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js.map +1 -1
  43. package/cjs/extensions/forms/Form/Section/Section.d.ts +4 -4
  44. package/cjs/extensions/forms/Form/Section/Section.js +2 -1
  45. package/cjs/extensions/forms/Form/Section/Section.js.map +1 -1
  46. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js +1 -1
  47. package/cjs/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js.map +1 -1
  48. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.d.ts +1 -1
  49. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js +1 -0
  50. package/cjs/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  51. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.css +10 -6
  52. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  53. package/cjs/extensions/forms/Form/Section/style/dnb-form-section.scss +13 -7
  54. package/cjs/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.css +3 -0
  55. package/cjs/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.min.css +1 -0
  56. package/cjs/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.scss +7 -0
  57. package/cjs/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.css +4 -0
  58. package/cjs/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.min.css +1 -0
  59. package/cjs/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.scss +8 -0
  60. package/cjs/extensions/forms/Form/Section/style/themes/ui.d.ts +1 -0
  61. package/cjs/extensions/forms/Form/Section/style/themes/ui.js +4 -0
  62. package/cjs/extensions/forms/Form/Section/style/themes/ui.js.map +1 -0
  63. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.js +3 -3
  64. package/cjs/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  65. package/cjs/extensions/forms/Form/data-context/clearData.d.ts +2 -1
  66. package/cjs/extensions/forms/Form/data-context/clearData.js +1 -1
  67. package/cjs/extensions/forms/Form/data-context/clearData.js.map +1 -1
  68. package/cjs/extensions/forms/Form/data-context/getData.js +1 -1
  69. package/cjs/extensions/forms/Form/data-context/getData.js.map +1 -1
  70. package/cjs/extensions/forms/Form/data-context/useData.js +1 -1
  71. package/cjs/extensions/forms/Form/data-context/useData.js.map +1 -1
  72. package/cjs/extensions/forms/Form/data-context/useValidation.js +2 -2
  73. package/cjs/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  74. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +3 -2
  75. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js +9 -5
  76. package/cjs/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  77. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +3 -0
  78. package/cjs/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -1
  79. package/cjs/extensions/forms/Iterate/Count/Count.d.ts +4 -3
  80. package/cjs/extensions/forms/Iterate/Count/Count.js.map +1 -1
  81. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -1
  82. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js +7 -4
  83. package/cjs/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  84. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +2 -2
  85. package/cjs/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  86. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +1 -1
  87. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  88. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.d.ts +3 -1
  89. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js +27 -6
  90. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  91. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButtonDocs.js +5 -0
  92. package/cjs/extensions/forms/Iterate/RemoveButton/RemoveButtonDocs.js.map +1 -1
  93. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js +8 -4
  94. package/cjs/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  95. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +2 -1
  96. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js +4 -3
  97. package/cjs/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -1
  98. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +1 -1
  99. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js +3 -2
  100. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  101. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +2 -2
  102. package/cjs/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  103. package/cjs/extensions/forms/Iterate/hooks/useItem.d.ts +5 -1
  104. package/cjs/extensions/forms/Iterate/hooks/useItem.js.map +1 -1
  105. package/cjs/extensions/forms/Tools/ListAllProps.d.ts +7 -7
  106. package/cjs/extensions/forms/Tools/ListAllProps.js.map +1 -1
  107. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.js +1 -1
  108. package/cjs/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  109. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +1 -1
  110. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  111. package/cjs/extensions/forms/Wizard/hooks/useStep.d.ts +2 -2
  112. package/cjs/extensions/forms/Wizard/hooks/useStep.js +1 -1
  113. package/cjs/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  114. package/cjs/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +2 -0
  115. package/cjs/extensions/forms/constants/countries.js +1 -1
  116. package/cjs/extensions/forms/constants/countries.js.map +1 -1
  117. package/cjs/extensions/forms/constants/locales/en-GB.d.ts +1 -0
  118. package/cjs/extensions/forms/constants/locales/en-GB.js +2 -1
  119. package/cjs/extensions/forms/constants/locales/en-GB.js.map +1 -1
  120. package/cjs/extensions/forms/constants/locales/en-US.d.ts +1 -0
  121. package/cjs/extensions/forms/constants/locales/index.d.ts +2 -0
  122. package/cjs/extensions/forms/constants/locales/nb-NO.d.ts +1 -0
  123. package/cjs/extensions/forms/constants/locales/nb-NO.js +2 -1
  124. package/cjs/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  125. package/cjs/extensions/forms/hooks/useDataContext.js +1 -1
  126. package/cjs/extensions/forms/hooks/useDataContext.js.map +1 -1
  127. package/cjs/extensions/forms/hooks/useSnapshot.d.ts +3 -2
  128. package/cjs/extensions/forms/hooks/useSnapshot.js.map +1 -1
  129. package/cjs/extensions/forms/style/dnb-forms.css +10 -6
  130. package/cjs/extensions/forms/style/dnb-forms.min.css +1 -1
  131. package/cjs/extensions/forms/types.d.ts +4 -4
  132. package/cjs/extensions/forms/types.js.map +1 -1
  133. package/cjs/extensions/forms/utils/json-pointer/json-pointer.d.ts +2 -2
  134. package/cjs/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
  135. package/cjs/shared/Eufemia.d.ts +1 -1
  136. package/cjs/shared/Eufemia.js +2 -2
  137. package/cjs/shared/Eufemia.js.map +1 -1
  138. package/cjs/shared/helpers/useSharedState.d.ts +19 -13
  139. package/cjs/shared/helpers/useSharedState.js +23 -11
  140. package/cjs/shared/helpers/useSharedState.js.map +1 -1
  141. package/cjs/style/core/scopes.scss +1 -1
  142. package/cjs/style/dnb-ui-basis.css +1 -1
  143. package/cjs/style/dnb-ui-basis.min.css +1 -1
  144. package/cjs/style/dnb-ui-body.css +1 -1
  145. package/cjs/style/dnb-ui-body.min.css +1 -1
  146. package/cjs/style/dnb-ui-components.css +10 -6
  147. package/cjs/style/dnb-ui-components.min.css +1 -1
  148. package/cjs/style/dnb-ui-core.css +1 -1
  149. package/cjs/style/dnb-ui-core.min.css +1 -1
  150. package/cjs/style/dnb-ui-extensions.css +10 -6
  151. package/cjs/style/dnb-ui-extensions.min.css +1 -1
  152. package/cjs/style/dnb-ui-forms.css +10 -6
  153. package/cjs/style/dnb-ui-forms.min.css +1 -1
  154. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.css +25 -12
  155. package/cjs/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
  156. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.css +15 -6
  157. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  158. package/cjs/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  159. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.css +15 -6
  160. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  161. package/cjs/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  162. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.css +24 -12
  163. package/cjs/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  164. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.css +14 -6
  165. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  166. package/cjs/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  167. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.css +14 -6
  168. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  169. package/cjs/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  170. package/cjs/style/themes/theme-ui/ui-theme-components.css +25 -12
  171. package/cjs/style/themes/theme-ui/ui-theme-components.min.css +2 -2
  172. package/cjs/style/themes/theme-ui/ui-theme-extensions.css +15 -6
  173. package/cjs/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  174. package/cjs/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  175. package/cjs/style/themes/theme-ui/ui-theme-forms.css +15 -6
  176. package/cjs/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  177. package/cjs/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  178. package/components/date-picker/DatePickerContext.d.ts +1 -1
  179. package/components/date-picker/DatePickerContext.js.map +1 -1
  180. package/components/date-picker/DatePickerFooter.js +5 -5
  181. package/components/date-picker/DatePickerFooter.js.map +1 -1
  182. package/components/date-picker/DatePickerProvider.js +2 -2
  183. package/components/date-picker/DatePickerProvider.js.map +1 -1
  184. package/components/date-picker/hooks/useDates.d.ts +1 -1
  185. package/components/date-picker/hooks/useDates.js +95 -24
  186. package/components/date-picker/hooks/useDates.js.map +1 -1
  187. package/components/dialog/parts/DialogAction.js +19 -17
  188. package/components/dialog/parts/DialogAction.js.map +1 -1
  189. package/components/form-label/FormLabel.js +13 -10
  190. package/components/form-label/FormLabel.js.map +1 -1
  191. package/components/number-format/NumberUtils.js +15 -15
  192. package/components/number-format/NumberUtils.js.map +1 -1
  193. package/components/upload/UploadFileListCell.js +2 -1
  194. package/components/upload/UploadFileListCell.js.map +1 -1
  195. package/es/components/date-picker/DatePickerContext.d.ts +1 -1
  196. package/es/components/date-picker/DatePickerContext.js.map +1 -1
  197. package/es/components/date-picker/DatePickerFooter.js +5 -5
  198. package/es/components/date-picker/DatePickerFooter.js.map +1 -1
  199. package/es/components/date-picker/DatePickerProvider.js +2 -2
  200. package/es/components/date-picker/DatePickerProvider.js.map +1 -1
  201. package/es/components/date-picker/hooks/useDates.d.ts +1 -1
  202. package/es/components/date-picker/hooks/useDates.js +87 -17
  203. package/es/components/date-picker/hooks/useDates.js.map +1 -1
  204. package/es/components/dialog/parts/DialogAction.js +19 -17
  205. package/es/components/dialog/parts/DialogAction.js.map +1 -1
  206. package/es/components/form-label/FormLabel.js +13 -10
  207. package/es/components/form-label/FormLabel.js.map +1 -1
  208. package/es/components/number-format/NumberUtils.js +15 -15
  209. package/es/components/number-format/NumberUtils.js.map +1 -1
  210. package/es/components/upload/UploadFileListCell.js +2 -1
  211. package/es/components/upload/UploadFileListCell.js.map +1 -1
  212. package/es/extensions/forms/DataContext/Context.d.ts +8 -5
  213. package/es/extensions/forms/DataContext/Context.js +0 -1
  214. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  215. package/es/extensions/forms/DataContext/Provider/Provider.d.ts +4 -3
  216. package/es/extensions/forms/DataContext/Provider/Provider.js +3 -3
  217. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  218. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  219. package/es/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  220. package/es/extensions/forms/Field/Date/Date.js +2 -2
  221. package/es/extensions/forms/Field/Date/Date.js.map +1 -1
  222. package/es/extensions/forms/Field/Provider/FieldProvider.d.ts +3 -2
  223. package/es/extensions/forms/Field/Provider/FieldProvider.js.map +1 -1
  224. package/es/extensions/forms/Field/Upload/Upload.js +6 -1
  225. package/es/extensions/forms/Field/Upload/Upload.js.map +1 -1
  226. package/es/extensions/forms/Form/Element/Element.d.ts +2 -2
  227. package/es/extensions/forms/Form/Element/Element.js +45 -12
  228. package/es/extensions/forms/Form/Element/Element.js.map +1 -1
  229. package/es/extensions/forms/Form/Handler/Handler.d.ts +7 -3
  230. package/es/extensions/forms/Form/Handler/Handler.js +24 -93
  231. package/es/extensions/forms/Form/Handler/Handler.js.map +1 -1
  232. package/es/extensions/forms/Form/Isolation/Isolation.d.ts +3 -3
  233. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  234. package/es/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js +1 -1
  235. package/es/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js.map +1 -1
  236. package/es/extensions/forms/Form/Section/Section.d.ts +4 -4
  237. package/es/extensions/forms/Form/Section/Section.js +2 -1
  238. package/es/extensions/forms/Form/Section/Section.js.map +1 -1
  239. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js +1 -1
  240. package/es/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js.map +1 -1
  241. package/es/extensions/forms/Form/Section/containers/SectionContainer.d.ts +1 -1
  242. package/es/extensions/forms/Form/Section/containers/SectionContainer.js +1 -0
  243. package/es/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  244. package/es/extensions/forms/Form/Section/style/dnb-form-section.css +10 -6
  245. package/es/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  246. package/es/extensions/forms/Form/Section/style/dnb-form-section.scss +13 -7
  247. package/es/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.css +3 -0
  248. package/es/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.min.css +1 -0
  249. package/es/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.scss +7 -0
  250. package/es/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.css +4 -0
  251. package/es/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.min.css +1 -0
  252. package/es/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.scss +8 -0
  253. package/es/extensions/forms/Form/Section/style/themes/ui.d.ts +1 -0
  254. package/es/extensions/forms/Form/Section/style/themes/ui.js +1 -0
  255. package/es/extensions/forms/Form/Section/style/themes/ui.js.map +1 -0
  256. package/es/extensions/forms/Form/SubmitButton/SubmitButton.js +3 -3
  257. package/es/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  258. package/es/extensions/forms/Form/data-context/clearData.d.ts +2 -1
  259. package/es/extensions/forms/Form/data-context/clearData.js +2 -2
  260. package/es/extensions/forms/Form/data-context/clearData.js.map +1 -1
  261. package/es/extensions/forms/Form/data-context/getData.js +2 -2
  262. package/es/extensions/forms/Form/data-context/getData.js.map +1 -1
  263. package/es/extensions/forms/Form/data-context/useData.js +2 -2
  264. package/es/extensions/forms/Form/data-context/useData.js.map +1 -1
  265. package/es/extensions/forms/Form/data-context/useValidation.js +3 -3
  266. package/es/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  267. package/es/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +3 -2
  268. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js +9 -5
  269. package/es/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  270. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +3 -0
  271. package/es/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -1
  272. package/es/extensions/forms/Iterate/Count/Count.d.ts +4 -3
  273. package/es/extensions/forms/Iterate/Count/Count.js.map +1 -1
  274. package/es/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -1
  275. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js +7 -4
  276. package/es/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  277. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +2 -2
  278. package/es/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  279. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +1 -1
  280. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  281. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.d.ts +3 -1
  282. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js +25 -7
  283. package/es/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  284. package/es/extensions/forms/Iterate/RemoveButton/RemoveButtonDocs.js +5 -0
  285. package/es/extensions/forms/Iterate/RemoveButton/RemoveButtonDocs.js.map +1 -1
  286. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js +8 -4
  287. package/es/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  288. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +2 -1
  289. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js +4 -3
  290. package/es/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -1
  291. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +1 -1
  292. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js +3 -2
  293. package/es/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  294. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +2 -2
  295. package/es/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  296. package/es/extensions/forms/Iterate/hooks/useItem.d.ts +5 -1
  297. package/es/extensions/forms/Iterate/hooks/useItem.js.map +1 -1
  298. package/es/extensions/forms/Tools/ListAllProps.d.ts +7 -7
  299. package/es/extensions/forms/Tools/ListAllProps.js.map +1 -1
  300. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.js +2 -2
  301. package/es/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  302. package/es/extensions/forms/Wizard/Container/WizardContainer.js +2 -2
  303. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  304. package/es/extensions/forms/Wizard/hooks/useStep.d.ts +2 -2
  305. package/es/extensions/forms/Wizard/hooks/useStep.js +2 -2
  306. package/es/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  307. package/es/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +2 -0
  308. package/es/extensions/forms/constants/countries.js +1 -1
  309. package/es/extensions/forms/constants/countries.js.map +1 -1
  310. package/es/extensions/forms/constants/locales/en-GB.d.ts +1 -0
  311. package/es/extensions/forms/constants/locales/en-GB.js +2 -1
  312. package/es/extensions/forms/constants/locales/en-GB.js.map +1 -1
  313. package/es/extensions/forms/constants/locales/en-US.d.ts +1 -0
  314. package/es/extensions/forms/constants/locales/index.d.ts +2 -0
  315. package/es/extensions/forms/constants/locales/nb-NO.d.ts +1 -0
  316. package/es/extensions/forms/constants/locales/nb-NO.js +2 -1
  317. package/es/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  318. package/es/extensions/forms/hooks/useDataContext.js +2 -2
  319. package/es/extensions/forms/hooks/useDataContext.js.map +1 -1
  320. package/es/extensions/forms/hooks/useSnapshot.d.ts +3 -2
  321. package/es/extensions/forms/hooks/useSnapshot.js.map +1 -1
  322. package/es/extensions/forms/style/dnb-forms.css +10 -6
  323. package/es/extensions/forms/style/dnb-forms.min.css +1 -1
  324. package/es/extensions/forms/types.d.ts +4 -4
  325. package/es/extensions/forms/types.js.map +1 -1
  326. package/es/extensions/forms/utils/json-pointer/json-pointer.d.ts +2 -2
  327. package/es/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
  328. package/es/shared/Eufemia.d.ts +1 -1
  329. package/es/shared/Eufemia.js +2 -2
  330. package/es/shared/Eufemia.js.map +1 -1
  331. package/es/shared/helpers/useSharedState.d.ts +19 -13
  332. package/es/shared/helpers/useSharedState.js +22 -11
  333. package/es/shared/helpers/useSharedState.js.map +1 -1
  334. package/es/style/core/scopes.scss +1 -1
  335. package/es/style/dnb-ui-basis.css +1 -1
  336. package/es/style/dnb-ui-basis.min.css +1 -1
  337. package/es/style/dnb-ui-body.css +1 -1
  338. package/es/style/dnb-ui-body.min.css +1 -1
  339. package/es/style/dnb-ui-components.css +10 -6
  340. package/es/style/dnb-ui-components.min.css +1 -1
  341. package/es/style/dnb-ui-core.css +1 -1
  342. package/es/style/dnb-ui-core.min.css +1 -1
  343. package/es/style/dnb-ui-extensions.css +10 -6
  344. package/es/style/dnb-ui-extensions.min.css +1 -1
  345. package/es/style/dnb-ui-forms.css +10 -6
  346. package/es/style/dnb-ui-forms.min.css +1 -1
  347. package/es/style/themes/theme-eiendom/eiendom-theme-components.css +25 -12
  348. package/es/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
  349. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.css +15 -6
  350. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  351. package/es/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  352. package/es/style/themes/theme-eiendom/eiendom-theme-forms.css +15 -6
  353. package/es/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  354. package/es/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  355. package/es/style/themes/theme-sbanken/sbanken-theme-components.css +24 -12
  356. package/es/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  357. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.css +14 -6
  358. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  359. package/es/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  360. package/es/style/themes/theme-sbanken/sbanken-theme-forms.css +14 -6
  361. package/es/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  362. package/es/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  363. package/es/style/themes/theme-ui/ui-theme-components.css +25 -12
  364. package/es/style/themes/theme-ui/ui-theme-components.min.css +2 -2
  365. package/es/style/themes/theme-ui/ui-theme-extensions.css +15 -6
  366. package/es/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  367. package/es/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  368. package/es/style/themes/theme-ui/ui-theme-forms.css +15 -6
  369. package/es/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  370. package/es/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  371. package/esm/dnb-ui-basis.min.mjs +1 -1
  372. package/esm/dnb-ui-components.min.mjs +1 -1
  373. package/esm/dnb-ui-elements.min.mjs +1 -1
  374. package/esm/dnb-ui-extensions.min.mjs +1 -1
  375. package/esm/dnb-ui-lib.min.mjs +1 -1
  376. package/extensions/forms/DataContext/Context.d.ts +8 -5
  377. package/extensions/forms/DataContext/Context.js +0 -1
  378. package/extensions/forms/DataContext/Context.js.map +1 -1
  379. package/extensions/forms/DataContext/Provider/Provider.d.ts +4 -3
  380. package/extensions/forms/DataContext/Provider/Provider.js +3 -3
  381. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  382. package/extensions/forms/DataContext/Provider/ProviderDocs.js +1 -1
  383. package/extensions/forms/DataContext/Provider/ProviderDocs.js.map +1 -1
  384. package/extensions/forms/Field/Date/Date.js +2 -2
  385. package/extensions/forms/Field/Date/Date.js.map +1 -1
  386. package/extensions/forms/Field/Provider/FieldProvider.d.ts +3 -2
  387. package/extensions/forms/Field/Provider/FieldProvider.js.map +1 -1
  388. package/extensions/forms/Field/Upload/Upload.js +11 -3
  389. package/extensions/forms/Field/Upload/Upload.js.map +1 -1
  390. package/extensions/forms/Form/Element/Element.d.ts +2 -2
  391. package/extensions/forms/Form/Element/Element.js +50 -13
  392. package/extensions/forms/Form/Element/Element.js.map +1 -1
  393. package/extensions/forms/Form/Handler/Handler.d.ts +7 -3
  394. package/extensions/forms/Form/Handler/Handler.js +24 -97
  395. package/extensions/forms/Form/Handler/Handler.js.map +1 -1
  396. package/extensions/forms/Form/Isolation/Isolation.d.ts +3 -3
  397. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  398. package/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js +1 -1
  399. package/extensions/forms/Form/Section/EditContainer/EditContainerDocs.js.map +1 -1
  400. package/extensions/forms/Form/Section/Section.d.ts +4 -4
  401. package/extensions/forms/Form/Section/Section.js +2 -1
  402. package/extensions/forms/Form/Section/Section.js.map +1 -1
  403. package/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js +1 -1
  404. package/extensions/forms/Form/Section/ViewContainer/ViewContainerDocs.js.map +1 -1
  405. package/extensions/forms/Form/Section/containers/SectionContainer.d.ts +1 -1
  406. package/extensions/forms/Form/Section/containers/SectionContainer.js +1 -0
  407. package/extensions/forms/Form/Section/containers/SectionContainer.js.map +1 -1
  408. package/extensions/forms/Form/Section/style/dnb-form-section.css +10 -6
  409. package/extensions/forms/Form/Section/style/dnb-form-section.min.css +1 -1
  410. package/extensions/forms/Form/Section/style/dnb-form-section.scss +13 -7
  411. package/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.css +3 -0
  412. package/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.min.css +1 -0
  413. package/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-sbanken.scss +7 -0
  414. package/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.css +4 -0
  415. package/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.min.css +1 -0
  416. package/extensions/forms/Form/Section/style/themes/dnb-form-section-theme-ui.scss +8 -0
  417. package/extensions/forms/Form/Section/style/themes/ui.d.ts +1 -0
  418. package/extensions/forms/Form/Section/style/themes/ui.js +1 -0
  419. package/extensions/forms/Form/Section/style/themes/ui.js.map +1 -0
  420. package/extensions/forms/Form/SubmitButton/SubmitButton.js +3 -3
  421. package/extensions/forms/Form/SubmitButton/SubmitButton.js.map +1 -1
  422. package/extensions/forms/Form/data-context/clearData.d.ts +2 -1
  423. package/extensions/forms/Form/data-context/clearData.js +2 -2
  424. package/extensions/forms/Form/data-context/clearData.js.map +1 -1
  425. package/extensions/forms/Form/data-context/getData.js +2 -2
  426. package/extensions/forms/Form/data-context/getData.js.map +1 -1
  427. package/extensions/forms/Form/data-context/useData.js +2 -2
  428. package/extensions/forms/Form/data-context/useData.js.map +1 -1
  429. package/extensions/forms/Form/data-context/useValidation.js +3 -3
  430. package/extensions/forms/Form/data-context/useValidation.js.map +1 -1
  431. package/extensions/forms/Iterate/Array/ArrayItemArea.d.ts +3 -2
  432. package/extensions/forms/Iterate/Array/ArrayItemArea.js +9 -5
  433. package/extensions/forms/Iterate/Array/ArrayItemArea.js.map +1 -1
  434. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.d.ts +3 -0
  435. package/extensions/forms/Iterate/Array/ArrayItemAreaContext.js.map +1 -1
  436. package/extensions/forms/Iterate/Count/Count.d.ts +4 -3
  437. package/extensions/forms/Iterate/Count/Count.js.map +1 -1
  438. package/extensions/forms/Iterate/EditContainer/EditContainer.d.ts +1 -1
  439. package/extensions/forms/Iterate/EditContainer/EditContainer.js +7 -4
  440. package/extensions/forms/Iterate/EditContainer/EditContainer.js.map +1 -1
  441. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js +2 -2
  442. package/extensions/forms/Iterate/EditContainer/EditContainerDocs.js.map +1 -1
  443. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +1 -1
  444. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  445. package/extensions/forms/Iterate/RemoveButton/RemoveButton.d.ts +3 -1
  446. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js +26 -7
  447. package/extensions/forms/Iterate/RemoveButton/RemoveButton.js.map +1 -1
  448. package/extensions/forms/Iterate/RemoveButton/RemoveButtonDocs.js +5 -0
  449. package/extensions/forms/Iterate/RemoveButton/RemoveButtonDocs.js.map +1 -1
  450. package/extensions/forms/Iterate/Toolbar/Toolbar.js +8 -4
  451. package/extensions/forms/Iterate/Toolbar/Toolbar.js.map +1 -1
  452. package/extensions/forms/Iterate/ViewContainer/RemoveButton.d.ts +2 -1
  453. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js +4 -3
  454. package/extensions/forms/Iterate/ViewContainer/RemoveButton.js.map +1 -1
  455. package/extensions/forms/Iterate/ViewContainer/ViewContainer.d.ts +1 -1
  456. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js +3 -2
  457. package/extensions/forms/Iterate/ViewContainer/ViewContainer.js.map +1 -1
  458. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js +2 -2
  459. package/extensions/forms/Iterate/ViewContainer/ViewContainerDocs.js.map +1 -1
  460. package/extensions/forms/Iterate/hooks/useItem.d.ts +5 -1
  461. package/extensions/forms/Iterate/hooks/useItem.js.map +1 -1
  462. package/extensions/forms/Tools/ListAllProps.d.ts +7 -7
  463. package/extensions/forms/Tools/ListAllProps.js.map +1 -1
  464. package/extensions/forms/Value/PhoneNumber/PhoneNumber.js +2 -2
  465. package/extensions/forms/Value/PhoneNumber/PhoneNumber.js.map +1 -1
  466. package/extensions/forms/Wizard/Container/WizardContainer.js +2 -2
  467. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  468. package/extensions/forms/Wizard/hooks/useStep.d.ts +2 -2
  469. package/extensions/forms/Wizard/hooks/useStep.js +2 -2
  470. package/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  471. package/extensions/forms/Wizard/style/themes/dnb-wizard-layout-theme-ui.scss +2 -0
  472. package/extensions/forms/constants/countries.js +1 -1
  473. package/extensions/forms/constants/countries.js.map +1 -1
  474. package/extensions/forms/constants/locales/en-GB.d.ts +1 -0
  475. package/extensions/forms/constants/locales/en-GB.js +2 -1
  476. package/extensions/forms/constants/locales/en-GB.js.map +1 -1
  477. package/extensions/forms/constants/locales/en-US.d.ts +1 -0
  478. package/extensions/forms/constants/locales/index.d.ts +2 -0
  479. package/extensions/forms/constants/locales/nb-NO.d.ts +1 -0
  480. package/extensions/forms/constants/locales/nb-NO.js +2 -1
  481. package/extensions/forms/constants/locales/nb-NO.js.map +1 -1
  482. package/extensions/forms/hooks/useDataContext.js +2 -2
  483. package/extensions/forms/hooks/useDataContext.js.map +1 -1
  484. package/extensions/forms/hooks/useSnapshot.d.ts +3 -2
  485. package/extensions/forms/hooks/useSnapshot.js.map +1 -1
  486. package/extensions/forms/style/dnb-forms.css +10 -6
  487. package/extensions/forms/style/dnb-forms.min.css +1 -1
  488. package/extensions/forms/types.d.ts +4 -4
  489. package/extensions/forms/types.js.map +1 -1
  490. package/extensions/forms/utils/json-pointer/json-pointer.d.ts +2 -2
  491. package/extensions/forms/utils/json-pointer/json-pointer.js.map +1 -1
  492. package/package.json +1 -1
  493. package/shared/Eufemia.d.ts +1 -1
  494. package/shared/Eufemia.js +2 -2
  495. package/shared/Eufemia.js.map +1 -1
  496. package/shared/helpers/useSharedState.d.ts +19 -13
  497. package/shared/helpers/useSharedState.js +22 -11
  498. package/shared/helpers/useSharedState.js.map +1 -1
  499. package/style/core/scopes.scss +1 -1
  500. package/style/dnb-ui-basis.css +1 -1
  501. package/style/dnb-ui-basis.min.css +1 -1
  502. package/style/dnb-ui-body.css +1 -1
  503. package/style/dnb-ui-body.min.css +1 -1
  504. package/style/dnb-ui-components.css +10 -6
  505. package/style/dnb-ui-components.min.css +1 -1
  506. package/style/dnb-ui-core.css +1 -1
  507. package/style/dnb-ui-core.min.css +1 -1
  508. package/style/dnb-ui-extensions.css +10 -6
  509. package/style/dnb-ui-extensions.min.css +1 -1
  510. package/style/dnb-ui-forms.css +10 -6
  511. package/style/dnb-ui-forms.min.css +1 -1
  512. package/style/themes/theme-eiendom/eiendom-theme-components.css +25 -12
  513. package/style/themes/theme-eiendom/eiendom-theme-components.min.css +2 -2
  514. package/style/themes/theme-eiendom/eiendom-theme-extensions.css +15 -6
  515. package/style/themes/theme-eiendom/eiendom-theme-extensions.min.css +2 -2
  516. package/style/themes/theme-eiendom/eiendom-theme-extensions.scss +1 -0
  517. package/style/themes/theme-eiendom/eiendom-theme-forms.css +15 -6
  518. package/style/themes/theme-eiendom/eiendom-theme-forms.min.css +2 -2
  519. package/style/themes/theme-eiendom/eiendom-theme-forms.scss +1 -0
  520. package/style/themes/theme-sbanken/sbanken-theme-components.css +24 -12
  521. package/style/themes/theme-sbanken/sbanken-theme-components.min.css +2 -2
  522. package/style/themes/theme-sbanken/sbanken-theme-extensions.css +14 -6
  523. package/style/themes/theme-sbanken/sbanken-theme-extensions.min.css +2 -2
  524. package/style/themes/theme-sbanken/sbanken-theme-extensions.scss +1 -0
  525. package/style/themes/theme-sbanken/sbanken-theme-forms.css +14 -6
  526. package/style/themes/theme-sbanken/sbanken-theme-forms.min.css +2 -2
  527. package/style/themes/theme-sbanken/sbanken-theme-forms.scss +1 -0
  528. package/style/themes/theme-ui/ui-theme-components.css +25 -12
  529. package/style/themes/theme-ui/ui-theme-components.min.css +2 -2
  530. package/style/themes/theme-ui/ui-theme-extensions.css +15 -6
  531. package/style/themes/theme-ui/ui-theme-extensions.min.css +2 -2
  532. package/style/themes/theme-ui/ui-theme-extensions.scss +1 -0
  533. package/style/themes/theme-ui/ui-theme-forms.css +15 -6
  534. package/style/themes/theme-ui/ui-theme-forms.min.css +2 -2
  535. package/style/themes/theme-ui/ui-theme-forms.scss +1 -0
  536. package/umd/dnb-ui-basis.min.js +1 -1
  537. package/umd/dnb-ui-components.min.js +1 -1
  538. package/umd/dnb-ui-elements.min.js +1 -1
  539. package/umd/dnb-ui-extensions.min.js +1 -1
  540. package/umd/dnb-ui-lib.min.js +1 -1
@@ -6,7 +6,7 @@ export type SectionContainerProps = {
6
6
  * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.
7
7
  * Defaults to `outline`.
8
8
  */
9
- variant?: 'outline' | 'basic';
9
+ variant?: 'outline' | 'basic' | 'filled';
10
10
  };
11
11
  export type Props = {
12
12
  mode: ContainerMode;
@@ -74,6 +74,7 @@ function SectionContainer(props) {
74
74
  }, React.createElement(Card, _extends({
75
75
  stack: true,
76
76
  innerSpace: variant === 'basic' ? false : 'small',
77
+ filled: variant === 'filled',
77
78
  className: "dnb-forms-section-block__inner"
78
79
  }, restProps, {
79
80
  "aria-label": ariaLabel,
@@ -1 +1 @@
1
- {"version":3,"file":"SectionContainer.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Card","HeightAnimation","SectionContainerContext","FieldBoundaryContext","SectionContainer","props","mode","open","ariaLabel","onAnimationEnd","className","children","variant","omitFocusManagementRef","current","undefined","restProps","_objectWithoutProperties","_excluded","forceUpdate","containerRef","contextRef","hasError","hasSubmitError","containerMode","openRef","setOpenState","setFocus","state","_containerRef$current","_containerRef$current2","focus","call","handleAnimationEnd","createElement","duration","keepInDOM","_extends","stack","innerSpace","innerRef","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainer.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Card, HeightAnimation } from '../../../../../components'\nimport SectionContainerContext, {\n SectionContainerContextState,\n} from './SectionContainerContext'\nimport { Props as FlexContainerProps } from '../../../../../components/flex/Container'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type SectionContainerProps = {\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 omitFocusManagementRef?: React.MutableRefObject<boolean>\n} & SectionContainerProps\n\nfunction SectionContainer(props: Props & FlexContainerProps) {\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n variant = 'outline',\n omitFocusManagementRef = { current: undefined },\n ...restProps\n } = props\n\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const containerRef = useRef<HTMLDivElement>()\n const contextRef = useRef<\n SectionContainerContextState & {\n hasError?: boolean\n hasSubmitError?: boolean\n }\n >()\n contextRef.current = useContext(SectionContainerContext) || {}\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 { containerMode } = contextRef.current\n\n const openRef = useRef(open ?? containerMode === mode)\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\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 setOpenState(containerMode === mode)\n }\n }\n }, [containerMode, mode, open, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (state === 'opened') {\n if (\n !omitFocusManagementRef.current &&\n !contextRef.current.hasSubmitError\n ) {\n containerRef?.current?.focus?.()\n }\n omitFocusManagementRef.current = false\n }\n },\n [omitFocusManagementRef]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n return (\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n omitFocusManagementRef.current &&\n 'dnb-forms-section-block--no-animation',\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 <Card\n stack\n innerSpace={variant === 'basic' ? false : 'small'}\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n aria-label={ariaLabel}\n innerRef={containerRef}\n tabIndex={-1}\n >\n {children}\n </Card>\n </HeightAnimation>\n )\n}\n\nSectionContainer._supportsSpacingProps = true\nexport default SectionContainer\n"],"mappings":"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"}
1
+ {"version":3,"file":"SectionContainer.js","names":["React","useCallback","useContext","useEffect","useReducer","useRef","classnames","Card","HeightAnimation","SectionContainerContext","FieldBoundaryContext","SectionContainer","props","mode","open","ariaLabel","onAnimationEnd","className","children","variant","omitFocusManagementRef","current","undefined","restProps","_objectWithoutProperties","_excluded","forceUpdate","containerRef","contextRef","hasError","hasSubmitError","containerMode","openRef","setOpenState","setFocus","state","_containerRef$current","_containerRef$current2","focus","call","handleAnimationEnd","createElement","duration","keepInDOM","_extends","stack","innerSpace","filled","innerRef","tabIndex","_supportsSpacingProps"],"sources":["../../../../../../../src/extensions/forms/Form/Section/containers/SectionContainer.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useRef,\n} from 'react'\nimport classnames from 'classnames'\nimport { Card, HeightAnimation } from '../../../../../components'\nimport SectionContainerContext, {\n SectionContainerContextState,\n} from './SectionContainerContext'\nimport { Props as FlexContainerProps } from '../../../../../components/flex/Container'\nimport FieldBoundaryContext from '../../../DataContext/FieldBoundary/FieldBoundaryContext'\n\nexport type ContainerMode = 'view' | 'edit' | 'auto'\nexport type SectionContainerProps = {\n /**\n * Defines the variant of the ViewContainer or EditContainer. Can be `outline`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic' | 'filled'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n omitFocusManagementRef?: React.MutableRefObject<boolean>\n} & SectionContainerProps\n\nfunction SectionContainer(props: Props & FlexContainerProps) {\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n variant = 'outline',\n omitFocusManagementRef = { current: undefined },\n ...restProps\n } = props\n\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const containerRef = useRef<HTMLDivElement>()\n const contextRef = useRef<\n SectionContainerContextState & {\n hasError?: boolean\n hasSubmitError?: boolean\n }\n >()\n contextRef.current = useContext(SectionContainerContext) || {}\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 { containerMode } = contextRef.current\n\n const openRef = useRef(open ?? containerMode === mode)\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useEffect(() => {\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 setOpenState(containerMode === mode)\n }\n }\n }, [containerMode, mode, open, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (state === 'opened') {\n if (\n !omitFocusManagementRef.current &&\n !contextRef.current.hasSubmitError\n ) {\n containerRef?.current?.focus?.()\n }\n omitFocusManagementRef.current = false\n }\n },\n [omitFocusManagementRef]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n return (\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n omitFocusManagementRef.current &&\n 'dnb-forms-section-block--no-animation',\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 <Card\n stack\n innerSpace={variant === 'basic' ? false : 'small'}\n filled={variant === 'filled'}\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n aria-label={ariaLabel}\n innerRef={containerRef}\n tabIndex={-1}\n >\n {children}\n </Card>\n </HeightAnimation>\n )\n}\n\nSectionContainer._supportsSpacingProps = true\nexport default SectionContainer\n"],"mappings":"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"}
@@ -8,12 +8,6 @@
8
8
  display: flex;
9
9
  flex-direction: column;
10
10
  }
11
- .dnb-forms-section-block--variant-basic {
12
- --border-color: transparent;
13
- }
14
- .dnb-forms-section-block--variant-basic .dnb-card {
15
- --card-outline-color: transparent;
16
- }
17
11
  .dnb-forms-section-block__inner {
18
12
  flex: 1;
19
13
  outline: none;
@@ -33,6 +27,16 @@
33
27
  .dnb-forms-section-block__inner .dnb-dl .dnb-dd {
34
28
  margin-bottom: 0;
35
29
  }
30
+ .dnb-forms-section-block--variant-basic {
31
+ --border-color: transparent;
32
+ }
33
+ .dnb-forms-section-block--variant-basic .dnb-card, .dnb-card .dnb-forms-section-block--variant-basic .dnb-card {
34
+ --card-outline-color: transparent;
35
+ }
36
+ .dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner {
37
+ --space: var(--spacing-small);
38
+ background-color: var(--color-lavender);
39
+ }
36
40
  .dnb-forms-section-block--no-animation .dnb-forms-section-block__inner {
37
41
  transform: translateY(0);
38
42
  }
@@ -1 +1 @@
1
- .dnb-forms-section-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-section-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-section-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-section-block--variant-basic{--border-color:transparent}.dnb-forms-section-block--variant-basic .dnb-card{--card-outline-color:transparent}.dnb-forms-section-block__inner{flex:1;margin-bottom:var(--space);outline:none;transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-small){--space:var(--spacing-small)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-medium){--space:var(--spacing-medium)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-large){--space:var(--spacing-large)}.dnb-forms-section-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-section-block--no-animation .dnb-forms-section-block__inner{transform:translateY(0)}.dnb-forms-section-block.dnb-height-animation--is-visible .dnb-forms-section-block__inner{transform:translateY(-.5rem)}.dnb-forms-section-block.dnb-height-animation--parallax .dnb-forms-section-block__inner{transform:translateY(0)}
1
+ .dnb-forms-section-block{--block-outline-color:var(--outline-color,var(--color-lavender))}.dnb-forms-section-block--error:has(.dnb-form-status--error){--block-outline-color:var(--color-fire-red)}.dnb-forms-section-block:not(.dnb-height-animation--hidden){display:flex;flex-direction:column}.dnb-forms-section-block__inner{flex:1;margin-bottom:var(--space);outline:none;transform:translateY(-2.5rem);transition:transform .4s var(--easing-default) 50ms,box-shadow .8s var(--easing-default)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-small){--space:var(--spacing-small)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-medium){--space:var(--spacing-medium)}.dnb-forms-section-block__inner:has(.dnb-flex-container--spacing-large){--space:var(--spacing-large)}.dnb-forms-section-block__inner .dnb-dl .dnb-dd{margin-bottom:0}.dnb-forms-section-block--variant-basic{--border-color:transparent}.dnb-card .dnb-forms-section-block--variant-basic .dnb-card,.dnb-forms-section-block--variant-basic .dnb-card{--card-outline-color:transparent}.dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner{--space:var(--spacing-small);background-color:var(--color-lavender)}.dnb-forms-section-block--no-animation .dnb-forms-section-block__inner{transform:translateY(0)}.dnb-forms-section-block.dnb-height-animation--is-visible .dnb-forms-section-block__inner{transform:translateY(-.5rem)}.dnb-forms-section-block.dnb-height-animation--parallax .dnb-forms-section-block__inner{transform:translateY(0)}
@@ -11,13 +11,6 @@
11
11
  flex-direction: column;
12
12
  }
13
13
 
14
- &--variant-basic {
15
- --border-color: transparent;
16
- .dnb-card {
17
- --card-outline-color: transparent;
18
- }
19
- }
20
-
21
14
  &__inner {
22
15
  flex: 1;
23
16
  outline: none; // for JavaSCript focus
@@ -43,6 +36,19 @@
43
36
  }
44
37
  }
45
38
 
39
+ &--variant-basic {
40
+ --border-color: transparent;
41
+ .dnb-card,
42
+ .dnb-card & .dnb-card {
43
+ --card-outline-color: transparent;
44
+ }
45
+ }
46
+
47
+ &--variant-filled &__inner {
48
+ --space: var(--spacing-small);
49
+ background-color: var(--color-lavender);
50
+ }
51
+
46
52
  &--no-animation &__inner {
47
53
  transform: translateY(0);
48
54
  }
@@ -0,0 +1,3 @@
1
+ .dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner {
2
+ --space: var(--spacing-small);
3
+ }
@@ -0,0 +1 @@
1
+ .dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner{--space:var(--spacing-small)}
@@ -0,0 +1,7 @@
1
+ .dnb-forms-section {
2
+ &-block {
3
+ &--variant-filled &__inner {
4
+ --space: var(--spacing-small);
5
+ }
6
+ }
7
+ }
@@ -0,0 +1,4 @@
1
+ .dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner {
2
+ --space: var(--spacing-small);
3
+ background-color: var(--color-lavender);
4
+ }
@@ -0,0 +1 @@
1
+ .dnb-forms-section-block--variant-filled .dnb-forms-section-block__inner{--space:var(--spacing-small);background-color:var(--color-lavender)}
@@ -0,0 +1,8 @@
1
+ .dnb-forms-section {
2
+ &-block {
3
+ &--variant-filled &__inner {
4
+ --space: var(--spacing-small);
5
+ background-color: var(--color-lavender);
6
+ }
7
+ }
8
+ }
@@ -0,0 +1 @@
1
+ import "./dnb-form-section-theme-ui.min.css";
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui.js","names":[],"sources":["../../../../../../../../src/extensions/forms/Form/Section/style/themes/ui.js"],"sourcesContent":["/**\n * Imports the default theme\n *\n */\n\nimport './dnb-form-section-theme-ui.scss'\n"],"mappings":"AAKA,OAAO,qCAAkC"}
@@ -24,17 +24,17 @@ function SubmitButton(props) {
24
24
  const {
25
25
  formState,
26
26
  handleSubmit,
27
- isInsideFormElement,
27
+ hasElementRef,
28
28
  props: dataContextProps
29
29
  } = useContext(DataContext) || {};
30
30
  const {
31
31
  isolate
32
32
  } = dataContextProps || {};
33
33
  const onClickHandler = useCallback(() => {
34
- if (!isInsideFormElement) {
34
+ if (!(hasElementRef !== null && hasElementRef !== void 0 && hasElementRef.current)) {
35
35
  handleSubmit === null || handleSubmit === void 0 ? void 0 : handleSubmit();
36
36
  }
37
- }, [isInsideFormElement, handleSubmit]);
37
+ }, [hasElementRef, handleSubmit]);
38
38
  return React.createElement(Button, _extends({
39
39
  className: classnames('dnb-forms-submit-button', className),
40
40
  onClick: onClickHandler,
@@ -1 +1 @@
1
- {"version":3,"file":"SubmitButton.js","names":["React","useCallback","useContext","classnames","DataContext","Button","SubmitIndicator","useTranslation","send","SubmitButton","props","translations","variant","className","showIndicator","children","text","rest","_objectWithoutProperties","_excluded","content","sendText","formState","handleSubmit","isInsideFormElement","dataContextProps","isolate","onClickHandler","createElement","_extends","onClick","type","icon","state","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/SubmitButton/SubmitButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport type { ComponentProps } from '../../types'\nimport DataContext from '../../DataContext/Context'\nimport Button, { ButtonProps } from '../../../../components/button/Button'\nimport SubmitIndicator from '../SubmitIndicator'\nimport useTranslation from '../../hooks/useTranslation'\nimport { send } from '../../../../icons'\n\nexport type Props = {\n /**\n * Show the submit indicator\n */\n showIndicator?: boolean\n} & ComponentProps &\n Omit<ButtonProps, 'variant'> &\n Partial<React.HTMLAttributes<HTMLButtonElement | HTMLAnchorElement>> & {\n variant?: 'send'\n }\n\nfunction SubmitButton(props: Props) {\n const translations = useTranslation().SubmitButton\n\n const { variant, className, showIndicator, children, text, ...rest } =\n props\n\n const content =\n text ||\n children ||\n (variant === 'send' ? translations.sendText : translations.text)\n\n const {\n formState,\n handleSubmit,\n isInsideFormElement,\n props: dataContextProps,\n } = useContext(DataContext) || {}\n const { isolate } = dataContextProps || {}\n\n const onClickHandler = useCallback(() => {\n if (!isInsideFormElement) {\n handleSubmit?.()\n }\n }, [isInsideFormElement, handleSubmit])\n\n return (\n <Button\n className={classnames('dnb-forms-submit-button', className)}\n onClick={onClickHandler}\n type={isolate ? 'button' : 'submit'}\n icon={variant === 'send' ? send : null}\n {...rest}\n >\n {content}\n\n <SubmitIndicator state={showIndicator ? 'pending' : formState} />\n </Button>\n )\n}\n\nSubmitButton._supportsSpacingProps = true\nexport default SubmitButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AAEnC,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,MAAM,MAAuB,sCAAsC;AAC1E,OAAOC,eAAe,MAAM,oBAAoB;AAChD,OAAOC,cAAc,MAAM,4BAA4B;AACvD,SAASC,IAAI,QAAQ,mBAAmB;AAaxC,SAASC,YAAYA,CAACC,KAAY,EAAE;EAClC,MAAMC,YAAY,GAAGJ,cAAc,CAAC,CAAC,CAACE,YAAY;EAElD,MAAM;MAAEG,OAAO;MAAEC,SAAS;MAAEC,aAAa;MAAEC,QAAQ;MAAEC;IAAc,CAAC,GAClEN,KAAK;IADuDO,IAAI,GAAAC,wBAAA,CAChER,KAAK,EAAAS,SAAA;EAEP,MAAMC,OAAO,GACXJ,IAAI,IACJD,QAAQ,KACPH,OAAO,KAAK,MAAM,GAAGD,YAAY,CAACU,QAAQ,GAAGV,YAAY,CAACK,IAAI,CAAC;EAElE,MAAM;IACJM,SAAS;IACTC,YAAY;IACZC,mBAAmB;IACnBd,KAAK,EAAEe;EACT,CAAC,GAAGvB,UAAU,CAACE,WAAW,CAAC,IAAI,CAAC,CAAC;EACjC,MAAM;IAAEsB;EAAQ,CAAC,GAAGD,gBAAgB,IAAI,CAAC,CAAC;EAE1C,MAAME,cAAc,GAAG1B,WAAW,CAAC,MAAM;IACvC,IAAI,CAACuB,mBAAmB,EAAE;MACxBD,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAG,CAAC;IAClB;EACF,CAAC,EAAE,CAACC,mBAAmB,EAAED,YAAY,CAAC,CAAC;EAEvC,OACEvB,KAAA,CAAA4B,aAAA,CAACvB,MAAM,EAAAwB,QAAA;IACLhB,SAAS,EAAEV,UAAU,CAAC,yBAAyB,EAAEU,SAAS,CAAE;IAC5DiB,OAAO,EAAEH,cAAe;IACxBI,IAAI,EAAEL,OAAO,GAAG,QAAQ,GAAG,QAAS;IACpCM,IAAI,EAAEpB,OAAO,KAAK,MAAM,GAAGJ,IAAI,GAAG;EAAK,GACnCS,IAAI,GAEPG,OAAO,EAERpB,KAAA,CAAA4B,aAAA,CAACtB,eAAe;IAAC2B,KAAK,EAAEnB,aAAa,GAAG,SAAS,GAAGQ;EAAU,CAAE,CAC1D,CAAC;AAEb;AAEAb,YAAY,CAACyB,qBAAqB,GAAG,IAAI;AACzC,eAAezB,YAAY"}
1
+ {"version":3,"file":"SubmitButton.js","names":["React","useCallback","useContext","classnames","DataContext","Button","SubmitIndicator","useTranslation","send","SubmitButton","props","translations","variant","className","showIndicator","children","text","rest","_objectWithoutProperties","_excluded","content","sendText","formState","handleSubmit","hasElementRef","dataContextProps","isolate","onClickHandler","current","createElement","_extends","onClick","type","icon","state","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/SubmitButton/SubmitButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport type { ComponentProps } from '../../types'\nimport DataContext from '../../DataContext/Context'\nimport Button, { ButtonProps } from '../../../../components/button/Button'\nimport SubmitIndicator from '../SubmitIndicator'\nimport useTranslation from '../../hooks/useTranslation'\nimport { send } from '../../../../icons'\n\nexport type Props = {\n /**\n * Show the submit indicator\n */\n showIndicator?: boolean\n} & ComponentProps &\n Omit<ButtonProps, 'variant'> &\n Partial<React.HTMLAttributes<HTMLButtonElement | HTMLAnchorElement>> & {\n variant?: 'send'\n }\n\nfunction SubmitButton(props: Props) {\n const translations = useTranslation().SubmitButton\n\n const { variant, className, showIndicator, children, text, ...rest } =\n props\n\n const content =\n text ||\n children ||\n (variant === 'send' ? translations.sendText : translations.text)\n\n const {\n formState,\n handleSubmit,\n hasElementRef,\n props: dataContextProps,\n } = useContext(DataContext) || {}\n const { isolate } = dataContextProps || {}\n\n const onClickHandler = useCallback(() => {\n if (!hasElementRef?.current) {\n handleSubmit?.()\n }\n }, [hasElementRef, handleSubmit])\n\n return (\n <Button\n className={classnames('dnb-forms-submit-button', className)}\n onClick={onClickHandler}\n type={isolate ? 'button' : 'submit'}\n icon={variant === 'send' ? send : null}\n {...rest}\n >\n {content}\n\n <SubmitIndicator state={showIndicator ? 'pending' : formState} />\n </Button>\n )\n}\n\nSubmitButton._supportsSpacingProps = true\nexport default SubmitButton\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,QAAQ,OAAO;AACtD,OAAOC,UAAU,MAAM,YAAY;AAEnC,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,MAAM,MAAuB,sCAAsC;AAC1E,OAAOC,eAAe,MAAM,oBAAoB;AAChD,OAAOC,cAAc,MAAM,4BAA4B;AACvD,SAASC,IAAI,QAAQ,mBAAmB;AAaxC,SAASC,YAAYA,CAACC,KAAY,EAAE;EAClC,MAAMC,YAAY,GAAGJ,cAAc,CAAC,CAAC,CAACE,YAAY;EAElD,MAAM;MAAEG,OAAO;MAAEC,SAAS;MAAEC,aAAa;MAAEC,QAAQ;MAAEC;IAAc,CAAC,GAClEN,KAAK;IADuDO,IAAI,GAAAC,wBAAA,CAChER,KAAK,EAAAS,SAAA;EAEP,MAAMC,OAAO,GACXJ,IAAI,IACJD,QAAQ,KACPH,OAAO,KAAK,MAAM,GAAGD,YAAY,CAACU,QAAQ,GAAGV,YAAY,CAACK,IAAI,CAAC;EAElE,MAAM;IACJM,SAAS;IACTC,YAAY;IACZC,aAAa;IACbd,KAAK,EAAEe;EACT,CAAC,GAAGvB,UAAU,CAACE,WAAW,CAAC,IAAI,CAAC,CAAC;EACjC,MAAM;IAAEsB;EAAQ,CAAC,GAAGD,gBAAgB,IAAI,CAAC,CAAC;EAE1C,MAAME,cAAc,GAAG1B,WAAW,CAAC,MAAM;IACvC,IAAI,EAACuB,aAAa,aAAbA,aAAa,eAAbA,aAAa,CAAEI,OAAO,GAAE;MAC3BL,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAG,CAAC;IAClB;EACF,CAAC,EAAE,CAACC,aAAa,EAAED,YAAY,CAAC,CAAC;EAEjC,OACEvB,KAAA,CAAA6B,aAAA,CAACxB,MAAM,EAAAyB,QAAA;IACLjB,SAAS,EAAEV,UAAU,CAAC,yBAAyB,EAAEU,SAAS,CAAE;IAC5DkB,OAAO,EAAEJ,cAAe;IACxBK,IAAI,EAAEN,OAAO,GAAG,QAAQ,GAAG,QAAS;IACpCO,IAAI,EAAErB,OAAO,KAAK,MAAM,GAAGJ,IAAI,GAAG;EAAK,GACnCS,IAAI,GAEPG,OAAO,EAERpB,KAAA,CAAA6B,aAAA,CAACvB,eAAe;IAAC4B,KAAK,EAAEpB,aAAa,GAAG,SAAS,GAAGQ;EAAU,CAAE,CAC1D,CAAC;AAEb;AAEAb,YAAY,CAAC0B,qBAAqB,GAAG,IAAI;AACzC,eAAe1B,YAAY"}
@@ -1 +1,2 @@
1
- export default function clearData(id: string): void;
1
+ import { SharedStateId } from '../../../../shared/helpers/useSharedState';
2
+ export default function clearData(id: SharedStateId): void;
@@ -1,7 +1,7 @@
1
- import { createSharedState } from '../../../../shared/helpers/useSharedState';
1
+ import { createReferenceKey, createSharedState } from '../../../../shared/helpers/useSharedState';
2
2
  export default function clearData(id) {
3
3
  var _sharedAttachments$da, _sharedAttachments$da2;
4
- const sharedAttachments = createSharedState(id + '-attachments');
4
+ const sharedAttachments = createSharedState(createReferenceKey(id, 'attachments'));
5
5
  (_sharedAttachments$da = (_sharedAttachments$da2 = sharedAttachments.data).clearData) === null || _sharedAttachments$da === void 0 ? void 0 : _sharedAttachments$da.call(_sharedAttachments$da2);
6
6
  }
7
7
  //# sourceMappingURL=clearData.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"clearData.js","names":["createSharedState","clearData","id","_sharedAttachments$da","_sharedAttachments$da2","sharedAttachments","data","call"],"sources":["../../../../../../src/extensions/forms/Form/data-context/clearData.ts"],"sourcesContent":["import { createSharedState } from '../../../../shared/helpers/useSharedState'\nimport { SharedAttachments } from '../../DataContext/Provider'\n\nexport default function clearData(id: string) {\n const sharedAttachments = createSharedState<SharedAttachments<unknown>>(\n id + '-attachments'\n )\n sharedAttachments.data.clearData?.()\n}\n"],"mappings":"AAAA,SAASA,iBAAiB,QAAQ,2CAA2C;AAG7E,eAAe,SAASC,SAASA,CAACC,EAAU,EAAE;EAAA,IAAAC,qBAAA,EAAAC,sBAAA;EAC5C,MAAMC,iBAAiB,GAAGL,iBAAiB,CACzCE,EAAE,GAAG,cACP,CAAC;EACD,CAAAC,qBAAA,IAAAC,sBAAA,GAAAC,iBAAiB,CAACC,IAAI,EAACL,SAAS,cAAAE,qBAAA,uBAAhCA,qBAAA,CAAAI,IAAA,CAAAH,sBAAmC,CAAC;AACtC"}
1
+ {"version":3,"file":"clearData.js","names":["createReferenceKey","createSharedState","clearData","id","_sharedAttachments$da","_sharedAttachments$da2","sharedAttachments","data","call"],"sources":["../../../../../../src/extensions/forms/Form/data-context/clearData.ts"],"sourcesContent":["import {\n SharedStateId,\n createReferenceKey,\n createSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport { SharedAttachments } from '../../DataContext/Provider'\n\nexport default function clearData(id: SharedStateId) {\n const sharedAttachments = createSharedState<SharedAttachments<unknown>>(\n createReferenceKey(id, 'attachments')\n )\n sharedAttachments.data.clearData?.()\n}\n"],"mappings":"AAAA,SAEEA,kBAAkB,EAClBC,iBAAiB,QACZ,2CAA2C;AAGlD,eAAe,SAASC,SAASA,CAACC,EAAiB,EAAE;EAAA,IAAAC,qBAAA,EAAAC,sBAAA;EACnD,MAAMC,iBAAiB,GAAGL,iBAAiB,CACzCD,kBAAkB,CAACG,EAAE,EAAE,aAAa,CACtC,CAAC;EACD,CAAAC,qBAAA,IAAAC,sBAAA,GAAAC,iBAAiB,CAACC,IAAI,EAACL,SAAS,cAAAE,qBAAA,uBAAhCA,qBAAA,CAAAI,IAAA,CAAAH,sBAAmC,CAAC;AACtC"}
@@ -1,8 +1,8 @@
1
1
  import pointer from '../../utils/json-pointer';
2
- import { createSharedState } from '../../../../shared/helpers/useSharedState';
2
+ import { createReferenceKey, createSharedState } from '../../../../shared/helpers/useSharedState';
3
3
  export default function getData(id) {
4
4
  const sharedState = createSharedState(id);
5
- const sharedAttachments = createSharedState(id + '-attachments');
5
+ const sharedAttachments = createSharedState(createReferenceKey(id, 'attachments'));
6
6
  const data = sharedState.get();
7
7
  const filterData = filter => {
8
8
  var _sharedAttachments$da, _sharedAttachments$da2;
@@ -1 +1 @@
1
- {"version":3,"file":"getData.js","names":["pointer","createSharedState","getData","id","sharedState","sharedAttachments","data","get","filterData","filter","_sharedAttachments$da","_sharedAttachments$da2","filterDataHandler","call","reduceToVisibleFields","options","_sharedAttachments$da3","_sharedAttachments$da4","visibleDataHandler","getValue","path","has","undefined"],"sources":["../../../../../../src/extensions/forms/Form/data-context/getData.tsx"],"sourcesContent":["import pointer from '../../utils/json-pointer'\nimport {\n SharedStateId,\n createSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport { SharedAttachments } from '../../DataContext/Provider'\nimport type { Path } from '../../types'\nimport type {\n UseDataReturnGetValue,\n UseDataReturnFilterData,\n UseDataReturnVisibleData,\n} from './useData'\n\ntype SetDataReturn<Data> = {\n data: Data\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n reduceToVisibleFields: UseDataReturnVisibleData<Data>\n}\n\nexport default function getData<Data>(\n id: SharedStateId\n): SetDataReturn<Data> {\n const sharedState = createSharedState(id)\n const sharedAttachments = createSharedState<SharedAttachments<Data>>(\n id + '-attachments'\n )\n\n const data = sharedState.get() as Data\n\n const filterData: SetDataReturn<Data>['filterData'] = (filter) =>\n sharedAttachments.data?.filterDataHandler?.(data, filter)\n\n const reduceToVisibleFields: SetDataReturn<Data>['reduceToVisibleFields'] =\n (data, options) =>\n sharedAttachments.data?.visibleDataHandler?.(data, options)\n\n const getValue = (path: Path) => {\n if (pointer.has(data, path)) {\n return pointer.get(data, path)\n }\n\n return undefined\n }\n\n return {\n data,\n getValue,\n filterData,\n reduceToVisibleFields,\n }\n}\n"],"mappings":"AAAA,OAAOA,OAAO,MAAM,0BAA0B;AAC9C,SAEEC,iBAAiB,QACZ,2CAA2C;AAgBlD,eAAe,SAASC,OAAOA,CAC7BC,EAAiB,EACI;EACrB,MAAMC,WAAW,GAAGH,iBAAiB,CAACE,EAAE,CAAC;EACzC,MAAME,iBAAiB,GAAGJ,iBAAiB,CACzCE,EAAE,GAAG,cACP,CAAC;EAED,MAAMG,IAAI,GAAGF,WAAW,CAACG,GAAG,CAAC,CAAS;EAEtC,MAAMC,UAA6C,GAAIC,MAAM;IAAA,IAAAC,qBAAA,EAAAC,sBAAA;IAAA,QAAAD,qBAAA,GAC3DL,iBAAiB,CAACC,IAAI,cAAAI,qBAAA,wBAAAC,sBAAA,GAAtBD,qBAAA,CAAwBE,iBAAiB,cAAAD,sBAAA,uBAAzCA,sBAAA,CAAAE,IAAA,CAAAH,qBAAA,EAA4CJ,IAAI,EAAEG,MAAM,CAAC;EAAA;EAE3D,MAAMK,qBAAmE,GACvEA,CAACR,IAAI,EAAES,OAAO;IAAA,IAAAC,sBAAA,EAAAC,sBAAA;IAAA,QAAAD,sBAAA,GACZX,iBAAiB,CAACC,IAAI,cAAAU,sBAAA,wBAAAC,sBAAA,GAAtBD,sBAAA,CAAwBE,kBAAkB,cAAAD,sBAAA,uBAA1CA,sBAAA,CAAAJ,IAAA,CAAAG,sBAAA,EAA6CV,IAAI,EAAES,OAAO,CAAC;EAAA;EAE/D,MAAMI,QAAQ,GAAIC,IAAU,IAAK;IAC/B,IAAIpB,OAAO,CAACqB,GAAG,CAACf,IAAI,EAAEc,IAAI,CAAC,EAAE;MAC3B,OAAOpB,OAAO,CAACO,GAAG,CAACD,IAAI,EAAEc,IAAI,CAAC;IAChC;IAEA,OAAOE,SAAS;EAClB,CAAC;EAED,OAAO;IACLhB,IAAI;IACJa,QAAQ;IACRX,UAAU;IACVM;EACF,CAAC;AACH"}
1
+ {"version":3,"file":"getData.js","names":["pointer","createReferenceKey","createSharedState","getData","id","sharedState","sharedAttachments","data","get","filterData","filter","_sharedAttachments$da","_sharedAttachments$da2","filterDataHandler","call","reduceToVisibleFields","options","_sharedAttachments$da3","_sharedAttachments$da4","visibleDataHandler","getValue","path","has","undefined"],"sources":["../../../../../../src/extensions/forms/Form/data-context/getData.tsx"],"sourcesContent":["import pointer from '../../utils/json-pointer'\nimport {\n SharedStateId,\n createReferenceKey,\n createSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport { SharedAttachments } from '../../DataContext/Provider'\nimport type { Path } from '../../types'\nimport type {\n UseDataReturnGetValue,\n UseDataReturnFilterData,\n UseDataReturnVisibleData,\n} from './useData'\n\ntype SetDataReturn<Data> = {\n data: Data\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n reduceToVisibleFields: UseDataReturnVisibleData<Data>\n}\n\nexport default function getData<Data>(\n id: SharedStateId\n): SetDataReturn<Data> {\n const sharedState = createSharedState(id)\n const sharedAttachments = createSharedState<SharedAttachments<Data>>(\n createReferenceKey(id, 'attachments')\n )\n\n const data = sharedState.get() as Data\n\n const filterData: SetDataReturn<Data>['filterData'] = (filter) =>\n sharedAttachments.data?.filterDataHandler?.(data, filter)\n\n const reduceToVisibleFields: SetDataReturn<Data>['reduceToVisibleFields'] =\n (data, options) =>\n sharedAttachments.data?.visibleDataHandler?.(data, options)\n\n const getValue = (path: Path) => {\n if (pointer.has(data, path)) {\n return pointer.get(data, path)\n }\n\n return undefined\n }\n\n return {\n data,\n getValue,\n filterData,\n reduceToVisibleFields,\n }\n}\n"],"mappings":"AAAA,OAAOA,OAAO,MAAM,0BAA0B;AAC9C,SAEEC,kBAAkB,EAClBC,iBAAiB,QACZ,2CAA2C;AAgBlD,eAAe,SAASC,OAAOA,CAC7BC,EAAiB,EACI;EACrB,MAAMC,WAAW,GAAGH,iBAAiB,CAACE,EAAE,CAAC;EACzC,MAAME,iBAAiB,GAAGJ,iBAAiB,CACzCD,kBAAkB,CAACG,EAAE,EAAE,aAAa,CACtC,CAAC;EAED,MAAMG,IAAI,GAAGF,WAAW,CAACG,GAAG,CAAC,CAAS;EAEtC,MAAMC,UAA6C,GAAIC,MAAM;IAAA,IAAAC,qBAAA,EAAAC,sBAAA;IAAA,QAAAD,qBAAA,GAC3DL,iBAAiB,CAACC,IAAI,cAAAI,qBAAA,wBAAAC,sBAAA,GAAtBD,qBAAA,CAAwBE,iBAAiB,cAAAD,sBAAA,uBAAzCA,sBAAA,CAAAE,IAAA,CAAAH,qBAAA,EAA4CJ,IAAI,EAAEG,MAAM,CAAC;EAAA;EAE3D,MAAMK,qBAAmE,GACvEA,CAACR,IAAI,EAAES,OAAO;IAAA,IAAAC,sBAAA,EAAAC,sBAAA;IAAA,QAAAD,sBAAA,GACZX,iBAAiB,CAACC,IAAI,cAAAU,sBAAA,wBAAAC,sBAAA,GAAtBD,sBAAA,CAAwBE,kBAAkB,cAAAD,sBAAA,uBAA1CA,sBAAA,CAAAJ,IAAA,CAAAG,sBAAA,EAA6CV,IAAI,EAAES,OAAO,CAAC;EAAA;EAE/D,MAAMI,QAAQ,GAAIC,IAAU,IAAK;IAC/B,IAAIrB,OAAO,CAACsB,GAAG,CAACf,IAAI,EAAEc,IAAI,CAAC,EAAE;MAC3B,OAAOrB,OAAO,CAACQ,GAAG,CAACD,IAAI,EAAEc,IAAI,CAAC;IAChC;IAEA,OAAOE,SAAS;EAClB,CAAC;EAED,OAAO;IACLhB,IAAI;IACJa,QAAQ;IACRX,UAAU;IACVM;EACF,CAAC;AACH"}
@@ -2,7 +2,7 @@
2
2
 
3
3
  import { useCallback, useContext, useMemo, useReducer, useRef } from 'react';
4
4
  import pointer from '../../utils/json-pointer';
5
- import { useSharedState } from '../../../../shared/helpers/useSharedState';
5
+ import { createReferenceKey, useSharedState } from '../../../../shared/helpers/useSharedState';
6
6
  import useMountEffect from '../../../../shared/helpers/useMountEffect';
7
7
  import DataContext from '../../DataContext/Context';
8
8
  import structuredClone from '@ungap/structured-clone';
@@ -11,7 +11,7 @@ export default function useData(id = undefined, initialData = undefined) {
11
11
  const sharedAttachmentsRef = useRef(null);
12
12
  const [, forceUpdate] = useReducer(() => ({}), {});
13
13
  sharedDataRef.current = useSharedState(id, initialData, forceUpdate);
14
- sharedAttachmentsRef.current = useSharedState(id + '-attachments', {
14
+ sharedAttachmentsRef.current = useSharedState(createReferenceKey(id, 'attachments'), {
15
15
  rerenderUseDataHook: forceUpdate
16
16
  });
17
17
  const dataContext = useContext(DataContext);
@@ -1 +1 @@
1
- {"version":3,"file":"useData.js","names":["useCallback","useContext","useMemo","useReducer","useRef","pointer","useSharedState","useMountEffect","DataContext","structuredClone","useData","id","undefined","initialData","sharedDataRef","sharedAttachmentsRef","forceUpdate","current","rerenderUseDataHook","dataContext","hasContext","Error","data","filterDataHandler","updateDataValue","setData","set","newData","update","path","value","existingData","existingValue","has","get","newValue","extend","remove","reduceToVisibleFields","options","_dataContext$visibleD","_sharedAttachmentsRef","_sharedAttachmentsRef2","visibleDataHandler","call","filterData","filter","_dataContext$filterDa","_sharedAttachmentsRef3","_sharedAttachmentsRef4","getValue","hadInitialData"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useData.tsx"],"sourcesContent":["import {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer, { JsonObject } from '../../utils/json-pointer'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport type { Path } from '../../types'\nimport DataContext, {\n FilterData,\n VisibleDataHandler,\n} from '../../DataContext/Context'\nimport { SharedAttachments } from '../../DataContext/Provider'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So it's a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\ntype PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}`\n ? Key extends keyof T\n ? Rest extends ''\n ? T[Key]\n : PathImpl<T[Key], Rest>\n : never\n : T[P & keyof T]\n\ntype PathType<T, P extends string> = P extends `/${infer Rest}`\n ? PathImpl<T, Rest>\n : never\n\ntype UseDataReturnUpdate<Data> = <P extends Path>(\n path: P,\n value: ((value: PathType<Data, P>) => unknown) | unknown\n) => void\n\nexport type UseDataReturnGetValue<Data> = <P extends Path>(\n path: P\n) => PathType<Data, P> | any\n\nexport type UseDataReturnFilterData<Data> = (\n filterDataHandler: FilterData,\n data?: Data\n) => Partial<Data>\n\nexport type UseDataReturnVisibleData<Data> = VisibleDataHandler<Data>\n\ntype UseDataReturn<Data> = {\n data: Data\n set: (newData: Data) => void\n update: UseDataReturnUpdate<Data>\n remove: (path: Path) => void\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n reduceToVisibleFields: UseDataReturnVisibleData<Data>\n}\n\n/**\n * Custom hook that provides form data management functionality.\n *\n * @template Data - The type of data being managed.\n * @param {SharedStateId} id - The identifier for the data.\n * @param {Data} initialData - The initial data value (optional).\n * @returns {UseDataReturn<Data>} An object containing the data and data management functions.\n */\nexport default function useData<Data = JsonObject>(\n id: SharedStateId = undefined,\n initialData: Data = undefined\n): UseDataReturn<Data> {\n const sharedDataRef =\n useRef<ReturnType<typeof useSharedState<Data>>>(null)\n const sharedAttachmentsRef =\n useRef<ReturnType<typeof useSharedState<SharedAttachments<Data>>>>(\n null\n )\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n sharedDataRef.current = useSharedState<Data>(\n id,\n initialData,\n forceUpdate\n )\n\n sharedAttachmentsRef.current = useSharedState<SharedAttachments<Data>>(\n id + '-attachments',\n { rerenderUseDataHook: forceUpdate }\n )\n\n // If no id is provided, use the context data\n const dataContext = useContext(DataContext)\n if (!id) {\n if (!dataContext.hasContext) {\n throw new Error(\n 'useData needs to run inside DataContext (Form.Handler) or have a valid id'\n )\n }\n\n sharedDataRef.current.data = dataContext.data\n sharedAttachmentsRef.current.data.filterDataHandler =\n dataContext.filterDataHandler\n }\n\n const updateDataValue = dataContext?.updateDataValue\n const setData = dataContext?.setData\n\n const set = useCallback(\n (newData: Data) => {\n if (id) {\n sharedDataRef.current.update(newData)\n } else {\n setData?.(newData)\n }\n },\n [id, setData]\n )\n\n const update = useCallback<UseDataReturnUpdate<Data>>(\n (path, value = undefined) => {\n const existingData = structuredClone(\n sharedDataRef.current.data || {}\n ) as Data & JsonObject\n const existingValue = pointer.has(existingData, path)\n ? pointer.get(existingData, path)\n : undefined\n\n // Get new value\n const newValue =\n typeof value === 'function' ? value(existingValue) : value\n\n if (newValue !== existingValue) {\n // Update existing data\n pointer.set(existingData, path, newValue)\n\n // Update provider with new data\n if (id) {\n sharedDataRef.current.extend(existingData)\n } else {\n updateDataValue(path, newValue)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const remove = useCallback<UseDataReturn<Data>['remove']>(\n (path) => {\n const existingData = structuredClone(\n sharedDataRef.current.data || {}\n ) as Data & JsonObject\n\n if (pointer.has(existingData, path)) {\n // Remove existing data\n pointer.remove(existingData, path)\n\n // Update provider with new data\n if (id) {\n sharedDataRef.current.set(existingData)\n } else {\n updateDataValue(path, undefined)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const reduceToVisibleFields = useCallback<\n UseDataReturn<Data>['reduceToVisibleFields']\n >(\n (data, options = {}) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.visibleDataHandler?.(\n data,\n options\n )\n }\n\n return dataContext?.visibleDataHandler?.(data, options)\n },\n [dataContext, id]\n )\n\n const filterData = useCallback<UseDataReturn<Data>['filterData']>(\n (filter, data = sharedDataRef.current.data) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.filterDataHandler?.(\n data,\n filter\n )\n }\n\n return dataContext?.filterDataHandler?.(data, filter)\n },\n [dataContext, id]\n )\n\n const getValue = useCallback<UseDataReturn<Data>['getValue']>((path) => {\n if (pointer.has(sharedDataRef.current.data, path)) {\n return pointer.get(sharedDataRef.current.data, path)\n }\n\n return undefined\n }, [])\n\n useMountEffect(() => {\n if (id && !sharedDataRef.current.hadInitialData && initialData) {\n sharedDataRef.current.extend(initialData)\n }\n })\n\n const { data } = sharedDataRef.current\n\n return useMemo(\n () => ({\n data,\n remove,\n update,\n set,\n getValue,\n reduceToVisibleFields,\n filterData,\n }),\n [\n data,\n remove,\n update,\n set,\n getValue,\n reduceToVisibleFields,\n filterData,\n ]\n )\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"useData.js","names":["useCallback","useContext","useMemo","useReducer","useRef","pointer","createReferenceKey","useSharedState","useMountEffect","DataContext","structuredClone","useData","id","undefined","initialData","sharedDataRef","sharedAttachmentsRef","forceUpdate","current","rerenderUseDataHook","dataContext","hasContext","Error","data","filterDataHandler","updateDataValue","setData","set","newData","update","path","value","existingData","existingValue","has","get","newValue","extend","remove","reduceToVisibleFields","options","_dataContext$visibleD","_sharedAttachmentsRef","_sharedAttachmentsRef2","visibleDataHandler","call","filterData","filter","_dataContext$filterDa","_sharedAttachmentsRef3","_sharedAttachmentsRef4","getValue","hadInitialData"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useData.tsx"],"sourcesContent":["import {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport pointer, { JsonObject } from '../../utils/json-pointer'\nimport {\n SharedStateId,\n createReferenceKey,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport useMountEffect from '../../../../shared/helpers/useMountEffect'\nimport type { Path } from '../../types'\nimport DataContext, {\n FilterData,\n VisibleDataHandler,\n} from '../../DataContext/Context'\nimport { SharedAttachments } from '../../DataContext/Provider'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So it's a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\ntype PathImpl<T, P extends string> = P extends `${infer Key}/${infer Rest}`\n ? Key extends keyof T\n ? Rest extends ''\n ? T[Key]\n : PathImpl<T[Key], Rest>\n : never\n : T[P & keyof T]\n\ntype PathType<T, P extends string> = P extends `/${infer Rest}`\n ? PathImpl<T, Rest>\n : never\n\ntype UseDataReturnUpdate<Data> = <P extends Path>(\n path: P,\n value: ((value: PathType<Data, P>) => unknown) | unknown\n) => void\n\nexport type UseDataReturnGetValue<Data> = <P extends Path>(\n path: P\n) => PathType<Data, P> | any\n\nexport type UseDataReturnFilterData<Data> = (\n filterDataHandler: FilterData,\n data?: Data\n) => Partial<Data>\n\nexport type UseDataReturnVisibleData<Data> = VisibleDataHandler<Data>\n\ntype UseDataReturn<Data> = {\n data: Data\n set: (newData: Data) => void\n update: UseDataReturnUpdate<Data>\n remove: (path: Path) => void\n getValue: UseDataReturnGetValue<Data>\n filterData: UseDataReturnFilterData<Data>\n reduceToVisibleFields: UseDataReturnVisibleData<Data>\n}\n\n/**\n * Custom hook that provides form data management functionality.\n *\n * @template Data - The type of data being managed.\n * @param {SharedStateId} id - The identifier for the data.\n * @param {Data} initialData - The initial data value (optional).\n * @returns {UseDataReturn<Data>} An object containing the data and data management functions.\n */\nexport default function useData<Data = JsonObject>(\n id: SharedStateId = undefined,\n initialData: Data = undefined\n): UseDataReturn<Data> {\n const sharedDataRef =\n useRef<ReturnType<typeof useSharedState<Data>>>(null)\n const sharedAttachmentsRef =\n useRef<ReturnType<typeof useSharedState<SharedAttachments<Data>>>>(\n null\n )\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n sharedDataRef.current = useSharedState<Data>(\n id,\n initialData,\n forceUpdate\n )\n\n sharedAttachmentsRef.current = useSharedState<SharedAttachments<Data>>(\n createReferenceKey(id, 'attachments'),\n { rerenderUseDataHook: forceUpdate }\n )\n\n // If no id is provided, use the context data\n const dataContext = useContext(DataContext)\n if (!id) {\n if (!dataContext.hasContext) {\n throw new Error(\n 'useData needs to run inside DataContext (Form.Handler) or have a valid id'\n )\n }\n\n sharedDataRef.current.data = dataContext.data\n sharedAttachmentsRef.current.data.filterDataHandler =\n dataContext.filterDataHandler\n }\n\n const updateDataValue = dataContext?.updateDataValue\n const setData = dataContext?.setData\n\n const set = useCallback(\n (newData: Data) => {\n if (id) {\n sharedDataRef.current.update(newData)\n } else {\n setData?.(newData)\n }\n },\n [id, setData]\n )\n\n const update = useCallback<UseDataReturnUpdate<Data>>(\n (path, value = undefined) => {\n const existingData = structuredClone(\n sharedDataRef.current.data || {}\n ) as Data & JsonObject\n const existingValue = pointer.has(existingData, path)\n ? pointer.get(existingData, path)\n : undefined\n\n // Get new value\n const newValue =\n typeof value === 'function' ? value(existingValue) : value\n\n if (newValue !== existingValue) {\n // Update existing data\n pointer.set(existingData, path, newValue)\n\n // Update provider with new data\n if (id) {\n sharedDataRef.current.extend(existingData)\n } else {\n updateDataValue(path, newValue)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const remove = useCallback<UseDataReturn<Data>['remove']>(\n (path) => {\n const existingData = structuredClone(\n sharedDataRef.current.data || {}\n ) as Data & JsonObject\n\n if (pointer.has(existingData, path)) {\n // Remove existing data\n pointer.remove(existingData, path)\n\n // Update provider with new data\n if (id) {\n sharedDataRef.current.set(existingData)\n } else {\n updateDataValue(path, undefined)\n }\n }\n },\n [id, updateDataValue]\n )\n\n const reduceToVisibleFields = useCallback<\n UseDataReturn<Data>['reduceToVisibleFields']\n >(\n (data, options = {}) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.visibleDataHandler?.(\n data,\n options\n )\n }\n\n return dataContext?.visibleDataHandler?.(data, options)\n },\n [dataContext, id]\n )\n\n const filterData = useCallback<UseDataReturn<Data>['filterData']>(\n (filter, data = sharedDataRef.current.data) => {\n if (id) {\n return sharedAttachmentsRef.current.data?.filterDataHandler?.(\n data,\n filter\n )\n }\n\n return dataContext?.filterDataHandler?.(data, filter)\n },\n [dataContext, id]\n )\n\n const getValue = useCallback<UseDataReturn<Data>['getValue']>((path) => {\n if (pointer.has(sharedDataRef.current.data, path)) {\n return pointer.get(sharedDataRef.current.data, path)\n }\n\n return undefined\n }, [])\n\n useMountEffect(() => {\n if (id && !sharedDataRef.current.hadInitialData && initialData) {\n sharedDataRef.current.extend(initialData)\n }\n })\n\n const { data } = sharedDataRef.current\n\n return useMemo(\n () => ({\n data,\n remove,\n update,\n set,\n getValue,\n reduceToVisibleFields,\n filterData,\n }),\n [\n data,\n remove,\n update,\n set,\n getValue,\n reduceToVisibleFields,\n filterData,\n ]\n )\n}\n"],"mappings":"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"}
@@ -1,12 +1,12 @@
1
1
  "use client";
2
2
 
3
3
  import { useCallback, useContext, useMemo } from 'react';
4
- import { useSharedState } from '../../../../shared/helpers/useSharedState';
4
+ import { createReferenceKey, useSharedState } from '../../../../shared/helpers/useSharedState';
5
5
  import DataContext from '../../DataContext/Context';
6
6
  export default function useValidation(id = undefined) {
7
7
  const {
8
8
  data
9
- } = useSharedState(id + '-attachments');
9
+ } = useSharedState(createReferenceKey(id, 'attachments'));
10
10
  const fallback = useCallback(() => false, []);
11
11
  const context = useContext(DataContext);
12
12
  const hasErrors = (data === null || data === void 0 ? void 0 : data.hasErrors) || !id && (context === null || context === void 0 ? void 0 : context.hasErrors) || fallback;
@@ -35,7 +35,7 @@ export default function useValidation(id = undefined) {
35
35
  function useConnections(id = undefined) {
36
36
  const {
37
37
  get
38
- } = useSharedState(id + '-attachments');
38
+ } = useSharedState(createReferenceKey(id, 'attachments'));
39
39
  const dataContext = useContext(DataContext);
40
40
  const {
41
41
  fieldConnectionsRef
@@ -1 +1 @@
1
- {"version":3,"file":"useValidation.js","names":["useCallback","useContext","useMemo","useSharedState","DataContext","useValidation","id","undefined","data","fallback","context","hasErrors","hasFieldError","setSubmitState","setFormError","error","getFieldConnections","useConnections","setFieldStatus","path","status","_connections$path","_connections$path$set","connections","setEventResult","call","get","dataContext","fieldConnectionsRef","attachments","current"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useValidation.tsx"],"sourcesContent":["import { useCallback, useContext, useMemo } from 'react'\nimport {\n SharedStateId,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport DataContext, { ContextState } from '../../DataContext/Context'\nimport { SharedAttachments } from '../../DataContext/Provider'\nimport { EventStateObject, Path } from '../../types'\n\ntype UseDataReturn = {\n hasErrors: ContextState['hasErrors']\n hasFieldError: ContextState['hasFieldError']\n setFormError: (error: Error) => void\n setFieldStatus: (path: Path, status: EventStateObject) => void\n}\n\nexport default function useValidation(\n id: SharedStateId = undefined\n): UseDataReturn {\n const { data } = useSharedState<\n UseDataReturn & SharedAttachments<unknown>\n >(id + '-attachments')\n\n const fallback = useCallback(() => false, [])\n\n // If no id is provided, use the context version\n const context = useContext(DataContext)\n const hasErrors =\n data?.hasErrors || (!id && context?.hasErrors) || fallback\n const hasFieldError =\n data?.hasFieldError || (!id && context?.hasFieldError) || fallback\n\n // Error handling\n const setSubmitState =\n data?.setSubmitState || (!id && context?.setSubmitState) || fallback\n const setFormError = useCallback(\n (error: Error) => {\n setSubmitState?.({ error })\n },\n [setSubmitState]\n )\n\n // Field status\n const { getFieldConnections } = useConnections(id)\n const setFieldStatus = useCallback(\n (path: Path, status: EventStateObject) => {\n const connections = getFieldConnections()\n connections?.[path]?.setEventResult?.(status)\n },\n [getFieldConnections]\n )\n\n return useMemo(\n () => ({ hasErrors, hasFieldError, setFormError, setFieldStatus }),\n [hasErrors, hasFieldError, setFormError, setFieldStatus]\n )\n}\n\ntype UseConnectionsSharedState = {\n fieldConnectionsRef: ContextState['fieldConnectionsRef']\n}\n\nfunction useConnections(id: SharedStateId = undefined) {\n const { get } = useSharedState<UseConnectionsSharedState>(\n id + '-attachments'\n )\n\n const dataContext = useContext(DataContext)\n const { fieldConnectionsRef } = dataContext || {}\n\n const getFieldConnections = useCallback(() => {\n const attachments = get()\n const connections =\n attachments?.fieldConnectionsRef || (!id && fieldConnectionsRef)\n\n return connections.current\n }, [fieldConnectionsRef, get, id])\n\n return useMemo(() => ({ getFieldConnections }), [getFieldConnections])\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"useValidation.js","names":["useCallback","useContext","useMemo","createReferenceKey","useSharedState","DataContext","useValidation","id","undefined","data","fallback","context","hasErrors","hasFieldError","setSubmitState","setFormError","error","getFieldConnections","useConnections","setFieldStatus","path","status","_connections$path","_connections$path$set","connections","setEventResult","call","get","dataContext","fieldConnectionsRef","attachments","current"],"sources":["../../../../../../src/extensions/forms/Form/data-context/useValidation.tsx"],"sourcesContent":["import { useCallback, useContext, useMemo } from 'react'\nimport {\n SharedStateId,\n createReferenceKey,\n useSharedState,\n} from '../../../../shared/helpers/useSharedState'\nimport DataContext, { ContextState } from '../../DataContext/Context'\nimport { SharedAttachments } from '../../DataContext/Provider'\nimport { EventStateObject, Path } from '../../types'\n\ntype UseDataReturn = {\n hasErrors: ContextState['hasErrors']\n hasFieldError: ContextState['hasFieldError']\n setFormError: (error: Error) => void\n setFieldStatus: (path: Path, status: EventStateObject) => void\n}\n\nexport default function useValidation(\n id: SharedStateId = undefined\n): UseDataReturn {\n const { data } = useSharedState<\n UseDataReturn & SharedAttachments<unknown>\n >(createReferenceKey(id, 'attachments'))\n\n const fallback = useCallback(() => false, [])\n\n // If no id is provided, use the context version\n const context = useContext(DataContext)\n const hasErrors =\n data?.hasErrors || (!id && context?.hasErrors) || fallback\n const hasFieldError =\n data?.hasFieldError || (!id && context?.hasFieldError) || fallback\n\n // Error handling\n const setSubmitState =\n data?.setSubmitState || (!id && context?.setSubmitState) || fallback\n const setFormError = useCallback(\n (error: Error) => {\n setSubmitState?.({ error })\n },\n [setSubmitState]\n )\n\n // Field status\n const { getFieldConnections } = useConnections(id)\n const setFieldStatus = useCallback(\n (path: Path, status: EventStateObject) => {\n const connections = getFieldConnections()\n connections?.[path]?.setEventResult?.(status)\n },\n [getFieldConnections]\n )\n\n return useMemo(\n () => ({ hasErrors, hasFieldError, setFormError, setFieldStatus }),\n [hasErrors, hasFieldError, setFormError, setFieldStatus]\n )\n}\n\ntype UseConnectionsSharedState = {\n fieldConnectionsRef: ContextState['fieldConnectionsRef']\n}\n\nfunction useConnections(id: SharedStateId = undefined) {\n const { get } = useSharedState<UseConnectionsSharedState>(\n createReferenceKey(id, 'attachments')\n )\n\n const dataContext = useContext(DataContext)\n const { fieldConnectionsRef } = dataContext || {}\n\n const getFieldConnections = useCallback(() => {\n const attachments = get()\n const connections =\n attachments?.fieldConnectionsRef || (!id && fieldConnectionsRef)\n\n return connections.current\n }, [fieldConnectionsRef, get, id])\n\n return useMemo(() => ({ getFieldConnections }), [getFieldConnections])\n}\n"],"mappings":"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"}
@@ -2,10 +2,11 @@ import { Props as FlexContainerProps } from '../../../../components/flex/Contain
2
2
  import { ContainerMode } from './types';
3
3
  export type ArrayItemAreaProps = {
4
4
  /**
5
- * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline` or `basic`.
5
+ * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline`, `filled` or `basic`.
6
6
  * Defaults to `outline`.
7
7
  */
8
- variant?: 'outline' | 'basic';
8
+ variant?: 'outline' | 'basic' | 'filled';
9
+ toolbarVariant?: 'minimumOneItem' | 'custom';
9
10
  };
10
11
  export type Props = {
11
12
  mode: ContainerMode;
@@ -2,7 +2,7 @@
2
2
 
3
3
  import _extends from "@babel/runtime/helpers/esm/extends";
4
4
  import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
5
- const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "openDelay", "variant"];
5
+ const _excluded = ["mode", "open", "ariaLabel", "onAnimationEnd", "className", "children", "openDelay", "variant", "toolbarVariant"];
6
6
  import React, { useCallback, useContext, useReducer, useRef } from 'react';
7
7
  import classnames from 'classnames';
8
8
  import { Card, HeightAnimation } from '../../../../components';
@@ -20,7 +20,8 @@ function ArrayItemArea(props) {
20
20
  className,
21
21
  children,
22
22
  openDelay = 100,
23
- variant = 'outline'
23
+ variant = 'outline',
24
+ toolbarVariant
24
25
  } = props,
25
26
  restProps = _objectWithoutProperties(props, _excluded);
26
27
  const localContextRef = useRef();
@@ -123,14 +124,16 @@ function ArrayItemArea(props) {
123
124
  nextFocusElementRef.current = Array.from(localContextRef.current.elementRef.current.parentElement.childNodes).at(index - 1);
124
125
  } catch (e) {}
125
126
  isRemoving.current = true;
127
+ setOpenState(false);
126
128
  handleRemove === null || handleRemove === void 0 ? void 0 : handleRemove({
127
129
  keepItems: true
128
130
  });
129
- setOpenState(false);
130
131
  }, [handleRemove, index, setOpenState]);
131
132
  return React.createElement(ArrayItemAreaContext.Provider, {
132
133
  value: {
133
- handleRemoveItem
134
+ handleRemoveItem,
135
+ variant,
136
+ toolbarVariant
134
137
  }
135
138
  }, React.createElement(HeightAnimation, {
136
139
  className: classnames('dnb-forms-section-block', className, variant && `dnb-forms-section-block--variant-${variant}`, isNew && 'dnb-forms-section-block--new', hasSubmitError && 'dnb-forms-section-block--error'),
@@ -140,7 +143,8 @@ function ArrayItemArea(props) {
140
143
  keepInDOM: true
141
144
  }, React.createElement(Card, _extends({
142
145
  stack: true,
143
- innerSpace: "small",
146
+ filled: variant === 'filled',
147
+ innerSpace: variant === 'basic' ? false : 'small',
144
148
  className: "dnb-forms-section-block__inner"
145
149
  }, restProps, {
146
150
  "aria-label": ariaLabel
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayItemArea.js","names":["React","useCallback","useContext","useReducer","useRef","classnames","Card","HeightAnimation","IterateItemContext","ArrayItemAreaContext","FieldBoundaryContext","useLayoutEffect","window","useEffect","ArrayItemArea","props","forceUpdate","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","restProps","_objectWithoutProperties","_excluded","localContextRef","hasError","hasSubmitError","current","nextFocusElementRef","isNew","determineMode","value","initialContainerMode","Object","keys","length","containerMode","modeOptions","omitFocusManagement","editMode","switchContainerMode","preventUpdate","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","call","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","duration","keepInDOM","_extends","stack","innerSpace","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, { useCallback, useContext, useReducer, useRef } from 'react'\nimport classnames from 'classnames'\nimport { Card, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\n// SSR warning fix: https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\nconst useLayoutEffect =\n typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline` or `basic`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew } = localContextRef.current\n\n const determineMode = useCallback(() => {\n const { value, initialContainerMode } = localContextRef.current\n if (initialContainerMode === 'auto') {\n // - Set the container mode to \"edit\" if we have an error\n if (\n hasSubmitError ||\n hasError ||\n !value ||\n (typeof value === 'object' && Object.keys(value).length === 0)\n ) {\n return 'edit'\n }\n }\n }, [hasError, hasSubmitError])\n\n if (determineMode() === 'edit') {\n localContextRef.current.containerMode = 'edit'\n if (!localContextRef.current.modeOptions) {\n localContextRef.current.modeOptions = {}\n }\n localContextRef.current.modeOptions.omitFocusManagement = true\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n useLayoutEffect(() => {\n if (mode === 'edit') {\n const editMode = determineMode()\n if (editMode) {\n const { switchContainerMode } = localContextRef.current\n switchContainerMode?.(editMode, {\n omitFocusManagement: true,\n preventUpdate: true,\n })\n }\n }\n }, [determineMode, mode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useLayoutEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n handleRemove?.({ keepItems: true })\n setOpenState(false)\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider value={{ handleRemoveItem }}>\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Card\n stack\n innerSpace=\"small\"\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n aria-label={ariaLabel}\n >\n {children}\n </Card>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":"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"}
1
+ {"version":3,"file":"ArrayItemArea.js","names":["React","useCallback","useContext","useReducer","useRef","classnames","Card","HeightAnimation","IterateItemContext","ArrayItemAreaContext","FieldBoundaryContext","useLayoutEffect","window","useEffect","ArrayItemArea","props","forceUpdate","mode","open","ariaLabel","onAnimationEnd","className","children","openDelay","variant","toolbarVariant","restProps","_objectWithoutProperties","_excluded","localContextRef","hasError","hasSubmitError","current","nextFocusElementRef","isNew","determineMode","value","initialContainerMode","Object","keys","length","containerMode","modeOptions","omitFocusManagement","editMode","switchContainerMode","preventUpdate","handleRemove","index","previousContainerMode","openRef","isRemoving","setOpenState","setTimeout","setFocus","state","_localContextRef$curr","_localContextRef$curr2","_localContextRef$curr3","_localContextRef$curr4","elementRef","focus","call","_nextFocusElementRef$","_nextFocusElementRef$2","handleAnimationEnd","_localContextRef$curr5","_localContextRef$curr6","fulfillRemove","handleRemoveItem","Array","from","parentElement","childNodes","at","e","keepItems","createElement","Provider","duration","keepInDOM","_extends","stack","filled","innerSpace","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemArea.tsx"],"sourcesContent":["import React, { useCallback, useContext, useReducer, useRef } from 'react'\nimport classnames from 'classnames'\nimport { Card, HeightAnimation } from '../../../../components'\nimport IterateItemContext, {\n IterateItemContextState,\n} from '../IterateItemContext'\nimport ArrayItemAreaContext from './ArrayItemAreaContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { Props as FlexContainerProps } from '../../../../components/flex/Container'\nimport { ContainerMode } from './types'\n\n// SSR warning fix: https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\nconst useLayoutEffect =\n typeof window === 'undefined' ? React.useEffect : React.useLayoutEffect\n\nexport type ArrayItemAreaProps = {\n /**\n * Defines the variant of the ViewContainer, EditContainer or PushContainer. Can be `outline`, `filled` or `basic`.\n * Defaults to `outline`.\n */\n variant?: 'outline' | 'basic' | 'filled'\n toolbarVariant?: 'minimumOneItem' | 'custom'\n}\n\nexport type Props = {\n mode: ContainerMode\n open?: boolean | undefined\n ariaLabel?: string\n openDelay?: number\n} & ArrayItemAreaProps\n\nfunction ArrayItemArea(props: Props & FlexContainerProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n mode,\n open,\n ariaLabel,\n onAnimationEnd,\n className,\n children,\n openDelay = 100,\n variant = 'outline',\n toolbarVariant,\n ...restProps\n } = props\n\n const localContextRef = useRef<IterateItemContextState>()\n const { hasError, hasSubmitError } =\n useContext(FieldBoundaryContext) || {}\n localContextRef.current = useContext(IterateItemContext) || {}\n const nextFocusElementRef = useRef<HTMLElement>()\n const { isNew } = localContextRef.current\n\n const determineMode = useCallback(() => {\n const { value, initialContainerMode } = localContextRef.current\n if (initialContainerMode === 'auto') {\n // - Set the container mode to \"edit\" if we have an error\n if (\n hasSubmitError ||\n hasError ||\n !value ||\n (typeof value === 'object' && Object.keys(value).length === 0)\n ) {\n return 'edit'\n }\n }\n }, [hasError, hasSubmitError])\n\n if (determineMode() === 'edit') {\n localContextRef.current.containerMode = 'edit'\n if (!localContextRef.current.modeOptions) {\n localContextRef.current.modeOptions = {}\n }\n localContextRef.current.modeOptions.omitFocusManagement = true\n }\n if (localContextRef.current.containerMode === 'auto') {\n localContextRef.current.containerMode = 'view'\n }\n\n useLayoutEffect(() => {\n if (mode === 'edit') {\n const editMode = determineMode()\n if (editMode) {\n const { switchContainerMode } = localContextRef.current\n switchContainerMode?.(editMode, {\n omitFocusManagement: true,\n preventUpdate: true,\n })\n }\n }\n }, [determineMode, mode])\n\n const { handleRemove, index, previousContainerMode, containerMode } =\n localContextRef.current\n\n const openRef = useRef(open ?? (containerMode === mode && !isNew))\n const isRemoving = useRef(false)\n\n const setOpenState = useCallback((open: boolean) => {\n openRef.current = open\n forceUpdate()\n }, [])\n\n useLayoutEffect(() => {\n if (!isRemoving.current) {\n // - Set the open state, if it's controlled\n if (typeof open !== 'undefined') {\n setOpenState(open)\n } else {\n // - Open the block with animation, if it's in the right mode\n if (openRef.current !== (containerMode === mode)) {\n if (isNew) {\n setTimeout(() => {\n setOpenState(containerMode === mode)\n }, openDelay) // in order to apply the animation\n } else {\n setOpenState(containerMode === mode)\n }\n }\n }\n }\n }, [containerMode, isNew, mode, open, openDelay, setOpenState])\n\n const setFocus = useCallback(\n (state) => {\n if (\n localContextRef.current.modeOptions?.omitFocusManagement !==\n true &&\n !hasSubmitError &&\n containerMode === mode && // ensure we match the correct mode\n containerMode !== previousContainerMode // ensure we have a new mode\n ) {\n if (state === 'opened') {\n localContextRef.current.elementRef?.current?.focus?.()\n } else if (state === 'closed') {\n nextFocusElementRef.current?.focus?.()\n }\n }\n },\n [containerMode, hasSubmitError, mode, previousContainerMode]\n )\n\n // - Remove the block with animation, if it's in the right mode\n const handleAnimationEnd = useCallback(\n (state) => {\n if (!openRef.current && isRemoving.current) {\n isRemoving.current = false\n localContextRef.current.fulfillRemove?.()\n }\n\n setFocus(state)\n onAnimationEnd?.(state)\n },\n [onAnimationEnd, setFocus]\n )\n\n const handleRemoveItem = useCallback(() => {\n try {\n // Because \"previousElementSibling\" did not work in Jest/JSDOM\n nextFocusElementRef.current = Array.from(\n localContextRef.current.elementRef.current.parentElement.childNodes\n ).at(index - 1) as HTMLElement\n } catch (e) {\n //\n }\n isRemoving.current = true\n setOpenState(false)\n handleRemove?.({ keepItems: true })\n }, [handleRemove, index, setOpenState])\n\n return (\n <ArrayItemAreaContext.Provider\n value={{ handleRemoveItem, variant, toolbarVariant }}\n >\n <HeightAnimation\n className={classnames(\n 'dnb-forms-section-block',\n variant && `dnb-forms-section-block--variant-${variant}`,\n isNew && 'dnb-forms-section-block--new',\n hasSubmitError && 'dnb-forms-section-block--error',\n className\n )}\n open={openRef.current}\n onAnimationEnd={handleAnimationEnd}\n duration={450}\n keepInDOM // Ensure fields get mounted so they will sync with the data context\n >\n <Card\n stack\n filled={variant === 'filled'}\n innerSpace={variant === 'basic' ? false : 'small'}\n className=\"dnb-forms-section-block__inner\"\n {...restProps}\n aria-label={ariaLabel}\n >\n {children}\n </Card>\n </HeightAnimation>\n </ArrayItemAreaContext.Provider>\n )\n}\n\nArrayItemArea._supportsSpacingProps = true\nexport default ArrayItemArea\n"],"mappings":";;;;;AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,UAAU,EAAEC,UAAU,EAAEC,MAAM,QAAQ,OAAO;AAC1E,OAAOC,UAAU,MAAM,YAAY;AACnC,SAASC,IAAI,EAAEC,eAAe,QAAQ,wBAAwB;AAC9D,OAAOC,kBAAkB,MAElB,uBAAuB;AAC9B,OAAOC,oBAAoB,MAAM,wBAAwB;AACzD,OAAOC,oBAAoB,MAAM,sDAAsD;AAKvF,MAAMC,eAAe,GACnB,OAAOC,MAAM,KAAK,WAAW,GAAGZ,KAAK,CAACa,SAAS,GAAGb,KAAK,CAACW,eAAe;AAkBzE,SAASG,aAAaA,CAACC,KAAiC,EAAE;EACxD,MAAM,GAAGC,WAAW,CAAC,GAAGb,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAElD,MAAM;MACJc,IAAI;MACJC,IAAI;MACJC,SAAS;MACTC,cAAc;MACdC,SAAS;MACTC,QAAQ;MACRC,SAAS,GAAG,GAAG;MACfC,OAAO,GAAG,SAAS;MACnBC;IAEF,CAAC,GAAGV,KAAK;IADJW,SAAS,GAAAC,wBAAA,CACVZ,KAAK,EAAAa,SAAA;EAET,MAAMC,eAAe,GAAGzB,MAAM,CAA0B,CAAC;EACzD,MAAM;IAAE0B,QAAQ;IAAEC;EAAe,CAAC,GAChC7B,UAAU,CAACQ,oBAAoB,CAAC,IAAI,CAAC,CAAC;EACxCmB,eAAe,CAACG,OAAO,GAAG9B,UAAU,CAACM,kBAAkB,CAAC,IAAI,CAAC,CAAC;EAC9D,MAAMyB,mBAAmB,GAAG7B,MAAM,CAAc,CAAC;EACjD,MAAM;IAAE8B;EAAM,CAAC,GAAGL,eAAe,CAACG,OAAO;EAEzC,MAAMG,aAAa,GAAGlC,WAAW,CAAC,MAAM;IACtC,MAAM;MAAEmC,KAAK;MAAEC;IAAqB,CAAC,GAAGR,eAAe,CAACG,OAAO;IAC/D,IAAIK,oBAAoB,KAAK,MAAM,EAAE;MAEnC,IACEN,cAAc,IACdD,QAAQ,IACR,CAACM,KAAK,IACL,OAAOA,KAAK,KAAK,QAAQ,IAAIE,MAAM,CAACC,IAAI,CAACH,KAAK,CAAC,CAACI,MAAM,KAAK,CAAE,EAC9D;QACA,OAAO,MAAM;MACf;IACF;EACF,CAAC,EAAE,CAACV,QAAQ,EAAEC,cAAc,CAAC,CAAC;EAE9B,IAAII,aAAa,CAAC,CAAC,KAAK,MAAM,EAAE;IAC9BN,eAAe,CAACG,OAAO,CAACS,aAAa,GAAG,MAAM;IAC9C,IAAI,CAACZ,eAAe,CAACG,OAAO,CAACU,WAAW,EAAE;MACxCb,eAAe,CAACG,OAAO,CAACU,WAAW,GAAG,CAAC,CAAC;IAC1C;IACAb,eAAe,CAACG,OAAO,CAACU,WAAW,CAACC,mBAAmB,GAAG,IAAI;EAChE;EACA,IAAId,eAAe,CAACG,OAAO,CAACS,aAAa,KAAK,MAAM,EAAE;IACpDZ,eAAe,CAACG,OAAO,CAACS,aAAa,GAAG,MAAM;EAChD;EAEA9B,eAAe,CAAC,MAAM;IACpB,IAAIM,IAAI,KAAK,MAAM,EAAE;MACnB,MAAM2B,QAAQ,GAAGT,aAAa,CAAC,CAAC;MAChC,IAAIS,QAAQ,EAAE;QACZ,MAAM;UAAEC;QAAoB,CAAC,GAAGhB,eAAe,CAACG,OAAO;QACvDa,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAGD,QAAQ,EAAE;UAC9BD,mBAAmB,EAAE,IAAI;UACzBG,aAAa,EAAE;QACjB,CAAC,CAAC;MACJ;IACF;EACF,CAAC,EAAE,CAACX,aAAa,EAAElB,IAAI,CAAC,CAAC;EAEzB,MAAM;IAAE8B,YAAY;IAAEC,KAAK;IAAEC,qBAAqB;IAAER;EAAc,CAAC,GACjEZ,eAAe,CAACG,OAAO;EAEzB,MAAMkB,OAAO,GAAG9C,MAAM,CAACc,IAAI,aAAJA,IAAI,cAAJA,IAAI,GAAKuB,aAAa,KAAKxB,IAAI,IAAI,CAACiB,KAAM,CAAC;EAClE,MAAMiB,UAAU,GAAG/C,MAAM,CAAC,KAAK,CAAC;EAEhC,MAAMgD,YAAY,GAAGnD,WAAW,CAAEiB,IAAa,IAAK;IAClDgC,OAAO,CAAClB,OAAO,GAAGd,IAAI;IACtBF,WAAW,CAAC,CAAC;EACf,CAAC,EAAE,EAAE,CAAC;EAENL,eAAe,CAAC,MAAM;IACpB,IAAI,CAACwC,UAAU,CAACnB,OAAO,EAAE;MAEvB,IAAI,OAAOd,IAAI,KAAK,WAAW,EAAE;QAC/BkC,YAAY,CAAClC,IAAI,CAAC;MACpB,CAAC,MAAM;QAEL,IAAIgC,OAAO,CAAClB,OAAO,MAAMS,aAAa,KAAKxB,IAAI,CAAC,EAAE;UAChD,IAAIiB,KAAK,EAAE;YACTmB,UAAU,CAAC,MAAM;cACfD,YAAY,CAACX,aAAa,KAAKxB,IAAI,CAAC;YACtC,CAAC,EAAEM,SAAS,CAAC;UACf,CAAC,MAAM;YACL6B,YAAY,CAACX,aAAa,KAAKxB,IAAI,CAAC;UACtC;QACF;MACF;IACF;EACF,CAAC,EAAE,CAACwB,aAAa,EAAEP,KAAK,EAAEjB,IAAI,EAAEC,IAAI,EAAEK,SAAS,EAAE6B,YAAY,CAAC,CAAC;EAE/D,MAAME,QAAQ,GAAGrD,WAAW,CACzBsD,KAAK,IAAK;IAAA,IAAAC,qBAAA;IACT,IACE,EAAAA,qBAAA,GAAA3B,eAAe,CAACG,OAAO,CAACU,WAAW,cAAAc,qBAAA,uBAAnCA,qBAAA,CAAqCb,mBAAmB,MACtD,IAAI,IACN,CAACZ,cAAc,IACfU,aAAa,KAAKxB,IAAI,IACtBwB,aAAa,KAAKQ,qBAAqB,EACvC;MACA,IAAIM,KAAK,KAAK,QAAQ,EAAE;QAAA,IAAAE,sBAAA,EAAAC,sBAAA,EAAAC,sBAAA;QACtB,CAAAF,sBAAA,GAAA5B,eAAe,CAACG,OAAO,CAAC4B,UAAU,cAAAH,sBAAA,wBAAAC,sBAAA,GAAlCD,sBAAA,CAAoCzB,OAAO,cAAA0B,sBAAA,wBAAAC,sBAAA,GAA3CD,sBAAA,CAA6CG,KAAK,cAAAF,sBAAA,uBAAlDA,sBAAA,CAAAG,IAAA,CAAAJ,sBAAqD,CAAC;MACxD,CAAC,MAAM,IAAIH,KAAK,KAAK,QAAQ,EAAE;QAAA,IAAAQ,qBAAA,EAAAC,sBAAA;QAC7B,CAAAD,qBAAA,GAAA9B,mBAAmB,CAACD,OAAO,cAAA+B,qBAAA,wBAAAC,sBAAA,GAA3BD,qBAAA,CAA6BF,KAAK,cAAAG,sBAAA,uBAAlCA,sBAAA,CAAAF,IAAA,CAAAC,qBAAqC,CAAC;MACxC;IACF;EACF,CAAC,EACD,CAACtB,aAAa,EAAEV,cAAc,EAAEd,IAAI,EAAEgC,qBAAqB,CAC7D,CAAC;EAGD,MAAMgB,kBAAkB,GAAGhE,WAAW,CACnCsD,KAAK,IAAK;IACT,IAAI,CAACL,OAAO,CAAClB,OAAO,IAAImB,UAAU,CAACnB,OAAO,EAAE;MAAA,IAAAkC,sBAAA,EAAAC,sBAAA;MAC1ChB,UAAU,CAACnB,OAAO,GAAG,KAAK;MAC1B,CAAAkC,sBAAA,IAAAC,sBAAA,GAAAtC,eAAe,CAACG,OAAO,EAACoC,aAAa,cAAAF,sBAAA,uBAArCA,sBAAA,CAAAJ,IAAA,CAAAK,sBAAwC,CAAC;IAC3C;IAEAb,QAAQ,CAACC,KAAK,CAAC;IACfnC,cAAc,aAAdA,cAAc,uBAAdA,cAAc,CAAGmC,KAAK,CAAC;EACzB,CAAC,EACD,CAACnC,cAAc,EAAEkC,QAAQ,CAC3B,CAAC;EAED,MAAMe,gBAAgB,GAAGpE,WAAW,CAAC,MAAM;IACzC,IAAI;MAEFgC,mBAAmB,CAACD,OAAO,GAAGsC,KAAK,CAACC,IAAI,CACtC1C,eAAe,CAACG,OAAO,CAAC4B,UAAU,CAAC5B,OAAO,CAACwC,aAAa,CAACC,UAC3D,CAAC,CAACC,EAAE,CAAC1B,KAAK,GAAG,CAAC,CAAgB;IAChC,CAAC,CAAC,OAAO2B,CAAC,EAAE,CAEZ;IACAxB,UAAU,CAACnB,OAAO,GAAG,IAAI;IACzBoB,YAAY,CAAC,KAAK,CAAC;IACnBL,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAG;MAAE6B,SAAS,EAAE;IAAK,CAAC,CAAC;EACrC,CAAC,EAAE,CAAC7B,YAAY,EAAEC,KAAK,EAAEI,YAAY,CAAC,CAAC;EAEvC,OACEpD,KAAA,CAAA6E,aAAA,CAACpE,oBAAoB,CAACqE,QAAQ;IAC5B1C,KAAK,EAAE;MAAEiC,gBAAgB;MAAE7C,OAAO;MAAEC;IAAe;EAAE,GAErDzB,KAAA,CAAA6E,aAAA,CAACtE,eAAe;IACdc,SAAS,EAAEhB,UAAU,CACnB,yBAAyB,EAIzBgB,SAAS,EAHTG,OAAO,IAAK,oCAAmCA,OAAQ,EAAC,EACxDU,KAAK,IAAI,8BAA8B,EACvCH,cAAc,IAAI,gCAEpB,CAAE;IACFb,IAAI,EAAEgC,OAAO,CAAClB,OAAQ;IACtBZ,cAAc,EAAE6C,kBAAmB;IACnCc,QAAQ,EAAE,GAAI;IACdC,SAAS;EAAA,GAEThF,KAAA,CAAA6E,aAAA,CAACvE,IAAI,EAAA2E,QAAA;IACHC,KAAK;IACLC,MAAM,EAAE3D,OAAO,KAAK,QAAS;IAC7B4D,UAAU,EAAE5D,OAAO,KAAK,OAAO,GAAG,KAAK,GAAG,OAAQ;IAClDH,SAAS,EAAC;EAAgC,GACtCK,SAAS;IACb,cAAYP;EAAU,IAErBG,QACG,CACS,CACY,CAAC;AAEpC;AAEAR,aAAa,CAACuE,qBAAqB,GAAG,IAAI;AAC1C,eAAevE,aAAa"}
@@ -1,6 +1,9 @@
1
1
  /// <reference types="react" />
2
+ import { ArrayItemAreaProps } from './ArrayItemArea';
2
3
  type ArrayItemAreaContext = {
3
4
  handleRemoveItem?: () => void;
5
+ variant?: ArrayItemAreaProps['variant'];
6
+ toolbarVariant?: ArrayItemAreaProps['toolbarVariant'];
4
7
  };
5
8
  declare const ArrayItemAreaContext: import("react").Context<ArrayItemAreaContext>;
6
9
  export default ArrayItemAreaContext;
@@ -1 +1 @@
1
- {"version":3,"file":"ArrayItemAreaContext.js","names":["createContext","ArrayItemAreaContext"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemAreaContext.ts"],"sourcesContent":["import { createContext } from 'react'\n\ntype ArrayItemAreaContext = {\n handleRemoveItem?: () => void\n}\n\nconst ArrayItemAreaContext = createContext<ArrayItemAreaContext>(null)\n\nexport default ArrayItemAreaContext\n"],"mappings":";;AAAA,SAASA,aAAa,QAAQ,OAAO;AAMrC,MAAMC,oBAAoB,GAAGD,aAAa,CAAuB,IAAI,CAAC;AAEtE,eAAeC,oBAAoB"}
1
+ {"version":3,"file":"ArrayItemAreaContext.js","names":["createContext","ArrayItemAreaContext"],"sources":["../../../../../../src/extensions/forms/Iterate/Array/ArrayItemAreaContext.ts"],"sourcesContent":["import { createContext } from 'react'\nimport { ArrayItemAreaProps } from './ArrayItemArea'\n\ntype ArrayItemAreaContext = {\n handleRemoveItem?: () => void\n variant?: ArrayItemAreaProps['variant']\n toolbarVariant?: ArrayItemAreaProps['toolbarVariant']\n}\n\nconst ArrayItemAreaContext = createContext<ArrayItemAreaContext>(null)\n\nexport default ArrayItemAreaContext\n"],"mappings":";;AAAA,SAASA,aAAa,QAAQ,OAAO;AASrC,MAAMC,oBAAoB,GAAGD,aAAa,CAAuB,IAAI,CAAC;AAEtE,eAAeC,oBAAoB"}
@@ -1,4 +1,5 @@
1
- import { Identifier, Path } from '../../types';
1
+ import { Path } from '../../types';
2
+ import { SharedStateId } from '../../../../shared/helpers/useSharedState';
2
3
  export type Props = {
3
4
  /**
4
5
  * The path (JSON Pointer) to the array or object to count.
@@ -7,7 +8,7 @@ export type Props = {
7
8
  /**
8
9
  * A Form.Handler or DataContext `id` for when called outside of the context.
9
10
  */
10
- id?: Identifier;
11
+ id?: SharedStateId;
11
12
  /**
12
13
  * A filter function to filter the data before counting.
13
14
  */
@@ -15,6 +16,6 @@ export type Props = {
15
16
  };
16
17
  export declare function Count(props: Props): number;
17
18
  export declare function count(props: Props): number;
18
- export declare function useCount(id?: Identifier): {
19
+ export declare function useCount(id?: SharedStateId): {
19
20
  count: (path: Props['path'], filter?: Props['filter']) => number;
20
21
  };