@wise/dynamic-flow-client 5.8.1 → 5.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (420) hide show
  1. package/build/DynamicFlowCore.js +5 -0
  2. package/build/common/errorBoundary/ErrorBoundary.js +26 -0
  3. package/build/common/errorBoundary/ErrorBoundary.test.js +29 -0
  4. package/build/common/errorBoundary/ErrorBoundaryAlert.js +11 -0
  5. package/build/common/makeHttpClient/api-utils.js +3 -0
  6. package/build/common/makeHttpClient/index.js +1 -0
  7. package/build/common/makeHttpClient/makeHttpClient.js +10 -0
  8. package/build/common/makeHttpClient/makeHttpClient.test.js +186 -0
  9. package/build/common/messages/external-confirmation.messages.js +23 -0
  10. package/build/common/messages/file-upload.messages.js +13 -0
  11. package/build/common/messages/generic-error.messages.js +18 -0
  12. package/build/common/messages/help.messages.js +8 -0
  13. package/build/common/messages/multi-file-upload.messages.js +18 -0
  14. package/build/common/messages/multi-select.messages.js +8 -0
  15. package/build/common/messages/paragraph.messages.js +13 -0
  16. package/build/common/messages/repeatable.messages.js +23 -0
  17. package/build/common/messages/search.messages.js +8 -0
  18. package/build/common/messages/validation.array.messages.js +13 -0
  19. package/build/common/messages/validation.messages.js +53 -0
  20. package/build/controller/FlowController.js +368 -0
  21. package/build/controller/executePoll.js +49 -0
  22. package/build/controller/executeRefresh.js +39 -0
  23. package/build/controller/executeRequest.js +77 -0
  24. package/build/controller/executeSubmission.js +69 -0
  25. package/build/controller/getErrorMessage.js +7 -0
  26. package/build/controller/getRequestAbortController.js +13 -0
  27. package/build/controller/getResponseType.js +35 -0
  28. package/build/controller/getSafeHttpClient.js +8 -0
  29. package/build/controller/getStepCounter.js +16 -0
  30. package/build/controller/handleErrorResponse.js +26 -0
  31. package/build/controller/makeSafeHttpClient.js +8 -0
  32. package/build/controller/response-utils.js +72 -0
  33. package/build/domain/components/AlertComponent.js +1 -0
  34. package/build/domain/components/AllOfComponent.js +40 -0
  35. package/build/domain/components/BooleanInputComponent.js +50 -0
  36. package/build/domain/components/BoxComponent.js +3 -0
  37. package/build/domain/components/ButtonComponent.js +1 -0
  38. package/build/domain/components/ColumnsComponent.js +3 -0
  39. package/build/domain/components/ConstComponent.js +18 -0
  40. package/build/domain/components/ContainerComponent.js +3 -0
  41. package/build/domain/components/DateInputComponent.js +75 -0
  42. package/build/domain/components/DecisionComponent.js +1 -0
  43. package/build/domain/components/DividerComponent.js +1 -0
  44. package/build/domain/components/FormComponent.js +3 -0
  45. package/build/domain/components/FormattedValueComponent.js +44 -0
  46. package/build/domain/components/HeadingComponent.js +1 -0
  47. package/build/domain/components/ImageComponent.js +1 -0
  48. package/build/domain/components/InstructionsComponent.js +1 -0
  49. package/build/domain/components/IntegerInputComponent.js +74 -0
  50. package/build/domain/components/ListComponent.js +1 -0
  51. package/build/domain/components/LoadingIndicatorComponent.js +1 -0
  52. package/build/domain/components/MarkdownComponent.js +1 -0
  53. package/build/domain/components/MediaComponent.js +1 -0
  54. package/build/domain/components/ModalComponent.js +16 -0
  55. package/build/domain/components/ModalLayoutComponent.js +3 -0
  56. package/build/domain/components/MoneyInputComponent.js +57 -0
  57. package/build/domain/components/MultiSelectInputComponent.js +81 -0
  58. package/build/domain/components/MultiUploadInputComponent.js +88 -0
  59. package/build/domain/components/NumberInputComponent.js +73 -0
  60. package/build/domain/components/ObjectComponent.js +45 -0
  61. package/build/domain/components/ParagraphComponent.js +1 -0
  62. package/build/domain/components/PersistAsyncComponent.js +92 -0
  63. package/build/domain/components/ProgressComponent.js +1 -0
  64. package/build/domain/components/RepeatableComponent.js +103 -0
  65. package/build/domain/components/ReviewComponent.js +1 -0
  66. package/build/domain/components/RootDomainComponent.js +173 -0
  67. package/build/domain/components/SectionComponent.js +5 -0
  68. package/build/domain/components/SelectInputComponent.js +88 -0
  69. package/build/domain/components/StatusListComponent.js +1 -0
  70. package/build/domain/components/SubflowDomainComponent.js +9 -0
  71. package/build/domain/components/TabsComponent.js +1 -0
  72. package/build/domain/components/TextInputComponent.js +76 -0
  73. package/build/domain/components/TupleComponent.js +41 -0
  74. package/build/domain/components/UploadInputComponent.js +83 -0
  75. package/build/domain/components/UpsellComponent.js +25 -0
  76. package/build/domain/components/searchComponent/SearchComponent.js +92 -0
  77. package/build/domain/components/searchComponent/SearchComponent.test.js +190 -0
  78. package/build/domain/components/step/ExternalConfirmationComponent.js +28 -0
  79. package/build/domain/components/step/StepDomainComponent.js +73 -0
  80. package/build/domain/components/step/ToolbarComponent.js +1 -0
  81. package/build/domain/components/utils/WithUpdate.js +1 -0
  82. package/build/domain/components/utils/component-utils.js +12 -0
  83. package/build/domain/components/utils/debounce.js +34 -0
  84. package/build/domain/components/utils/debounce.test.js +67 -0
  85. package/build/domain/components/utils/file-utils.js +21 -0
  86. package/build/domain/components/utils/file-utils.test.js +27 -0
  87. package/build/domain/components/utils/getRandomId.js +1 -0
  88. package/build/domain/components/utils/isExactLocalValueMatch.js +14 -0
  89. package/build/domain/components/utils/isOrWasValid.js +5 -0
  90. package/build/domain/components/utils/isPartialModelMatch.js +18 -0
  91. package/build/domain/components/utils/isPartialModelMatch.test.js +74 -0
  92. package/build/domain/features/eventNames.js +24 -0
  93. package/build/domain/features/events.js +1 -0
  94. package/build/domain/features/persistAsync/getComponentMultiPersistAsync.js +50 -0
  95. package/build/domain/features/persistAsync/getInitialPersistedState.js +7 -0
  96. package/build/domain/features/persistAsync/getPerformPersistAsync.js +43 -0
  97. package/build/domain/features/persistAsync/getPerformPersistAsync.test.js +139 -0
  98. package/build/domain/features/polling/getStepPolling.js +43 -0
  99. package/build/domain/features/polling/getStepPolling.test.js +90 -0
  100. package/build/domain/features/prefetch/getStepPrefetch.js +43 -0
  101. package/build/domain/features/prefetch/request-cache.js +49 -0
  102. package/build/domain/features/prefetch/request-cache.test.js +70 -0
  103. package/build/domain/features/refreshAfter/getStepRefreshAfter.js +24 -0
  104. package/build/domain/features/refreshAfter/getStepRefreshAfter.test.js +40 -0
  105. package/build/domain/features/schema-on-change/getDebouncedSchemaOnChange.js +50 -0
  106. package/build/domain/features/schema-on-change/getSchemaOnChange.js +34 -0
  107. package/build/domain/features/search/getPerformSearchFunction.js +75 -0
  108. package/build/domain/features/search/getPerformSearchFunction.test.js +301 -0
  109. package/build/domain/features/summary/summary-utils.js +40 -0
  110. package/build/domain/features/summary/summary-utils.test.js +125 -0
  111. package/build/domain/features/utils/http-utils.js +21 -0
  112. package/build/domain/features/utils/response-utils.js +9 -0
  113. package/build/domain/features/validation/spec-utils.js +19 -0
  114. package/build/domain/features/validation/validateStringPattern.js +24 -0
  115. package/build/domain/features/validation/validation-functions.js +6 -0
  116. package/build/domain/features/validation/validation-functions.test.js +108 -0
  117. package/build/domain/features/validation/value-checks.js +125 -0
  118. package/build/domain/features/validation/value-checks.test.js +262 -0
  119. package/build/domain/features/validationAsync/getComponentValidationAsync.js +53 -0
  120. package/build/domain/features/validationAsync/getComponentValidationAsync.test.js +67 -0
  121. package/build/domain/features/validationAsync/getInitialValidationAsyncState.js +5 -0
  122. package/build/domain/features/validationAsync/getPerformValidationAsync.js +45 -0
  123. package/build/domain/features/validationAsync/getPerformValidationAsync.test.js +143 -0
  124. package/build/domain/mappers/layout/alertLayoutToComponent.js +16 -0
  125. package/build/domain/mappers/layout/boxLayoutToComponent.js +13 -0
  126. package/build/domain/mappers/layout/buttonLayoutToComponent.js +77 -0
  127. package/build/domain/mappers/layout/columnsLayoutToComponent.js +13 -0
  128. package/build/domain/mappers/layout/decisionLayoutToComponent.js +22 -0
  129. package/build/domain/mappers/layout/deprecatedListLayoutToComponent.js +30 -0
  130. package/build/domain/mappers/layout/dividerLayoutToComponent.js +2 -0
  131. package/build/domain/mappers/layout/formLayoutToComponent.js +19 -0
  132. package/build/domain/mappers/layout/headingLayoutToComponent.js +12 -0
  133. package/build/domain/mappers/layout/imageLayoutToComponent.js +20 -0
  134. package/build/domain/mappers/layout/infoLayoutToComponent.js +12 -0
  135. package/build/domain/mappers/layout/instructionsLayoutToComponent.js +12 -0
  136. package/build/domain/mappers/layout/listLayoutToComponent.js +39 -0
  137. package/build/domain/mappers/layout/loadingIndicatorLayoutToComponent.js +9 -0
  138. package/build/domain/mappers/layout/markdownLayoutToComponent.js +12 -0
  139. package/build/domain/mappers/layout/mediaLayoutToComponent.js +12 -0
  140. package/build/domain/mappers/layout/modalLayoutToComponent.js +17 -0
  141. package/build/domain/mappers/layout/modalToComponent.js +8 -0
  142. package/build/domain/mappers/layout/paragraphLayoutToComponent.js +12 -0
  143. package/build/domain/mappers/layout/progressLayoutToComponent.js +15 -0
  144. package/build/domain/mappers/layout/reviewLayoutToComponent.js +48 -0
  145. package/build/domain/mappers/layout/searchLayoutToComponent.js +44 -0
  146. package/build/domain/mappers/layout/sectionLayoutToComponent.js +15 -0
  147. package/build/domain/mappers/layout/statusListLayoutToComponent.js +15 -0
  148. package/build/domain/mappers/layout/tabsLayoutToComponent.js +16 -0
  149. package/build/domain/mappers/layout/upsellLayoutToComponent.js +25 -0
  150. package/build/domain/mappers/mapLayoutToComponent.js +81 -0
  151. package/build/domain/mappers/mapSchemaToComponent.js +61 -0
  152. package/build/domain/mappers/mapSchemaToComponent.test.js +112 -0
  153. package/build/domain/mappers/mapStepSchemas.js +17 -0
  154. package/build/domain/mappers/mapStepToComponent.js +132 -0
  155. package/build/domain/mappers/mapStepToComponent.test.js +221 -0
  156. package/build/domain/mappers/mapToolbarToComponent.js +15 -0
  157. package/build/domain/mappers/schema/allOfSchemaToComponent.js +16 -0
  158. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToComponent.js +26 -0
  159. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiSelectComponent.js +55 -0
  160. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiUploadComponent.js +67 -0
  161. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToRepeatableComponent.js +57 -0
  162. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToTupleComponent.js +20 -0
  163. package/build/domain/mappers/schema/blobSchemaToComponent.js +15 -0
  164. package/build/domain/mappers/schema/booleanSchemaToComponent.js +29 -0
  165. package/build/domain/mappers/schema/constSchemaToComponent.js +23 -0
  166. package/build/domain/mappers/schema/integerSchemaToComponent.js +28 -0
  167. package/build/domain/mappers/schema/numberSchemaToComponent.js +26 -0
  168. package/build/domain/mappers/schema/objectSchemaToComponent/assertDisplayOrder.js +23 -0
  169. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToFormattedValueComponent.js +9 -0
  170. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.js +119 -0
  171. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.test.js +96 -0
  172. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.js +31 -0
  173. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.test.js +99 -0
  174. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.js +76 -0
  175. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.test.js +265 -0
  176. package/build/domain/mappers/schema/persistAsyncSchemaToComponent.js +29 -0
  177. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.js +18 -0
  178. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.test.js +133 -0
  179. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToDateInputComponent.js +48 -0
  180. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToTextInputComponent.js +37 -0
  181. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToUploadInputComponent.js +28 -0
  182. package/build/domain/mappers/schema/tests/test-utils.js +16 -0
  183. package/build/domain/mappers/schema/types.js +1 -0
  184. package/build/domain/mappers/schema/utils/getPerformPersistAsyncFn.js +19 -0
  185. package/build/domain/mappers/schema/utils/getValidationAsyncInitialState.js +23 -0
  186. package/build/domain/mappers/schema/utils/mapCommonSchemaProps.js +16 -0
  187. package/build/domain/mappers/types.js +1 -0
  188. package/build/domain/mappers/utils/FeatureFlags.js +22 -0
  189. package/build/domain/mappers/utils/behavior-utils.js +44 -0
  190. package/build/domain/mappers/utils/call-to-action-utils.js +21 -0
  191. package/build/domain/mappers/utils/getAutocompleteString.js +76 -0
  192. package/build/domain/mappers/utils/getAutocompleteString.test.js +21 -0
  193. package/build/domain/mappers/utils/groupLayoutByPinned.js +38 -0
  194. package/build/domain/mappers/utils/groupLayoutByPinned.test.js +166 -0
  195. package/build/domain/mappers/utils/image.js +9 -0
  196. package/build/domain/mappers/utils/layout-utils.js +11 -0
  197. package/build/domain/mappers/utils/legacy-utils.js +49 -0
  198. package/build/domain/mappers/utils/media-utils.js +14 -0
  199. package/build/domain/mappers/utils/suggestions-utils.js +26 -0
  200. package/build/domain/mappers/utils/suggestions-utils.test.js +36 -0
  201. package/build/domain/mappers/utils/tags-utils.js +1 -0
  202. package/build/domain/mappers/utils/utils.js +35 -0
  203. package/build/domain/types.js +1 -0
  204. package/build/getSubflowCallbacks.js +38 -0
  205. package/build/i18n/index.js +40 -0
  206. package/build/index.js +8 -0
  207. package/build/main.js +112 -54
  208. package/build/main.mjs +111 -53
  209. package/build/renderers/CoreContainerRenderer.js +5 -0
  210. package/build/renderers/CoreRootRenderer.js +12 -0
  211. package/build/renderers/EmptyLoadingStateRenderer.js +5 -0
  212. package/build/renderers/getRenderFunction.js +24 -0
  213. package/build/renderers/getSchemaErrorMessageFunction.js +97 -0
  214. package/build/renderers/mappers/alertComponentToProps.js +2 -0
  215. package/build/renderers/mappers/allOfComponentToProps.js +6 -0
  216. package/build/renderers/mappers/booleanInputComponentToProps.js +5 -0
  217. package/build/renderers/mappers/boxComponentToProps.js +13 -0
  218. package/build/renderers/mappers/buttonComponentToProps.js +4 -0
  219. package/build/renderers/mappers/columnsComponentToProps.js +11 -0
  220. package/build/renderers/mappers/componentToRendererProps.js +164 -0
  221. package/build/renderers/mappers/constComponentToProps.js +5 -0
  222. package/build/renderers/mappers/containerComponentToProps.js +7 -0
  223. package/build/renderers/mappers/dateInputComponentToProps.js +2 -0
  224. package/build/renderers/mappers/decisionComponentToProps.js +16 -0
  225. package/build/renderers/mappers/dividerComponentToProps.js +2 -0
  226. package/build/renderers/mappers/externalComponentToProps.js +3 -0
  227. package/build/renderers/mappers/formComponentToProps.js +12 -0
  228. package/build/renderers/mappers/formattedValueComponentToProps.js +5 -0
  229. package/build/renderers/mappers/headingComponentToProps.js +2 -0
  230. package/build/renderers/mappers/hiddenComponentToProps.js +4 -0
  231. package/build/renderers/mappers/imageComponentToProps.js +2 -0
  232. package/build/renderers/mappers/instructionsComponentToProps.js +2 -0
  233. package/build/renderers/mappers/integerInputComponentToProps.js +2 -0
  234. package/build/renderers/mappers/listComponentToProps.js +2 -0
  235. package/build/renderers/mappers/loadingIndicatorComponentToProps.js +2 -0
  236. package/build/renderers/mappers/markdownComponentToProps.js +2 -0
  237. package/build/renderers/mappers/mediaComponentToProps.js +2 -0
  238. package/build/renderers/mappers/modalComponentToProps.js +11 -0
  239. package/build/renderers/mappers/modalLayoutComponentToProps.js +16 -0
  240. package/build/renderers/mappers/moneyInputComponentToProps.js +36 -0
  241. package/build/renderers/mappers/multiSelectComponentToProps.js +23 -0
  242. package/build/renderers/mappers/multiUploadInputComponentToProps.js +12 -0
  243. package/build/renderers/mappers/numberInputComponentToProps.js +2 -0
  244. package/build/renderers/mappers/objectComponentToProps.js +8 -0
  245. package/build/renderers/mappers/paragraphComponentToProps.js +2 -0
  246. package/build/renderers/mappers/persistAsyncComponentToProps.js +8 -0
  247. package/build/renderers/mappers/progressComponentToProps.js +2 -0
  248. package/build/renderers/mappers/repeatableComponentToProps.js +30 -0
  249. package/build/renderers/mappers/reviewComponentToProps.js +2 -0
  250. package/build/renderers/mappers/rootComponentToProps.js +21 -0
  251. package/build/renderers/mappers/searchComponentToProps.js +57 -0
  252. package/build/renderers/mappers/sectionComponentToProps.js +6 -0
  253. package/build/renderers/mappers/selectInputComponentToProps.js +26 -0
  254. package/build/renderers/mappers/statusListComponentToProps.js +2 -0
  255. package/build/renderers/mappers/subflowComponentToRendererProps.js +4 -0
  256. package/build/renderers/mappers/tabsComponentToProps.js +14 -0
  257. package/build/renderers/mappers/textInputComponentToProps.js +2 -0
  258. package/build/renderers/mappers/tupleComponentToProps.js +8 -0
  259. package/build/renderers/mappers/uploadInputComponentToProps.js +8 -0
  260. package/build/renderers/mappers/upsellComponentToProps.js +2 -0
  261. package/build/renderers/mappers/utils/getValidationState.js +12 -0
  262. package/build/renderers/mappers/utils/inputComponentToProps.js +26 -0
  263. package/build/renderers/mappers/utils/mapErrorsToValidationState.js +9 -0
  264. package/build/renderers/mappers/utils/pick.js +8 -0
  265. package/build/renderers/mappers/utils/selectInputOptionsToProps.js +11 -0
  266. package/build/renderers/stepComponentToProps.js +32 -0
  267. package/build/renderers/utils.js +69 -0
  268. package/build/renderers/utils.test.js +70 -0
  269. package/build/stories/dev-tools/ContainerQueries.story.js +66 -0
  270. package/build/stories/dev-tools/Debugger.story.js +38 -0
  271. package/build/stories/dev-tools/FixtureSelect.story.js +23 -0
  272. package/build/stories/dev-tools/TestServer.story.js +32 -0
  273. package/build/stories/examples/NativeFlow.story.js +80 -0
  274. package/build/stories/examples/Recipients.story.js +568 -0
  275. package/build/stories/spec/behavior/Copy.story.js +59 -0
  276. package/build/stories/spec/behavior/Modal.story.js +76 -0
  277. package/build/stories/spec/behavior/Subflow.story.js +267 -0
  278. package/build/stories/spec/layouts/Decision.story.js +241 -0
  279. package/build/stories/spec/layouts/Image.story.js +42 -0
  280. package/build/stories/spec/layouts/Modal.story.js +81 -0
  281. package/build/stories/spec/layouts/Search.story.js +325 -0
  282. package/build/stories/spec/layouts/Upsell.story.js +55 -0
  283. package/build/stories/spec/layouts/button/Button.story.js +100 -0
  284. package/build/stories/spec/layouts/button/PinnedButton.story.js +81 -0
  285. package/build/stories/spec/response/ActionResponse.story.js +66 -0
  286. package/build/stories/spec/schemas/MultiSelect.story.js +148 -0
  287. package/build/stories/spec/schemas/Upload.story.js +168 -0
  288. package/build/stories/spec/schemas/const/ConstLayout.story.js +159 -0
  289. package/build/stories/spec/schemas/const/ObjectConst.story.js +94 -0
  290. package/build/stories/spec/schemas/features/PersistAsync.story.js +176 -0
  291. package/build/stories/spec/schemas/features/ValidationAsync.story.js +103 -0
  292. package/build/stories/spec/schemas/object/FormattedValue.story.js +92 -0
  293. package/build/stories/spec/schemas/object/MoneyInput.story.js +240 -0
  294. package/build/stories/spec/schemas/oneOf/OneOfInitialisation.story.js +55 -0
  295. package/build/stories/spec/step/Controls.story.js +109 -0
  296. package/build/stories/spec/step/DFModal.story.js +58 -0
  297. package/build/stories/spec/step/Footer.story.js +70 -0
  298. package/build/stories/spec/step/Navigation.story.js +20 -0
  299. package/build/stories/spec/step/Tags.story.js +39 -0
  300. package/build/stories/spec/step/ToolBar.story.js +60 -0
  301. package/build/stories/spec/step/features/ErrorHandling.story.js +92 -0
  302. package/build/stories/spec/step/features/External.story.js +44 -0
  303. package/build/stories/spec/step/features/Polling.story.js +108 -0
  304. package/build/stories/spec/step/features/RefreshAfter.story.js +92 -0
  305. package/build/stories/spec/step/features/refresh/Refresh.story.js +258 -0
  306. package/build/stories/spec/step/features/refresh/RefreshWithPersistAsync.story.js +958 -0
  307. package/build/stories/types.js +1 -0
  308. package/build/stories/utils/fixtureHttpClient.js +70 -0
  309. package/build/stories/utils/getBasicStep.js +223 -0
  310. package/build/stories/utils/mockSearchHandler.js +71 -0
  311. package/build/stories/utils/render-utils.js +41 -0
  312. package/build/stories/visual-tests/layouts/NotUsingListItem.story.js +17 -0
  313. package/build/test-utils/DynamicFlowWise.js +32 -0
  314. package/build/test-utils/DynamicFlowWiseModal.js +34 -0
  315. package/build/test-utils/NeptuneProviders.js +11 -0
  316. package/build/test-utils/component-utils.js +5 -0
  317. package/build/test-utils/fetch-utils.js +45 -0
  318. package/build/test-utils/getMergedTestRenderers.js +34 -0
  319. package/build/test-utils/getRandomId.js +1 -0
  320. package/build/test-utils/index.js +3 -0
  321. package/build/test-utils/rtl-utils.js +7 -0
  322. package/build/test-utils/step-utils.js +6 -0
  323. package/build/test-utils/wait.js +3 -0
  324. package/build/tests/AlertLayout.test.js +78 -0
  325. package/build/tests/ArrayTuple.test.js +118 -0
  326. package/build/tests/ButtonLayout.test.js +308 -0
  327. package/build/tests/ConstLayout.test.js +95 -0
  328. package/build/tests/DateInput.test.js +163 -0
  329. package/build/tests/DecisionLayout.test.js +146 -0
  330. package/build/tests/DynamicFlow.test.js +147 -0
  331. package/build/tests/External.test.js +169 -0
  332. package/build/tests/Flow.test.js +328 -0
  333. package/build/tests/FormLayout.test.js +28 -0
  334. package/build/tests/FormattedValue.test.js +107 -0
  335. package/build/tests/ImageRenderer.test.js +78 -0
  336. package/build/tests/InitialAction.test.js +179 -0
  337. package/build/tests/InitialStep.test.js +168 -0
  338. package/build/tests/InstructionsLayout.test.js +45 -0
  339. package/build/tests/ListLayout.test.js +145 -0
  340. package/build/tests/Logging.test.js +53 -0
  341. package/build/tests/ModalBehavior.test.js +149 -0
  342. package/build/tests/MoneyInput.test.js +316 -0
  343. package/build/tests/MultiUpload.test.js +293 -0
  344. package/build/tests/NativeBack.test.js +267 -0
  345. package/build/tests/OneOfInitialisation.test.js +571 -0
  346. package/build/tests/PersistAsync.test.js +653 -0
  347. package/build/tests/Polling.test.js +617 -0
  348. package/build/tests/Prefetching.test.js +230 -0
  349. package/build/tests/RefreshAfter.test.js +63 -0
  350. package/build/tests/RefreshOnChange.ResponseHandling.test.js +205 -0
  351. package/build/tests/RefreshOnChange.test.js +233 -0
  352. package/build/tests/RefreshOnChange.with.Segmented.test.js +348 -0
  353. package/build/tests/RefreshOnChange.with.Tabs.test.js +358 -0
  354. package/build/tests/RefreshOnChangePreserve.test.js +224 -0
  355. package/build/tests/RendererProps.test.js +342 -0
  356. package/build/tests/Repeatable.test.js +107 -0
  357. package/build/tests/Rerendering.test.js +67 -0
  358. package/build/tests/ReviewLayout.test.js +274 -0
  359. package/build/tests/SchemaOnChange.test.js +133 -0
  360. package/build/tests/ScrollToError.test.js +217 -0
  361. package/build/tests/SegmentedControl.test.js +49 -0
  362. package/build/tests/SingleFileUpload.test.js +88 -0
  363. package/build/tests/StatusList.test.js +85 -0
  364. package/build/tests/Subflow.test.js +710 -0
  365. package/build/tests/Submission.ResponseHandling.test.js +557 -0
  366. package/build/tests/Submission.merging.test.js +202 -0
  367. package/build/tests/Submission.test.js +523 -0
  368. package/build/tests/Tags.test.js +475 -0
  369. package/build/tests/Upsell.test.js +126 -0
  370. package/build/tests/ValidationAsync.test.js +295 -0
  371. package/build/tests/legacy/Actions.test.js +158 -0
  372. package/build/tests/legacy/BackButton.test.js +114 -0
  373. package/build/tests/legacy/HiddenSchemas.test.js +246 -0
  374. package/build/tests/legacy/MultiSelect.test.js +497 -0
  375. package/build/tests/legacy/MultipleFileUploadSchema.test.js +341 -0
  376. package/build/tests/legacy/PersistAsync.blob-schema.test.js +224 -0
  377. package/build/tests/legacy/PersistAsync.string-schema.test.js +211 -0
  378. package/build/tests/legacy/RefreshStepOnChange.debouncing.test.js +209 -0
  379. package/build/tests/legacy/RefreshStepOnChange.test.js +424 -0
  380. package/build/tests/legacy/Search.test.js +437 -0
  381. package/build/tests/renderers/MultiSelectInputRendererProps.test.js +58 -0
  382. package/build/tests/renderers/SelectInputRendererProps.test.js +42 -0
  383. package/build/tests/renderers/TextInputRenderer.test.js +51 -0
  384. package/build/types/domain/components/UpsellComponent.d.ts +2 -3
  385. package/build/types/domain/components/UpsellComponent.d.ts.map +1 -1
  386. package/build/types/domain/components/searchComponent/SearchComponent.d.ts +5 -4
  387. package/build/types/domain/components/searchComponent/SearchComponent.d.ts.map +1 -1
  388. package/build/types/domain/features/search/getPerformSearchFunction.d.ts +1 -1
  389. package/build/types/domain/features/search/getPerformSearchFunction.d.ts.map +1 -1
  390. package/build/types/domain/mappers/layout/searchLayoutToComponent.d.ts +2 -1
  391. package/build/types/domain/mappers/layout/searchLayoutToComponent.d.ts.map +1 -1
  392. package/build/types/domain/mappers/layout/upsellLayoutToComponent.d.ts +1 -1
  393. package/build/types/domain/mappers/layout/upsellLayoutToComponent.d.ts.map +1 -1
  394. package/build/types/renderers/EmptyLoadingStateRenderer.d.ts +3 -0
  395. package/build/types/renderers/EmptyLoadingStateRenderer.d.ts.map +1 -0
  396. package/build/types/renderers/mappers/rootComponentToProps.d.ts.map +1 -1
  397. package/build/types/renderers/mappers/searchComponentToProps.d.ts +1 -1
  398. package/build/types/renderers/mappers/searchComponentToProps.d.ts.map +1 -1
  399. package/build/types/renderers/mappers/upsellComponentToProps.d.ts +2 -2
  400. package/build/types/renderers/mappers/upsellComponentToProps.d.ts.map +1 -1
  401. package/build/types/test-utils/getMergedTestRenderers.d.ts +1 -1
  402. package/build/types/test-utils/getMergedTestRenderers.d.ts.map +1 -1
  403. package/build/types/useDynamicFlow.d.ts.map +1 -1
  404. package/build/types.js +1 -0
  405. package/build/useDynamicFlow.js +104 -0
  406. package/build/useDynamicFlowModal.js +58 -0
  407. package/build/utils/analyse-step.js +14 -0
  408. package/build/utils/component-utils.js +8 -0
  409. package/build/utils/component-utils.test.js +113 -0
  410. package/build/utils/getScrollToTop.js +12 -0
  411. package/build/utils/normalise-flow-id.js +1 -0
  412. package/build/utils/normalise-flow-id.test.js +24 -0
  413. package/build/utils/openLinkInNewTab.js +10 -0
  414. package/build/utils/recursiveMerge.js +40 -0
  415. package/build/utils/recursiveMerge.test.js +93 -0
  416. package/build/utils/type-utils.js +21 -0
  417. package/build/utils/type-validators.js +11 -0
  418. package/build/utils/type-validators.test.js +180 -0
  419. package/build/utils/useStableCallback.js +15 -0
  420. package/package.json +4 -4
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,70 @@
1
+ import { action } from 'storybook/actions';
2
+ import { layouts, schemas, responses } from '@wise/dynamic-flow-fixtures';
3
+ export const getObjectKeys = Object.keys;
4
+ const fixtures = Object.assign(Object.assign({}, schemas), layouts);
5
+ const isObject = (val) => typeof val === 'object' && val !== null;
6
+ export const fixtureHttpClient = async (input, init) => {
7
+ action('fixtureHttpClient')(input, init);
8
+ const url = getURL(input);
9
+ if (url.pathname.startsWith('/steps/')) {
10
+ return respondWithFixture(fixtures, url, init);
11
+ }
12
+ if (url.pathname.startsWith('/responses/')) {
13
+ return respondWithFixture(responses, url, init);
14
+ }
15
+ if (url.pathname.startsWith('/validate')) {
16
+ return new Response(JSON.stringify({ message: 'Validation-async OK' }));
17
+ }
18
+ if (url.pathname.startsWith('/persist-async')) {
19
+ return Promise.resolve(new Response(JSON.stringify({ nameToken: '123456' }), { status: 200 }));
20
+ }
21
+ if (url.pathname.startsWith('/validate')) {
22
+ return new Response(JSON.stringify({ message: 'Validation-async OK' }));
23
+ }
24
+ if (url.pathname.startsWith('/refresh')) {
25
+ return new Response(null, { status: 304 });
26
+ }
27
+ return new Response(null, { status: 404 });
28
+ };
29
+ const getURL = (input) => {
30
+ if (input instanceof URL) {
31
+ return input;
32
+ }
33
+ if (input instanceof Request) {
34
+ return new URL(input.url, 'http://foo');
35
+ }
36
+ return new URL(input, 'http://foo');
37
+ };
38
+ const respondWithFixture = async (fixtureList, url, init) => {
39
+ var _a;
40
+ const fixtureNames = getObjectKeys(fixtureList);
41
+ const name = url.pathname
42
+ .split('/')
43
+ .filter((part) => Boolean(part))
44
+ .pop();
45
+ if (!fixtureNames.includes(name !== null && name !== void 0 ? name : '')) {
46
+ action('ERROR 404')(url);
47
+ return new Response(null, { status: 404 });
48
+ }
49
+ const fixture = fixtureList[name];
50
+ // By convention if the url contains a "delay" query parameter, we delay the response
51
+ if (url.searchParams.has('delay')) {
52
+ await new Promise((resolve) => {
53
+ setTimeout(resolve, Number(url.searchParams.get('delay')));
54
+ });
55
+ }
56
+ // By convention if the url contains a "refresh" query parameter, we use the payload as model
57
+ if (url.searchParams.has('refresh') &&
58
+ (init === null || init === void 0 ? void 0 : init.body) &&
59
+ typeof init.body === 'string' &&
60
+ isObject(fixture)) {
61
+ const body = JSON.parse(init.body);
62
+ return new Response(JSON.stringify(Object.assign(Object.assign({}, fixture), { model: Object.assign(Object.assign({}, ((_a = fixture.model) !== null && _a !== void 0 ? _a : {})), body) })));
63
+ }
64
+ if (url.pathname.includes('exit')) {
65
+ return new Response(JSON.stringify(fixture), {
66
+ headers: { 'X-DF-Exit': 'true' },
67
+ });
68
+ }
69
+ return new Response(JSON.stringify(fixture));
70
+ };
@@ -0,0 +1,223 @@
1
+ export const getBasicStep = () => ({
2
+ id: 'step',
3
+ title: 'Dynamic Flow Step Title',
4
+ schemas: [
5
+ {
6
+ $id: '#personal-details',
7
+ type: 'object',
8
+ title: 'Personal details object',
9
+ description: 'Personal details schema description',
10
+ displayOrder: ['name', 'date', 'occupation', 'age', 'money', 'profileId'],
11
+ alert: {
12
+ type: 'alert',
13
+ markdown: 'Please enter the correct details here',
14
+ },
15
+ properties: {
16
+ profileId: { const: 12345678 },
17
+ name: {
18
+ title: 'Full name',
19
+ type: 'string',
20
+ minLength: 3,
21
+ maxLength: 50,
22
+ help: { markdown: 'Put your name here' },
23
+ validationMessages: {
24
+ required: 'Name is required',
25
+ minLength: 'Name is too short',
26
+ maxLength: 'Name is too long',
27
+ },
28
+ },
29
+ occupation: {
30
+ title: 'Occupation',
31
+ type: 'string',
32
+ },
33
+ date: {
34
+ title: 'Date',
35
+ type: 'string',
36
+ format: 'date',
37
+ control: 'date-lookup',
38
+ minimum: '2023-01-01',
39
+ maximum: '2023-12-31',
40
+ },
41
+ age: {
42
+ title: 'Age',
43
+ type: 'integer',
44
+ minimum: 10,
45
+ maximum: 99,
46
+ help: { markdown: 'Put your age here' },
47
+ validationMessages: {
48
+ required: 'Age is required',
49
+ minimum: 'Age is too low',
50
+ maximum: 'Age is too high',
51
+ },
52
+ alert: { type: 'alert', markdown: 'You must be over 18' },
53
+ },
54
+ money: {
55
+ title: 'How much money would you like?',
56
+ type: 'number',
57
+ minimum: 0,
58
+ maximum: 9999,
59
+ validationMessages: {
60
+ required: 'Money is required',
61
+ minimum: 'Money is too low',
62
+ maximum: 'Money is too high',
63
+ },
64
+ },
65
+ },
66
+ required: ['name', 'age'],
67
+ },
68
+ {
69
+ $id: '#bank-info',
70
+ type: 'object',
71
+ title: 'Bank info object',
72
+ description: 'Bank info schema description',
73
+ displayOrder: ['currency', 'complexOneOf'],
74
+ required: ['currency', 'complexOneOf'],
75
+ properties: {
76
+ currency: {
77
+ description: 'Currency schema description.',
78
+ help: { markdown: 'Currency schema help' },
79
+ control: 'select',
80
+ autocompleteHint: ['transaction-currency'],
81
+ placeholder: 'This is a placeholder',
82
+ disabled: false,
83
+ validationMessages: { required: 'Please select an option' },
84
+ default: 'EUR',
85
+ oneOf: [
86
+ {
87
+ title: 'EUR',
88
+ icon: { name: 'flag-eur' },
89
+ description: 'Euro (schema default)',
90
+ const: 'EUR',
91
+ },
92
+ {
93
+ title: 'GBP',
94
+ icon: { name: 'flag-gbp' },
95
+ description: 'British pound',
96
+ const: { gbp: 'GBP' },
97
+ },
98
+ {
99
+ title: 'USD',
100
+ icon: { name: 'flag-usd' },
101
+ description: 'United States dollar',
102
+ const: 'USD',
103
+ },
104
+ ],
105
+ },
106
+ complexOneOf: {
107
+ title: 'Complex oneOf',
108
+ description: 'Complex oneOf schema description blah blah blah blah.',
109
+ control: 'tab',
110
+ default: { type: 'type-a', accountNumber: '12345678' },
111
+ oneOf: [
112
+ {
113
+ type: 'object',
114
+ title: 'Option A (schema default)',
115
+ icon: { name: 'flag-ars' },
116
+ description: 'Option A description',
117
+ displayOrder: ['type', 'accountNumber', 'sortCodeA'],
118
+ required: ['sortCodeA'],
119
+ properties: {
120
+ type: { const: 'type-a' },
121
+ accountNumber: {
122
+ title: '(A) Account number',
123
+ type: 'string',
124
+ },
125
+ sortCodeA: {
126
+ title: '(A) Sort code',
127
+ type: 'string',
128
+ },
129
+ },
130
+ },
131
+ {
132
+ type: 'object',
133
+ title: 'Option B',
134
+ icon: { name: 'flag-brl' },
135
+ description: 'Option B description',
136
+ displayOrder: ['type', 'accountNumber', 'sortCodeB'],
137
+ properties: {
138
+ type: { const: 'type-b' },
139
+ accountNumber: {
140
+ title: '(B) Account number',
141
+ type: 'string',
142
+ },
143
+ sortCodeB: {
144
+ title: '(B) Sort code',
145
+ type: 'string',
146
+ },
147
+ },
148
+ },
149
+ ],
150
+ },
151
+ },
152
+ },
153
+ ],
154
+ layout: [
155
+ { type: 'heading', text: 'Welcome to the revamped Dynamic Flow', size: 'sm' },
156
+ {
157
+ type: 'alert',
158
+ markdown: 'If you can see this, things are going **well**.',
159
+ context: 'positive',
160
+ },
161
+ {
162
+ type: 'columns',
163
+ left: [
164
+ {
165
+ type: 'form',
166
+ schemaId: '#personal-details',
167
+ },
168
+ ],
169
+ right: [
170
+ {
171
+ type: 'form',
172
+ schemaId: '#bank-info',
173
+ },
174
+ ],
175
+ },
176
+ {
177
+ type: 'columns',
178
+ bias: 'left',
179
+ left: [
180
+ {
181
+ type: 'paragraph',
182
+ text: `Starting paragraph: The Wise account is the universal way for you to manage money internationally. It's made for the world. And it's built to save your money and time, so you can do more of the things you love.`,
183
+ },
184
+ ],
185
+ right: [
186
+ {
187
+ type: 'paragraph',
188
+ text: `Ending paragraph: The Wise account is the universal way for you to manage money internationally. It's made for the world. And it's built to save your money and time, so you can do more of the things you love.`,
189
+ },
190
+ ],
191
+ },
192
+ {
193
+ type: 'box',
194
+ border: true,
195
+ width: 'md',
196
+ components: [
197
+ {
198
+ type: 'paragraph',
199
+ text: `The Wise account is the universal way for you to manage money internationally. It's made for the world. And it's built to save your money and time, so you can do more of the things you love.`,
200
+ align: 'center',
201
+ },
202
+ ],
203
+ },
204
+ {
205
+ type: 'button',
206
+ title: 'Submit',
207
+ control: 'primary',
208
+ action: {
209
+ url: '/submit',
210
+ method: 'POST',
211
+ },
212
+ },
213
+ {
214
+ type: 'button',
215
+ title: 'Cancel',
216
+ control: 'secondary',
217
+ action: {
218
+ url: '/cancel',
219
+ method: 'POST',
220
+ },
221
+ },
222
+ ],
223
+ });
@@ -0,0 +1,71 @@
1
+ import { abortableDelay } from '../../test-utils/fetch-utils';
2
+ export const mockSearchHandler = async (input, init) => {
3
+ var _a;
4
+ if (typeof input !== 'string') {
5
+ return fetch(input, init);
6
+ }
7
+ const query = (init === null || init === void 0 ? void 0 : init.method) === 'POST'
8
+ ? Object.values(JSON.parse(init.body))[0]
9
+ : input.split('=')[1];
10
+ const signal = (_a = init === null || init === void 0 ? void 0 : init.signal) !== null && _a !== void 0 ? _a : null;
11
+ if (query === 'nothing') {
12
+ return abortableDelay(1000, signal).then(async () => Promise.resolve(new Response(JSON.stringify({ results: [] }))));
13
+ }
14
+ if (query === 'error') {
15
+ return abortableDelay(1000, signal).then(async () => Promise.resolve(new Response(null, { status: 500 })));
16
+ }
17
+ if (input.startsWith('/search')) {
18
+ const delay = query.length <= 3 ? 2000 : 1000;
19
+ return abortableDelay(delay, signal).then(async () => Promise.resolve(new Response(JSON.stringify({ results: getFakeSearchResults(query) }))));
20
+ }
21
+ if (input.startsWith('/more-search')) {
22
+ return abortableDelay(1000, signal).then(async () => Promise.resolve(new Response(JSON.stringify({ results: getMoreFakeSearchResults(query) }))));
23
+ }
24
+ return fetch(input, init);
25
+ };
26
+ const getFakeSearchResults = (query) => [
27
+ ...Array.from({ length: 3 }, () => null).map((_, index) => ({
28
+ type: 'action',
29
+ title: `Result #${index + 1} for ${decodeURIComponent(query)}`,
30
+ description: `This is a search result for ${decodeURIComponent(query)}. The type is "action".`,
31
+ icon: { name: 'building' },
32
+ value: {
33
+ url: `/next-step?result=${index + 1}`,
34
+ method: 'GET',
35
+ },
36
+ })),
37
+ {
38
+ type: 'search',
39
+ title: `Search for "more ${decodeURIComponent(query)}"`,
40
+ description: `Search for "get more ${decodeURIComponent(query)}" description. This is a search result using GET method.`,
41
+ icon: { name: 'search' },
42
+ value: {
43
+ url: '/more-search',
44
+ method: 'GET',
45
+ param: 'query',
46
+ query: `get more ${decodeURIComponent(query)}`,
47
+ },
48
+ },
49
+ {
50
+ type: 'search',
51
+ title: `Search for "more ${decodeURIComponent(query)}"`,
52
+ description: `Search for "post more ${decodeURIComponent(query)}" description. This is a search result using POST method.`,
53
+ icon: { name: 'search' },
54
+ value: {
55
+ url: '/more-search',
56
+ method: 'POST',
57
+ param: 'query',
58
+ query: `post more ${decodeURIComponent(query)}`,
59
+ },
60
+ },
61
+ ];
62
+ const getMoreFakeSearchResults = (query) => Array.from({ length: 3 }, () => null).map((_, index) => ({
63
+ type: 'action',
64
+ title: `Another result for "${decodeURIComponent(query)}" - ${index + 1}`,
65
+ description: `Description for this thing.`,
66
+ icon: { name: 'cog' },
67
+ value: {
68
+ url: `/next-step?result=${index + 1}`,
69
+ method: 'GET',
70
+ },
71
+ }));
@@ -0,0 +1,41 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ /* eslint-disable no-bitwise */
3
+ import { fixtureHttpClient } from './fixtureHttpClient';
4
+ import { action } from 'storybook/actions';
5
+ import DynamicFlowWise from '../../test-utils/DynamicFlowWise';
6
+ export const renderWithStep = (step, httpClient = fixtureHttpClient) => renderWithStepAndOverrides(step, { httpClient });
7
+ export const renderWithAction = (initialAction, httpClient = fixtureHttpClient, overrides = {}) => (_jsx(DynamicFlowWise, Object.assign({ flowId: "flow-id", features: {}, httpClient: async (input, init) => {
8
+ action('httpClient')(input, init);
9
+ const response = await httpClient(input, init);
10
+ action('httpClient response status')(response.status);
11
+ return response;
12
+ }, initialAction: initialAction, onCompletion: action('onCompletion'), onEvent: action('onEvent'), onError: (error) => {
13
+ action('onError');
14
+ console.error(error);
15
+ }, onLog: action('onLog'), onCancellation: () => {
16
+ action('onCancellation')('User cancelled the flow');
17
+ } }, overrides), JSON.stringify(initialAction)));
18
+ export const renderWithStepAndOverrides = (step, overrides) => {
19
+ var _a;
20
+ const httpClient = (_a = overrides.httpClient) !== null && _a !== void 0 ? _a : fixtureHttpClient;
21
+ return (_jsx(DynamicFlowWise, Object.assign({ flowId: "flow-id", features: { nativeBack: true }, initialStep: step, onCompletion: action('onCompletion'), onEvent: action('onEvent'), onError: (error) => {
22
+ action('onError');
23
+ console.error(error);
24
+ }, onLog: action('onLog') }, overrides, { httpClient: async (input, init) => {
25
+ action('httpClient')(input, init);
26
+ const response = await httpClient(input, init);
27
+ action('httpClient response status')(response.status);
28
+ return response;
29
+ } }), hashStep(step)));
30
+ };
31
+ // Hash function for steps (thanks claude)
32
+ const hashStep = (step) => {
33
+ const str = JSON.stringify(step);
34
+ let hash = 0;
35
+ for (let i = 0; i < str.length; i += 1) {
36
+ const char = str.charCodeAt(i);
37
+ hash = (hash << 5) - hash + char;
38
+ hash &= hash; // Convert to 32-bit integer
39
+ }
40
+ return Math.abs(hash).toString(36);
41
+ };
@@ -0,0 +1,17 @@
1
+ import DynamicFlowWise from '../../../test-utils/DynamicFlowWise';
2
+ import { layouts } from '@wise/dynamic-flow-fixtures';
3
+ import { getWiseRenderers } from '@wise/dynamic-flow-renderers';
4
+ import { renderWithStepAndOverrides } from '../../utils/render-utils';
5
+ const renderers = getWiseRenderers();
6
+ export default {
7
+ component: DynamicFlowWise,
8
+ title: 'Visual Tests/Layouts/NotUsingListItem',
9
+ };
10
+ const decisionStep = JSON.parse(layouts.decision);
11
+ const listStep = JSON.parse(layouts.list);
12
+ const reviewStep = JSON.parse(layouts.review);
13
+ const statusListStep = JSON.parse(layouts.statusList);
14
+ export const Decision = () => renderWithStepAndOverrides(decisionStep, { renderers });
15
+ export const ListNotUsingListItem = () => renderWithStepAndOverrides(listStep, { renderers });
16
+ export const ReviewNotUsingListItem = () => renderWithStepAndOverrides(reviewStep, { renderers });
17
+ export const StatusListNotUsingListItem = () => renderWithStepAndOverrides(statusListStep, { renderers });
@@ -0,0 +1,32 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { ThemeRequiredEventName, useSnackBarIfAvailable } from '@wise/dynamic-flow-renderers';
3
+ import { useMemo } from 'react';
4
+ import { DynamicFlowCore } from '../DynamicFlowCore';
5
+ import { openLinkInNewTab } from '../utils/openLinkInNewTab';
6
+ import { getMergedTestRenderers } from './getMergedTestRenderers';
7
+ /**
8
+ * This component is only used in tests.
9
+ */
10
+ function DynamicFlowWise(props) {
11
+ var _a;
12
+ const { renderers, onAnalytics, onEvent, onLink = openLinkInNewTab } = props;
13
+ // eslint-disable-next-line react-hooks/exhaustive-deps
14
+ const mergedRenderers = useMemo(() => getMergedTestRenderers(props), [renderers]);
15
+ const createSnackBar = useSnackBarIfAvailable();
16
+ const onCopy = (copiedContent) => {
17
+ if (copiedContent) {
18
+ createSnackBar({ text: 'Copied!' });
19
+ }
20
+ else {
21
+ createSnackBar({ text: 'Not copied!' });
22
+ }
23
+ };
24
+ return (_jsx("div", { className: "df-prefer-container-queries", children: _jsx(DynamicFlowCore, Object.assign({}, props, { renderers: mergedRenderers, onEvent: filteredOnEvent(onEvent, onAnalytics), onLink: onLink, onCopy: (_a = props.onCopy) !== null && _a !== void 0 ? _a : onCopy })) }));
25
+ }
26
+ const filteredOnEvent = (onEvent, onAnalytics) => (name, properties) => {
27
+ onEvent === null || onEvent === void 0 ? void 0 : onEvent(name, properties);
28
+ if (!name.includes(ThemeRequiredEventName)) {
29
+ onAnalytics === null || onAnalytics === void 0 ? void 0 : onAnalytics(name, properties);
30
+ }
31
+ };
32
+ export default DynamicFlowWise;
@@ -0,0 +1,34 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import { useMemo } from 'react';
14
+ import { Modal } from '@transferwise/components';
15
+ import { openLinkInNewTab } from '../utils/openLinkInNewTab';
16
+ import { getMergedTestRenderers } from './getMergedTestRenderers';
17
+ import { ThemeRequiredEventName } from '@wise/dynamic-flow-renderers';
18
+ import { useDynamicFlowModal } from '../useDynamicFlowModal';
19
+ /**
20
+ * This component is only used in tests.
21
+ */
22
+ export function DynamicFlowWiseModal(props) {
23
+ const { renderers, onAnalytics, onEvent, onLink = openLinkInNewTab } = props, rest = __rest(props, ["renderers", "onAnalytics", "onEvent", "onLink"]);
24
+ // eslint-disable-next-line react-hooks/exhaustive-deps
25
+ const mergedRenderers = useMemo(() => getMergedTestRenderers(props), [renderers]);
26
+ const df = useDynamicFlowModal(Object.assign(Object.assign({}, rest), { renderers: mergedRenderers, onEvent: filteredOnEvent(onEvent, onAnalytics), onLink }));
27
+ return (_jsx(Modal, Object.assign({ className: "dynamic-flow-modal", disableDimmerClickToClose: true }, df.modal, { body: _jsx("div", { className: "dynamic-flow-modal", children: df.modal.body }) })));
28
+ }
29
+ const filteredOnEvent = (onEvent, onAnalytics) => (name, properties) => {
30
+ onEvent === null || onEvent === void 0 ? void 0 : onEvent(name, properties);
31
+ if (!name.includes(ThemeRequiredEventName)) {
32
+ onAnalytics === null || onAnalytics === void 0 ? void 0 : onAnalytics(name, properties);
33
+ }
34
+ };
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Provider as ComponentProvider, DEFAULT_LANG, DEFAULT_LOCALE, SnackbarProvider, translations as componentTranslations, getLangFromLocale, } from '@transferwise/components';
3
+ import { ThemeProvider } from '@wise/components-theming';
4
+ import translations from '../i18n';
5
+ const locale = DEFAULT_LOCALE;
6
+ const lang = getLangFromLocale(locale) || DEFAULT_LANG;
7
+ const messages = Object.assign(Object.assign({}, componentTranslations[lang]), translations[lang]);
8
+ function NeptuneProviders({ children }) {
9
+ return (_jsx(ThemeProvider, { theme: "personal", screenMode: "light", children: _jsx(SnackbarProvider, { children: _jsx(ComponentProvider, { i18n: { locale, messages }, children: children }) }) }));
10
+ }
11
+ export default NeptuneProviders;
@@ -0,0 +1,5 @@
1
+ import { vi } from 'vitest';
2
+ import { createTextInputComponent } from '../domain/components/TextInputComponent';
3
+ import { getInitialValidationAsyncState } from '../domain/features/validationAsync/getInitialValidationAsyncState';
4
+ import { getRandomId } from './getRandomId';
5
+ export const createMockTextInputComponent = (props = {}) => createTextInputComponent(Object.assign({ uid: getRandomId(), checks: [], analyticsId: 'analyticsId', autocapitalization: 'none', autoComplete: 'off', disabled: true, errors: [], id: 'id', hidden: false, required: false, validationAsyncState: getInitialValidationAsyncState(), value: '', summariser: () => ({}), performValidationAsync: undefined, schemaOnChange: undefined, onValueChange: () => { }, onPersistAsync: async () => Promise.resolve() }, props), vi.fn());
@@ -0,0 +1,45 @@
1
+ /**
2
+ * Returns a mock http client you can use in your DynamicFlow.
3
+ *
4
+ * @param handlers Map of flow URL to http clients
5
+ * @returns An http client that will handle real URLs and URLs in the handlers map
6
+ * @example getMockHttpClient({
7
+ * '/form': () => respondWith(formStep),
8
+ * '/recipient': () => respondWith(recipientStep),
9
+ * })
10
+ */
11
+ export const getMockHttpClient = (handlers) => async (input, init) => {
12
+ if (typeof input !== 'string') {
13
+ throw new Error(`Cannot handle non URL httpClient input`);
14
+ }
15
+ if (isRealUrl(input)) {
16
+ return handleRealUrl(input, init);
17
+ }
18
+ const handler = handlers[input];
19
+ if (handler) {
20
+ return handler(input, init);
21
+ }
22
+ throw new Error(`No handler for ${input}`);
23
+ };
24
+ export const respondWith = async (data, init) => new Response(data == null ? null : JSON.stringify(data), init);
25
+ export const respondWithDelay = async (data, delayMs, init) => new Promise((resolve) => {
26
+ setTimeout(() => {
27
+ resolve(new Response(JSON.stringify(data), init));
28
+ }, delayMs);
29
+ });
30
+ export const respondWithEtag = async (step) => new Response(JSON.stringify(step), { headers: { etag: eTagFromStep(step) } });
31
+ export const respondWithEmptyOk = async () => new Response(null, { status: 200 });
32
+ export const respondWithEmptyAndEtag = async (step) => new Response(null, { headers: { etag: eTagFromStep(step) }, status: 304 });
33
+ const eTagFromStep = (step) => {
34
+ const schema = JSON.stringify(step.schemas ? step.schemas[0] : {});
35
+ return `${schema.slice(0, 50)}-${schema.length}`;
36
+ };
37
+ const isRealUrl = (url) => url.startsWith('http');
38
+ const handleRealUrl = async (url, init) => fetch(url, init);
39
+ export const abortableDelay = async (delayMs, signal) => new Promise((resolve, reject) => {
40
+ const timeoutId = setTimeout(() => resolve(), delayMs);
41
+ signal === null || signal === void 0 ? void 0 : signal.addEventListener('abort', () => {
42
+ clearTimeout(timeoutId);
43
+ reject(new DOMException('AbortError', 'AbortError'));
44
+ });
45
+ });
@@ -0,0 +1,34 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import { getSubflowRenderer, getWiseRenderers, InitialLoadingStateRenderer, } from '@wise/dynamic-flow-renderers';
14
+ import DynamicFlowWise from './DynamicFlowWise';
15
+ import { DynamicFlowWiseModal } from './DynamicFlowWiseModal';
16
+ const wiseRenderers = getWiseRenderers();
17
+ export const getMergedTestRenderers = (props) => {
18
+ var _a, _b;
19
+ const { initialAction, initialStep } = props, restProps = __rest(props, ["initialAction", "initialStep"]);
20
+ const subflowFeatures = Object.assign(Object.assign({}, props.features), { nativeBack: true });
21
+ const subflowRenderer = getSubflowRenderer({
22
+ Component: (_a) => {
23
+ var { presentation, initialRequest } = _a, rest = __rest(_a, ["presentation", "initialRequest"]);
24
+ const action = {
25
+ url: initialRequest.url,
26
+ method: initialRequest.method,
27
+ data: initialRequest.body,
28
+ };
29
+ return presentation.type === 'push' ? (_jsx(DynamicFlowWise, Object.assign({}, restProps, rest, { features: subflowFeatures, initialAction: action }))) : (_jsx(DynamicFlowWiseModal, Object.assign({}, restProps, rest, { features: subflowFeatures, initialAction: action })));
30
+ },
31
+ });
32
+ const loadingStateRenderer = ((_a = props.features) === null || _a === void 0 ? void 0 : _a.initialLoader) ? [InitialLoadingStateRenderer] : [];
33
+ return [...((_b = props.renderers) !== null && _b !== void 0 ? _b : []), subflowRenderer, ...loadingStateRenderer, ...wiseRenderers];
34
+ };
@@ -0,0 +1 @@
1
+ export const getRandomId = () => Math.random().toString(36).substring(2);
@@ -0,0 +1,3 @@
1
+ export { getMockHttpClient, respondWith, respondWithDelay, respondWithEtag, respondWithEmptyOk, respondWithEmptyAndEtag, } from './fetch-utils';
2
+ export { renderWithProviders } from './rtl-utils';
3
+ export { wait } from './wait';
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { render } from '@testing-library/react';
3
+ import NeptuneProviders from './NeptuneProviders';
4
+ export const renderWithProviders = (children, options) => {
5
+ const renderedResult = render(_jsx(NeptuneProviders, { children: children }), options);
6
+ return Object.assign(Object.assign({}, renderedResult), { rerender: (ui, renderOptions) => renderWithProviders(ui, Object.assign({ container: renderedResult.container }, renderOptions)) });
7
+ };
@@ -0,0 +1,6 @@
1
+ export const createEmptyStep = () => ({
2
+ id: 'empty-step',
3
+ title: '',
4
+ layout: [],
5
+ schemas: [],
6
+ });
@@ -0,0 +1,3 @@
1
+ export const wait = async (ms) => new Promise((resolve) => {
2
+ setTimeout(resolve, ms);
3
+ });