@wise/dynamic-flow-client 5.12.1 → 5.13.0

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