@wise/dynamic-flow-client 5.10.0 → 5.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (418) hide show
  1. package/build/i18n/fr.json +1 -1
  2. package/build/main.css +4 -0
  3. package/build/main.js +32 -17
  4. package/build/main.mjs +32 -17
  5. package/build/types/controller/FlowController.d.ts +0 -1
  6. package/build/types/controller/FlowController.d.ts.map +1 -1
  7. package/build/types/controller/executePoll.d.ts.map +1 -1
  8. package/build/types/domain/components/step/ExternalConfirmationComponent.d.ts +2 -3
  9. package/build/types/domain/components/step/ExternalConfirmationComponent.d.ts.map +1 -1
  10. package/build/types/domain/mappers/mapStepToComponent.d.ts.map +1 -1
  11. package/build/types/domain/mappers/schema/types.d.ts +1 -0
  12. package/build/types/domain/mappers/schema/types.d.ts.map +1 -1
  13. package/build/types/renderers/mappers/externalComponentToProps.d.ts.map +1 -1
  14. package/build/types/test-utils/openLinkInNewTab.d.ts.map +1 -0
  15. package/package.json +7 -7
  16. package/build/DynamicFlowCore.js +0 -5
  17. package/build/common/errorBoundary/ErrorBoundary.js +0 -26
  18. package/build/common/errorBoundary/ErrorBoundary.test.js +0 -29
  19. package/build/common/errorBoundary/ErrorBoundaryAlert.js +0 -11
  20. package/build/common/makeHttpClient/api-utils.js +0 -3
  21. package/build/common/makeHttpClient/index.js +0 -1
  22. package/build/common/makeHttpClient/makeHttpClient.js +0 -10
  23. package/build/common/makeHttpClient/makeHttpClient.test.js +0 -186
  24. package/build/common/messages/external-confirmation.messages.js +0 -23
  25. package/build/common/messages/file-upload.messages.js +0 -13
  26. package/build/common/messages/generic-error.messages.js +0 -18
  27. package/build/common/messages/help.messages.js +0 -8
  28. package/build/common/messages/multi-file-upload.messages.js +0 -18
  29. package/build/common/messages/multi-select.messages.js +0 -8
  30. package/build/common/messages/paragraph.messages.js +0 -13
  31. package/build/common/messages/repeatable.messages.js +0 -23
  32. package/build/common/messages/search.messages.js +0 -8
  33. package/build/common/messages/validation.array.messages.js +0 -13
  34. package/build/common/messages/validation.messages.js +0 -53
  35. package/build/controller/FlowController.js +0 -372
  36. package/build/controller/executePoll.js +0 -49
  37. package/build/controller/executeRefresh.js +0 -45
  38. package/build/controller/executeRequest.js +0 -80
  39. package/build/controller/executeSubmission.js +0 -70
  40. package/build/controller/getErrorMessage.js +0 -7
  41. package/build/controller/getRequestAbortController.js +0 -13
  42. package/build/controller/getResponseType.js +0 -35
  43. package/build/controller/getSafeHttpClient.js +0 -8
  44. package/build/controller/getStepCounter.js +0 -16
  45. package/build/controller/handleErrorResponse.js +0 -26
  46. package/build/controller/makeSafeHttpClient.js +0 -8
  47. package/build/controller/response-utils.js +0 -72
  48. package/build/domain/components/AlertComponent.js +0 -1
  49. package/build/domain/components/AllOfComponent.js +0 -40
  50. package/build/domain/components/BooleanInputComponent.js +0 -50
  51. package/build/domain/components/BoxComponent.js +0 -3
  52. package/build/domain/components/ButtonComponent.js +0 -1
  53. package/build/domain/components/ColumnsComponent.js +0 -3
  54. package/build/domain/components/ConstComponent.js +0 -18
  55. package/build/domain/components/ContainerComponent.js +0 -3
  56. package/build/domain/components/DateInputComponent.js +0 -75
  57. package/build/domain/components/DecisionComponent.js +0 -1
  58. package/build/domain/components/DividerComponent.js +0 -1
  59. package/build/domain/components/FormComponent.js +0 -3
  60. package/build/domain/components/FormattedValueComponent.js +0 -44
  61. package/build/domain/components/HeadingComponent.js +0 -1
  62. package/build/domain/components/ImageComponent.js +0 -1
  63. package/build/domain/components/InstructionsComponent.js +0 -1
  64. package/build/domain/components/IntegerInputComponent.js +0 -74
  65. package/build/domain/components/ListComponent.js +0 -1
  66. package/build/domain/components/LoadingIndicatorComponent.js +0 -1
  67. package/build/domain/components/MarkdownComponent.js +0 -1
  68. package/build/domain/components/MediaComponent.js +0 -1
  69. package/build/domain/components/ModalComponent.js +0 -16
  70. package/build/domain/components/ModalLayoutComponent.js +0 -3
  71. package/build/domain/components/MoneyInputComponent.js +0 -57
  72. package/build/domain/components/MultiSelectInputComponent.js +0 -81
  73. package/build/domain/components/MultiUploadInputComponent.js +0 -88
  74. package/build/domain/components/NumberInputComponent.js +0 -73
  75. package/build/domain/components/ObjectComponent.js +0 -45
  76. package/build/domain/components/ParagraphComponent.js +0 -1
  77. package/build/domain/components/PersistAsyncComponent.js +0 -92
  78. package/build/domain/components/ProgressComponent.js +0 -1
  79. package/build/domain/components/RepeatableComponent.js +0 -103
  80. package/build/domain/components/ReviewComponent.js +0 -1
  81. package/build/domain/components/RootDomainComponent.js +0 -173
  82. package/build/domain/components/SectionComponent.js +0 -5
  83. package/build/domain/components/SelectInputComponent.js +0 -88
  84. package/build/domain/components/StatusListComponent.js +0 -1
  85. package/build/domain/components/SubflowDomainComponent.js +0 -9
  86. package/build/domain/components/TabsComponent.js +0 -1
  87. package/build/domain/components/TextInputComponent.js +0 -76
  88. package/build/domain/components/TupleComponent.js +0 -41
  89. package/build/domain/components/UploadInputComponent.js +0 -83
  90. package/build/domain/components/UpsellComponent.js +0 -25
  91. package/build/domain/components/searchComponent/SearchComponent.js +0 -92
  92. package/build/domain/components/searchComponent/SearchComponent.test.js +0 -190
  93. package/build/domain/components/step/ExternalConfirmationComponent.js +0 -28
  94. package/build/domain/components/step/StepDomainComponent.js +0 -78
  95. package/build/domain/components/step/ToolbarComponent.js +0 -1
  96. package/build/domain/components/utils/WithUpdate.js +0 -1
  97. package/build/domain/components/utils/component-utils.js +0 -12
  98. package/build/domain/components/utils/debounce.js +0 -34
  99. package/build/domain/components/utils/debounce.test.js +0 -67
  100. package/build/domain/components/utils/file-utils.js +0 -21
  101. package/build/domain/components/utils/file-utils.test.js +0 -27
  102. package/build/domain/components/utils/getRandomId.js +0 -1
  103. package/build/domain/components/utils/isExactLocalValueMatch.js +0 -14
  104. package/build/domain/components/utils/isOrWasValid.js +0 -5
  105. package/build/domain/components/utils/isPartialModelMatch.js +0 -18
  106. package/build/domain/components/utils/isPartialModelMatch.test.js +0 -74
  107. package/build/domain/features/eventNames.js +0 -24
  108. package/build/domain/features/events.js +0 -1
  109. package/build/domain/features/persistAsync/getComponentMultiPersistAsync.js +0 -50
  110. package/build/domain/features/persistAsync/getInitialPersistedState.js +0 -7
  111. package/build/domain/features/persistAsync/getPerformPersistAsync.js +0 -43
  112. package/build/domain/features/persistAsync/getPerformPersistAsync.test.js +0 -139
  113. package/build/domain/features/polling/getStepPolling.js +0 -43
  114. package/build/domain/features/polling/getStepPolling.test.js +0 -90
  115. package/build/domain/features/prefetch/getStepPrefetch.js +0 -43
  116. package/build/domain/features/prefetch/request-cache.js +0 -49
  117. package/build/domain/features/prefetch/request-cache.test.js +0 -70
  118. package/build/domain/features/refreshAfter/getStepRefreshAfter.js +0 -24
  119. package/build/domain/features/refreshAfter/getStepRefreshAfter.test.js +0 -40
  120. package/build/domain/features/schema-on-change/getDebouncedSchemaOnChange.js +0 -50
  121. package/build/domain/features/schema-on-change/getSchemaOnChange.js +0 -34
  122. package/build/domain/features/search/getPerformSearchFunction.js +0 -75
  123. package/build/domain/features/search/getPerformSearchFunction.test.js +0 -301
  124. package/build/domain/features/summary/summary-utils.js +0 -40
  125. package/build/domain/features/summary/summary-utils.test.js +0 -125
  126. package/build/domain/features/utils/http-utils.js +0 -21
  127. package/build/domain/features/utils/response-utils.js +0 -9
  128. package/build/domain/features/validation/spec-utils.js +0 -19
  129. package/build/domain/features/validation/validateStringPattern.js +0 -24
  130. package/build/domain/features/validation/validation-functions.js +0 -6
  131. package/build/domain/features/validation/validation-functions.test.js +0 -108
  132. package/build/domain/features/validation/value-checks.js +0 -125
  133. package/build/domain/features/validation/value-checks.test.js +0 -262
  134. package/build/domain/features/validationAsync/getComponentValidationAsync.js +0 -53
  135. package/build/domain/features/validationAsync/getComponentValidationAsync.test.js +0 -67
  136. package/build/domain/features/validationAsync/getInitialValidationAsyncState.js +0 -5
  137. package/build/domain/features/validationAsync/getPerformValidationAsync.js +0 -45
  138. package/build/domain/features/validationAsync/getPerformValidationAsync.test.js +0 -143
  139. package/build/domain/mappers/layout/alertLayoutToComponent.js +0 -16
  140. package/build/domain/mappers/layout/boxLayoutToComponent.js +0 -13
  141. package/build/domain/mappers/layout/buttonLayoutToComponent.js +0 -77
  142. package/build/domain/mappers/layout/columnsLayoutToComponent.js +0 -13
  143. package/build/domain/mappers/layout/decisionLayoutToComponent.js +0 -22
  144. package/build/domain/mappers/layout/deprecatedListLayoutToComponent.js +0 -30
  145. package/build/domain/mappers/layout/dividerLayoutToComponent.js +0 -2
  146. package/build/domain/mappers/layout/formLayoutToComponent.js +0 -19
  147. package/build/domain/mappers/layout/headingLayoutToComponent.js +0 -12
  148. package/build/domain/mappers/layout/imageLayoutToComponent.js +0 -20
  149. package/build/domain/mappers/layout/infoLayoutToComponent.js +0 -12
  150. package/build/domain/mappers/layout/instructionsLayoutToComponent.js +0 -12
  151. package/build/domain/mappers/layout/listLayoutToComponent.js +0 -39
  152. package/build/domain/mappers/layout/loadingIndicatorLayoutToComponent.js +0 -9
  153. package/build/domain/mappers/layout/markdownLayoutToComponent.js +0 -12
  154. package/build/domain/mappers/layout/mediaLayoutToComponent.js +0 -12
  155. package/build/domain/mappers/layout/modalLayoutToComponent.js +0 -17
  156. package/build/domain/mappers/layout/modalToComponent.js +0 -8
  157. package/build/domain/mappers/layout/paragraphLayoutToComponent.js +0 -12
  158. package/build/domain/mappers/layout/progressLayoutToComponent.js +0 -15
  159. package/build/domain/mappers/layout/reviewLayoutToComponent.js +0 -48
  160. package/build/domain/mappers/layout/searchLayoutToComponent.js +0 -44
  161. package/build/domain/mappers/layout/sectionLayoutToComponent.js +0 -15
  162. package/build/domain/mappers/layout/statusListLayoutToComponent.js +0 -15
  163. package/build/domain/mappers/layout/tabsLayoutToComponent.js +0 -16
  164. package/build/domain/mappers/layout/upsellLayoutToComponent.js +0 -25
  165. package/build/domain/mappers/mapLayoutToComponent.js +0 -81
  166. package/build/domain/mappers/mapSchemaToComponent.js +0 -61
  167. package/build/domain/mappers/mapSchemaToComponent.test.js +0 -112
  168. package/build/domain/mappers/mapStepSchemas.js +0 -15
  169. package/build/domain/mappers/mapStepToComponent.js +0 -133
  170. package/build/domain/mappers/mapStepToComponent.test.js +0 -221
  171. package/build/domain/mappers/mapToolbarToComponent.js +0 -15
  172. package/build/domain/mappers/schema/allOfSchemaToComponent.js +0 -16
  173. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToComponent.js +0 -26
  174. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiSelectComponent.js +0 -55
  175. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiUploadComponent.js +0 -67
  176. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToRepeatableComponent.js +0 -57
  177. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToTupleComponent.js +0 -20
  178. package/build/domain/mappers/schema/blobSchemaToComponent.js +0 -15
  179. package/build/domain/mappers/schema/booleanSchemaToComponent.js +0 -29
  180. package/build/domain/mappers/schema/constSchemaToComponent.js +0 -23
  181. package/build/domain/mappers/schema/integerSchemaToComponent.js +0 -28
  182. package/build/domain/mappers/schema/numberSchemaToComponent.js +0 -26
  183. package/build/domain/mappers/schema/objectSchemaToComponent/assertDisplayOrder.js +0 -23
  184. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToFormattedValueComponent.js +0 -9
  185. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.js +0 -119
  186. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.test.js +0 -96
  187. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.js +0 -31
  188. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.test.js +0 -99
  189. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.js +0 -66
  190. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.test.js +0 -225
  191. package/build/domain/mappers/schema/persistAsyncSchemaToComponent.js +0 -29
  192. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.js +0 -18
  193. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.test.js +0 -133
  194. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToDateInputComponent.js +0 -48
  195. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToTextInputComponent.js +0 -37
  196. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToUploadInputComponent.js +0 -28
  197. package/build/domain/mappers/schema/tests/test-utils.js +0 -16
  198. package/build/domain/mappers/schema/types.js +0 -1
  199. package/build/domain/mappers/schema/utils/getPerformPersistAsyncFn.js +0 -19
  200. package/build/domain/mappers/schema/utils/getValidationAsyncInitialState.js +0 -23
  201. package/build/domain/mappers/schema/utils/mapCommonSchemaProps.js +0 -16
  202. package/build/domain/mappers/types.js +0 -1
  203. package/build/domain/mappers/utils/FeatureFlags.js +0 -22
  204. package/build/domain/mappers/utils/behavior-utils.js +0 -44
  205. package/build/domain/mappers/utils/call-to-action-utils.js +0 -21
  206. package/build/domain/mappers/utils/getAutocompleteString.js +0 -76
  207. package/build/domain/mappers/utils/getAutocompleteString.test.js +0 -21
  208. package/build/domain/mappers/utils/groupLayoutByPinned.js +0 -38
  209. package/build/domain/mappers/utils/groupLayoutByPinned.test.js +0 -166
  210. package/build/domain/mappers/utils/image.js +0 -9
  211. package/build/domain/mappers/utils/layout-utils.js +0 -11
  212. package/build/domain/mappers/utils/legacy-utils.js +0 -49
  213. package/build/domain/mappers/utils/media-utils.js +0 -14
  214. package/build/domain/mappers/utils/suggestions-utils.js +0 -26
  215. package/build/domain/mappers/utils/suggestions-utils.test.js +0 -36
  216. package/build/domain/mappers/utils/tags-utils.js +0 -1
  217. package/build/domain/mappers/utils/utils.js +0 -35
  218. package/build/domain/types.js +0 -1
  219. package/build/getSubflowCallbacks.js +0 -38
  220. package/build/i18n/index.js +0 -40
  221. package/build/index.js +0 -8
  222. package/build/renderers/CoreContainerRenderer.js +0 -5
  223. package/build/renderers/CoreRootRenderer.js +0 -12
  224. package/build/renderers/EmptyLoadingStateRenderer.js +0 -5
  225. package/build/renderers/getRenderFunction.js +0 -24
  226. package/build/renderers/getSchemaErrorMessageFunction.js +0 -97
  227. package/build/renderers/mappers/alertComponentToProps.js +0 -2
  228. package/build/renderers/mappers/allOfComponentToProps.js +0 -6
  229. package/build/renderers/mappers/booleanInputComponentToProps.js +0 -5
  230. package/build/renderers/mappers/boxComponentToProps.js +0 -13
  231. package/build/renderers/mappers/buttonComponentToProps.js +0 -4
  232. package/build/renderers/mappers/columnsComponentToProps.js +0 -11
  233. package/build/renderers/mappers/componentToRendererProps.js +0 -164
  234. package/build/renderers/mappers/constComponentToProps.js +0 -5
  235. package/build/renderers/mappers/containerComponentToProps.js +0 -7
  236. package/build/renderers/mappers/dateInputComponentToProps.js +0 -2
  237. package/build/renderers/mappers/decisionComponentToProps.js +0 -16
  238. package/build/renderers/mappers/dividerComponentToProps.js +0 -2
  239. package/build/renderers/mappers/externalComponentToProps.js +0 -3
  240. package/build/renderers/mappers/formComponentToProps.js +0 -12
  241. package/build/renderers/mappers/formattedValueComponentToProps.js +0 -5
  242. package/build/renderers/mappers/headingComponentToProps.js +0 -2
  243. package/build/renderers/mappers/hiddenComponentToProps.js +0 -4
  244. package/build/renderers/mappers/imageComponentToProps.js +0 -2
  245. package/build/renderers/mappers/instructionsComponentToProps.js +0 -2
  246. package/build/renderers/mappers/integerInputComponentToProps.js +0 -2
  247. package/build/renderers/mappers/listComponentToProps.js +0 -2
  248. package/build/renderers/mappers/loadingIndicatorComponentToProps.js +0 -2
  249. package/build/renderers/mappers/markdownComponentToProps.js +0 -2
  250. package/build/renderers/mappers/mediaComponentToProps.js +0 -2
  251. package/build/renderers/mappers/modalComponentToProps.js +0 -11
  252. package/build/renderers/mappers/modalLayoutComponentToProps.js +0 -16
  253. package/build/renderers/mappers/moneyInputComponentToProps.js +0 -36
  254. package/build/renderers/mappers/multiSelectComponentToProps.js +0 -23
  255. package/build/renderers/mappers/multiUploadInputComponentToProps.js +0 -12
  256. package/build/renderers/mappers/numberInputComponentToProps.js +0 -2
  257. package/build/renderers/mappers/objectComponentToProps.js +0 -8
  258. package/build/renderers/mappers/paragraphComponentToProps.js +0 -2
  259. package/build/renderers/mappers/persistAsyncComponentToProps.js +0 -8
  260. package/build/renderers/mappers/progressComponentToProps.js +0 -2
  261. package/build/renderers/mappers/repeatableComponentToProps.js +0 -30
  262. package/build/renderers/mappers/reviewComponentToProps.js +0 -2
  263. package/build/renderers/mappers/rootComponentToProps.js +0 -21
  264. package/build/renderers/mappers/searchComponentToProps.js +0 -57
  265. package/build/renderers/mappers/sectionComponentToProps.js +0 -6
  266. package/build/renderers/mappers/selectInputComponentToProps.js +0 -34
  267. package/build/renderers/mappers/statusListComponentToProps.js +0 -2
  268. package/build/renderers/mappers/subflowComponentToRendererProps.js +0 -4
  269. package/build/renderers/mappers/tabsComponentToProps.js +0 -14
  270. package/build/renderers/mappers/textInputComponentToProps.js +0 -2
  271. package/build/renderers/mappers/tupleComponentToProps.js +0 -8
  272. package/build/renderers/mappers/uploadInputComponentToProps.js +0 -8
  273. package/build/renderers/mappers/upsellComponentToProps.js +0 -2
  274. package/build/renderers/mappers/utils/getValidationState.js +0 -12
  275. package/build/renderers/mappers/utils/inputComponentToProps.js +0 -26
  276. package/build/renderers/mappers/utils/mapErrorsToValidationState.js +0 -9
  277. package/build/renderers/mappers/utils/pick.js +0 -8
  278. package/build/renderers/mappers/utils/selectInputOptionsToProps.js +0 -11
  279. package/build/renderers/stepComponentToProps.js +0 -32
  280. package/build/renderers/utils.js +0 -69
  281. package/build/renderers/utils.test.js +0 -70
  282. package/build/stories/dev-tools/ContainerQueries.story.js +0 -66
  283. package/build/stories/dev-tools/Debugger.story.js +0 -38
  284. package/build/stories/dev-tools/FixtureSelect.story.js +0 -23
  285. package/build/stories/dev-tools/TestServer.story.js +0 -32
  286. package/build/stories/examples/NativeFlow.story.js +0 -80
  287. package/build/stories/examples/Recipients.story.js +0 -568
  288. package/build/stories/spec/behavior/Copy.story.js +0 -71
  289. package/build/stories/spec/behavior/Link.story.js +0 -40
  290. package/build/stories/spec/behavior/Modal.story.js +0 -79
  291. package/build/stories/spec/behavior/Subflow.story.js +0 -267
  292. package/build/stories/spec/layouts/Decision.story.js +0 -241
  293. package/build/stories/spec/layouts/Image.story.js +0 -42
  294. package/build/stories/spec/layouts/Modal.story.js +0 -81
  295. package/build/stories/spec/layouts/Search.story.js +0 -325
  296. package/build/stories/spec/layouts/Upsell.story.js +0 -55
  297. package/build/stories/spec/layouts/button/Button.story.js +0 -100
  298. package/build/stories/spec/layouts/button/PinnedButton.story.js +0 -81
  299. package/build/stories/spec/response/ActionResponse.story.js +0 -66
  300. package/build/stories/spec/schemas/MultiSelect.story.js +0 -148
  301. package/build/stories/spec/schemas/Upload.story.js +0 -168
  302. package/build/stories/spec/schemas/const/ConstLayout.story.js +0 -159
  303. package/build/stories/spec/schemas/const/ObjectConst.story.js +0 -94
  304. package/build/stories/spec/schemas/features/PersistAsync.story.js +0 -211
  305. package/build/stories/spec/schemas/features/ValidationAsync.story.js +0 -103
  306. package/build/stories/spec/schemas/object/FormattedValue.story.js +0 -92
  307. package/build/stories/spec/schemas/object/MoneyInput.story.js +0 -240
  308. package/build/stories/spec/schemas/oneOf/OneOfInitialisation.story.js +0 -55
  309. package/build/stories/spec/schemas/oneOf/OneOfWithSingleOption.story.js +0 -114
  310. package/build/stories/spec/step/Controls.story.js +0 -109
  311. package/build/stories/spec/step/DFModal.story.js +0 -58
  312. package/build/stories/spec/step/Footer.story.js +0 -70
  313. package/build/stories/spec/step/Navigation.story.js +0 -20
  314. package/build/stories/spec/step/Tags.story.js +0 -39
  315. package/build/stories/spec/step/ToolBar.story.js +0 -60
  316. package/build/stories/spec/step/features/ErrorHandling.story.js +0 -92
  317. package/build/stories/spec/step/features/External.story.js +0 -91
  318. package/build/stories/spec/step/features/Polling.story.js +0 -108
  319. package/build/stories/spec/step/features/RefreshAfter.story.js +0 -92
  320. package/build/stories/spec/step/features/refresh/Refresh.story.js +0 -258
  321. package/build/stories/spec/step/features/refresh/RefreshWithPersistAsync.story.js +0 -958
  322. package/build/stories/types.js +0 -1
  323. package/build/stories/utils/fixtureHttpClient.js +0 -70
  324. package/build/stories/utils/getBasicStep.js +0 -223
  325. package/build/stories/utils/mockSearchHandler.js +0 -71
  326. package/build/stories/utils/render-utils.js +0 -41
  327. package/build/stories/visual-tests/layouts/NotUsingListItem.story.js +0 -17
  328. package/build/test-utils/DynamicFlowWise.js +0 -32
  329. package/build/test-utils/DynamicFlowWiseModal.js +0 -34
  330. package/build/test-utils/NeptuneProviders.js +0 -11
  331. package/build/test-utils/component-utils.js +0 -5
  332. package/build/test-utils/fetch-utils.js +0 -45
  333. package/build/test-utils/getMergedTestRenderers.js +0 -34
  334. package/build/test-utils/getRandomId.js +0 -1
  335. package/build/test-utils/index.js +0 -3
  336. package/build/test-utils/rtl-utils.js +0 -7
  337. package/build/test-utils/step-utils.js +0 -6
  338. package/build/test-utils/wait.js +0 -3
  339. package/build/tests/AlertLayout.test.js +0 -78
  340. package/build/tests/ArrayTuple.test.js +0 -118
  341. package/build/tests/ButtonLayout.test.js +0 -308
  342. package/build/tests/ConstLayout.test.js +0 -95
  343. package/build/tests/DateInput.test.js +0 -163
  344. package/build/tests/DecisionLayout.test.js +0 -146
  345. package/build/tests/DynamicFlow.test.js +0 -147
  346. package/build/tests/External.test.js +0 -169
  347. package/build/tests/Flow.test.js +0 -328
  348. package/build/tests/FormLayout.test.js +0 -28
  349. package/build/tests/FormattedValue.test.js +0 -107
  350. package/build/tests/ImageRenderer.test.js +0 -78
  351. package/build/tests/InitialAction.test.js +0 -179
  352. package/build/tests/InitialStep.test.js +0 -168
  353. package/build/tests/InstructionsLayout.test.js +0 -45
  354. package/build/tests/ListLayout.test.js +0 -145
  355. package/build/tests/Logging.test.js +0 -53
  356. package/build/tests/ModalBehavior.test.js +0 -149
  357. package/build/tests/MoneyInput.test.js +0 -316
  358. package/build/tests/MultiUpload.test.js +0 -293
  359. package/build/tests/NativeBack.test.js +0 -267
  360. package/build/tests/NoOp.test.js +0 -194
  361. package/build/tests/OneOfInitialisation.test.js +0 -571
  362. package/build/tests/PersistAsync.test.js +0 -687
  363. package/build/tests/Polling.test.js +0 -617
  364. package/build/tests/Prefetching.test.js +0 -230
  365. package/build/tests/RefreshAfter.test.js +0 -63
  366. package/build/tests/RefreshOnChange.ResponseHandling.test.js +0 -205
  367. package/build/tests/RefreshOnChange.test.js +0 -233
  368. package/build/tests/RefreshOnChange.with.Segmented.test.js +0 -348
  369. package/build/tests/RefreshOnChange.with.Tabs.test.js +0 -358
  370. package/build/tests/RefreshOnChangePreserve.test.js +0 -224
  371. package/build/tests/RendererProps.test.js +0 -342
  372. package/build/tests/Repeatable.test.js +0 -107
  373. package/build/tests/Rerendering.test.js +0 -67
  374. package/build/tests/ReviewLayout.test.js +0 -274
  375. package/build/tests/SchemaOnChange.test.js +0 -133
  376. package/build/tests/SchemaReferences.test.js +0 -88
  377. package/build/tests/ScrollToError.test.js +0 -217
  378. package/build/tests/SegmentedControl.test.js +0 -49
  379. package/build/tests/SingleFileUpload.test.js +0 -88
  380. package/build/tests/StatusList.test.js +0 -85
  381. package/build/tests/Subflow.test.js +0 -710
  382. package/build/tests/Submission.ResponseHandling.test.js +0 -557
  383. package/build/tests/Submission.merging.test.js +0 -202
  384. package/build/tests/Submission.test.js +0 -748
  385. package/build/tests/Tags.test.js +0 -475
  386. package/build/tests/Upsell.test.js +0 -154
  387. package/build/tests/ValidationAsync.test.js +0 -295
  388. package/build/tests/legacy/Actions.test.js +0 -158
  389. package/build/tests/legacy/BackButton.test.js +0 -114
  390. package/build/tests/legacy/HiddenSchemas.test.js +0 -246
  391. package/build/tests/legacy/MultiSelect.test.js +0 -501
  392. package/build/tests/legacy/MultipleFileUploadSchema.test.js +0 -341
  393. package/build/tests/legacy/PersistAsync.blob-schema.test.js +0 -224
  394. package/build/tests/legacy/PersistAsync.string-schema.test.js +0 -211
  395. package/build/tests/legacy/RefreshStepOnChange.debouncing.test.js +0 -209
  396. package/build/tests/legacy/RefreshStepOnChange.test.js +0 -424
  397. package/build/tests/legacy/Search.test.js +0 -437
  398. package/build/tests/renderers/MultiSelectInputRendererProps.test.js +0 -58
  399. package/build/tests/renderers/SelectInputRendererProps.test.js +0 -43
  400. package/build/tests/renderers/TextInputRenderer.test.js +0 -51
  401. package/build/types/utils/openLinkInNewTab.d.ts.map +0 -1
  402. package/build/types.js +0 -1
  403. package/build/useDynamicFlow.js +0 -104
  404. package/build/useDynamicFlowModal.js +0 -58
  405. package/build/utils/analyse-step.js +0 -14
  406. package/build/utils/component-utils.js +0 -8
  407. package/build/utils/component-utils.test.js +0 -113
  408. package/build/utils/getScrollToTop.js +0 -12
  409. package/build/utils/normalise-flow-id.js +0 -1
  410. package/build/utils/normalise-flow-id.test.js +0 -24
  411. package/build/utils/openLinkInNewTab.js +0 -10
  412. package/build/utils/recursiveMerge.js +0 -40
  413. package/build/utils/recursiveMerge.test.js +0 -93
  414. package/build/utils/type-utils.js +0 -21
  415. package/build/utils/type-validators.js +0 -11
  416. package/build/utils/type-validators.test.js +0 -180
  417. package/build/utils/useStableCallback.js +0 -15
  418. /package/build/types/{utils → test-utils}/openLinkInNewTab.d.ts +0 -0
@@ -1,88 +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 { getLocalValueValidator } from '../features/validation/validation-functions';
13
- import { getInputUpdateFunction } from './utils/component-utils';
14
- import { isPartialModelMatch } from './utils/isPartialModelMatch';
15
- export const createSelectInputComponent = (selectProps, onComponentUpdate) => {
16
- const { uid, checks, initialModel, options, schemaOnChange, onValueChange, summariser } = selectProps, rest = __rest(selectProps, ["uid", "checks", "initialModel", "options", "schemaOnChange", "onValueChange", "summariser"]);
17
- const children = options.map((option) => option.component);
18
- const matchingOptions = options.map((option) => isPartialModelMatch(option.component.getSubmittableValueSync(), initialModel));
19
- const selectedIndex = matchingOptions.filter((match) => match).length === 1 ? matchingOptions.indexOf(true) : null;
20
- const update = getInputUpdateFunction(onComponentUpdate);
21
- const getValidationErrors = getLocalValueValidator(checks);
22
- const component = Object.assign(Object.assign({ uid, type: 'select', kind: 'input', children,
23
- options,
24
- selectedIndex, value: null }, rest), { _update(updateFn) {
25
- update(this, updateFn);
26
- },
27
- getChildren() {
28
- return this.children;
29
- },
30
- getSelectedChild() {
31
- return this.selectedIndex !== null ? this.children[this.selectedIndex] : null;
32
- },
33
- async getSubmittableValue() {
34
- var _a, _b;
35
- return (_b = (await ((_a = this.getSelectedChild()) === null || _a === void 0 ? void 0 : _a.getSubmittableValue()))) !== null && _b !== void 0 ? _b : null;
36
- },
37
- getSubmittableValueSync() {
38
- var _a, _b;
39
- return (_b = (_a = this.getSelectedChild()) === null || _a === void 0 ? void 0 : _a.getSubmittableValueSync()) !== null && _b !== void 0 ? _b : null;
40
- },
41
- getSummary() {
42
- var _a, _b;
43
- return (_b = (_a = this.getSelectedChild()) === null || _a === void 0 ? void 0 : _a.getSummary()) !== null && _b !== void 0 ? _b : {};
44
- },
45
- getLocalValue() {
46
- var _a, _b;
47
- return (_b = (_a = this.getSelectedChild()) === null || _a === void 0 ? void 0 : _a.getLocalValue()) !== null && _b !== void 0 ? _b : null;
48
- },
49
- onBlur() {
50
- this.validate();
51
- },
52
- onFocus() { }, // noop
53
- onSelect(updatedIndex) {
54
- if (updatedIndex === this.selectedIndex) {
55
- return;
56
- }
57
- if (updatedIndex !== null) {
58
- // new event, always triggered when an option is selected
59
- selectProps.trackEvent('OneOf Option Selected', {
60
- schema: this.analyticsId,
61
- selectedOption: this.children[updatedIndex].analyticsId,
62
- });
63
- if (this.analyticsId) {
64
- // legacy event, only triggered if the main schema has an analyticsId or $id
65
- selectProps.trackEvent('OneOf Selected', {
66
- oneOfId: this.analyticsId,
67
- schemaId: this.children[updatedIndex].analyticsId,
68
- });
69
- }
70
- }
71
- this._update((draft) => {
72
- draft.errors = [];
73
- draft.selectedIndex = updatedIndex;
74
- });
75
- void (schemaOnChange === null || schemaOnChange === void 0 ? void 0 : schemaOnChange());
76
- onValueChange();
77
- },
78
- validate() {
79
- var _a, _b;
80
- const validChild = (_b = (_a = this.getSelectedChild()) === null || _a === void 0 ? void 0 : _a.validate()) !== null && _b !== void 0 ? _b : true;
81
- const errors = getValidationErrors(this.getLocalValue());
82
- this._update((draft) => {
83
- draft.errors = errors;
84
- });
85
- return errors.length === 0 && validChild;
86
- } });
87
- return component;
88
- };
@@ -1 +0,0 @@
1
- export const createStatusListComponent = (statusListProps) => (Object.assign({ type: 'status-list', kind: 'layout' }, statusListProps));
@@ -1,9 +0,0 @@
1
- import { getInputUpdateFunction } from './utils/component-utils';
2
- import { getRandomId } from './utils/getRandomId';
3
- export const createSubflowDomainComponent = (subflowProps, onComponentUpdate) => {
4
- const update = getInputUpdateFunction(onComponentUpdate);
5
- const subflowComponent = Object.assign(Object.assign({ uid: `subflow-${getRandomId()}`, type: 'subflow', kind: 'layout' }, subflowProps), { _update(updateFn) {
6
- update(this, updateFn);
7
- } });
8
- return subflowComponent;
9
- };
@@ -1 +0,0 @@
1
- export const createTabsComponent = (tabsProps) => (Object.assign(Object.assign({}, tabsProps), { type: 'tabs', kind: 'layout' }));
@@ -1,76 +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 { getDebouncedSchemaOnChange } from '../features/schema-on-change/getDebouncedSchemaOnChange';
13
- import { getLocalValueValidator } from '../features/validation/validation-functions';
14
- import { getDebouncedComponentValidationAsync } from '../features/validationAsync/getComponentValidationAsync';
15
- import { getInputUpdateFunction } from './utils/component-utils';
16
- export const createTextInputComponent = (textInputProps, onComponentUpdate) => {
17
- const { uid, id, checks, schemaOnChange, performValidationAsync, onValueChange, onPersistAsync, summariser, value } = textInputProps, rest = __rest(textInputProps, ["uid", "id", "checks", "schemaOnChange", "performValidationAsync", "onValueChange", "onPersistAsync", "summariser", "value"]);
18
- const update = getInputUpdateFunction(onComponentUpdate);
19
- const getValidationErrors = getLocalValueValidator(checks);
20
- const performOnChange = getDebouncedSchemaOnChange(schemaOnChange, getValidationErrors);
21
- const validateAsync = performValidationAsync
22
- ? getDebouncedComponentValidationAsync(update, performValidationAsync)
23
- : undefined;
24
- const inputComponent = Object.assign({ type: 'text', kind: 'input', uid,
25
- id,
26
- value,
27
- _update(updateFn) {
28
- update(this, updateFn);
29
- },
30
- onBlur() {
31
- const isValid = this.validate();
32
- performOnChange === null || performOnChange === void 0 ? void 0 : performOnChange.flush();
33
- if (isValid) {
34
- void (onPersistAsync === null || onPersistAsync === void 0 ? void 0 : onPersistAsync().catch(() => { }));
35
- validateAsync === null || validateAsync === void 0 ? void 0 : validateAsync.flush();
36
- }
37
- },
38
- onFocus() { }, // Noop
39
- onChange(updatedValue) {
40
- const prevValue = this.value;
41
- this._update((draft) => {
42
- draft.errors = [];
43
- draft.validationAsyncState.messages = {};
44
- draft.value = updatedValue;
45
- });
46
- performOnChange === null || performOnChange === void 0 ? void 0 : performOnChange(prevValue, updatedValue);
47
- const isValid = getValidationErrors(updatedValue).length === 0;
48
- if (isValid) {
49
- validateAsync === null || validateAsync === void 0 ? void 0 : validateAsync(this, updatedValue);
50
- }
51
- if (!updatedValue) {
52
- validateAsync === null || validateAsync === void 0 ? void 0 : validateAsync.cancel();
53
- }
54
- onValueChange();
55
- },
56
- async getSubmittableValue() {
57
- return this.getSubmittableValueSync();
58
- },
59
- getSubmittableValueSync() {
60
- return this.getLocalValue() || null;
61
- },
62
- getSummary() {
63
- return summariser(this.getLocalValue());
64
- },
65
- getLocalValue() {
66
- return this.value;
67
- },
68
- validate() {
69
- const errors = getValidationErrors(this.getLocalValue());
70
- this._update((draft) => {
71
- draft.errors = errors;
72
- });
73
- return errors.length === 0;
74
- } }, rest);
75
- return inputComponent;
76
- };
@@ -1,41 +0,0 @@
1
- import { mergeSummaries, summariseFromChildren } from '../features/summary/summary-utils';
2
- import { validateComponents } from '../features/validation/validation-functions';
3
- export const createTupleComponent = (tupleProps) => {
4
- const { uid, schemaId, analyticsId, alert, components, control, description, help, hidden, media, summariser, title, tags, } = tupleProps;
5
- return {
6
- type: 'tuple',
7
- kind: 'input',
8
- uid,
9
- schemaId,
10
- analyticsId,
11
- alert,
12
- components,
13
- control,
14
- description,
15
- help,
16
- hidden,
17
- media,
18
- title,
19
- tags,
20
- getChildren() {
21
- return this.components;
22
- },
23
- async getSubmittableValue() {
24
- return Promise.all(this.components.map(async (child) => child.getSubmittableValue()));
25
- },
26
- getSubmittableValueSync() {
27
- return this.components.map((child) => child.getSubmittableValueSync());
28
- },
29
- getSummary() {
30
- const summary = summariser(this.getLocalValue());
31
- const childSummary = summariseFromChildren(this.getChildren());
32
- return mergeSummaries(summary, childSummary);
33
- },
34
- getLocalValue() {
35
- return this.components.map((child) => child.getLocalValue());
36
- },
37
- validate() {
38
- return hidden ? true : validateComponents(this.getChildren());
39
- },
40
- };
41
- };
@@ -1,83 +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 { getLocalValueValidator } from '../features/validation/validation-functions';
13
- import { getInputUpdateFunction } from './utils/component-utils';
14
- import { toBase64 } from './utils/file-utils';
15
- export const createUploadInputComponent = (uploadInputProps, onComponentUpdate) => {
16
- const { uid, id, checks, format, value, schemaOnChange, onValueChange, onPersistAsync, summariser } = uploadInputProps, rest = __rest(uploadInputProps, ["uid", "id", "checks", "format", "value", "schemaOnChange", "onValueChange", "onPersistAsync", "summariser"]);
17
- const update = getInputUpdateFunction(onComponentUpdate);
18
- const getValidationErrors = getLocalValueValidator(checks);
19
- const uploadComponent = Object.assign({ type: 'upload', kind: 'input', uid,
20
- id,
21
- format,
22
- value, base64Value: null, _update(updateFn) {
23
- update(this, updateFn);
24
- },
25
- onBlur() {
26
- this.validate();
27
- },
28
- onFocus() { }, // Noop
29
- async onUpload(updatedValue) {
30
- const base64Value = this.format === 'base64' && updatedValue ? await toBase64(updatedValue) : null;
31
- this._update((draft) => {
32
- draft.errors = [];
33
- draft.value = updatedValue;
34
- draft.base64Value = base64Value;
35
- });
36
- void (schemaOnChange === null || schemaOnChange === void 0 ? void 0 : schemaOnChange());
37
- onValueChange();
38
- await (onPersistAsync === null || onPersistAsync === void 0 ? void 0 : onPersistAsync().catch((e) => {
39
- this._update((draft) => {
40
- draft.value = null;
41
- });
42
- throw e;
43
- }));
44
- },
45
- async getSubmittableValue() {
46
- const file = this.getLocalValue();
47
- if (this.format === 'base64' && file) {
48
- return toBase64(file);
49
- }
50
- return null;
51
- },
52
- getSubmittableValueSync() {
53
- return this.base64Value;
54
- },
55
- getSummary() {
56
- var _a, _b;
57
- return summariser((_b = (_a = this.getLocalValue()) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : null);
58
- },
59
- getLocalValue() {
60
- return this.value;
61
- },
62
- validate() {
63
- const errors = getValidationErrors(this.getLocalValue());
64
- this._update((draft) => {
65
- draft.errors = errors;
66
- });
67
- return errors.length === 0;
68
- } }, rest);
69
- if (format === 'base64' && value && !onPersistAsync) {
70
- void initialiseBase64Value(uploadComponent);
71
- }
72
- return uploadComponent;
73
- };
74
- const initialiseBase64Value = async (uploadComponent) => {
75
- const { format, value } = uploadComponent;
76
- const base64Value = format === 'base64' && value ? await toBase64(value) : null;
77
- if (base64Value) {
78
- // eslint-disable-next-line no-underscore-dangle
79
- uploadComponent._update((draft) => {
80
- draft.base64Value = base64Value;
81
- });
82
- }
83
- };
@@ -1,25 +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 { getInputUpdateFunction } from './utils/component-utils';
13
- export const createUpsellComponent = (upsellProps, onComponentUpdate) => {
14
- const update = getInputUpdateFunction(onComponentUpdate);
15
- const { onDismiss: propsOnDismiss } = upsellProps, restProps = __rest(upsellProps, ["onDismiss"]);
16
- const component = Object.assign(Object.assign({ type: 'upsell', kind: 'layout' }, restProps), { visible: true, onDismiss: propsOnDismiss
17
- ? () => {
18
- update(component, (draft) => {
19
- draft.visible = false;
20
- });
21
- propsOnDismiss();
22
- }
23
- : undefined });
24
- return component;
25
- };
@@ -1,92 +0,0 @@
1
- import { getInputUpdateFunction } from '../utils/component-utils';
2
- import { debounce } from '../utils/debounce';
3
- const DEBOUNCE_TIME = 400;
4
- export const createSearchComponent = (searchProps, performSearch, onBehavior, onComponentUpdate) => {
5
- const { uid, analyticsId, control, emptyMessage, initialState, hint, margin, tags, title } = searchProps;
6
- const update = getInputUpdateFunction(onComponentUpdate);
7
- let abortController = new AbortController();
8
- const search = (component, query, searchConfig) => {
9
- abortController.abort();
10
- abortController = new AbortController();
11
- const { signal } = abortController;
12
- performSearch({
13
- signal,
14
- query,
15
- config: searchConfig,
16
- })
17
- .then((state) => {
18
- if (!signal.aborted) {
19
- update(component, (draft) => {
20
- draft.state = state !== null && state !== void 0 ? state : initialState;
21
- draft.isLoading = false;
22
- draft.error = undefined;
23
- });
24
- }
25
- })
26
- .catch(() => {
27
- if (!signal.aborted) {
28
- update(component, (draft) => {
29
- draft.error = 'No response';
30
- draft.isLoading = false;
31
- });
32
- }
33
- });
34
- };
35
- const debouncedSearch = debounce(search, DEBOUNCE_TIME);
36
- const component = {
37
- type: 'search',
38
- kind: 'layout',
39
- uid,
40
- analyticsId,
41
- control,
42
- emptyMessage,
43
- initialState,
44
- hint,
45
- margin,
46
- state: initialState,
47
- tags,
48
- title,
49
- isLoading: false,
50
- query: '',
51
- _update(updateFn) {
52
- update(this, updateFn);
53
- },
54
- onChange(query) {
55
- if (query.trim()) {
56
- this._update((draft) => {
57
- draft.query = query;
58
- draft.isLoading = true;
59
- });
60
- debouncedSearch(this, query.trim());
61
- }
62
- else {
63
- // if the query is empty, we want to reset to the initial state immediately
64
- abortController.abort();
65
- debouncedSearch.cancel();
66
- update(component, (draft) => {
67
- draft.query = query;
68
- draft.state = initialState;
69
- draft.isLoading = false;
70
- draft.error = undefined;
71
- });
72
- }
73
- },
74
- onSelect({ type, value }) {
75
- if (type === 'action') {
76
- void onBehavior({ type: 'action', action: value });
77
- }
78
- else {
79
- this._update((draft) => {
80
- draft.query = value.query;
81
- draft.isLoading = true;
82
- });
83
- search(this, value.query, {
84
- method: value.method,
85
- param: value.param,
86
- url: value.url,
87
- });
88
- }
89
- },
90
- };
91
- return component;
92
- };
@@ -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,28 +0,0 @@
1
- import { getInputUpdateFunction } from '../utils/component-utils';
2
- export const createExternalConfirmation = (uid, url, onComponentUpdate) => {
3
- const update = getInputUpdateFunction(onComponentUpdate);
4
- return {
5
- type: 'external-confirmation',
6
- kind: 'layout',
7
- uid,
8
- url,
9
- status: 'initial',
10
- onSuccess() {
11
- update(this, (draft) => {
12
- draft.status = 'success';
13
- });
14
- },
15
- onFailure() {
16
- if (this.status === 'initial') {
17
- update(this, (draft) => {
18
- draft.status = 'failure';
19
- });
20
- }
21
- },
22
- onCancel() {
23
- update(this, (draft) => {
24
- draft.status = 'dismissed';
25
- });
26
- },
27
- };
28
- };