@wise/dynamic-flow-client 5.13.2 → 5.13.3

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 (409) hide show
  1. package/build/main.css +24 -15
  2. package/build/tsconfig.types.tsbuildinfo +1 -1
  3. package/build/types/stories/utils/render-utils.d.ts.map +1 -1
  4. package/package.json +16 -16
  5. package/build/DynamicFlowCore.js +0 -5
  6. package/build/common/errorBoundary/ErrorBoundary.js +0 -26
  7. package/build/common/errorBoundary/ErrorBoundary.test.js +0 -29
  8. package/build/common/errorBoundary/ErrorBoundaryAlert.js +0 -11
  9. package/build/common/makeHttpClient/api-utils.js +0 -3
  10. package/build/common/makeHttpClient/index.js +0 -1
  11. package/build/common/makeHttpClient/makeHttpClient.js +0 -10
  12. package/build/common/makeHttpClient/makeHttpClient.test.js +0 -186
  13. package/build/common/messages/external-confirmation.messages.js +0 -23
  14. package/build/common/messages/file-upload.messages.js +0 -13
  15. package/build/common/messages/generic-error.messages.js +0 -18
  16. package/build/common/messages/help.messages.js +0 -8
  17. package/build/common/messages/multi-file-upload.messages.js +0 -18
  18. package/build/common/messages/multi-select.messages.js +0 -8
  19. package/build/common/messages/paragraph.messages.js +0 -13
  20. package/build/common/messages/repeatable.messages.js +0 -23
  21. package/build/common/messages/search.messages.js +0 -8
  22. package/build/common/messages/validation.array.messages.js +0 -13
  23. package/build/common/messages/validation.messages.js +0 -53
  24. package/build/controller/FlowController.js +0 -378
  25. package/build/controller/executePoll.js +0 -64
  26. package/build/controller/executeRefresh.js +0 -45
  27. package/build/controller/executeRequest.js +0 -80
  28. package/build/controller/executeSubmission.js +0 -70
  29. package/build/controller/getErrorMessage.js +0 -7
  30. package/build/controller/getRequestAbortController.js +0 -13
  31. package/build/controller/getResponseType.js +0 -35
  32. package/build/controller/getSafeHttpClient.js +0 -8
  33. package/build/controller/getStepCounter.js +0 -16
  34. package/build/controller/handleErrorResponse.js +0 -26
  35. package/build/controller/makeSafeHttpClient.js +0 -8
  36. package/build/controller/response-utils.js +0 -72
  37. package/build/controller/response-utils.test.js +0 -52
  38. package/build/domain/components/AlertComponent.js +0 -1
  39. package/build/domain/components/AllOfComponent.js +0 -40
  40. package/build/domain/components/BooleanInputComponent.js +0 -50
  41. package/build/domain/components/BoxComponent.js +0 -3
  42. package/build/domain/components/ButtonComponent.js +0 -1
  43. package/build/domain/components/ColumnsComponent.js +0 -3
  44. package/build/domain/components/ConstComponent.js +0 -18
  45. package/build/domain/components/ContainerComponent.js +0 -3
  46. package/build/domain/components/DateInputComponent.js +0 -75
  47. package/build/domain/components/DecisionComponent.js +0 -1
  48. package/build/domain/components/DividerComponent.js +0 -1
  49. package/build/domain/components/FormComponent.js +0 -3
  50. package/build/domain/components/FormattedValueComponent.js +0 -44
  51. package/build/domain/components/HeadingComponent.js +0 -1
  52. package/build/domain/components/ImageComponent.js +0 -1
  53. package/build/domain/components/InstructionsComponent.js +0 -1
  54. package/build/domain/components/IntegerInputComponent.js +0 -74
  55. package/build/domain/components/ListComponent.js +0 -1
  56. package/build/domain/components/LoadingIndicatorComponent.js +0 -1
  57. package/build/domain/components/MarkdownComponent.js +0 -1
  58. package/build/domain/components/MediaComponent.js +0 -1
  59. package/build/domain/components/ModalComponent.js +0 -16
  60. package/build/domain/components/ModalLayoutComponent.js +0 -3
  61. package/build/domain/components/MoneyInputComponent.js +0 -57
  62. package/build/domain/components/MultiSelectInputComponent.js +0 -81
  63. package/build/domain/components/MultiUploadInputComponent.js +0 -88
  64. package/build/domain/components/NumberInputComponent.js +0 -73
  65. package/build/domain/components/ObjectComponent.js +0 -45
  66. package/build/domain/components/ParagraphComponent.js +0 -1
  67. package/build/domain/components/PersistAsyncComponent.js +0 -92
  68. package/build/domain/components/ProgressComponent.js +0 -1
  69. package/build/domain/components/RepeatableComponent.js +0 -103
  70. package/build/domain/components/ReviewComponent.js +0 -1
  71. package/build/domain/components/RootDomainComponent.js +0 -173
  72. package/build/domain/components/SectionComponent.js +0 -5
  73. package/build/domain/components/SelectInputComponent.js +0 -88
  74. package/build/domain/components/StatusListComponent.js +0 -1
  75. package/build/domain/components/SubflowDomainComponent.js +0 -9
  76. package/build/domain/components/TabsComponent.js +0 -1
  77. package/build/domain/components/TextInputComponent.js +0 -76
  78. package/build/domain/components/TupleComponent.js +0 -41
  79. package/build/domain/components/UploadInputComponent.js +0 -83
  80. package/build/domain/components/UpsellComponent.js +0 -25
  81. package/build/domain/components/searchComponent/SearchComponent.js +0 -92
  82. package/build/domain/components/searchComponent/SearchComponent.test.js +0 -190
  83. package/build/domain/components/step/ExternalConfirmationComponent.js +0 -24
  84. package/build/domain/components/step/StepDomainComponent.js +0 -78
  85. package/build/domain/components/step/ToolbarComponent.js +0 -1
  86. package/build/domain/components/utils/WithUpdate.js +0 -1
  87. package/build/domain/components/utils/component-utils.js +0 -12
  88. package/build/domain/components/utils/debounce.js +0 -34
  89. package/build/domain/components/utils/debounce.test.js +0 -67
  90. package/build/domain/components/utils/file-utils.js +0 -21
  91. package/build/domain/components/utils/file-utils.test.js +0 -27
  92. package/build/domain/components/utils/getRandomId.js +0 -1
  93. package/build/domain/components/utils/isExactLocalValueMatch.js +0 -14
  94. package/build/domain/components/utils/isOrWasValid.js +0 -5
  95. package/build/domain/components/utils/isPartialModelMatch.js +0 -18
  96. package/build/domain/components/utils/isPartialModelMatch.test.js +0 -74
  97. package/build/domain/features/eventNames.js +0 -24
  98. package/build/domain/features/events.js +0 -1
  99. package/build/domain/features/persistAsync/getComponentMultiPersistAsync.js +0 -50
  100. package/build/domain/features/persistAsync/getInitialPersistedState.js +0 -7
  101. package/build/domain/features/persistAsync/getPerformPersistAsync.js +0 -43
  102. package/build/domain/features/persistAsync/getPerformPersistAsync.test.js +0 -139
  103. package/build/domain/features/polling/getStepPolling.js +0 -50
  104. package/build/domain/features/polling/getStepPolling.test.js +0 -115
  105. package/build/domain/features/prefetch/getStepPrefetch.js +0 -43
  106. package/build/domain/features/prefetch/request-cache.js +0 -49
  107. package/build/domain/features/prefetch/request-cache.test.js +0 -70
  108. package/build/domain/features/refreshAfter/getStepRefreshAfter.js +0 -24
  109. package/build/domain/features/refreshAfter/getStepRefreshAfter.test.js +0 -40
  110. package/build/domain/features/schema-on-change/getDebouncedSchemaOnChange.js +0 -50
  111. package/build/domain/features/schema-on-change/getSchemaOnChange.js +0 -34
  112. package/build/domain/features/search/getPerformSearchFunction.js +0 -75
  113. package/build/domain/features/search/getPerformSearchFunction.test.js +0 -301
  114. package/build/domain/features/summary/summary-utils.js +0 -40
  115. package/build/domain/features/summary/summary-utils.test.js +0 -125
  116. package/build/domain/features/utils/http-utils.js +0 -21
  117. package/build/domain/features/utils/response-utils.js +0 -9
  118. package/build/domain/features/validation/spec-utils.js +0 -19
  119. package/build/domain/features/validation/validateStringPattern.js +0 -24
  120. package/build/domain/features/validation/validation-functions.js +0 -6
  121. package/build/domain/features/validation/validation-functions.test.js +0 -108
  122. package/build/domain/features/validation/value-checks.js +0 -125
  123. package/build/domain/features/validation/value-checks.test.js +0 -262
  124. package/build/domain/features/validationAsync/getComponentValidationAsync.js +0 -53
  125. package/build/domain/features/validationAsync/getComponentValidationAsync.test.js +0 -67
  126. package/build/domain/features/validationAsync/getInitialValidationAsyncState.js +0 -5
  127. package/build/domain/features/validationAsync/getPerformValidationAsync.js +0 -45
  128. package/build/domain/features/validationAsync/getPerformValidationAsync.test.js +0 -143
  129. package/build/domain/mappers/layout/alertLayoutToComponent.js +0 -16
  130. package/build/domain/mappers/layout/boxLayoutToComponent.js +0 -13
  131. package/build/domain/mappers/layout/buttonLayoutToComponent.js +0 -77
  132. package/build/domain/mappers/layout/columnsLayoutToComponent.js +0 -13
  133. package/build/domain/mappers/layout/decisionLayoutToComponent.js +0 -22
  134. package/build/domain/mappers/layout/deprecatedListLayoutToComponent.js +0 -30
  135. package/build/domain/mappers/layout/dividerLayoutToComponent.js +0 -2
  136. package/build/domain/mappers/layout/formLayoutToComponent.js +0 -19
  137. package/build/domain/mappers/layout/headingLayoutToComponent.js +0 -12
  138. package/build/domain/mappers/layout/imageLayoutToComponent.js +0 -20
  139. package/build/domain/mappers/layout/infoLayoutToComponent.js +0 -12
  140. package/build/domain/mappers/layout/instructionsLayoutToComponent.js +0 -12
  141. package/build/domain/mappers/layout/listLayoutToComponent.js +0 -39
  142. package/build/domain/mappers/layout/loadingIndicatorLayoutToComponent.js +0 -9
  143. package/build/domain/mappers/layout/markdownLayoutToComponent.js +0 -12
  144. package/build/domain/mappers/layout/mediaLayoutToComponent.js +0 -12
  145. package/build/domain/mappers/layout/modalLayoutToComponent.js +0 -17
  146. package/build/domain/mappers/layout/modalToComponent.js +0 -8
  147. package/build/domain/mappers/layout/paragraphLayoutToComponent.js +0 -12
  148. package/build/domain/mappers/layout/progressLayoutToComponent.js +0 -15
  149. package/build/domain/mappers/layout/reviewLayoutToComponent.js +0 -48
  150. package/build/domain/mappers/layout/searchLayoutToComponent.js +0 -44
  151. package/build/domain/mappers/layout/sectionLayoutToComponent.js +0 -15
  152. package/build/domain/mappers/layout/statusListLayoutToComponent.js +0 -15
  153. package/build/domain/mappers/layout/tabsLayoutToComponent.js +0 -16
  154. package/build/domain/mappers/layout/upsellLayoutToComponent.js +0 -25
  155. package/build/domain/mappers/mapLayoutToComponent.js +0 -81
  156. package/build/domain/mappers/mapSchemaToComponent.js +0 -61
  157. package/build/domain/mappers/mapSchemaToComponent.test.js +0 -112
  158. package/build/domain/mappers/mapStepSchemas.js +0 -15
  159. package/build/domain/mappers/mapStepToComponent.js +0 -133
  160. package/build/domain/mappers/mapStepToComponent.test.js +0 -221
  161. package/build/domain/mappers/mapToolbarToComponent.js +0 -15
  162. package/build/domain/mappers/schema/allOfSchemaToComponent.js +0 -16
  163. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToComponent.js +0 -26
  164. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiSelectComponent.js +0 -55
  165. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiUploadComponent.js +0 -67
  166. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToRepeatableComponent.js +0 -57
  167. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToTupleComponent.js +0 -20
  168. package/build/domain/mappers/schema/blobSchemaToComponent.js +0 -15
  169. package/build/domain/mappers/schema/booleanSchemaToComponent.js +0 -29
  170. package/build/domain/mappers/schema/constSchemaToComponent.js +0 -23
  171. package/build/domain/mappers/schema/integerSchemaToComponent.js +0 -28
  172. package/build/domain/mappers/schema/numberSchemaToComponent.js +0 -26
  173. package/build/domain/mappers/schema/objectSchemaToComponent/assertDisplayOrder.js +0 -23
  174. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToFormattedValueComponent.js +0 -9
  175. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.js +0 -119
  176. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.test.js +0 -96
  177. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.js +0 -31
  178. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.test.js +0 -99
  179. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.js +0 -66
  180. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.test.js +0 -225
  181. package/build/domain/mappers/schema/persistAsyncSchemaToComponent.js +0 -29
  182. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.js +0 -18
  183. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.test.js +0 -133
  184. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToDateInputComponent.js +0 -48
  185. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToTextInputComponent.js +0 -38
  186. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToUploadInputComponent.js +0 -28
  187. package/build/domain/mappers/schema/tests/test-utils.js +0 -16
  188. package/build/domain/mappers/schema/types.js +0 -1
  189. package/build/domain/mappers/schema/utils/getPerformPersistAsyncFn.js +0 -19
  190. package/build/domain/mappers/schema/utils/getValidationAsyncInitialState.js +0 -23
  191. package/build/domain/mappers/schema/utils/mapCommonSchemaProps.js +0 -16
  192. package/build/domain/mappers/types.js +0 -1
  193. package/build/domain/mappers/utils/FeatureFlags.js +0 -22
  194. package/build/domain/mappers/utils/behavior-utils.js +0 -44
  195. package/build/domain/mappers/utils/call-to-action-utils.js +0 -21
  196. package/build/domain/mappers/utils/getAutocompleteString.js +0 -76
  197. package/build/domain/mappers/utils/getAutocompleteString.test.js +0 -21
  198. package/build/domain/mappers/utils/groupLayoutByPinned.js +0 -38
  199. package/build/domain/mappers/utils/groupLayoutByPinned.test.js +0 -166
  200. package/build/domain/mappers/utils/image.js +0 -9
  201. package/build/domain/mappers/utils/layout-utils.js +0 -11
  202. package/build/domain/mappers/utils/legacy-utils.js +0 -49
  203. package/build/domain/mappers/utils/media-utils.js +0 -14
  204. package/build/domain/mappers/utils/suggestions-utils.js +0 -26
  205. package/build/domain/mappers/utils/suggestions-utils.test.js +0 -36
  206. package/build/domain/mappers/utils/tags-utils.js +0 -1
  207. package/build/domain/mappers/utils/utils.js +0 -35
  208. package/build/domain/types.js +0 -1
  209. package/build/getSubflowCallbacks.js +0 -38
  210. package/build/i18n/index.js +0 -40
  211. package/build/index.js +0 -8
  212. package/build/renderers/CoreContainerRenderer.js +0 -5
  213. package/build/renderers/CoreRootRenderer.js +0 -12
  214. package/build/renderers/EmptyLoadingStateRenderer.js +0 -5
  215. package/build/renderers/getRenderFunction.js +0 -24
  216. package/build/renderers/getSchemaErrorMessageFunction.js +0 -97
  217. package/build/renderers/mappers/alertComponentToProps.js +0 -2
  218. package/build/renderers/mappers/allOfComponentToProps.js +0 -6
  219. package/build/renderers/mappers/booleanInputComponentToProps.js +0 -5
  220. package/build/renderers/mappers/boxComponentToProps.js +0 -13
  221. package/build/renderers/mappers/buttonComponentToProps.js +0 -4
  222. package/build/renderers/mappers/columnsComponentToProps.js +0 -11
  223. package/build/renderers/mappers/componentToRendererProps.js +0 -164
  224. package/build/renderers/mappers/constComponentToProps.js +0 -5
  225. package/build/renderers/mappers/containerComponentToProps.js +0 -7
  226. package/build/renderers/mappers/dateInputComponentToProps.js +0 -2
  227. package/build/renderers/mappers/decisionComponentToProps.js +0 -16
  228. package/build/renderers/mappers/dividerComponentToProps.js +0 -2
  229. package/build/renderers/mappers/externalComponentToProps.js +0 -3
  230. package/build/renderers/mappers/formComponentToProps.js +0 -12
  231. package/build/renderers/mappers/formattedValueComponentToProps.js +0 -5
  232. package/build/renderers/mappers/headingComponentToProps.js +0 -2
  233. package/build/renderers/mappers/hiddenComponentToProps.js +0 -4
  234. package/build/renderers/mappers/imageComponentToProps.js +0 -2
  235. package/build/renderers/mappers/instructionsComponentToProps.js +0 -2
  236. package/build/renderers/mappers/integerInputComponentToProps.js +0 -2
  237. package/build/renderers/mappers/listComponentToProps.js +0 -2
  238. package/build/renderers/mappers/loadingIndicatorComponentToProps.js +0 -2
  239. package/build/renderers/mappers/markdownComponentToProps.js +0 -2
  240. package/build/renderers/mappers/mediaComponentToProps.js +0 -2
  241. package/build/renderers/mappers/modalComponentToProps.js +0 -11
  242. package/build/renderers/mappers/modalLayoutComponentToProps.js +0 -16
  243. package/build/renderers/mappers/moneyInputComponentToProps.js +0 -36
  244. package/build/renderers/mappers/multiSelectComponentToProps.js +0 -23
  245. package/build/renderers/mappers/multiUploadInputComponentToProps.js +0 -12
  246. package/build/renderers/mappers/numberInputComponentToProps.js +0 -2
  247. package/build/renderers/mappers/objectComponentToProps.js +0 -8
  248. package/build/renderers/mappers/paragraphComponentToProps.js +0 -2
  249. package/build/renderers/mappers/persistAsyncComponentToProps.js +0 -8
  250. package/build/renderers/mappers/progressComponentToProps.js +0 -2
  251. package/build/renderers/mappers/repeatableComponentToProps.js +0 -30
  252. package/build/renderers/mappers/reviewComponentToProps.js +0 -2
  253. package/build/renderers/mappers/rootComponentToProps.js +0 -21
  254. package/build/renderers/mappers/searchComponentToProps.js +0 -57
  255. package/build/renderers/mappers/sectionComponentToProps.js +0 -6
  256. package/build/renderers/mappers/selectInputComponentToProps.js +0 -34
  257. package/build/renderers/mappers/statusListComponentToProps.js +0 -2
  258. package/build/renderers/mappers/subflowComponentToRendererProps.js +0 -4
  259. package/build/renderers/mappers/tabsComponentToProps.js +0 -14
  260. package/build/renderers/mappers/textInputComponentToProps.js +0 -2
  261. package/build/renderers/mappers/tupleComponentToProps.js +0 -8
  262. package/build/renderers/mappers/uploadInputComponentToProps.js +0 -8
  263. package/build/renderers/mappers/upsellComponentToProps.js +0 -2
  264. package/build/renderers/mappers/utils/getValidationState.js +0 -12
  265. package/build/renderers/mappers/utils/inputComponentToProps.js +0 -26
  266. package/build/renderers/mappers/utils/mapErrorsToValidationState.js +0 -9
  267. package/build/renderers/mappers/utils/pick.js +0 -8
  268. package/build/renderers/mappers/utils/selectInputOptionsToProps.js +0 -11
  269. package/build/renderers/stepComponentToProps.js +0 -32
  270. package/build/renderers/utils.js +0 -69
  271. package/build/renderers/utils.test.js +0 -70
  272. package/build/stories/dev-tools/ContainerQueries.story.js +0 -66
  273. package/build/stories/dev-tools/Debugger.story.js +0 -38
  274. package/build/stories/dev-tools/FixtureSelect.story.js +0 -23
  275. package/build/stories/dev-tools/TestServer.story.js +0 -32
  276. package/build/stories/examples/NativeFlow.story.js +0 -80
  277. package/build/stories/examples/Recipients.story.js +0 -568
  278. package/build/stories/spec/behavior/Copy.story.js +0 -71
  279. package/build/stories/spec/behavior/Link.story.js +0 -40
  280. package/build/stories/spec/behavior/Modal.story.js +0 -79
  281. package/build/stories/spec/behavior/Subflow.story.js +0 -267
  282. package/build/stories/spec/layouts/Decision.story.js +0 -241
  283. package/build/stories/spec/layouts/Image.Illustrations.Animated.story.js +0 -37
  284. package/build/stories/spec/layouts/Image.Sizes.story.js +0 -58
  285. package/build/stories/spec/layouts/Modal.story.js +0 -81
  286. package/build/stories/spec/layouts/Search.story.js +0 -325
  287. package/build/stories/spec/layouts/Upsell.story.js +0 -55
  288. package/build/stories/spec/layouts/button/Button.story.js +0 -100
  289. package/build/stories/spec/layouts/button/PinnedButton.story.js +0 -81
  290. package/build/stories/spec/response/ActionResponse.story.js +0 -66
  291. package/build/stories/spec/schemas/MultiSelect.story.js +0 -148
  292. package/build/stories/spec/schemas/Upload.story.js +0 -168
  293. package/build/stories/spec/schemas/const/ConstLayout.story.js +0 -159
  294. package/build/stories/spec/schemas/const/ObjectConst.story.js +0 -94
  295. package/build/stories/spec/schemas/features/PersistAsync.story.js +0 -211
  296. package/build/stories/spec/schemas/features/ValidationAsync.story.js +0 -103
  297. package/build/stories/spec/schemas/object/FormattedValue.story.js +0 -92
  298. package/build/stories/spec/schemas/object/MoneyInput.story.js +0 -240
  299. package/build/stories/spec/schemas/oneOf/OneOfInitialisation.story.js +0 -55
  300. package/build/stories/spec/schemas/oneOf/OneOfWithSingleOption.story.js +0 -114
  301. package/build/stories/spec/step/Controls.story.js +0 -109
  302. package/build/stories/spec/step/DFModal.story.js +0 -58
  303. package/build/stories/spec/step/Footer.story.js +0 -70
  304. package/build/stories/spec/step/Navigation.story.js +0 -20
  305. package/build/stories/spec/step/ScrollToBottom.story.js +0 -103
  306. package/build/stories/spec/step/Tags.story.js +0 -39
  307. package/build/stories/spec/step/ToolBar.story.js +0 -60
  308. package/build/stories/spec/step/features/ErrorHandling.story.js +0 -92
  309. package/build/stories/spec/step/features/External.story.js +0 -91
  310. package/build/stories/spec/step/features/Polling.story.js +0 -108
  311. package/build/stories/spec/step/features/RefreshAfter.story.js +0 -92
  312. package/build/stories/spec/step/features/refresh/Refresh.story.js +0 -258
  313. package/build/stories/spec/step/features/refresh/RefreshWithPersistAsync.story.js +0 -958
  314. package/build/stories/types.js +0 -1
  315. package/build/stories/utils/fixtureHttpClient.js +0 -70
  316. package/build/stories/utils/getBasicStep.js +0 -223
  317. package/build/stories/utils/mockSearchHandler.js +0 -71
  318. package/build/stories/utils/render-utils.js +0 -41
  319. package/build/stories/visual-tests/layouts/NotUsingListItem.story.js +0 -17
  320. package/build/test-utils/DynamicFlowWise.js +0 -37
  321. package/build/test-utils/DynamicFlowWiseModal.js +0 -34
  322. package/build/test-utils/NeptuneProviders.js +0 -11
  323. package/build/test-utils/component-utils.js +0 -5
  324. package/build/test-utils/fetch-utils.js +0 -45
  325. package/build/test-utils/getMergedTestRenderers.js +0 -34
  326. package/build/test-utils/getRandomId.js +0 -1
  327. package/build/test-utils/index.js +0 -3
  328. package/build/test-utils/openLinkInNewTab.js +0 -15
  329. package/build/test-utils/rtl-utils.js +0 -7
  330. package/build/test-utils/step-utils.js +0 -6
  331. package/build/test-utils/wait.js +0 -3
  332. package/build/tests/AlertLayout.test.js +0 -78
  333. package/build/tests/ArrayTuple.test.js +0 -118
  334. package/build/tests/ButtonLayout.test.js +0 -308
  335. package/build/tests/ConstLayout.test.js +0 -95
  336. package/build/tests/DateInput.test.js +0 -163
  337. package/build/tests/DecisionLayout.test.js +0 -146
  338. package/build/tests/DynamicFlow.test.js +0 -147
  339. package/build/tests/External.test.js +0 -169
  340. package/build/tests/Flow.test.js +0 -328
  341. package/build/tests/FormLayout.test.js +0 -28
  342. package/build/tests/FormattedValue.test.js +0 -107
  343. package/build/tests/ImageRenderer.test.js +0 -78
  344. package/build/tests/InitialAction.test.js +0 -179
  345. package/build/tests/InitialStep.test.js +0 -168
  346. package/build/tests/InstructionsLayout.test.js +0 -45
  347. package/build/tests/ListLayout.test.js +0 -168
  348. package/build/tests/Logging.test.js +0 -53
  349. package/build/tests/ModalBehavior.test.js +0 -149
  350. package/build/tests/MoneyInput.test.js +0 -316
  351. package/build/tests/MultiUpload.test.js +0 -293
  352. package/build/tests/NativeBack.test.js +0 -267
  353. package/build/tests/NoOp.test.js +0 -194
  354. package/build/tests/OneOfInitialisation.test.js +0 -571
  355. package/build/tests/PersistAsync.test.js +0 -687
  356. package/build/tests/Polling.test.js +0 -702
  357. package/build/tests/Prefetching.test.js +0 -230
  358. package/build/tests/RefreshAfter.test.js +0 -63
  359. package/build/tests/RefreshOnChange.ResponseHandling.test.js +0 -205
  360. package/build/tests/RefreshOnChange.test.js +0 -233
  361. package/build/tests/RefreshOnChange.with.Segmented.test.js +0 -350
  362. package/build/tests/RefreshOnChange.with.Tabs.test.js +0 -358
  363. package/build/tests/RefreshOnChangePreserve.test.js +0 -224
  364. package/build/tests/RendererProps.test.js +0 -361
  365. package/build/tests/Repeatable.test.js +0 -107
  366. package/build/tests/Rerendering.test.js +0 -67
  367. package/build/tests/ReviewLayout.test.js +0 -274
  368. package/build/tests/SchemaOnChange.test.js +0 -133
  369. package/build/tests/SchemaReferences.test.js +0 -88
  370. package/build/tests/ScrollToBottom.test.js +0 -122
  371. package/build/tests/ScrollToError.test.js +0 -217
  372. package/build/tests/SegmentedControl.test.js +0 -49
  373. package/build/tests/SingleFileUpload.test.js +0 -168
  374. package/build/tests/StatusList.test.js +0 -85
  375. package/build/tests/Subflow.test.js +0 -887
  376. package/build/tests/Submission.ResponseHandling.test.js +0 -557
  377. package/build/tests/Submission.merging.test.js +0 -202
  378. package/build/tests/Submission.test.js +0 -748
  379. package/build/tests/Tags.test.js +0 -475
  380. package/build/tests/Upsell.test.js +0 -154
  381. package/build/tests/ValidationAsync.test.js +0 -295
  382. package/build/tests/legacy/Actions.test.js +0 -158
  383. package/build/tests/legacy/BackButton.test.js +0 -114
  384. package/build/tests/legacy/HiddenSchemas.test.js +0 -246
  385. package/build/tests/legacy/MultiSelect.test.js +0 -501
  386. package/build/tests/legacy/MultipleFileUploadSchema.test.js +0 -350
  387. package/build/tests/legacy/PersistAsync.blob-schema.test.js +0 -224
  388. package/build/tests/legacy/PersistAsync.string-schema.test.js +0 -211
  389. package/build/tests/legacy/RefreshStepOnChange.debouncing.test.js +0 -209
  390. package/build/tests/legacy/RefreshStepOnChange.test.js +0 -424
  391. package/build/tests/legacy/Search.test.js +0 -439
  392. package/build/tests/renderers/MultiSelectInputRendererProps.test.js +0 -58
  393. package/build/tests/renderers/SelectInputRendererProps.test.js +0 -43
  394. package/build/tests/renderers/TextInputRenderer.test.js +0 -51
  395. package/build/types.js +0 -1
  396. package/build/useDynamicFlow.js +0 -105
  397. package/build/useDynamicFlowModal.js +0 -58
  398. package/build/utils/analyse-step.js +0 -14
  399. package/build/utils/component-utils.js +0 -8
  400. package/build/utils/component-utils.test.js +0 -113
  401. package/build/utils/getScrollToTop.js +0 -12
  402. package/build/utils/normalise-flow-id.js +0 -1
  403. package/build/utils/normalise-flow-id.test.js +0 -24
  404. package/build/utils/recursiveMerge.js +0 -40
  405. package/build/utils/recursiveMerge.test.js +0 -93
  406. package/build/utils/type-utils.js +0 -21
  407. package/build/utils/type-validators.js +0 -11
  408. package/build/utils/type-validators.test.js +0 -180
  409. package/build/utils/useStableCallback.js +0 -15
@@ -1,350 +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
- // This file is a copy of the E2E test in legacy. It should remain as unchanged
9
- // as possible, to ensure the new client functionality matches the old one.
10
- const accepts = ['image/png', 'image/jpg', 'application/pdf'];
11
- const maxSize = 5242000;
12
- const description = 'PNG, JPG, or PDF, less than 5mb';
13
- const idProperty = 'responseKey';
14
- const param = 'bodyAttribute';
15
- const uploadTitle = 'Invoice (optional)';
16
- describe('Given a multiple file upload schema with persist-async', () => {
17
- const getArraySchema = (overrides) => (Object.assign({ type: 'array', title: 'upload schema title', minItems: 1, maxItems: 2, addItemTitle: '', editItemTitle: '', items: {
18
- type: 'string',
19
- persistAsync: {
20
- url: 'http://localhost:3001/v1/save-file/',
21
- method: 'POST',
22
- param,
23
- idProperty,
24
- schema: {
25
- // Modification: we now read the analytics id from the inner schema
26
- $id: 'upload-id',
27
- type: 'string',
28
- format: 'base64url',
29
- title: uploadTitle,
30
- description,
31
- maxSize,
32
- accepts,
33
- validationMessages: {
34
- maxSize: 'Your file is too large',
35
- },
36
- },
37
- },
38
- } }, overrides));
39
- const getMultipleFileUploadSchemaObject = (arraySchema = getArraySchema({})) => ({
40
- type: 'object',
41
- $id: '#schema',
42
- displayOrder: ['files'],
43
- required: ['files'],
44
- title: 'upload schema title',
45
- properties: {
46
- files: Object.assign({ $id: 'upload-id' }, arraySchema),
47
- },
48
- });
49
- const getMultipleFileUploadSchemaObjectWithoutId = () => ({
50
- type: 'object',
51
- $id: '#schema',
52
- displayOrder: ['files'],
53
- required: ['files'],
54
- title: 'upload schema title',
55
- properties: {
56
- files: Object.assign(Object.assign({}, getArraySchema({})), { minItems: 2, maxItems: 3, validationMessages: {
57
- minItems: 'minimum items not met error (from schema)',
58
- maxItems: 'maximum items uploaded already (from schema)',
59
- } }),
60
- },
61
- validationMessages: {
62
- minItems: 'minimum items not met error (from schema)',
63
- maxItems: 'maximum items uploaded already (from schema)',
64
- },
65
- });
66
- const testFile = new File([], 'test-file.pdf', { type: 'application/pdf' });
67
- const mockHttpClient = vi.fn();
68
- const initialStep = {
69
- id: 'multiple-file-upload-schema-test-step-id',
70
- title: 'OneOf Schema Step Title',
71
- layout: [
72
- { type: 'form', schemaId: '#schema' },
73
- {
74
- type: 'button',
75
- title: 'Submit',
76
- action: { url: '/submit', method: 'POST' },
77
- },
78
- ],
79
- schemas: [getMultipleFileUploadSchemaObject()],
80
- model: {},
81
- errors: {},
82
- };
83
- const onEvent = vi.fn();
84
- const getProps = (overrides = {}) => (Object.assign({ flowId: 'multiple-file-upload-schema-test-flow-id', initialStep, httpClient: mockHttpClient, onCompletion: vi.fn(), onError: vi.fn(), onEvent, onLog: vi.fn() }, overrides));
85
- // We have some duplicate key warnings because we're mocking the random id generator
86
- // But I want to keep this file as close to the original as possible, so I'm not going to fix it
87
- const originalError = console.error;
88
- beforeEach(() => {
89
- mockHttpClient.mockResolvedValue({
90
- ok: true,
91
- status: 200,
92
- json: vi.fn().mockResolvedValue({ [idProperty]: 'mockFileId' }),
93
- });
94
- console.error = vi.fn();
95
- });
96
- afterEach(() => {
97
- vi.clearAllMocks();
98
- onEvent.mockClear();
99
- console.error = originalError;
100
- });
101
- describe('and the schema has an $id prop', () => {
102
- // We use the inner id now (and it doesn't really matter anyway)
103
- it.skip('should be the $id given to the input component', () => {
104
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps())));
105
- expect(screen.getByLabelText('upload schema title')).toBeInTheDocument();
106
- expect(screen.getByLabelText('upload schema title')).toHaveAttribute('id', 'upload-id');
107
- });
108
- });
109
- describe('and the schema has no $id prop', () => {
110
- it.skip('should be a generated id given to the input component', () => {
111
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps({
112
- initialStep: Object.assign(Object.assign({}, initialStep), { schemas: [getMultipleFileUploadSchemaObjectWithoutId()] }),
113
- }))));
114
- expect(screen.getByLabelText('upload schema title')).toBeInTheDocument();
115
- expect(screen.getByLabelText('upload schema title')).toHaveAttribute('id', 'DUMMY_GENERATED_UNIQUE_ID');
116
- });
117
- });
118
- it('should render the file input', () => {
119
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps())));
120
- expect(screen.getByLabelText('upload schema title')).toHaveAttribute('type', 'file');
121
- });
122
- describe('when upload successful', () => {
123
- it('the files should show as uploaded', async () => {
124
- const props = getProps();
125
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
126
- onEvent.mockClear();
127
- await user.upload(screen.getByLabelText('upload schema title'), testFile);
128
- await waitFor(() => expect(onEvent).toHaveBeenCalledTimes(2));
129
- // Modification (we've changed the events):
130
- expect(onEvent).toHaveBeenCalledWith('Dynamic Flow - PersistAsync Triggered', expect.objectContaining({
131
- flowId: 'multiple-file-upload-schema-test-flow-id',
132
- stepId: 'multiple-file-upload-schema-test-step-id',
133
- schema: 'upload-id',
134
- }));
135
- expect(onEvent).toHaveBeenCalledWith('Dynamic Flow - PersistAsync Succeeded', expect.objectContaining({
136
- flowId: 'multiple-file-upload-schema-test-flow-id',
137
- stepId: 'multiple-file-upload-schema-test-step-id',
138
- schema: 'upload-id',
139
- }));
140
- // Original:
141
- // expect(onEvent).toHaveBeenCalledWith(
142
- // 'Dynamic Flow - PersistAsync',
143
- // expect.objectContaining({ status: 'pending' }),
144
- // );
145
- // expect(onEvent).toHaveBeenCalledWith(
146
- // 'Dynamic Flow - PersistAsync',
147
- // expect.objectContaining({ status: 'success' }),
148
- // );
149
- expect(screen.getByText('test-file.pdf')).toBeInTheDocument();
150
- expect(screen.getByText('Uploaded')).toBeInTheDocument();
151
- });
152
- it('the file IDs should be in the payload on submission', async () => {
153
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps())));
154
- onEvent.mockClear();
155
- await user.upload(screen.getByLabelText('upload schema title'), testFile);
156
- await waitFor(() => expect(onEvent).toHaveBeenCalledTimes(2));
157
- await user.click(screen.getByText('Submit'));
158
- await waitFor(() => expect(mockHttpClient).toHaveBeenCalledWith('/submit', expect.objectContaining({ body: JSON.stringify({ files: ['mockFileId'] }) })));
159
- });
160
- });
161
- describe('when upload fails', () => {
162
- it('shows error message to the user', async () => {
163
- const errorMessage = 'Error uploading';
164
- mockHttpClient.mockResolvedValueOnce({
165
- ok: false,
166
- status: 401,
167
- json: vi.fn().mockResolvedValue({ validation: { [param]: errorMessage } }),
168
- });
169
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps())));
170
- onEvent.mockClear();
171
- await user.upload(screen.getByLabelText('upload schema title'), testFile);
172
- await waitFor(() => expect(onEvent).toHaveBeenCalledTimes(2));
173
- // Modification (we've changed the events):
174
- expect(onEvent).toHaveBeenCalledWith('Dynamic Flow - PersistAsync Triggered', expect.objectContaining({
175
- flowId: 'multiple-file-upload-schema-test-flow-id',
176
- stepId: 'multiple-file-upload-schema-test-step-id',
177
- schema: 'upload-id',
178
- }));
179
- expect(onEvent).toHaveBeenCalledWith('Dynamic Flow - PersistAsync Failed', expect.objectContaining({
180
- flowId: 'multiple-file-upload-schema-test-flow-id',
181
- stepId: 'multiple-file-upload-schema-test-step-id',
182
- schema: 'upload-id',
183
- }));
184
- // Original
185
- // expect(onEvent).toHaveBeenCalledWith(
186
- // 'Dynamic Flow - PersistAsync',
187
- // expect.objectContaining({ status: 'pending' }),
188
- // );
189
- // expect(onEvent).toHaveBeenCalledWith(
190
- // 'Dynamic Flow - PersistAsync',
191
- // expect.objectContaining({ status: 'failure' }),
192
- // );
193
- expect(screen.getByText('test-file.pdf')).toBeInTheDocument();
194
- expect(screen.getByText('Error uploading')).toBeInTheDocument();
195
- });
196
- it('model is NOT updated', async () => {
197
- const errorMessage = 'Error uploading';
198
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps())));
199
- onEvent.mockClear();
200
- await user.upload(screen.getByLabelText('upload schema title'), testFile);
201
- mockHttpClient.mockResolvedValueOnce({
202
- ok: false,
203
- status: 401,
204
- json: vi.fn().mockResolvedValue({ validation: { [param]: errorMessage } }),
205
- });
206
- await user.upload(screen.getByLabelText('upload schema title'), new File([], 'test-file2.pdf', { type: 'application/pdf' }));
207
- await waitFor(() => expect(onEvent).toHaveBeenCalledTimes(4));
208
- await user.click(screen.getByText('Submit'));
209
- // only valid file is added to model
210
- await waitFor(() => expect(mockHttpClient).toHaveBeenCalledWith('/submit', expect.objectContaining({ body: JSON.stringify({ files: ['mockFileId'] }) })));
211
- });
212
- });
213
- describe('when uploading fewer files than required', () => {
214
- it('should show default min items error when submitted with no. of files less than expected if no custom validation message is given', async () => {
215
- const props = getProps({
216
- initialStep: {
217
- id: 'multiple-file-upload-schema-test-step-id',
218
- title: 'OneOf Schema Step Title',
219
- layout: [
220
- { type: 'form', schemaId: '#schema' },
221
- {
222
- type: 'button',
223
- title: 'Submit',
224
- action: { url: '/submit', method: 'POST' },
225
- },
226
- ],
227
- schemas: [
228
- getMultipleFileUploadSchemaObject(getArraySchema({ minItems: 2, maxItems: 2 })),
229
- ],
230
- model: {},
231
- errors: {},
232
- },
233
- });
234
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
235
- await user.upload(screen.getByLabelText('upload schema title'), testFile);
236
- await user.click(screen.getByText('Submit'));
237
- await waitFor(() => {
238
- expect(screen.getByText('Please upload at least 2 file(s).')).toBeInTheDocument();
239
- });
240
- });
241
- it('should show min items error from schema, when submitted with no. of files less than expected', async () => {
242
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps({
243
- initialStep: Object.assign(Object.assign({}, initialStep), { schemas: [getMultipleFileUploadSchemaObjectWithoutId()] }),
244
- }))));
245
- await user.upload(screen.getByLabelText('upload schema title'), testFile);
246
- await user.click(screen.getByText('Submit'));
247
- expect(screen.getByText('minimum items not met error (from schema)')).toBeInTheDocument();
248
- });
249
- });
250
- // Currently Neptune's UploadInput handles all the max upload errors on drag-drop, bulk upload cases.
251
- describe('when trying to upload more files than are allowed', () => {
252
- it('should show the maximum allowed number of file uploads', async () => {
253
- let it = 0;
254
- const httpClient = vi.fn().mockImplementation(() => ({
255
- ok: true,
256
- status: 200,
257
- // eslint-disable-next-line no-plusplus
258
- json: vi.fn().mockResolvedValue({ [idProperty]: `mockFileId${it++}` }),
259
- }));
260
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps({
261
- initialStep: Object.assign(Object.assign({}, initialStep), { schemas: [getMultipleFileUploadSchemaObjectWithoutId()] }),
262
- httpClient,
263
- }))));
264
- onEvent.mockClear();
265
- // upload 4 items
266
- await user.upload(screen.getByLabelText('upload schema title'), new File([], 'test-file1.pdf', { type: 'application/pdf' }));
267
- await waitFor(() => {
268
- expect(screen.getAllByText('Uploaded')).toHaveLength(1);
269
- });
270
- await user.upload(screen.getByLabelText('upload schema title'), new File([], 'test-file2.pdf', { type: 'application/pdf' }));
271
- await waitFor(() => {
272
- expect(screen.getAllByText('Uploaded')).toHaveLength(2);
273
- });
274
- await user.upload(screen.getByLabelText('upload schema title'), new File([], 'test-file3.pdf', { type: 'application/pdf' }));
275
- await waitFor(() => {
276
- expect(screen.getAllByText('Uploaded')).toHaveLength(3);
277
- });
278
- await user.upload(screen.getByLabelText('upload schema title'), new File([], 'test-file4.pdf', { type: 'application/pdf' }));
279
- // only 3 shown
280
- await expect(waitFor(async () => screen.findAllByText('Uploaded'))).resolves.toHaveLength(3);
281
- await user.click(screen.getByText('Submit'));
282
- await waitFor(() => expect(httpClient).toHaveBeenCalledWith('/submit', expect.objectContaining({
283
- body: JSON.stringify({ files: ['mockFileId0', 'mockFileId1', 'mockFileId2'] }),
284
- })));
285
- });
286
- });
287
- });
288
- describe('Given a multiple file upload schema without persist-async', () => {
289
- const initialStep = {
290
- id: 'multiple-file-upload-schema-test-step-id',
291
- title: 'OneOf Schema Step Title',
292
- layout: [
293
- { type: 'form', schemaId: '#schema' },
294
- {
295
- type: 'button',
296
- title: 'Refresh',
297
- behavior: { type: 'refresh' },
298
- },
299
- ],
300
- refreshUrl: '/refresh',
301
- schemas: [
302
- {
303
- type: 'object',
304
- $id: '#schema',
305
- displayOrder: ['files'],
306
- required: ['files'],
307
- title: 'upload schema title',
308
- properties: {
309
- files: {
310
- $id: 'upload-id',
311
- type: 'array',
312
- title: 'upload schema title',
313
- minItems: 1,
314
- maxItems: 2,
315
- addItemTitle: '',
316
- editItemTitle: '',
317
- items: {
318
- type: 'string',
319
- $id: 'upload-id',
320
- format: 'base64url',
321
- title: uploadTitle,
322
- description,
323
- maxSize,
324
- accepts,
325
- validationMessages: {
326
- maxSize: 'Your file is too large',
327
- },
328
- },
329
- },
330
- },
331
- },
332
- ],
333
- model: {},
334
- errors: {},
335
- };
336
- const getProps = (overrides = {}) => (Object.assign({ flowId: 'multiple-file-upload-schema-test-flow-id', initialStep, httpClient: vi.fn(), onCompletion: vi.fn(), onError: vi.fn(), onEvent: vi.fn(), onLog: vi.fn() }, overrides));
337
- it('should contain the base64uri of the selected files in the payload for a refresh request', async () => {
338
- const props = getProps();
339
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
340
- // first upload 2 files
341
- await user.upload(screen.getByLabelText('upload schema title'), new File([], 'mockFile0.pdf', { type: 'application/pdf' }));
342
- await user.upload(screen.getByLabelText('upload schema title'), new File([], 'mockFile1.pdf', { type: 'application/pdf' }));
343
- await user.click(screen.getByText('Refresh'));
344
- await waitFor(() => expect(props.httpClient).toHaveBeenCalledWith('/refresh', expect.objectContaining({
345
- body: JSON.stringify({
346
- files: ['data:application/pdf;base64,', 'data:application/pdf;base64,'],
347
- }),
348
- })));
349
- });
350
- });
@@ -1,224 +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({ applyAccept: false });
8
- // This file is a copy of the E2E test in legacy. It should remain as unchanged
9
- // as possible, to ensure the new client functionality matches the old one.
10
- describe('PersistAsync with blob schema', () => {
11
- const schema = {
12
- $id: '#schema',
13
- type: 'object',
14
- title: 'File Upload',
15
- displayOrder: ['file'],
16
- properties: {
17
- file: {
18
- $id: '#file-upload-schema',
19
- type: 'integer',
20
- title: 'File Upload',
21
- description: 'Upload a JPG or PNG file (max 150kb)',
22
- persistAsync: {
23
- method: 'POST',
24
- url: '/upload-file-url',
25
- param: 'file',
26
- idProperty: 'token',
27
- schema: {
28
- $id: '#persist-async-schema',
29
- type: 'blob',
30
- maxSize: 150000,
31
- accepts: ['image/png', 'image/jpg'],
32
- },
33
- },
34
- },
35
- },
36
- };
37
- const model = {};
38
- const initialStep = {
39
- id: 'persist-async-blob-step-id',
40
- title: 'Persist Async Blob Test',
41
- layout: [
42
- { type: 'form', schemaId: '#schema' },
43
- {
44
- type: 'button',
45
- title: 'Submit',
46
- action: { url: '/submit', method: 'POST' },
47
- },
48
- ],
49
- schemas: [schema],
50
- model,
51
- };
52
- const getProps = (overrides = {}) => (Object.assign({ flowId: 'flow-id', initialStep, httpClient: vi.fn(), onCompletion: vi.fn(), onError: vi.fn(), onEvent: vi.fn(), onLog: vi.fn() }, overrides));
53
- describe('when initialised', () => {
54
- it('renders a file upload control', () => {
55
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps())));
56
- const input = screen.getByTestId('uploadInput');
57
- expect(input).toBeInTheDocument();
58
- expect(input.tagName).toBe('INPUT');
59
- expect(input).toHaveAttribute('type', 'file');
60
- });
61
- describe('when the schema has an $id property', () => {
62
- // We don't care about this - we're only going to use the inner ID
63
- it.skip('renders the UploadInput with an id prop based on the schema $id', () => {
64
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, getProps())));
65
- expect(screen.getByTestId('uploadInput')).toHaveAttribute('id', '#file-upload-schema');
66
- });
67
- });
68
- describe('when the main schema has no $id, but the persist async schema has an $id property', () => {
69
- it('renders the UploadInput with an id prop based on the persist async schema $id', () => {
70
- const schemaWithNoId = {
71
- $id: '#schema',
72
- type: 'object',
73
- title: 'File Upload',
74
- displayOrder: ['file'],
75
- properties: {
76
- file: {
77
- type: 'integer',
78
- title: 'File Upload',
79
- description: 'Upload a JPG or PNG file (max 150kb)',
80
- persistAsync: {
81
- method: 'POST',
82
- url: '/upload-file-url',
83
- param: 'file',
84
- idProperty: 'token',
85
- schema: {
86
- $id: '#persist-async-schema',
87
- type: 'blob',
88
- maxSize: 150000,
89
- accepts: ['image/png', 'image/jpg'],
90
- },
91
- },
92
- },
93
- },
94
- };
95
- const props = getProps({ initialStep: Object.assign(Object.assign({}, initialStep), { schemas: [schemaWithNoId] }) });
96
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
97
- expect(screen.getByTestId('uploadInput')).toHaveAttribute('id', '#persist-async-schema');
98
- });
99
- });
100
- describe('when none of the schemas have an $id', () => {
101
- // This is strange behaviour which we're not going to replicate
102
- it.skip('renders the UploadInput with an id prop based on the idProperty', () => {
103
- const schemaWithNoId = {
104
- $id: '#schema',
105
- type: 'object',
106
- title: 'File Upload',
107
- displayOrder: ['file'],
108
- properties: {
109
- file: {
110
- type: 'integer',
111
- title: 'File Upload',
112
- description: 'Upload a JPG or PNG file (max 150kb)',
113
- persistAsync: {
114
- method: 'POST',
115
- url: '/upload-file-url',
116
- param: 'file',
117
- idProperty: 'token',
118
- schema: {
119
- type: 'blob',
120
- maxSize: 150000,
121
- accepts: ['image/png', 'image/jpg'],
122
- },
123
- },
124
- },
125
- },
126
- };
127
- const props = getProps({ initialStep: Object.assign(Object.assign({}, initialStep), { schemas: [schemaWithNoId] }) });
128
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
129
- expect(screen.getByTestId('uploadInput')).toHaveAttribute('id', 'token');
130
- });
131
- });
132
- });
133
- describe('when a file is selected', () => {
134
- it('calls the httpClient to upload the file with a FormData body containing the file', async () => {
135
- var _a, _b;
136
- const httpClient = vi.fn(async () => Promise.resolve(new Response(JSON.stringify({ token: 123 }))));
137
- const props = getProps({ httpClient });
138
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
139
- const file = new File(['foo'], 'foo.png', { type: 'image/png' });
140
- await user.upload(screen.getByTestId('uploadInput'), file);
141
- await waitFor(() => expect(httpClient).toHaveBeenCalledTimes(1));
142
- // Modification (call now has headers and signal):
143
- expect(httpClient).toHaveBeenCalledWith('/upload-file-url', expect.objectContaining({ method: 'POST', body: expect.any(FormData) }));
144
- // Original:
145
- // expect(httpClient).toHaveBeenCalledWith('/upload-file-url', {
146
- // method: 'POST',
147
- // body: expect.any(FormData) as FormData,
148
- // });
149
- const formData = (_b = (_a = httpClient.mock.calls[0]) === null || _a === void 0 ? void 0 : _a[1]) === null || _b === void 0 ? void 0 : _b.body;
150
- expect(formData.get('file')).toBe(file);
151
- });
152
- describe('when the file is too large', () => {
153
- it('does not call the httpClient and displays an error message', async () => {
154
- const httpClient = vi.fn();
155
- const props = getProps({ httpClient });
156
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
157
- const file = new File(['foo'], 'foo.png', { type: 'image/png' });
158
- // eslint-disable-next-line functional/immutable-data
159
- Object.defineProperty(file, 'size', { value: 150001 });
160
- await user.upload(screen.getByTestId('uploadInput'), file);
161
- await waitFor(() => {
162
- expect(screen.getByText('File is too large')).toBeInTheDocument();
163
- });
164
- expect(httpClient).not.toHaveBeenCalled();
165
- });
166
- });
167
- describe('when the file is not of the correct type', () => {
168
- it('does not call the httpClient and displays an error message', async () => {
169
- const httpClient = vi.fn();
170
- const props = getProps({ httpClient });
171
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
172
- const file = new File(['foo'], 'foo.gif', { type: 'image/gif' });
173
- await user.upload(screen.getByTestId('uploadInput'), file);
174
- await waitFor(() => {
175
- expect(screen.getByText('File type not supported')).toBeInTheDocument();
176
- });
177
- expect(httpClient).not.toHaveBeenCalled();
178
- });
179
- });
180
- describe('when a file is successfully uploaded', () => {
181
- it('displays the file name on screen with the "Uploaded" tag', async () => {
182
- const httpClient = vi.fn(async () => Promise.resolve(new Response(JSON.stringify({ token: 123 }))));
183
- const props = getProps({ httpClient });
184
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
185
- await user.upload(screen.getByTestId('uploadInput'), new File(['foo'], 'foo.png', { type: 'image/png' }));
186
- await waitFor(() => {
187
- expect(screen.getByText('Uploaded')).toBeInTheDocument();
188
- });
189
- expect(screen.getByText('foo.png')).toBeInTheDocument();
190
- });
191
- });
192
- describe('when a file fails to upload', () => {
193
- describe('when there is a general failure', () => {
194
- it('displays an error message', async () => {
195
- const httpClient = vi.fn(async () => Promise.resolve(new Response(null, { status: 500 })));
196
- const props = getProps({ httpClient });
197
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
198
- await user.upload(screen.getByTestId('uploadInput'), new File(['foo'], 'foo.png', { type: 'image/png' }));
199
- // Modification (we now use our general error message, not Neptune's):
200
- await waitFor(() => {
201
- expect(screen.getByText('Something went wrong.')).toBeInTheDocument();
202
- });
203
- // Original:
204
- // await waitFor(() => {
205
- // expect(screen.getByText('Uploading failed')).toBeInTheDocument();
206
- // });
207
- });
208
- });
209
- describe('when there is a validation error', () => {
210
- it('displays the validation error message provided in the response', async () => {
211
- const httpClient = vi.fn(async () => Promise.resolve(new Response(JSON.stringify({
212
- validation: { file: 'The server overlords dislike the uploaded file.' },
213
- }), { status: 401 })));
214
- const props = getProps({ httpClient });
215
- renderWithProviders(_jsx(DynamicFlowWise, Object.assign({}, props)));
216
- await user.upload(screen.getByTestId('uploadInput'), new File(['foo'], 'foo.png', { type: 'image/png' }));
217
- await waitFor(() => {
218
- expect(screen.getByText('The server overlords dislike the uploaded file.')).toBeInTheDocument();
219
- });
220
- });
221
- });
222
- });
223
- });
224
- });