@wise/dynamic-flow-client 3.4.0 → 3.5.0-experimental-6654c72

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 (275) hide show
  1. package/build/common/errorBoundary/ErrorBoundary.js +44 -0
  2. package/build/common/errorBoundary/ErrorBoundaryAlert.js +12 -0
  3. package/build/common/httpClientContext/HttpClientContext.js +35 -0
  4. package/build/common/httpClientContext/index.js +1 -0
  5. package/build/common/makeHttpClient/index.js +1 -0
  6. package/build/common/makeHttpClient/makeHttpClient.js +34 -0
  7. package/build/common/messages/external-confirmation.messages.js +23 -0
  8. package/build/common/messages/generic-error.messages.js +18 -0
  9. package/build/common/messages/help.messages.js +8 -0
  10. package/build/common/messages/multi-file-upload.messages.js +18 -0
  11. package/build/common/messages/multi-select.messages.js +8 -0
  12. package/build/common/messages/paragraph.messages.js +13 -0
  13. package/build/common/messages/repeatable.messages.js +23 -0
  14. package/build/common/messages/validation.array.messages.js +13 -0
  15. package/build/common/messages/validation.messages.js +53 -0
  16. package/build/common/utils/api-utils.js +4 -0
  17. package/build/i18n/de.json +2 -1
  18. package/build/i18n/es.json +1 -0
  19. package/build/i18n/fr.json +1 -0
  20. package/build/i18n/hu.json +1 -0
  21. package/build/i18n/id.json +1 -0
  22. package/build/i18n/index.js +36 -0
  23. package/build/i18n/it.json +1 -0
  24. package/build/i18n/ja.json +1 -0
  25. package/build/i18n/pl.json +1 -0
  26. package/build/i18n/pt.json +1 -0
  27. package/build/i18n/ro.json +1 -0
  28. package/build/i18n/ru.json +1 -0
  29. package/build/i18n/th.json +1 -0
  30. package/build/i18n/tr.json +1 -0
  31. package/build/i18n/zh_CN.json +1 -0
  32. package/build/i18n/zh_HK.json +1 -0
  33. package/build/legacy/common/constants/DateMode.js +4 -0
  34. package/build/legacy/common/constants/FeatureName.js +4 -0
  35. package/build/legacy/common/constants/FormControlType.js +21 -0
  36. package/build/legacy/common/constants/MonthFormat.js +4 -0
  37. package/build/legacy/common/constants/Size.js +7 -0
  38. package/build/legacy/common/constants/index.js +4 -0
  39. package/build/legacy/common/contexts/dynamicFlowContexts/DynamicFlowContexts.js +36 -0
  40. package/build/legacy/common/contexts/dynamicFlowContexts/usePendingPromiseCounter.js +13 -0
  41. package/build/legacy/common/contexts/eventsContext/EventsContext.js +38 -0
  42. package/build/legacy/common/contexts/featureContext/FeatureContext.js +22 -0
  43. package/build/legacy/common/contexts/index.js +3 -0
  44. package/build/legacy/common/contexts/logContext/LogContext.js +44 -0
  45. package/build/legacy/common/hooks/index.js +7 -0
  46. package/build/legacy/common/hooks/useDebouncedFunction/useDebouncedFunction.js +9 -0
  47. package/build/legacy/common/hooks/useExternal/useExternal.js +15 -0
  48. package/build/legacy/common/hooks/useExternalStepPolling/useExternalStepPolling.js +70 -0
  49. package/build/legacy/common/hooks/usePersistAsync/usePersistAsync.js +172 -0
  50. package/build/legacy/common/hooks/usePolling/usePolling.js +51 -0
  51. package/build/legacy/common/hooks/usePrevious/usePrevious.js +8 -0
  52. package/build/legacy/common/hooks/useStepPolling/useStepPolling.js +43 -0
  53. package/build/legacy/common/messages.js +8 -0
  54. package/build/legacy/common/utils/api-utils.js +6 -0
  55. package/build/legacy/common/utils/date-utils.js +22 -0
  56. package/build/legacy/common/utils/debounce.js +38 -0
  57. package/build/legacy/common/utils/file-utils.js +45 -0
  58. package/build/legacy/common/utils/id-utils.js +5 -0
  59. package/build/legacy/common/utils/index.js +11 -0
  60. package/build/legacy/common/utils/is-equal.js +21 -0
  61. package/build/legacy/common/utils/misc-utils.js +4 -0
  62. package/build/legacy/common/utils/mobile-utils.js +23 -0
  63. package/build/legacy/common/utils/model-utils.js +33 -0
  64. package/build/legacy/common/utils/schema-utils.js +113 -0
  65. package/build/legacy/common/utils/step-utils.js +32 -0
  66. package/build/legacy/common/validators/index.js +5 -0
  67. package/build/legacy/common/validators/models/model-utils.js +119 -0
  68. package/build/legacy/common/validators/models/model-validators.js +62 -0
  69. package/build/legacy/common/validators/schemas/schema-validators.js +101 -0
  70. package/build/legacy/common/validators/types/type-validators.js +14 -0
  71. package/build/legacy/common/validators/validationFailures/validation-failures.js +139 -0
  72. package/build/legacy/common/validators/validationFailures/validation-failures.utils.js +40 -0
  73. package/build/legacy/common/validators/values/value-validators.js +6 -0
  74. package/build/legacy/dynamic-flow-types.js +1 -0
  75. package/build/legacy/dynamicFlow/BackButton.js +22 -0
  76. package/build/legacy/dynamicFlow/DynamicFlow.js +346 -0
  77. package/build/legacy/dynamicFlow/DynamicFlowStep.js +37 -0
  78. package/build/legacy/dynamicFlow/DynamicFlowTypes.js +1 -0
  79. package/build/legacy/dynamicFlow/index.js +1 -0
  80. package/build/legacy/dynamicFlow/utils/index.js +5 -0
  81. package/build/legacy/dynamicFlow/utils/responseParsers/response-parsers.js +185 -0
  82. package/build/legacy/dynamicFlow/utils/useDebouncedRefresh/useDebouncedRefresh.js +26 -0
  83. package/build/legacy/dynamicFlow/utils/useDynamicFlowState.js +137 -0
  84. package/build/legacy/dynamicFlow/utils/useLoader.js +22 -0
  85. package/build/legacy/formControl/FormControl.js +266 -0
  86. package/build/legacy/formControl/index.js +1 -0
  87. package/build/legacy/formControl/utils/getAutocompleteString.js +80 -0
  88. package/build/legacy/formControl/utils/index.js +2 -0
  89. package/build/legacy/formControl/utils/value-utils.js +108 -0
  90. package/build/legacy/jsonSchemaForm/JsonSchemaForm.js +24 -0
  91. package/build/legacy/jsonSchemaForm/allOfSchema/AllOfSchema.js +50 -0
  92. package/build/legacy/jsonSchemaForm/allOfSchema/index.js +1 -0
  93. package/build/legacy/jsonSchemaForm/arrayTypeSchema/ArraySchema.js +25 -0
  94. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/ArrayListSchema.js +34 -0
  95. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multiSelectSchema/MultiSelectSchema.js +84 -0
  96. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/MultipleFileUploadSchema.js +141 -0
  97. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/index.js +1 -0
  98. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/utils/index.js +2 -0
  99. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/utils/upload-utils.js +79 -0
  100. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/utils/useFormattedDefaultErrorMessages.js +14 -0
  101. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/ItemSummary.js +7 -0
  102. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/RepeatableSchema.js +134 -0
  103. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/RepeatableSchemaStep.js +85 -0
  104. package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/utils/summary-utils.js +135 -0
  105. package/build/legacy/jsonSchemaForm/arrayTypeSchema/index.js +1 -0
  106. package/build/legacy/jsonSchemaForm/basicTypeSchema/BasicTypeSchema.js +111 -0
  107. package/build/legacy/jsonSchemaForm/basicTypeSchema/index.js +1 -0
  108. package/build/legacy/jsonSchemaForm/controlFeedback/ControlFeedback.js +86 -0
  109. package/build/legacy/jsonSchemaForm/controlFeedback/index.js +1 -0
  110. package/build/legacy/jsonSchemaForm/genericSchema/GenericSchema.js +85 -0
  111. package/build/legacy/jsonSchemaForm/genericSchema/index.js +1 -0
  112. package/build/legacy/jsonSchemaForm/help/Help.js +20 -0
  113. package/build/legacy/jsonSchemaForm/help/index.js +1 -0
  114. package/build/legacy/jsonSchemaForm/index.js +1 -0
  115. package/build/legacy/jsonSchemaForm/objectSchema/ObjectSchema.js +77 -0
  116. package/build/legacy/jsonSchemaForm/objectSchema/index.js +1 -0
  117. package/build/legacy/jsonSchemaForm/oneOfSchema/OneOfSchema.js +155 -0
  118. package/build/legacy/jsonSchemaForm/oneOfSchema/index.js +1 -0
  119. package/build/legacy/jsonSchemaForm/oneOfSchema/utils.js +68 -0
  120. package/build/legacy/jsonSchemaForm/persistAsyncSchema/PersistAsyncSchema.js +26 -0
  121. package/build/legacy/jsonSchemaForm/persistAsyncSchema/index.js +1 -0
  122. package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBasicSchema/PersistAsyncBasicSchema.js +165 -0
  123. package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBasicSchema/index.js +1 -0
  124. package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBlobSchema/PersistAsyncBlobSchema.js +131 -0
  125. package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBlobSchema/UploadInputAdapter.js +31 -0
  126. package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBlobSchema/index.js +1 -0
  127. package/build/legacy/jsonSchemaForm/promotedOneOfSchema/PromotedOneOfSchema.js +72 -0
  128. package/build/legacy/jsonSchemaForm/promotedOneOfSchema/index.js +1 -0
  129. package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promoted-one-of-utils.js +8 -0
  130. package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promotedOneOfControl/PromotedOneOfCheckboxControl.js +27 -0
  131. package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promotedOneOfControl/PromotedOneOfControl.js +31 -0
  132. package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promotedOneOfControl/PromotedOneOfRadioControl.js +32 -0
  133. package/build/legacy/jsonSchemaForm/readOnlySchema/ReadOnlySchema.js +54 -0
  134. package/build/legacy/jsonSchemaForm/readOnlySchema/ReadOnlySchema.messages.js +13 -0
  135. package/build/legacy/jsonSchemaForm/readOnlySchema/index.js +1 -0
  136. package/build/legacy/jsonSchemaForm/schemaFormControl/SchemaFormControl.js +133 -0
  137. package/build/legacy/jsonSchemaForm/schemaFormControl/index.js +1 -0
  138. package/build/legacy/jsonSchemaForm/schemaFormControl/utils/index.js +1 -0
  139. package/build/legacy/jsonSchemaForm/schemaFormControl/utils/mapping-utils.js +107 -0
  140. package/build/legacy/jsonSchemaForm/validationAsyncSchema/ValidationAsyncSchema.js +150 -0
  141. package/build/legacy/jsonSchemaForm/validationAsyncSchema/index.js +1 -0
  142. package/build/legacy/layout/DynamicLayout.js +68 -0
  143. package/build/legacy/layout/alert/DynamicAlert.js +29 -0
  144. package/build/legacy/layout/box/DynamicBox.js +41 -0
  145. package/build/legacy/layout/button/DynamicButton.js +27 -0
  146. package/build/legacy/layout/button/utils.js +45 -0
  147. package/build/legacy/layout/columns/DynamicColumns.js +38 -0
  148. package/build/legacy/layout/decision/DynamicDecision.js +21 -0
  149. package/build/legacy/layout/divider/DynamicDivider.js +9 -0
  150. package/build/legacy/layout/external/DynamicExternal.js +32 -0
  151. package/build/legacy/layout/external/DynamicExternal.messages.js +8 -0
  152. package/build/legacy/layout/form/DynamicForm.js +22 -0
  153. package/build/legacy/layout/heading/DynamicHeading.js +51 -0
  154. package/build/legacy/layout/icon/DynamicIcon.js +17 -0
  155. package/build/legacy/layout/icon/FlagIcon.js +198 -0
  156. package/build/legacy/layout/icon/NamedIcon.js +19 -0
  157. package/build/legacy/layout/image/DynamicImage.js +111 -0
  158. package/build/legacy/layout/index.js +20 -0
  159. package/build/legacy/layout/instructions/DynamicInstructions.js +30 -0
  160. package/build/legacy/layout/list/DynamicStatusList.js +37 -0
  161. package/build/legacy/layout/loadingIndicator/DynamicLoadingIndicator.js +11 -0
  162. package/build/legacy/layout/markdown/DynamicMarkdown.js +23 -0
  163. package/build/legacy/layout/modal/DynamicModal.js +26 -0
  164. package/build/legacy/layout/paragraph/DynamicParagraph.js +46 -0
  165. package/build/legacy/layout/paragraph/useSnackBarIfAvailable.js +9 -0
  166. package/build/legacy/layout/review/DynamicReview.js +58 -0
  167. package/build/legacy/layout/search/DynamicSearch.js +58 -0
  168. package/build/legacy/layout/search/SearchInput.js +17 -0
  169. package/build/legacy/layout/search/SearchResults.js +31 -0
  170. package/build/legacy/layout/search/useSearch.js +137 -0
  171. package/build/legacy/layout/utils/getNavigationOptionMedia.js +28 -0
  172. package/build/legacy/layout/utils/index.js +32 -0
  173. package/build/legacy/step/cameraStep/CameraStep.js +124 -0
  174. package/build/legacy/step/cameraStep/cameraCapture/CameraCapture.js +161 -0
  175. package/build/legacy/step/cameraStep/cameraCapture/CameraCapture.messages.js +58 -0
  176. package/build/legacy/step/cameraStep/cameraCapture/components/bottomBar/BottomBar.js +28 -0
  177. package/build/legacy/step/cameraStep/cameraCapture/components/index.js +3 -0
  178. package/build/legacy/step/cameraStep/cameraCapture/components/orientationLockOverlay/OrientationLockOverlay.js +19 -0
  179. package/build/legacy/step/cameraStep/cameraCapture/components/orientationLockOverlay/OrientationLockOverlay.messages.js +8 -0
  180. package/build/legacy/step/cameraStep/cameraCapture/hooks/useFullScreenOrientationLock.js +60 -0
  181. package/build/legacy/step/cameraStep/cameraCapture/hooks/useVideoConstraints.js +80 -0
  182. package/build/legacy/step/cameraStep/cameraCapture/index.js +1 -0
  183. package/build/legacy/step/cameraStep/cameraCapture/overlay/Overlay.js +77 -0
  184. package/build/legacy/step/cameraStep/cameraCapture/screens/cameraErrorScreen/CameraErrorScreen.js +18 -0
  185. package/build/legacy/step/cameraStep/cameraCapture/screens/index.js +1 -0
  186. package/build/legacy/step/cameraStep/cameraCapture/tracking/index.js +109 -0
  187. package/build/legacy/step/cameraStep/cameraCapture/types/index.js +7 -0
  188. package/build/legacy/step/cameraStep/cameraCapture/utils/index.js +107 -0
  189. package/build/legacy/step/cameraStep/index.js +1 -0
  190. package/build/legacy/step/externalConfirmationStep/ExternalConfirmationStep.js +64 -0
  191. package/build/legacy/step/externalConfirmationStep/index.js +1 -0
  192. package/build/legacy/step/index.js +3 -0
  193. package/build/legacy/step/layoutStep/LayoutStep.js +33 -0
  194. package/build/legacy/step/layoutStep/index.js +1 -0
  195. package/build/legacy/step/layoutStep/utils/index.js +2 -0
  196. package/build/legacy/step/layoutStep/utils/inline-reference-utils.js +105 -0
  197. package/build/legacy/step/layoutStep/utils/layout-utils.js +212 -0
  198. package/build/main.js +4791 -226
  199. package/build/main.min.js +1 -1
  200. package/build/main.mjs +4792 -227
  201. package/build/revamp/domain/components/AlertComponent.js +50 -0
  202. package/build/revamp/domain/components/AllOfComponent.js +72 -0
  203. package/build/revamp/domain/components/BooleanInputComponent.js +108 -0
  204. package/build/revamp/domain/components/BoxComponent.js +65 -0
  205. package/build/revamp/domain/components/ButtonComponent.js +50 -0
  206. package/build/revamp/domain/components/ColumnsComponent.js +74 -0
  207. package/build/revamp/domain/components/ConstComponent.js +50 -0
  208. package/build/revamp/domain/components/ContainerComponent.js +65 -0
  209. package/build/revamp/domain/components/DateInputComponent.js +127 -0
  210. package/build/revamp/domain/components/DecisionComponent.js +50 -0
  211. package/build/revamp/domain/components/DividerComponent.js +50 -0
  212. package/build/revamp/domain/components/FormComponent.js +65 -0
  213. package/build/revamp/domain/components/HeadingComponent.js +50 -0
  214. package/build/revamp/domain/components/ImageComponent.js +50 -0
  215. package/build/revamp/domain/components/InstructionsComponent.js +50 -0
  216. package/build/revamp/domain/components/IntegerInputComponent.js +125 -0
  217. package/build/revamp/domain/components/LoadingIndicatorComponent.js +50 -0
  218. package/build/revamp/domain/components/MarkdownComponent.js +50 -0
  219. package/build/revamp/domain/components/ModalComponent.js +65 -0
  220. package/build/revamp/domain/components/MultiUploadInputComponent.js +190 -0
  221. package/build/revamp/domain/components/NumberInputComponent.js +125 -0
  222. package/build/revamp/domain/components/ObjectComponent.js +104 -0
  223. package/build/revamp/domain/components/ParagraphComponent.js +50 -0
  224. package/build/revamp/domain/components/ReviewComponent.js +50 -0
  225. package/build/revamp/domain/components/SelectInputComponent.js +138 -0
  226. package/build/revamp/domain/components/StatusListComponent.js +50 -0
  227. package/build/revamp/domain/components/StepDomainComponent.js +93 -0
  228. package/build/revamp/domain/components/TextInputComponent.js +125 -0
  229. package/build/revamp/domain/components/UploadInputComponent.js +151 -0
  230. package/build/revamp/domain/components/repeatableComponent/RepeatableComponent.js +148 -0
  231. package/build/revamp/domain/components/searchComponent/SearchComponent.js +108 -0
  232. package/build/revamp/domain/components/utils/component-utils.js +18 -0
  233. package/build/revamp/domain/components/utils/debounce.js +38 -0
  234. package/build/revamp/domain/components/utils/file-utils.js +46 -0
  235. package/build/revamp/domain/components/utils/getComponentForLocalValueKey.js +31 -0
  236. package/build/revamp/domain/components/utils/isPartialLocalValueMatch.js +40 -0
  237. package/build/revamp/domain/features/events.js +1 -0
  238. package/build/revamp/domain/features/persistAsync/getComponentPersistAsync.js +133 -0
  239. package/build/revamp/domain/features/persistAsync/getPerformPersistAsync.js +103 -0
  240. package/build/revamp/domain/features/refresh/getPerformRefresh.js +53 -0
  241. package/build/revamp/domain/features/summary/summary-utils.js +39 -0
  242. package/build/revamp/domain/features/utils/http-utils.js +34 -0
  243. package/build/revamp/domain/features/utils/response-utils.js +9 -0
  244. package/build/revamp/domain/features/validation/validation-functions.js +12 -0
  245. package/build/revamp/domain/features/validation/value-checks.js +111 -0
  246. package/build/revamp/domain/features/validationAsync/getComponentValidationAsync.js +94 -0
  247. package/build/revamp/domain/features/validationAsync/getPerformValidationAsync.js +107 -0
  248. package/build/revamp/domain/mappers/types.js +1 -0
  249. package/build/revamp/domain/types.js +1 -0
  250. package/build/revamp/flow/response-utils.js +88 -0
  251. package/build/revamp/renderers/CoreContainerRenderer.js +8 -0
  252. package/build/revamp/renderers/LoadingContext.js +7 -0
  253. package/build/revamp/renderers/types.js +1 -0
  254. package/build/revamp/types.js +1 -0
  255. package/build/revamp/utils/component-utils.js +86 -0
  256. package/build/revamp/utils/type-utils.js +56 -0
  257. package/build/revamp/utils/type-validators.js +16 -0
  258. package/build/revamp/wise/renderers/AlertRenderer.js +11 -0
  259. package/build/revamp/wise/renderers/BooleanInputRenderer.js +34 -0
  260. package/build/revamp/wise/renderers/BoxRenderer.js +30 -0
  261. package/build/revamp/wise/renderers/ButtonRenderer.js +64 -0
  262. package/build/revamp/wise/renderers/ColumnsRenderer.js +25 -0
  263. package/build/revamp/wise/renderers/components/FieldInput.js +20 -0
  264. package/build/revamp/wise/renderers/components/Help.js +21 -0
  265. package/build/revamp/wise/renderers/components/LabelContentWithHelp.js +6 -0
  266. package/build/revamp/wise/renderers/utils/layout-utils.js +31 -0
  267. package/build/types/legacy/step/externalConfirmationStep/ExternalConfirmationStep.d.ts +1 -1
  268. package/build/types/revamp/domain/components/StepDomainComponent.d.ts +4 -2
  269. package/build/types/revamp/renderers/step/ExternalConfirmationDialog.d.ts +6 -0
  270. package/build/types/revamp/renderers/{StepRenderer.d.ts → step/StepRenderer.d.ts} +1 -1
  271. package/build/types/revamp/renderers/step/useExternal.d.ts +4 -0
  272. package/build/types/revamp/renderers/stepComponentToProps.d.ts +1 -1
  273. package/build/types/revamp/renderers/types.d.ts +3 -0
  274. package/package.json +13 -13
  275. /package/build/types/{legacy/step/externalConfirmationStep/ExternalConfirmationStep.messages.d.ts → common/messages/external-confirmation.messages.d.ts} +0 -0
@@ -0,0 +1,111 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
23
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
48
+ import { jsx as _jsx } from "react/jsx-runtime";
49
+ import { Image } from '@transferwise/components';
50
+ import { useEffect, useState } from 'react';
51
+ import { isRelativePath } from '../../../common/utils/api-utils';
52
+ import { getMargin } from '../utils';
53
+ import { useHttpClient } from '../../../common/httpClientContext';
54
+ function DynamicImage(_a) {
55
+ var image = _a.component;
56
+ var url = image.url, size = image.size, text = image.text, margin = image.margin, accessibilityDescription = image.accessibilityDescription;
57
+ var httpClient = useHttpClient();
58
+ var _b = useState(''), imageSource = _b[0], setImageSource = _b[1];
59
+ useEffect(function () {
60
+ void getImageSource(httpClient, url).then(setImageSource);
61
+ }, [url, httpClient]);
62
+ var imageProps = {
63
+ alt: accessibilityDescription || text || '',
64
+ src: imageSource,
65
+ stretch: true,
66
+ shrink: true
67
+ };
68
+ if (!imageSource) {
69
+ return null;
70
+ }
71
+ return (_jsx("div", __assign({ className: "df-image ".concat(size || 'md') }, { children: _jsx(Image, __assign({ className: "img-responsive ".concat(getMargin(margin || 'md')) }, imageProps)) })));
72
+ }
73
+ var readImageBlobAsDataURL = function (imageBlob) {
74
+ // we can safely assume the type of reader.result is string
75
+ // because we're calling reader.readAsDataURL
76
+ // https://developer.mozilla.org/en-US/docs/Web/API/FileReader/result
77
+ return new Promise(function (resolve, reject) {
78
+ var reader = new FileReader();
79
+ reader.addEventListener('loadend', function () { return resolve(reader.result); });
80
+ reader.addEventListener('error', function (error) { return reject(error); });
81
+ reader.readAsDataURL(imageBlob);
82
+ });
83
+ };
84
+ var getImageSource = function (httpClient, imageUrl) { return __awaiter(void 0, void 0, void 0, function () {
85
+ var _a;
86
+ return __generator(this, function (_b) {
87
+ try {
88
+ if (isRelativePath(imageUrl) || (imageUrl === null || imageUrl === void 0 ? void 0 : imageUrl.startsWith("".concat((_a = window === null || window === void 0 ? void 0 : window.location) === null || _a === void 0 ? void 0 : _a.origin, "/")))) {
89
+ // eslint-disable-next-line @typescript-eslint/return-await
90
+ return [2 /*return*/, httpClient(imageUrl, {
91
+ method: 'GET',
92
+ headers: { 'Content-Type': 'image/image' },
93
+ credentials: 'same-origin'
94
+ })
95
+ .then(function (response) {
96
+ if (response.ok) {
97
+ return response.blob();
98
+ }
99
+ throw new Error('Image fetching failed');
100
+ })
101
+ .then(readImageBlobAsDataURL)["catch"](function () { return imageUrl; })];
102
+ }
103
+ return [2 /*return*/, imageUrl];
104
+ }
105
+ catch (_c) {
106
+ return [2 /*return*/, imageUrl];
107
+ }
108
+ return [2 /*return*/];
109
+ });
110
+ }); };
111
+ export default DynamicImage;
@@ -0,0 +1,20 @@
1
+ export { default as DynamicAlert } from './alert/DynamicAlert';
2
+ export { default as DynamicBox } from './box/DynamicBox';
3
+ export { default as DynamicButton } from './button/DynamicButton';
4
+ export { default as DynamicColumns } from './columns/DynamicColumns';
5
+ export { default as DynamicDecision } from './decision/DynamicDecision';
6
+ export { default as DynamicDivider } from './divider/DynamicDivider';
7
+ export { default as DynamicExternal } from './external/DynamicExternal';
8
+ export { default as DynamicForm } from './form/DynamicForm';
9
+ export { default as DynamicHeading } from './heading/DynamicHeading';
10
+ export { default as DynamicIcon } from './icon/DynamicIcon';
11
+ export { DynamicInfo, DynamicMarkdown } from './markdown/DynamicMarkdown';
12
+ export { default as DynamicImage } from './image/DynamicImage';
13
+ export { default as DynamicInstructions } from './instructions/DynamicInstructions';
14
+ export { default as DynamicLayout } from './DynamicLayout';
15
+ export { default as DynamicStatusList } from './list/DynamicStatusList';
16
+ export { default as DynamicLoadingIndicator } from './loadingIndicator/DynamicLoadingIndicator';
17
+ export { default as DynamicParagraph } from './paragraph/DynamicParagraph';
18
+ export { default as DynamicReview } from './review/DynamicReview';
19
+ export { default as DynamicSearch } from './search/DynamicSearch';
20
+ export { default as DynamicModal } from './modal/DynamicModal';
@@ -0,0 +1,30 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { Header, InstructionsList } from '@transferwise/components';
14
+ import { getMargin } from '../utils';
15
+ var doContext = ['positive', 'neutral'];
16
+ var dontContext = ['warning', 'negative'];
17
+ var DynamicInstructions = function (_a) {
18
+ var component = _a.component;
19
+ var items = component.items;
20
+ var dos = items.filter(function (item) { return doContext.includes(item.context); }).map(function (_a) {
21
+ var text = _a.text;
22
+ return text;
23
+ });
24
+ var donts = items.filter(function (item) { return dontContext.includes(item.context); }).map(function (_a) {
25
+ var text = _a.text;
26
+ return text;
27
+ });
28
+ return (_jsxs("div", __assign({ className: getMargin(component.margin || 'md') }, { children: [component.title ? _jsx(Header, { title: component.title }) : null, _jsx(InstructionsList, { dos: dos, donts: donts })] })));
29
+ };
30
+ export default DynamicInstructions;
@@ -0,0 +1,37 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ /* eslint-disable @typescript-eslint/no-unsafe-return */
14
+ import { Header, Summary } from '@transferwise/components';
15
+ import { DynamicIcon } from '..';
16
+ import { getMargin } from '../utils';
17
+ var DynamicStatusList = function (_a) {
18
+ var component = _a.component;
19
+ return (_jsxs("div", __assign({ className: getMargin(component.margin || 'md') }, { children: [component.title ? _jsx(Header, { title: component.title }) : null, component.items.map(mapListItemToSummary)] })));
20
+ };
21
+ var mapListItemToSummary = function (_a) {
22
+ var title = _a.title, description = _a.description, icon = _a.icon, status = _a.status;
23
+ var props = __assign(__assign({ key: "".concat(title, "/").concat(description || ''), title: title, description: description }, ((icon === null || icon === void 0 ? void 0 : icon.name) ? { icon: _jsx(DynamicIcon, { type: icon.name }) } : {})), (status ? { status: statusMap[status] } : {}));
24
+ return _jsx(Summary, __assign({}, props));
25
+ };
26
+ var statusListMap = {
27
+ done: 'done',
28
+ pending: 'pending',
29
+ 'not-done': 'notDone'
30
+ };
31
+ var legacyStatusMap = {
32
+ positive: 'done',
33
+ warning: 'pending',
34
+ neutral: 'notDone'
35
+ };
36
+ var statusMap = __assign(__assign({}, statusListMap), legacyStatusMap);
37
+ export default DynamicStatusList;
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Loader } from '@transferwise/components';
3
+ import { getMargin } from '../utils';
4
+ var DynamicLoadingIndicator = function (_a) {
5
+ var component = _a.component;
6
+ var _b = component.margin, margin = _b === void 0 ? 'md' : _b, _c = component.size, size = _c === void 0 ? 'md' : _c;
7
+ return (_jsx(Loader, { size: size, classNames: {
8
+ 'tw-loader': "tw-loader m-x-auto ".concat(getMargin(margin))
9
+ }, "data-testid": "loading-indicator" }));
10
+ };
11
+ export default DynamicLoadingIndicator;
@@ -0,0 +1,23 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import { Markdown } from '@transferwise/components';
14
+ import { getTextAlignmentAndMargin } from '../utils';
15
+ export var DynamicMarkdown = function (_a) {
16
+ var component = _a.component;
17
+ var content = component.content, align = component.align, margin = component.margin;
18
+ return (_jsx("div", __assign({ className: getTextAlignmentAndMargin({ align: align, margin: margin }) }, { children: _jsx(Markdown, __assign({ config: { link: { target: '_blank' } } }, { children: content })) })));
19
+ };
20
+ export var DynamicInfo = function (_a) {
21
+ var component = _a.component;
22
+ return (_jsx("div", __assign({ className: getTextAlignmentAndMargin(component) }, { children: _jsx(Markdown, __assign({ config: { link: { target: '_blank' } } }, { children: component.markdown })) })));
23
+ };
@@ -0,0 +1,26 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { Button, Modal } from '@transferwise/components';
14
+ import { useState } from 'react';
15
+ import DynamicLayout from '../DynamicLayout';
16
+ import { getTextAlignmentAndMargin } from '../utils';
17
+ function DynamicModal(props) {
18
+ var _a = useState(false), visible = _a[0], isVisible = _a[1];
19
+ var component = props.component, onAction = props.onAction;
20
+ var _b = component.margin, margin = _b === void 0 ? 'md' : _b;
21
+ return (_jsxs("div", __assign({ className: getTextAlignmentAndMargin({ margin: margin }) }, { children: [_jsx(Button, __assign({ priority: "tertiary", block: true, onClick: function () { return isVisible(true); } }, { children: component.trigger.title })), _jsx(Modal, { scroll: "content", open: visible, size: "lg", body: _jsx(DynamicLayout, __assign({}, props, { components: component.content.components, onAction: function (action) {
22
+ isVisible(false);
23
+ onAction(action);
24
+ } })), onClose: function () { return isVisible(false); } })] })));
25
+ }
26
+ export default DynamicModal;
@@ -0,0 +1,46 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { Button } from '@transferwise/components';
14
+ import { useIntl } from 'react-intl';
15
+ import { getTextAlignmentAndMargin } from '../utils';
16
+ import messages from '../../../common/messages/paragraph.messages';
17
+ import { useSnackBarIfAvailable } from './useSnackBarIfAvailable';
18
+ function DynamicParagraph(_a) {
19
+ var component = _a.component;
20
+ return component.control === 'copyable' ? (_jsx(CopyableDynamicParagraph, { component: component })) : (_jsx(BasicDynamicParagraph, { component: component }));
21
+ }
22
+ function BasicDynamicParagraph(_a) {
23
+ var component = _a.component;
24
+ return _jsxs("p", __assign({ className: getTextAlignmentAndMargin(component) }, { children: [" ", component.text, " "] }));
25
+ }
26
+ function CopyableDynamicParagraph(_a) {
27
+ var component = _a.component;
28
+ var formatMessage = useIntl().formatMessage;
29
+ var createSnackbar = useSnackBarIfAvailable();
30
+ var text = component.text;
31
+ var copy = function () {
32
+ var _a;
33
+ (_a = navigator.clipboard) === null || _a === void 0 ? void 0 : _a.writeText(text).then(function () { return createSnackbar({ text: formatMessage(messages.copied) }); })["catch"](noop);
34
+ };
35
+ var classNames = "".concat(getTextAlignmentAndMargin({
36
+ align: component.align,
37
+ margin: 'sm'
38
+ }), " form-control");
39
+ return (_jsxs("div", __assign({ className: getTextAlignmentAndMargin(component) }, { children: [_jsx("input", { type: "text", className: classNames, value: text, readOnly: true,
40
+ // eslint-disable-next-line react/forbid-dom-props
41
+ style: { textOverflow: 'ellipsis' } }), _jsx(Button, __assign({ block: true, onClick: copy }, { children: formatMessage(messages.copy) }))] })));
42
+ }
43
+ function noop() {
44
+ //
45
+ }
46
+ export default DynamicParagraph;
@@ -0,0 +1,9 @@
1
+ import { SnackbarContext } from '@transferwise/components';
2
+ import { useContext } from 'react';
3
+ export function useSnackBarIfAvailable() {
4
+ var context = useContext(SnackbarContext);
5
+ return context ? context.createSnackbar : noop;
6
+ }
7
+ function noop() {
8
+ //
9
+ }
@@ -0,0 +1,58 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { DefinitionList, Header } from '@transferwise/components';
14
+ import Help from '../../jsonSchemaForm/help/Help';
15
+ import { getMargin } from '../utils';
16
+ var getDefinitions = function (orientation, review) {
17
+ return review.fields.map(function (_a, index) {
18
+ var label = _a.label, value = _a.value, help = _a.help;
19
+ return ({
20
+ key: String(index),
21
+ title: label,
22
+ value: getFieldValue(value, help, orientation)
23
+ });
24
+ });
25
+ };
26
+ var getFieldValue = function (value, help, orientation) {
27
+ if (help) {
28
+ return orientation === 'HORIZONTAL_RIGHT_ALIGNED' ? (_jsxs(_Fragment, { children: [_jsx(Help, { help: help }), " ", value] })) : (_jsxs(_Fragment, { children: [value, " ", _jsx(Help, { help: help })] }));
29
+ }
30
+ return value;
31
+ };
32
+ var getReviewLayout = function (review) {
33
+ var orientation = review.control || review.orientation;
34
+ return orientation === 'horizontal' ? 'HORIZONTAL_RIGHT_ALIGNED' : 'VERTICAL_ONE_COLUMN';
35
+ };
36
+ function DynamicReview(props) {
37
+ var review = props.component;
38
+ var margin = getMargin(review.margin || 'xs');
39
+ var getReviewAction = function (title, action) { return ({
40
+ text: title !== null && title !== void 0 ? title : '',
41
+ href: action.url,
42
+ onClick: function (event) {
43
+ event.preventDefault();
44
+ if (action) {
45
+ props.onAction(action);
46
+ }
47
+ }
48
+ }); };
49
+ var orientation = getReviewLayout(review);
50
+ var callToAction = review.callToAction
51
+ ? getReviewAction(review.callToAction.title, review.callToAction.action)
52
+ : null;
53
+ var legacyCallToAction = !callToAction && review.action
54
+ ? getReviewAction(review.action.title || '', review.action)
55
+ : null;
56
+ return (_jsxs("div", __assign({ className: margin }, { children: [review.title && (_jsx(Header, { title: review.title, action: callToAction || legacyCallToAction || undefined })), _jsx("div", __assign({ className: margin }, { children: _jsx(DefinitionList, { layout: orientation, definitions: getDefinitions(orientation, review) }) }))] })));
57
+ }
58
+ export default DynamicReview;
@@ -0,0 +1,58 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { useMemo, useState } from 'react';
14
+ import { useEventDispatcher } from '../../common/contexts';
15
+ import { debounce } from '../../common/utils';
16
+ import DynamicLoadingIndicator from '../loadingIndicator/DynamicLoadingIndicator';
17
+ import { getMargin } from '../utils';
18
+ import { SearchInput } from './SearchInput';
19
+ import { ErrorResult, SearchResults } from './SearchResults';
20
+ import { useSearch } from './useSearch';
21
+ var DEBOUNCE_TIME = 400;
22
+ function DynamicSearch(_a) {
23
+ var component = _a.component, onAction = _a.onAction;
24
+ var _b = useState(''), query = _b[0], setQuery = _b[1];
25
+ var title = component.title, margin = component.margin, url = component.url, method = component.method, param = component.param, emptyMessage = component.emptyMessage;
26
+ var _c = useSearch({ url: url, method: method, param: param }), status = _c.status, results = _c.results, search = _c.search;
27
+ var onEvent = useEventDispatcher();
28
+ var debouncedSearch = useMemo(function () { return debounce(search, DEBOUNCE_TIME); }, [search]);
29
+ var onSearchStart = function () {
30
+ onEvent('Dynamic Flow - Search Started', {});
31
+ };
32
+ var onChange = function (value) {
33
+ setQuery(value);
34
+ debouncedSearch(value);
35
+ };
36
+ var onResultSelected = function (_a) {
37
+ var type = _a.type, value = _a.value;
38
+ if (type === 'action') {
39
+ onEvent('Dynamic Flow - Search Result Selected', {
40
+ type: 'action',
41
+ actionId: value.id || value.$id
42
+ });
43
+ onAction(value);
44
+ }
45
+ if (type === 'search') {
46
+ setQuery(value.query);
47
+ var url_1 = value.url, method_1 = value.method, param_1 = value.param, query_1 = value.query;
48
+ onEvent('Dynamic Flow - Search Result Selected', { type: 'search' });
49
+ void search(query_1, { url: url_1, method: method_1, param: param_1 });
50
+ }
51
+ };
52
+ var onRetrySearch = function () {
53
+ setQuery(query);
54
+ void search(query);
55
+ };
56
+ return (_jsxs("div", __assign({ className: getMargin(margin || 'md') }, { children: [_jsx(SearchInput, { title: title, value: query, onChange: onChange, onFocus: onSearchStart }), status === 'loading' && (_jsx(DynamicLoadingIndicator, { component: { type: 'loading-indicator', size: 'sm' } })), status === 'error' && _jsx(ErrorResult, { onRetrySearch: onRetrySearch }), status === 'success' && (_jsx(SearchResults, { results: results, emptyMessage: emptyMessage, onSelect: onResultSelected }))] })));
57
+ }
58
+ export default DynamicSearch;
@@ -0,0 +1,17 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { Input } from '@transferwise/components';
14
+ export var SearchInput = function (_a) {
15
+ var title = _a.title, value = _a.value, onFocus = _a.onFocus, onChange = _a.onChange;
16
+ return (_jsxs("label", __assign({ className: "control-label d-inline" }, { children: [title, _jsx(Input, { type: "text", value: value, className: "m-t-1", onFocus: onFocus, onChange: function (event) { return onChange(event.currentTarget.value); } })] })));
17
+ };
@@ -0,0 +1,31 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { NavigationOption, NavigationOptionsList } from '@transferwise/components';
14
+ import { useIntl } from 'react-intl';
15
+ import messages from '../../../common/messages/generic-error.messages';
16
+ import { getNavigationOptionMedia } from '../utils';
17
+ export function SearchResults(_a) {
18
+ var results = _a.results, emptyMessage = _a.emptyMessage, onSelect = _a.onSelect;
19
+ if (results.length === 0) {
20
+ return _jsx("p", __assign({ className: "m-t-2" }, { children: emptyMessage }));
21
+ }
22
+ return (_jsx(NavigationOptionsList, { children: results.map(function (result) { return (_jsx(NavigationOption, { title: result.title, content: result.description, media: getNavigationOptionMedia(result), showMediaCircle: false, showMediaAtAllSizes: true, onClick: function () { return onSelect(result); } }, JSON.stringify(result))); }) }));
23
+ }
24
+ export function ErrorResult(_a) {
25
+ var onRetrySearch = _a.onRetrySearch;
26
+ var intl = useIntl();
27
+ return (_jsxs("p", __assign({ className: "m-t-2" }, { children: [intl.formatMessage(messages.genericError), "\u00A0", _jsx("a", __assign({ href: "/", onClick: function (e) {
28
+ e.preventDefault();
29
+ onRetrySearch();
30
+ } }, { children: intl.formatMessage(messages.retry) }))] })));
31
+ }
@@ -0,0 +1,137 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ var __generator = (this && this.__generator) || function (thisArg, body) {
11
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
12
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
13
+ function verb(n) { return function (v) { return step([n, v]); }; }
14
+ function step(op) {
15
+ if (f) throw new TypeError("Generator is already executing.");
16
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
17
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
18
+ if (y = 0, t) op = [op[0] & 2, t.value];
19
+ switch (op[0]) {
20
+ case 0: case 1: t = op; break;
21
+ case 4: _.label++; return { value: op[1], done: false };
22
+ case 5: _.label++; y = op[1]; op = [0]; continue;
23
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
24
+ default:
25
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
26
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
27
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
28
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
29
+ if (t[2]) _.ops.pop();
30
+ _.trys.pop(); continue;
31
+ }
32
+ op = body.call(thisArg, _);
33
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
34
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
35
+ }
36
+ };
37
+ import { useCallback, useRef, useState } from 'react';
38
+ import { isArray, isObject } from '../../common/validators';
39
+ import { useHttpClient } from '../../../common/httpClientContext';
40
+ var headers = { 'Content-Type': 'application/json' };
41
+ export var useSearch = function (defaultSearchConfig) {
42
+ var _a = useState({
43
+ status: 'idle'
44
+ }), state = _a[0], setState = _a[1];
45
+ var abortControllerRef = useRef(null);
46
+ var httpClient = useHttpClient();
47
+ var search = useCallback(function (query, _a) {
48
+ var _b = _a === void 0 ? defaultSearchConfig : _a, url = _b.url, method = _b.method, param = _b.param;
49
+ return __awaiter(void 0, void 0, void 0, function () {
50
+ var signal, request, response, error_1;
51
+ var _c;
52
+ var _d;
53
+ return __generator(this, function (_e) {
54
+ switch (_e.label) {
55
+ case 0:
56
+ (_d = abortControllerRef.current) === null || _d === void 0 ? void 0 : _d.abort();
57
+ if (!query) {
58
+ setState({ status: 'idle' });
59
+ return [2 /*return*/];
60
+ }
61
+ abortControllerRef.current = new AbortController();
62
+ signal = abortControllerRef.current.signal;
63
+ setState({ status: 'loading' });
64
+ _e.label = 1;
65
+ case 1:
66
+ _e.trys.push([1, 3, , 4]);
67
+ request = method === 'GET'
68
+ ? httpClient(addQueryParameter(url, param, query), {
69
+ method: method,
70
+ signal: signal,
71
+ headers: headers
72
+ })
73
+ : httpClient(url, {
74
+ method: method,
75
+ signal: signal,
76
+ headers: headers,
77
+ body: JSON.stringify((_c = {}, _c[param] = query, _c))
78
+ });
79
+ return [4 /*yield*/, request];
80
+ case 2:
81
+ response = _e.sent();
82
+ void handleResponse(response, query);
83
+ return [3 /*break*/, 4];
84
+ case 3:
85
+ error_1 = _e.sent();
86
+ handleError(error_1, query);
87
+ return [3 /*break*/, 4];
88
+ case 4: return [2 /*return*/];
89
+ }
90
+ });
91
+ });
92
+ },
93
+ // eslint-disable-next-line react-hooks/exhaustive-deps
94
+ [httpClient, JSON.stringify(defaultSearchConfig)]);
95
+ var handleResponse = function (response, query) { return __awaiter(void 0, void 0, void 0, function () {
96
+ var body;
97
+ return __generator(this, function (_a) {
98
+ switch (_a.label) {
99
+ case 0:
100
+ if (!response.ok) return [3 /*break*/, 2];
101
+ return [4 /*yield*/, response.json()["catch"](function () { return null; })];
102
+ case 1:
103
+ body = _a.sent();
104
+ if (isValidResponseBody(body)) {
105
+ setState({ status: 'success', results: body.results });
106
+ return [2 /*return*/];
107
+ }
108
+ _a.label = 2;
109
+ case 2:
110
+ setState({ status: 'error' });
111
+ return [2 /*return*/];
112
+ }
113
+ });
114
+ }); };
115
+ var handleError = function (error, query) {
116
+ if (!isAbortError(error)) {
117
+ setState({ status: 'error' });
118
+ }
119
+ };
120
+ var results = state.status === 'success' ? state.results : [];
121
+ return { status: state.status, results: results, search: search };
122
+ };
123
+ var isValidResponseBody = function (body) {
124
+ return isObject(body) &&
125
+ 'results' in body &&
126
+ isArray(body.results) &&
127
+ body.results.every(function (result) { return isObject(result) && 'title' in result && 'type' in result && 'value' in result; });
128
+ };
129
+ var isAbortError = function (error) {
130
+ return error instanceof DOMException && error.name === 'AbortError';
131
+ };
132
+ var addQueryParameter = function (url, key, value) {
133
+ var _a = url.split('?'), urlBase = _a[0], urlQuery = _a[1];
134
+ var urlQueryParams = new URLSearchParams(urlQuery);
135
+ urlQueryParams.set(key, value);
136
+ return "".concat(urlBase, "?").concat(urlQueryParams.toString());
137
+ };