@wise/dynamic-flow-client 5.9.1 → 5.9.2-exp-ext-renderer-5899c9c

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