@wise/dynamic-flow-client 5.9.1 → 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 (402) hide show
  1. package/build/main.js +7 -1
  2. package/build/main.mjs +7 -1
  3. package/package.json +9 -8
  4. package/build/DynamicFlowCore.js +0 -5
  5. package/build/common/errorBoundary/ErrorBoundary.js +0 -26
  6. package/build/common/errorBoundary/ErrorBoundary.test.js +0 -29
  7. package/build/common/errorBoundary/ErrorBoundaryAlert.js +0 -11
  8. package/build/common/makeHttpClient/api-utils.js +0 -3
  9. package/build/common/makeHttpClient/index.js +0 -1
  10. package/build/common/makeHttpClient/makeHttpClient.js +0 -10
  11. package/build/common/makeHttpClient/makeHttpClient.test.js +0 -186
  12. package/build/common/messages/external-confirmation.messages.js +0 -23
  13. package/build/common/messages/file-upload.messages.js +0 -13
  14. package/build/common/messages/generic-error.messages.js +0 -18
  15. package/build/common/messages/help.messages.js +0 -8
  16. package/build/common/messages/multi-file-upload.messages.js +0 -18
  17. package/build/common/messages/multi-select.messages.js +0 -8
  18. package/build/common/messages/paragraph.messages.js +0 -13
  19. package/build/common/messages/repeatable.messages.js +0 -23
  20. package/build/common/messages/search.messages.js +0 -8
  21. package/build/common/messages/validation.array.messages.js +0 -13
  22. package/build/common/messages/validation.messages.js +0 -53
  23. package/build/controller/FlowController.js +0 -368
  24. package/build/controller/executePoll.js +0 -49
  25. package/build/controller/executeRefresh.js +0 -39
  26. package/build/controller/executeRequest.js +0 -77
  27. package/build/controller/executeSubmission.js +0 -69
  28. package/build/controller/getErrorMessage.js +0 -7
  29. package/build/controller/getRequestAbortController.js +0 -13
  30. package/build/controller/getResponseType.js +0 -35
  31. package/build/controller/getSafeHttpClient.js +0 -8
  32. package/build/controller/getStepCounter.js +0 -16
  33. package/build/controller/handleErrorResponse.js +0 -26
  34. package/build/controller/makeSafeHttpClient.js +0 -8
  35. package/build/controller/response-utils.js +0 -72
  36. package/build/domain/components/AlertComponent.js +0 -1
  37. package/build/domain/components/AllOfComponent.js +0 -40
  38. package/build/domain/components/BooleanInputComponent.js +0 -50
  39. package/build/domain/components/BoxComponent.js +0 -3
  40. package/build/domain/components/ButtonComponent.js +0 -1
  41. package/build/domain/components/ColumnsComponent.js +0 -3
  42. package/build/domain/components/ConstComponent.js +0 -18
  43. package/build/domain/components/ContainerComponent.js +0 -3
  44. package/build/domain/components/DateInputComponent.js +0 -75
  45. package/build/domain/components/DecisionComponent.js +0 -1
  46. package/build/domain/components/DividerComponent.js +0 -1
  47. package/build/domain/components/FormComponent.js +0 -3
  48. package/build/domain/components/FormattedValueComponent.js +0 -44
  49. package/build/domain/components/HeadingComponent.js +0 -1
  50. package/build/domain/components/ImageComponent.js +0 -1
  51. package/build/domain/components/InstructionsComponent.js +0 -1
  52. package/build/domain/components/IntegerInputComponent.js +0 -74
  53. package/build/domain/components/ListComponent.js +0 -1
  54. package/build/domain/components/LoadingIndicatorComponent.js +0 -1
  55. package/build/domain/components/MarkdownComponent.js +0 -1
  56. package/build/domain/components/MediaComponent.js +0 -1
  57. package/build/domain/components/ModalComponent.js +0 -16
  58. package/build/domain/components/ModalLayoutComponent.js +0 -3
  59. package/build/domain/components/MoneyInputComponent.js +0 -57
  60. package/build/domain/components/MultiSelectInputComponent.js +0 -81
  61. package/build/domain/components/MultiUploadInputComponent.js +0 -88
  62. package/build/domain/components/NumberInputComponent.js +0 -73
  63. package/build/domain/components/ObjectComponent.js +0 -45
  64. package/build/domain/components/ParagraphComponent.js +0 -1
  65. package/build/domain/components/PersistAsyncComponent.js +0 -92
  66. package/build/domain/components/ProgressComponent.js +0 -1
  67. package/build/domain/components/RepeatableComponent.js +0 -103
  68. package/build/domain/components/ReviewComponent.js +0 -1
  69. package/build/domain/components/RootDomainComponent.js +0 -173
  70. package/build/domain/components/SectionComponent.js +0 -5
  71. package/build/domain/components/SelectInputComponent.js +0 -88
  72. package/build/domain/components/StatusListComponent.js +0 -1
  73. package/build/domain/components/SubflowDomainComponent.js +0 -9
  74. package/build/domain/components/TabsComponent.js +0 -1
  75. package/build/domain/components/TextInputComponent.js +0 -76
  76. package/build/domain/components/TupleComponent.js +0 -41
  77. package/build/domain/components/UploadInputComponent.js +0 -83
  78. package/build/domain/components/UpsellComponent.js +0 -25
  79. package/build/domain/components/searchComponent/SearchComponent.js +0 -92
  80. package/build/domain/components/searchComponent/SearchComponent.test.js +0 -190
  81. package/build/domain/components/step/ExternalConfirmationComponent.js +0 -28
  82. package/build/domain/components/step/StepDomainComponent.js +0 -78
  83. package/build/domain/components/step/ToolbarComponent.js +0 -1
  84. package/build/domain/components/utils/WithUpdate.js +0 -1
  85. package/build/domain/components/utils/component-utils.js +0 -12
  86. package/build/domain/components/utils/debounce.js +0 -34
  87. package/build/domain/components/utils/debounce.test.js +0 -67
  88. package/build/domain/components/utils/file-utils.js +0 -21
  89. package/build/domain/components/utils/file-utils.test.js +0 -27
  90. package/build/domain/components/utils/getRandomId.js +0 -1
  91. package/build/domain/components/utils/isExactLocalValueMatch.js +0 -14
  92. package/build/domain/components/utils/isOrWasValid.js +0 -5
  93. package/build/domain/components/utils/isPartialModelMatch.js +0 -18
  94. package/build/domain/components/utils/isPartialModelMatch.test.js +0 -74
  95. package/build/domain/features/eventNames.js +0 -24
  96. package/build/domain/features/events.js +0 -1
  97. package/build/domain/features/persistAsync/getComponentMultiPersistAsync.js +0 -50
  98. package/build/domain/features/persistAsync/getInitialPersistedState.js +0 -7
  99. package/build/domain/features/persistAsync/getPerformPersistAsync.js +0 -43
  100. package/build/domain/features/persistAsync/getPerformPersistAsync.test.js +0 -139
  101. package/build/domain/features/polling/getStepPolling.js +0 -43
  102. package/build/domain/features/polling/getStepPolling.test.js +0 -90
  103. package/build/domain/features/prefetch/getStepPrefetch.js +0 -43
  104. package/build/domain/features/prefetch/request-cache.js +0 -49
  105. package/build/domain/features/prefetch/request-cache.test.js +0 -70
  106. package/build/domain/features/refreshAfter/getStepRefreshAfter.js +0 -24
  107. package/build/domain/features/refreshAfter/getStepRefreshAfter.test.js +0 -40
  108. package/build/domain/features/schema-on-change/getDebouncedSchemaOnChange.js +0 -50
  109. package/build/domain/features/schema-on-change/getSchemaOnChange.js +0 -34
  110. package/build/domain/features/search/getPerformSearchFunction.js +0 -75
  111. package/build/domain/features/search/getPerformSearchFunction.test.js +0 -301
  112. package/build/domain/features/summary/summary-utils.js +0 -40
  113. package/build/domain/features/summary/summary-utils.test.js +0 -125
  114. package/build/domain/features/utils/http-utils.js +0 -21
  115. package/build/domain/features/utils/response-utils.js +0 -9
  116. package/build/domain/features/validation/spec-utils.js +0 -19
  117. package/build/domain/features/validation/validateStringPattern.js +0 -24
  118. package/build/domain/features/validation/validation-functions.js +0 -6
  119. package/build/domain/features/validation/validation-functions.test.js +0 -108
  120. package/build/domain/features/validation/value-checks.js +0 -125
  121. package/build/domain/features/validation/value-checks.test.js +0 -262
  122. package/build/domain/features/validationAsync/getComponentValidationAsync.js +0 -53
  123. package/build/domain/features/validationAsync/getComponentValidationAsync.test.js +0 -67
  124. package/build/domain/features/validationAsync/getInitialValidationAsyncState.js +0 -5
  125. package/build/domain/features/validationAsync/getPerformValidationAsync.js +0 -45
  126. package/build/domain/features/validationAsync/getPerformValidationAsync.test.js +0 -143
  127. package/build/domain/mappers/layout/alertLayoutToComponent.js +0 -16
  128. package/build/domain/mappers/layout/boxLayoutToComponent.js +0 -13
  129. package/build/domain/mappers/layout/buttonLayoutToComponent.js +0 -77
  130. package/build/domain/mappers/layout/columnsLayoutToComponent.js +0 -13
  131. package/build/domain/mappers/layout/decisionLayoutToComponent.js +0 -22
  132. package/build/domain/mappers/layout/deprecatedListLayoutToComponent.js +0 -30
  133. package/build/domain/mappers/layout/dividerLayoutToComponent.js +0 -2
  134. package/build/domain/mappers/layout/formLayoutToComponent.js +0 -19
  135. package/build/domain/mappers/layout/headingLayoutToComponent.js +0 -12
  136. package/build/domain/mappers/layout/imageLayoutToComponent.js +0 -20
  137. package/build/domain/mappers/layout/infoLayoutToComponent.js +0 -12
  138. package/build/domain/mappers/layout/instructionsLayoutToComponent.js +0 -12
  139. package/build/domain/mappers/layout/listLayoutToComponent.js +0 -39
  140. package/build/domain/mappers/layout/loadingIndicatorLayoutToComponent.js +0 -9
  141. package/build/domain/mappers/layout/markdownLayoutToComponent.js +0 -12
  142. package/build/domain/mappers/layout/mediaLayoutToComponent.js +0 -12
  143. package/build/domain/mappers/layout/modalLayoutToComponent.js +0 -17
  144. package/build/domain/mappers/layout/modalToComponent.js +0 -8
  145. package/build/domain/mappers/layout/paragraphLayoutToComponent.js +0 -12
  146. package/build/domain/mappers/layout/progressLayoutToComponent.js +0 -15
  147. package/build/domain/mappers/layout/reviewLayoutToComponent.js +0 -48
  148. package/build/domain/mappers/layout/searchLayoutToComponent.js +0 -44
  149. package/build/domain/mappers/layout/sectionLayoutToComponent.js +0 -15
  150. package/build/domain/mappers/layout/statusListLayoutToComponent.js +0 -15
  151. package/build/domain/mappers/layout/tabsLayoutToComponent.js +0 -16
  152. package/build/domain/mappers/layout/upsellLayoutToComponent.js +0 -25
  153. package/build/domain/mappers/mapLayoutToComponent.js +0 -81
  154. package/build/domain/mappers/mapSchemaToComponent.js +0 -61
  155. package/build/domain/mappers/mapSchemaToComponent.test.js +0 -112
  156. package/build/domain/mappers/mapStepSchemas.js +0 -15
  157. package/build/domain/mappers/mapStepToComponent.js +0 -133
  158. package/build/domain/mappers/mapStepToComponent.test.js +0 -221
  159. package/build/domain/mappers/mapToolbarToComponent.js +0 -15
  160. package/build/domain/mappers/schema/allOfSchemaToComponent.js +0 -16
  161. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToComponent.js +0 -26
  162. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiSelectComponent.js +0 -55
  163. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiUploadComponent.js +0 -67
  164. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToRepeatableComponent.js +0 -57
  165. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToTupleComponent.js +0 -20
  166. package/build/domain/mappers/schema/blobSchemaToComponent.js +0 -15
  167. package/build/domain/mappers/schema/booleanSchemaToComponent.js +0 -29
  168. package/build/domain/mappers/schema/constSchemaToComponent.js +0 -23
  169. package/build/domain/mappers/schema/integerSchemaToComponent.js +0 -28
  170. package/build/domain/mappers/schema/numberSchemaToComponent.js +0 -26
  171. package/build/domain/mappers/schema/objectSchemaToComponent/assertDisplayOrder.js +0 -23
  172. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToFormattedValueComponent.js +0 -9
  173. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.js +0 -119
  174. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.test.js +0 -96
  175. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.js +0 -31
  176. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.test.js +0 -99
  177. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.js +0 -66
  178. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.test.js +0 -225
  179. package/build/domain/mappers/schema/persistAsyncSchemaToComponent.js +0 -29
  180. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.js +0 -18
  181. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.test.js +0 -133
  182. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToDateInputComponent.js +0 -48
  183. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToTextInputComponent.js +0 -37
  184. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToUploadInputComponent.js +0 -28
  185. package/build/domain/mappers/schema/tests/test-utils.js +0 -16
  186. package/build/domain/mappers/schema/types.js +0 -1
  187. package/build/domain/mappers/schema/utils/getPerformPersistAsyncFn.js +0 -19
  188. package/build/domain/mappers/schema/utils/getValidationAsyncInitialState.js +0 -23
  189. package/build/domain/mappers/schema/utils/mapCommonSchemaProps.js +0 -16
  190. package/build/domain/mappers/types.js +0 -1
  191. package/build/domain/mappers/utils/FeatureFlags.js +0 -22
  192. package/build/domain/mappers/utils/behavior-utils.js +0 -44
  193. package/build/domain/mappers/utils/call-to-action-utils.js +0 -21
  194. package/build/domain/mappers/utils/getAutocompleteString.js +0 -76
  195. package/build/domain/mappers/utils/getAutocompleteString.test.js +0 -21
  196. package/build/domain/mappers/utils/groupLayoutByPinned.js +0 -38
  197. package/build/domain/mappers/utils/groupLayoutByPinned.test.js +0 -166
  198. package/build/domain/mappers/utils/image.js +0 -9
  199. package/build/domain/mappers/utils/layout-utils.js +0 -11
  200. package/build/domain/mappers/utils/legacy-utils.js +0 -49
  201. package/build/domain/mappers/utils/media-utils.js +0 -14
  202. package/build/domain/mappers/utils/suggestions-utils.js +0 -26
  203. package/build/domain/mappers/utils/suggestions-utils.test.js +0 -36
  204. package/build/domain/mappers/utils/tags-utils.js +0 -1
  205. package/build/domain/mappers/utils/utils.js +0 -35
  206. package/build/domain/types.js +0 -1
  207. package/build/getSubflowCallbacks.js +0 -38
  208. package/build/i18n/index.js +0 -40
  209. package/build/index.js +0 -8
  210. package/build/renderers/CoreContainerRenderer.js +0 -5
  211. package/build/renderers/CoreRootRenderer.js +0 -12
  212. package/build/renderers/EmptyLoadingStateRenderer.js +0 -5
  213. package/build/renderers/getRenderFunction.js +0 -24
  214. package/build/renderers/getSchemaErrorMessageFunction.js +0 -97
  215. package/build/renderers/mappers/alertComponentToProps.js +0 -2
  216. package/build/renderers/mappers/allOfComponentToProps.js +0 -6
  217. package/build/renderers/mappers/booleanInputComponentToProps.js +0 -5
  218. package/build/renderers/mappers/boxComponentToProps.js +0 -13
  219. package/build/renderers/mappers/buttonComponentToProps.js +0 -4
  220. package/build/renderers/mappers/columnsComponentToProps.js +0 -11
  221. package/build/renderers/mappers/componentToRendererProps.js +0 -164
  222. package/build/renderers/mappers/constComponentToProps.js +0 -5
  223. package/build/renderers/mappers/containerComponentToProps.js +0 -7
  224. package/build/renderers/mappers/dateInputComponentToProps.js +0 -2
  225. package/build/renderers/mappers/decisionComponentToProps.js +0 -16
  226. package/build/renderers/mappers/dividerComponentToProps.js +0 -2
  227. package/build/renderers/mappers/externalComponentToProps.js +0 -3
  228. package/build/renderers/mappers/formComponentToProps.js +0 -12
  229. package/build/renderers/mappers/formattedValueComponentToProps.js +0 -5
  230. package/build/renderers/mappers/headingComponentToProps.js +0 -2
  231. package/build/renderers/mappers/hiddenComponentToProps.js +0 -4
  232. package/build/renderers/mappers/imageComponentToProps.js +0 -2
  233. package/build/renderers/mappers/instructionsComponentToProps.js +0 -2
  234. package/build/renderers/mappers/integerInputComponentToProps.js +0 -2
  235. package/build/renderers/mappers/listComponentToProps.js +0 -2
  236. package/build/renderers/mappers/loadingIndicatorComponentToProps.js +0 -2
  237. package/build/renderers/mappers/markdownComponentToProps.js +0 -2
  238. package/build/renderers/mappers/mediaComponentToProps.js +0 -2
  239. package/build/renderers/mappers/modalComponentToProps.js +0 -11
  240. package/build/renderers/mappers/modalLayoutComponentToProps.js +0 -16
  241. package/build/renderers/mappers/moneyInputComponentToProps.js +0 -36
  242. package/build/renderers/mappers/multiSelectComponentToProps.js +0 -23
  243. package/build/renderers/mappers/multiUploadInputComponentToProps.js +0 -12
  244. package/build/renderers/mappers/numberInputComponentToProps.js +0 -2
  245. package/build/renderers/mappers/objectComponentToProps.js +0 -8
  246. package/build/renderers/mappers/paragraphComponentToProps.js +0 -2
  247. package/build/renderers/mappers/persistAsyncComponentToProps.js +0 -8
  248. package/build/renderers/mappers/progressComponentToProps.js +0 -2
  249. package/build/renderers/mappers/repeatableComponentToProps.js +0 -30
  250. package/build/renderers/mappers/reviewComponentToProps.js +0 -2
  251. package/build/renderers/mappers/rootComponentToProps.js +0 -21
  252. package/build/renderers/mappers/searchComponentToProps.js +0 -57
  253. package/build/renderers/mappers/sectionComponentToProps.js +0 -6
  254. package/build/renderers/mappers/selectInputComponentToProps.js +0 -34
  255. package/build/renderers/mappers/statusListComponentToProps.js +0 -2
  256. package/build/renderers/mappers/subflowComponentToRendererProps.js +0 -4
  257. package/build/renderers/mappers/tabsComponentToProps.js +0 -14
  258. package/build/renderers/mappers/textInputComponentToProps.js +0 -2
  259. package/build/renderers/mappers/tupleComponentToProps.js +0 -8
  260. package/build/renderers/mappers/uploadInputComponentToProps.js +0 -8
  261. package/build/renderers/mappers/upsellComponentToProps.js +0 -2
  262. package/build/renderers/mappers/utils/getValidationState.js +0 -12
  263. package/build/renderers/mappers/utils/inputComponentToProps.js +0 -26
  264. package/build/renderers/mappers/utils/mapErrorsToValidationState.js +0 -9
  265. package/build/renderers/mappers/utils/pick.js +0 -8
  266. package/build/renderers/mappers/utils/selectInputOptionsToProps.js +0 -11
  267. package/build/renderers/stepComponentToProps.js +0 -32
  268. package/build/renderers/utils.js +0 -69
  269. package/build/renderers/utils.test.js +0 -70
  270. package/build/stories/dev-tools/ContainerQueries.story.js +0 -66
  271. package/build/stories/dev-tools/Debugger.story.js +0 -38
  272. package/build/stories/dev-tools/FixtureSelect.story.js +0 -23
  273. package/build/stories/dev-tools/TestServer.story.js +0 -32
  274. package/build/stories/examples/NativeFlow.story.js +0 -80
  275. package/build/stories/examples/Recipients.story.js +0 -568
  276. package/build/stories/spec/behavior/Copy.story.js +0 -59
  277. package/build/stories/spec/behavior/Modal.story.js +0 -76
  278. package/build/stories/spec/behavior/Subflow.story.js +0 -267
  279. package/build/stories/spec/layouts/Decision.story.js +0 -241
  280. package/build/stories/spec/layouts/Image.story.js +0 -42
  281. package/build/stories/spec/layouts/Modal.story.js +0 -81
  282. package/build/stories/spec/layouts/Search.story.js +0 -325
  283. package/build/stories/spec/layouts/Upsell.story.js +0 -55
  284. package/build/stories/spec/layouts/button/Button.story.js +0 -100
  285. package/build/stories/spec/layouts/button/PinnedButton.story.js +0 -81
  286. package/build/stories/spec/response/ActionResponse.story.js +0 -66
  287. package/build/stories/spec/schemas/MultiSelect.story.js +0 -148
  288. package/build/stories/spec/schemas/Upload.story.js +0 -168
  289. package/build/stories/spec/schemas/const/ConstLayout.story.js +0 -159
  290. package/build/stories/spec/schemas/const/ObjectConst.story.js +0 -94
  291. package/build/stories/spec/schemas/features/PersistAsync.story.js +0 -211
  292. package/build/stories/spec/schemas/features/ValidationAsync.story.js +0 -103
  293. package/build/stories/spec/schemas/object/FormattedValue.story.js +0 -92
  294. package/build/stories/spec/schemas/object/MoneyInput.story.js +0 -240
  295. package/build/stories/spec/schemas/oneOf/OneOfInitialisation.story.js +0 -55
  296. package/build/stories/spec/schemas/oneOf/OneOfWithSingleOption.story.js +0 -114
  297. package/build/stories/spec/step/Controls.story.js +0 -109
  298. package/build/stories/spec/step/DFModal.story.js +0 -58
  299. package/build/stories/spec/step/Footer.story.js +0 -70
  300. package/build/stories/spec/step/Navigation.story.js +0 -20
  301. package/build/stories/spec/step/Tags.story.js +0 -39
  302. package/build/stories/spec/step/ToolBar.story.js +0 -60
  303. package/build/stories/spec/step/features/ErrorHandling.story.js +0 -92
  304. package/build/stories/spec/step/features/External.story.js +0 -44
  305. package/build/stories/spec/step/features/Polling.story.js +0 -108
  306. package/build/stories/spec/step/features/RefreshAfter.story.js +0 -92
  307. package/build/stories/spec/step/features/refresh/Refresh.story.js +0 -258
  308. package/build/stories/spec/step/features/refresh/RefreshWithPersistAsync.story.js +0 -958
  309. package/build/stories/types.js +0 -1
  310. package/build/stories/utils/fixtureHttpClient.js +0 -70
  311. package/build/stories/utils/getBasicStep.js +0 -223
  312. package/build/stories/utils/mockSearchHandler.js +0 -71
  313. package/build/stories/utils/render-utils.js +0 -41
  314. package/build/stories/visual-tests/layouts/NotUsingListItem.story.js +0 -17
  315. package/build/test-utils/DynamicFlowWise.js +0 -32
  316. package/build/test-utils/DynamicFlowWiseModal.js +0 -34
  317. package/build/test-utils/NeptuneProviders.js +0 -11
  318. package/build/test-utils/component-utils.js +0 -5
  319. package/build/test-utils/fetch-utils.js +0 -45
  320. package/build/test-utils/getMergedTestRenderers.js +0 -34
  321. package/build/test-utils/getRandomId.js +0 -1
  322. package/build/test-utils/index.js +0 -3
  323. package/build/test-utils/rtl-utils.js +0 -7
  324. package/build/test-utils/step-utils.js +0 -6
  325. package/build/test-utils/wait.js +0 -3
  326. package/build/tests/AlertLayout.test.js +0 -78
  327. package/build/tests/ArrayTuple.test.js +0 -118
  328. package/build/tests/ButtonLayout.test.js +0 -308
  329. package/build/tests/ConstLayout.test.js +0 -95
  330. package/build/tests/DateInput.test.js +0 -163
  331. package/build/tests/DecisionLayout.test.js +0 -146
  332. package/build/tests/DynamicFlow.test.js +0 -147
  333. package/build/tests/External.test.js +0 -169
  334. package/build/tests/Flow.test.js +0 -328
  335. package/build/tests/FormLayout.test.js +0 -28
  336. package/build/tests/FormattedValue.test.js +0 -107
  337. package/build/tests/ImageRenderer.test.js +0 -78
  338. package/build/tests/InitialAction.test.js +0 -179
  339. package/build/tests/InitialStep.test.js +0 -168
  340. package/build/tests/InstructionsLayout.test.js +0 -45
  341. package/build/tests/ListLayout.test.js +0 -145
  342. package/build/tests/Logging.test.js +0 -53
  343. package/build/tests/ModalBehavior.test.js +0 -149
  344. package/build/tests/MoneyInput.test.js +0 -316
  345. package/build/tests/MultiUpload.test.js +0 -293
  346. package/build/tests/NativeBack.test.js +0 -267
  347. package/build/tests/OneOfInitialisation.test.js +0 -571
  348. package/build/tests/PersistAsync.test.js +0 -686
  349. package/build/tests/Polling.test.js +0 -617
  350. package/build/tests/Prefetching.test.js +0 -230
  351. package/build/tests/RefreshAfter.test.js +0 -63
  352. package/build/tests/RefreshOnChange.ResponseHandling.test.js +0 -205
  353. package/build/tests/RefreshOnChange.test.js +0 -233
  354. package/build/tests/RefreshOnChange.with.Segmented.test.js +0 -348
  355. package/build/tests/RefreshOnChange.with.Tabs.test.js +0 -358
  356. package/build/tests/RefreshOnChangePreserve.test.js +0 -224
  357. package/build/tests/RendererProps.test.js +0 -342
  358. package/build/tests/Repeatable.test.js +0 -107
  359. package/build/tests/Rerendering.test.js +0 -67
  360. package/build/tests/ReviewLayout.test.js +0 -274
  361. package/build/tests/SchemaOnChange.test.js +0 -133
  362. package/build/tests/SchemaReferences.test.js +0 -88
  363. package/build/tests/ScrollToError.test.js +0 -217
  364. package/build/tests/SegmentedControl.test.js +0 -49
  365. package/build/tests/SingleFileUpload.test.js +0 -88
  366. package/build/tests/StatusList.test.js +0 -85
  367. package/build/tests/Subflow.test.js +0 -710
  368. package/build/tests/Submission.ResponseHandling.test.js +0 -557
  369. package/build/tests/Submission.merging.test.js +0 -202
  370. package/build/tests/Submission.test.js +0 -603
  371. package/build/tests/Tags.test.js +0 -475
  372. package/build/tests/Upsell.test.js +0 -126
  373. package/build/tests/ValidationAsync.test.js +0 -295
  374. package/build/tests/legacy/Actions.test.js +0 -158
  375. package/build/tests/legacy/BackButton.test.js +0 -114
  376. package/build/tests/legacy/HiddenSchemas.test.js +0 -246
  377. package/build/tests/legacy/MultiSelect.test.js +0 -497
  378. package/build/tests/legacy/MultipleFileUploadSchema.test.js +0 -341
  379. package/build/tests/legacy/PersistAsync.blob-schema.test.js +0 -224
  380. package/build/tests/legacy/PersistAsync.string-schema.test.js +0 -211
  381. package/build/tests/legacy/RefreshStepOnChange.debouncing.test.js +0 -209
  382. package/build/tests/legacy/RefreshStepOnChange.test.js +0 -424
  383. package/build/tests/legacy/Search.test.js +0 -437
  384. package/build/tests/renderers/MultiSelectInputRendererProps.test.js +0 -58
  385. package/build/tests/renderers/SelectInputRendererProps.test.js +0 -43
  386. package/build/tests/renderers/TextInputRenderer.test.js +0 -51
  387. package/build/types.js +0 -1
  388. package/build/useDynamicFlow.js +0 -104
  389. package/build/useDynamicFlowModal.js +0 -58
  390. package/build/utils/analyse-step.js +0 -14
  391. package/build/utils/component-utils.js +0 -8
  392. package/build/utils/component-utils.test.js +0 -113
  393. package/build/utils/getScrollToTop.js +0 -12
  394. package/build/utils/normalise-flow-id.js +0 -1
  395. package/build/utils/normalise-flow-id.test.js +0 -24
  396. package/build/utils/openLinkInNewTab.js +0 -10
  397. package/build/utils/recursiveMerge.js +0 -40
  398. package/build/utils/recursiveMerge.test.js +0 -93
  399. package/build/utils/type-utils.js +0 -21
  400. package/build/utils/type-validators.js +0 -11
  401. package/build/utils/type-validators.test.js +0 -180
  402. 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,43 +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.type).toBe('input-select');
28
- expect(props.options).toHaveLength(2);
29
- expect(props.options[0].children).toBeDefined();
30
- expect(props.options[1].children).toBeDefined();
31
- expect(props.options[0].childrenProps).toBeDefined();
32
- expect((_a = props.options[0].childrenProps) === null || _a === void 0 ? void 0 : _a.type).toBe('container');
33
- expect((_b = props.options[0].childrenProps.childrenProps) === null || _b === void 0 ? void 0 : _b[0].type).toBe('paragraph');
34
- expect(((_c = props.options[0].childrenProps
35
- .childrenProps) === null || _c === void 0 ? void 0 : _c[0]).text).toBe('This is option 1');
36
- expect(props.options[1].childrenProps).toBeDefined();
37
- expect((_d = props.options[1].childrenProps) === null || _d === void 0 ? void 0 : _d.type).toBe('container');
38
- expect((_e = props.options[1].childrenProps.childrenProps) === null || _e === void 0 ? void 0 : _e[0].type).toBe('paragraph');
39
- expect(((_f = props.options[1].childrenProps
40
- .childrenProps) === null || _f === void 0 ? void 0 : _f[0]).text).toBe('This is option 2');
41
- });
42
- });
43
- });
@@ -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 {};