@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,437 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { act, screen, waitFor } from '@testing-library/react';
3
- import { userEvent } from '@testing-library/user-event';
4
- import { renderWithProviders } from '../../test-utils';
5
- import { abortableDelay, getMockHttpClient } from '../../test-utils/fetch-utils';
6
- import DynamicFlowWise from '../../test-utils/DynamicFlowWise';
7
- import { vi } from 'vitest';
8
- const user = userEvent.setup({ advanceTimers: vi.advanceTimersByTime });
9
- const getSearchStep = (search = {}) => ({
10
- id: 'Features/Search',
11
- title: 'Search Layout',
12
- schemas: [],
13
- layout: [
14
- Object.assign({ type: 'search', analyticsId: 'search-layout-aid', title: 'Title', url: '/search', method: 'GET', param: 'query', emptyMessage: 'No results (sorry!)' }, search),
15
- ],
16
- });
17
- const getSearchResults = (query) => [
18
- {
19
- type: 'action',
20
- title: `Title ${query} #1`,
21
- description: `This is an action search result.`,
22
- image: {
23
- accessibilityDescription: 'image from URL',
24
- url: 'https://example.com/image.png',
25
- },
26
- value: {
27
- id: 'search-result-action-id-01',
28
- url: `/next-step`,
29
- method: 'GET',
30
- },
31
- },
32
- {
33
- type: 'search',
34
- title: `Title ${query} #2`,
35
- description: `This is a search search result.`,
36
- image: {
37
- accessibilityDescription: 'image from URI',
38
- uri: 'https://example.com/image.png',
39
- },
40
- value: {
41
- url: `/new-search`,
42
- method: 'GET',
43
- param: 'new-query',
44
- query: 'new query with special characters (!@£$%^&*)',
45
- },
46
- },
47
- ];
48
- const getLegacySearchResponse = (query) => new Response(JSON.stringify({ results: getSearchResults(query) }));
49
- const getResultsResponse = (query) => new Response(JSON.stringify({ type: 'results', results: getSearchResults(query) }));
50
- const getLayoutResponse = (query) => new Response(JSON.stringify({
51
- type: 'layout',
52
- content: [
53
- {
54
- type: 'markdown',
55
- content: `You've searched for ${query}, but we didn't find anything, so here is an empty state`,
56
- },
57
- ],
58
- }));
59
- describe('DynamicFlow / Search Layout Component', () => {
60
- const onCompletion = vi.fn();
61
- const onError = vi.fn();
62
- const httpClient = vi.fn();
63
- beforeEach(() => {
64
- vi.clearAllMocks();
65
- });
66
- describe('user interface', () => {
67
- it('renders a search input with the title as a label', () => {
68
- const title = 'Search for something';
69
- const searchStep = getSearchStep({ title });
70
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: httpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
71
- expect(screen.getByLabelText(title)).toBeInTheDocument();
72
- });
73
- it('renders the initialState when it is a layout type', () => {
74
- const title = 'Search for something';
75
- const initialState = {
76
- type: 'layout',
77
- content: [
78
- {
79
- type: 'markdown',
80
- content: 'This is the initial state',
81
- },
82
- ],
83
- };
84
- const searchStep = getSearchStep({ title, initialState });
85
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: httpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
86
- expect(screen.getByText('This is the initial state')).toBeInTheDocument();
87
- });
88
- it('renders the initialState when it is a results type', () => {
89
- const title = 'Search for something';
90
- const initialState = {
91
- type: 'results',
92
- results: getSearchResults('initial query'),
93
- };
94
- const searchStep = getSearchStep({ title, initialState });
95
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: httpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
96
- expect(screen.getByText('Title initial query #1')).toBeInTheDocument();
97
- });
98
- });
99
- // TODO we haven't added search events yet
100
- describe('when user focuses the text field', () => {
101
- it('calls onEvent with the correct analytics event', async () => {
102
- const title = 'Search for something';
103
- const searchStep = getSearchStep({ title });
104
- const onEvent = vi.fn();
105
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: httpClient, initialStep: searchStep, onEvent: onEvent, onCompletion: onCompletion, onError: onError }));
106
- const input = screen.getByLabelText(title);
107
- // await user.click(input); // the revamp version trigger on the first character, not on focus
108
- await user.type(input, 'abcd');
109
- await waitFor(() => expect(onEvent).toHaveBeenCalledWith('Dynamic Flow - Search Started', expect.objectContaining({
110
- flowId: 'the-flow-id',
111
- stepId: 'Features/Search',
112
- stepCount: 0,
113
- layoutId: 'search-layout-aid',
114
- })));
115
- });
116
- });
117
- describe('when user types into text field', () => {
118
- it('makes a GET request to the search endpoint', async () => {
119
- const title = 'Search for something';
120
- const query = 'test';
121
- const mockHttpClient = vi.fn(async () => Promise.resolve(new Response(null, { status: 404 })));
122
- const searchStep = getSearchStep({ title, url: '/search', method: 'GET' });
123
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
124
- const input = screen.getByLabelText(title);
125
- await user.type(input, query);
126
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
127
- expect(mockHttpClient).toHaveBeenCalledTimes(1);
128
- expect(mockHttpClient).toHaveBeenCalledWith(`/search?query=${query}`, expect.anything());
129
- });
130
- it('makes a GET request to the search endpoint, with the correct query parameters', async () => {
131
- const title = 'Search for something';
132
- const query = 'test';
133
- const mockHttpClient = vi.fn(async () => Promise.resolve(new Response(null, { status: 404 })));
134
- const searchStep = getSearchStep({ title, url: '/search?extra=stuff', method: 'GET' });
135
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
136
- const input = screen.getByLabelText(title);
137
- await user.type(input, query);
138
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
139
- expect(mockHttpClient).toHaveBeenCalledTimes(1);
140
- expect(mockHttpClient).toHaveBeenCalledWith(`/search?extra=stuff&query=${query}`, expect.anything());
141
- });
142
- it('makes a POST request to the search endpoint', async () => {
143
- const mockHttpClient = vi.fn(async () => Promise.resolve(new Response(null, { status: 404 })));
144
- const title = 'Search for something';
145
- const method = 'POST';
146
- const query = 'test';
147
- const searchStep = getSearchStep({ title, method });
148
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
149
- const input = screen.getByLabelText(title);
150
- await user.type(input, query);
151
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
152
- expect(mockHttpClient).toHaveBeenCalledTimes(1);
153
- expect(mockHttpClient).toHaveBeenCalledWith('/search', expect.objectContaining({
154
- method: 'POST',
155
- body: JSON.stringify({ query }),
156
- }));
157
- });
158
- describe('when the legacy results type is provided', () => {
159
- it('renders the search results', async () => {
160
- const mockHttpClient = vi.fn(async () => Promise.resolve(getLegacySearchResponse('abcd')));
161
- const title = 'Search for something';
162
- const searchStep = getSearchStep({ title });
163
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
164
- const input = screen.getByLabelText(title);
165
- await user.type(input, 'abcd');
166
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
167
- expect(screen.getByText('Title abcd #1')).toBeInTheDocument();
168
- expect(screen.getByText('Title abcd #2')).toBeInTheDocument();
169
- });
170
- });
171
- describe('when the modern results type is provided', () => {
172
- it('renders the search results', async () => {
173
- const mockHttpClient = vi.fn(async () => Promise.resolve(getResultsResponse('abcd')));
174
- const title = 'Search for something';
175
- const searchStep = getSearchStep({ title });
176
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
177
- const input = screen.getByLabelText(title);
178
- await user.type(input, 'abcd');
179
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
180
- expect(screen.getByText('Title abcd #1')).toBeInTheDocument();
181
- expect(screen.getByText('Title abcd #2')).toBeInTheDocument();
182
- });
183
- });
184
- describe('when the layout response type is provided', () => {
185
- it('renders the search results', async () => {
186
- const mockHttpClient = vi.fn(async () => Promise.resolve(getLayoutResponse('abcd')));
187
- const title = 'Search for something';
188
- const searchStep = getSearchStep({ title });
189
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
190
- const input = screen.getByLabelText(title);
191
- await user.type(input, 'abcd');
192
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
193
- expect(screen.getByText("You've searched for abcd, but we didn't find anything, so here is an empty state")).toBeInTheDocument();
194
- });
195
- });
196
- it('renders the images for each result', async () => {
197
- const mockHttpClient = vi.fn(async () => Promise.resolve(getLegacySearchResponse('abcd')));
198
- const title = 'Search for something';
199
- const searchStep = getSearchStep({ title });
200
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
201
- const input = screen.getByLabelText(title);
202
- await user.type(input, 'abcd');
203
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
204
- expect(screen.getByAltText('image from URL')).toHaveAttribute('src', 'https://example.com/image.png');
205
- expect(screen.getByAltText('image from URI')).toHaveAttribute('src', 'https://example.com/image.png');
206
- });
207
- describe('debouncing', () => {
208
- describe('when the user resumes typing before the first request is made', () => {
209
- it('only makes 1 request with the last query string, rather than every time the search query changes', async () => {
210
- const mockHttpClient = vi.fn(async () => Promise.resolve(new Response(null, { status: 404 })));
211
- const title = 'Search for something';
212
- const searchStep = getSearchStep({ title });
213
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
214
- const input = screen.getByLabelText(title);
215
- await user.type(input, 'abcd');
216
- act(() => {
217
- vi.advanceTimersByTime(200); // half the debounce time
218
- });
219
- expect(mockHttpClient).toHaveBeenCalledTimes(0); // no request yet
220
- await user.type(input, 'efgh'); // continue typing on the text field
221
- act(() => {
222
- vi.advanceTimersByTime(200); // half the debounce time
223
- });
224
- await waitFor(() => expect(mockHttpClient).toHaveBeenCalledTimes(1));
225
- expect(mockHttpClient).toHaveBeenCalledWith(`/search?query=abcdefgh`, expect.anything());
226
- });
227
- });
228
- });
229
- describe('de-duplication', () => {
230
- describe('when the user adds a trailing space to a successful query', () => {
231
- it('only makes 1 request with the original query string, rather than a second one', async () => {
232
- const mockHttpClient = vi.fn(async () => Promise.resolve(getLegacySearchResponse('abcd')));
233
- const title = 'Search for something';
234
- const searchStep = getSearchStep({ title });
235
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
236
- const input = screen.getByLabelText(title);
237
- await user.type(input, 'abcd');
238
- await act(async () => vi.advanceTimersByTime(500)); // debounce delay
239
- expect(mockHttpClient).toHaveBeenCalledTimes(1);
240
- await user.type(input, ' ');
241
- await act(async () => vi.advanceTimersByTime(500)); // debounce delay
242
- expect(mockHttpClient).toHaveBeenCalledTimes(1); // no new requests
243
- });
244
- });
245
- describe('when the user adds a trailing space to a failed query', () => {
246
- it('makes a second request', async () => {
247
- const mockHttpClient = vi.fn(async () => Promise.resolve(new Response(null, { status: 404 })));
248
- const title = 'Search for something';
249
- const searchStep = getSearchStep({ title });
250
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
251
- const input = screen.getByLabelText(title);
252
- await user.type(input, 'abcd');
253
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
254
- expect(mockHttpClient).toHaveBeenCalledTimes(1);
255
- await user.type(input, ' '); // add a space to the text input field
256
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
257
- expect(mockHttpClient).toHaveBeenCalledTimes(2); // it tries again
258
- });
259
- });
260
- });
261
- describe('aborting requests', () => {
262
- describe('when the user types into the text field, then clears it before the request is made', () => {
263
- it('aborts the request', async () => {
264
- const mockHttpClient = vi.fn(async () => Promise.resolve(new Response(null, { status: 404 })));
265
- const title = 'Search for something';
266
- const searchStep = getSearchStep({ title });
267
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
268
- const input = screen.getByLabelText(title);
269
- await user.type(input, 'abcd');
270
- await user.clear(input);
271
- act(() => {
272
- vi.advanceTimersByTime(500); // more than the debounce time
273
- });
274
- await waitFor(() => expect(mockHttpClient).toHaveBeenCalledTimes(0));
275
- });
276
- });
277
- describe('when the user types into the text field, and a first request is made, then they type again before the request resolves', () => {
278
- it('aborts the first request and makes a new one, only displaying the results for the second request', async () => {
279
- const mockHttpClient = vi.fn(async (url, init) => {
280
- const query = String(url).split('=')[1];
281
- await abortableDelay(query === 'abcd' ? 2000 : 500, init === null || init === void 0 ? void 0 : init.signal);
282
- return getLegacySearchResponse(query);
283
- });
284
- const title = 'Search for something';
285
- const searchStep = getSearchStep({ title });
286
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
287
- const input = screen.getByLabelText(title);
288
- await user.type(input, 'abcd');
289
- act(() => {
290
- vi.advanceTimersByTime(1000);
291
- });
292
- await user.type(input, 'efgh');
293
- act(() => {
294
- vi.advanceTimersByTime(1000);
295
- });
296
- await waitFor(() => {
297
- expect(screen.getByText('Title abcdefgh #1')).toBeInTheDocument();
298
- });
299
- await waitFor(() => expect(mockHttpClient).toHaveBeenCalledTimes(2));
300
- await act(async () => {
301
- vi.advanceTimersByTime(1500);
302
- return Promise.resolve();
303
- });
304
- expect(screen.queryByText('Title abcd #1')).not.toBeInTheDocument();
305
- });
306
- });
307
- });
308
- describe('when the user clears the search input after some results were displayed', () => {
309
- it('clears the results and displays the initial state', async () => {
310
- const title = 'Search for something';
311
- const initialState = {
312
- type: 'layout',
313
- content: [
314
- {
315
- type: 'markdown',
316
- content: 'This is the initial state',
317
- },
318
- ],
319
- };
320
- const mockHttpClient = vi.fn(async () => Promise.resolve(getResultsResponse('abcd')));
321
- const searchStep = getSearchStep({ title, initialState });
322
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
323
- expect(screen.getByText('This is the initial state')).toBeInTheDocument();
324
- await user.type(screen.getByLabelText(title), 'abcd');
325
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
326
- expect(screen.getByText('Title abcd #1')).toBeInTheDocument();
327
- await user.clear(screen.getByLabelText(title));
328
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
329
- expect(screen.getByText('This is the initial state')).toBeInTheDocument();
330
- });
331
- });
332
- });
333
- describe('when the user clicks on an action search result', () => {
334
- it('loads a new step and triggers analytics event', async () => {
335
- const mockHttpClient = vi.fn(getMockHttpClient({
336
- '/search?query=abcd': async () => Promise.resolve(getLegacySearchResponse('abcd')),
337
- '/next-step': async () => Promise.resolve(new Response(JSON.stringify(nextStep))),
338
- }));
339
- const onEvent = vi.fn();
340
- const title = 'Search for something';
341
- const searchStep = getSearchStep({ title, url: '/search' });
342
- const nextStep = {
343
- id: 'next-step',
344
- title: 'Next Step',
345
- schemas: [],
346
- layout: [
347
- {
348
- type: 'paragraph',
349
- text: 'This is the next step.',
350
- },
351
- ],
352
- };
353
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError, onEvent: onEvent }));
354
- const input = screen.getByLabelText(title);
355
- await user.type(input, 'abcd');
356
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
357
- expect(screen.getByText('Title abcd #1')).toBeInTheDocument();
358
- await user.click(screen.getByText('Title abcd #1'));
359
- await expect(screen.findByText('Next Step')).resolves.toBeInTheDocument();
360
- expect(screen.queryByText('Title abcd #1')).not.toBeInTheDocument();
361
- expect(onEvent).toHaveBeenCalledWith('Dynamic Flow - Search Result Selected', expect.objectContaining({
362
- flowId: 'the-flow-id',
363
- stepId: 'Features/Search',
364
- stepCount: 0,
365
- layoutId: 'search-layout-aid',
366
- type: 'action',
367
- actionId: 'search-result-action-id-01',
368
- }));
369
- });
370
- });
371
- describe('when the user clicks on a search search result', () => {
372
- it('makes a new search request, displays the results, and updates the search input, and triggers analytics event', async () => {
373
- const mockHttpClient = vi.fn(getMockHttpClient({
374
- '/search?query=abcd': async () => Promise.resolve(getLegacySearchResponse('abcd')),
375
- '/new-search?new-query=new+query+with+special+characters+%28%21%40%C2%A3%24%25%5E%26*%29': async () => Promise.resolve(getLegacySearchResponse('new query results')),
376
- }));
377
- const onEvent = vi.fn();
378
- const title = 'Search for something';
379
- const searchStep = getSearchStep({ title, url: '/search' });
380
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError, onEvent: onEvent }));
381
- const input = screen.getByLabelText(title);
382
- await user.type(input, 'abcd');
383
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
384
- expect(screen.getByText('Title abcd #1')).toBeInTheDocument();
385
- await user.click(screen.getByText('Title abcd #2'));
386
- expect(mockHttpClient).toHaveBeenCalledWith(`/new-search?new-query=new+query+with+special+characters+%28%21%40%C2%A3%24%25%5E%26*%29`, expect.anything());
387
- expect(screen.getByText('Title new query results #1')).toBeInTheDocument();
388
- expect(screen.getByLabelText(title)).toHaveValue('new query with special characters (!@£$%^&*)');
389
- expect(onEvent).toHaveBeenCalledWith('Dynamic Flow - Search Result Selected', expect.objectContaining({
390
- flowId: 'the-flow-id',
391
- stepId: 'Features/Search',
392
- stepCount: 0,
393
- layoutId: 'search-layout-aid',
394
- type: 'search',
395
- }));
396
- });
397
- });
398
- describe('when the search request fails', () => {
399
- it('displays an error message and allows to retry', async () => {
400
- const responses = [
401
- Promise.resolve(new Response(null, { status: 404 })),
402
- Promise.resolve(getLegacySearchResponse('abcd')),
403
- ];
404
- let callCount = 0;
405
- const mockHttpClient = vi.fn(async () => {
406
- const response = responses[Math.min(callCount, responses.length - 1)];
407
- callCount += 1;
408
- return response;
409
- });
410
- const title = 'Search for something';
411
- const searchStep = getSearchStep({ title, url: '/search' });
412
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
413
- const input = screen.getByLabelText(title);
414
- await user.type(input, 'abcd');
415
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
416
- expect(screen.getByText('Something went wrong.')).toBeInTheDocument();
417
- expect(mockHttpClient).toHaveBeenCalledTimes(1);
418
- const link = screen.getByText('Retry');
419
- await user.click(link);
420
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
421
- expect(mockHttpClient).toHaveBeenCalledTimes(2);
422
- expect(screen.getByText('Title abcd #1')).toBeInTheDocument();
423
- });
424
- });
425
- describe('when a search returns no results', () => {
426
- it('displays the empty message from the search configuration', async () => {
427
- const mockHttpClient = vi.fn(async () => Promise.resolve(new Response(JSON.stringify({ type: 'results', results: [] }))));
428
- const title = 'Search for something';
429
- const searchStep = getSearchStep({ title });
430
- renderWithProviders(_jsx(DynamicFlowWise, { flowId: "the-flow-id", httpClient: mockHttpClient, initialStep: searchStep, onCompletion: onCompletion, onError: onError }));
431
- const input = screen.getByLabelText(title);
432
- await user.type(input, 'abcd');
433
- await act(async () => vi.advanceTimersByTimeAsync(500)); // debounce delay
434
- expect(screen.getByText('No results (sorry!)')).toBeInTheDocument();
435
- });
436
- });
437
- });
@@ -1,58 +0,0 @@
1
- import { mapSchemaToComponent } from '../../domain/mappers/mapSchemaToComponent';
2
- import { getMockMapperProps, getMockRendererMapperProps, getMockSchemaMapperProps, } from '../../domain/mappers/schema/tests/test-utils';
3
- import { multiSelectInputComponentToProps } from '../../renderers/mappers/multiSelectComponentToProps';
4
- describe('MultiSelectInputRendererProps mapper', () => {
5
- describe('given a MultiSelectInputComponent in which each option has a layout', () => {
6
- it('should map options including their children and childrenProps', () => {
7
- var _a, _b, _c, _d, _e, _f, _g, _h, _j;
8
- const schema = {
9
- type: 'array',
10
- addItemTitle: '',
11
- editItemTitle: '',
12
- items: {
13
- oneOf: [
14
- {
15
- const: 'option-1',
16
- title: 'Option 1',
17
- layout: [{ type: 'paragraph', text: 'This is option 1' }],
18
- },
19
- {
20
- const: 'option-2',
21
- title: 'Option 2',
22
- layout: [{ type: 'paragraph', text: 'This is option 2' }],
23
- },
24
- {
25
- const: 'option-3',
26
- title: 'Option 3',
27
- layout: [{ type: 'paragraph', text: 'This is option 3' }],
28
- },
29
- ],
30
- },
31
- };
32
- const schemaMapperProps = getMockSchemaMapperProps({ schema });
33
- const mapperProps = getMockMapperProps();
34
- const component = mapSchemaToComponent(schemaMapperProps, mapperProps);
35
- const rendererMapperProps = Object.assign(Object.assign({}, getMockRendererMapperProps()), { render: () => null });
36
- const props = multiSelectInputComponentToProps(component, rendererMapperProps);
37
- expect(props.options).toHaveLength(3);
38
- expect(props.options[0].children).toBeDefined();
39
- expect(props.options[1].children).toBeDefined();
40
- expect(props.options[2].children).toBeDefined();
41
- expect(props.options[0].childrenProps).toBeDefined();
42
- expect((_a = props.options[0].childrenProps) === null || _a === void 0 ? void 0 : _a.type).toBe('container');
43
- expect((_b = props.options[0].childrenProps.childrenProps) === null || _b === void 0 ? void 0 : _b[0].type).toBe('paragraph');
44
- expect(((_c = props.options[0].childrenProps
45
- .childrenProps) === null || _c === void 0 ? void 0 : _c[0]).text).toBe('This is option 1');
46
- expect(props.options[1].childrenProps).toBeDefined();
47
- expect((_d = props.options[1].childrenProps) === null || _d === void 0 ? void 0 : _d.type).toBe('container');
48
- expect((_e = props.options[1].childrenProps.childrenProps) === null || _e === void 0 ? void 0 : _e[0].type).toBe('paragraph');
49
- expect(((_f = props.options[1].childrenProps
50
- .childrenProps) === null || _f === void 0 ? void 0 : _f[0]).text).toBe('This is option 2');
51
- expect(props.options[2].childrenProps).toBeDefined();
52
- expect((_g = props.options[2].childrenProps) === null || _g === void 0 ? void 0 : _g.type).toBe('container');
53
- expect((_h = props.options[2].childrenProps.childrenProps) === null || _h === void 0 ? void 0 : _h[0].type).toBe('paragraph');
54
- expect(((_j = props.options[2].childrenProps
55
- .childrenProps) === null || _j === void 0 ? void 0 : _j[0]).text).toBe('This is option 3');
56
- });
57
- });
58
- });
@@ -1,42 +0,0 @@
1
- import { mapSchemaToComponent } from '../../domain/mappers/mapSchemaToComponent';
2
- import { getMockMapperProps, getMockRendererMapperProps, getMockSchemaMapperProps, } from '../../domain/mappers/schema/tests/test-utils';
3
- import { selectInputComponentToProps } from '../../renderers/mappers/selectInputComponentToProps';
4
- describe('SelectInputRendererProps mapper', () => {
5
- describe('given a SelectInputComponent in which each option has a layout', () => {
6
- it('should map options including their children and childrenProps', () => {
7
- var _a, _b, _c, _d, _e, _f;
8
- const schema = {
9
- oneOf: [
10
- {
11
- title: 'Option 1',
12
- const: 'option-1',
13
- layout: [{ type: 'paragraph', text: 'This is option 1' }],
14
- },
15
- {
16
- title: 'Option 2',
17
- const: 'option-2',
18
- layout: [{ type: 'paragraph', text: 'This is option 2' }],
19
- },
20
- ],
21
- };
22
- const schemaMapperProps = getMockSchemaMapperProps({ schema });
23
- const mapperProps = getMockMapperProps();
24
- const component = mapSchemaToComponent(schemaMapperProps, mapperProps);
25
- const rendererMapperProps = Object.assign(Object.assign({}, getMockRendererMapperProps()), { render: () => null });
26
- const props = selectInputComponentToProps(component, rendererMapperProps);
27
- expect(props.options).toHaveLength(2);
28
- expect(props.options[0].children).toBeDefined();
29
- expect(props.options[1].children).toBeDefined();
30
- expect(props.options[0].childrenProps).toBeDefined();
31
- expect((_a = props.options[0].childrenProps) === null || _a === void 0 ? void 0 : _a.type).toBe('container');
32
- expect((_b = props.options[0].childrenProps.childrenProps) === null || _b === void 0 ? void 0 : _b[0].type).toBe('paragraph');
33
- expect(((_c = props.options[0].childrenProps
34
- .childrenProps) === null || _c === void 0 ? void 0 : _c[0]).text).toBe('This is option 1');
35
- expect(props.options[1].childrenProps).toBeDefined();
36
- expect((_d = props.options[1].childrenProps) === null || _d === void 0 ? void 0 : _d.type).toBe('container');
37
- expect((_e = props.options[1].childrenProps.childrenProps) === null || _e === void 0 ? void 0 : _e[0].type).toBe('paragraph');
38
- expect(((_f = props.options[1].childrenProps
39
- .childrenProps) === null || _f === void 0 ? void 0 : _f[0]).text).toBe('This is option 2');
40
- });
41
- });
42
- });
@@ -1,51 +0,0 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
2
- import { screen, waitFor } from '@testing-library/react';
3
- import { userEvent } from '@testing-library/user-event';
4
- import { vi } from 'vitest';
5
- import { renderWithProviders } from '../../test-utils';
6
- import DynamicFlowWise from '../../test-utils/DynamicFlowWise';
7
- const user = userEvent.setup({ advanceTimers: vi.advanceTimersByTime });
8
- const getDefaultProps = () => ({
9
- flowId: 'flow-id',
10
- onCompletion: vi.fn(),
11
- onError: vi.fn(),
12
- onEvent: vi.fn(),
13
- onLog: vi.fn(),
14
- });
15
- const getStep = (model, schema) => {
16
- var _a;
17
- return ({
18
- id: 'step-id',
19
- title: 'Submission test',
20
- layout: [
21
- { type: 'form', schemaId: (_a = schema.$id) !== null && _a !== void 0 ? _a : '' },
22
- {
23
- type: 'button',
24
- title: 'Submit',
25
- action: { id: 'action-id', url: '/submit', method: 'POST' },
26
- },
27
- ],
28
- schemas: [schema],
29
- model,
30
- });
31
- };
32
- describe('TextInputRenderer', () => {
33
- const variants = [
34
- ['without control nor format', { $id: '#schema', type: 'string', title: 'Name' }],
35
- ['with numeric format', { $id: '#schema', type: 'string', title: 'Name', format: 'numeric' }],
36
- ['with numeric control', { $id: '#schema', type: 'string', title: 'Name', control: 'numeric' }],
37
- ];
38
- describe.each(variants)('%s', (_, schema) => {
39
- it('should submit the user-entered data to the server', async () => {
40
- const step = getStep(null, schema);
41
- const httpClient = vi.fn();
42
- const props = getDefaultProps();
43
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({ httpClient: httpClient, initialStep: step }, props)));
44
- await user.type(screen.getByLabelText('Name'), '12345.6789');
45
- await user.click(screen.getByText('Submit'));
46
- await waitFor(() => {
47
- expect(httpClient).toHaveBeenCalledWith('/submit', expect.objectContaining({ body: JSON.stringify('12345.6789') }));
48
- });
49
- });
50
- });
51
- });
package/build/types.js DELETED
@@ -1 +0,0 @@
1
- export {};