@wise/dynamic-flow-client 5.9.0 → 5.9.2-logging-bf0bd22

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 (413) hide show
  1. package/build/main.js +41 -44
  2. package/build/main.mjs +41 -44
  3. package/build/types/domain/components/step/StepDomainComponent.d.ts +2 -1
  4. package/build/types/domain/components/step/StepDomainComponent.d.ts.map +1 -1
  5. package/build/types/domain/mappers/mapStepSchemas.d.ts +1 -1
  6. package/build/types/domain/mappers/mapStepSchemas.d.ts.map +1 -1
  7. package/build/types/domain/mappers/mapStepToComponent.d.ts.map +1 -1
  8. package/build/types/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.d.ts +1 -531
  9. package/build/types/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.d.ts.map +1 -1
  10. package/build/types/domain/mappers/schema/persistAsyncSchemaToComponent.d.ts +0 -16
  11. package/build/types/domain/mappers/schema/persistAsyncSchemaToComponent.d.ts.map +1 -1
  12. package/build/types/domain/types.d.ts +0 -1
  13. package/build/types/domain/types.d.ts.map +1 -1
  14. package/build/types/renderers/mappers/selectInputComponentToProps.d.ts +2 -2
  15. package/build/types/renderers/mappers/selectInputComponentToProps.d.ts.map +1 -1
  16. package/package.json +20 -19
  17. package/build/DynamicFlowCore.js +0 -5
  18. package/build/common/errorBoundary/ErrorBoundary.js +0 -26
  19. package/build/common/errorBoundary/ErrorBoundary.test.js +0 -29
  20. package/build/common/errorBoundary/ErrorBoundaryAlert.js +0 -11
  21. package/build/common/makeHttpClient/api-utils.js +0 -3
  22. package/build/common/makeHttpClient/index.js +0 -1
  23. package/build/common/makeHttpClient/makeHttpClient.js +0 -10
  24. package/build/common/makeHttpClient/makeHttpClient.test.js +0 -186
  25. package/build/common/messages/external-confirmation.messages.js +0 -23
  26. package/build/common/messages/file-upload.messages.js +0 -13
  27. package/build/common/messages/generic-error.messages.js +0 -18
  28. package/build/common/messages/help.messages.js +0 -8
  29. package/build/common/messages/multi-file-upload.messages.js +0 -18
  30. package/build/common/messages/multi-select.messages.js +0 -8
  31. package/build/common/messages/paragraph.messages.js +0 -13
  32. package/build/common/messages/repeatable.messages.js +0 -23
  33. package/build/common/messages/search.messages.js +0 -8
  34. package/build/common/messages/validation.array.messages.js +0 -13
  35. package/build/common/messages/validation.messages.js +0 -53
  36. package/build/controller/FlowController.js +0 -368
  37. package/build/controller/executePoll.js +0 -49
  38. package/build/controller/executeRefresh.js +0 -39
  39. package/build/controller/executeRequest.js +0 -77
  40. package/build/controller/executeSubmission.js +0 -69
  41. package/build/controller/getErrorMessage.js +0 -7
  42. package/build/controller/getRequestAbortController.js +0 -13
  43. package/build/controller/getResponseType.js +0 -35
  44. package/build/controller/getSafeHttpClient.js +0 -8
  45. package/build/controller/getStepCounter.js +0 -16
  46. package/build/controller/handleErrorResponse.js +0 -26
  47. package/build/controller/makeSafeHttpClient.js +0 -8
  48. package/build/controller/response-utils.js +0 -72
  49. package/build/domain/components/AlertComponent.js +0 -1
  50. package/build/domain/components/AllOfComponent.js +0 -40
  51. package/build/domain/components/BooleanInputComponent.js +0 -50
  52. package/build/domain/components/BoxComponent.js +0 -3
  53. package/build/domain/components/ButtonComponent.js +0 -1
  54. package/build/domain/components/ColumnsComponent.js +0 -3
  55. package/build/domain/components/ConstComponent.js +0 -18
  56. package/build/domain/components/ContainerComponent.js +0 -3
  57. package/build/domain/components/DateInputComponent.js +0 -75
  58. package/build/domain/components/DecisionComponent.js +0 -1
  59. package/build/domain/components/DividerComponent.js +0 -1
  60. package/build/domain/components/FormComponent.js +0 -3
  61. package/build/domain/components/FormattedValueComponent.js +0 -44
  62. package/build/domain/components/HeadingComponent.js +0 -1
  63. package/build/domain/components/ImageComponent.js +0 -1
  64. package/build/domain/components/InstructionsComponent.js +0 -1
  65. package/build/domain/components/IntegerInputComponent.js +0 -74
  66. package/build/domain/components/ListComponent.js +0 -1
  67. package/build/domain/components/LoadingIndicatorComponent.js +0 -1
  68. package/build/domain/components/MarkdownComponent.js +0 -1
  69. package/build/domain/components/MediaComponent.js +0 -1
  70. package/build/domain/components/ModalComponent.js +0 -16
  71. package/build/domain/components/ModalLayoutComponent.js +0 -3
  72. package/build/domain/components/MoneyInputComponent.js +0 -57
  73. package/build/domain/components/MultiSelectInputComponent.js +0 -81
  74. package/build/domain/components/MultiUploadInputComponent.js +0 -88
  75. package/build/domain/components/NumberInputComponent.js +0 -73
  76. package/build/domain/components/ObjectComponent.js +0 -45
  77. package/build/domain/components/ParagraphComponent.js +0 -1
  78. package/build/domain/components/PersistAsyncComponent.js +0 -92
  79. package/build/domain/components/ProgressComponent.js +0 -1
  80. package/build/domain/components/RepeatableComponent.js +0 -103
  81. package/build/domain/components/ReviewComponent.js +0 -1
  82. package/build/domain/components/RootDomainComponent.js +0 -173
  83. package/build/domain/components/SectionComponent.js +0 -5
  84. package/build/domain/components/SelectInputComponent.js +0 -88
  85. package/build/domain/components/StatusListComponent.js +0 -1
  86. package/build/domain/components/SubflowDomainComponent.js +0 -9
  87. package/build/domain/components/TabsComponent.js +0 -1
  88. package/build/domain/components/TextInputComponent.js +0 -76
  89. package/build/domain/components/TupleComponent.js +0 -41
  90. package/build/domain/components/UploadInputComponent.js +0 -83
  91. package/build/domain/components/UpsellComponent.js +0 -25
  92. package/build/domain/components/searchComponent/SearchComponent.js +0 -92
  93. package/build/domain/components/searchComponent/SearchComponent.test.js +0 -190
  94. package/build/domain/components/step/ExternalConfirmationComponent.js +0 -28
  95. package/build/domain/components/step/StepDomainComponent.js +0 -73
  96. package/build/domain/components/step/ToolbarComponent.js +0 -1
  97. package/build/domain/components/utils/WithUpdate.js +0 -1
  98. package/build/domain/components/utils/component-utils.js +0 -12
  99. package/build/domain/components/utils/debounce.js +0 -34
  100. package/build/domain/components/utils/debounce.test.js +0 -67
  101. package/build/domain/components/utils/file-utils.js +0 -21
  102. package/build/domain/components/utils/file-utils.test.js +0 -27
  103. package/build/domain/components/utils/getRandomId.js +0 -1
  104. package/build/domain/components/utils/isExactLocalValueMatch.js +0 -14
  105. package/build/domain/components/utils/isOrWasValid.js +0 -5
  106. package/build/domain/components/utils/isPartialModelMatch.js +0 -18
  107. package/build/domain/components/utils/isPartialModelMatch.test.js +0 -74
  108. package/build/domain/features/eventNames.js +0 -24
  109. package/build/domain/features/events.js +0 -1
  110. package/build/domain/features/persistAsync/getComponentMultiPersistAsync.js +0 -50
  111. package/build/domain/features/persistAsync/getInitialPersistedState.js +0 -7
  112. package/build/domain/features/persistAsync/getPerformPersistAsync.js +0 -43
  113. package/build/domain/features/persistAsync/getPerformPersistAsync.test.js +0 -139
  114. package/build/domain/features/polling/getStepPolling.js +0 -43
  115. package/build/domain/features/polling/getStepPolling.test.js +0 -90
  116. package/build/domain/features/prefetch/getStepPrefetch.js +0 -43
  117. package/build/domain/features/prefetch/request-cache.js +0 -49
  118. package/build/domain/features/prefetch/request-cache.test.js +0 -70
  119. package/build/domain/features/refreshAfter/getStepRefreshAfter.js +0 -24
  120. package/build/domain/features/refreshAfter/getStepRefreshAfter.test.js +0 -40
  121. package/build/domain/features/schema-on-change/getDebouncedSchemaOnChange.js +0 -50
  122. package/build/domain/features/schema-on-change/getSchemaOnChange.js +0 -34
  123. package/build/domain/features/search/getPerformSearchFunction.js +0 -75
  124. package/build/domain/features/search/getPerformSearchFunction.test.js +0 -301
  125. package/build/domain/features/summary/summary-utils.js +0 -40
  126. package/build/domain/features/summary/summary-utils.test.js +0 -125
  127. package/build/domain/features/utils/http-utils.js +0 -21
  128. package/build/domain/features/utils/response-utils.js +0 -9
  129. package/build/domain/features/validation/spec-utils.js +0 -19
  130. package/build/domain/features/validation/validateStringPattern.js +0 -24
  131. package/build/domain/features/validation/validation-functions.js +0 -6
  132. package/build/domain/features/validation/validation-functions.test.js +0 -108
  133. package/build/domain/features/validation/value-checks.js +0 -125
  134. package/build/domain/features/validation/value-checks.test.js +0 -262
  135. package/build/domain/features/validationAsync/getComponentValidationAsync.js +0 -53
  136. package/build/domain/features/validationAsync/getComponentValidationAsync.test.js +0 -67
  137. package/build/domain/features/validationAsync/getInitialValidationAsyncState.js +0 -5
  138. package/build/domain/features/validationAsync/getPerformValidationAsync.js +0 -45
  139. package/build/domain/features/validationAsync/getPerformValidationAsync.test.js +0 -143
  140. package/build/domain/mappers/layout/alertLayoutToComponent.js +0 -16
  141. package/build/domain/mappers/layout/boxLayoutToComponent.js +0 -13
  142. package/build/domain/mappers/layout/buttonLayoutToComponent.js +0 -77
  143. package/build/domain/mappers/layout/columnsLayoutToComponent.js +0 -13
  144. package/build/domain/mappers/layout/decisionLayoutToComponent.js +0 -22
  145. package/build/domain/mappers/layout/deprecatedListLayoutToComponent.js +0 -30
  146. package/build/domain/mappers/layout/dividerLayoutToComponent.js +0 -2
  147. package/build/domain/mappers/layout/formLayoutToComponent.js +0 -19
  148. package/build/domain/mappers/layout/headingLayoutToComponent.js +0 -12
  149. package/build/domain/mappers/layout/imageLayoutToComponent.js +0 -20
  150. package/build/domain/mappers/layout/infoLayoutToComponent.js +0 -12
  151. package/build/domain/mappers/layout/instructionsLayoutToComponent.js +0 -12
  152. package/build/domain/mappers/layout/listLayoutToComponent.js +0 -39
  153. package/build/domain/mappers/layout/loadingIndicatorLayoutToComponent.js +0 -9
  154. package/build/domain/mappers/layout/markdownLayoutToComponent.js +0 -12
  155. package/build/domain/mappers/layout/mediaLayoutToComponent.js +0 -12
  156. package/build/domain/mappers/layout/modalLayoutToComponent.js +0 -17
  157. package/build/domain/mappers/layout/modalToComponent.js +0 -8
  158. package/build/domain/mappers/layout/paragraphLayoutToComponent.js +0 -12
  159. package/build/domain/mappers/layout/progressLayoutToComponent.js +0 -15
  160. package/build/domain/mappers/layout/reviewLayoutToComponent.js +0 -48
  161. package/build/domain/mappers/layout/searchLayoutToComponent.js +0 -44
  162. package/build/domain/mappers/layout/sectionLayoutToComponent.js +0 -15
  163. package/build/domain/mappers/layout/statusListLayoutToComponent.js +0 -15
  164. package/build/domain/mappers/layout/tabsLayoutToComponent.js +0 -16
  165. package/build/domain/mappers/layout/upsellLayoutToComponent.js +0 -25
  166. package/build/domain/mappers/mapLayoutToComponent.js +0 -81
  167. package/build/domain/mappers/mapSchemaToComponent.js +0 -61
  168. package/build/domain/mappers/mapSchemaToComponent.test.js +0 -112
  169. package/build/domain/mappers/mapStepSchemas.js +0 -17
  170. package/build/domain/mappers/mapStepToComponent.js +0 -132
  171. package/build/domain/mappers/mapStepToComponent.test.js +0 -221
  172. package/build/domain/mappers/mapToolbarToComponent.js +0 -15
  173. package/build/domain/mappers/schema/allOfSchemaToComponent.js +0 -16
  174. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToComponent.js +0 -26
  175. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiSelectComponent.js +0 -55
  176. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiUploadComponent.js +0 -67
  177. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToRepeatableComponent.js +0 -57
  178. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToTupleComponent.js +0 -20
  179. package/build/domain/mappers/schema/blobSchemaToComponent.js +0 -15
  180. package/build/domain/mappers/schema/booleanSchemaToComponent.js +0 -29
  181. package/build/domain/mappers/schema/constSchemaToComponent.js +0 -23
  182. package/build/domain/mappers/schema/integerSchemaToComponent.js +0 -28
  183. package/build/domain/mappers/schema/numberSchemaToComponent.js +0 -26
  184. package/build/domain/mappers/schema/objectSchemaToComponent/assertDisplayOrder.js +0 -23
  185. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToFormattedValueComponent.js +0 -9
  186. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.js +0 -119
  187. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.test.js +0 -96
  188. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.js +0 -31
  189. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.test.js +0 -99
  190. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.js +0 -76
  191. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.test.js +0 -265
  192. package/build/domain/mappers/schema/persistAsyncSchemaToComponent.js +0 -29
  193. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.js +0 -18
  194. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.test.js +0 -133
  195. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToDateInputComponent.js +0 -48
  196. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToTextInputComponent.js +0 -37
  197. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToUploadInputComponent.js +0 -28
  198. package/build/domain/mappers/schema/tests/test-utils.js +0 -16
  199. package/build/domain/mappers/schema/types.js +0 -1
  200. package/build/domain/mappers/schema/utils/getPerformPersistAsyncFn.js +0 -19
  201. package/build/domain/mappers/schema/utils/getValidationAsyncInitialState.js +0 -23
  202. package/build/domain/mappers/schema/utils/mapCommonSchemaProps.js +0 -16
  203. package/build/domain/mappers/types.js +0 -1
  204. package/build/domain/mappers/utils/FeatureFlags.js +0 -22
  205. package/build/domain/mappers/utils/behavior-utils.js +0 -44
  206. package/build/domain/mappers/utils/call-to-action-utils.js +0 -21
  207. package/build/domain/mappers/utils/getAutocompleteString.js +0 -76
  208. package/build/domain/mappers/utils/getAutocompleteString.test.js +0 -21
  209. package/build/domain/mappers/utils/groupLayoutByPinned.js +0 -38
  210. package/build/domain/mappers/utils/groupLayoutByPinned.test.js +0 -166
  211. package/build/domain/mappers/utils/image.js +0 -9
  212. package/build/domain/mappers/utils/layout-utils.js +0 -11
  213. package/build/domain/mappers/utils/legacy-utils.js +0 -49
  214. package/build/domain/mappers/utils/media-utils.js +0 -14
  215. package/build/domain/mappers/utils/suggestions-utils.js +0 -26
  216. package/build/domain/mappers/utils/suggestions-utils.test.js +0 -36
  217. package/build/domain/mappers/utils/tags-utils.js +0 -1
  218. package/build/domain/mappers/utils/utils.js +0 -35
  219. package/build/domain/types.js +0 -1
  220. package/build/getSubflowCallbacks.js +0 -38
  221. package/build/i18n/index.js +0 -40
  222. package/build/index.js +0 -8
  223. package/build/renderers/CoreContainerRenderer.js +0 -5
  224. package/build/renderers/CoreRootRenderer.js +0 -12
  225. package/build/renderers/EmptyLoadingStateRenderer.js +0 -5
  226. package/build/renderers/getRenderFunction.js +0 -24
  227. package/build/renderers/getSchemaErrorMessageFunction.js +0 -97
  228. package/build/renderers/mappers/alertComponentToProps.js +0 -2
  229. package/build/renderers/mappers/allOfComponentToProps.js +0 -6
  230. package/build/renderers/mappers/booleanInputComponentToProps.js +0 -5
  231. package/build/renderers/mappers/boxComponentToProps.js +0 -13
  232. package/build/renderers/mappers/buttonComponentToProps.js +0 -4
  233. package/build/renderers/mappers/columnsComponentToProps.js +0 -11
  234. package/build/renderers/mappers/componentToRendererProps.js +0 -164
  235. package/build/renderers/mappers/constComponentToProps.js +0 -5
  236. package/build/renderers/mappers/containerComponentToProps.js +0 -7
  237. package/build/renderers/mappers/dateInputComponentToProps.js +0 -2
  238. package/build/renderers/mappers/decisionComponentToProps.js +0 -16
  239. package/build/renderers/mappers/dividerComponentToProps.js +0 -2
  240. package/build/renderers/mappers/externalComponentToProps.js +0 -3
  241. package/build/renderers/mappers/formComponentToProps.js +0 -12
  242. package/build/renderers/mappers/formattedValueComponentToProps.js +0 -5
  243. package/build/renderers/mappers/headingComponentToProps.js +0 -2
  244. package/build/renderers/mappers/hiddenComponentToProps.js +0 -4
  245. package/build/renderers/mappers/imageComponentToProps.js +0 -2
  246. package/build/renderers/mappers/instructionsComponentToProps.js +0 -2
  247. package/build/renderers/mappers/integerInputComponentToProps.js +0 -2
  248. package/build/renderers/mappers/listComponentToProps.js +0 -2
  249. package/build/renderers/mappers/loadingIndicatorComponentToProps.js +0 -2
  250. package/build/renderers/mappers/markdownComponentToProps.js +0 -2
  251. package/build/renderers/mappers/mediaComponentToProps.js +0 -2
  252. package/build/renderers/mappers/modalComponentToProps.js +0 -11
  253. package/build/renderers/mappers/modalLayoutComponentToProps.js +0 -16
  254. package/build/renderers/mappers/moneyInputComponentToProps.js +0 -36
  255. package/build/renderers/mappers/multiSelectComponentToProps.js +0 -23
  256. package/build/renderers/mappers/multiUploadInputComponentToProps.js +0 -12
  257. package/build/renderers/mappers/numberInputComponentToProps.js +0 -2
  258. package/build/renderers/mappers/objectComponentToProps.js +0 -8
  259. package/build/renderers/mappers/paragraphComponentToProps.js +0 -2
  260. package/build/renderers/mappers/persistAsyncComponentToProps.js +0 -8
  261. package/build/renderers/mappers/progressComponentToProps.js +0 -2
  262. package/build/renderers/mappers/repeatableComponentToProps.js +0 -30
  263. package/build/renderers/mappers/reviewComponentToProps.js +0 -2
  264. package/build/renderers/mappers/rootComponentToProps.js +0 -21
  265. package/build/renderers/mappers/searchComponentToProps.js +0 -57
  266. package/build/renderers/mappers/sectionComponentToProps.js +0 -6
  267. package/build/renderers/mappers/selectInputComponentToProps.js +0 -26
  268. package/build/renderers/mappers/statusListComponentToProps.js +0 -2
  269. package/build/renderers/mappers/subflowComponentToRendererProps.js +0 -4
  270. package/build/renderers/mappers/tabsComponentToProps.js +0 -14
  271. package/build/renderers/mappers/textInputComponentToProps.js +0 -2
  272. package/build/renderers/mappers/tupleComponentToProps.js +0 -8
  273. package/build/renderers/mappers/uploadInputComponentToProps.js +0 -8
  274. package/build/renderers/mappers/upsellComponentToProps.js +0 -2
  275. package/build/renderers/mappers/utils/getValidationState.js +0 -12
  276. package/build/renderers/mappers/utils/inputComponentToProps.js +0 -26
  277. package/build/renderers/mappers/utils/mapErrorsToValidationState.js +0 -9
  278. package/build/renderers/mappers/utils/pick.js +0 -8
  279. package/build/renderers/mappers/utils/selectInputOptionsToProps.js +0 -11
  280. package/build/renderers/stepComponentToProps.js +0 -32
  281. package/build/renderers/utils.js +0 -69
  282. package/build/renderers/utils.test.js +0 -70
  283. package/build/stories/dev-tools/ContainerQueries.story.js +0 -66
  284. package/build/stories/dev-tools/Debugger.story.js +0 -38
  285. package/build/stories/dev-tools/FixtureSelect.story.js +0 -23
  286. package/build/stories/dev-tools/TestServer.story.js +0 -32
  287. package/build/stories/examples/NativeFlow.story.js +0 -80
  288. package/build/stories/examples/Recipients.story.js +0 -568
  289. package/build/stories/spec/behavior/Copy.story.js +0 -59
  290. package/build/stories/spec/behavior/Modal.story.js +0 -76
  291. package/build/stories/spec/behavior/Subflow.story.js +0 -267
  292. package/build/stories/spec/layouts/Decision.story.js +0 -241
  293. package/build/stories/spec/layouts/Image.story.js +0 -42
  294. package/build/stories/spec/layouts/Modal.story.js +0 -81
  295. package/build/stories/spec/layouts/Search.story.js +0 -325
  296. package/build/stories/spec/layouts/Upsell.story.js +0 -55
  297. package/build/stories/spec/layouts/button/Button.story.js +0 -100
  298. package/build/stories/spec/layouts/button/PinnedButton.story.js +0 -81
  299. package/build/stories/spec/response/ActionResponse.story.js +0 -66
  300. package/build/stories/spec/schemas/MultiSelect.story.js +0 -148
  301. package/build/stories/spec/schemas/Upload.story.js +0 -168
  302. package/build/stories/spec/schemas/const/ConstLayout.story.js +0 -159
  303. package/build/stories/spec/schemas/const/ObjectConst.story.js +0 -94
  304. package/build/stories/spec/schemas/features/PersistAsync.story.js +0 -176
  305. package/build/stories/spec/schemas/features/ValidationAsync.story.js +0 -103
  306. package/build/stories/spec/schemas/object/FormattedValue.story.js +0 -92
  307. package/build/stories/spec/schemas/object/MoneyInput.story.js +0 -240
  308. package/build/stories/spec/schemas/oneOf/OneOfInitialisation.story.js +0 -55
  309. package/build/stories/spec/step/Controls.story.js +0 -109
  310. package/build/stories/spec/step/DFModal.story.js +0 -58
  311. package/build/stories/spec/step/Footer.story.js +0 -70
  312. package/build/stories/spec/step/Navigation.story.js +0 -20
  313. package/build/stories/spec/step/Tags.story.js +0 -39
  314. package/build/stories/spec/step/ToolBar.story.js +0 -60
  315. package/build/stories/spec/step/features/ErrorHandling.story.js +0 -92
  316. package/build/stories/spec/step/features/External.story.js +0 -44
  317. package/build/stories/spec/step/features/Polling.story.js +0 -108
  318. package/build/stories/spec/step/features/RefreshAfter.story.js +0 -92
  319. package/build/stories/spec/step/features/refresh/Refresh.story.js +0 -258
  320. package/build/stories/spec/step/features/refresh/RefreshWithPersistAsync.story.js +0 -958
  321. package/build/stories/types.js +0 -1
  322. package/build/stories/utils/fixtureHttpClient.js +0 -70
  323. package/build/stories/utils/getBasicStep.js +0 -223
  324. package/build/stories/utils/mockSearchHandler.js +0 -71
  325. package/build/stories/utils/render-utils.js +0 -41
  326. package/build/stories/visual-tests/layouts/NotUsingListItem.story.js +0 -17
  327. package/build/test-utils/DynamicFlowWise.js +0 -32
  328. package/build/test-utils/DynamicFlowWiseModal.js +0 -34
  329. package/build/test-utils/NeptuneProviders.js +0 -11
  330. package/build/test-utils/component-utils.js +0 -5
  331. package/build/test-utils/fetch-utils.js +0 -45
  332. package/build/test-utils/getMergedTestRenderers.js +0 -34
  333. package/build/test-utils/getRandomId.js +0 -1
  334. package/build/test-utils/index.js +0 -3
  335. package/build/test-utils/rtl-utils.js +0 -7
  336. package/build/test-utils/step-utils.js +0 -6
  337. package/build/test-utils/wait.js +0 -3
  338. package/build/tests/AlertLayout.test.js +0 -78
  339. package/build/tests/ArrayTuple.test.js +0 -118
  340. package/build/tests/ButtonLayout.test.js +0 -308
  341. package/build/tests/ConstLayout.test.js +0 -95
  342. package/build/tests/DateInput.test.js +0 -163
  343. package/build/tests/DecisionLayout.test.js +0 -146
  344. package/build/tests/DynamicFlow.test.js +0 -147
  345. package/build/tests/External.test.js +0 -169
  346. package/build/tests/Flow.test.js +0 -328
  347. package/build/tests/FormLayout.test.js +0 -28
  348. package/build/tests/FormattedValue.test.js +0 -107
  349. package/build/tests/ImageRenderer.test.js +0 -78
  350. package/build/tests/InitialAction.test.js +0 -179
  351. package/build/tests/InitialStep.test.js +0 -168
  352. package/build/tests/InstructionsLayout.test.js +0 -45
  353. package/build/tests/ListLayout.test.js +0 -145
  354. package/build/tests/Logging.test.js +0 -53
  355. package/build/tests/ModalBehavior.test.js +0 -149
  356. package/build/tests/MoneyInput.test.js +0 -316
  357. package/build/tests/MultiUpload.test.js +0 -293
  358. package/build/tests/NativeBack.test.js +0 -267
  359. package/build/tests/OneOfInitialisation.test.js +0 -571
  360. package/build/tests/PersistAsync.test.js +0 -653
  361. package/build/tests/Polling.test.js +0 -617
  362. package/build/tests/Prefetching.test.js +0 -230
  363. package/build/tests/RefreshAfter.test.js +0 -63
  364. package/build/tests/RefreshOnChange.ResponseHandling.test.js +0 -205
  365. package/build/tests/RefreshOnChange.test.js +0 -233
  366. package/build/tests/RefreshOnChange.with.Segmented.test.js +0 -348
  367. package/build/tests/RefreshOnChange.with.Tabs.test.js +0 -358
  368. package/build/tests/RefreshOnChangePreserve.test.js +0 -224
  369. package/build/tests/RendererProps.test.js +0 -342
  370. package/build/tests/Repeatable.test.js +0 -107
  371. package/build/tests/Rerendering.test.js +0 -67
  372. package/build/tests/ReviewLayout.test.js +0 -274
  373. package/build/tests/SchemaOnChange.test.js +0 -133
  374. package/build/tests/ScrollToError.test.js +0 -217
  375. package/build/tests/SegmentedControl.test.js +0 -49
  376. package/build/tests/SingleFileUpload.test.js +0 -88
  377. package/build/tests/StatusList.test.js +0 -85
  378. package/build/tests/Subflow.test.js +0 -710
  379. package/build/tests/Submission.ResponseHandling.test.js +0 -557
  380. package/build/tests/Submission.merging.test.js +0 -202
  381. package/build/tests/Submission.test.js +0 -523
  382. package/build/tests/Tags.test.js +0 -475
  383. package/build/tests/Upsell.test.js +0 -126
  384. package/build/tests/ValidationAsync.test.js +0 -295
  385. package/build/tests/legacy/Actions.test.js +0 -158
  386. package/build/tests/legacy/BackButton.test.js +0 -114
  387. package/build/tests/legacy/HiddenSchemas.test.js +0 -246
  388. package/build/tests/legacy/MultiSelect.test.js +0 -497
  389. package/build/tests/legacy/MultipleFileUploadSchema.test.js +0 -341
  390. package/build/tests/legacy/PersistAsync.blob-schema.test.js +0 -224
  391. package/build/tests/legacy/PersistAsync.string-schema.test.js +0 -211
  392. package/build/tests/legacy/RefreshStepOnChange.debouncing.test.js +0 -209
  393. package/build/tests/legacy/RefreshStepOnChange.test.js +0 -424
  394. package/build/tests/legacy/Search.test.js +0 -437
  395. package/build/tests/renderers/MultiSelectInputRendererProps.test.js +0 -58
  396. package/build/tests/renderers/SelectInputRendererProps.test.js +0 -42
  397. package/build/tests/renderers/TextInputRenderer.test.js +0 -51
  398. package/build/types.js +0 -1
  399. package/build/useDynamicFlow.js +0 -104
  400. package/build/useDynamicFlowModal.js +0 -58
  401. package/build/utils/analyse-step.js +0 -14
  402. package/build/utils/component-utils.js +0 -8
  403. package/build/utils/component-utils.test.js +0 -113
  404. package/build/utils/getScrollToTop.js +0 -12
  405. package/build/utils/normalise-flow-id.js +0 -1
  406. package/build/utils/normalise-flow-id.test.js +0 -24
  407. package/build/utils/openLinkInNewTab.js +0 -10
  408. package/build/utils/recursiveMerge.js +0 -40
  409. package/build/utils/recursiveMerge.test.js +0 -93
  410. package/build/utils/type-utils.js +0 -21
  411. package/build/utils/type-validators.js +0 -11
  412. package/build/utils/type-validators.test.js +0 -180
  413. package/build/utils/useStableCallback.js +0 -15
@@ -1,274 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- /* eslint-disable @typescript-eslint/no-unsafe-assignment */
3
- import { screen, waitFor } from '@testing-library/react';
4
- import { userEvent } from '@testing-library/user-event';
5
- import { Fragment } from 'react/jsx-runtime';
6
- import { renderWithProviders } from '../test-utils';
7
- import DynamicFlowWise from '../test-utils/DynamicFlowWise';
8
- import { vi } from 'vitest';
9
- const user = userEvent.setup({ advanceTimers: vi.advanceTimersByTime });
10
- describe('ReviewLayout component', () => {
11
- const getDefaultProps = () => ({
12
- flowId: 'flow-id',
13
- httpClient: vi.fn(),
14
- onCompletion: vi.fn(),
15
- onError: vi.fn(),
16
- onEvent: vi.fn(),
17
- onLog: vi.fn(),
18
- });
19
- const getInitialStep = (behavior) => ({
20
- id: 'step-id',
21
- title: 'Step with alert',
22
- layout: [
23
- {
24
- type: 'review',
25
- title: 'Review Title',
26
- analyticsId: 'review-layout-aid',
27
- fields: [
28
- {
29
- analyticsId: 'review-field-1-aid',
30
- label: 'Label 1',
31
- value: 'Value 1',
32
- rawValue: 'Raw value 1',
33
- tag: 'tag1',
34
- inlineAlert: { content: 'Inline alert 1', context: 'positive' },
35
- additionalInfo: { text: 'Additional info 1' },
36
- callToAction: {
37
- title: 'Call to Action 1',
38
- behavior: { type: 'action', action: { url: '/call-to-action', method: 'GET' } },
39
- },
40
- },
41
- {
42
- analyticsId: 'review-field-2-aid',
43
- label: 'Label 2',
44
- value: 'Value 2',
45
- rawValue: 'Raw value 2',
46
- tag: 'tag2',
47
- inlineAlert: { content: 'Inline alert 2', context: 'negative' },
48
- additionalInfo: {
49
- text: 'Additional info 2',
50
- behavior: { type: 'action', action: { url: '/additional-info', method: 'GET' } },
51
- },
52
- },
53
- ],
54
- callToAction: Object.assign({ title: 'Call to Action', action: {} }, (behavior ? { behavior } : {})),
55
- },
56
- ],
57
- schemas: [],
58
- });
59
- describe('Behavior / Call to Action', () => {
60
- describe('Old "container" behavior type', () => {
61
- describe('Given a review layout component with a link behavior', () => {
62
- const props = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: getInitialStep({ link: { url: 'https://google.com' } }) });
63
- it('should render a link that opens the url on click', async () => {
64
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
65
- await waitFor(() => {
66
- expect(screen.getByRole('link')).toHaveTextContent('Call to Action');
67
- });
68
- expect(screen.getByRole('link')).toHaveAttribute('href', 'https://google.com');
69
- });
70
- });
71
- describe('Given a review layout component with an action behavior', () => {
72
- const props = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: getInitialStep({ action: { url: '/action' } }) });
73
- it('should trigger the action on click', async () => {
74
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
75
- await waitFor(() => {
76
- expect(screen.getByRole('button', { name: 'Call to Action' })).toBeInTheDocument();
77
- });
78
- await user.click(screen.getByRole('button', { name: 'Call to Action' }));
79
- expect(props.httpClient).toHaveBeenCalledWith('/action', expect.any(Object));
80
- });
81
- });
82
- });
83
- describe('New "union type" behavior type', () => {
84
- describe('Given a review layout component with a link behavior', () => {
85
- const props = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: getInitialStep({ type: 'link', url: 'https://google.com' }) });
86
- it('should render a link that opens the url on click', async () => {
87
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
88
- await waitFor(() => {
89
- expect(screen.getByRole('link')).toHaveTextContent('Call to Action');
90
- });
91
- expect(screen.getByRole('link')).toHaveAttribute('href', 'https://google.com');
92
- });
93
- });
94
- describe('Given a review layout component with an action behavior', () => {
95
- const props = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: getInitialStep({ type: 'action', action: { url: '/action' } }) });
96
- it('should trigger the action on click', async () => {
97
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
98
- await waitFor(() => {
99
- expect(screen.getByRole('button', { name: 'Call to Action' })).toBeInTheDocument();
100
- });
101
- await user.click(screen.getByRole('button', { name: 'Call to Action' }));
102
- expect(props.httpClient).toHaveBeenCalledWith('/action', expect.any(Object));
103
- });
104
- });
105
- });
106
- describe('Deprecated "action" support', () => {
107
- describe('Given a review layout component with an action', () => {
108
- const props = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: {
109
- id: 'step-id',
110
- title: 'Step with alert',
111
- layout: [
112
- {
113
- type: 'review',
114
- title: 'Review Title',
115
- fields: [],
116
- action: { url: '/action', title: 'Old Action with Title' },
117
- },
118
- ],
119
- schemas: [],
120
- } });
121
- it('should trigger the action on click', async () => {
122
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
123
- await waitFor(() => {
124
- expect(screen.getByRole('button')).toHaveTextContent('Old Action with Title');
125
- });
126
- await user.click(screen.getByRole('button'));
127
- expect(props.httpClient).toHaveBeenCalledWith('/action', expect.any(Object));
128
- });
129
- });
130
- });
131
- describe('Deprecated "calltoAction" with "action" support', () => {
132
- describe('Given a review layout component with an action', () => {
133
- const props = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: {
134
- id: 'step-id',
135
- title: 'Step with alert',
136
- layout: [
137
- {
138
- type: 'review',
139
- title: 'Review Title',
140
- fields: [],
141
- callToAction: {
142
- title: 'Call to Action',
143
- action: { url: '/action' },
144
- },
145
- },
146
- ],
147
- schemas: [],
148
- } });
149
- it('should trigger the action on click', async () => {
150
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
151
- await waitFor(() => {
152
- expect(screen.getByRole('button')).toHaveTextContent('Call to Action');
153
- });
154
- await user.click(screen.getByRole('button'));
155
- expect(props.httpClient).toHaveBeenCalledWith('/action', expect.any(Object));
156
- });
157
- });
158
- });
159
- });
160
- describe('Extra props', () => {
161
- describe('Given a review layout component with extra properties in its fields', () => {
162
- const props = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: getInitialStep() });
163
- it('should pass the tag to the the renderer', async () => {
164
- const customRenderer = {
165
- canRenderType: 'review',
166
- render: vi.fn(),
167
- };
168
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props, { renderers: [customRenderer] })));
169
- expect(customRenderer.render).toHaveBeenCalledWith(expect.objectContaining({
170
- fields: expect.arrayContaining([
171
- expect.objectContaining({ tag: 'tag1' }),
172
- expect.objectContaining({ tag: 'tag2' }),
173
- ]),
174
- }));
175
- });
176
- it('should pass the rawValue to the the renderer', async () => {
177
- const customRenderer = {
178
- canRenderType: 'review',
179
- render: vi.fn(),
180
- };
181
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props, { renderers: [customRenderer] })));
182
- expect(customRenderer.render).toHaveBeenCalledWith(expect.objectContaining({
183
- fields: expect.arrayContaining([
184
- expect.objectContaining({ rawValue: 'Raw value 1' }),
185
- expect.objectContaining({ rawValue: 'Raw value 2' }),
186
- ]),
187
- }));
188
- });
189
- it('should pass the inlineAlert to the the renderer', async () => {
190
- const customRenderer = {
191
- canRenderType: 'review',
192
- render: vi.fn(),
193
- };
194
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props, { renderers: [customRenderer] })));
195
- expect(customRenderer.render).toHaveBeenCalledWith(expect.objectContaining({
196
- fields: expect.arrayContaining([
197
- expect.objectContaining({
198
- inlineAlert: { content: 'Inline alert 1', context: 'positive' },
199
- }),
200
- expect.objectContaining({
201
- inlineAlert: { content: 'Inline alert 2', context: 'negative' },
202
- }),
203
- ]),
204
- }));
205
- });
206
- it('should pass the additionalInfo to the the renderer', async () => {
207
- const customRenderer = {
208
- canRenderType: 'review',
209
- render: vi.fn(),
210
- };
211
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props, { renderers: [customRenderer] })));
212
- expect(customRenderer.render).toHaveBeenCalledWith(expect.objectContaining({
213
- fields: expect.arrayContaining([
214
- expect.objectContaining({
215
- additionalInfo: expect.objectContaining({ text: 'Additional info 1' }),
216
- }),
217
- expect.objectContaining({
218
- additionalInfo: expect.objectContaining({ text: 'Additional info 2' }),
219
- }),
220
- ]),
221
- }));
222
- });
223
- it('should pass the callToAction to the the renderer', async () => {
224
- const customRenderer = {
225
- canRenderType: 'review',
226
- render: vi.fn(),
227
- };
228
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props, { renderers: [customRenderer] })));
229
- expect(customRenderer.render).toHaveBeenCalledWith(expect.objectContaining({
230
- fields: expect.arrayContaining([
231
- expect.objectContaining({
232
- callToAction: expect.objectContaining({ title: 'Call to Action 1' }),
233
- }),
234
- ]),
235
- }));
236
- });
237
- it('should pass the analyticsId to the renderer', async () => {
238
- const customRenderer = {
239
- canRenderType: 'review',
240
- render: vi.fn(),
241
- };
242
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props, { renderers: [customRenderer] })));
243
- expect(customRenderer.render).toHaveBeenCalledWith(expect.objectContaining({
244
- analyticsId: 'review-layout-aid',
245
- fields: expect.arrayContaining([
246
- expect.objectContaining({ analyticsId: 'review-field-1-aid' }),
247
- expect.objectContaining({ analyticsId: 'review-field-2-aid' }),
248
- ]),
249
- }));
250
- });
251
- describe('interactivity', () => {
252
- const customRenderer = {
253
- canRenderType: 'review',
254
- render: (review) => (_jsx(_Fragment, { children: review.fields.map((field) => {
255
- var _a, _b, _c, _d;
256
- return (_jsxs(Fragment, { children: [_jsx("button", { type: "button", onClick: (_a = field.additionalInfo) === null || _a === void 0 ? void 0 : _a.onClick, children: (_b = field.additionalInfo) === null || _b === void 0 ? void 0 : _b.text }), _jsx("button", { type: "button", onClick: (_c = field.callToAction) === null || _c === void 0 ? void 0 : _c.onClick, children: (_d = field.callToAction) === null || _d === void 0 ? void 0 : _d.title })] }, field.label));
257
- }) })),
258
- };
259
- it('should call httpClient when clicking on an additionalInfo', async () => {
260
- const localProps = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: getInitialStep() });
261
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, localProps, { renderers: [customRenderer] })));
262
- await user.click(screen.getByText('Additional info 2'));
263
- expect(localProps.httpClient).toHaveBeenCalledWith('/additional-info', expect.any(Object));
264
- });
265
- it('should call httpClient when clicking on an items callToAction', async () => {
266
- const localProps = Object.assign(Object.assign({}, getDefaultProps()), { initialStep: getInitialStep() });
267
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, localProps, { renderers: [customRenderer] })));
268
- await user.click(screen.getByText('Call to Action 1'));
269
- expect(localProps.httpClient).toHaveBeenCalledWith('/call-to-action', expect.any(Object));
270
- });
271
- });
272
- });
273
- });
274
- });
@@ -1,133 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- /* eslint-disable @typescript-eslint/no-non-null-assertion */
3
- import { act, screen, waitFor } from '@testing-library/react';
4
- import { userEvent } from '@testing-library/user-event';
5
- import { renderWithProviders, respondWith } from '../test-utils';
6
- import DynamicFlowWise from '../test-utils/DynamicFlowWise';
7
- import { vi } from 'vitest';
8
- const user = userEvent.setup({ advanceTimers: vi.advanceTimersByTime });
9
- describe('SchemaOnChange', () => {
10
- const getStep = (schema) => ({
11
- id: 'step-1',
12
- title: 'SchemaOnChange Test',
13
- schemas: [schema],
14
- layout: [{ type: 'form', schemaId: schema.$id }],
15
- });
16
- const renderDF = (props) => {
17
- var _a, _b, _c;
18
- const flowId = (_a = props.flowId) !== null && _a !== void 0 ? _a : 'persist-async-test-flow';
19
- const onError = (_b = props.onError) !== null && _b !== void 0 ? _b : vi.fn();
20
- const onCompletion = (_c = props.onCompletion) !== null && _c !== void 0 ? _c : vi.fn();
21
- return renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, Object.assign({ onError, onCompletion, flowId }, props))));
22
- };
23
- describe('StringSchema & ActionBehavior', () => {
24
- it('should submit the step on string schema change', async () => {
25
- const initialStep = getStep({
26
- $id: '#name',
27
- type: 'string',
28
- title: 'Name',
29
- onChange: { type: 'action', action: { url: '/submit' } },
30
- });
31
- const httpClient = vi.fn();
32
- renderDF({ initialStep, httpClient });
33
- const nameInput = screen.getByLabelText('Name');
34
- await user.type(nameInput, 'John Doe');
35
- await act(async () => vi.advanceTimersByTimeAsync(1000)); // wait for debounce
36
- await waitFor(() => {
37
- expect(httpClient).toHaveBeenCalledWith('/submit', expect.objectContaining({
38
- body: '"John Doe"',
39
- }));
40
- });
41
- });
42
- });
43
- describe('OneOfSchema & ModalBehavior', () => {
44
- it('should open a modal on oneOf schema change', async () => {
45
- const initialStep = getStep({
46
- $id: '#name',
47
- title: 'Currency',
48
- control: 'radio',
49
- oneOf: [
50
- { const: 'USD', title: 'USD' },
51
- { const: 'EUR', title: 'EUR' },
52
- { const: 'GBP', title: 'GBP' },
53
- ],
54
- onChange: {
55
- type: 'modal',
56
- title: 'Currency Selected',
57
- content: [
58
- {
59
- type: 'paragraph',
60
- text: 'You have selected a currency, but this modal doesnt know which one.',
61
- },
62
- ],
63
- },
64
- });
65
- renderDF({ initialStep });
66
- await user.click(screen.getByText('GBP'));
67
- await waitFor(() => {
68
- expect(screen.getByText('Currency Selected')).toBeInTheDocument();
69
- });
70
- });
71
- });
72
- describe('BooleanSchema & LinkBehavior', () => {
73
- it('should open a link on boolean schema change', async () => {
74
- const initialStep = getStep({
75
- $id: '#terms',
76
- type: 'boolean',
77
- title: 'Accept Terms',
78
- onChange: {
79
- type: 'link',
80
- url: 'https://example.com/terms',
81
- },
82
- });
83
- const onLink = vi.fn();
84
- renderDF({ initialStep, onLink });
85
- const termsCheckbox = screen.getByLabelText('Accept Terms');
86
- await user.click(termsCheckbox);
87
- await waitFor(() => {
88
- expect(onLink).toHaveBeenCalledWith('https://example.com/terms');
89
- });
90
- });
91
- });
92
- describe('File Upload Schema with PersistAsync & ActionBehavior', () => {
93
- it('should submit the step on file upload schema change', async () => {
94
- const initialStep = getStep({
95
- $id: '#file-upload',
96
- type: 'string',
97
- title: 'Upload File Outer Schema',
98
- persistAsync: {
99
- url: '/upload',
100
- method: 'POST',
101
- idProperty: 'id',
102
- param: 'value',
103
- schema: {
104
- type: 'blob',
105
- title: 'Upload File',
106
- description: 'Upload a file',
107
- },
108
- },
109
- onChange: { type: 'action', action: { url: '/submit' } },
110
- });
111
- const httpClient = vi.fn(async (input) => {
112
- switch (input) {
113
- case '/upload':
114
- return respondWith({ id: '###ttoken###' });
115
- default:
116
- return respondWith({});
117
- }
118
- });
119
- renderDF({ initialStep, httpClient });
120
- const file = new File(['file content'], 'test.txt', { type: 'text/plain' });
121
- await user.upload(screen.getByTestId('uploadInput'), file);
122
- await waitFor(() => {
123
- expect(httpClient).toHaveBeenCalledWith('/upload', expect.objectContaining({
124
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
125
- body: expect.any(FormData),
126
- }));
127
- });
128
- await waitFor(() => {
129
- expect(httpClient).toHaveBeenLastCalledWith('/submit', expect.objectContaining({}));
130
- });
131
- });
132
- });
133
- });
@@ -1,217 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { renderWithProviders, respondWith, respondWithDelay } from '../test-utils';
3
- import DynamicFlowWise from '../test-utils/DynamicFlowWise';
4
- import userEvent from '@testing-library/user-event';
5
- import { screen, waitFor } from '@testing-library/react';
6
- import { vi } from 'vitest';
7
- import { act } from 'react';
8
- const user = userEvent.setup({ advanceTimers: vi.advanceTimersByTime });
9
- const WINDOW_HEIGHT = 768;
10
- const WINDOW_WIDTH = 1024;
11
- const ELEMENT_HEIGHT = 100;
12
- const getDefaultProps = () => ({
13
- flowId: 'flow-id',
14
- onCompletion: vi.fn(),
15
- onError: vi.fn(),
16
- onEvent: vi.fn(),
17
- onLog: vi.fn(),
18
- });
19
- const makeStep = (overrides = {}) => (Object.assign({ id: 'step-id', title: 'Step', schemas: [], layout: [] }, overrides));
20
- const getMockBoundingClientRect = (top) => vi.fn(() => ({
21
- top,
22
- bottom: top + ELEMENT_HEIGHT,
23
- left: 0,
24
- right: WINDOW_WIDTH,
25
- width: WINDOW_WIDTH,
26
- height: ELEMENT_HEIGHT,
27
- x: 0,
28
- y: top,
29
- toJSON: () => { },
30
- }));
31
- describe('Scrolling to global error', () => {
32
- beforeEach(() => {
33
- // Mock window height
34
- Object.defineProperty(window, 'innerHeight', {
35
- writable: true,
36
- configurable: true,
37
- value: WINDOW_HEIGHT,
38
- });
39
- });
40
- describe('when loading the initial step', () => {
41
- it('does not attempt to scroll to the top of the step (initialStep)', async () => {
42
- const scrollIntoViewMock = vi.fn();
43
- window.HTMLElement.prototype.scrollIntoView = scrollIntoViewMock;
44
- // Element is not visible
45
- window.HTMLElement.prototype.getBoundingClientRect = getMockBoundingClientRect(WINDOW_HEIGHT + 100);
46
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ initialStep: makeStep({ id: 'initial-step', title: 'Initial Step' }), httpClient: vi.fn() }, getDefaultProps())));
47
- await waitFor(() => {
48
- expect(screen.getByText('Initial Step')).toBeInTheDocument();
49
- });
50
- expect(scrollIntoViewMock).not.toHaveBeenCalled();
51
- });
52
- it('does not attempt to scroll to the top of the step (initialAction)', async () => {
53
- const scrollIntoViewMock = vi.fn();
54
- window.HTMLElement.prototype.scrollIntoView = scrollIntoViewMock;
55
- // Element is not visible
56
- window.HTMLElement.prototype.getBoundingClientRect = getMockBoundingClientRect(WINDOW_HEIGHT + 100);
57
- const httpClient = vi
58
- .fn()
59
- .mockImplementation(async () => respondWith(makeStep({ id: 'first-loaded-step', title: 'First Loaded Step' })));
60
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ initialAction: { url: '/' }, httpClient: httpClient }, getDefaultProps())));
61
- await waitFor(() => {
62
- expect(screen.getByText('First Loaded Step')).toBeInTheDocument();
63
- });
64
- expect(scrollIntoViewMock).not.toHaveBeenCalled();
65
- });
66
- });
67
- describe('when loading a step', () => {
68
- it('attempts to scroll back up to the top of the step', async () => {
69
- const scrollIntoViewMock = vi.fn();
70
- window.HTMLElement.prototype.scrollIntoView = scrollIntoViewMock;
71
- // Element is not visible
72
- window.HTMLElement.prototype.getBoundingClientRect = getMockBoundingClientRect(WINDOW_HEIGHT + 100);
73
- const httpClient = vi
74
- .fn()
75
- .mockImplementation(async () => respondWith(makeStep({ id: 'second-step', title: 'Second Step' })));
76
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ initialStep: makeStep({
77
- id: 'initial-step',
78
- title: 'Initial Step',
79
- layout: [
80
- {
81
- type: 'button',
82
- title: 'Next',
83
- behavior: { type: 'action', action: { url: '/next', method: 'POST' } },
84
- },
85
- ],
86
- }), httpClient: httpClient }, getDefaultProps())));
87
- await waitFor(() => {
88
- expect(screen.getByText('Initial Step')).toBeInTheDocument();
89
- });
90
- await user.click(screen.getByRole('button', { name: 'Next' }));
91
- await waitFor(() => {
92
- expect(screen.getByText('Second Step')).toBeInTheDocument();
93
- });
94
- expect(scrollIntoViewMock).toHaveBeenCalledTimes(1);
95
- });
96
- it('does not attempt to scroll if the top of the step is already visible inside the viewport', async () => {
97
- const scrollIntoViewMock = vi.fn();
98
- window.HTMLElement.prototype.scrollIntoView = scrollIntoViewMock;
99
- // Element is visible
100
- window.HTMLElement.prototype.getBoundingClientRect = getMockBoundingClientRect(WINDOW_HEIGHT / 2);
101
- const httpClient = vi
102
- .fn()
103
- .mockImplementation(async () => respondWith(makeStep({ id: 'second-step', title: 'Second Step' })));
104
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ initialStep: makeStep({
105
- id: 'initial-step',
106
- title: 'Initial Step',
107
- layout: [
108
- {
109
- type: 'button',
110
- title: 'Next',
111
- behavior: { type: 'action', action: { url: '/next', method: 'POST' } },
112
- },
113
- ],
114
- }), httpClient: httpClient }, getDefaultProps())));
115
- await waitFor(() => {
116
- expect(screen.getByText('Initial Step')).toBeInTheDocument();
117
- });
118
- await user.click(screen.getByRole('button', { name: 'Next' }));
119
- await waitFor(() => {
120
- expect(screen.getByText('Second Step')).toBeInTheDocument();
121
- });
122
- expect(scrollIntoViewMock).not.toHaveBeenCalled();
123
- });
124
- });
125
- describe('when an action results in an error', () => {
126
- const httpClient = vi
127
- .fn()
128
- .mockImplementation(async () => respondWithDelay({ error: 'There was a problem' }, 100, { status: 400 }));
129
- const initialStep = makeStep({
130
- layout: [
131
- {
132
- type: 'button',
133
- title: 'Submit',
134
- behavior: {
135
- type: 'action',
136
- action: { url: '/submit', method: 'POST' },
137
- },
138
- },
139
- ],
140
- });
141
- it('shows a global error which is scrolled into view', async () => {
142
- const scrollIntoViewMock = vi.fn();
143
- window.HTMLElement.prototype.scrollIntoView = scrollIntoViewMock;
144
- // Element is not visible
145
- window.HTMLElement.prototype.getBoundingClientRect = getMockBoundingClientRect(WINDOW_HEIGHT + 100);
146
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ initialStep: initialStep, httpClient: httpClient }, getDefaultProps())));
147
- await user.click(screen.getByRole('button', { name: 'Submit' }));
148
- await waitFor(() => {
149
- expect(screen.getByText('There was a problem')).toBeInTheDocument();
150
- });
151
- expect(scrollIntoViewMock).toHaveBeenCalled();
152
- });
153
- it('does not scroll to the error again if the button is clicked but the message does not change', async () => {
154
- const scrollIntoViewMock = vi.fn();
155
- window.HTMLElement.prototype.scrollIntoView = scrollIntoViewMock;
156
- // Element is not visible
157
- window.HTMLElement.prototype.getBoundingClientRect = getMockBoundingClientRect(WINDOW_HEIGHT + 100);
158
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ initialStep: initialStep, httpClient: httpClient }, getDefaultProps())));
159
- await user.click(screen.getByRole('button', { name: 'Submit' }));
160
- await waitFor(() => {
161
- expect(screen.getByText('There was a problem')).toBeInTheDocument();
162
- });
163
- await user.click(screen.getByRole('button', { name: 'Submit' }));
164
- await waitFor(() => {
165
- expect(scrollIntoViewMock).toHaveBeenCalledTimes(1);
166
- });
167
- });
168
- });
169
- describe('when refresh on change returns a step with an error', () => {
170
- const httpClient = vi
171
- .fn()
172
- .mockImplementation(async () => respondWith(Object.assign(Object.assign({}, step), { errors: { error: 'There was a problem' } }), { status: 200 }));
173
- const step = {
174
- id: 'step-id',
175
- title: 'Step',
176
- refreshUrl: '/refresh',
177
- schemas: [
178
- {
179
- $id: '#iban',
180
- type: 'string',
181
- title: 'IBAN',
182
- refreshStepOnChange: true,
183
- },
184
- ],
185
- layout: [
186
- {
187
- type: 'form',
188
- schemaId: '#iban',
189
- },
190
- {
191
- type: 'button',
192
- title: 'Submit',
193
- behavior: {
194
- type: 'action',
195
- action: {
196
- url: '/submit',
197
- method: 'POST',
198
- },
199
- },
200
- },
201
- ],
202
- };
203
- it('shows a global error which is scrolled into view', async () => {
204
- const scrollIntoViewMock = vi.fn();
205
- window.HTMLElement.prototype.scrollIntoView = scrollIntoViewMock;
206
- // Element is not visible
207
- window.HTMLElement.prototype.getBoundingClientRect = getMockBoundingClientRect(WINDOW_HEIGHT + 100);
208
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ initialStep: step, httpClient: httpClient }, getDefaultProps())));
209
- await user.type(screen.getByLabelText('IBAN'), '12345');
210
- await act(async () => vi.advanceTimersByTimeAsync(1000)); // wait for debounce
211
- await waitFor(() => {
212
- expect(screen.getByText('There was a problem')).toBeInTheDocument();
213
- });
214
- expect(scrollIntoViewMock).toHaveBeenCalledTimes(1);
215
- });
216
- });
217
- });
@@ -1,49 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { renderWithProviders } from '../test-utils';
3
- import DynamicFlowWise from '../test-utils/DynamicFlowWise';
4
- import { screen } from '@testing-library/react';
5
- import { vi } from 'vitest';
6
- describe('given a step with a oneOf schema with control segmented', () => {
7
- const makeConstSchema = (options) => ({
8
- oneOf: Array(options)
9
- .fill(0)
10
- .map((value, index) => ({
11
- const: String(index),
12
- title: `Option ${index + 1}`,
13
- })),
14
- title: '',
15
- control: 'segmented',
16
- });
17
- const initialStep = (options) => ({
18
- id: 'step-id',
19
- title: 'title',
20
- layout: [
21
- {
22
- type: 'form',
23
- schemaId: '#schema',
24
- },
25
- ],
26
- schemas: [
27
- {
28
- $id: '#schema',
29
- type: 'object',
30
- displayOrder: ['paymentMethod'],
31
- properties: {
32
- paymentMethod: makeConstSchema(options),
33
- },
34
- },
35
- ],
36
- });
37
- it('when it has 3 or fewer children, a SegmentedControl is rendered', () => {
38
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "flow", initialStep: initialStep(3), httpClient: vi.fn(), onError: vi.fn(), onCompletion: vi.fn() }));
39
- expect(screen.getByText('Option 1')).toBeInTheDocument();
40
- expect(screen.getByText('Option 2')).toBeInTheDocument();
41
- expect(screen.getByText('Option 3')).toBeInTheDocument();
42
- });
43
- it('when it has more than 3 children, a select is rendered', () => {
44
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "flow", initialStep: initialStep(4), httpClient: vi.fn(), onError: vi.fn(), onCompletion: vi.fn() }));
45
- expect(screen.queryByText('Option 1')).not.toBeInTheDocument();
46
- expect(screen.queryByText('Option 2')).not.toBeInTheDocument();
47
- expect(screen.queryByText('Option 3')).not.toBeInTheDocument();
48
- });
49
- });