@wise/dynamic-flow-client 5.13.2 → 5.13.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (409) hide show
  1. package/build/main.css +24 -15
  2. package/build/tsconfig.types.tsbuildinfo +1 -1
  3. package/build/types/stories/utils/render-utils.d.ts.map +1 -1
  4. package/package.json +16 -16
  5. package/build/DynamicFlowCore.js +0 -5
  6. package/build/common/errorBoundary/ErrorBoundary.js +0 -26
  7. package/build/common/errorBoundary/ErrorBoundary.test.js +0 -29
  8. package/build/common/errorBoundary/ErrorBoundaryAlert.js +0 -11
  9. package/build/common/makeHttpClient/api-utils.js +0 -3
  10. package/build/common/makeHttpClient/index.js +0 -1
  11. package/build/common/makeHttpClient/makeHttpClient.js +0 -10
  12. package/build/common/makeHttpClient/makeHttpClient.test.js +0 -186
  13. package/build/common/messages/external-confirmation.messages.js +0 -23
  14. package/build/common/messages/file-upload.messages.js +0 -13
  15. package/build/common/messages/generic-error.messages.js +0 -18
  16. package/build/common/messages/help.messages.js +0 -8
  17. package/build/common/messages/multi-file-upload.messages.js +0 -18
  18. package/build/common/messages/multi-select.messages.js +0 -8
  19. package/build/common/messages/paragraph.messages.js +0 -13
  20. package/build/common/messages/repeatable.messages.js +0 -23
  21. package/build/common/messages/search.messages.js +0 -8
  22. package/build/common/messages/validation.array.messages.js +0 -13
  23. package/build/common/messages/validation.messages.js +0 -53
  24. package/build/controller/FlowController.js +0 -378
  25. package/build/controller/executePoll.js +0 -64
  26. package/build/controller/executeRefresh.js +0 -45
  27. package/build/controller/executeRequest.js +0 -80
  28. package/build/controller/executeSubmission.js +0 -70
  29. package/build/controller/getErrorMessage.js +0 -7
  30. package/build/controller/getRequestAbortController.js +0 -13
  31. package/build/controller/getResponseType.js +0 -35
  32. package/build/controller/getSafeHttpClient.js +0 -8
  33. package/build/controller/getStepCounter.js +0 -16
  34. package/build/controller/handleErrorResponse.js +0 -26
  35. package/build/controller/makeSafeHttpClient.js +0 -8
  36. package/build/controller/response-utils.js +0 -72
  37. package/build/controller/response-utils.test.js +0 -52
  38. package/build/domain/components/AlertComponent.js +0 -1
  39. package/build/domain/components/AllOfComponent.js +0 -40
  40. package/build/domain/components/BooleanInputComponent.js +0 -50
  41. package/build/domain/components/BoxComponent.js +0 -3
  42. package/build/domain/components/ButtonComponent.js +0 -1
  43. package/build/domain/components/ColumnsComponent.js +0 -3
  44. package/build/domain/components/ConstComponent.js +0 -18
  45. package/build/domain/components/ContainerComponent.js +0 -3
  46. package/build/domain/components/DateInputComponent.js +0 -75
  47. package/build/domain/components/DecisionComponent.js +0 -1
  48. package/build/domain/components/DividerComponent.js +0 -1
  49. package/build/domain/components/FormComponent.js +0 -3
  50. package/build/domain/components/FormattedValueComponent.js +0 -44
  51. package/build/domain/components/HeadingComponent.js +0 -1
  52. package/build/domain/components/ImageComponent.js +0 -1
  53. package/build/domain/components/InstructionsComponent.js +0 -1
  54. package/build/domain/components/IntegerInputComponent.js +0 -74
  55. package/build/domain/components/ListComponent.js +0 -1
  56. package/build/domain/components/LoadingIndicatorComponent.js +0 -1
  57. package/build/domain/components/MarkdownComponent.js +0 -1
  58. package/build/domain/components/MediaComponent.js +0 -1
  59. package/build/domain/components/ModalComponent.js +0 -16
  60. package/build/domain/components/ModalLayoutComponent.js +0 -3
  61. package/build/domain/components/MoneyInputComponent.js +0 -57
  62. package/build/domain/components/MultiSelectInputComponent.js +0 -81
  63. package/build/domain/components/MultiUploadInputComponent.js +0 -88
  64. package/build/domain/components/NumberInputComponent.js +0 -73
  65. package/build/domain/components/ObjectComponent.js +0 -45
  66. package/build/domain/components/ParagraphComponent.js +0 -1
  67. package/build/domain/components/PersistAsyncComponent.js +0 -92
  68. package/build/domain/components/ProgressComponent.js +0 -1
  69. package/build/domain/components/RepeatableComponent.js +0 -103
  70. package/build/domain/components/ReviewComponent.js +0 -1
  71. package/build/domain/components/RootDomainComponent.js +0 -173
  72. package/build/domain/components/SectionComponent.js +0 -5
  73. package/build/domain/components/SelectInputComponent.js +0 -88
  74. package/build/domain/components/StatusListComponent.js +0 -1
  75. package/build/domain/components/SubflowDomainComponent.js +0 -9
  76. package/build/domain/components/TabsComponent.js +0 -1
  77. package/build/domain/components/TextInputComponent.js +0 -76
  78. package/build/domain/components/TupleComponent.js +0 -41
  79. package/build/domain/components/UploadInputComponent.js +0 -83
  80. package/build/domain/components/UpsellComponent.js +0 -25
  81. package/build/domain/components/searchComponent/SearchComponent.js +0 -92
  82. package/build/domain/components/searchComponent/SearchComponent.test.js +0 -190
  83. package/build/domain/components/step/ExternalConfirmationComponent.js +0 -24
  84. package/build/domain/components/step/StepDomainComponent.js +0 -78
  85. package/build/domain/components/step/ToolbarComponent.js +0 -1
  86. package/build/domain/components/utils/WithUpdate.js +0 -1
  87. package/build/domain/components/utils/component-utils.js +0 -12
  88. package/build/domain/components/utils/debounce.js +0 -34
  89. package/build/domain/components/utils/debounce.test.js +0 -67
  90. package/build/domain/components/utils/file-utils.js +0 -21
  91. package/build/domain/components/utils/file-utils.test.js +0 -27
  92. package/build/domain/components/utils/getRandomId.js +0 -1
  93. package/build/domain/components/utils/isExactLocalValueMatch.js +0 -14
  94. package/build/domain/components/utils/isOrWasValid.js +0 -5
  95. package/build/domain/components/utils/isPartialModelMatch.js +0 -18
  96. package/build/domain/components/utils/isPartialModelMatch.test.js +0 -74
  97. package/build/domain/features/eventNames.js +0 -24
  98. package/build/domain/features/events.js +0 -1
  99. package/build/domain/features/persistAsync/getComponentMultiPersistAsync.js +0 -50
  100. package/build/domain/features/persistAsync/getInitialPersistedState.js +0 -7
  101. package/build/domain/features/persistAsync/getPerformPersistAsync.js +0 -43
  102. package/build/domain/features/persistAsync/getPerformPersistAsync.test.js +0 -139
  103. package/build/domain/features/polling/getStepPolling.js +0 -50
  104. package/build/domain/features/polling/getStepPolling.test.js +0 -115
  105. package/build/domain/features/prefetch/getStepPrefetch.js +0 -43
  106. package/build/domain/features/prefetch/request-cache.js +0 -49
  107. package/build/domain/features/prefetch/request-cache.test.js +0 -70
  108. package/build/domain/features/refreshAfter/getStepRefreshAfter.js +0 -24
  109. package/build/domain/features/refreshAfter/getStepRefreshAfter.test.js +0 -40
  110. package/build/domain/features/schema-on-change/getDebouncedSchemaOnChange.js +0 -50
  111. package/build/domain/features/schema-on-change/getSchemaOnChange.js +0 -34
  112. package/build/domain/features/search/getPerformSearchFunction.js +0 -75
  113. package/build/domain/features/search/getPerformSearchFunction.test.js +0 -301
  114. package/build/domain/features/summary/summary-utils.js +0 -40
  115. package/build/domain/features/summary/summary-utils.test.js +0 -125
  116. package/build/domain/features/utils/http-utils.js +0 -21
  117. package/build/domain/features/utils/response-utils.js +0 -9
  118. package/build/domain/features/validation/spec-utils.js +0 -19
  119. package/build/domain/features/validation/validateStringPattern.js +0 -24
  120. package/build/domain/features/validation/validation-functions.js +0 -6
  121. package/build/domain/features/validation/validation-functions.test.js +0 -108
  122. package/build/domain/features/validation/value-checks.js +0 -125
  123. package/build/domain/features/validation/value-checks.test.js +0 -262
  124. package/build/domain/features/validationAsync/getComponentValidationAsync.js +0 -53
  125. package/build/domain/features/validationAsync/getComponentValidationAsync.test.js +0 -67
  126. package/build/domain/features/validationAsync/getInitialValidationAsyncState.js +0 -5
  127. package/build/domain/features/validationAsync/getPerformValidationAsync.js +0 -45
  128. package/build/domain/features/validationAsync/getPerformValidationAsync.test.js +0 -143
  129. package/build/domain/mappers/layout/alertLayoutToComponent.js +0 -16
  130. package/build/domain/mappers/layout/boxLayoutToComponent.js +0 -13
  131. package/build/domain/mappers/layout/buttonLayoutToComponent.js +0 -77
  132. package/build/domain/mappers/layout/columnsLayoutToComponent.js +0 -13
  133. package/build/domain/mappers/layout/decisionLayoutToComponent.js +0 -22
  134. package/build/domain/mappers/layout/deprecatedListLayoutToComponent.js +0 -30
  135. package/build/domain/mappers/layout/dividerLayoutToComponent.js +0 -2
  136. package/build/domain/mappers/layout/formLayoutToComponent.js +0 -19
  137. package/build/domain/mappers/layout/headingLayoutToComponent.js +0 -12
  138. package/build/domain/mappers/layout/imageLayoutToComponent.js +0 -20
  139. package/build/domain/mappers/layout/infoLayoutToComponent.js +0 -12
  140. package/build/domain/mappers/layout/instructionsLayoutToComponent.js +0 -12
  141. package/build/domain/mappers/layout/listLayoutToComponent.js +0 -39
  142. package/build/domain/mappers/layout/loadingIndicatorLayoutToComponent.js +0 -9
  143. package/build/domain/mappers/layout/markdownLayoutToComponent.js +0 -12
  144. package/build/domain/mappers/layout/mediaLayoutToComponent.js +0 -12
  145. package/build/domain/mappers/layout/modalLayoutToComponent.js +0 -17
  146. package/build/domain/mappers/layout/modalToComponent.js +0 -8
  147. package/build/domain/mappers/layout/paragraphLayoutToComponent.js +0 -12
  148. package/build/domain/mappers/layout/progressLayoutToComponent.js +0 -15
  149. package/build/domain/mappers/layout/reviewLayoutToComponent.js +0 -48
  150. package/build/domain/mappers/layout/searchLayoutToComponent.js +0 -44
  151. package/build/domain/mappers/layout/sectionLayoutToComponent.js +0 -15
  152. package/build/domain/mappers/layout/statusListLayoutToComponent.js +0 -15
  153. package/build/domain/mappers/layout/tabsLayoutToComponent.js +0 -16
  154. package/build/domain/mappers/layout/upsellLayoutToComponent.js +0 -25
  155. package/build/domain/mappers/mapLayoutToComponent.js +0 -81
  156. package/build/domain/mappers/mapSchemaToComponent.js +0 -61
  157. package/build/domain/mappers/mapSchemaToComponent.test.js +0 -112
  158. package/build/domain/mappers/mapStepSchemas.js +0 -15
  159. package/build/domain/mappers/mapStepToComponent.js +0 -133
  160. package/build/domain/mappers/mapStepToComponent.test.js +0 -221
  161. package/build/domain/mappers/mapToolbarToComponent.js +0 -15
  162. package/build/domain/mappers/schema/allOfSchemaToComponent.js +0 -16
  163. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToComponent.js +0 -26
  164. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiSelectComponent.js +0 -55
  165. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiUploadComponent.js +0 -67
  166. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToRepeatableComponent.js +0 -57
  167. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToTupleComponent.js +0 -20
  168. package/build/domain/mappers/schema/blobSchemaToComponent.js +0 -15
  169. package/build/domain/mappers/schema/booleanSchemaToComponent.js +0 -29
  170. package/build/domain/mappers/schema/constSchemaToComponent.js +0 -23
  171. package/build/domain/mappers/schema/integerSchemaToComponent.js +0 -28
  172. package/build/domain/mappers/schema/numberSchemaToComponent.js +0 -26
  173. package/build/domain/mappers/schema/objectSchemaToComponent/assertDisplayOrder.js +0 -23
  174. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToFormattedValueComponent.js +0 -9
  175. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.js +0 -119
  176. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.test.js +0 -96
  177. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.js +0 -31
  178. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.test.js +0 -99
  179. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.js +0 -66
  180. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.test.js +0 -225
  181. package/build/domain/mappers/schema/persistAsyncSchemaToComponent.js +0 -29
  182. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.js +0 -18
  183. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.test.js +0 -133
  184. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToDateInputComponent.js +0 -48
  185. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToTextInputComponent.js +0 -38
  186. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToUploadInputComponent.js +0 -28
  187. package/build/domain/mappers/schema/tests/test-utils.js +0 -16
  188. package/build/domain/mappers/schema/types.js +0 -1
  189. package/build/domain/mappers/schema/utils/getPerformPersistAsyncFn.js +0 -19
  190. package/build/domain/mappers/schema/utils/getValidationAsyncInitialState.js +0 -23
  191. package/build/domain/mappers/schema/utils/mapCommonSchemaProps.js +0 -16
  192. package/build/domain/mappers/types.js +0 -1
  193. package/build/domain/mappers/utils/FeatureFlags.js +0 -22
  194. package/build/domain/mappers/utils/behavior-utils.js +0 -44
  195. package/build/domain/mappers/utils/call-to-action-utils.js +0 -21
  196. package/build/domain/mappers/utils/getAutocompleteString.js +0 -76
  197. package/build/domain/mappers/utils/getAutocompleteString.test.js +0 -21
  198. package/build/domain/mappers/utils/groupLayoutByPinned.js +0 -38
  199. package/build/domain/mappers/utils/groupLayoutByPinned.test.js +0 -166
  200. package/build/domain/mappers/utils/image.js +0 -9
  201. package/build/domain/mappers/utils/layout-utils.js +0 -11
  202. package/build/domain/mappers/utils/legacy-utils.js +0 -49
  203. package/build/domain/mappers/utils/media-utils.js +0 -14
  204. package/build/domain/mappers/utils/suggestions-utils.js +0 -26
  205. package/build/domain/mappers/utils/suggestions-utils.test.js +0 -36
  206. package/build/domain/mappers/utils/tags-utils.js +0 -1
  207. package/build/domain/mappers/utils/utils.js +0 -35
  208. package/build/domain/types.js +0 -1
  209. package/build/getSubflowCallbacks.js +0 -38
  210. package/build/i18n/index.js +0 -40
  211. package/build/index.js +0 -8
  212. package/build/renderers/CoreContainerRenderer.js +0 -5
  213. package/build/renderers/CoreRootRenderer.js +0 -12
  214. package/build/renderers/EmptyLoadingStateRenderer.js +0 -5
  215. package/build/renderers/getRenderFunction.js +0 -24
  216. package/build/renderers/getSchemaErrorMessageFunction.js +0 -97
  217. package/build/renderers/mappers/alertComponentToProps.js +0 -2
  218. package/build/renderers/mappers/allOfComponentToProps.js +0 -6
  219. package/build/renderers/mappers/booleanInputComponentToProps.js +0 -5
  220. package/build/renderers/mappers/boxComponentToProps.js +0 -13
  221. package/build/renderers/mappers/buttonComponentToProps.js +0 -4
  222. package/build/renderers/mappers/columnsComponentToProps.js +0 -11
  223. package/build/renderers/mappers/componentToRendererProps.js +0 -164
  224. package/build/renderers/mappers/constComponentToProps.js +0 -5
  225. package/build/renderers/mappers/containerComponentToProps.js +0 -7
  226. package/build/renderers/mappers/dateInputComponentToProps.js +0 -2
  227. package/build/renderers/mappers/decisionComponentToProps.js +0 -16
  228. package/build/renderers/mappers/dividerComponentToProps.js +0 -2
  229. package/build/renderers/mappers/externalComponentToProps.js +0 -3
  230. package/build/renderers/mappers/formComponentToProps.js +0 -12
  231. package/build/renderers/mappers/formattedValueComponentToProps.js +0 -5
  232. package/build/renderers/mappers/headingComponentToProps.js +0 -2
  233. package/build/renderers/mappers/hiddenComponentToProps.js +0 -4
  234. package/build/renderers/mappers/imageComponentToProps.js +0 -2
  235. package/build/renderers/mappers/instructionsComponentToProps.js +0 -2
  236. package/build/renderers/mappers/integerInputComponentToProps.js +0 -2
  237. package/build/renderers/mappers/listComponentToProps.js +0 -2
  238. package/build/renderers/mappers/loadingIndicatorComponentToProps.js +0 -2
  239. package/build/renderers/mappers/markdownComponentToProps.js +0 -2
  240. package/build/renderers/mappers/mediaComponentToProps.js +0 -2
  241. package/build/renderers/mappers/modalComponentToProps.js +0 -11
  242. package/build/renderers/mappers/modalLayoutComponentToProps.js +0 -16
  243. package/build/renderers/mappers/moneyInputComponentToProps.js +0 -36
  244. package/build/renderers/mappers/multiSelectComponentToProps.js +0 -23
  245. package/build/renderers/mappers/multiUploadInputComponentToProps.js +0 -12
  246. package/build/renderers/mappers/numberInputComponentToProps.js +0 -2
  247. package/build/renderers/mappers/objectComponentToProps.js +0 -8
  248. package/build/renderers/mappers/paragraphComponentToProps.js +0 -2
  249. package/build/renderers/mappers/persistAsyncComponentToProps.js +0 -8
  250. package/build/renderers/mappers/progressComponentToProps.js +0 -2
  251. package/build/renderers/mappers/repeatableComponentToProps.js +0 -30
  252. package/build/renderers/mappers/reviewComponentToProps.js +0 -2
  253. package/build/renderers/mappers/rootComponentToProps.js +0 -21
  254. package/build/renderers/mappers/searchComponentToProps.js +0 -57
  255. package/build/renderers/mappers/sectionComponentToProps.js +0 -6
  256. package/build/renderers/mappers/selectInputComponentToProps.js +0 -34
  257. package/build/renderers/mappers/statusListComponentToProps.js +0 -2
  258. package/build/renderers/mappers/subflowComponentToRendererProps.js +0 -4
  259. package/build/renderers/mappers/tabsComponentToProps.js +0 -14
  260. package/build/renderers/mappers/textInputComponentToProps.js +0 -2
  261. package/build/renderers/mappers/tupleComponentToProps.js +0 -8
  262. package/build/renderers/mappers/uploadInputComponentToProps.js +0 -8
  263. package/build/renderers/mappers/upsellComponentToProps.js +0 -2
  264. package/build/renderers/mappers/utils/getValidationState.js +0 -12
  265. package/build/renderers/mappers/utils/inputComponentToProps.js +0 -26
  266. package/build/renderers/mappers/utils/mapErrorsToValidationState.js +0 -9
  267. package/build/renderers/mappers/utils/pick.js +0 -8
  268. package/build/renderers/mappers/utils/selectInputOptionsToProps.js +0 -11
  269. package/build/renderers/stepComponentToProps.js +0 -32
  270. package/build/renderers/utils.js +0 -69
  271. package/build/renderers/utils.test.js +0 -70
  272. package/build/stories/dev-tools/ContainerQueries.story.js +0 -66
  273. package/build/stories/dev-tools/Debugger.story.js +0 -38
  274. package/build/stories/dev-tools/FixtureSelect.story.js +0 -23
  275. package/build/stories/dev-tools/TestServer.story.js +0 -32
  276. package/build/stories/examples/NativeFlow.story.js +0 -80
  277. package/build/stories/examples/Recipients.story.js +0 -568
  278. package/build/stories/spec/behavior/Copy.story.js +0 -71
  279. package/build/stories/spec/behavior/Link.story.js +0 -40
  280. package/build/stories/spec/behavior/Modal.story.js +0 -79
  281. package/build/stories/spec/behavior/Subflow.story.js +0 -267
  282. package/build/stories/spec/layouts/Decision.story.js +0 -241
  283. package/build/stories/spec/layouts/Image.Illustrations.Animated.story.js +0 -37
  284. package/build/stories/spec/layouts/Image.Sizes.story.js +0 -58
  285. package/build/stories/spec/layouts/Modal.story.js +0 -81
  286. package/build/stories/spec/layouts/Search.story.js +0 -325
  287. package/build/stories/spec/layouts/Upsell.story.js +0 -55
  288. package/build/stories/spec/layouts/button/Button.story.js +0 -100
  289. package/build/stories/spec/layouts/button/PinnedButton.story.js +0 -81
  290. package/build/stories/spec/response/ActionResponse.story.js +0 -66
  291. package/build/stories/spec/schemas/MultiSelect.story.js +0 -148
  292. package/build/stories/spec/schemas/Upload.story.js +0 -168
  293. package/build/stories/spec/schemas/const/ConstLayout.story.js +0 -159
  294. package/build/stories/spec/schemas/const/ObjectConst.story.js +0 -94
  295. package/build/stories/spec/schemas/features/PersistAsync.story.js +0 -211
  296. package/build/stories/spec/schemas/features/ValidationAsync.story.js +0 -103
  297. package/build/stories/spec/schemas/object/FormattedValue.story.js +0 -92
  298. package/build/stories/spec/schemas/object/MoneyInput.story.js +0 -240
  299. package/build/stories/spec/schemas/oneOf/OneOfInitialisation.story.js +0 -55
  300. package/build/stories/spec/schemas/oneOf/OneOfWithSingleOption.story.js +0 -114
  301. package/build/stories/spec/step/Controls.story.js +0 -109
  302. package/build/stories/spec/step/DFModal.story.js +0 -58
  303. package/build/stories/spec/step/Footer.story.js +0 -70
  304. package/build/stories/spec/step/Navigation.story.js +0 -20
  305. package/build/stories/spec/step/ScrollToBottom.story.js +0 -103
  306. package/build/stories/spec/step/Tags.story.js +0 -39
  307. package/build/stories/spec/step/ToolBar.story.js +0 -60
  308. package/build/stories/spec/step/features/ErrorHandling.story.js +0 -92
  309. package/build/stories/spec/step/features/External.story.js +0 -91
  310. package/build/stories/spec/step/features/Polling.story.js +0 -108
  311. package/build/stories/spec/step/features/RefreshAfter.story.js +0 -92
  312. package/build/stories/spec/step/features/refresh/Refresh.story.js +0 -258
  313. package/build/stories/spec/step/features/refresh/RefreshWithPersistAsync.story.js +0 -958
  314. package/build/stories/types.js +0 -1
  315. package/build/stories/utils/fixtureHttpClient.js +0 -70
  316. package/build/stories/utils/getBasicStep.js +0 -223
  317. package/build/stories/utils/mockSearchHandler.js +0 -71
  318. package/build/stories/utils/render-utils.js +0 -41
  319. package/build/stories/visual-tests/layouts/NotUsingListItem.story.js +0 -17
  320. package/build/test-utils/DynamicFlowWise.js +0 -37
  321. package/build/test-utils/DynamicFlowWiseModal.js +0 -34
  322. package/build/test-utils/NeptuneProviders.js +0 -11
  323. package/build/test-utils/component-utils.js +0 -5
  324. package/build/test-utils/fetch-utils.js +0 -45
  325. package/build/test-utils/getMergedTestRenderers.js +0 -34
  326. package/build/test-utils/getRandomId.js +0 -1
  327. package/build/test-utils/index.js +0 -3
  328. package/build/test-utils/openLinkInNewTab.js +0 -15
  329. package/build/test-utils/rtl-utils.js +0 -7
  330. package/build/test-utils/step-utils.js +0 -6
  331. package/build/test-utils/wait.js +0 -3
  332. package/build/tests/AlertLayout.test.js +0 -78
  333. package/build/tests/ArrayTuple.test.js +0 -118
  334. package/build/tests/ButtonLayout.test.js +0 -308
  335. package/build/tests/ConstLayout.test.js +0 -95
  336. package/build/tests/DateInput.test.js +0 -163
  337. package/build/tests/DecisionLayout.test.js +0 -146
  338. package/build/tests/DynamicFlow.test.js +0 -147
  339. package/build/tests/External.test.js +0 -169
  340. package/build/tests/Flow.test.js +0 -328
  341. package/build/tests/FormLayout.test.js +0 -28
  342. package/build/tests/FormattedValue.test.js +0 -107
  343. package/build/tests/ImageRenderer.test.js +0 -78
  344. package/build/tests/InitialAction.test.js +0 -179
  345. package/build/tests/InitialStep.test.js +0 -168
  346. package/build/tests/InstructionsLayout.test.js +0 -45
  347. package/build/tests/ListLayout.test.js +0 -168
  348. package/build/tests/Logging.test.js +0 -53
  349. package/build/tests/ModalBehavior.test.js +0 -149
  350. package/build/tests/MoneyInput.test.js +0 -316
  351. package/build/tests/MultiUpload.test.js +0 -293
  352. package/build/tests/NativeBack.test.js +0 -267
  353. package/build/tests/NoOp.test.js +0 -194
  354. package/build/tests/OneOfInitialisation.test.js +0 -571
  355. package/build/tests/PersistAsync.test.js +0 -687
  356. package/build/tests/Polling.test.js +0 -702
  357. package/build/tests/Prefetching.test.js +0 -230
  358. package/build/tests/RefreshAfter.test.js +0 -63
  359. package/build/tests/RefreshOnChange.ResponseHandling.test.js +0 -205
  360. package/build/tests/RefreshOnChange.test.js +0 -233
  361. package/build/tests/RefreshOnChange.with.Segmented.test.js +0 -350
  362. package/build/tests/RefreshOnChange.with.Tabs.test.js +0 -358
  363. package/build/tests/RefreshOnChangePreserve.test.js +0 -224
  364. package/build/tests/RendererProps.test.js +0 -361
  365. package/build/tests/Repeatable.test.js +0 -107
  366. package/build/tests/Rerendering.test.js +0 -67
  367. package/build/tests/ReviewLayout.test.js +0 -274
  368. package/build/tests/SchemaOnChange.test.js +0 -133
  369. package/build/tests/SchemaReferences.test.js +0 -88
  370. package/build/tests/ScrollToBottom.test.js +0 -122
  371. package/build/tests/ScrollToError.test.js +0 -217
  372. package/build/tests/SegmentedControl.test.js +0 -49
  373. package/build/tests/SingleFileUpload.test.js +0 -168
  374. package/build/tests/StatusList.test.js +0 -85
  375. package/build/tests/Subflow.test.js +0 -887
  376. package/build/tests/Submission.ResponseHandling.test.js +0 -557
  377. package/build/tests/Submission.merging.test.js +0 -202
  378. package/build/tests/Submission.test.js +0 -748
  379. package/build/tests/Tags.test.js +0 -475
  380. package/build/tests/Upsell.test.js +0 -154
  381. package/build/tests/ValidationAsync.test.js +0 -295
  382. package/build/tests/legacy/Actions.test.js +0 -158
  383. package/build/tests/legacy/BackButton.test.js +0 -114
  384. package/build/tests/legacy/HiddenSchemas.test.js +0 -246
  385. package/build/tests/legacy/MultiSelect.test.js +0 -501
  386. package/build/tests/legacy/MultipleFileUploadSchema.test.js +0 -350
  387. package/build/tests/legacy/PersistAsync.blob-schema.test.js +0 -224
  388. package/build/tests/legacy/PersistAsync.string-schema.test.js +0 -211
  389. package/build/tests/legacy/RefreshStepOnChange.debouncing.test.js +0 -209
  390. package/build/tests/legacy/RefreshStepOnChange.test.js +0 -424
  391. package/build/tests/legacy/Search.test.js +0 -439
  392. package/build/tests/renderers/MultiSelectInputRendererProps.test.js +0 -58
  393. package/build/tests/renderers/SelectInputRendererProps.test.js +0 -43
  394. package/build/tests/renderers/TextInputRenderer.test.js +0 -51
  395. package/build/types.js +0 -1
  396. package/build/useDynamicFlow.js +0 -105
  397. package/build/useDynamicFlowModal.js +0 -58
  398. package/build/utils/analyse-step.js +0 -14
  399. package/build/utils/component-utils.js +0 -8
  400. package/build/utils/component-utils.test.js +0 -113
  401. package/build/utils/getScrollToTop.js +0 -12
  402. package/build/utils/normalise-flow-id.js +0 -1
  403. package/build/utils/normalise-flow-id.test.js +0 -24
  404. package/build/utils/recursiveMerge.js +0 -40
  405. package/build/utils/recursiveMerge.test.js +0 -93
  406. package/build/utils/type-utils.js +0 -21
  407. package/build/utils/type-validators.js +0 -11
  408. package/build/utils/type-validators.test.js +0 -180
  409. package/build/utils/useStableCallback.js +0 -15
@@ -1,190 +0,0 @@
1
- import { vi } from 'vitest';
2
- import { wait } from '../../../test-utils';
3
- import { getUpdateFunctionMock } from '../../mappers/schema/tests/test-utils';
4
- import { createMarkdownComponent } from '../MarkdownComponent';
5
- import { createSearchComponent } from './SearchComponent';
6
- const defaultSearchProps = {
7
- uid: '0',
8
- emptyMessage: '',
9
- initialState: { type: 'layout', content: [] },
10
- margin: 'md',
11
- title: 'title',
12
- };
13
- describe('SearchComponent', () => {
14
- describe('when onChange is called', () => {
15
- it('searching is debounced', () => {
16
- const performSearch = vi.fn().mockImplementation(async () => Promise.resolve([]));
17
- const onAction = vi.fn();
18
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
19
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
20
- component.onChange('query');
21
- expect(performSearch).toHaveBeenCalledTimes(0);
22
- vi.advanceTimersByTime(500);
23
- expect(performSearch).toHaveBeenCalledTimes(1);
24
- });
25
- it('updates the query state immediately', () => {
26
- const performSearch = vi
27
- .fn()
28
- .mockImplementation(async () => Promise.resolve({ type: 'noResults' }));
29
- const onAction = vi.fn();
30
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
31
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
32
- component.onChange('query');
33
- expect(performSearch).toHaveBeenCalledTimes(0);
34
- expect(component.query).toBe('query');
35
- });
36
- describe('after debouncing', () => {
37
- it('performs a search', async () => {
38
- const performSearch = vi.fn().mockImplementation(async () => {
39
- return Promise.resolve({ type: 'noResults' });
40
- });
41
- const onAction = vi.fn();
42
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
43
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
44
- component.onChange('query');
45
- await vi.advanceTimersByTimeAsync(1000); // debounce time
46
- expect(performSearch).toHaveBeenCalled();
47
- });
48
- it('sets isLoading when search begins, and when search ends sets isLoading to false', async () => {
49
- const performSearch = vi.fn().mockImplementation(async () => {
50
- await wait(1000);
51
- return Promise.resolve({ type: 'noResults' });
52
- });
53
- const onAction = vi.fn();
54
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
55
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
56
- component.onChange('query');
57
- await vi.advanceTimersByTimeAsync(500);
58
- expect(performSearch).toHaveBeenCalled();
59
- expect(component.isLoading).toBe(true);
60
- await vi.advanceTimersByTimeAsync(1000);
61
- expect(component.isLoading).toBe(false);
62
- });
63
- });
64
- describe('when a valid response is received', () => {
65
- describe('and the response is the results type', () => {
66
- describe('and results is non-empty', () => {
67
- it('updates results', async () => {
68
- const performSearch = vi.fn().mockImplementation(async () => Promise.resolve({
69
- type: 'results',
70
- results: [{ type: 'action', title: '', action: {} }],
71
- }));
72
- const onAction = vi.fn();
73
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
74
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
75
- component.onChange('query');
76
- await vi.advanceTimersByTimeAsync(500);
77
- expect(performSearch).toHaveBeenCalled();
78
- expect(component.isLoading).toBe(false);
79
- expect(component.state).toStrictEqual(expect.objectContaining({
80
- type: 'results',
81
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
82
- results: expect.arrayContaining([expect.objectContaining({ type: 'action' })]),
83
- }));
84
- });
85
- });
86
- describe('and results is empty', () => {
87
- it('updates results', async () => {
88
- const performSearch = vi
89
- .fn()
90
- .mockImplementation(async () => Promise.resolve({ type: 'results', results: [] }));
91
- const onAction = vi.fn();
92
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
93
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
94
- component.onChange('query');
95
- await vi.advanceTimersByTimeAsync(500);
96
- expect(performSearch).toHaveBeenCalled();
97
- expect(component.isLoading).toBe(false);
98
- expect(component.state).toStrictEqual(expect.objectContaining({
99
- type: 'results',
100
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
101
- results: expect.arrayContaining([]),
102
- }));
103
- });
104
- });
105
- });
106
- describe('and the response is the modern layout type', () => {
107
- it('updates the state to contain the new layout', async () => {
108
- const performSearch = vi.fn().mockImplementation(async () => Promise.resolve({
109
- type: 'layout',
110
- content: [
111
- createMarkdownComponent({
112
- uid: 'markdown',
113
- margin: 'md',
114
- align: 'start',
115
- content: 'Here is some markdown',
116
- size: 'md',
117
- }),
118
- ],
119
- }));
120
- const onAction = vi.fn();
121
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
122
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
123
- component.onChange('query');
124
- await vi.advanceTimersByTimeAsync(500);
125
- expect(performSearch).toHaveBeenCalled();
126
- expect(component.isLoading).toBe(false);
127
- expect(component.state).toStrictEqual(expect.objectContaining({
128
- type: 'layout',
129
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
130
- content: expect.arrayContaining([
131
- expect.objectContaining({ type: 'markdown', content: 'Here is some markdown' }),
132
- ]),
133
- }));
134
- });
135
- });
136
- });
137
- describe('when an invalid response is received', () => {
138
- it('sets error string', async () => {
139
- const performSearch = vi.fn().mockImplementation(async () => {
140
- throw Error('cannot parse response');
141
- });
142
- const onAction = vi.fn();
143
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
144
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
145
- component.onChange('query');
146
- await vi.advanceTimersByTimeAsync(500);
147
- expect(performSearch).toHaveBeenCalled();
148
- expect(component.isLoading).toBe(false);
149
- expect(component.error).toBeDefined();
150
- });
151
- });
152
- describe('when onClick is called', () => {
153
- describe('on an `action` result', () => {
154
- it('calls onAction with the result', async () => {
155
- const performSearch = vi.fn();
156
- const onBehavior = vi.fn();
157
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
158
- const component = createSearchComponent(defaultSearchProps, performSearch, onBehavior, mockUpdateFunction);
159
- component.onSelect({
160
- type: 'action',
161
- title: 'title',
162
- value: { id: 'selected-action-id' },
163
- });
164
- expect(onBehavior).toHaveBeenCalledWith(expect.objectContaining({ type: 'action', action: { id: 'selected-action-id' } }));
165
- });
166
- });
167
- describe('on a `search` result', () => {
168
- it('performs a search with the new config', async () => {
169
- const performSearch = vi.fn().mockImplementation(async () => Promise.resolve([]));
170
- const onAction = vi.fn();
171
- const mockUpdateFunction = getUpdateFunctionMock(() => component);
172
- const component = createSearchComponent(defaultSearchProps, performSearch, onAction, mockUpdateFunction);
173
- component.onSelect({
174
- type: 'search',
175
- title: 'title',
176
- value: { url: '/new-search', param: 'query', method: 'GET', query: 'new' },
177
- });
178
- expect(performSearch).toHaveBeenCalledWith(expect.objectContaining({
179
- query: 'new',
180
- config: expect.objectContaining({
181
- url: '/new-search',
182
- method: 'GET',
183
- param: 'query',
184
- }),
185
- }));
186
- });
187
- });
188
- });
189
- });
190
- });
@@ -1,24 +0,0 @@
1
- import { getInputUpdateFunction } from '../utils/component-utils';
2
- export const createExternalConfirmation = (uid, url, onLink, onComponentUpdate) => {
3
- const update = getInputUpdateFunction(onComponentUpdate);
4
- return {
5
- type: 'external-confirmation',
6
- kind: 'layout',
7
- uid,
8
- url,
9
- status: 'initial',
10
- open() {
11
- if (this.status === 'initial' || this.status === 'failure') {
12
- const success = onLink(this.url);
13
- update(this, (draft) => {
14
- draft.status = success ? 'success' : 'failure';
15
- });
16
- }
17
- },
18
- onCancel() {
19
- update(this, (draft) => {
20
- draft.status = 'dismissed';
21
- });
22
- },
23
- };
24
- };
@@ -1,78 +0,0 @@
1
- var __rest = (this && this.__rest) || function (s, e) {
2
- var t = {};
3
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
- t[p] = s[p];
5
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
- t[p[i]] = s[p[i]];
9
- }
10
- return t;
11
- };
12
- import { getLocalValues, getSubmittableData, getSubmittableDataSync, } from '../../../utils/component-utils';
13
- import { getInputUpdateFunction } from '../utils/component-utils';
14
- export const createStepComponent = (stepProps) => {
15
- const { uid, stepPolling, stepRefreshAfter, stepPrefetch, onComponentUpdate } = stepProps, rest = __rest(stepProps, ["uid", "stepPolling", "stepRefreshAfter", "stepPrefetch", "onComponentUpdate"]);
16
- const update = getInputUpdateFunction(onComponentUpdate);
17
- const component = Object.assign(Object.assign({ uid }, rest), { type: 'step', kind: 'step', modals: [], requestCache: stepPrefetch.requestCache, dismissModal() {
18
- var _a;
19
- (_a = this.modals.at(-1)) === null || _a === void 0 ? void 0 : _a.close();
20
- },
21
- dismissAllModals() {
22
- this._update((draft) => {
23
- draft.modals = draft.modals.map((m) => (Object.assign(Object.assign({}, m), { open: false })));
24
- });
25
- },
26
- showModal(modal) {
27
- this._update((draft) => {
28
- draft.modals = [...draft.modals, modal];
29
- });
30
- },
31
- _update(updateFn) {
32
- update(this, updateFn);
33
- },
34
- getChildren() {
35
- return this.externalConfirmation
36
- ? [...this.layoutComponents, this.externalConfirmation]
37
- : this.layoutComponents;
38
- },
39
- getModals() {
40
- return this.modals;
41
- },
42
- async getSubmittableValue() {
43
- return getSubmittableData(this.schemaComponents);
44
- },
45
- getSubmittableValueSync() {
46
- return getSubmittableDataSync(this.schemaComponents);
47
- },
48
- getLocalValue() {
49
- return getLocalValues(this.schemaComponents);
50
- },
51
- validate() {
52
- return this.schemaComponents.every((inputComponent) => {
53
- var _a;
54
- return this.referencedSchemaIds.includes((_a = inputComponent.schemaId) !== null && _a !== void 0 ? _a : '')
55
- ? inputComponent.validate()
56
- : true;
57
- });
58
- },
59
- setLoadingState(loadingState) {
60
- this._update((draft) => {
61
- draft.loadingState = loadingState;
62
- });
63
- },
64
- start() {
65
- stepPolling === null || stepPolling === void 0 ? void 0 : stepPolling.start();
66
- stepRefreshAfter === null || stepRefreshAfter === void 0 ? void 0 : stepRefreshAfter.start();
67
- stepPrefetch.start(this.getSubmittableValueSync());
68
- },
69
- stop() {
70
- stepPolling === null || stepPolling === void 0 ? void 0 : stepPolling.stop();
71
- stepRefreshAfter === null || stepRefreshAfter === void 0 ? void 0 : stepRefreshAfter.stop();
72
- stepPrefetch.stop();
73
- this._update((draft) => {
74
- draft.modals = [];
75
- });
76
- } });
77
- return component;
78
- };
@@ -1 +0,0 @@
1
- export {};
@@ -1 +0,0 @@
1
- export {};
@@ -1,12 +0,0 @@
1
- /**
2
- * Helper function to update a component.
3
- *
4
- * @param onComponentUpdate the function that will notify the view layer that something has changed in the domain layer
5
- * @returns a function that can be used to update components without the linter shouting at us.
6
- */
7
- export const getInputUpdateFunction = (onComponentUpdate) => {
8
- return (component, updateFn) => {
9
- updateFn(component);
10
- onComponentUpdate();
11
- };
12
- };
@@ -1,34 +0,0 @@
1
- export const debounce = (callback, waitMs) => {
2
- let timeoutId = null;
3
- let lastArgs = null;
4
- const clearTimer = () => {
5
- if (timeoutId) {
6
- clearTimeout(timeoutId);
7
- timeoutId = null;
8
- }
9
- lastArgs = null;
10
- };
11
- const debouncedFn = (...args) => {
12
- lastArgs = args;
13
- if (timeoutId !== null) {
14
- clearTimeout(timeoutId);
15
- }
16
- timeoutId = setTimeout(() => {
17
- callback(...lastArgs);
18
- timeoutId = null;
19
- lastArgs = null;
20
- }, waitMs);
21
- };
22
- debouncedFn.cancel = () => {
23
- if (timeoutId !== null) {
24
- clearTimer();
25
- }
26
- };
27
- debouncedFn.flush = () => {
28
- if (timeoutId !== null) {
29
- callback(...lastArgs);
30
- clearTimer();
31
- }
32
- };
33
- return debouncedFn;
34
- };
@@ -1,67 +0,0 @@
1
- import { vi } from 'vitest';
2
- import { debounce } from './debounce';
3
- describe('debounce', () => {
4
- it('will delay function execution until the wait period has passed', () => {
5
- const fn = vi.fn();
6
- const debouncedFn = debounce(fn, 5);
7
- debouncedFn();
8
- expect(fn).toHaveBeenCalledTimes(0);
9
- vi.advanceTimersByTime(5);
10
- expect(fn).toHaveBeenCalledTimes(1);
11
- });
12
- it('will call function with provided arguments', () => {
13
- const fn = vi.fn();
14
- const debouncedFn = debounce(fn, 5);
15
- debouncedFn('a', 'b', 'c');
16
- vi.advanceTimersByTime(5);
17
- expect(fn).toHaveBeenCalledTimes(1);
18
- expect(fn).toHaveBeenCalledWith('a', 'b', 'c');
19
- });
20
- it('will reset the wait period and ignore previous executions if called within the wait period', () => {
21
- const fn = vi.fn();
22
- const debouncedFn = debounce(fn, 5);
23
- debouncedFn(1, 2, 3);
24
- vi.advanceTimersByTime(4);
25
- debouncedFn('a', 'b', 'c');
26
- vi.advanceTimersByTime(5);
27
- expect(fn).toHaveBeenCalledTimes(1);
28
- expect(fn).toHaveBeenCalledWith('a', 'b', 'c');
29
- });
30
- it('will call the same function twice if invoked after the wait period', () => {
31
- const fn = vi.fn();
32
- const debouncedFn = debounce(fn, 5);
33
- debouncedFn();
34
- vi.advanceTimersByTime(5);
35
- debouncedFn();
36
- vi.advanceTimersByTime(5);
37
- expect(fn).toHaveBeenCalledTimes(2);
38
- });
39
- describe('flush', () => {
40
- it('will call the callback immediately', () => {
41
- const fn = vi.fn();
42
- const debouncedFn = debounce(fn, 5);
43
- debouncedFn();
44
- debouncedFn.flush();
45
- expect(fn).toHaveBeenCalledTimes(1);
46
- });
47
- it('uses the last passed args', () => {
48
- const fn = vi.fn();
49
- const debouncedFn = debounce(fn, 5);
50
- debouncedFn(1, 2, 3);
51
- debouncedFn('a', 'b', 'c');
52
- debouncedFn.flush();
53
- expect(fn).toHaveBeenCalledTimes(1);
54
- expect(fn).toHaveBeenCalledWith('a', 'b', 'c');
55
- });
56
- });
57
- describe('cancel', () => {
58
- it('cancels any waiting callback', () => {
59
- const fn = vi.fn();
60
- const debouncedFn = debounce(fn, 5);
61
- debouncedFn();
62
- debouncedFn.cancel();
63
- vi.advanceTimersByTime(5);
64
- expect(fn).toHaveBeenCalledTimes(0);
65
- });
66
- });
67
- });
@@ -1,21 +0,0 @@
1
- export const toBase64 = async (file) => new Promise((resolve, reject) => {
2
- const reader = new FileReader();
3
- reader.addEventListener('load', () => resolve(reader.result));
4
- reader.addEventListener('error', reject);
5
- reader.readAsDataURL(file);
6
- });
7
- export const base64dataUrltoFile = (dataurl, filename) => {
8
- if (!isBase64DataUrl(dataurl)) {
9
- return null;
10
- }
11
- const [, base64data] = dataurl.split(',');
12
- return new File([base64ToBytes(base64data)], filename, { type: getMimeType(dataurl) });
13
- };
14
- const isBase64DataUrl = (dataurl) => dataurl.startsWith('data:') && dataurl.includes('base64') && dataurl.includes(',');
15
- const getMimeType = (base64dataUrl) => base64dataUrl.substring('data:'.length).split(';')[0];
16
- const base64ToBytes = (base64) => {
17
- const charCodes = atob(base64)
18
- .split('')
19
- .map((m) => m.charCodeAt(0));
20
- return Uint8Array.from(charCodes);
21
- };
@@ -1,27 +0,0 @@
1
- /* eslint-disable @typescript-eslint/no-non-null-assertion */
2
- import { base64dataUrltoFile, toBase64 } from './file-utils';
3
- describe('toBase64', () => {
4
- describe('given a valid file', () => {
5
- it('should return a base64 string', async () => {
6
- const file = new File(['hello'], 'test.txt', { type: 'text/plain' });
7
- await expect(toBase64(file)).resolves.toBe('data:text/plain;base64,aGVsbG8=');
8
- });
9
- });
10
- });
11
- describe('dataURLtoFile', () => {
12
- describe('given a valid data URL', () => {
13
- const dataurl = 'data:text/plain;base64,aGVsbG8=';
14
- it('should return a file that can be encoded back to the given string', async () => {
15
- const file = base64dataUrltoFile(dataurl, 'test.txt');
16
- expect(file).toBeInstanceOf(File);
17
- expect(file.type).toBe('text/plain');
18
- expect(file.name).toBe('test.txt');
19
- await expect(toBase64(file)).resolves.toBe(dataurl);
20
- });
21
- });
22
- describe('given an invalid data URL', () => {
23
- it('should return null', () => {
24
- expect(base64dataUrltoFile('invalid', 'test.txt')).toBeNull();
25
- });
26
- });
27
- });
@@ -1 +0,0 @@
1
- export const getRandomId = () => Math.random().toString(36).substring(2);
@@ -1,14 +0,0 @@
1
- import { isArrayLocalValue, isObjectLocalValue } from '../../../utils/type-utils';
2
- export const isExactLocalValueMatch = (valueA, valueB) => {
3
- if (isArrayLocalValue(valueA) && isArrayLocalValue(valueB)) {
4
- return (valueA.length === valueB.length &&
5
- valueA.every((value, index) => isExactLocalValueMatch(value, valueB[index])));
6
- }
7
- if (isObjectLocalValue(valueA) && isObjectLocalValue(valueB)) {
8
- const keysA = Object.keys(valueA);
9
- const keysB = Object.keys(valueB);
10
- return (keysA.length === keysB.length &&
11
- keysA.every((key) => isExactLocalValueMatch(valueA[key], valueB[key])));
12
- }
13
- return valueA === valueB;
14
- };
@@ -1,5 +0,0 @@
1
- export const isOrWasValid = (getErrors, previous, current) => {
2
- const wasValid = getErrors(previous).length === 0 && previous !== null;
3
- const isValid = getErrors(current).length === 0;
4
- return wasValid || isValid;
5
- };
@@ -1,18 +0,0 @@
1
- import { isArrayModel, isObjectModel } from '../../../utils/type-utils';
2
- import { isNullish } from '../../../utils/type-validators';
3
- export const isPartialModelMatch = (localModel, incomingModel) => {
4
- if (isArrayModel(localModel) && isArrayModel(incomingModel)) {
5
- return (localModel.length === incomingModel.length &&
6
- localModel.every((value, index) => isPartialModelMatch(value, incomingModel[index])));
7
- }
8
- if (isObjectModel(localModel) && isObjectModel(incomingModel)) {
9
- if (Object.keys(localModel).length === 0 && Object.keys(incomingModel).length === 0) {
10
- return true;
11
- }
12
- const nonNullishKeysInBoth = nonNullishKeys(localModel).filter((key) => nonNullishKeys(incomingModel).includes(key));
13
- return (nonNullishKeysInBoth.length > 0 &&
14
- nonNullishKeysInBoth.every((key) => isPartialModelMatch(localModel[key], incomingModel[key])));
15
- }
16
- return localModel === incomingModel;
17
- };
18
- const nonNullishKeys = (model) => Object.keys(model).filter((key) => !isNullish(model[key]));
@@ -1,74 +0,0 @@
1
- import { isPartialModelMatch } from './isPartialModelMatch';
2
- describe('isPartialModelMatch', () => {
3
- describe('when both models are arrays', () => {
4
- it('will return true if both models are empty', () => {
5
- expect(isPartialModelMatch([], [])).toBe(true);
6
- });
7
- it('will return false if the models have different lengths', () => {
8
- expect(isPartialModelMatch([1], [1, 2])).toBe(false);
9
- expect(isPartialModelMatch([1, 2], [1])).toBe(false);
10
- });
11
- it('will return false if any of the items in the array do not partially match', () => {
12
- expect(isPartialModelMatch([1], [2])).toBe(false);
13
- expect(isPartialModelMatch([[1]], [[2]])).toBe(false);
14
- expect(isPartialModelMatch([{ prop: 'value' }], [{ prop: 'different value' }])).toBe(false);
15
- });
16
- it('will return true if all items in the arrays partially match', () => {
17
- expect(isPartialModelMatch([1], [1])).toBe(true);
18
- });
19
- });
20
- describe('when both models are objects', () => {
21
- it('wil return true if both localModel and incomingModel are empty', () => {
22
- expect(isPartialModelMatch({}, {})).toBe(true);
23
- });
24
- it('will return false if localModel is empty', () => {
25
- expect(isPartialModelMatch({}, { prop: 1 })).toBe(false);
26
- });
27
- it('will return false if incomingModel is empty', () => {
28
- expect(isPartialModelMatch({ prop: 1 }, {})).toBe(false);
29
- });
30
- it('will return false if the models have matching keys with different values', () => {
31
- expect(isPartialModelMatch({ key: 1 }, { key: 2 })).toBe(false);
32
- expect(isPartialModelMatch({ key: 2 }, { key: 1 })).toBe(false);
33
- });
34
- it('will return true if matching keys have the same value', () => {
35
- expect(isPartialModelMatch({ key: 1 }, { key: 1 })).toBe(true);
36
- });
37
- it('will ignore the value of non-matching keys', () => {
38
- expect(isPartialModelMatch({ matchingKey: 1 }, { matchingKey: 1, otherKey: 2 })).toBe(true);
39
- expect(isPartialModelMatch({ otherKey: 2, matchingKey: 1 }, { matchingKey: 1 })).toBe(true);
40
- });
41
- it('will ignore the value of nullish keys', () => {
42
- expect(isPartialModelMatch({ matchingKey: 1, otherKey: 2 }, { matchingKey: 1, otherKey: null })).toBe(true);
43
- expect(isPartialModelMatch({ otherKey: null, matchingKey: 1 }, { matchingKey: 1, otherKey: 2 })).toBe(true);
44
- expect(isPartialModelMatch({ matchingKey: 1, otherKey: null }, { matchingKey: 1 })).toBe(true);
45
- expect(isPartialModelMatch({ matchingKey: 1 }, { matchingKey: 1, otherKey: null })).toBe(true);
46
- });
47
- it('looks for matches recursively', () => {
48
- expect(isPartialModelMatch({ matchingKey: [{ matchingKey: 2 }] }, { matchingKey: [{ matchingKey: 2 }] })).toBe(true);
49
- expect(isPartialModelMatch({ matchingKey: [{ matchingKey: 2 }] }, { matchingKey: [{ matchingKey: 3 }] })).toBe(false);
50
- });
51
- });
52
- describe('when both models are matching primitives', () => {
53
- it('will return true if the models are equal', () => {
54
- expect(isPartialModelMatch(1, 1)).toBe(true);
55
- expect(isPartialModelMatch('value', 'value')).toBe(true);
56
- expect(isPartialModelMatch(true, true)).toBe(true);
57
- });
58
- it('will return false if the models are not equal', () => {
59
- expect(isPartialModelMatch(1, 2)).toBe(false);
60
- expect(isPartialModelMatch('value', 'different value')).toBe(false);
61
- expect(isPartialModelMatch(true, false)).toBe(false);
62
- });
63
- });
64
- describe('when models are of different types', () => {
65
- it('will always return false', () => {
66
- expect(isPartialModelMatch(null, 1)).toBe(false);
67
- expect(isPartialModelMatch(1, null)).toBe(false);
68
- expect(isPartialModelMatch({}, [])).toBe(false);
69
- expect(isPartialModelMatch([], {})).toBe(false);
70
- expect(isPartialModelMatch(1, {})).toBe(false);
71
- expect(isPartialModelMatch({}, 1)).toBe(false);
72
- });
73
- });
74
- });
@@ -1,24 +0,0 @@
1
- export const eventNames = [
2
- 'Initiated',
3
- 'Succeeded',
4
- 'Failed',
5
- 'Cancelled',
6
- 'Step Shown',
7
- 'Action Triggered',
8
- 'Action Succeeded',
9
- 'Action Aborted',
10
- 'Action Failed',
11
- 'Refresh Triggered',
12
- 'Refresh Succeeded',
13
- 'Refresh Aborted',
14
- 'Refresh Failed',
15
- 'OneOf Selected',
16
- 'OneOf Option Selected',
17
- 'PersistAsync Triggered',
18
- 'PersistAsync Succeeded',
19
- 'PersistAsync Failed',
20
- 'Polling Failed',
21
- 'ValidationAsync Triggered',
22
- 'ValidationAsync Succeeded',
23
- 'ValidationAsync Failed',
24
- ];
@@ -1 +0,0 @@
1
- export {};