@dnb/eufemia 10.75.0 → 10.75.2

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 (379) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/cjs/components/dropdown/Dropdown.js +1 -1
  3. package/cjs/components/dropdown/Dropdown.js.map +1 -1
  4. package/cjs/components/toggle-button/ToggleButton.d.ts +1 -1
  5. package/cjs/components/toggle-button/ToggleButtonDocs.js +1 -1
  6. package/cjs/components/toggle-button/ToggleButtonDocs.js.map +1 -1
  7. package/cjs/components/upload/Upload.js +5 -2
  8. package/cjs/components/upload/Upload.js.map +1 -1
  9. package/cjs/components/upload/UploadFileInput.d.ts +2 -1
  10. package/cjs/components/upload/UploadFileInput.js +7 -4
  11. package/cjs/components/upload/UploadFileInput.js.map +1 -1
  12. package/cjs/extensions/forms/DataContext/Context.d.ts +5 -2
  13. package/cjs/extensions/forms/DataContext/Context.js.map +1 -1
  14. package/cjs/extensions/forms/DataContext/Provider/Provider.js +42 -16
  15. package/cjs/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  16. package/cjs/extensions/forms/DataContext/Provider/useEventListener.d.ts +3 -0
  17. package/cjs/extensions/forms/DataContext/Provider/useEventListener.js +29 -0
  18. package/cjs/extensions/forms/DataContext/Provider/useEventListener.js.map +1 -0
  19. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +8 -2
  20. package/cjs/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  21. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +8 -2
  22. package/cjs/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  23. package/cjs/extensions/forms/Field/Number/NumberDocs.js +1 -1
  24. package/cjs/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  25. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +8 -2
  26. package/cjs/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  27. package/cjs/extensions/forms/Field/Password/PasswordDocs.js +8 -2
  28. package/cjs/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
  29. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +1 -1
  30. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  31. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +9 -0
  32. package/cjs/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  33. package/cjs/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
  34. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js +1 -1
  35. package/cjs/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  36. package/cjs/extensions/forms/Field/String/StringDocs.js +7 -7
  37. package/cjs/extensions/forms/Field/String/StringDocs.js.map +1 -1
  38. package/cjs/extensions/forms/Field/Toggle/Toggle.js +2 -2
  39. package/cjs/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  40. package/cjs/extensions/forms/Field/Upload/Upload.d.ts +1 -1
  41. package/cjs/extensions/forms/Field/Upload/Upload.js +3 -1
  42. package/cjs/extensions/forms/Field/Upload/Upload.js.map +1 -1
  43. package/cjs/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
  44. package/cjs/extensions/forms/FieldBlock/FieldBlock.js +2 -2
  45. package/cjs/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  46. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  47. package/cjs/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  48. package/cjs/extensions/forms/Form/Isolation/IsolatedContainer.js +4 -6
  49. package/cjs/extensions/forms/Form/Isolation/IsolatedContainer.js.map +1 -1
  50. package/cjs/extensions/forms/Form/Isolation/Isolation.js +2 -3
  51. package/cjs/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  52. package/cjs/extensions/forms/Form/Isolation/IsolationDataReference.d.ts +4 -2
  53. package/cjs/extensions/forms/Form/Isolation/IsolationDataReference.js +20 -4
  54. package/cjs/extensions/forms/Form/Isolation/IsolationDataReference.js.map +1 -1
  55. package/cjs/extensions/forms/Form/Isolation/IsolationResetButton.js +2 -1
  56. package/cjs/extensions/forms/Form/Isolation/IsolationResetButton.js.map +1 -1
  57. package/cjs/extensions/forms/Form/Isolation/useDataContextSnapshot.js +24 -10
  58. package/cjs/extensions/forms/Form/Isolation/useDataContextSnapshot.js.map +1 -1
  59. package/cjs/extensions/forms/Form/Isolation/useHandleStatus.d.ts +2 -1
  60. package/cjs/extensions/forms/Form/Isolation/useHandleStatus.js +10 -3
  61. package/cjs/extensions/forms/Form/Isolation/useHandleStatus.js.map +1 -1
  62. package/cjs/extensions/forms/Form/Isolation/useHasContentChanged.d.ts +3 -1
  63. package/cjs/extensions/forms/Form/Isolation/useHasContentChanged.js +6 -2
  64. package/cjs/extensions/forms/Form/Isolation/useHasContentChanged.js.map +1 -1
  65. package/cjs/extensions/forms/Form/Isolation/useReportError.d.ts +1 -1
  66. package/cjs/extensions/forms/Form/Isolation/useReportError.js +22 -7
  67. package/cjs/extensions/forms/Form/Isolation/useReportError.js.map +1 -1
  68. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +6 -6
  69. package/cjs/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  70. package/cjs/extensions/forms/Iterate/EditContainer/ResetButton.js +3 -1
  71. package/cjs/extensions/forms/Iterate/EditContainer/ResetButton.js.map +1 -1
  72. package/cjs/extensions/forms/Iterate/ItemNo/{useIItemNo.js → useIterateItemNo.js} +2 -2
  73. package/cjs/extensions/forms/Iterate/ItemNo/useIterateItemNo.js.map +1 -0
  74. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +3 -1
  75. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -3
  76. package/cjs/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  77. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  78. package/cjs/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  79. package/cjs/extensions/forms/Tools/Errors.d.ts +5 -0
  80. package/cjs/extensions/forms/Tools/Errors.js +46 -0
  81. package/cjs/extensions/forms/Tools/Errors.js.map +1 -0
  82. package/cjs/extensions/forms/Tools/index.d.ts +1 -0
  83. package/cjs/extensions/forms/Tools/index.js +7 -0
  84. package/cjs/extensions/forms/Tools/index.js.map +1 -1
  85. package/cjs/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js +2 -4
  86. package/cjs/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js.map +1 -1
  87. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js +11 -5
  88. package/cjs/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  89. package/cjs/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  90. package/cjs/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  91. package/cjs/extensions/forms/Wizard/Step/Step.js +1 -1
  92. package/cjs/extensions/forms/Wizard/Step/Step.js.map +1 -1
  93. package/cjs/extensions/forms/Wizard/hooks/useStep.js +13 -5
  94. package/cjs/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  95. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -3
  96. package/cjs/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  97. package/cjs/extensions/forms/hooks/useFieldProps.js +17 -10
  98. package/cjs/extensions/forms/hooks/useFieldProps.js.map +1 -1
  99. package/cjs/extensions/payment-card/icons/brandLogos/DNB.js +2 -2
  100. package/cjs/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -1
  101. package/cjs/extensions/payment-card/icons/providers/BankAxept.js +2 -2
  102. package/cjs/extensions/payment-card/icons/providers/BankAxept.js.map +1 -1
  103. package/cjs/extensions/payment-card/icons/providers/ClickToPay.js +2 -2
  104. package/cjs/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -1
  105. package/cjs/extensions/payment-card/icons/providers/MastercardDefault.js +2 -2
  106. package/cjs/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -1
  107. package/cjs/extensions/payment-card/icons/providers/VisaDefault.js +2 -2
  108. package/cjs/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -1
  109. package/cjs/extensions/payment-card/icons/providers/VisaPlatinum.js +2 -2
  110. package/cjs/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -1
  111. package/cjs/fragments/drawer-list/DrawerListHelpers.js +2 -1
  112. package/cjs/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  113. package/cjs/shared/Eufemia.d.ts +1 -1
  114. package/cjs/shared/Eufemia.js +2 -2
  115. package/cjs/shared/Eufemia.js.map +1 -1
  116. package/cjs/style/core/scopes.scss +1 -1
  117. package/cjs/style/dnb-ui-basis.css +1 -1
  118. package/cjs/style/dnb-ui-basis.min.css +1 -1
  119. package/cjs/style/dnb-ui-body.css +1 -1
  120. package/cjs/style/dnb-ui-body.min.css +1 -1
  121. package/cjs/style/dnb-ui-core.css +1 -1
  122. package/cjs/style/dnb-ui-core.min.css +1 -1
  123. package/components/dropdown/Dropdown.js +2 -2
  124. package/components/dropdown/Dropdown.js.map +1 -1
  125. package/components/toggle-button/ToggleButton.d.ts +1 -1
  126. package/components/toggle-button/ToggleButtonDocs.js +1 -1
  127. package/components/toggle-button/ToggleButtonDocs.js.map +1 -1
  128. package/components/upload/Upload.js +5 -2
  129. package/components/upload/Upload.js.map +1 -1
  130. package/components/upload/UploadFileInput.d.ts +2 -1
  131. package/components/upload/UploadFileInput.js +7 -4
  132. package/components/upload/UploadFileInput.js.map +1 -1
  133. package/es/components/dropdown/Dropdown.js +2 -2
  134. package/es/components/dropdown/Dropdown.js.map +1 -1
  135. package/es/components/toggle-button/ToggleButton.d.ts +1 -1
  136. package/es/components/toggle-button/ToggleButtonDocs.js +1 -1
  137. package/es/components/toggle-button/ToggleButtonDocs.js.map +1 -1
  138. package/es/components/upload/Upload.js +5 -2
  139. package/es/components/upload/Upload.js.map +1 -1
  140. package/es/components/upload/UploadFileInput.d.ts +2 -1
  141. package/es/components/upload/UploadFileInput.js +7 -4
  142. package/es/components/upload/UploadFileInput.js.map +1 -1
  143. package/es/extensions/forms/DataContext/Context.d.ts +5 -2
  144. package/es/extensions/forms/DataContext/Context.js.map +1 -1
  145. package/es/extensions/forms/DataContext/Provider/Provider.js +42 -16
  146. package/es/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  147. package/es/extensions/forms/DataContext/Provider/useEventListener.d.ts +3 -0
  148. package/es/extensions/forms/DataContext/Provider/useEventListener.js +22 -0
  149. package/es/extensions/forms/DataContext/Provider/useEventListener.js.map +1 -0
  150. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +6 -2
  151. package/es/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  152. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +6 -2
  153. package/es/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  154. package/es/extensions/forms/Field/Number/NumberDocs.js +1 -1
  155. package/es/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  156. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +6 -2
  157. package/es/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  158. package/es/extensions/forms/Field/Password/PasswordDocs.js +6 -2
  159. package/es/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
  160. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +1 -1
  161. package/es/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  162. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +7 -0
  163. package/es/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  164. package/es/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
  165. package/es/extensions/forms/Field/Selection/SelectionDocs.js +1 -1
  166. package/es/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  167. package/es/extensions/forms/Field/String/StringDocs.js +7 -7
  168. package/es/extensions/forms/Field/String/StringDocs.js.map +1 -1
  169. package/es/extensions/forms/Field/Toggle/Toggle.js +1 -1
  170. package/es/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  171. package/es/extensions/forms/Field/Upload/Upload.d.ts +1 -1
  172. package/es/extensions/forms/Field/Upload/Upload.js +3 -1
  173. package/es/extensions/forms/Field/Upload/Upload.js.map +1 -1
  174. package/es/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
  175. package/es/extensions/forms/FieldBlock/FieldBlock.js +1 -1
  176. package/es/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  177. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  178. package/es/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  179. package/es/extensions/forms/Form/Isolation/IsolatedContainer.js +4 -6
  180. package/es/extensions/forms/Form/Isolation/IsolatedContainer.js.map +1 -1
  181. package/es/extensions/forms/Form/Isolation/Isolation.js +2 -3
  182. package/es/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  183. package/es/extensions/forms/Form/Isolation/IsolationDataReference.d.ts +4 -2
  184. package/es/extensions/forms/Form/Isolation/IsolationDataReference.js +18 -4
  185. package/es/extensions/forms/Form/Isolation/IsolationDataReference.js.map +1 -1
  186. package/es/extensions/forms/Form/Isolation/IsolationResetButton.js +2 -1
  187. package/es/extensions/forms/Form/Isolation/IsolationResetButton.js.map +1 -1
  188. package/es/extensions/forms/Form/Isolation/useDataContextSnapshot.js +24 -11
  189. package/es/extensions/forms/Form/Isolation/useDataContextSnapshot.js.map +1 -1
  190. package/es/extensions/forms/Form/Isolation/useHandleStatus.d.ts +2 -1
  191. package/es/extensions/forms/Form/Isolation/useHandleStatus.js +10 -3
  192. package/es/extensions/forms/Form/Isolation/useHandleStatus.js.map +1 -1
  193. package/es/extensions/forms/Form/Isolation/useHasContentChanged.d.ts +3 -1
  194. package/es/extensions/forms/Form/Isolation/useHasContentChanged.js +6 -3
  195. package/es/extensions/forms/Form/Isolation/useHasContentChanged.js.map +1 -1
  196. package/es/extensions/forms/Form/Isolation/useReportError.d.ts +1 -1
  197. package/es/extensions/forms/Form/Isolation/useReportError.js +22 -7
  198. package/es/extensions/forms/Form/Isolation/useReportError.js.map +1 -1
  199. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +6 -6
  200. package/es/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  201. package/es/extensions/forms/Iterate/EditContainer/ResetButton.js +3 -1
  202. package/es/extensions/forms/Iterate/EditContainer/ResetButton.js.map +1 -1
  203. package/es/extensions/forms/Iterate/ItemNo/{useIItemNo.js → useIterateItemNo.js} +2 -2
  204. package/es/extensions/forms/Iterate/ItemNo/useIterateItemNo.js.map +1 -0
  205. package/es/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +3 -1
  206. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -3
  207. package/es/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  208. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  209. package/es/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  210. package/es/extensions/forms/Tools/Errors.d.ts +5 -0
  211. package/es/extensions/forms/Tools/Errors.js +37 -0
  212. package/es/extensions/forms/Tools/Errors.js.map +1 -0
  213. package/es/extensions/forms/Tools/index.d.ts +1 -0
  214. package/es/extensions/forms/Tools/index.js +1 -0
  215. package/es/extensions/forms/Tools/index.js.map +1 -1
  216. package/es/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js +2 -4
  217. package/es/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js.map +1 -1
  218. package/es/extensions/forms/Wizard/Container/WizardContainer.js +11 -5
  219. package/es/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  220. package/es/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  221. package/es/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  222. package/es/extensions/forms/Wizard/Step/Step.js +1 -1
  223. package/es/extensions/forms/Wizard/Step/Step.js.map +1 -1
  224. package/es/extensions/forms/Wizard/hooks/useStep.js +13 -5
  225. package/es/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  226. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -3
  227. package/es/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  228. package/es/extensions/forms/hooks/useFieldProps.js +19 -12
  229. package/es/extensions/forms/hooks/useFieldProps.js.map +1 -1
  230. package/es/extensions/payment-card/icons/brandLogos/DNB.js +2 -2
  231. package/es/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -1
  232. package/es/extensions/payment-card/icons/providers/BankAxept.js +2 -2
  233. package/es/extensions/payment-card/icons/providers/BankAxept.js.map +1 -1
  234. package/es/extensions/payment-card/icons/providers/ClickToPay.js +2 -2
  235. package/es/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -1
  236. package/es/extensions/payment-card/icons/providers/MastercardDefault.js +2 -2
  237. package/es/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -1
  238. package/es/extensions/payment-card/icons/providers/VisaDefault.js +2 -2
  239. package/es/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -1
  240. package/es/extensions/payment-card/icons/providers/VisaPlatinum.js +2 -2
  241. package/es/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -1
  242. package/es/fragments/drawer-list/DrawerListHelpers.js +2 -1
  243. package/es/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  244. package/es/shared/Eufemia.d.ts +1 -1
  245. package/es/shared/Eufemia.js +2 -2
  246. package/es/shared/Eufemia.js.map +1 -1
  247. package/es/style/core/scopes.scss +1 -1
  248. package/es/style/dnb-ui-basis.css +1 -1
  249. package/es/style/dnb-ui-basis.min.css +1 -1
  250. package/es/style/dnb-ui-body.css +1 -1
  251. package/es/style/dnb-ui-body.min.css +1 -1
  252. package/es/style/dnb-ui-core.css +1 -1
  253. package/es/style/dnb-ui-core.min.css +1 -1
  254. package/esm/dnb-ui-components.min.mjs +1 -1
  255. package/esm/dnb-ui-elements.min.mjs +1 -1
  256. package/esm/dnb-ui-extensions.min.mjs +3 -3
  257. package/esm/dnb-ui-lib.min.mjs +1 -1
  258. package/extensions/forms/DataContext/Context.d.ts +5 -2
  259. package/extensions/forms/DataContext/Context.js.map +1 -1
  260. package/extensions/forms/DataContext/Provider/Provider.js +42 -16
  261. package/extensions/forms/DataContext/Provider/Provider.js.map +1 -1
  262. package/extensions/forms/DataContext/Provider/useEventListener.d.ts +3 -0
  263. package/extensions/forms/DataContext/Provider/useEventListener.js +23 -0
  264. package/extensions/forms/DataContext/Provider/useEventListener.js.map +1 -0
  265. package/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js +6 -2
  266. package/extensions/forms/Field/BankAccountNumber/BankAccountNumberDocs.js.map +1 -1
  267. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js +6 -2
  268. package/extensions/forms/Field/NationalIdentityNumber/NationalIdentityNumberDocs.js.map +1 -1
  269. package/extensions/forms/Field/Number/NumberDocs.js +1 -1
  270. package/extensions/forms/Field/Number/NumberDocs.js.map +1 -1
  271. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js +6 -2
  272. package/extensions/forms/Field/OrganizationNumber/OrganizationNumberDocs.js.map +1 -1
  273. package/extensions/forms/Field/Password/PasswordDocs.js +6 -2
  274. package/extensions/forms/Field/Password/PasswordDocs.js.map +1 -1
  275. package/extensions/forms/Field/PhoneNumber/PhoneNumber.d.ts +1 -1
  276. package/extensions/forms/Field/PhoneNumber/PhoneNumber.js.map +1 -1
  277. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js +7 -0
  278. package/extensions/forms/Field/PhoneNumber/PhoneNumberDocs.js.map +1 -1
  279. package/extensions/forms/Field/Provider/useFieldProvider.d.ts +3 -3
  280. package/extensions/forms/Field/Selection/SelectionDocs.js +1 -1
  281. package/extensions/forms/Field/Selection/SelectionDocs.js.map +1 -1
  282. package/extensions/forms/Field/String/StringDocs.js +7 -7
  283. package/extensions/forms/Field/String/StringDocs.js.map +1 -1
  284. package/extensions/forms/Field/Toggle/Toggle.js +1 -1
  285. package/extensions/forms/Field/Toggle/Toggle.js.map +1 -1
  286. package/extensions/forms/Field/Upload/Upload.d.ts +1 -1
  287. package/extensions/forms/Field/Upload/Upload.js +3 -1
  288. package/extensions/forms/Field/Upload/Upload.js.map +1 -1
  289. package/extensions/forms/Field/Upload/UploadDocs.js.map +1 -1
  290. package/extensions/forms/FieldBlock/FieldBlock.js +1 -1
  291. package/extensions/forms/FieldBlock/FieldBlock.js.map +1 -1
  292. package/extensions/forms/FieldBlock/FieldBlockDocs.js +1 -1
  293. package/extensions/forms/FieldBlock/FieldBlockDocs.js.map +1 -1
  294. package/extensions/forms/Form/Isolation/IsolatedContainer.js +4 -6
  295. package/extensions/forms/Form/Isolation/IsolatedContainer.js.map +1 -1
  296. package/extensions/forms/Form/Isolation/Isolation.js +2 -3
  297. package/extensions/forms/Form/Isolation/Isolation.js.map +1 -1
  298. package/extensions/forms/Form/Isolation/IsolationDataReference.d.ts +4 -2
  299. package/extensions/forms/Form/Isolation/IsolationDataReference.js +20 -4
  300. package/extensions/forms/Form/Isolation/IsolationDataReference.js.map +1 -1
  301. package/extensions/forms/Form/Isolation/IsolationResetButton.js +2 -1
  302. package/extensions/forms/Form/Isolation/IsolationResetButton.js.map +1 -1
  303. package/extensions/forms/Form/Isolation/useDataContextSnapshot.js +25 -11
  304. package/extensions/forms/Form/Isolation/useDataContextSnapshot.js.map +1 -1
  305. package/extensions/forms/Form/Isolation/useHandleStatus.d.ts +2 -1
  306. package/extensions/forms/Form/Isolation/useHandleStatus.js +10 -3
  307. package/extensions/forms/Form/Isolation/useHandleStatus.js.map +1 -1
  308. package/extensions/forms/Form/Isolation/useHasContentChanged.d.ts +3 -1
  309. package/extensions/forms/Form/Isolation/useHasContentChanged.js +6 -2
  310. package/extensions/forms/Form/Isolation/useHasContentChanged.js.map +1 -1
  311. package/extensions/forms/Form/Isolation/useReportError.d.ts +1 -1
  312. package/extensions/forms/Form/Isolation/useReportError.js +22 -7
  313. package/extensions/forms/Form/Isolation/useReportError.js.map +1 -1
  314. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js +6 -6
  315. package/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.js.map +1 -1
  316. package/extensions/forms/Iterate/EditContainer/ResetButton.js +3 -1
  317. package/extensions/forms/Iterate/EditContainer/ResetButton.js.map +1 -1
  318. package/extensions/forms/Iterate/ItemNo/{useIItemNo.js → useIterateItemNo.js} +2 -2
  319. package/extensions/forms/Iterate/ItemNo/useIterateItemNo.js.map +1 -0
  320. package/extensions/forms/Iterate/PushContainer/PushContainer.d.ts +3 -1
  321. package/extensions/forms/Iterate/PushContainer/PushContainer.js +7 -3
  322. package/extensions/forms/Iterate/PushContainer/PushContainer.js.map +1 -1
  323. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js +5 -0
  324. package/extensions/forms/Iterate/PushContainer/PushContainerDocs.js.map +1 -1
  325. package/extensions/forms/Tools/Errors.d.ts +5 -0
  326. package/extensions/forms/Tools/Errors.js +38 -0
  327. package/extensions/forms/Tools/Errors.js.map +1 -0
  328. package/extensions/forms/Tools/index.d.ts +1 -0
  329. package/extensions/forms/Tools/index.js +1 -0
  330. package/extensions/forms/Tools/index.js.map +1 -1
  331. package/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js +2 -4
  332. package/extensions/forms/Wizard/Container/PrerenderFieldPropsOfOtherSteps.js.map +1 -1
  333. package/extensions/forms/Wizard/Container/WizardContainer.js +11 -5
  334. package/extensions/forms/Wizard/Container/WizardContainer.js.map +1 -1
  335. package/extensions/forms/Wizard/Context/WizardContext.d.ts +2 -1
  336. package/extensions/forms/Wizard/Context/WizardContext.js.map +1 -1
  337. package/extensions/forms/Wizard/Step/Step.js +1 -1
  338. package/extensions/forms/Wizard/Step/Step.js.map +1 -1
  339. package/extensions/forms/Wizard/hooks/useStep.js +13 -5
  340. package/extensions/forms/Wizard/hooks/useStep.js.map +1 -1
  341. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js +4 -3
  342. package/extensions/forms/blocks/ChildrenWithAge/ChildrenWithAge.js.map +1 -1
  343. package/extensions/forms/hooks/useFieldProps.js +19 -12
  344. package/extensions/forms/hooks/useFieldProps.js.map +1 -1
  345. package/extensions/payment-card/icons/brandLogos/DNB.js +2 -2
  346. package/extensions/payment-card/icons/brandLogos/DNB.js.map +1 -1
  347. package/extensions/payment-card/icons/providers/BankAxept.js +2 -2
  348. package/extensions/payment-card/icons/providers/BankAxept.js.map +1 -1
  349. package/extensions/payment-card/icons/providers/ClickToPay.js +2 -2
  350. package/extensions/payment-card/icons/providers/ClickToPay.js.map +1 -1
  351. package/extensions/payment-card/icons/providers/MastercardDefault.js +2 -2
  352. package/extensions/payment-card/icons/providers/MastercardDefault.js.map +1 -1
  353. package/extensions/payment-card/icons/providers/VisaDefault.js +2 -2
  354. package/extensions/payment-card/icons/providers/VisaDefault.js.map +1 -1
  355. package/extensions/payment-card/icons/providers/VisaPlatinum.js +2 -2
  356. package/extensions/payment-card/icons/providers/VisaPlatinum.js.map +1 -1
  357. package/fragments/drawer-list/DrawerListHelpers.js +2 -1
  358. package/fragments/drawer-list/DrawerListHelpers.js.map +1 -1
  359. package/package.json +1 -1
  360. package/shared/Eufemia.d.ts +1 -1
  361. package/shared/Eufemia.js +2 -2
  362. package/shared/Eufemia.js.map +1 -1
  363. package/style/core/scopes.scss +1 -1
  364. package/style/dnb-ui-basis.css +1 -1
  365. package/style/dnb-ui-basis.min.css +1 -1
  366. package/style/dnb-ui-body.css +1 -1
  367. package/style/dnb-ui-body.min.css +1 -1
  368. package/style/dnb-ui-core.css +1 -1
  369. package/style/dnb-ui-core.min.css +1 -1
  370. package/umd/dnb-ui-components.min.js +1 -1
  371. package/umd/dnb-ui-elements.min.js +1 -1
  372. package/umd/dnb-ui-extensions.min.js +1 -1
  373. package/umd/dnb-ui-lib.min.js +1 -1
  374. package/cjs/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +0 -1
  375. package/es/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +0 -1
  376. package/extensions/forms/Iterate/ItemNo/useIItemNo.js.map +0 -1
  377. /package/cjs/extensions/forms/Iterate/ItemNo/{useIItemNo.d.ts → useIterateItemNo.d.ts} +0 -0
  378. /package/es/extensions/forms/Iterate/ItemNo/{useIItemNo.d.ts → useIterateItemNo.d.ts} +0 -0
  379. /package/extensions/forms/Iterate/ItemNo/{useIItemNo.d.ts → useIterateItemNo.d.ts} +0 -0
@@ -1,8 +1,10 @@
1
1
  import React from 'react';
2
2
  export type IsolationDataReference = {
3
- refresh: () => void;
3
+ refresh: (options?: {
4
+ deferred?: boolean;
5
+ }) => void;
4
6
  update: (data: unknown) => void;
5
- cleanup: () => void;
7
+ cleanup: (fn?: () => void) => void;
6
8
  snapshotRef: React.MutableRefObject<unknown>;
7
9
  eventsRef: React.MutableRefObject<Array<() => void>>;
8
10
  };
@@ -5,14 +5,28 @@ export function createDataReference() {
5
5
  const eventsRef = {
6
6
  current: []
7
7
  };
8
- const refresh = () => {
9
- eventsRef.current.forEach(fn => fn());
8
+ const refresh = ({
9
+ deferred = false
10
+ } = {}) => {
11
+ const update = () => eventsRef.current.forEach(fn => fn());
12
+ if (deferred && typeof window !== 'undefined') {
13
+ requestAnimationFrame(update);
14
+ } else {
15
+ update();
16
+ }
10
17
  };
11
18
  const update = data => {
12
19
  snapshotRef.current = data;
13
20
  };
14
- const cleanup = () => {
15
- eventsRef.current = [];
21
+ const cleanup = (fn = null) => {
22
+ if (fn) {
23
+ const index = eventsRef.current.indexOf(fn);
24
+ if (index !== -1) {
25
+ eventsRef.current.splice(index, 1);
26
+ }
27
+ } else {
28
+ eventsRef.current = [];
29
+ }
16
30
  };
17
31
  return {
18
32
  refresh,
@@ -1 +1 @@
1
- {"version":3,"file":"IsolationDataReference.js","names":["createDataReference","snapshotRef","current","undefined","eventsRef","refresh","forEach","fn","update","data","cleanup"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/IsolationDataReference.ts"],"sourcesContent":["import React from 'react'\n\nexport type IsolationDataReference = {\n refresh: () => void\n update: (data: unknown) => void\n cleanup: () => void\n snapshotRef: React.MutableRefObject<unknown>\n eventsRef: React.MutableRefObject<Array<() => void>>\n}\n\nexport function createDataReference(): IsolationDataReference {\n const snapshotRef = { current: undefined }\n const eventsRef = { current: [] }\n\n const refresh: IsolationDataReference['refresh'] = () => {\n eventsRef.current.forEach((fn) => fn())\n }\n\n const update: IsolationDataReference['update'] = (data) => {\n snapshotRef.current = data\n }\n\n const cleanup: IsolationDataReference['cleanup'] = () => {\n eventsRef.current = []\n }\n\n return {\n refresh,\n update,\n cleanup,\n snapshotRef,\n eventsRef,\n }\n}\n"],"mappings":"AAUA,OAAO,SAASA,mBAAmBA,CAAA,EAA2B;EAC5D,MAAMC,WAAW,GAAG;IAAEC,OAAO,EAAEC;EAAU,CAAC;EAC1C,MAAMC,SAAS,GAAG;IAAEF,OAAO,EAAE;EAAG,CAAC;EAEjC,MAAMG,OAA0C,GAAGA,CAAA,KAAM;IACvDD,SAAS,CAACF,OAAO,CAACI,OAAO,CAAEC,EAAE,IAAKA,EAAE,CAAC,CAAC,CAAC;EACzC,CAAC;EAED,MAAMC,MAAwC,GAAIC,IAAI,IAAK;IACzDR,WAAW,CAACC,OAAO,GAAGO,IAAI;EAC5B,CAAC;EAED,MAAMC,OAA0C,GAAGA,CAAA,KAAM;IACvDN,SAAS,CAACF,OAAO,GAAG,EAAE;EACxB,CAAC;EAED,OAAO;IACLG,OAAO;IACPG,MAAM;IACNE,OAAO;IACPT,WAAW;IACXG;EACF,CAAC;AACH","ignoreList":[]}
1
+ {"version":3,"file":"IsolationDataReference.js","names":["createDataReference","snapshotRef","current","undefined","eventsRef","refresh","deferred","update","forEach","fn","window","requestAnimationFrame","data","cleanup","index","indexOf","splice"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/IsolationDataReference.ts"],"sourcesContent":["import React from 'react'\n\nexport type IsolationDataReference = {\n refresh: (options?: { deferred?: boolean }) => void\n update: (data: unknown) => void\n cleanup: (fn?: () => void) => void\n snapshotRef: React.MutableRefObject<unknown>\n eventsRef: React.MutableRefObject<Array<() => void>>\n}\n\nexport function createDataReference(): IsolationDataReference {\n const snapshotRef = { current: undefined }\n const eventsRef = { current: [] }\n\n const refresh: IsolationDataReference['refresh'] = ({\n deferred = false,\n } = {}) => {\n const update = () => eventsRef.current.forEach((fn) => fn())\n if (deferred && typeof window !== 'undefined') {\n requestAnimationFrame(update)\n } else {\n update()\n }\n }\n\n const update: IsolationDataReference['update'] = (data) => {\n snapshotRef.current = data\n }\n\n const cleanup: IsolationDataReference['cleanup'] = (fn = null) => {\n if (fn) {\n const index = eventsRef.current.indexOf(fn)\n if (index !== -1) {\n eventsRef.current.splice(index, 1)\n }\n } else {\n eventsRef.current = []\n }\n }\n\n return {\n refresh,\n update,\n cleanup,\n snapshotRef,\n eventsRef,\n }\n}\n"],"mappings":"AAUA,OAAO,SAASA,mBAAmBA,CAAA,EAA2B;EAC5D,MAAMC,WAAW,GAAG;IAAEC,OAAO,EAAEC;EAAU,CAAC;EAC1C,MAAMC,SAAS,GAAG;IAAEF,OAAO,EAAE;EAAG,CAAC;EAEjC,MAAMG,OAA0C,GAAGA,CAAC;IAClDC,QAAQ,GAAG;EACb,CAAC,GAAG,CAAC,CAAC,KAAK;IACT,MAAMC,MAAM,GAAGA,CAAA,KAAMH,SAAS,CAACF,OAAO,CAACM,OAAO,CAAEC,EAAE,IAAKA,EAAE,CAAC,CAAC,CAAC;IAC5D,IAAIH,QAAQ,IAAI,OAAOI,MAAM,KAAK,WAAW,EAAE;MAC7CC,qBAAqB,CAACJ,MAAM,CAAC;IAC/B,CAAC,MAAM;MACLA,MAAM,CAAC,CAAC;IACV;EACF,CAAC;EAED,MAAMA,MAAwC,GAAIK,IAAI,IAAK;IACzDX,WAAW,CAACC,OAAO,GAAGU,IAAI;EAC5B,CAAC;EAED,MAAMC,OAA0C,GAAGA,CAACJ,EAAE,GAAG,IAAI,KAAK;IAChE,IAAIA,EAAE,EAAE;MACN,MAAMK,KAAK,GAAGV,SAAS,CAACF,OAAO,CAACa,OAAO,CAACN,EAAE,CAAC;MAC3C,IAAIK,KAAK,KAAK,CAAC,CAAC,EAAE;QAChBV,SAAS,CAACF,OAAO,CAACc,MAAM,CAACF,KAAK,EAAE,CAAC,CAAC;MACpC;IACF,CAAC,MAAM;MACLV,SAAS,CAACF,OAAO,GAAG,EAAE;IACxB;EACF,CAAC;EAED,OAAO;IACLG,OAAO;IACPE,MAAM;IACNM,OAAO;IACPZ,WAAW;IACXG;EACF,CAAC;AACH","ignoreList":[]}
@@ -49,7 +49,8 @@ export default function IsolationResetButton(props) {
49
49
  } = useHandleStatus({
50
50
  outerContext,
51
51
  preventUncommittedChanges,
52
- error: isolationError
52
+ error: isolationError,
53
+ name: 'isolation-reset-button'
53
54
  });
54
55
  const buttonProps = omitDataValueReadWriteProps(restProps);
55
56
  const {
@@ -1 +1 @@
1
- {"version":3,"file":"IsolationResetButton.js","names":["React","useCallback","useContext","classnames","Button","Dialog","useTranslation","FieldBoundaryContext","reset","useHasContentChanged","omitDataValueReadWriteProps","useDataContextSnapshot","useHandleStatus","isolationError","IsolationContext","IsolationResetButton","props","text","children","onClick","className","hidden","showConfirmDialog","showWhen","restProps","_objectWithoutProperties","_excluded","outerContext","preventUncommittedChanges","setShowBoundaryErrors","handleReset","enabled","hasContentChanged","showStatus","showCommitStatus","error","buttonProps","resetButton","IterateEditContainer","confirmResetText","textContent","buttonWrapperRef","useRef","handleClick","close","event","_buttonWrapperRef$cur","current","focus","triggerAttributes","_objectSpread","variant","icon","icon_position","disabled","createElement","tabIndex","ref","Boolean","title","onConfirm","_extends","on_click"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/IsolationResetButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button, Dialog } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { reset } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport useHasContentChanged from './useHasContentChanged'\nimport { omitDataValueReadWriteProps } from '../../types'\nimport useDataContextSnapshot from './useDataContextSnapshot'\nimport useHandleStatus from './useHandleStatus'\nimport { isolationError } from './IsolatedContainer'\nimport IsolationContext from './IsolationContext'\n\ntype Props = ButtonProps & {\n showConfirmDialog?: boolean\n showWhen?: 'uncommittedChangeDetected'\n}\n\nexport default function IsolationResetButton(props: Props) {\n const {\n text,\n children,\n onClick,\n className,\n hidden,\n showConfirmDialog = true,\n showWhen,\n ...restProps\n } = props\n\n const { outerContext, preventUncommittedChanges } =\n useContext(IsolationContext)\n const { setShowBoundaryErrors } = useContext(FieldBoundaryContext) || {}\n\n const { handleReset } = useDataContextSnapshot({ enabled: true })\n const { hasContentChanged } = useHasContentChanged()\n const { showStatus: showCommitStatus } = useHandleStatus({\n outerContext,\n preventUncommittedChanges,\n error: isolationError,\n })\n\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const { resetButton } = useTranslation().IterateEditContainer\n const { confirmResetText } = useTranslation().IterateEditContainer\n const textContent = text || children || resetButton\n\n const buttonWrapperRef = React.useRef<HTMLButtonElement>(null)\n const handleClick = useCallback(\n ({ close, event }) => {\n close?.()\n onClick?.(event)\n handleReset()\n setShowBoundaryErrors?.(false)\n buttonWrapperRef.current?.focus()\n },\n [onClick, handleReset, setShowBoundaryErrors]\n )\n\n if (hidden) {\n return null\n }\n\n const triggerAttributes: ButtonProps = {\n className: classnames('dnb-forms-isolate__reset-button', className),\n text: textContent,\n variant: textContent ? 'tertiary' : 'secondary',\n icon: reset,\n icon_position: 'left',\n disabled:\n typeof hasContentChanged === 'boolean' ? !hasContentChanged : false,\n ...buttonProps,\n }\n\n return (\n <span\n tabIndex={-1}\n ref={buttonWrapperRef}\n className=\"dnb-no-focus\"\n hidden={\n !(showWhen === 'uncommittedChangeDetected'\n ? Boolean(showCommitStatus)\n : true)\n }\n >\n {showConfirmDialog ? (\n <Dialog\n variant=\"confirmation\"\n title={confirmResetText}\n triggerAttributes={triggerAttributes}\n onConfirm={handleClick}\n />\n ) : (\n <Button\n {...triggerAttributes}\n on_click={handleClick}\n {...buttonProps}\n >\n {resetButton}\n </Button>\n )}\n </span>\n )\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"IsolationResetButton.js","names":["React","useCallback","useContext","classnames","Button","Dialog","useTranslation","FieldBoundaryContext","reset","useHasContentChanged","omitDataValueReadWriteProps","useDataContextSnapshot","useHandleStatus","isolationError","IsolationContext","IsolationResetButton","props","text","children","onClick","className","hidden","showConfirmDialog","showWhen","restProps","_objectWithoutProperties","_excluded","outerContext","preventUncommittedChanges","setShowBoundaryErrors","handleReset","enabled","hasContentChanged","showStatus","showCommitStatus","error","name","buttonProps","resetButton","IterateEditContainer","confirmResetText","textContent","buttonWrapperRef","useRef","handleClick","close","event","_buttonWrapperRef$cur","current","focus","triggerAttributes","_objectSpread","variant","icon","icon_position","disabled","createElement","tabIndex","ref","Boolean","title","onConfirm","_extends","on_click"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/IsolationResetButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button, Dialog } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { reset } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport useHasContentChanged from './useHasContentChanged'\nimport { omitDataValueReadWriteProps } from '../../types'\nimport useDataContextSnapshot from './useDataContextSnapshot'\nimport useHandleStatus from './useHandleStatus'\nimport { isolationError } from './IsolatedContainer'\nimport IsolationContext from './IsolationContext'\n\ntype Props = ButtonProps & {\n showConfirmDialog?: boolean\n showWhen?: 'uncommittedChangeDetected'\n}\n\nexport default function IsolationResetButton(props: Props) {\n const {\n text,\n children,\n onClick,\n className,\n hidden,\n showConfirmDialog = true,\n showWhen,\n ...restProps\n } = props\n\n const { outerContext, preventUncommittedChanges } =\n useContext(IsolationContext)\n const { setShowBoundaryErrors } = useContext(FieldBoundaryContext) || {}\n\n const { handleReset } = useDataContextSnapshot({ enabled: true })\n const { hasContentChanged } = useHasContentChanged()\n const { showStatus: showCommitStatus } = useHandleStatus({\n outerContext,\n preventUncommittedChanges,\n error: isolationError,\n name: 'isolation-reset-button',\n })\n\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const { resetButton } = useTranslation().IterateEditContainer\n const { confirmResetText } = useTranslation().IterateEditContainer\n const textContent = text || children || resetButton\n\n const buttonWrapperRef = React.useRef<HTMLButtonElement>(null)\n const handleClick = useCallback(\n ({ close, event }) => {\n close?.()\n onClick?.(event)\n handleReset()\n setShowBoundaryErrors?.(false)\n buttonWrapperRef.current?.focus()\n },\n [onClick, handleReset, setShowBoundaryErrors]\n )\n\n if (hidden) {\n return null\n }\n\n const triggerAttributes: ButtonProps = {\n className: classnames('dnb-forms-isolate__reset-button', className),\n text: textContent,\n variant: textContent ? 'tertiary' : 'secondary',\n icon: reset,\n icon_position: 'left',\n disabled:\n typeof hasContentChanged === 'boolean' ? !hasContentChanged : false,\n ...buttonProps,\n }\n\n return (\n <span\n tabIndex={-1}\n ref={buttonWrapperRef}\n className=\"dnb-no-focus\"\n hidden={\n !(showWhen === 'uncommittedChangeDetected'\n ? Boolean(showCommitStatus)\n : true)\n }\n >\n {showConfirmDialog ? (\n <Dialog\n variant=\"confirmation\"\n title={confirmResetText}\n triggerAttributes={triggerAttributes}\n onConfirm={handleClick}\n />\n ) : (\n <Button\n {...triggerAttributes}\n on_click={handleClick}\n {...buttonProps}\n >\n {resetButton}\n </Button>\n )}\n </span>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,8 +1,10 @@
1
1
  "use client";
2
2
 
3
- import { useCallback, useContext, useEffect, useReducer } from 'react';
3
+ import { useCallback, useContext, useEffect, useReducer, useState } from 'react';
4
4
  import DataContext from '../../DataContext/Context';
5
+ import WizardContext from '../../Wizard/Context';
5
6
  import IsolationContext from './IsolationContext';
7
+ import { createDataReference } from './IsolationDataReference';
6
8
  import structuredClone from '@ungap/structured-clone';
7
9
  export default function useDataContextSnapshot({
8
10
  enabled
@@ -12,10 +14,17 @@ export default function useDataContextSnapshot({
12
14
  internalDataRef,
13
15
  setData
14
16
  } = useContext(DataContext);
17
+ const isolationContext = useContext(IsolationContext);
18
+ const hasWizard = Boolean(useContext(WizardContext));
19
+ const [dataReferenceFallback] = useState(() => {
20
+ if (enabled && !(isolationContext !== null && isolationContext !== void 0 && isolationContext.dataReference)) {
21
+ return createDataReference();
22
+ }
23
+ });
15
24
  const {
16
- dataReference,
25
+ dataReference = dataReferenceFallback,
17
26
  setIsolatedData
18
- } = useContext(IsolationContext) || {};
27
+ } = isolationContext || {};
19
28
  const {
20
29
  snapshotRef,
21
30
  eventsRef,
@@ -23,25 +32,29 @@ export default function useDataContextSnapshot({
23
32
  refresh,
24
33
  cleanup
25
34
  } = dataReference || {};
35
+ const updateHandler = useCallback((data = null) => {
36
+ update(data || structuredClone(internalDataRef === null || internalDataRef === void 0 ? void 0 : internalDataRef.current));
37
+ forceUpdate();
38
+ }, [internalDataRef, update]);
26
39
  useEffect(() => {
27
40
  if (enabled && eventsRef) {
28
- eventsRef.current.push(() => {
29
- update(structuredClone(internalDataRef === null || internalDataRef === void 0 ? void 0 : internalDataRef.current));
30
- forceUpdate();
41
+ eventsRef.current.push(updateHandler);
42
+ refresh({
43
+ deferred: hasWizard
31
44
  });
32
- refresh();
33
45
  }
34
- return () => cleanup === null || cleanup === void 0 ? void 0 : cleanup();
35
- }, [cleanup, enabled, eventsRef, internalDataRef, refresh, update]);
46
+ return () => cleanup === null || cleanup === void 0 ? void 0 : cleanup(updateHandler);
47
+ }, [cleanup, enabled, eventsRef, hasWizard, refresh, updateHandler]);
36
48
  const handleReset = useCallback(() => {
37
49
  window.requestAnimationFrame(() => {
38
50
  if (snapshotRef) {
39
51
  const data = structuredClone(snapshotRef.current);
40
- setData(data);
41
52
  setIsolatedData(data);
53
+ setData(data);
54
+ updateHandler(data);
42
55
  }
43
56
  });
44
- }, [setData, setIsolatedData, snapshotRef]);
57
+ }, [setData, setIsolatedData, snapshotRef, updateHandler]);
45
58
  return {
46
59
  handleReset,
47
60
  snapshotRef
@@ -1 +1 @@
1
- {"version":3,"file":"useDataContextSnapshot.js","names":["useCallback","useContext","useEffect","useReducer","DataContext","IsolationContext","structuredClone","useDataContextSnapshot","enabled","forceUpdate","internalDataRef","setData","dataReference","setIsolatedData","snapshotRef","eventsRef","update","refresh","cleanup","current","push","handleReset","window","requestAnimationFrame","data"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useDataContextSnapshot.ts"],"sourcesContent":["import { useCallback, useContext, useEffect, useReducer } from 'react'\nimport DataContext from '../../DataContext/Context'\nimport IsolationContext from './IsolationContext'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport default function useDataContextSnapshot({\n enabled,\n}: {\n enabled?: boolean\n} = {}) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n const { internalDataRef, setData } = useContext(DataContext)\n const { dataReference, setIsolatedData } =\n useContext(IsolationContext) || {}\n const { snapshotRef, eventsRef, update, refresh, cleanup } =\n dataReference || {}\n\n useEffect(() => {\n if (enabled && eventsRef) {\n eventsRef.current.push(() => {\n update(structuredClone(internalDataRef?.current))\n forceUpdate()\n })\n refresh()\n }\n\n return () => cleanup?.()\n }, [cleanup, enabled, eventsRef, internalDataRef, refresh, update])\n\n const handleReset = useCallback(() => {\n window.requestAnimationFrame(() => {\n if (snapshotRef) {\n const data = structuredClone(snapshotRef.current)\n setData(data)\n setIsolatedData(data)\n }\n }) // To actually reset the data without influence the data we are about to push, we need to wait for the next frame\n }, [setData, setIsolatedData, snapshotRef])\n\n return { handleReset, snapshotRef }\n}\n"],"mappings":";;AAAA,SAASA,WAAW,EAAEC,UAAU,EAAEC,SAAS,EAAEC,UAAU,QAAQ,OAAO;AACtE,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,gBAAgB,MAAM,oBAAoB;AAMjD,OAAOC,eAAe,MAAM,yBAAyB;AAErD,eAAe,SAASC,sBAAsBA,CAAC;EAC7CC;AAGF,CAAC,GAAG,CAAC,CAAC,EAAE;EACN,MAAM,GAAGC,WAAW,CAAC,GAAGN,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAClD,MAAM;IAAEO,eAAe;IAAEC;EAAQ,CAAC,GAAGV,UAAU,CAACG,WAAW,CAAC;EAC5D,MAAM;IAAEQ,aAAa;IAAEC;EAAgB,CAAC,GACtCZ,UAAU,CAACI,gBAAgB,CAAC,IAAI,CAAC,CAAC;EACpC,MAAM;IAAES,WAAW;IAAEC,SAAS;IAAEC,MAAM;IAAEC,OAAO;IAAEC;EAAQ,CAAC,GACxDN,aAAa,IAAI,CAAC,CAAC;EAErBV,SAAS,CAAC,MAAM;IACd,IAAIM,OAAO,IAAIO,SAAS,EAAE;MACxBA,SAAS,CAACI,OAAO,CAACC,IAAI,CAAC,MAAM;QAC3BJ,MAAM,CAACV,eAAe,CAACI,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAES,OAAO,CAAC,CAAC;QACjDV,WAAW,CAAC,CAAC;MACf,CAAC,CAAC;MACFQ,OAAO,CAAC,CAAC;IACX;IAEA,OAAO,MAAMC,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAG,CAAC;EAC1B,CAAC,EAAE,CAACA,OAAO,EAAEV,OAAO,EAAEO,SAAS,EAAEL,eAAe,EAAEO,OAAO,EAAED,MAAM,CAAC,CAAC;EAEnE,MAAMK,WAAW,GAAGrB,WAAW,CAAC,MAAM;IACpCsB,MAAM,CAACC,qBAAqB,CAAC,MAAM;MACjC,IAAIT,WAAW,EAAE;QACf,MAAMU,IAAI,GAAGlB,eAAe,CAACQ,WAAW,CAACK,OAAO,CAAC;QACjDR,OAAO,CAACa,IAAI,CAAC;QACbX,eAAe,CAACW,IAAI,CAAC;MACvB;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACb,OAAO,EAAEE,eAAe,EAAEC,WAAW,CAAC,CAAC;EAE3C,OAAO;IAAEO,WAAW;IAAEP;EAAY,CAAC;AACrC","ignoreList":[]}
1
+ {"version":3,"file":"useDataContextSnapshot.js","names":["useCallback","useContext","useEffect","useReducer","useState","DataContext","WizardContext","IsolationContext","createDataReference","structuredClone","useDataContextSnapshot","enabled","forceUpdate","internalDataRef","setData","isolationContext","hasWizard","Boolean","dataReferenceFallback","dataReference","setIsolatedData","snapshotRef","eventsRef","update","refresh","cleanup","updateHandler","data","current","push","deferred","handleReset","window","requestAnimationFrame"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useDataContextSnapshot.ts"],"sourcesContent":["import {\n useCallback,\n useContext,\n useEffect,\n useReducer,\n useState,\n} from 'react'\nimport DataContext from '../../DataContext/Context'\nimport WizardContext from '../../Wizard/Context'\nimport IsolationContext from './IsolationContext'\nimport { createDataReference } from './IsolationDataReference'\n\n/**\n * Deprecated, as it is supported by all major browsers and Node.js >=v18\n * So its a question of time, when we will remove this polyfill\n */\nimport structuredClone from '@ungap/structured-clone'\n\nexport default function useDataContextSnapshot({\n enabled,\n}: {\n enabled?: boolean\n} = {}) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n const { internalDataRef, setData } = useContext(DataContext)\n const isolationContext = useContext(IsolationContext)\n const hasWizard = Boolean(useContext(WizardContext))\n const [dataReferenceFallback] = useState(() => {\n if (enabled && !isolationContext?.dataReference) {\n return createDataReference()\n }\n })\n const { dataReference = dataReferenceFallback, setIsolatedData } =\n isolationContext || {}\n const { snapshotRef, eventsRef, update, refresh, cleanup } =\n dataReference || {}\n\n const updateHandler = useCallback(\n (data = null) => {\n update(data || structuredClone(internalDataRef?.current))\n forceUpdate() // Ensure the hasContentChanged hook gets updated\n },\n [internalDataRef, update]\n )\n\n useEffect(() => {\n if (enabled && eventsRef) {\n eventsRef.current.push(updateHandler)\n\n // Also run refresh again and wait for the Wizard to finish prerendering,\n // in case there are fields in steps beyond the current one.\n refresh({ deferred: hasWizard })\n }\n\n return () => cleanup?.(updateHandler)\n }, [cleanup, enabled, eventsRef, hasWizard, refresh, updateHandler])\n\n const handleReset = useCallback(() => {\n window.requestAnimationFrame(() => {\n if (snapshotRef) {\n const data = structuredClone(snapshotRef.current)\n setIsolatedData(data)\n setData(data)\n updateHandler(data)\n }\n }) // To actually reset the data without influence the data we are about to push, we need to wait for the next frame\n }, [setData, setIsolatedData, snapshotRef, updateHandler])\n\n return { handleReset, snapshotRef }\n}\n"],"mappings":";;AAAA,SACEA,WAAW,EACXC,UAAU,EACVC,SAAS,EACTC,UAAU,EACVC,QAAQ,QACH,OAAO;AACd,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,aAAa,MAAM,sBAAsB;AAChD,OAAOC,gBAAgB,MAAM,oBAAoB;AACjD,SAASC,mBAAmB,QAAQ,0BAA0B;AAM9D,OAAOC,eAAe,MAAM,yBAAyB;AAErD,eAAe,SAASC,sBAAsBA,CAAC;EAC7CC;AAGF,CAAC,GAAG,CAAC,CAAC,EAAE;EACN,MAAM,GAAGC,WAAW,CAAC,GAAGT,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;EAClD,MAAM;IAAEU,eAAe;IAAEC;EAAQ,CAAC,GAAGb,UAAU,CAACI,WAAW,CAAC;EAC5D,MAAMU,gBAAgB,GAAGd,UAAU,CAACM,gBAAgB,CAAC;EACrD,MAAMS,SAAS,GAAGC,OAAO,CAAChB,UAAU,CAACK,aAAa,CAAC,CAAC;EACpD,MAAM,CAACY,qBAAqB,CAAC,GAAGd,QAAQ,CAAC,MAAM;IAC7C,IAAIO,OAAO,IAAI,EAACI,gBAAgB,aAAhBA,gBAAgB,eAAhBA,gBAAgB,CAAEI,aAAa,GAAE;MAC/C,OAAOX,mBAAmB,CAAC,CAAC;IAC9B;EACF,CAAC,CAAC;EACF,MAAM;IAAEW,aAAa,GAAGD,qBAAqB;IAAEE;EAAgB,CAAC,GAC9DL,gBAAgB,IAAI,CAAC,CAAC;EACxB,MAAM;IAAEM,WAAW;IAAEC,SAAS;IAAEC,MAAM;IAAEC,OAAO;IAAEC;EAAQ,CAAC,GACxDN,aAAa,IAAI,CAAC,CAAC;EAErB,MAAMO,aAAa,GAAG1B,WAAW,CAC/B,CAAC2B,IAAI,GAAG,IAAI,KAAK;IACfJ,MAAM,CAACI,IAAI,IAAIlB,eAAe,CAACI,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAEe,OAAO,CAAC,CAAC;IACzDhB,WAAW,CAAC,CAAC;EACf,CAAC,EACD,CAACC,eAAe,EAAEU,MAAM,CAC1B,CAAC;EAEDrB,SAAS,CAAC,MAAM;IACd,IAAIS,OAAO,IAAIW,SAAS,EAAE;MACxBA,SAAS,CAACM,OAAO,CAACC,IAAI,CAACH,aAAa,CAAC;MAIrCF,OAAO,CAAC;QAAEM,QAAQ,EAAEd;MAAU,CAAC,CAAC;IAClC;IAEA,OAAO,MAAMS,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAGC,aAAa,CAAC;EACvC,CAAC,EAAE,CAACD,OAAO,EAAEd,OAAO,EAAEW,SAAS,EAAEN,SAAS,EAAEQ,OAAO,EAAEE,aAAa,CAAC,CAAC;EAEpE,MAAMK,WAAW,GAAG/B,WAAW,CAAC,MAAM;IACpCgC,MAAM,CAACC,qBAAqB,CAAC,MAAM;MACjC,IAAIZ,WAAW,EAAE;QACf,MAAMM,IAAI,GAAGlB,eAAe,CAACY,WAAW,CAACO,OAAO,CAAC;QACjDR,eAAe,CAACO,IAAI,CAAC;QACrBb,OAAO,CAACa,IAAI,CAAC;QACbD,aAAa,CAACC,IAAI,CAAC;MACrB;IACF,CAAC,CAAC;EACJ,CAAC,EAAE,CAACb,OAAO,EAAEM,eAAe,EAAEC,WAAW,EAAEK,aAAa,CAAC,CAAC;EAE1D,OAAO;IAAEK,WAAW;IAAEV;EAAY,CAAC;AACrC","ignoreList":[]}
@@ -1,8 +1,9 @@
1
1
  import { ContextState } from '../../DataContext';
2
- export default function useHandleStatus({ outerContext, preventUncommittedChanges, error, }: {
2
+ export default function useHandleStatus({ outerContext, preventUncommittedChanges, error, name, }: {
3
3
  outerContext: ContextState;
4
4
  preventUncommittedChanges: boolean;
5
5
  error: Error;
6
+ name?: string;
6
7
  }): {
7
8
  hasContentChanged: boolean;
8
9
  showStatus: any;
@@ -6,12 +6,19 @@ import useReportError from './useReportError';
6
6
  export default function useHandleStatus({
7
7
  outerContext,
8
8
  preventUncommittedChanges,
9
- error
9
+ error,
10
+ name
10
11
  }) {
11
12
  const {
12
13
  hasContentChanged
13
- } = useHasContentChanged();
14
- useReportError(preventUncommittedChanges && hasContentChanged ? error : undefined, outerContext);
14
+ } = useHasContentChanged({
15
+ enabled: preventUncommittedChanges
16
+ });
17
+ let errorToReport = undefined;
18
+ if (preventUncommittedChanges && hasContentChanged) {
19
+ errorToReport = error;
20
+ }
21
+ useReportError(errorToReport, outerContext, name);
15
22
  const showStatus = useShowStatus({
16
23
  outerContext,
17
24
  hasContentChanged,
@@ -1 +1 @@
1
- {"version":3,"file":"useHandleStatus.js","names":["useEffect","useRef","useState","useHasContentChanged","useReportError","useHandleStatus","outerContext","preventUncommittedChanges","error","hasContentChanged","undefined","showStatus","useShowStatus","showAllErrors","setShowStatus","showRef","current"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useHandleStatus.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react'\nimport { ContextState } from '../../DataContext'\nimport useHasContentChanged from './useHasContentChanged'\nimport useReportError from './useReportError'\n\nexport default function useHandleStatus({\n outerContext,\n preventUncommittedChanges,\n error,\n}: {\n outerContext: ContextState\n preventUncommittedChanges: boolean\n error: Error\n}) {\n const { hasContentChanged } = useHasContentChanged()\n\n useReportError(\n preventUncommittedChanges && hasContentChanged ? error : undefined,\n outerContext\n )\n\n const showStatus = useShowStatus({\n outerContext,\n hasContentChanged,\n preventUncommittedChanges,\n })\n\n return { hasContentChanged, showStatus }\n}\n\n// This hook/state is used to not show the status right away, after the user has cleared the PushContainer data.\nfunction useShowStatus({\n outerContext,\n hasContentChanged,\n preventUncommittedChanges,\n}) {\n const showAllErrors = outerContext?.showAllErrors\n const [showStatus, setShowStatus] = useState(showAllErrors)\n const showRef = useRef(showAllErrors)\n\n useEffect(() => {\n if (!preventUncommittedChanges) {\n return // stop here\n }\n\n if (!hasContentChanged) {\n setShowStatus(false)\n } else {\n if (showRef.current !== showAllErrors) {\n setShowStatus(showAllErrors)\n }\n }\n showRef.current = showAllErrors\n }, [hasContentChanged, preventUncommittedChanges, showAllErrors])\n\n return showStatus\n}\n"],"mappings":";;AAAA,SAASA,SAAS,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AAEnD,OAAOC,oBAAoB,MAAM,wBAAwB;AACzD,OAAOC,cAAc,MAAM,kBAAkB;AAE7C,eAAe,SAASC,eAAeA,CAAC;EACtCC,YAAY;EACZC,yBAAyB;EACzBC;AAKF,CAAC,EAAE;EACD,MAAM;IAAEC;EAAkB,CAAC,GAAGN,oBAAoB,CAAC,CAAC;EAEpDC,cAAc,CACZG,yBAAyB,IAAIE,iBAAiB,GAAGD,KAAK,GAAGE,SAAS,EAClEJ,YACF,CAAC;EAED,MAAMK,UAAU,GAAGC,aAAa,CAAC;IAC/BN,YAAY;IACZG,iBAAiB;IACjBF;EACF,CAAC,CAAC;EAEF,OAAO;IAAEE,iBAAiB;IAAEE;EAAW,CAAC;AAC1C;AAGA,SAASC,aAAaA,CAAC;EACrBN,YAAY;EACZG,iBAAiB;EACjBF;AACF,CAAC,EAAE;EACD,MAAMM,aAAa,GAAGP,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEO,aAAa;EACjD,MAAM,CAACF,UAAU,EAAEG,aAAa,CAAC,GAAGZ,QAAQ,CAACW,aAAa,CAAC;EAC3D,MAAME,OAAO,GAAGd,MAAM,CAACY,aAAa,CAAC;EAErCb,SAAS,CAAC,MAAM;IACd,IAAI,CAACO,yBAAyB,EAAE;MAC9B;IACF;IAEA,IAAI,CAACE,iBAAiB,EAAE;MACtBK,aAAa,CAAC,KAAK,CAAC;IACtB,CAAC,MAAM;MACL,IAAIC,OAAO,CAACC,OAAO,KAAKH,aAAa,EAAE;QACrCC,aAAa,CAACD,aAAa,CAAC;MAC9B;IACF;IACAE,OAAO,CAACC,OAAO,GAAGH,aAAa;EACjC,CAAC,EAAE,CAACJ,iBAAiB,EAAEF,yBAAyB,EAAEM,aAAa,CAAC,CAAC;EAEjE,OAAOF,UAAU;AACnB","ignoreList":[]}
1
+ {"version":3,"file":"useHandleStatus.js","names":["useEffect","useRef","useState","useHasContentChanged","useReportError","useHandleStatus","outerContext","preventUncommittedChanges","error","name","hasContentChanged","enabled","errorToReport","undefined","showStatus","useShowStatus","showAllErrors","setShowStatus","showRef","current"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useHandleStatus.ts"],"sourcesContent":["import { useEffect, useRef, useState } from 'react'\nimport { ContextState } from '../../DataContext'\nimport useHasContentChanged from './useHasContentChanged'\nimport useReportError from './useReportError'\n\nexport default function useHandleStatus({\n outerContext,\n preventUncommittedChanges,\n error,\n name,\n}: {\n outerContext: ContextState\n preventUncommittedChanges: boolean\n error: Error\n name?: string\n}) {\n const { hasContentChanged } = useHasContentChanged({\n enabled: preventUncommittedChanges,\n })\n\n let errorToReport = undefined\n if (preventUncommittedChanges && hasContentChanged) {\n errorToReport = error\n }\n useReportError(errorToReport, outerContext, name)\n\n const showStatus = useShowStatus({\n outerContext,\n hasContentChanged,\n preventUncommittedChanges,\n })\n\n return { hasContentChanged, showStatus }\n}\n\n// This hook/state is used to not show the status right away, after the user has cleared the PushContainer data.\nfunction useShowStatus({\n outerContext,\n hasContentChanged,\n preventUncommittedChanges,\n}) {\n const showAllErrors = outerContext?.showAllErrors\n const [showStatus, setShowStatus] = useState(showAllErrors)\n const showRef = useRef(showAllErrors)\n\n useEffect(() => {\n if (!preventUncommittedChanges) {\n return // stop here\n }\n\n if (!hasContentChanged) {\n setShowStatus(false)\n } else {\n if (showRef.current !== showAllErrors) {\n setShowStatus(showAllErrors)\n }\n }\n showRef.current = showAllErrors\n }, [hasContentChanged, preventUncommittedChanges, showAllErrors])\n\n return showStatus\n}\n"],"mappings":";;AAAA,SAASA,SAAS,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AAEnD,OAAOC,oBAAoB,MAAM,wBAAwB;AACzD,OAAOC,cAAc,MAAM,kBAAkB;AAE7C,eAAe,SAASC,eAAeA,CAAC;EACtCC,YAAY;EACZC,yBAAyB;EACzBC,KAAK;EACLC;AAMF,CAAC,EAAE;EACD,MAAM;IAAEC;EAAkB,CAAC,GAAGP,oBAAoB,CAAC;IACjDQ,OAAO,EAAEJ;EACX,CAAC,CAAC;EAEF,IAAIK,aAAa,GAAGC,SAAS;EAC7B,IAAIN,yBAAyB,IAAIG,iBAAiB,EAAE;IAClDE,aAAa,GAAGJ,KAAK;EACvB;EACAJ,cAAc,CAACQ,aAAa,EAAEN,YAAY,EAAEG,IAAI,CAAC;EAEjD,MAAMK,UAAU,GAAGC,aAAa,CAAC;IAC/BT,YAAY;IACZI,iBAAiB;IACjBH;EACF,CAAC,CAAC;EAEF,OAAO;IAAEG,iBAAiB;IAAEI;EAAW,CAAC;AAC1C;AAGA,SAASC,aAAaA,CAAC;EACrBT,YAAY;EACZI,iBAAiB;EACjBH;AACF,CAAC,EAAE;EACD,MAAMS,aAAa,GAAGV,YAAY,aAAZA,YAAY,uBAAZA,YAAY,CAAEU,aAAa;EACjD,MAAM,CAACF,UAAU,EAAEG,aAAa,CAAC,GAAGf,QAAQ,CAACc,aAAa,CAAC;EAC3D,MAAME,OAAO,GAAGjB,MAAM,CAACe,aAAa,CAAC;EAErChB,SAAS,CAAC,MAAM;IACd,IAAI,CAACO,yBAAyB,EAAE;MAC9B;IACF;IAEA,IAAI,CAACG,iBAAiB,EAAE;MACtBO,aAAa,CAAC,KAAK,CAAC;IACtB,CAAC,MAAM;MACL,IAAIC,OAAO,CAACC,OAAO,KAAKH,aAAa,EAAE;QACrCC,aAAa,CAACD,aAAa,CAAC;MAC9B;IACF;IACAE,OAAO,CAACC,OAAO,GAAGH,aAAa;EACjC,CAAC,EAAE,CAACN,iBAAiB,EAAEH,yBAAyB,EAAES,aAAa,CAAC,CAAC;EAEjE,OAAOF,UAAU;AACnB","ignoreList":[]}
@@ -1,3 +1,5 @@
1
- export default function useHasContentChanged(): {
1
+ export default function useHasContentChanged({ enabled, }?: {
2
+ enabled?: boolean;
3
+ }): {
2
4
  hasContentChanged: boolean;
3
5
  };
@@ -4,14 +4,16 @@ import { useContext, useMemo } from 'react';
4
4
  import pointer from '../../utils/json-pointer';
5
5
  import DataContext from '../../DataContext/Context';
6
6
  import useDataContextSnapshot from './useDataContextSnapshot';
7
- export default function useHasContentChanged() {
7
+ export default function useHasContentChanged({
8
+ enabled = false
9
+ } = {}) {
8
10
  const {
9
11
  internalDataRef
10
12
  } = useContext(DataContext);
11
13
  const {
12
14
  snapshotRef
13
15
  } = useDataContextSnapshot({
14
- enabled: true
16
+ enabled
15
17
  });
16
18
  const data = internalDataRef === null || internalDataRef === void 0 ? void 0 : internalDataRef.current;
17
19
  const snapshot = snapshotRef === null || snapshotRef === void 0 ? void 0 : snapshotRef.current;
@@ -21,7 +23,8 @@ export default function useHasContentChanged() {
21
23
  }
22
24
  let hasChanged = false;
23
25
  pointer.walk(data, (value, path) => {
24
- if (pointer.has(snapshot, path) && pointer.get(snapshot, path) !== value) {
26
+ const exists = pointer.has(snapshot, path);
27
+ if (!exists || exists && pointer.get(snapshot, path) !== value) {
25
28
  hasChanged = true;
26
29
  return false;
27
30
  }
@@ -1 +1 @@
1
- {"version":3,"file":"useHasContentChanged.js","names":["useContext","useMemo","pointer","DataContext","useDataContextSnapshot","useHasContentChanged","internalDataRef","snapshotRef","enabled","data","current","snapshot","hasContentChanged","undefined","hasChanged","walk","value","path","has","get"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useHasContentChanged.ts"],"sourcesContent":["import { useContext, useMemo } from 'react'\nimport pointer from '../../utils/json-pointer'\nimport DataContext from '../../DataContext/Context'\nimport useDataContextSnapshot from './useDataContextSnapshot'\n\nexport default function useHasContentChanged() {\n const { internalDataRef } = useContext(DataContext)\n const { snapshotRef } = useDataContextSnapshot({ enabled: true })\n\n const data = internalDataRef?.current\n const snapshot = snapshotRef?.current // To support a custom data reference, we need to have a snapshot in the hook deps.\n const hasContentChanged = useMemo(() => {\n if (!data || !snapshot) {\n return undefined\n }\n\n let hasChanged = false\n\n pointer.walk(data, (value, path) => {\n if (\n pointer.has(snapshot, path) &&\n pointer.get(snapshot, path) !== value\n ) {\n hasChanged = true\n return false\n }\n })\n\n return hasChanged\n }, [data, snapshot])\n\n return { hasContentChanged }\n}\n"],"mappings":";;AAAA,SAASA,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAC3C,OAAOC,OAAO,MAAM,0BAA0B;AAC9C,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,sBAAsB,MAAM,0BAA0B;AAE7D,eAAe,SAASC,oBAAoBA,CAAA,EAAG;EAC7C,MAAM;IAAEC;EAAgB,CAAC,GAAGN,UAAU,CAACG,WAAW,CAAC;EACnD,MAAM;IAAEI;EAAY,CAAC,GAAGH,sBAAsB,CAAC;IAAEI,OAAO,EAAE;EAAK,CAAC,CAAC;EAEjE,MAAMC,IAAI,GAAGH,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAEI,OAAO;EACrC,MAAMC,QAAQ,GAAGJ,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEG,OAAO;EACrC,MAAME,iBAAiB,GAAGX,OAAO,CAAC,MAAM;IACtC,IAAI,CAACQ,IAAI,IAAI,CAACE,QAAQ,EAAE;MACtB,OAAOE,SAAS;IAClB;IAEA,IAAIC,UAAU,GAAG,KAAK;IAEtBZ,OAAO,CAACa,IAAI,CAACN,IAAI,EAAE,CAACO,KAAK,EAAEC,IAAI,KAAK;MAClC,IACEf,OAAO,CAACgB,GAAG,CAACP,QAAQ,EAAEM,IAAI,CAAC,IAC3Bf,OAAO,CAACiB,GAAG,CAACR,QAAQ,EAAEM,IAAI,CAAC,KAAKD,KAAK,EACrC;QACAF,UAAU,GAAG,IAAI;QACjB,OAAO,KAAK;MACd;IACF,CAAC,CAAC;IAEF,OAAOA,UAAU;EACnB,CAAC,EAAE,CAACL,IAAI,EAAEE,QAAQ,CAAC,CAAC;EAEpB,OAAO;IAAEC;EAAkB,CAAC;AAC9B","ignoreList":[]}
1
+ {"version":3,"file":"useHasContentChanged.js","names":["useContext","useMemo","pointer","DataContext","useDataContextSnapshot","useHasContentChanged","enabled","internalDataRef","snapshotRef","data","current","snapshot","hasContentChanged","undefined","hasChanged","walk","value","path","exists","has","get"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useHasContentChanged.ts"],"sourcesContent":["import { useContext, useMemo } from 'react'\nimport pointer from '../../utils/json-pointer'\nimport DataContext from '../../DataContext/Context'\nimport useDataContextSnapshot from './useDataContextSnapshot'\n\nexport default function useHasContentChanged({\n enabled = false,\n}: {\n enabled?: boolean\n} = {}) {\n const { internalDataRef } = useContext(DataContext)\n const { snapshotRef } = useDataContextSnapshot({ enabled })\n\n const data = internalDataRef?.current\n const snapshot = snapshotRef?.current // To support a custom data reference, we need to have a snapshot in the hook deps.\n\n const hasContentChanged = useMemo(() => {\n if (!data || !snapshot) {\n return undefined\n }\n\n let hasChanged = false\n\n pointer.walk(data, (value, path) => {\n const exists = pointer.has(snapshot, path)\n if (!exists || (exists && pointer.get(snapshot, path) !== value)) {\n hasChanged = true\n return false\n }\n })\n\n return hasChanged\n }, [data, snapshot])\n\n return { hasContentChanged }\n}\n"],"mappings":";;AAAA,SAASA,UAAU,EAAEC,OAAO,QAAQ,OAAO;AAC3C,OAAOC,OAAO,MAAM,0BAA0B;AAC9C,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,sBAAsB,MAAM,0BAA0B;AAE7D,eAAe,SAASC,oBAAoBA,CAAC;EAC3CC,OAAO,GAAG;AAGZ,CAAC,GAAG,CAAC,CAAC,EAAE;EACN,MAAM;IAAEC;EAAgB,CAAC,GAAGP,UAAU,CAACG,WAAW,CAAC;EACnD,MAAM;IAAEK;EAAY,CAAC,GAAGJ,sBAAsB,CAAC;IAAEE;EAAQ,CAAC,CAAC;EAE3D,MAAMG,IAAI,GAAGF,eAAe,aAAfA,eAAe,uBAAfA,eAAe,CAAEG,OAAO;EACrC,MAAMC,QAAQ,GAAGH,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEE,OAAO;EAErC,MAAME,iBAAiB,GAAGX,OAAO,CAAC,MAAM;IACtC,IAAI,CAACQ,IAAI,IAAI,CAACE,QAAQ,EAAE;MACtB,OAAOE,SAAS;IAClB;IAEA,IAAIC,UAAU,GAAG,KAAK;IAEtBZ,OAAO,CAACa,IAAI,CAACN,IAAI,EAAE,CAACO,KAAK,EAAEC,IAAI,KAAK;MAClC,MAAMC,MAAM,GAAGhB,OAAO,CAACiB,GAAG,CAACR,QAAQ,EAAEM,IAAI,CAAC;MAC1C,IAAI,CAACC,MAAM,IAAKA,MAAM,IAAIhB,OAAO,CAACkB,GAAG,CAACT,QAAQ,EAAEM,IAAI,CAAC,KAAKD,KAAM,EAAE;QAChEF,UAAU,GAAG,IAAI;QACjB,OAAO,KAAK;MACd;IACF,CAAC,CAAC;IAEF,OAAOA,UAAU;EACnB,CAAC,EAAE,CAACL,IAAI,EAAEE,QAAQ,CAAC,CAAC;EAEpB,OAAO;IAAEC;EAAkB,CAAC;AAC9B","ignoreList":[]}
@@ -1,2 +1,2 @@
1
1
  import { ContextState } from '../../DataContext';
2
- export default function useReportError(error: Error, customDataContext?: ContextState): void;
2
+ export default function useReportError(error: Error, customDataContext?: ContextState, name?: string): void;
@@ -5,13 +5,20 @@ import useId from '../../../../shared/helpers/useId';
5
5
  import DataContext from '../../DataContext/Context';
6
6
  import WizardStepContext from '../../Wizard/Step/StepContext';
7
7
  import WizardContext from '../../Wizard/Context';
8
- export default function useReportError(error, customDataContext) {
8
+ import VisibilityContext from '../Visibility/VisibilityContext';
9
+ import { usePath } from '../../hooks';
10
+ export default function useReportError(error, customDataContext, name) {
11
+ const {
12
+ joinPath
13
+ } = usePath();
9
14
  const dataContext = useContext(DataContext);
10
15
  const wizardContext = useContext(WizardContext);
11
16
  const wizardStepContext = useContext(WizardStepContext);
17
+ const visibilityContext = useContext(VisibilityContext);
12
18
  const {
13
19
  setFieldError: setFieldErrorDataContext,
14
- setMountedFieldState
20
+ setMountedFieldState,
21
+ prerenderFieldProps
15
22
  } = customDataContext || dataContext;
16
23
  const {
17
24
  setFieldError: setFieldErrorWizard
@@ -19,16 +26,24 @@ export default function useReportError(error, customDataContext) {
19
26
  const {
20
27
  index: wizardIndex
21
28
  } = wizardStepContext || {};
29
+ const {
30
+ isVisible
31
+ } = visibilityContext || {};
32
+ const handleFieldAsVisible = isVisible;
22
33
  const id = useId();
23
34
  useEffect(() => {
24
- const path = `/${id}`;
25
- if (error) {
35
+ if (prerenderFieldProps) {
36
+ return;
37
+ }
38
+ const path = joinPath(['internal', name, id]);
39
+ const currentError = handleFieldAsVisible !== false ? error : undefined;
40
+ if (currentError) {
26
41
  setMountedFieldState === null || setMountedFieldState === void 0 ? void 0 : setMountedFieldState(path, {
27
42
  isMounted: true
28
43
  });
29
44
  }
30
- setFieldErrorWizard === null || setFieldErrorWizard === void 0 ? void 0 : setFieldErrorWizard(wizardIndex, path, error ? true : undefined);
31
- setFieldErrorDataContext === null || setFieldErrorDataContext === void 0 ? void 0 : setFieldErrorDataContext(path, error);
45
+ setFieldErrorWizard === null || setFieldErrorWizard === void 0 ? void 0 : setFieldErrorWizard(wizardIndex, path, currentError ? true : undefined);
46
+ setFieldErrorDataContext === null || setFieldErrorDataContext === void 0 ? void 0 : setFieldErrorDataContext(path, currentError);
32
47
  return () => {
33
48
  setMountedFieldState === null || setMountedFieldState === void 0 ? void 0 : setMountedFieldState(path, {
34
49
  isMounted: false
@@ -36,6 +51,6 @@ export default function useReportError(error, customDataContext) {
36
51
  setFieldErrorWizard === null || setFieldErrorWizard === void 0 ? void 0 : setFieldErrorWizard(wizardIndex, path, undefined);
37
52
  setFieldErrorDataContext === null || setFieldErrorDataContext === void 0 ? void 0 : setFieldErrorDataContext(path, undefined);
38
53
  };
39
- }, [error, id, setFieldErrorDataContext, setFieldErrorWizard, setMountedFieldState, wizardIndex]);
54
+ }, [error, handleFieldAsVisible, id, joinPath, name, prerenderFieldProps, setFieldErrorDataContext, setFieldErrorWizard, setMountedFieldState, wizardIndex]);
40
55
  }
41
56
  //# sourceMappingURL=useReportError.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useReportError.js","names":["useContext","useEffect","useId","DataContext","WizardStepContext","WizardContext","useReportError","error","customDataContext","dataContext","wizardContext","wizardStepContext","setFieldError","setFieldErrorDataContext","setMountedFieldState","setFieldErrorWizard","index","wizardIndex","id","path","isMounted","undefined"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useReportError.ts"],"sourcesContent":["import { useContext, useEffect } from 'react'\nimport useId from '../../../../shared/helpers/useId'\nimport { ContextState } from '../../DataContext'\nimport DataContext from '../../DataContext/Context'\nimport WizardStepContext from '../../Wizard/Step/StepContext'\nimport WizardContext from '../../Wizard/Context'\n\nexport default function useReportError(\n error: Error,\n customDataContext?: ContextState\n) {\n const dataContext = useContext(DataContext)\n const wizardContext = useContext(WizardContext)\n const wizardStepContext = useContext(WizardStepContext)\n\n const { setFieldError: setFieldErrorDataContext, setMountedFieldState } =\n customDataContext || dataContext\n const { setFieldError: setFieldErrorWizard } = wizardContext || {}\n const { index: wizardIndex } = wizardStepContext || {}\n\n const id = useId()\n useEffect(() => {\n const path = `/${id}`\n\n if (error) {\n setMountedFieldState?.(path, {\n isMounted: true,\n })\n }\n\n setFieldErrorWizard?.(wizardIndex, path, error ? true : undefined)\n setFieldErrorDataContext?.(path, error)\n\n // Unmount procedure\n return () => {\n setMountedFieldState?.(path, {\n isMounted: false,\n })\n\n setFieldErrorWizard?.(wizardIndex, path, undefined)\n setFieldErrorDataContext?.(path, undefined)\n }\n }, [\n error,\n id,\n setFieldErrorDataContext,\n setFieldErrorWizard,\n setMountedFieldState,\n wizardIndex,\n ])\n}\n"],"mappings":";;AAAA,SAASA,UAAU,EAAEC,SAAS,QAAQ,OAAO;AAC7C,OAAOC,KAAK,MAAM,kCAAkC;AAEpD,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,iBAAiB,MAAM,+BAA+B;AAC7D,OAAOC,aAAa,MAAM,sBAAsB;AAEhD,eAAe,SAASC,cAAcA,CACpCC,KAAY,EACZC,iBAAgC,EAChC;EACA,MAAMC,WAAW,GAAGT,UAAU,CAACG,WAAW,CAAC;EAC3C,MAAMO,aAAa,GAAGV,UAAU,CAACK,aAAa,CAAC;EAC/C,MAAMM,iBAAiB,GAAGX,UAAU,CAACI,iBAAiB,CAAC;EAEvD,MAAM;IAAEQ,aAAa,EAAEC,wBAAwB;IAAEC;EAAqB,CAAC,GACrEN,iBAAiB,IAAIC,WAAW;EAClC,MAAM;IAAEG,aAAa,EAAEG;EAAoB,CAAC,GAAGL,aAAa,IAAI,CAAC,CAAC;EAClE,MAAM;IAAEM,KAAK,EAAEC;EAAY,CAAC,GAAGN,iBAAiB,IAAI,CAAC,CAAC;EAEtD,MAAMO,EAAE,GAAGhB,KAAK,CAAC,CAAC;EAClBD,SAAS,CAAC,MAAM;IACd,MAAMkB,IAAI,GAAG,IAAID,EAAE,EAAE;IAErB,IAAIX,KAAK,EAAE;MACTO,oBAAoB,aAApBA,oBAAoB,uBAApBA,oBAAoB,CAAGK,IAAI,EAAE;QAC3BC,SAAS,EAAE;MACb,CAAC,CAAC;IACJ;IAEAL,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAGE,WAAW,EAAEE,IAAI,EAAEZ,KAAK,GAAG,IAAI,GAAGc,SAAS,CAAC;IAClER,wBAAwB,aAAxBA,wBAAwB,uBAAxBA,wBAAwB,CAAGM,IAAI,EAAEZ,KAAK,CAAC;IAGvC,OAAO,MAAM;MACXO,oBAAoB,aAApBA,oBAAoB,uBAApBA,oBAAoB,CAAGK,IAAI,EAAE;QAC3BC,SAAS,EAAE;MACb,CAAC,CAAC;MAEFL,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAGE,WAAW,EAAEE,IAAI,EAAEE,SAAS,CAAC;MACnDR,wBAAwB,aAAxBA,wBAAwB,uBAAxBA,wBAAwB,CAAGM,IAAI,EAAEE,SAAS,CAAC;IAC7C,CAAC;EACH,CAAC,EAAE,CACDd,KAAK,EACLW,EAAE,EACFL,wBAAwB,EACxBE,mBAAmB,EACnBD,oBAAoB,EACpBG,WAAW,CACZ,CAAC;AACJ","ignoreList":[]}
1
+ {"version":3,"file":"useReportError.js","names":["useContext","useEffect","useId","DataContext","WizardStepContext","WizardContext","VisibilityContext","usePath","useReportError","error","customDataContext","name","joinPath","dataContext","wizardContext","wizardStepContext","visibilityContext","setFieldError","setFieldErrorDataContext","setMountedFieldState","prerenderFieldProps","setFieldErrorWizard","index","wizardIndex","isVisible","handleFieldAsVisible","id","path","currentError","undefined","isMounted"],"sources":["../../../../../../src/extensions/forms/Form/Isolation/useReportError.ts"],"sourcesContent":["import { useContext, useEffect } from 'react'\nimport useId from '../../../../shared/helpers/useId'\nimport { ContextState } from '../../DataContext'\nimport DataContext from '../../DataContext/Context'\nimport WizardStepContext from '../../Wizard/Step/StepContext'\nimport WizardContext from '../../Wizard/Context'\nimport VisibilityContext from '../Visibility/VisibilityContext'\nimport { usePath } from '../../hooks'\n\nexport default function useReportError(\n error: Error,\n customDataContext?: ContextState,\n name?: string\n) {\n const { joinPath } = usePath()\n const dataContext = useContext(DataContext)\n const wizardContext = useContext(WizardContext)\n const wizardStepContext = useContext(WizardStepContext)\n const visibilityContext = useContext(VisibilityContext)\n\n const {\n setFieldError: setFieldErrorDataContext,\n setMountedFieldState,\n prerenderFieldProps,\n } = customDataContext || dataContext\n const { setFieldError: setFieldErrorWizard } = wizardContext || {}\n const { index: wizardIndex } = wizardStepContext || {}\n const { isVisible } = visibilityContext || {}\n const handleFieldAsVisible = isVisible\n\n const id = useId()\n useEffect(() => {\n if (prerenderFieldProps) {\n return // stop here\n }\n\n const path = joinPath(['internal', name, id])\n const currentError = handleFieldAsVisible !== false ? error : undefined\n\n if (currentError) {\n setMountedFieldState?.(path, {\n isMounted: true,\n })\n }\n\n setFieldErrorWizard?.(\n wizardIndex,\n path,\n currentError ? true : undefined\n )\n\n setFieldErrorDataContext?.(path, currentError)\n\n // Unmount procedure\n return () => {\n setMountedFieldState?.(path, {\n isMounted: false,\n })\n\n setFieldErrorWizard?.(wizardIndex, path, undefined)\n setFieldErrorDataContext?.(path, undefined)\n }\n }, [\n error,\n handleFieldAsVisible,\n id,\n joinPath,\n name,\n prerenderFieldProps,\n setFieldErrorDataContext,\n setFieldErrorWizard,\n setMountedFieldState,\n wizardIndex,\n ])\n}\n"],"mappings":";;AAAA,SAASA,UAAU,EAAEC,SAAS,QAAQ,OAAO;AAC7C,OAAOC,KAAK,MAAM,kCAAkC;AAEpD,OAAOC,WAAW,MAAM,2BAA2B;AACnD,OAAOC,iBAAiB,MAAM,+BAA+B;AAC7D,OAAOC,aAAa,MAAM,sBAAsB;AAChD,OAAOC,iBAAiB,MAAM,iCAAiC;AAC/D,SAASC,OAAO,QAAQ,aAAa;AAErC,eAAe,SAASC,cAAcA,CACpCC,KAAY,EACZC,iBAAgC,EAChCC,IAAa,EACb;EACA,MAAM;IAAEC;EAAS,CAAC,GAAGL,OAAO,CAAC,CAAC;EAC9B,MAAMM,WAAW,GAAGb,UAAU,CAACG,WAAW,CAAC;EAC3C,MAAMW,aAAa,GAAGd,UAAU,CAACK,aAAa,CAAC;EAC/C,MAAMU,iBAAiB,GAAGf,UAAU,CAACI,iBAAiB,CAAC;EACvD,MAAMY,iBAAiB,GAAGhB,UAAU,CAACM,iBAAiB,CAAC;EAEvD,MAAM;IACJW,aAAa,EAAEC,wBAAwB;IACvCC,oBAAoB;IACpBC;EACF,CAAC,GAAGV,iBAAiB,IAAIG,WAAW;EACpC,MAAM;IAAEI,aAAa,EAAEI;EAAoB,CAAC,GAAGP,aAAa,IAAI,CAAC,CAAC;EAClE,MAAM;IAAEQ,KAAK,EAAEC;EAAY,CAAC,GAAGR,iBAAiB,IAAI,CAAC,CAAC;EACtD,MAAM;IAAES;EAAU,CAAC,GAAGR,iBAAiB,IAAI,CAAC,CAAC;EAC7C,MAAMS,oBAAoB,GAAGD,SAAS;EAEtC,MAAME,EAAE,GAAGxB,KAAK,CAAC,CAAC;EAClBD,SAAS,CAAC,MAAM;IACd,IAAImB,mBAAmB,EAAE;MACvB;IACF;IAEA,MAAMO,IAAI,GAAGf,QAAQ,CAAC,CAAC,UAAU,EAAED,IAAI,EAAEe,EAAE,CAAC,CAAC;IAC7C,MAAME,YAAY,GAAGH,oBAAoB,KAAK,KAAK,GAAGhB,KAAK,GAAGoB,SAAS;IAEvE,IAAID,YAAY,EAAE;MAChBT,oBAAoB,aAApBA,oBAAoB,uBAApBA,oBAAoB,CAAGQ,IAAI,EAAE;QAC3BG,SAAS,EAAE;MACb,CAAC,CAAC;IACJ;IAEAT,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CACjBE,WAAW,EACXI,IAAI,EACJC,YAAY,GAAG,IAAI,GAAGC,SACxB,CAAC;IAEDX,wBAAwB,aAAxBA,wBAAwB,uBAAxBA,wBAAwB,CAAGS,IAAI,EAAEC,YAAY,CAAC;IAG9C,OAAO,MAAM;MACXT,oBAAoB,aAApBA,oBAAoB,uBAApBA,oBAAoB,CAAGQ,IAAI,EAAE;QAC3BG,SAAS,EAAE;MACb,CAAC,CAAC;MAEFT,mBAAmB,aAAnBA,mBAAmB,uBAAnBA,mBAAmB,CAAGE,WAAW,EAAEI,IAAI,EAAEE,SAAS,CAAC;MACnDX,wBAAwB,aAAxBA,wBAAwB,uBAAxBA,wBAAwB,CAAGS,IAAI,EAAEE,SAAS,CAAC;IAC7C,CAAC;EACH,CAAC,EAAE,CACDpB,KAAK,EACLgB,oBAAoB,EACpBC,EAAE,EACFd,QAAQ,EACRD,IAAI,EACJS,mBAAmB,EACnBF,wBAAwB,EACxBG,mBAAmB,EACnBF,oBAAoB,EACpBI,WAAW,CACZ,CAAC;AACJ","ignoreList":[]}
@@ -5,6 +5,7 @@ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbol
5
5
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
6
6
  import React, { useCallback, useContext, useMemo, useReducer, useRef } from 'react';
7
7
  import DataContext from '../../DataContext/Context';
8
+ import useEventListener from '../../DataContext/Provider/useEventListener';
8
9
  import SharedProvider from '../../../../shared/Provider';
9
10
  import { HeightAnimation } from '../../../../components';
10
11
  import { removeUndefinedProps } from '../../../../shared/component-helper';
@@ -19,7 +20,6 @@ function SubmitConfirmation(props) {
19
20
  } = props;
20
21
  const {
21
22
  setFormState,
22
- setFieldEventListener,
23
23
  handleSubmit: handleFinalSubmit,
24
24
  submitState,
25
25
  formElementRef,
@@ -118,16 +118,16 @@ function SubmitConfirmation(props) {
118
118
  preventSubmit();
119
119
  await setConfirmationState('readyToBeSubmitted');
120
120
  }, [setConfirmationState, validatePreventSubmit]);
121
- setFieldEventListener === null || setFieldEventListener === void 0 ? void 0 : setFieldEventListener(undefined, 'onSubmit', handleSubmit);
121
+ const {
122
+ removeEvent
123
+ } = useEventListener('onSubmit', handleSubmit);
122
124
  const submitHandler = useCallback(async () => {
123
- setFieldEventListener === null || setFieldEventListener === void 0 ? void 0 : setFieldEventListener(undefined, 'onSubmit', handleSubmit, {
124
- remove: true
125
- });
125
+ removeEvent();
126
126
  await setConfirmationState('submitInProgress');
127
127
  await handleFinalSubmit();
128
128
  await setConfirmationState('submissionComplete');
129
129
  setFocusOnButton();
130
- }, [handleFinalSubmit, handleSubmit, setFocusOnButton, setFieldEventListener, setConfirmationState]);
130
+ }, [removeEvent, setConfirmationState, handleFinalSubmit, setFocusOnButton]);
131
131
  const sharedProviderParams = {
132
132
  formElement: {
133
133
  disabled: false
@@ -1 +1 @@
1
- {"version":3,"file":"SubmitConfirmation.js","names":["React","useCallback","useContext","useMemo","useReducer","useRef","DataContext","SharedProvider","HeightAnimation","removeUndefinedProps","SubmitConfirmation","props","forceUpdate","preventSubmitWhen","onStateChange","onSubmitResult","renderWithState","children","setFormState","setFieldEventListener","handleSubmit","handleFinalSubmit","submitState","formElementRef","internalDataRef","confirmationStateRef","submitStateRef","preventSubmitRef","undefined","validatePreventSubmit","current","getParamsRef","setConfirmationState","state","window","requestAnimationFrame","keepPending","confirmationState","connectWithDialog","openState","onConfirm","submitHandler","onDecline","cancelHandler","onClose","triggeredBy","data","Object","keys","length","_objectSpread","setFocusOnButton","form","element","querySelector","focus","e","preventSubmit","remove","sharedProviderParams","formElement","disabled","createElement","Fragment","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport DataContext from '../../DataContext/Context'\nimport SharedProvider from '../../../../shared/Provider'\nimport { ContextProps } from '../../../../shared/Context'\nimport { HeightAnimation } from '../../../../components'\nimport {\n DialogContentProps,\n DialogProps,\n} from '../../../../components/dialog/types'\nimport { EventStateObject } from '../../types'\nimport { removeUndefinedProps } from '../../../../shared/component-helper'\n\nexport type ConfirmationState =\n | 'idle'\n | 'readyToBeSubmitted'\n | 'submitInProgress'\n | 'submissionComplete'\n\nexport type ConfirmParams = {\n data: unknown\n confirmationState: ConfirmationState\n submitState: EventStateObject | undefined\n connectWithDialog: Pick<\n DialogProps & DialogContentProps,\n 'openState' | 'onConfirm' | 'onDecline' | 'onClose'\n >\n setConfirmationState: (state: ConfirmationState) => void\n submitHandler: () => void | Promise<void>\n cancelHandler: () => void | Promise<void>\n}\n\nexport type ConfirmProps = {\n preventSubmitWhen?: (params: ConfirmParams) => boolean\n onStateChange?: (params: ConfirmParams) => void | Promise<void>\n onSubmitResult?: (params: ConfirmParams) => void\n renderWithState?: (params: ConfirmParams) => React.ReactNode\n children?: React.ReactNode\n}\n\nfunction SubmitConfirmation(props: ConfirmProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n preventSubmitWhen,\n onStateChange,\n onSubmitResult,\n renderWithState,\n children,\n } = props\n\n const {\n setFormState,\n setFieldEventListener,\n handleSubmit: handleFinalSubmit,\n submitState,\n formElementRef,\n internalDataRef,\n } = useContext(DataContext)\n\n const confirmationStateRef = useRef<ConfirmationState>('idle')\n const submitStateRef = useRef<EventStateObject>()\n const preventSubmitRef = useRef<boolean>(undefined)\n\n const validatePreventSubmit = useCallback(() => {\n return (preventSubmitRef.current = preventSubmitWhen?.(\n getParamsRef.current()\n ))\n }, [preventSubmitWhen])\n\n const setConfirmationState = useCallback(\n async (state: ConfirmationState) => {\n confirmationStateRef.current = state\n await onStateChange?.(getParamsRef.current())\n if (typeof window !== 'undefined') {\n window.requestAnimationFrame(() => {\n switch (state) {\n case 'idle':\n setFormState('complete', { keepPending: false })\n break\n case 'readyToBeSubmitted':\n setFormState('pending', { keepPending: true })\n break\n case 'submitInProgress':\n setFormState('pending', { keepPending: true })\n break\n case 'submissionComplete':\n setFormState('complete', { keepPending: false })\n break\n default:\n forceUpdate()\n }\n })\n }\n },\n [onStateChange, setFormState]\n )\n\n const getParamsRef = useRef(() => {\n const confirmationState = confirmationStateRef.current\n\n const connectWithDialog = {\n openState: confirmationState === 'readyToBeSubmitted',\n onConfirm: submitHandler,\n onDecline: cancelHandler,\n onClose: ({ triggeredBy }) => {\n if (triggeredBy === 'keyboard') {\n cancelHandler()\n }\n },\n }\n\n return {\n data: internalDataRef?.current,\n confirmationState,\n setConfirmationState,\n submitHandler,\n cancelHandler,\n connectWithDialog,\n submitState: submitStateRef.current,\n } satisfies ConfirmParams\n })\n\n useMemo(() => {\n if (Object.keys(removeUndefinedProps(submitState) || {}).length > 0) {\n submitStateRef.current = {\n ...submitState,\n } as EventStateObject\n onSubmitResult?.(getParamsRef.current())\n }\n }, [submitState, onSubmitResult])\n\n const setFocusOnButton = useCallback(() => {\n try {\n const form = formElementRef.current\n const element = (form.querySelector('.dnb-forms-submit-button') ||\n form) as HTMLElement\n element.focus()\n } catch (e) {\n //\n }\n }, [formElementRef])\n\n const cancelHandler = useCallback(async () => {\n await setConfirmationState('idle')\n setFocusOnButton()\n }, [setFocusOnButton, setConfirmationState])\n\n const handleSubmit = useCallback(\n async ({ preventSubmit }) => {\n if (confirmationStateRef.current === 'submitInProgress') {\n return // stop here\n }\n\n if (validatePreventSubmit() !== true) {\n await setConfirmationState('submitInProgress')\n return // stop here\n }\n\n submitStateRef.current = undefined\n\n // Prevent the form form from being submitted\n preventSubmit()\n\n await setConfirmationState('readyToBeSubmitted')\n },\n [setConfirmationState, validatePreventSubmit]\n )\n setFieldEventListener?.(undefined, 'onSubmit', handleSubmit)\n\n const submitHandler = useCallback(async () => {\n setFieldEventListener?.(undefined, 'onSubmit', handleSubmit, {\n remove: true,\n })\n\n await setConfirmationState('submitInProgress')\n await handleFinalSubmit()\n await setConfirmationState('submissionComplete')\n\n setFocusOnButton()\n }, [\n handleFinalSubmit,\n handleSubmit,\n setFocusOnButton,\n setFieldEventListener,\n setConfirmationState,\n ])\n\n const sharedProviderParams: ContextProps = {\n formElement: {\n disabled: false,\n },\n }\n\n return (\n <>\n {children}\n\n <SharedProvider {...sharedProviderParams}>\n <HeightAnimation>\n {renderWithState?.(getParamsRef.current())}\n </HeightAnimation>\n </SharedProvider>\n </>\n )\n}\n\nSubmitConfirmation._supportsSpacingProps = 'children'\nexport default SubmitConfirmation\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"SubmitConfirmation.js","names":["React","useCallback","useContext","useMemo","useReducer","useRef","DataContext","useEventListener","SharedProvider","HeightAnimation","removeUndefinedProps","SubmitConfirmation","props","forceUpdate","preventSubmitWhen","onStateChange","onSubmitResult","renderWithState","children","setFormState","handleSubmit","handleFinalSubmit","submitState","formElementRef","internalDataRef","confirmationStateRef","submitStateRef","preventSubmitRef","undefined","validatePreventSubmit","current","getParamsRef","setConfirmationState","state","window","requestAnimationFrame","keepPending","confirmationState","connectWithDialog","openState","onConfirm","submitHandler","onDecline","cancelHandler","onClose","triggeredBy","data","Object","keys","length","_objectSpread","setFocusOnButton","form","element","querySelector","focus","e","preventSubmit","removeEvent","sharedProviderParams","formElement","disabled","createElement","Fragment","_supportsSpacingProps"],"sources":["../../../../../../src/extensions/forms/Form/SubmitConfirmation/SubmitConfirmation.tsx"],"sourcesContent":["import React, {\n useCallback,\n useContext,\n useMemo,\n useReducer,\n useRef,\n} from 'react'\nimport DataContext from '../../DataContext/Context'\nimport useEventListener from '../../DataContext/Provider/useEventListener'\nimport SharedProvider from '../../../../shared/Provider'\nimport { ContextProps } from '../../../../shared/Context'\nimport { HeightAnimation } from '../../../../components'\nimport {\n DialogContentProps,\n DialogProps,\n} from '../../../../components/dialog/types'\nimport { EventStateObject } from '../../types'\nimport { removeUndefinedProps } from '../../../../shared/component-helper'\n\nexport type ConfirmationState =\n | 'idle'\n | 'readyToBeSubmitted'\n | 'submitInProgress'\n | 'submissionComplete'\n\nexport type ConfirmParams = {\n data: unknown\n confirmationState: ConfirmationState\n submitState: EventStateObject | undefined\n connectWithDialog: Pick<\n DialogProps & DialogContentProps,\n 'openState' | 'onConfirm' | 'onDecline' | 'onClose'\n >\n setConfirmationState: (state: ConfirmationState) => void\n submitHandler: () => void | Promise<void>\n cancelHandler: () => void | Promise<void>\n}\n\nexport type ConfirmProps = {\n preventSubmitWhen?: (params: ConfirmParams) => boolean\n onStateChange?: (params: ConfirmParams) => void | Promise<void>\n onSubmitResult?: (params: ConfirmParams) => void\n renderWithState?: (params: ConfirmParams) => React.ReactNode\n children?: React.ReactNode\n}\n\nfunction SubmitConfirmation(props: ConfirmProps) {\n const [, forceUpdate] = useReducer(() => ({}), {})\n\n const {\n preventSubmitWhen,\n onStateChange,\n onSubmitResult,\n renderWithState,\n children,\n } = props\n\n const {\n setFormState,\n handleSubmit: handleFinalSubmit,\n submitState,\n formElementRef,\n internalDataRef,\n } = useContext(DataContext)\n\n const confirmationStateRef = useRef<ConfirmationState>('idle')\n const submitStateRef = useRef<EventStateObject>()\n const preventSubmitRef = useRef<boolean>(undefined)\n\n const validatePreventSubmit = useCallback(() => {\n return (preventSubmitRef.current = preventSubmitWhen?.(\n getParamsRef.current()\n ))\n }, [preventSubmitWhen])\n\n const setConfirmationState = useCallback(\n async (state: ConfirmationState) => {\n confirmationStateRef.current = state\n await onStateChange?.(getParamsRef.current())\n if (typeof window !== 'undefined') {\n window.requestAnimationFrame(() => {\n switch (state) {\n case 'idle':\n setFormState('complete', { keepPending: false })\n break\n case 'readyToBeSubmitted':\n setFormState('pending', { keepPending: true })\n break\n case 'submitInProgress':\n setFormState('pending', { keepPending: true })\n break\n case 'submissionComplete':\n setFormState('complete', { keepPending: false })\n break\n default:\n forceUpdate()\n }\n })\n }\n },\n [onStateChange, setFormState]\n )\n\n const getParamsRef = useRef(() => {\n const confirmationState = confirmationStateRef.current\n\n const connectWithDialog = {\n openState: confirmationState === 'readyToBeSubmitted',\n onConfirm: submitHandler,\n onDecline: cancelHandler,\n onClose: ({ triggeredBy }) => {\n if (triggeredBy === 'keyboard') {\n cancelHandler()\n }\n },\n }\n\n return {\n data: internalDataRef?.current,\n confirmationState,\n setConfirmationState,\n submitHandler,\n cancelHandler,\n connectWithDialog,\n submitState: submitStateRef.current,\n } satisfies ConfirmParams\n })\n\n useMemo(() => {\n if (Object.keys(removeUndefinedProps(submitState) || {}).length > 0) {\n submitStateRef.current = {\n ...submitState,\n } as EventStateObject\n onSubmitResult?.(getParamsRef.current())\n }\n }, [submitState, onSubmitResult])\n\n const setFocusOnButton = useCallback(() => {\n try {\n const form = formElementRef.current\n const element = (form.querySelector('.dnb-forms-submit-button') ||\n form) as HTMLElement\n element.focus()\n } catch (e) {\n //\n }\n }, [formElementRef])\n\n const cancelHandler = useCallback(async () => {\n await setConfirmationState('idle')\n setFocusOnButton()\n }, [setFocusOnButton, setConfirmationState])\n\n const handleSubmit = useCallback(\n async ({ preventSubmit }) => {\n if (confirmationStateRef.current === 'submitInProgress') {\n return // stop here\n }\n\n if (validatePreventSubmit() !== true) {\n await setConfirmationState('submitInProgress')\n return // stop here\n }\n\n submitStateRef.current = undefined\n\n // Prevent the form form from being submitted\n preventSubmit()\n\n await setConfirmationState('readyToBeSubmitted')\n },\n [setConfirmationState, validatePreventSubmit]\n )\n const { removeEvent } = useEventListener('onSubmit', handleSubmit)\n\n const submitHandler = useCallback(async () => {\n removeEvent()\n\n await setConfirmationState('submitInProgress')\n await handleFinalSubmit()\n await setConfirmationState('submissionComplete')\n\n setFocusOnButton()\n }, [\n removeEvent,\n setConfirmationState,\n handleFinalSubmit,\n setFocusOnButton,\n ])\n\n const sharedProviderParams: ContextProps = {\n formElement: {\n disabled: false,\n },\n }\n\n return (\n <>\n {children}\n\n <SharedProvider {...sharedProviderParams}>\n <HeightAnimation>\n {renderWithState?.(getParamsRef.current())}\n </HeightAnimation>\n </SharedProvider>\n </>\n )\n}\n\nSubmitConfirmation._supportsSpacingProps = 'children'\nexport default SubmitConfirmation\n"],"mappings":"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","ignoreList":[]}
@@ -37,7 +37,9 @@ export default function ResetButton(props) {
37
37
  } = useContext(ToolbarContext) || {};
38
38
  const {
39
39
  hasContentChanged
40
- } = useHasContentChanged();
40
+ } = useHasContentChanged({
41
+ enabled: true
42
+ });
41
43
  const buttonProps = omitDataValueReadWriteProps(restProps);
42
44
  const {
43
45
  resetButton
@@ -1 +1 @@
1
- {"version":3,"file":"ResetButton.js","names":["React","useCallback","useContext","classnames","Button","Dialog","useTranslation","IterateItemContext","ToolbarContext","FieldBoundaryContext","reset","useHasContentChanged","omitDataValueReadWriteProps","ResetButton","props","text","children","onClick","className","hidden","showConfirmDialog","restProps","_objectWithoutProperties","_excluded","restoreOriginalValue","setShowBoundaryErrors","setShowError","hasContentChanged","buttonProps","resetButton","IterateEditContainer","confirmResetText","textContent","buttonWrapperRef","useRef","handleClick","close","event","_buttonWrapperRef$cur","current","focus","triggerAttributes","_objectSpread","variant","icon","icon_position","disabled","createElement","tabIndex","ref","title","onConfirm","_extends","on_click"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/ResetButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button, Dialog } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { reset } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport useHasContentChanged from '../../Form/Isolation/useHasContentChanged'\nimport { omitDataValueReadWriteProps } from '../../types'\n\ntype Props = ButtonProps & {\n showConfirmDialog?: boolean\n}\n\nexport default function ResetButton(props: Props) {\n const {\n text,\n children,\n onClick,\n className,\n hidden,\n showConfirmDialog = true,\n ...restProps\n } = props\n const { restoreOriginalValue } = useContext(IterateItemContext) || {}\n const { setShowBoundaryErrors } = useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n const { hasContentChanged } = useHasContentChanged()\n\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const { resetButton } = useTranslation().IterateEditContainer\n const { confirmResetText } = useTranslation().IterateEditContainer\n const textContent = text || children || resetButton\n\n const buttonWrapperRef = React.useRef<HTMLButtonElement>(null)\n const handleClick = useCallback(\n ({ close, event }) => {\n close?.()\n onClick?.(event)\n restoreOriginalValue?.()\n setShowError(false)\n setShowBoundaryErrors?.(false)\n buttonWrapperRef.current?.focus()\n },\n [onClick, restoreOriginalValue, setShowBoundaryErrors, setShowError]\n )\n\n if (hidden) {\n return null\n }\n\n const triggerAttributes: ButtonProps = {\n className: classnames('dnb-forms-iterate__reset-button', className),\n text: textContent,\n variant: textContent ? 'tertiary' : 'secondary',\n icon: reset,\n icon_position: 'left',\n disabled:\n typeof hasContentChanged === 'boolean' ? !hasContentChanged : false,\n ...buttonProps,\n }\n\n return (\n <span tabIndex={-1} ref={buttonWrapperRef} className=\"dnb-no-focus\">\n {showConfirmDialog ? (\n <Dialog\n variant=\"confirmation\"\n title={confirmResetText}\n triggerAttributes={triggerAttributes}\n onConfirm={handleClick}\n />\n ) : (\n <Button\n {...triggerAttributes}\n on_click={handleClick}\n {...buttonProps}\n >\n {resetButton}\n </Button>\n )}\n </span>\n )\n}\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"ResetButton.js","names":["React","useCallback","useContext","classnames","Button","Dialog","useTranslation","IterateItemContext","ToolbarContext","FieldBoundaryContext","reset","useHasContentChanged","omitDataValueReadWriteProps","ResetButton","props","text","children","onClick","className","hidden","showConfirmDialog","restProps","_objectWithoutProperties","_excluded","restoreOriginalValue","setShowBoundaryErrors","setShowError","hasContentChanged","enabled","buttonProps","resetButton","IterateEditContainer","confirmResetText","textContent","buttonWrapperRef","useRef","handleClick","close","event","_buttonWrapperRef$cur","current","focus","triggerAttributes","_objectSpread","variant","icon","icon_position","disabled","createElement","tabIndex","ref","title","onConfirm","_extends","on_click"],"sources":["../../../../../../src/extensions/forms/Iterate/EditContainer/ResetButton.tsx"],"sourcesContent":["import React, { useCallback, useContext } from 'react'\nimport classnames from 'classnames'\nimport { Button, Dialog } from '../../../../components'\nimport useTranslation from '../../hooks/useTranslation'\nimport IterateItemContext from '../IterateItemContext'\nimport ToolbarContext from '../Toolbar/ToolbarContext'\nimport FieldBoundaryContext from '../../DataContext/FieldBoundary/FieldBoundaryContext'\nimport { reset } from '../../../../icons'\nimport { ButtonProps } from '../../../../components/Button'\nimport useHasContentChanged from '../../Form/Isolation/useHasContentChanged'\nimport { omitDataValueReadWriteProps } from '../../types'\n\ntype Props = ButtonProps & {\n showConfirmDialog?: boolean\n}\n\nexport default function ResetButton(props: Props) {\n const {\n text,\n children,\n onClick,\n className,\n hidden,\n showConfirmDialog = true,\n ...restProps\n } = props\n const { restoreOriginalValue } = useContext(IterateItemContext) || {}\n const { setShowBoundaryErrors } = useContext(FieldBoundaryContext) || {}\n const { setShowError } = useContext(ToolbarContext) || {}\n const { hasContentChanged } = useHasContentChanged({ enabled: true })\n\n const buttonProps = omitDataValueReadWriteProps(restProps)\n const { resetButton } = useTranslation().IterateEditContainer\n const { confirmResetText } = useTranslation().IterateEditContainer\n const textContent = text || children || resetButton\n\n const buttonWrapperRef = React.useRef<HTMLButtonElement>(null)\n const handleClick = useCallback(\n ({ close, event }) => {\n close?.()\n onClick?.(event)\n restoreOriginalValue?.()\n setShowError(false)\n setShowBoundaryErrors?.(false)\n buttonWrapperRef.current?.focus()\n },\n [onClick, restoreOriginalValue, setShowBoundaryErrors, setShowError]\n )\n\n if (hidden) {\n return null\n }\n\n const triggerAttributes: ButtonProps = {\n className: classnames('dnb-forms-iterate__reset-button', className),\n text: textContent,\n variant: textContent ? 'tertiary' : 'secondary',\n icon: reset,\n icon_position: 'left',\n disabled:\n typeof hasContentChanged === 'boolean' ? !hasContentChanged : false,\n ...buttonProps,\n }\n\n return (\n <span tabIndex={-1} ref={buttonWrapperRef} className=\"dnb-no-focus\">\n {showConfirmDialog ? (\n <Dialog\n variant=\"confirmation\"\n title={confirmResetText}\n triggerAttributes={triggerAttributes}\n onConfirm={handleClick}\n />\n ) : (\n <Button\n {...triggerAttributes}\n on_click={handleClick}\n {...buttonProps}\n >\n {resetButton}\n </Button>\n )}\n </span>\n )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -14,7 +14,7 @@ export function useIterateItemNo({
14
14
  optionalLabelSuffix
15
15
  } = useTranslation().Field;
16
16
  const labelSuffixText = useMemo(() => {
17
- if (required === false || typeof labelSuffix !== 'undefined') {
17
+ if (typeof labelSuffix !== 'boolean' && (required === false || typeof labelSuffix !== 'undefined')) {
18
18
  return labelSuffix !== null && labelSuffix !== void 0 ? labelSuffix : optionalLabelSuffix;
19
19
  }
20
20
  return '';
@@ -38,4 +38,4 @@ export function useIterateItemNo({
38
38
  return content;
39
39
  }, [iterateIndex, labelProp, labelSuffixText, optionalLabelSuffix]);
40
40
  }
41
- //# sourceMappingURL=useIItemNo.js.map
41
+ //# sourceMappingURL=useIterateItemNo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useIterateItemNo.js","names":["React","useMemo","useItem","useTranslation","convertJsxToString","useIterateItemNo","label","labelProp","labelSuffix","required","index","iterateIndex","optionalLabelSuffix","Field","labelSuffixText","content","undefined","replace","String","includes","isValidElement","createElement","Fragment"],"sources":["../../../../../../src/extensions/forms/Iterate/ItemNo/useIterateItemNo.tsx"],"sourcesContent":["import React, { useMemo } from 'react'\nimport { useItem } from '../hooks'\nimport { useTranslation } from '../../hooks'\nimport { convertJsxToString } from '../../../../shared/component-helper'\n\nexport function useIterateItemNo({\n label: labelProp,\n labelSuffix,\n required,\n}) {\n const { index: iterateIndex } = useItem() || {}\n\n const { optionalLabelSuffix } = useTranslation().Field\n const labelSuffixText = useMemo(() => {\n if (\n typeof labelSuffix !== 'boolean' &&\n (required === false || typeof labelSuffix !== 'undefined')\n ) {\n return labelSuffix ?? optionalLabelSuffix\n }\n return ''\n }, [required, labelSuffix, optionalLabelSuffix])\n\n return useMemo(() => {\n let content = labelProp\n\n if (iterateIndex !== undefined) {\n content = convertJsxToString(labelProp).replace(\n '{itemNo}',\n String(iterateIndex + 1)\n )\n }\n\n if (labelSuffixText) {\n if (convertJsxToString(content).includes(optionalLabelSuffix)) {\n return content\n }\n\n if (typeof content === 'string') {\n return content + ' ' + labelSuffixText\n }\n\n if (React.isValidElement(content)) {\n return (\n <>\n {content}\n {' '}\n {labelSuffixText}\n </>\n )\n }\n }\n\n return content\n }, [iterateIndex, labelProp, labelSuffixText, optionalLabelSuffix])\n}\n"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,OAAO,QAAQ,OAAO;AACtC,SAASC,OAAO,QAAQ,UAAU;AAClC,SAASC,cAAc,QAAQ,aAAa;AAC5C,SAASC,kBAAkB,QAAQ,qCAAqC;AAExE,OAAO,SAASC,gBAAgBA,CAAC;EAC/BC,KAAK,EAAEC,SAAS;EAChBC,WAAW;EACXC;AACF,CAAC,EAAE;EACD,MAAM;IAAEC,KAAK,EAAEC;EAAa,CAAC,GAAGT,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC;EAE/C,MAAM;IAAEU;EAAoB,CAAC,GAAGT,cAAc,CAAC,CAAC,CAACU,KAAK;EACtD,MAAMC,eAAe,GAAGb,OAAO,CAAC,MAAM;IACpC,IACE,OAAOO,WAAW,KAAK,SAAS,KAC/BC,QAAQ,KAAK,KAAK,IAAI,OAAOD,WAAW,KAAK,WAAW,CAAC,EAC1D;MACA,OAAOA,WAAW,aAAXA,WAAW,cAAXA,WAAW,GAAII,mBAAmB;IAC3C;IACA,OAAO,EAAE;EACX,CAAC,EAAE,CAACH,QAAQ,EAAED,WAAW,EAAEI,mBAAmB,CAAC,CAAC;EAEhD,OAAOX,OAAO,CAAC,MAAM;IACnB,IAAIc,OAAO,GAAGR,SAAS;IAEvB,IAAII,YAAY,KAAKK,SAAS,EAAE;MAC9BD,OAAO,GAAGX,kBAAkB,CAACG,SAAS,CAAC,CAACU,OAAO,CAC7C,UAAU,EACVC,MAAM,CAACP,YAAY,GAAG,CAAC,CACzB,CAAC;IACH;IAEA,IAAIG,eAAe,EAAE;MACnB,IAAIV,kBAAkB,CAACW,OAAO,CAAC,CAACI,QAAQ,CAACP,mBAAmB,CAAC,EAAE;QAC7D,OAAOG,OAAO;MAChB;MAEA,IAAI,OAAOA,OAAO,KAAK,QAAQ,EAAE;QAC/B,OAAOA,OAAO,GAAG,GAAG,GAAGD,eAAe;MACxC;MAEA,IAAId,KAAK,CAACoB,cAAc,CAACL,OAAO,CAAC,EAAE;QACjC,OACEf,KAAA,CAAAqB,aAAA,CAAArB,KAAA,CAAAsB,QAAA,QACGP,OAAO,EACP,GAAG,EACHD,eACD,CAAC;MAEP;IACF;IAEA,OAAOC,OAAO;EAChB,CAAC,EAAE,CAACJ,YAAY,EAAEJ,SAAS,EAAEO,eAAe,EAAEF,mBAAmB,CAAC,CAAC;AACrE","ignoreList":[]}
@@ -1,7 +1,9 @@
1
1
  import React from 'react';
2
+ import { IsolationProps } from '../../Form/Isolation';
2
3
  import { AllProps as EditContainerProps } from '../EditContainer';
3
4
  import { OnCommit, Path } from '../../types';
4
5
  import { SpacingProps } from '../../../../shared/types';
6
+ import { JsonObject } from '../../utils';
5
7
  type OnlyPathRequired = {
6
8
  /**
7
9
  * The path to the array to add the new item to.
@@ -83,7 +85,7 @@ export type Props = (OnlyPathRequired | OnlyItemPathRequired) & {
83
85
  * The container contents.
84
86
  */
85
87
  children: React.ReactNode;
86
- };
88
+ } & Pick<IsolationProps<JsonObject>, 'dataReference'>;
87
89
  export type AllProps = Props & SpacingProps & Omit<EditContainerProps, 'data'>;
88
90
  declare function PushContainer(props: AllProps): import("react/jsx-runtime").JSX.Element;
89
91
  declare namespace PushContainer {