@wise/dynamic-flow-client 5.9.2-logging-bf0bd22 → 5.9.2

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 (402) hide show
  1. package/build/DynamicFlowCore.js +5 -0
  2. package/build/common/errorBoundary/ErrorBoundary.js +26 -0
  3. package/build/common/errorBoundary/ErrorBoundary.test.js +29 -0
  4. package/build/common/errorBoundary/ErrorBoundaryAlert.js +11 -0
  5. package/build/common/makeHttpClient/api-utils.js +3 -0
  6. package/build/common/makeHttpClient/index.js +1 -0
  7. package/build/common/makeHttpClient/makeHttpClient.js +10 -0
  8. package/build/common/makeHttpClient/makeHttpClient.test.js +186 -0
  9. package/build/common/messages/external-confirmation.messages.js +23 -0
  10. package/build/common/messages/file-upload.messages.js +13 -0
  11. package/build/common/messages/generic-error.messages.js +18 -0
  12. package/build/common/messages/help.messages.js +8 -0
  13. package/build/common/messages/multi-file-upload.messages.js +18 -0
  14. package/build/common/messages/multi-select.messages.js +8 -0
  15. package/build/common/messages/paragraph.messages.js +13 -0
  16. package/build/common/messages/repeatable.messages.js +23 -0
  17. package/build/common/messages/search.messages.js +8 -0
  18. package/build/common/messages/validation.array.messages.js +13 -0
  19. package/build/common/messages/validation.messages.js +53 -0
  20. package/build/controller/FlowController.js +368 -0
  21. package/build/controller/executePoll.js +49 -0
  22. package/build/controller/executeRefresh.js +39 -0
  23. package/build/controller/executeRequest.js +77 -0
  24. package/build/controller/executeSubmission.js +69 -0
  25. package/build/controller/getErrorMessage.js +7 -0
  26. package/build/controller/getRequestAbortController.js +13 -0
  27. package/build/controller/getResponseType.js +35 -0
  28. package/build/controller/getSafeHttpClient.js +8 -0
  29. package/build/controller/getStepCounter.js +16 -0
  30. package/build/controller/handleErrorResponse.js +26 -0
  31. package/build/controller/makeSafeHttpClient.js +8 -0
  32. package/build/controller/response-utils.js +72 -0
  33. package/build/domain/components/AlertComponent.js +1 -0
  34. package/build/domain/components/AllOfComponent.js +40 -0
  35. package/build/domain/components/BooleanInputComponent.js +50 -0
  36. package/build/domain/components/BoxComponent.js +3 -0
  37. package/build/domain/components/ButtonComponent.js +1 -0
  38. package/build/domain/components/ColumnsComponent.js +3 -0
  39. package/build/domain/components/ConstComponent.js +18 -0
  40. package/build/domain/components/ContainerComponent.js +3 -0
  41. package/build/domain/components/DateInputComponent.js +75 -0
  42. package/build/domain/components/DecisionComponent.js +1 -0
  43. package/build/domain/components/DividerComponent.js +1 -0
  44. package/build/domain/components/FormComponent.js +3 -0
  45. package/build/domain/components/FormattedValueComponent.js +44 -0
  46. package/build/domain/components/HeadingComponent.js +1 -0
  47. package/build/domain/components/ImageComponent.js +1 -0
  48. package/build/domain/components/InstructionsComponent.js +1 -0
  49. package/build/domain/components/IntegerInputComponent.js +74 -0
  50. package/build/domain/components/ListComponent.js +1 -0
  51. package/build/domain/components/LoadingIndicatorComponent.js +1 -0
  52. package/build/domain/components/MarkdownComponent.js +1 -0
  53. package/build/domain/components/MediaComponent.js +1 -0
  54. package/build/domain/components/ModalComponent.js +16 -0
  55. package/build/domain/components/ModalLayoutComponent.js +3 -0
  56. package/build/domain/components/MoneyInputComponent.js +57 -0
  57. package/build/domain/components/MultiSelectInputComponent.js +81 -0
  58. package/build/domain/components/MultiUploadInputComponent.js +88 -0
  59. package/build/domain/components/NumberInputComponent.js +73 -0
  60. package/build/domain/components/ObjectComponent.js +45 -0
  61. package/build/domain/components/ParagraphComponent.js +1 -0
  62. package/build/domain/components/PersistAsyncComponent.js +92 -0
  63. package/build/domain/components/ProgressComponent.js +1 -0
  64. package/build/domain/components/RepeatableComponent.js +103 -0
  65. package/build/domain/components/ReviewComponent.js +1 -0
  66. package/build/domain/components/RootDomainComponent.js +173 -0
  67. package/build/domain/components/SectionComponent.js +5 -0
  68. package/build/domain/components/SelectInputComponent.js +88 -0
  69. package/build/domain/components/StatusListComponent.js +1 -0
  70. package/build/domain/components/SubflowDomainComponent.js +9 -0
  71. package/build/domain/components/TabsComponent.js +1 -0
  72. package/build/domain/components/TextInputComponent.js +76 -0
  73. package/build/domain/components/TupleComponent.js +41 -0
  74. package/build/domain/components/UploadInputComponent.js +83 -0
  75. package/build/domain/components/UpsellComponent.js +25 -0
  76. package/build/domain/components/searchComponent/SearchComponent.js +92 -0
  77. package/build/domain/components/searchComponent/SearchComponent.test.js +190 -0
  78. package/build/domain/components/step/ExternalConfirmationComponent.js +28 -0
  79. package/build/domain/components/step/StepDomainComponent.js +78 -0
  80. package/build/domain/components/step/ToolbarComponent.js +1 -0
  81. package/build/domain/components/utils/WithUpdate.js +1 -0
  82. package/build/domain/components/utils/component-utils.js +12 -0
  83. package/build/domain/components/utils/debounce.js +34 -0
  84. package/build/domain/components/utils/debounce.test.js +67 -0
  85. package/build/domain/components/utils/file-utils.js +21 -0
  86. package/build/domain/components/utils/file-utils.test.js +27 -0
  87. package/build/domain/components/utils/getRandomId.js +1 -0
  88. package/build/domain/components/utils/isExactLocalValueMatch.js +14 -0
  89. package/build/domain/components/utils/isOrWasValid.js +5 -0
  90. package/build/domain/components/utils/isPartialModelMatch.js +18 -0
  91. package/build/domain/components/utils/isPartialModelMatch.test.js +74 -0
  92. package/build/domain/features/eventNames.js +24 -0
  93. package/build/domain/features/events.js +1 -0
  94. package/build/domain/features/persistAsync/getComponentMultiPersistAsync.js +50 -0
  95. package/build/domain/features/persistAsync/getInitialPersistedState.js +7 -0
  96. package/build/domain/features/persistAsync/getPerformPersistAsync.js +43 -0
  97. package/build/domain/features/persistAsync/getPerformPersistAsync.test.js +139 -0
  98. package/build/domain/features/polling/getStepPolling.js +43 -0
  99. package/build/domain/features/polling/getStepPolling.test.js +90 -0
  100. package/build/domain/features/prefetch/getStepPrefetch.js +43 -0
  101. package/build/domain/features/prefetch/request-cache.js +49 -0
  102. package/build/domain/features/prefetch/request-cache.test.js +70 -0
  103. package/build/domain/features/refreshAfter/getStepRefreshAfter.js +24 -0
  104. package/build/domain/features/refreshAfter/getStepRefreshAfter.test.js +40 -0
  105. package/build/domain/features/schema-on-change/getDebouncedSchemaOnChange.js +50 -0
  106. package/build/domain/features/schema-on-change/getSchemaOnChange.js +34 -0
  107. package/build/domain/features/search/getPerformSearchFunction.js +75 -0
  108. package/build/domain/features/search/getPerformSearchFunction.test.js +301 -0
  109. package/build/domain/features/summary/summary-utils.js +40 -0
  110. package/build/domain/features/summary/summary-utils.test.js +125 -0
  111. package/build/domain/features/utils/http-utils.js +21 -0
  112. package/build/domain/features/utils/response-utils.js +9 -0
  113. package/build/domain/features/validation/spec-utils.js +19 -0
  114. package/build/domain/features/validation/validateStringPattern.js +24 -0
  115. package/build/domain/features/validation/validation-functions.js +6 -0
  116. package/build/domain/features/validation/validation-functions.test.js +108 -0
  117. package/build/domain/features/validation/value-checks.js +125 -0
  118. package/build/domain/features/validation/value-checks.test.js +262 -0
  119. package/build/domain/features/validationAsync/getComponentValidationAsync.js +53 -0
  120. package/build/domain/features/validationAsync/getComponentValidationAsync.test.js +67 -0
  121. package/build/domain/features/validationAsync/getInitialValidationAsyncState.js +5 -0
  122. package/build/domain/features/validationAsync/getPerformValidationAsync.js +45 -0
  123. package/build/domain/features/validationAsync/getPerformValidationAsync.test.js +143 -0
  124. package/build/domain/mappers/layout/alertLayoutToComponent.js +16 -0
  125. package/build/domain/mappers/layout/boxLayoutToComponent.js +13 -0
  126. package/build/domain/mappers/layout/buttonLayoutToComponent.js +77 -0
  127. package/build/domain/mappers/layout/columnsLayoutToComponent.js +13 -0
  128. package/build/domain/mappers/layout/decisionLayoutToComponent.js +22 -0
  129. package/build/domain/mappers/layout/deprecatedListLayoutToComponent.js +30 -0
  130. package/build/domain/mappers/layout/dividerLayoutToComponent.js +2 -0
  131. package/build/domain/mappers/layout/formLayoutToComponent.js +19 -0
  132. package/build/domain/mappers/layout/headingLayoutToComponent.js +12 -0
  133. package/build/domain/mappers/layout/imageLayoutToComponent.js +20 -0
  134. package/build/domain/mappers/layout/infoLayoutToComponent.js +12 -0
  135. package/build/domain/mappers/layout/instructionsLayoutToComponent.js +12 -0
  136. package/build/domain/mappers/layout/listLayoutToComponent.js +39 -0
  137. package/build/domain/mappers/layout/loadingIndicatorLayoutToComponent.js +9 -0
  138. package/build/domain/mappers/layout/markdownLayoutToComponent.js +12 -0
  139. package/build/domain/mappers/layout/mediaLayoutToComponent.js +12 -0
  140. package/build/domain/mappers/layout/modalLayoutToComponent.js +17 -0
  141. package/build/domain/mappers/layout/modalToComponent.js +8 -0
  142. package/build/domain/mappers/layout/paragraphLayoutToComponent.js +12 -0
  143. package/build/domain/mappers/layout/progressLayoutToComponent.js +15 -0
  144. package/build/domain/mappers/layout/reviewLayoutToComponent.js +48 -0
  145. package/build/domain/mappers/layout/searchLayoutToComponent.js +44 -0
  146. package/build/domain/mappers/layout/sectionLayoutToComponent.js +15 -0
  147. package/build/domain/mappers/layout/statusListLayoutToComponent.js +15 -0
  148. package/build/domain/mappers/layout/tabsLayoutToComponent.js +16 -0
  149. package/build/domain/mappers/layout/upsellLayoutToComponent.js +25 -0
  150. package/build/domain/mappers/mapLayoutToComponent.js +81 -0
  151. package/build/domain/mappers/mapSchemaToComponent.js +61 -0
  152. package/build/domain/mappers/mapSchemaToComponent.test.js +112 -0
  153. package/build/domain/mappers/mapStepSchemas.js +15 -0
  154. package/build/domain/mappers/mapStepToComponent.js +133 -0
  155. package/build/domain/mappers/mapStepToComponent.test.js +221 -0
  156. package/build/domain/mappers/mapToolbarToComponent.js +15 -0
  157. package/build/domain/mappers/schema/allOfSchemaToComponent.js +16 -0
  158. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToComponent.js +26 -0
  159. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiSelectComponent.js +55 -0
  160. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToMultiUploadComponent.js +67 -0
  161. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToRepeatableComponent.js +57 -0
  162. package/build/domain/mappers/schema/arraySchemaToComponent/arraySchemaToTupleComponent.js +20 -0
  163. package/build/domain/mappers/schema/blobSchemaToComponent.js +15 -0
  164. package/build/domain/mappers/schema/booleanSchemaToComponent.js +29 -0
  165. package/build/domain/mappers/schema/constSchemaToComponent.js +23 -0
  166. package/build/domain/mappers/schema/integerSchemaToComponent.js +28 -0
  167. package/build/domain/mappers/schema/numberSchemaToComponent.js +26 -0
  168. package/build/domain/mappers/schema/objectSchemaToComponent/assertDisplayOrder.js +23 -0
  169. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToFormattedValueComponent.js +9 -0
  170. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.js +119 -0
  171. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToMoneyInputComponent.test.js +96 -0
  172. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.js +31 -0
  173. package/build/domain/mappers/schema/objectSchemaToComponent/objectSchemaToObjectComponent.test.js +99 -0
  174. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.js +66 -0
  175. package/build/domain/mappers/schema/oneOfSchemaToComponent/oneOfSchemaToComponent.test.js +225 -0
  176. package/build/domain/mappers/schema/persistAsyncSchemaToComponent.js +29 -0
  177. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.js +18 -0
  178. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToComponent.test.js +133 -0
  179. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToDateInputComponent.js +48 -0
  180. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToTextInputComponent.js +37 -0
  181. package/build/domain/mappers/schema/stringSchemaToComponent/stringSchemaToUploadInputComponent.js +28 -0
  182. package/build/domain/mappers/schema/tests/test-utils.js +16 -0
  183. package/build/domain/mappers/schema/types.js +1 -0
  184. package/build/domain/mappers/schema/utils/getPerformPersistAsyncFn.js +19 -0
  185. package/build/domain/mappers/schema/utils/getValidationAsyncInitialState.js +23 -0
  186. package/build/domain/mappers/schema/utils/mapCommonSchemaProps.js +16 -0
  187. package/build/domain/mappers/types.js +1 -0
  188. package/build/domain/mappers/utils/FeatureFlags.js +22 -0
  189. package/build/domain/mappers/utils/behavior-utils.js +44 -0
  190. package/build/domain/mappers/utils/call-to-action-utils.js +21 -0
  191. package/build/domain/mappers/utils/getAutocompleteString.js +76 -0
  192. package/build/domain/mappers/utils/getAutocompleteString.test.js +21 -0
  193. package/build/domain/mappers/utils/groupLayoutByPinned.js +38 -0
  194. package/build/domain/mappers/utils/groupLayoutByPinned.test.js +166 -0
  195. package/build/domain/mappers/utils/image.js +9 -0
  196. package/build/domain/mappers/utils/layout-utils.js +11 -0
  197. package/build/domain/mappers/utils/legacy-utils.js +49 -0
  198. package/build/domain/mappers/utils/media-utils.js +14 -0
  199. package/build/domain/mappers/utils/suggestions-utils.js +26 -0
  200. package/build/domain/mappers/utils/suggestions-utils.test.js +36 -0
  201. package/build/domain/mappers/utils/tags-utils.js +1 -0
  202. package/build/domain/mappers/utils/utils.js +35 -0
  203. package/build/domain/types.js +1 -0
  204. package/build/getSubflowCallbacks.js +38 -0
  205. package/build/i18n/index.js +40 -0
  206. package/build/index.js +8 -0
  207. package/build/main.js +1 -7
  208. package/build/main.mjs +1 -7
  209. package/build/renderers/CoreContainerRenderer.js +5 -0
  210. package/build/renderers/CoreRootRenderer.js +12 -0
  211. package/build/renderers/EmptyLoadingStateRenderer.js +5 -0
  212. package/build/renderers/getRenderFunction.js +24 -0
  213. package/build/renderers/getSchemaErrorMessageFunction.js +97 -0
  214. package/build/renderers/mappers/alertComponentToProps.js +2 -0
  215. package/build/renderers/mappers/allOfComponentToProps.js +6 -0
  216. package/build/renderers/mappers/booleanInputComponentToProps.js +5 -0
  217. package/build/renderers/mappers/boxComponentToProps.js +13 -0
  218. package/build/renderers/mappers/buttonComponentToProps.js +4 -0
  219. package/build/renderers/mappers/columnsComponentToProps.js +11 -0
  220. package/build/renderers/mappers/componentToRendererProps.js +164 -0
  221. package/build/renderers/mappers/constComponentToProps.js +5 -0
  222. package/build/renderers/mappers/containerComponentToProps.js +7 -0
  223. package/build/renderers/mappers/dateInputComponentToProps.js +2 -0
  224. package/build/renderers/mappers/decisionComponentToProps.js +16 -0
  225. package/build/renderers/mappers/dividerComponentToProps.js +2 -0
  226. package/build/renderers/mappers/externalComponentToProps.js +3 -0
  227. package/build/renderers/mappers/formComponentToProps.js +12 -0
  228. package/build/renderers/mappers/formattedValueComponentToProps.js +5 -0
  229. package/build/renderers/mappers/headingComponentToProps.js +2 -0
  230. package/build/renderers/mappers/hiddenComponentToProps.js +4 -0
  231. package/build/renderers/mappers/imageComponentToProps.js +2 -0
  232. package/build/renderers/mappers/instructionsComponentToProps.js +2 -0
  233. package/build/renderers/mappers/integerInputComponentToProps.js +2 -0
  234. package/build/renderers/mappers/listComponentToProps.js +2 -0
  235. package/build/renderers/mappers/loadingIndicatorComponentToProps.js +2 -0
  236. package/build/renderers/mappers/markdownComponentToProps.js +2 -0
  237. package/build/renderers/mappers/mediaComponentToProps.js +2 -0
  238. package/build/renderers/mappers/modalComponentToProps.js +11 -0
  239. package/build/renderers/mappers/modalLayoutComponentToProps.js +16 -0
  240. package/build/renderers/mappers/moneyInputComponentToProps.js +36 -0
  241. package/build/renderers/mappers/multiSelectComponentToProps.js +23 -0
  242. package/build/renderers/mappers/multiUploadInputComponentToProps.js +12 -0
  243. package/build/renderers/mappers/numberInputComponentToProps.js +2 -0
  244. package/build/renderers/mappers/objectComponentToProps.js +8 -0
  245. package/build/renderers/mappers/paragraphComponentToProps.js +2 -0
  246. package/build/renderers/mappers/persistAsyncComponentToProps.js +8 -0
  247. package/build/renderers/mappers/progressComponentToProps.js +2 -0
  248. package/build/renderers/mappers/repeatableComponentToProps.js +30 -0
  249. package/build/renderers/mappers/reviewComponentToProps.js +2 -0
  250. package/build/renderers/mappers/rootComponentToProps.js +21 -0
  251. package/build/renderers/mappers/searchComponentToProps.js +57 -0
  252. package/build/renderers/mappers/sectionComponentToProps.js +6 -0
  253. package/build/renderers/mappers/selectInputComponentToProps.js +34 -0
  254. package/build/renderers/mappers/statusListComponentToProps.js +2 -0
  255. package/build/renderers/mappers/subflowComponentToRendererProps.js +4 -0
  256. package/build/renderers/mappers/tabsComponentToProps.js +14 -0
  257. package/build/renderers/mappers/textInputComponentToProps.js +2 -0
  258. package/build/renderers/mappers/tupleComponentToProps.js +8 -0
  259. package/build/renderers/mappers/uploadInputComponentToProps.js +8 -0
  260. package/build/renderers/mappers/upsellComponentToProps.js +2 -0
  261. package/build/renderers/mappers/utils/getValidationState.js +12 -0
  262. package/build/renderers/mappers/utils/inputComponentToProps.js +26 -0
  263. package/build/renderers/mappers/utils/mapErrorsToValidationState.js +9 -0
  264. package/build/renderers/mappers/utils/pick.js +8 -0
  265. package/build/renderers/mappers/utils/selectInputOptionsToProps.js +11 -0
  266. package/build/renderers/stepComponentToProps.js +32 -0
  267. package/build/renderers/utils.js +69 -0
  268. package/build/renderers/utils.test.js +70 -0
  269. package/build/stories/dev-tools/ContainerQueries.story.js +66 -0
  270. package/build/stories/dev-tools/Debugger.story.js +38 -0
  271. package/build/stories/dev-tools/FixtureSelect.story.js +23 -0
  272. package/build/stories/dev-tools/TestServer.story.js +32 -0
  273. package/build/stories/examples/NativeFlow.story.js +80 -0
  274. package/build/stories/examples/Recipients.story.js +568 -0
  275. package/build/stories/spec/behavior/Copy.story.js +59 -0
  276. package/build/stories/spec/behavior/Modal.story.js +76 -0
  277. package/build/stories/spec/behavior/Subflow.story.js +267 -0
  278. package/build/stories/spec/layouts/Decision.story.js +241 -0
  279. package/build/stories/spec/layouts/Image.story.js +42 -0
  280. package/build/stories/spec/layouts/Modal.story.js +81 -0
  281. package/build/stories/spec/layouts/Search.story.js +325 -0
  282. package/build/stories/spec/layouts/Upsell.story.js +55 -0
  283. package/build/stories/spec/layouts/button/Button.story.js +100 -0
  284. package/build/stories/spec/layouts/button/PinnedButton.story.js +81 -0
  285. package/build/stories/spec/response/ActionResponse.story.js +66 -0
  286. package/build/stories/spec/schemas/MultiSelect.story.js +148 -0
  287. package/build/stories/spec/schemas/Upload.story.js +168 -0
  288. package/build/stories/spec/schemas/const/ConstLayout.story.js +159 -0
  289. package/build/stories/spec/schemas/const/ObjectConst.story.js +94 -0
  290. package/build/stories/spec/schemas/features/PersistAsync.story.js +211 -0
  291. package/build/stories/spec/schemas/features/ValidationAsync.story.js +103 -0
  292. package/build/stories/spec/schemas/object/FormattedValue.story.js +92 -0
  293. package/build/stories/spec/schemas/object/MoneyInput.story.js +240 -0
  294. package/build/stories/spec/schemas/oneOf/OneOfInitialisation.story.js +55 -0
  295. package/build/stories/spec/schemas/oneOf/OneOfWithSingleOption.story.js +114 -0
  296. package/build/stories/spec/step/Controls.story.js +109 -0
  297. package/build/stories/spec/step/DFModal.story.js +58 -0
  298. package/build/stories/spec/step/Footer.story.js +70 -0
  299. package/build/stories/spec/step/Navigation.story.js +20 -0
  300. package/build/stories/spec/step/Tags.story.js +39 -0
  301. package/build/stories/spec/step/ToolBar.story.js +60 -0
  302. package/build/stories/spec/step/features/ErrorHandling.story.js +92 -0
  303. package/build/stories/spec/step/features/External.story.js +91 -0
  304. package/build/stories/spec/step/features/Polling.story.js +108 -0
  305. package/build/stories/spec/step/features/RefreshAfter.story.js +92 -0
  306. package/build/stories/spec/step/features/refresh/Refresh.story.js +258 -0
  307. package/build/stories/spec/step/features/refresh/RefreshWithPersistAsync.story.js +958 -0
  308. package/build/stories/types.js +1 -0
  309. package/build/stories/utils/fixtureHttpClient.js +70 -0
  310. package/build/stories/utils/getBasicStep.js +223 -0
  311. package/build/stories/utils/mockSearchHandler.js +71 -0
  312. package/build/stories/utils/render-utils.js +41 -0
  313. package/build/stories/visual-tests/layouts/NotUsingListItem.story.js +17 -0
  314. package/build/test-utils/DynamicFlowWise.js +32 -0
  315. package/build/test-utils/DynamicFlowWiseModal.js +34 -0
  316. package/build/test-utils/NeptuneProviders.js +11 -0
  317. package/build/test-utils/component-utils.js +5 -0
  318. package/build/test-utils/fetch-utils.js +45 -0
  319. package/build/test-utils/getMergedTestRenderers.js +34 -0
  320. package/build/test-utils/getRandomId.js +1 -0
  321. package/build/test-utils/index.js +3 -0
  322. package/build/test-utils/rtl-utils.js +7 -0
  323. package/build/test-utils/step-utils.js +6 -0
  324. package/build/test-utils/wait.js +3 -0
  325. package/build/tests/AlertLayout.test.js +78 -0
  326. package/build/tests/ArrayTuple.test.js +118 -0
  327. package/build/tests/ButtonLayout.test.js +308 -0
  328. package/build/tests/ConstLayout.test.js +95 -0
  329. package/build/tests/DateInput.test.js +163 -0
  330. package/build/tests/DecisionLayout.test.js +146 -0
  331. package/build/tests/DynamicFlow.test.js +147 -0
  332. package/build/tests/External.test.js +169 -0
  333. package/build/tests/Flow.test.js +328 -0
  334. package/build/tests/FormLayout.test.js +28 -0
  335. package/build/tests/FormattedValue.test.js +107 -0
  336. package/build/tests/ImageRenderer.test.js +78 -0
  337. package/build/tests/InitialAction.test.js +179 -0
  338. package/build/tests/InitialStep.test.js +168 -0
  339. package/build/tests/InstructionsLayout.test.js +45 -0
  340. package/build/tests/ListLayout.test.js +145 -0
  341. package/build/tests/Logging.test.js +53 -0
  342. package/build/tests/ModalBehavior.test.js +149 -0
  343. package/build/tests/MoneyInput.test.js +316 -0
  344. package/build/tests/MultiUpload.test.js +293 -0
  345. package/build/tests/NativeBack.test.js +267 -0
  346. package/build/tests/OneOfInitialisation.test.js +571 -0
  347. package/build/tests/PersistAsync.test.js +687 -0
  348. package/build/tests/Polling.test.js +617 -0
  349. package/build/tests/Prefetching.test.js +230 -0
  350. package/build/tests/RefreshAfter.test.js +63 -0
  351. package/build/tests/RefreshOnChange.ResponseHandling.test.js +205 -0
  352. package/build/tests/RefreshOnChange.test.js +233 -0
  353. package/build/tests/RefreshOnChange.with.Segmented.test.js +348 -0
  354. package/build/tests/RefreshOnChange.with.Tabs.test.js +358 -0
  355. package/build/tests/RefreshOnChangePreserve.test.js +224 -0
  356. package/build/tests/RendererProps.test.js +342 -0
  357. package/build/tests/Repeatable.test.js +107 -0
  358. package/build/tests/Rerendering.test.js +67 -0
  359. package/build/tests/ReviewLayout.test.js +274 -0
  360. package/build/tests/SchemaOnChange.test.js +133 -0
  361. package/build/tests/SchemaReferences.test.js +88 -0
  362. package/build/tests/ScrollToError.test.js +217 -0
  363. package/build/tests/SegmentedControl.test.js +49 -0
  364. package/build/tests/SingleFileUpload.test.js +88 -0
  365. package/build/tests/StatusList.test.js +85 -0
  366. package/build/tests/Subflow.test.js +710 -0
  367. package/build/tests/Submission.ResponseHandling.test.js +557 -0
  368. package/build/tests/Submission.merging.test.js +202 -0
  369. package/build/tests/Submission.test.js +603 -0
  370. package/build/tests/Tags.test.js +475 -0
  371. package/build/tests/Upsell.test.js +126 -0
  372. package/build/tests/ValidationAsync.test.js +295 -0
  373. package/build/tests/legacy/Actions.test.js +158 -0
  374. package/build/tests/legacy/BackButton.test.js +114 -0
  375. package/build/tests/legacy/HiddenSchemas.test.js +246 -0
  376. package/build/tests/legacy/MultiSelect.test.js +501 -0
  377. package/build/tests/legacy/MultipleFileUploadSchema.test.js +341 -0
  378. package/build/tests/legacy/PersistAsync.blob-schema.test.js +224 -0
  379. package/build/tests/legacy/PersistAsync.string-schema.test.js +211 -0
  380. package/build/tests/legacy/RefreshStepOnChange.debouncing.test.js +209 -0
  381. package/build/tests/legacy/RefreshStepOnChange.test.js +424 -0
  382. package/build/tests/legacy/Search.test.js +437 -0
  383. package/build/tests/renderers/MultiSelectInputRendererProps.test.js +58 -0
  384. package/build/tests/renderers/SelectInputRendererProps.test.js +43 -0
  385. package/build/tests/renderers/TextInputRenderer.test.js +51 -0
  386. package/build/types.js +1 -0
  387. package/build/useDynamicFlow.js +104 -0
  388. package/build/useDynamicFlowModal.js +58 -0
  389. package/build/utils/analyse-step.js +14 -0
  390. package/build/utils/component-utils.js +8 -0
  391. package/build/utils/component-utils.test.js +113 -0
  392. package/build/utils/getScrollToTop.js +12 -0
  393. package/build/utils/normalise-flow-id.js +1 -0
  394. package/build/utils/normalise-flow-id.test.js +24 -0
  395. package/build/utils/openLinkInNewTab.js +10 -0
  396. package/build/utils/recursiveMerge.js +40 -0
  397. package/build/utils/recursiveMerge.test.js +93 -0
  398. package/build/utils/type-utils.js +21 -0
  399. package/build/utils/type-validators.js +11 -0
  400. package/build/utils/type-validators.test.js +180 -0
  401. package/build/utils/useStableCallback.js +15 -0
  402. package/package.json +10 -10
@@ -0,0 +1,66 @@
1
+ import { getMockHttpClient, respondWith } from '../../../test-utils';
2
+ import DynamicFlowWise from '../../../test-utils/DynamicFlowWise';
3
+ import { renderWithStep } from '../../utils/render-utils';
4
+ export default {
5
+ component: DynamicFlowWise,
6
+ title: 'Spec/Response',
7
+ parameters: {
8
+ chromatic: { disableSnapshot: true },
9
+ },
10
+ argTypes: {},
11
+ };
12
+ export function ActionResponse() {
13
+ const httpClient = getMockHttpClient({
14
+ '/action/1234': async () => respondWith({ action: { url: '/success', data: { actionResponse: 'Action response action.data' } } }, { status: 200 }),
15
+ '/success': async () => respondWith(Object.assign(Object.assign({}, initialStep), { title: 'Success, try again!' })),
16
+ });
17
+ return renderWithStep(initialStep, httpClient);
18
+ }
19
+ const initialStep = {
20
+ id: 'action-response',
21
+ title: 'Action Response',
22
+ layout: [
23
+ {
24
+ type: 'box',
25
+ width: 'md',
26
+ border: true,
27
+ components: [
28
+ {
29
+ type: 'form',
30
+ schemaId: '#referenced-schema',
31
+ },
32
+ {
33
+ type: 'button',
34
+ title: 'Direct Success ("/success")',
35
+ control: 'primary',
36
+ action: { url: '/success', data: { direct: 'direct success button action data' } },
37
+ },
38
+ {
39
+ type: 'button',
40
+ title: 'Action Response ("/action/1234")',
41
+ control: 'primary',
42
+ action: { url: '/action/1234' },
43
+ },
44
+ { type: 'divider' },
45
+ {
46
+ type: 'markdown',
47
+ content: 'You can inspect the payload of every request using the Storybook "Actions" panel.\n\nWe expect the schema values to be part of the payload when triggering an action from a button.\n\nBut when the action is triggered as a result of an action response, only the `action.data` should be in the payload.',
48
+ },
49
+ ],
50
+ },
51
+ ],
52
+ schemas: [
53
+ {
54
+ $id: '#unreferenced-schema',
55
+ const: { unreferenced: 'schema-value' },
56
+ },
57
+ {
58
+ $id: '#referenced-schema',
59
+ type: 'object',
60
+ displayOrder: ['name'],
61
+ properties: {
62
+ name: { type: 'string', title: 'Name', default: 'John Doe' },
63
+ },
64
+ },
65
+ ],
66
+ };
@@ -0,0 +1,148 @@
1
+ import DynamicFlowWise from '../../../test-utils/DynamicFlowWise';
2
+ import { renderWithStep } from '../../utils/render-utils';
3
+ export default {
4
+ component: DynamicFlowWise,
5
+ title: 'Spec/Schemas/MultiSelect',
6
+ parameters: {
7
+ chromatic: { disableSnapshot: true },
8
+ },
9
+ };
10
+ export function MultiSelect() {
11
+ return renderWithStep(getStep(undefined));
12
+ }
13
+ export function InlineMultiSelect() {
14
+ return renderWithStep(getStep('inline'));
15
+ }
16
+ const getStep = (arraySchemaControl) => ({
17
+ id: 'multi-select',
18
+ title: 'A multiselect example',
19
+ layout: [
20
+ {
21
+ type: 'form',
22
+ schemaId: '#schema',
23
+ },
24
+ { type: 'button', action: { url: '/submit' }, title: 'Submit' },
25
+ ],
26
+ schemas: [
27
+ {
28
+ $id: '#schema',
29
+ type: 'object',
30
+ displayOrder: ['arrayField'],
31
+ required: ['arrayField'],
32
+ properties: {
33
+ arrayField: {
34
+ validationMessages: {
35
+ required: 'Please select at least two options. (required)',
36
+ },
37
+ type: 'array',
38
+ control: arraySchemaControl,
39
+ title: 'Select between two and four options',
40
+ minItems: 2,
41
+ maxItems: 4,
42
+ description: 'This is an example of an array schema with const options.',
43
+ addItemTitle: '',
44
+ editItemTitle: '',
45
+ validationAsync: {
46
+ url: '/validate',
47
+ method: 'POST',
48
+ param: 'value',
49
+ },
50
+ items: {
51
+ title: 'Select with few options',
52
+ description: 'A description of the select.',
53
+ oneOf: [
54
+ {
55
+ title: 'EUR',
56
+ description: 'Euro',
57
+ icon: { name: 'flag-eur' },
58
+ const: 'EUR',
59
+ inlineAlert: {
60
+ context: 'info',
61
+ content: 'This is an inline alert',
62
+ },
63
+ supportingValues: {
64
+ value: '0.05%',
65
+ subvalue: 'Fee',
66
+ },
67
+ },
68
+ {
69
+ title: 'GBP',
70
+ description: 'British pound',
71
+ icon: { name: 'flag-gbp' },
72
+ const: 'GBP',
73
+ disabled: true,
74
+ supportingValues: {
75
+ value: '0.00%',
76
+ subvalue: 'Fee',
77
+ },
78
+ },
79
+ {
80
+ title: 'USD',
81
+ description: 'US dollar',
82
+ icon: { name: 'flag-usd' },
83
+ const: 'USD',
84
+ supportingValues: {
85
+ value: '0.08%',
86
+ subvalue: 'Fee',
87
+ },
88
+ inlineAlert: {
89
+ context: 'warning',
90
+ content: 'This is a warning inline alert',
91
+ },
92
+ },
93
+ {
94
+ title: 'AUD',
95
+ description: 'Australian dollar',
96
+ icon: { name: 'flag-aud' },
97
+ const: 'AUD',
98
+ additionalText: 'Additional text can be long in Australia.',
99
+ supportingValues: {
100
+ value: '0.08%',
101
+ subvalue: 'Fee',
102
+ },
103
+ },
104
+ {
105
+ title: 'NZD',
106
+ description: 'New Zealand dollar',
107
+ icon: { name: 'flag-nzd' },
108
+ const: 'NZD',
109
+ supportingValues: {
110
+ value: '0.08%',
111
+ subvalue: 'Fee',
112
+ },
113
+ },
114
+ {
115
+ title: 'CNY',
116
+ description: 'Chinese yuan',
117
+ icon: { name: 'flag-cny' },
118
+ const: 'CNY',
119
+ supportingValues: {
120
+ value: '0.08%',
121
+ subvalue: 'Fee',
122
+ },
123
+ },
124
+ {
125
+ title: 'JPY',
126
+ description: 'Japanese yen',
127
+ icon: { name: 'flag-jpy' },
128
+ const: 'JPY',
129
+ },
130
+ {
131
+ title: 'HUF',
132
+ description: 'Hungarian Forint',
133
+ icon: { name: 'flag-huf' },
134
+ const: 'HUF',
135
+ supportingValues: {
136
+ value: '0.08%',
137
+ subvalue: 'Fee',
138
+ },
139
+ },
140
+ ],
141
+ },
142
+ },
143
+ },
144
+ },
145
+ ],
146
+ model: { arrayField: ['USD'] },
147
+ errors: { validation: { arrayField: 'This is an error message from the step' } },
148
+ });
@@ -0,0 +1,168 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { action } from 'storybook/actions';
3
+ import { getMockHttpClient, respondWith } from '../../../test-utils';
4
+ import DynamicFlowWise from '../../../test-utils/DynamicFlowWise';
5
+ const wait = async (ms) => new Promise((resolve) => {
6
+ setTimeout(resolve, ms);
7
+ });
8
+ const persistAsyncConfig = {
9
+ method: 'POST',
10
+ url: '/persist-async',
11
+ param: 'param',
12
+ idProperty: 'token',
13
+ };
14
+ const uploadConfig = {
15
+ title: 'Upload label (from innner schema title)',
16
+ accepts: ['image/png', 'image/jpeg', 'application/pdf'],
17
+ validationMessages: {
18
+ maxSize: 'Your file is too large',
19
+ required: 'Please enter a valid file (uploadConfig).',
20
+ },
21
+ };
22
+ const multiFileConfig = {
23
+ title: 'Upload label (from innner schema title)',
24
+ maxItems: 5,
25
+ addItemTitle: 'Add',
26
+ editItemTitle: 'Edit',
27
+ summary: {
28
+ defaultTitle: 'File',
29
+ defaultDescription: 'Click to edit or remove',
30
+ defaultIcon: { name: 'document', type: 'icon' },
31
+ },
32
+ };
33
+ const logPersistAsync = (input, init) => {
34
+ if (init && init.body instanceof FormData) {
35
+ console.log(input, init.body.get(persistAsyncConfig.param));
36
+ }
37
+ else {
38
+ console.log(input, init && JSON.parse(init.body));
39
+ }
40
+ };
41
+ const getHttpClient = (persistAsync = 'succeed') => getMockHttpClient({
42
+ '/submit': async (input, init) => {
43
+ console.log(input, init && JSON.parse(init.body));
44
+ return respondWith({
45
+ id: 'success',
46
+ title: 'Submission successful',
47
+ description: 'Your file has been uploaded successfully.',
48
+ schemas: [],
49
+ layout: [
50
+ { type: 'paragraph', text: 'Refresh the page to start again.', align: 'center' },
51
+ ],
52
+ }, { status: 200 });
53
+ },
54
+ '/persist-async': async (input, init) => {
55
+ logPersistAsync(input, init);
56
+ switch (persistAsync) {
57
+ case 'rejectPromise':
58
+ return Promise.reject(new Error('Failed to persist async'));
59
+ case 'failGenerically':
60
+ await wait(1000);
61
+ return Promise.resolve(new Response(null, { status: 404 }));
62
+ case 'failValidation':
63
+ await wait(1000);
64
+ return Promise.resolve(new Response(JSON.stringify({ validation: { param: 'Error message from the server.' } }), { status: 422 }));
65
+ case 'succeed':
66
+ default:
67
+ await wait(1000);
68
+ return respondWith({ token: '123' });
69
+ }
70
+ },
71
+ });
72
+ export default {
73
+ component: DynamicFlowWise,
74
+ title: 'Spec/Schemas/Upload',
75
+ parameters: {
76
+ chromatic: { disableSnapshot: true },
77
+ },
78
+ argTypes: {
79
+ persistAsync: {
80
+ options: ['succeed', 'rejectPromise', 'failGenerically', 'failValidation'],
81
+ type: 'select',
82
+ defaultValue: 'succeed',
83
+ },
84
+ },
85
+ };
86
+ export function Base64Upload() {
87
+ return renderWithStep(getBase64UploadStep());
88
+ }
89
+ export function Base64UploadLarge() {
90
+ return renderWithStep(getBase64UploadStepLarge());
91
+ }
92
+ export function Base64UploadWithPersistAsync({ persistAsync }) {
93
+ return renderWithStep(getBase64UploadWithPersistAsync(), persistAsync);
94
+ }
95
+ export function BlobUploadWithPersistAsync({ persistAsync }) {
96
+ return renderWithStep(getBlobUploadWithPersistAsync(), persistAsync);
97
+ }
98
+ export function BlobUploadWithPersistAsyncLarge({ persistAsync }) {
99
+ return renderWithStep(getBlobUploadWithPersistAsyncLarge(), persistAsync);
100
+ }
101
+ export function MultiBase64Upload() {
102
+ return renderWithStep(getMultiBase64Upload());
103
+ }
104
+ export function MultiBase64UploadWithPersistAsync({ persistAsync }) {
105
+ return renderWithStep(getMultiBase64UploadWithPersistAsync(), persistAsync);
106
+ }
107
+ export function MultiBlobUploadWithPersistAsync({ persistAsync }) {
108
+ return renderWithStep(getMultiBlobUploadWithPersistAsync(), persistAsync);
109
+ }
110
+ const renderWithStep = (step, persistAsync = 'succeed') => (_jsx(DynamicFlowWise, { flowId: "new-df-flow-id", httpClient: getHttpClient(persistAsync), initialStep: step, features: { nativeBack: true }, onCompletion: action('onCompletion'), onEvent: action('onEvent'), onLog: action('onLog'), onError: (error) => {
111
+ action('onError');
112
+ console.error(error);
113
+ } }));
114
+ const getBase64UploadStep = () => getStep('Base64 Upload', Object.assign({ $id: '#schema', type: 'string', format: 'base64url' }, uploadConfig));
115
+ const getBase64UploadStepLarge = () => getStep('Base64 Upload (Large)', Object.assign({ $id: '#schema', type: 'string', control: 'upload-large', format: 'base64url' }, uploadConfig));
116
+ const getBase64UploadWithPersistAsync = () => getStep('Base64 Upload (Persist Async)', {
117
+ $id: '#schema',
118
+ type: 'string',
119
+ persistAsync: Object.assign(Object.assign({}, persistAsyncConfig), { schema: Object.assign({ type: 'string', format: 'base64url' }, uploadConfig) }),
120
+ });
121
+ const getBlobUploadWithPersistAsync = () => getStep('Blob Upload (Persist Async)', {
122
+ $id: '#schema',
123
+ type: 'string',
124
+ validationMessages: { required: 'Please enter a valid file.' },
125
+ persistAsync: Object.assign(Object.assign({}, persistAsyncConfig), { schema: Object.assign({ type: 'blob', source: 'file' }, uploadConfig) }),
126
+ });
127
+ const getBlobUploadWithPersistAsyncLarge = () => getStep('Blob Upload (Persist Async, Large)', {
128
+ $id: '#schema',
129
+ type: 'string',
130
+ validationMessages: { required: 'Please enter a valid file.' },
131
+ persistAsync: Object.assign(Object.assign({}, persistAsyncConfig), { schema: Object.assign({ type: 'blob', control: 'upload-large', source: 'file' }, uploadConfig) }),
132
+ });
133
+ const getMultiBase64Upload = () => getStep('Base64 Upload (Multiple)', Object.assign(Object.assign({ $id: '#schema', type: 'array' }, multiFileConfig), { items: Object.assign({ type: 'string', format: 'base64url' }, uploadConfig) }));
134
+ const getMultiBase64UploadWithPersistAsync = () => getStep('Base64 Upload (Multiple, Persist Async)', Object.assign(Object.assign({ $id: '#schema', type: 'array' }, multiFileConfig), { items: {
135
+ $id: '#id',
136
+ type: 'string',
137
+ persistAsync: Object.assign(Object.assign({}, persistAsyncConfig), { schema: Object.assign({ type: 'string', format: 'base64url' }, uploadConfig) }),
138
+ } }));
139
+ const getMultiBlobUploadWithPersistAsync = () => getStep('Blob Upload (Multiple, Persist Async)', Object.assign(Object.assign({ type: 'array', $id: '#schema' }, multiFileConfig), { items: {
140
+ $id: '#id',
141
+ type: 'string',
142
+ persistAsync: Object.assign(Object.assign({}, persistAsyncConfig), { schema: Object.assign({ type: 'blob', source: 'file' }, uploadConfig) }),
143
+ } }));
144
+ const getStep = (title, schema) => {
145
+ const objectSchema = {
146
+ type: 'object',
147
+ $id: '#object-schema',
148
+ displayOrder: ['fileUpload', 'thing'],
149
+ required: ['fileUpload'],
150
+ properties: {
151
+ thing: { const: 'hidden-value' },
152
+ fileUpload: schema,
153
+ },
154
+ };
155
+ return {
156
+ id: 'step-id',
157
+ title,
158
+ schemas: [objectSchema],
159
+ layout: [
160
+ { type: 'form', schemaId: '#object-schema' },
161
+ {
162
+ type: 'button',
163
+ title: 'Submit',
164
+ action: { url: '/submit', method: 'POST' },
165
+ },
166
+ ],
167
+ };
168
+ };
@@ -0,0 +1,159 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import DynamicFlowWise from '../../../../test-utils/DynamicFlowWise';
3
+ import { renderWithStep } from '../../../utils/render-utils';
4
+ export default {
5
+ component: DynamicFlowWise,
6
+ title: 'Spec/Schemas/Const',
7
+ parameters: {
8
+ layout: 'fullscreen',
9
+ },
10
+ };
11
+ export function ConstSchemaWithLayoutWithSelect() {
12
+ return render(undefined);
13
+ }
14
+ export function ConstSchemaWithLayoutWithRadio() {
15
+ return render('radio');
16
+ }
17
+ export function ConstSchemaWithLayoutWithTabs() {
18
+ return render('tab');
19
+ }
20
+ const render = (control) => {
21
+ return (_jsx("div", { style: {
22
+ width: '60%',
23
+ margin: 'auto',
24
+ }, children: renderWithStep(step(control)) }));
25
+ };
26
+ const step = (control) => ({
27
+ id: 'const-layout-step',
28
+ title: 'Const Schemas with Layout',
29
+ schemas: [
30
+ {
31
+ $id: '#schema',
32
+ control,
33
+ oneOf: [
34
+ {
35
+ title: 'Option A',
36
+ const: 'A',
37
+ layout: [
38
+ {
39
+ type: 'heading',
40
+ text: 'This is Option A',
41
+ },
42
+ {
43
+ type: 'paragraph',
44
+ text: 'Option A is a great choice because, it offers unique benefits and features that are tailored to your needs.',
45
+ },
46
+ {
47
+ type: 'list',
48
+ items: [
49
+ {
50
+ title: 'Reason 1',
51
+ description: 'Firstly, it is a great choice because it offers unique benefits and features that are tailored to your needs.',
52
+ media: textMediaAvatar('T1'),
53
+ },
54
+ {
55
+ title: 'Reason 2',
56
+ description: 'Secondly, it provides exceptional value and quality, ensuring that you get the best possible experience.',
57
+ media: textMediaAvatar('T2'),
58
+ },
59
+ ],
60
+ },
61
+ ],
62
+ },
63
+ {
64
+ title: 'Option B',
65
+ const: 'B',
66
+ layout: [
67
+ {
68
+ type: 'heading',
69
+ text: 'This is Option B',
70
+ },
71
+ {
72
+ type: 'paragraph',
73
+ text: 'Option B stands out due to its innovative approach and user-friendly design, making it an excellent choice for those seeking simplicity and efficiency.',
74
+ },
75
+ {
76
+ type: 'list',
77
+ items: [
78
+ {
79
+ title: 'Reason 1',
80
+ description: 'Firstly, it is a great choice because it offers unique benefits and features that are tailored to your needs.',
81
+ media: textMediaAvatar('T1'),
82
+ },
83
+ {
84
+ title: 'Reason 2',
85
+ description: 'Secondly, it provides exceptional value and quality, ensuring that you get the best possible experience.',
86
+ media: textMediaAvatar('T2'),
87
+ },
88
+ {
89
+ title: 'Reason 3',
90
+ description: 'Finally, its reliability and performance make it a trusted option for users who prioritize consistency and dependability.',
91
+ media: textMediaAvatar('T3'),
92
+ },
93
+ ],
94
+ },
95
+ ],
96
+ },
97
+ {
98
+ title: 'Option C',
99
+ const: 'C',
100
+ layout: [
101
+ {
102
+ type: 'heading',
103
+ text: 'This is Option C',
104
+ },
105
+ {
106
+ type: 'paragraph',
107
+ text: 'Option C is distinguished by its comprehensive features and robust performance, making it a top choice for users who demand the best.',
108
+ },
109
+ {
110
+ type: 'image',
111
+ content: {
112
+ uri: 'urn:wise:illustrations:plane',
113
+ },
114
+ },
115
+ ],
116
+ },
117
+ ],
118
+ },
119
+ ],
120
+ layout: [
121
+ {
122
+ type: 'box',
123
+ width: 'md',
124
+ control: 'bordered',
125
+ components: [
126
+ {
127
+ type: 'markdown',
128
+ content: 'This example demonstrates the use of constant schemas with a defined layout.',
129
+ align: 'center',
130
+ margin: 'lg',
131
+ },
132
+ {
133
+ type: 'form',
134
+ schemaId: '#schema',
135
+ },
136
+ {
137
+ type: 'alert',
138
+ markdown: 'This alert is separate from the form const schemas.',
139
+ },
140
+ {
141
+ type: 'button',
142
+ title: 'Submit',
143
+ control: 'primary',
144
+ behavior: {
145
+ type: 'action',
146
+ action: {
147
+ url: '/submit',
148
+ },
149
+ },
150
+ },
151
+ ],
152
+ },
153
+ ],
154
+ model: 'A',
155
+ });
156
+ const textMediaAvatar = (text) => ({
157
+ type: 'avatar',
158
+ content: [{ type: 'text', text }],
159
+ });
@@ -0,0 +1,94 @@
1
+ import { getMockHttpClient, respondWith } from '../../../../test-utils';
2
+ import DynamicFlowWise from '../../../../test-utils/DynamicFlowWise';
3
+ import { renderWithStep } from '../../../utils/render-utils';
4
+ const getHttpClient = () => getMockHttpClient({
5
+ '/submit': async (input, init) => {
6
+ console.log(input, init && JSON.parse(init.body));
7
+ return respondWith({});
8
+ },
9
+ });
10
+ export default {
11
+ component: DynamicFlowWise,
12
+ title: 'Spec/Schemas/Const',
13
+ parameters: {
14
+ chromatic: { disableSnapshot: true },
15
+ },
16
+ };
17
+ export function ConstObjectSchema() {
18
+ return renderWithStep(getBasicStep(), getHttpClient());
19
+ }
20
+ export function ConstObjectSchemaWithModel() {
21
+ const step = Object.assign(Object.assign({}, getBasicStep()), { model: { recurrence: { interval: 1, frequency: 'WEEKLY' } } });
22
+ return renderWithStep(step, getHttpClient());
23
+ }
24
+ const getBasicStep = () => getStep('Object Const', {
25
+ $id: 'object-const',
26
+ properties: {
27
+ recurrence: {
28
+ oneOf: [
29
+ {
30
+ const: {
31
+ interval: 0,
32
+ frequency: 'ONCE',
33
+ },
34
+ title: 'Never',
35
+ description: 'On some date only',
36
+ },
37
+ {
38
+ const: {
39
+ interval: 1,
40
+ frequency: 'WEEKLY',
41
+ },
42
+ title: 'Weekly',
43
+ description: 'On some date every week',
44
+ },
45
+ {
46
+ const: {
47
+ interval: 2,
48
+ frequency: 'WEEKLY',
49
+ },
50
+ title: 'Biweekly',
51
+ description: 'On some date every two weeks',
52
+ },
53
+ {
54
+ const: {
55
+ interval: 1,
56
+ frequency: 'MONTHLY',
57
+ },
58
+ title: 'Monthly',
59
+ description: 'Monthly',
60
+ },
61
+ {
62
+ const: {
63
+ interval: 3,
64
+ frequency: 'MONTHLY',
65
+ },
66
+ title: 'Quarterly',
67
+ description: 'Every 3 months on X',
68
+ },
69
+ ],
70
+ placeholder: 'Select a start date',
71
+ title: 'Repeats',
72
+ default: {
73
+ interval: 0,
74
+ frequency: 'ONCE',
75
+ },
76
+ refreshStepOnChange: true,
77
+ },
78
+ },
79
+ displayOrder: ['recurrence'],
80
+ type: 'object',
81
+ });
82
+ const getStep = (title, schema) => ({
83
+ id: 'step-id',
84
+ title,
85
+ schemas: [schema],
86
+ layout: [
87
+ { type: 'form', schemaId: schema.$id },
88
+ {
89
+ type: 'button',
90
+ title: 'Submit',
91
+ action: { url: '/submit', method: 'POST' },
92
+ },
93
+ ],
94
+ });