@rabbitio/ui-kit 1.0.0-beta.9 → 1.0.0-beta.91

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 (369) hide show
  1. package/.gitlab-ci.yml +29 -0
  2. package/.husky/commit-msg +19 -0
  3. package/.husky/pre-push +1 -0
  4. package/CHANGELOG.md +0 -0
  5. package/README.md +27 -18
  6. package/coverage/base.css +224 -0
  7. package/coverage/block-navigation.js +87 -0
  8. package/coverage/clover.xml +16765 -0
  9. package/coverage/coverage-final.json +116 -0
  10. package/coverage/favicon.png +0 -0
  11. package/coverage/index.html +1001 -0
  12. package/coverage/prettify.css +1 -0
  13. package/coverage/prettify.js +2 -0
  14. package/coverage/rabbit-ui-kit/index.html +116 -0
  15. package/coverage/rabbit-ui-kit/index.js.html +88 -0
  16. package/coverage/rabbit-ui-kit/src/common-apis/adapters/analyticsAdapters/googleAnalyticsAdapter.js.html +148 -0
  17. package/coverage/rabbit-ui-kit/src/common-apis/adapters/analyticsAdapters/index.html +146 -0
  18. package/coverage/rabbit-ui-kit/src/common-apis/adapters/analyticsAdapters/metrikaAdapter.js.html +169 -0
  19. package/coverage/rabbit-ui-kit/src/common-apis/adapters/analyticsAdapters/mixpanelAdapter.js.html +199 -0
  20. package/coverage/rabbit-ui-kit/src/common-apis/adapters/axiosAdapter.js.html +190 -0
  21. package/coverage/rabbit-ui-kit/src/common-apis/adapters/index.html +131 -0
  22. package/coverage/rabbit-ui-kit/src/common-apis/adapters/qrUtils.js.html +139 -0
  23. package/coverage/rabbit-ui-kit/src/common-apis/external-apis/apiGroups.js.html +250 -0
  24. package/coverage/rabbit-ui-kit/src/common-apis/external-apis/emailAPI.js.html +133 -0
  25. package/coverage/rabbit-ui-kit/src/common-apis/external-apis/index.html +146 -0
  26. package/coverage/rabbit-ui-kit/src/common-apis/external-apis/ipAddressProviders.js.html +352 -0
  27. package/coverage/rabbit-ui-kit/src/common-apis/globalConstants.jsx.html +94 -0
  28. package/coverage/rabbit-ui-kit/src/common-apis/index.html +116 -0
  29. package/coverage/rabbit-ui-kit/src/common-apis/models/blockchain.js.html +115 -0
  30. package/coverage/rabbit-ui-kit/src/common-apis/models/coin.js.html +829 -0
  31. package/coverage/rabbit-ui-kit/src/common-apis/models/index.html +146 -0
  32. package/coverage/rabbit-ui-kit/src/common-apis/models/protocol.js.html +100 -0
  33. package/coverage/rabbit-ui-kit/src/common-apis/services/fiatCurrenciesService.js.html +544 -0
  34. package/coverage/rabbit-ui-kit/src/common-apis/services/index.html +116 -0
  35. package/coverage/rabbit-ui-kit/src/common-apis/utils/amountUtils.js.html +1162 -0
  36. package/coverage/rabbit-ui-kit/src/common-apis/utils/cache.js.html +811 -0
  37. package/coverage/rabbit-ui-kit/src/common-apis/utils/errorUtils.js.html +211 -0
  38. package/coverage/rabbit-ui-kit/src/common-apis/utils/index.html +191 -0
  39. package/coverage/rabbit-ui-kit/src/common-apis/utils/logging/index.html +131 -0
  40. package/coverage/rabbit-ui-kit/src/common-apis/utils/logging/logger.js.html +208 -0
  41. package/coverage/rabbit-ui-kit/src/common-apis/utils/logging/logsStorage.js.html +268 -0
  42. package/coverage/rabbit-ui-kit/src/common-apis/utils/postponeExecution.js.html +118 -0
  43. package/coverage/rabbit-ui-kit/src/common-apis/utils/rabbitTicker.js.html +157 -0
  44. package/coverage/rabbit-ui-kit/src/common-apis/utils/safeStringify.js.html +235 -0
  45. package/coverage/rabbit-ui-kit/src/index.html +116 -0
  46. package/coverage/rabbit-ui-kit/src/index.js.html +376 -0
  47. package/coverage/rabbit-ui-kit/src/robust-api-caller/cacheAndConcurrentRequestsResolver.js.html +1570 -0
  48. package/coverage/rabbit-ui-kit/src/robust-api-caller/cachedRobustExternalApiCallerService.js.html +526 -0
  49. package/coverage/rabbit-ui-kit/src/robust-api-caller/cancelProcessing.js.html +172 -0
  50. package/coverage/rabbit-ui-kit/src/robust-api-caller/concurrentCalculationsMetadataHolder.js.html +310 -0
  51. package/coverage/rabbit-ui-kit/src/robust-api-caller/externalApiProvider.js.html +553 -0
  52. package/coverage/rabbit-ui-kit/src/robust-api-caller/externalServicesStatsCollector.js.html +319 -0
  53. package/coverage/rabbit-ui-kit/src/robust-api-caller/index.html +206 -0
  54. package/coverage/rabbit-ui-kit/src/robust-api-caller/robustExternalAPICallerService.js.html +997 -0
  55. package/coverage/rabbit-ui-kit/src/swaps-lib/external-apis/exolixSwapProvider.js.html +1825 -0
  56. package/coverage/rabbit-ui-kit/src/swaps-lib/external-apis/index.html +161 -0
  57. package/coverage/rabbit-ui-kit/src/swaps-lib/external-apis/letsExchangeSwapProvider.js.html +1618 -0
  58. package/coverage/rabbit-ui-kit/src/swaps-lib/external-apis/swapProvider.js.html +1819 -0
  59. package/coverage/rabbit-ui-kit/src/swaps-lib/external-apis/swapspaceSwapProvider.js.html +1861 -0
  60. package/coverage/rabbit-ui-kit/src/swaps-lib/models/baseSwapCreationInfo.js.html +319 -0
  61. package/coverage/rabbit-ui-kit/src/swaps-lib/models/existingSwap.js.html +514 -0
  62. package/coverage/rabbit-ui-kit/src/swaps-lib/models/existingSwapWithFiatData.js.html +529 -0
  63. package/coverage/rabbit-ui-kit/src/swaps-lib/models/index.html +176 -0
  64. package/coverage/rabbit-ui-kit/src/swaps-lib/models/partner.js.html +166 -0
  65. package/coverage/rabbit-ui-kit/src/swaps-lib/models/swapProviderCoinInfo.js.html +331 -0
  66. package/coverage/rabbit-ui-kit/src/swaps-lib/services/index.html +116 -0
  67. package/coverage/rabbit-ui-kit/src/swaps-lib/services/publicSwapService.js.html +1555 -0
  68. package/coverage/rabbit-ui-kit/src/swaps-lib/utils/index.html +116 -0
  69. package/coverage/rabbit-ui-kit/src/swaps-lib/utils/swapUtils.js.html +670 -0
  70. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/arrowIcon.jsx.html +124 -0
  71. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/arrowTosca.jsx.html +127 -0
  72. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/arrowWhite.jsx.html +127 -0
  73. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/darkRectangle.jsx.html +106 -0
  74. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/determinedError.jsx.html +439 -0
  75. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/failedValidationIcon.jsx.html +202 -0
  76. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/index.html +281 -0
  77. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/infoIcon.jsx.html +133 -0
  78. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/messageIcon.jsx.html +346 -0
  79. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/noticeQuestionIcon.jsx.html +247 -0
  80. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/successfulValidationIcon.jsx.html +163 -0
  81. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/supportDialogImage.jsx.html +268 -0
  82. package/coverage/rabbit-ui-kit/src/ui-kit/assets/wrappedImages/walletIcon.jsx.html +151 -0
  83. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/AssetIcon/AssetIcon.jsx.html +256 -0
  84. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/AssetIcon/index.html +116 -0
  85. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/AssetSelection/AssetSelection.jsx.html +289 -0
  86. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/AssetSelection/index.html +116 -0
  87. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/BackgroundTitle/BackgroundTitle.jsx.html +187 -0
  88. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/BackgroundTitle/index.html +116 -0
  89. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/InformationMessage/InformationMessage.jsx.html +238 -0
  90. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/InformationMessage/index.html +116 -0
  91. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Input/Input.jsx.html +634 -0
  92. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Input/index.html +116 -0
  93. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/LoadingDots/LoadingDots.jsx.html +196 -0
  94. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/LoadingDots/index.html +116 -0
  95. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/NoticeIcon/NoticeIcon.jsx.html +277 -0
  96. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/NoticeIcon/index.html +116 -0
  97. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/QrCode/QrCode.jsx.html +217 -0
  98. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/QrCode/index.html +116 -0
  99. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/RateSelector/RateSelector.jsx.html +175 -0
  100. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/RateSelector/index.html +116 -0
  101. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/SupportChat/SupportChat.jsx.html +217 -0
  102. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/SupportChat/index.html +116 -0
  103. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Textarea/Textarea.jsx.html +529 -0
  104. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Textarea/index.html +116 -0
  105. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/TitleBox/TitleBox.jsx.html +508 -0
  106. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/TitleBox/index.html +116 -0
  107. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Tooltip/Tooltip.jsx.html +316 -0
  108. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Tooltip/index.html +116 -0
  109. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/TwoLinesOfText/LinesOfText.jsx.html +313 -0
  110. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/TwoLinesOfText/index.html +116 -0
  111. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Validation/Validation.jsx.html +202 -0
  112. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/Validation/index.html +116 -0
  113. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/Button/Button.jsx.html +712 -0
  114. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/Button/index.html +116 -0
  115. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/Close/Close.jsx.html +259 -0
  116. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/Close/index.html +116 -0
  117. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/LinkButton/LinkButton.jsx.html +421 -0
  118. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/LinkButton/index.html +116 -0
  119. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/RadioButtonWithText/RadioButtonWithText.jsx.html +415 -0
  120. package/coverage/rabbit-ui-kit/src/ui-kit/components/atoms/buttons/RadioButtonWithText/index.html +116 -0
  121. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/AmountInput/AmountInput.jsx.html +1429 -0
  122. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/AmountInput/index.html +116 -0
  123. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/CoinPicker/CoinPicker.jsx.html +1474 -0
  124. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/CoinPicker/index.html +116 -0
  125. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/ColoredNotice/ColoredNotice.jsx.html +211 -0
  126. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/ColoredNotice/index.html +116 -0
  127. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/LineWithIconLink/LineWithIconLink.jsx.html +190 -0
  128. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/LineWithIconLink/index.html +116 -0
  129. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/LogoCarousel/LogoCarousel.jsx.html +307 -0
  130. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/LogoCarousel/index.html +116 -0
  131. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/SearchableCoinsList/SearchableCoinsList.jsx.html +496 -0
  132. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/SearchableCoinsList/index.html +116 -0
  133. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/TitledLineWithIconLink/TitledLineWithIconLink.jsx.html +181 -0
  134. package/coverage/rabbit-ui-kit/src/ui-kit/components/molecules/TitledLineWithIconLink/index.html +116 -0
  135. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/CoinPickerDialogStep/CoinPickerDialogStep.jsx.html +283 -0
  136. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/CoinPickerDialogStep/index.html +116 -0
  137. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/Dialog/Dialog.jsx.html +1567 -0
  138. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/Dialog/DialogButtons/DialogButtons.jsx.html +481 -0
  139. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/Dialog/DialogButtons/index.html +116 -0
  140. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/Dialog/DialogStep/DialogStep.jsx.html +1747 -0
  141. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/Dialog/DialogStep/index.html +116 -0
  142. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/Dialog/index.html +116 -0
  143. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/SwapForm/SwapForm.jsx.html +4207 -0
  144. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/SwapForm/index.html +116 -0
  145. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/WaitlistSubscription/WaitlistSubscription.jsx.html +559 -0
  146. package/coverage/rabbit-ui-kit/src/ui-kit/components/organisms/WaitlistSubscription/index.html +116 -0
  147. package/coverage/rabbit-ui-kit/src/ui-kit/components/templates/DeterminedErrorDialogStep/DeterminedErrorDialogStep.jsx.html +316 -0
  148. package/coverage/rabbit-ui-kit/src/ui-kit/components/templates/DeterminedErrorDialogStep/index.html +116 -0
  149. package/coverage/rabbit-ui-kit/src/ui-kit/hooks/index.html +146 -0
  150. package/coverage/rabbit-ui-kit/src/ui-kit/hooks/useCallHandlingErrors.js.html +151 -0
  151. package/coverage/rabbit-ui-kit/src/ui-kit/hooks/useIsHydrated.js.html +121 -0
  152. package/coverage/rabbit-ui-kit/src/ui-kit/hooks/useReferredState.js.html +157 -0
  153. package/coverage/rabbit-ui-kit/src/ui-kit/utils/index.html +161 -0
  154. package/coverage/rabbit-ui-kit/src/ui-kit/utils/inputValueProviders.js.html +235 -0
  155. package/coverage/rabbit-ui-kit/src/ui-kit/utils/textUtils.js.html +139 -0
  156. package/coverage/rabbit-ui-kit/src/ui-kit/utils/uiUtils.js.html +121 -0
  157. package/coverage/rabbit-ui-kit/src/ui-kit/utils/urlQueryUtils.js.html +271 -0
  158. package/coverage/rabbit-ui-kit/stories/atoms/BackgroundTitle.stories.jsx.html +202 -0
  159. package/coverage/rabbit-ui-kit/stories/atoms/LinesOfText.stories.jsx.html +283 -0
  160. package/coverage/rabbit-ui-kit/stories/atoms/LoadingDots.stories.jsx.html +226 -0
  161. package/coverage/rabbit-ui-kit/stories/atoms/QrCode.stories.jsx.html +175 -0
  162. package/coverage/rabbit-ui-kit/stories/atoms/RateSelector.stories.jsx.html +136 -0
  163. package/coverage/rabbit-ui-kit/stories/atoms/Validation.stories.jsx.html +178 -0
  164. package/coverage/rabbit-ui-kit/stories/atoms/buttons/Button.stories.jsx.html +883 -0
  165. package/coverage/rabbit-ui-kit/stories/atoms/buttons/Close.stories.jsx.html +211 -0
  166. package/coverage/rabbit-ui-kit/stories/atoms/buttons/LinkButton.stories.jsx.html +301 -0
  167. package/coverage/rabbit-ui-kit/stories/atoms/buttons/index.html +146 -0
  168. package/coverage/rabbit-ui-kit/stories/atoms/index.html +191 -0
  169. package/coverage/rabbit-ui-kit/stories/molecules/AmountInput.stories.jsx.html +289 -0
  170. package/coverage/rabbit-ui-kit/stories/molecules/CoinPicker.stories.jsx.html +322 -0
  171. package/coverage/rabbit-ui-kit/stories/molecules/ColoredNotice.stories.jsx.html +178 -0
  172. package/coverage/rabbit-ui-kit/stories/molecules/LineWithIconLink.stories.jsx.html +154 -0
  173. package/coverage/rabbit-ui-kit/stories/molecules/LogoCarousel.stories.jsx.html +235 -0
  174. package/coverage/rabbit-ui-kit/stories/molecules/TitledLineWithIconLink.stories.jsx.html +160 -0
  175. package/coverage/rabbit-ui-kit/stories/molecules/index.html +191 -0
  176. package/coverage/rabbit-ui-kit/stories/organisms/Dialog/Dialog.stories.jsx.html +523 -0
  177. package/coverage/rabbit-ui-kit/stories/organisms/Dialog/DialogButtons/DialogButtons.stories.jsx.html +328 -0
  178. package/coverage/rabbit-ui-kit/stories/organisms/Dialog/DialogButtons/index.html +116 -0
  179. package/coverage/rabbit-ui-kit/stories/organisms/Dialog/DialogStep/DialogStep.stories.jsx.html +337 -0
  180. package/coverage/rabbit-ui-kit/stories/organisms/Dialog/DialogStep/index.html +116 -0
  181. package/coverage/rabbit-ui-kit/stories/organisms/Dialog/index.html +116 -0
  182. package/coverage/rabbit-ui-kit/stories/organisms/WaitlistSubscription.stories.jsx.html +151 -0
  183. package/coverage/rabbit-ui-kit/stories/organisms/index.html +116 -0
  184. package/coverage/rabbit-ui-kit/stories/stubs/coins.jsx.html +6880 -0
  185. package/coverage/rabbit-ui-kit/stories/stubs/exampleContent.jsx.html +145 -0
  186. package/coverage/rabbit-ui-kit/stories/stubs/index.html +131 -0
  187. package/coverage/rabbit-ui-kit/stories/templates/DeterminedErrorDialogStep.stories.jsx.html +190 -0
  188. package/coverage/rabbit-ui-kit/stories/templates/index.html +116 -0
  189. package/coverage/sort-arrow-sprite.png +0 -0
  190. package/coverage/sorter.js +196 -0
  191. package/dist/global.css +197 -0
  192. package/dist/global.css.map +1 -0
  193. package/dist/index.cjs +12451 -25
  194. package/dist/index.cjs.map +1 -1
  195. package/dist/index.css +2339 -8491
  196. package/dist/index.css.map +1 -1
  197. package/dist/index.modern.js +9597 -26
  198. package/dist/index.modern.js.map +1 -1
  199. package/dist/index.module.js +12357 -27
  200. package/dist/index.module.js.map +1 -1
  201. package/dist/index.umd.js +12442 -29
  202. package/dist/index.umd.js.map +1 -1
  203. package/package.json +35 -9
  204. package/raw +1000 -0
  205. package/src/common-apis/adapters/analyticsAdapters/googleAnalyticsAdapter.js +21 -0
  206. package/src/common-apis/adapters/analyticsAdapters/metrikaAdapter.js +28 -0
  207. package/src/common-apis/adapters/analyticsAdapters/mixpanelAdapter.js +38 -0
  208. package/src/common-apis/adapters/axiosAdapter.js +35 -0
  209. package/src/common-apis/adapters/qrUtils.js +18 -0
  210. package/src/common-apis/external-apis/apiGroups.js +55 -0
  211. package/src/common-apis/external-apis/emailAPI.js +16 -0
  212. package/src/common-apis/external-apis/ipAddressProviders.js +89 -0
  213. package/src/common-apis/globalConstants.jsx +3 -0
  214. package/src/common-apis/models/blockchain.js +10 -0
  215. package/src/common-apis/models/coin.js +248 -0
  216. package/src/common-apis/models/protocol.js +5 -0
  217. package/src/{common → common-apis/services}/fiatCurrenciesService.js +4 -12
  218. package/src/common-apis/tests/integration/external-apis/ipAddressProviders/getClientIpAddress.test.js +12 -0
  219. package/src/common-apis/tests/units/utils/amountUtils/composeRateText.test.js +152 -0
  220. package/src/{common → common-apis/utils}/amountUtils.js +72 -136
  221. package/src/common-apis/utils/cache.js +242 -0
  222. package/src/{common → common-apis/utils}/errorUtils.js +15 -0
  223. package/src/common-apis/utils/logging/logger.js +41 -0
  224. package/src/common-apis/utils/logging/logsStorage.js +61 -0
  225. package/src/common-apis/utils/postponeExecution.js +11 -0
  226. package/src/common-apis/utils/rabbitTicker.js +24 -0
  227. package/src/common-apis/utils/safeStringify.js +50 -0
  228. package/src/index.js +96 -9
  229. package/src/robust-api-caller/cacheAndConcurrentRequestsResolver.js +495 -0
  230. package/src/robust-api-caller/cachedRobustExternalApiCallerService.js +147 -0
  231. package/src/robust-api-caller/cancelProcessing.js +29 -0
  232. package/src/robust-api-caller/concurrentCalculationsMetadataHolder.js +75 -0
  233. package/src/robust-api-caller/externalApiProvider.js +156 -0
  234. package/src/robust-api-caller/externalServicesStatsCollector.js +78 -0
  235. package/src/robust-api-caller/robustExternalAPICallerService.js +304 -0
  236. package/src/robust-api-caller/tests/robustExternalAPICallerService/robustExternalAPICallerService/callExternalAPI/_performCallAttempt.test.js +533 -0
  237. package/src/robust-api-caller/tests/robustExternalAPICallerService/robustExternalAPICallerService/callExternalAPI/callExternalAPI.test.js +532 -0
  238. package/src/robust-api-caller/tests/robustExternalAPICallerService/robustExternalAPICallerService/constructor.test.js +19 -0
  239. package/src/swaps-lib/external-apis/exolixSwapProvider.js +580 -0
  240. package/src/swaps-lib/external-apis/letsExchangeSwapProvider.js +511 -0
  241. package/src/swaps-lib/external-apis/swapProvider.js +578 -0
  242. package/src/swaps-lib/external-apis/swapspaceSwapProvider.js +592 -0
  243. package/src/swaps-lib/models/baseSwapCreationInfo.js +78 -0
  244. package/src/swaps-lib/models/existingSwap.js +143 -0
  245. package/src/swaps-lib/models/existingSwapWithFiatData.js +148 -0
  246. package/src/swaps-lib/models/partner.js +27 -0
  247. package/src/swaps-lib/models/swapProviderCoinInfo.js +82 -0
  248. package/src/swaps-lib/services/publicSwapService.js +490 -0
  249. package/src/swaps-lib/test/external-apis/exolixSwapProvider/_fetchSupportedCurrenciesIfNeeded.test.js +34 -0
  250. package/src/swaps-lib/test/external-apis/exolixSwapProvider/createSwap.test.js +1043 -0
  251. package/src/swaps-lib/test/external-apis/exolixSwapProvider/getSwapInfo.test.js +611 -0
  252. package/src/swaps-lib/test/external-apis/swapProvider/getAllSupportedCurrencies.test.js +63 -0
  253. package/src/swaps-lib/test/external-apis/swapProvider/getDepositCurrencies.test.js +73 -0
  254. package/src/swaps-lib/test/external-apis/swapProvider/getWithdrawalCurrencies.test.js +102 -0
  255. package/src/swaps-lib/test/external-apis/swapProvider/removeProtocolNameFromCoinName.test.js +152 -0
  256. package/src/swaps-lib/test/external-apis/swapspaceSwapProvider/_fetchSupportedCurrenciesIfNeeded.test.js +536 -0
  257. package/src/swaps-lib/test/external-apis/swapspaceSwapProvider/createSwap.test.js +1214 -0
  258. package/src/swaps-lib/test/external-apis/swapspaceSwapProvider/getSwapInfo.test.js +1707 -0
  259. package/src/swaps-lib/test/utils/swapUtils/safeHandleRequestsLimitExceeding.test.js +80 -0
  260. package/src/swaps-lib/utils/swapUtils.js +195 -0
  261. package/{styles → src/ui-kit/assets/styles}/_functions.scss +5 -0
  262. package/{styles → src/ui-kit/assets/styles}/_mixins.scss +2 -2
  263. package/{styles → src/ui-kit/assets/styles}/_placeholder.scss +3 -3
  264. package/{styles → src/ui-kit/assets/styles}/_variables.scss +17 -15
  265. package/src/ui-kit/assets/styles/fonts/NunitoSans-Bold.ttf +0 -0
  266. package/src/ui-kit/assets/styles/fonts/NunitoSans-ExtraBold.ttf +0 -0
  267. package/src/ui-kit/assets/styles/fonts/NunitoSans-Light.ttf +0 -0
  268. package/src/ui-kit/assets/styles/fonts/NunitoSans-Regular.ttf +0 -0
  269. package/src/ui-kit/assets/styles/fonts/NunitoSans-SemiBold.ttf +0 -0
  270. package/src/ui-kit/assets/styles/global.scss +171 -0
  271. package/src/ui-kit/assets/styles/index.scss +10 -0
  272. package/src/ui-kit/assets/wrappedImages/arrowIcon.jsx +13 -0
  273. package/src/ui-kit/assets/wrappedImages/arrowTosca.jsx +14 -0
  274. package/src/ui-kit/assets/wrappedImages/arrowWhite.jsx +14 -0
  275. package/src/ui-kit/assets/wrappedImages/darkRectangle.jsx +7 -0
  276. package/src/ui-kit/assets/wrappedImages/determinedError.jsx +118 -0
  277. package/src/ui-kit/assets/wrappedImages/failedValidationIcon.jsx +39 -0
  278. package/src/ui-kit/assets/wrappedImages/infoIcon.jsx +16 -0
  279. package/src/ui-kit/assets/wrappedImages/messageIcon.jsx +87 -0
  280. package/src/ui-kit/assets/wrappedImages/noticeQuestionIcon.jsx +54 -0
  281. package/src/ui-kit/assets/wrappedImages/successfulValidationIcon.jsx +26 -0
  282. package/src/ui-kit/assets/wrappedImages/supportDialogImage.jsx +61 -0
  283. package/src/ui-kit/assets/wrappedImages/walletIcon.jsx +22 -0
  284. package/src/ui-kit/components/atoms/AssetIcon/AssetIcon.jsx +57 -0
  285. package/src/{components → ui-kit/components}/atoms/AssetIcon/asset-icon.module.scss +1 -1
  286. package/src/ui-kit/components/atoms/AssetSelection/AssetSelection.jsx +68 -0
  287. package/src/ui-kit/components/atoms/AssetSelection/asset-selection.module.scss +56 -0
  288. package/src/ui-kit/components/atoms/BackgroundTitle/BackgroundTitle.jsx +34 -0
  289. package/src/ui-kit/components/atoms/BackgroundTitle/background-title.module.scss +52 -0
  290. package/src/ui-kit/components/atoms/InformationMessage/InformationMessage.jsx +51 -0
  291. package/src/ui-kit/components/atoms/InformationMessage/information-message.module.scss +38 -0
  292. package/src/ui-kit/components/atoms/Input/Input.jsx +183 -0
  293. package/src/ui-kit/components/atoms/Input/input.module.scss +107 -0
  294. package/src/{components → ui-kit/components}/atoms/LoadingDots/LoadingDots.jsx +8 -28
  295. package/src/{components → ui-kit/components}/atoms/LoadingDots/LoadingDots.module.scss +3 -2
  296. package/src/ui-kit/components/atoms/NoticeIcon/NoticeIcon.jsx +64 -0
  297. package/src/ui-kit/components/atoms/NoticeIcon/notice-icon.module.scss +14 -0
  298. package/src/ui-kit/components/atoms/QrCode/QrCode.jsx +44 -0
  299. package/src/ui-kit/components/atoms/QrCode/qr-code.module.scss +15 -0
  300. package/src/ui-kit/components/atoms/RateSelector/RateSelector.jsx +30 -0
  301. package/src/ui-kit/components/atoms/RateSelector/rate-selector.module.scss +47 -0
  302. package/src/{components → ui-kit/components}/atoms/SupportChat/SupportChat.jsx +5 -1
  303. package/src/ui-kit/components/atoms/Textarea/Textarea.jsx +148 -0
  304. package/src/ui-kit/components/atoms/Textarea/textarea.module.scss +71 -0
  305. package/src/ui-kit/components/atoms/TitleBox/TitleBox.jsx +141 -0
  306. package/src/ui-kit/components/atoms/TitleBox/title-box.module.scss +32 -0
  307. package/src/ui-kit/components/atoms/Tooltip/Tooltip.jsx +77 -0
  308. package/src/ui-kit/components/atoms/Tooltip/tooltip.module.scss +237 -0
  309. package/src/ui-kit/components/atoms/TwoLinesOfText/LinesOfText.jsx +76 -0
  310. package/src/ui-kit/components/atoms/TwoLinesOfText/lines-of-text.module.scss +65 -0
  311. package/src/ui-kit/components/atoms/Validation/Validation.jsx +39 -0
  312. package/src/ui-kit/components/atoms/Validation/validation.module.scss +19 -0
  313. package/src/{components → ui-kit/components}/atoms/buttons/Button/Button.jsx +24 -50
  314. package/src/{components → ui-kit/components}/atoms/buttons/Button/Button.module.scss +1 -1
  315. package/src/ui-kit/components/atoms/buttons/Close/Close.jsx +58 -0
  316. package/src/ui-kit/components/atoms/buttons/Close/close.module.scss +75 -0
  317. package/src/ui-kit/components/atoms/buttons/LinkButton/LinkButton.jsx +112 -0
  318. package/src/ui-kit/components/atoms/buttons/LinkButton/link-button.module.scss +49 -0
  319. package/src/ui-kit/components/atoms/buttons/RadioButtonWithText/RadioButtonWithText.jsx +110 -0
  320. package/src/ui-kit/components/atoms/buttons/RadioButtonWithText/radio-button-with-text.module.scss +86 -0
  321. package/src/ui-kit/components/molecules/AmountInput/AmountInput.jsx +448 -0
  322. package/src/ui-kit/components/molecules/AmountInput/amount-input.module.scss +233 -0
  323. package/src/ui-kit/components/molecules/CoinPicker/CoinPicker.jsx +463 -0
  324. package/src/ui-kit/components/molecules/CoinPicker/coin-picker.module.scss +207 -0
  325. package/src/ui-kit/components/molecules/ColoredNotice/ColoredNotice.jsx +42 -0
  326. package/src/ui-kit/components/molecules/ColoredNotice/colored-notice.module.scss +20 -0
  327. package/src/ui-kit/components/molecules/LineWithIconLink/LineWithIconLink.jsx +35 -0
  328. package/src/ui-kit/components/molecules/LineWithIconLink/line-with-icon-link.module.scss +25 -0
  329. package/src/ui-kit/components/molecules/LogoCarousel/LogoCarousel.jsx +74 -0
  330. package/src/ui-kit/components/molecules/LogoCarousel/logo-carousel.module.scss +106 -0
  331. package/src/ui-kit/components/molecules/SearchableCoinsList/SearchableCoinsList.jsx +137 -0
  332. package/src/ui-kit/components/molecules/TitledLineWithIconLink/TitledLineWithIconLink.jsx +32 -0
  333. package/src/ui-kit/components/organisms/CoinPickerDialogStep/CoinPickerDialogStep.jsx +66 -0
  334. package/src/ui-kit/components/organisms/Dialog/Dialog.jsx +494 -0
  335. package/src/ui-kit/components/organisms/Dialog/DialogButtons/DialogButtons.jsx +132 -0
  336. package/src/ui-kit/components/organisms/Dialog/DialogButtons/dialog-buttons.module.scss +25 -0
  337. package/src/ui-kit/components/organisms/Dialog/DialogStep/DialogStep.jsx +554 -0
  338. package/src/ui-kit/components/organisms/Dialog/DialogStep/dialog-step.module.scss +381 -0
  339. package/src/ui-kit/components/organisms/Dialog/dialog.module.scss +226 -0
  340. package/src/ui-kit/components/organisms/SwapForm/SwapForm.jsx +1374 -0
  341. package/src/ui-kit/components/organisms/SwapForm/swap-form.module.scss +134 -0
  342. package/src/ui-kit/components/organisms/WaitlistSubscription/WaitlistSubscription.jsx +158 -0
  343. package/src/ui-kit/components/templates/DeterminedErrorDialogStep/DeterminedErrorDialogStep.jsx +77 -0
  344. package/src/ui-kit/hooks/useCallHandlingErrors.js +22 -0
  345. package/src/ui-kit/hooks/useIsHydrated.js +12 -0
  346. package/src/ui-kit/hooks/useReferredState.js +24 -0
  347. package/src/ui-kit/tests/utils/inputValueProviders/provideFormatOfFloatValueByInputString.test.js +146 -0
  348. package/src/ui-kit/tests/utils/urlQueryUtils/getQueryParameterValues.test.js +65 -0
  349. package/src/ui-kit/tests/utils/urlQueryUtils/saveQueryParameterAndValues.test.js +104 -0
  350. package/src/ui-kit/utils/inputValueProviders.js +50 -0
  351. package/src/ui-kit/utils/textUtils.js +18 -0
  352. package/src/ui-kit/utils/uiUtils.js +12 -0
  353. package/src/ui-kit/utils/urlQueryUtils.js +62 -0
  354. package/stories/font.scss +40 -0
  355. package/stories/stubs/coins.jsx +2266 -0
  356. package/stories/stubs/exampleContent.jsx +20 -0
  357. package/src/components/atoms/AssetIcon/AssetIcon.jsx +0 -55
  358. package/styles/_global-classes.scss +0 -433
  359. package/styles/fonts/NunitoSans-Bold.ttf +0 -0
  360. package/styles/fonts/NunitoSans-ExtraBold.ttf +0 -0
  361. package/styles/fonts/NunitoSans-Light.ttf +0 -0
  362. package/styles/fonts/NunitoSans-Regular.ttf +0 -0
  363. package/styles/fonts/NunitoSans-SemiBold.ttf +0 -0
  364. package/styles/global-styles-index.scss +0 -74
  365. package/styles/index.scss +0 -33
  366. /package/{styles → src/ui-kit/assets/styles}/colors/_light-colors.scss +0 -0
  367. /package/{styles → src/ui-kit/assets/styles}/colors/_solid-colors.scss +0 -0
  368. /package/{styles → src/ui-kit/assets/styles}/size/_margin-size.scss +0 -0
  369. /package/{styles → src/ui-kit/assets/styles}/size/_padding-size.scss +0 -0
@@ -0,0 +1,611 @@
1
+ import sinon from "sinon";
2
+ import axios from "axios";
3
+ import should from "should";
4
+
5
+ import { beforeEach, afterEach, describe, it } from "vitest";
6
+
7
+ import { SwapProvider } from "../../../external-apis/swapProvider.js";
8
+ import { ExolixSwapProvider } from "../../../external-apis/exolixSwapProvider.js";
9
+ import { Cache } from "../../../../common-apis/utils/cache.js";
10
+ import { AmountUtils } from "../../../../common-apis/utils/amountUtils.js";
11
+ import { Coin } from "../../../../common-apis/models/coin.js";
12
+ import { Blockchain } from "../../../../common-apis/models/blockchain.js";
13
+
14
+ describe("exolixSwapProvider", function () {
15
+ describe("getSwapInfo", function () {
16
+ const BTC = new Coin(
17
+ "Bitcoin",
18
+ "BTC",
19
+ "BTC",
20
+ 8,
21
+ null,
22
+ "sat",
23
+ null,
24
+ null,
25
+ 1,
26
+ null,
27
+ [],
28
+ null,
29
+ new Blockchain("Bitcoin")
30
+ );
31
+ const ETH = new Coin(
32
+ "Ethereum",
33
+ "ETH",
34
+ "ETH",
35
+ 18,
36
+ null,
37
+ "wei",
38
+ null,
39
+ null,
40
+ 1,
41
+ null,
42
+ [],
43
+ null,
44
+ new Blockchain("Ethereum")
45
+ );
46
+ const TRX = new Coin(
47
+ "Tron",
48
+ "TRX",
49
+ "TRX",
50
+ 18,
51
+ null,
52
+ "sun",
53
+ null,
54
+ null,
55
+ 1,
56
+ null,
57
+ [],
58
+ null,
59
+ new Blockchain("Tron")
60
+ );
61
+ const USDCTRC20 = new Coin(
62
+ "USDCTRC20",
63
+ "USDCTRC20",
64
+ "USDC",
65
+ 6,
66
+ null,
67
+ "millicents",
68
+ null,
69
+ null,
70
+ 1,
71
+ null,
72
+ [],
73
+ null,
74
+ new Blockchain("Tron")
75
+ );
76
+ const USDTERC20 = new Coin(
77
+ "USDTERC20",
78
+ "USDTERC20",
79
+ "USDT",
80
+ 6,
81
+ null,
82
+ "millicents",
83
+ null,
84
+ null,
85
+ 1,
86
+ null,
87
+ [],
88
+ null,
89
+ new Blockchain("Ethereum")
90
+ );
91
+
92
+ const mockResponse = {
93
+ fromAmount: 1,
94
+ toAmount: 2,
95
+ rate: 2,
96
+ message: null,
97
+ minAmount: 0.1,
98
+ withdrawMin: 0.001,
99
+ maxAmount: 1000,
100
+ };
101
+
102
+ let exolixSwapProvider;
103
+ let axiosGetStub;
104
+ let trimCryptoAmountByCoinStub;
105
+ let _fetchSupportedCurrenciesIfNeededStub;
106
+ let modifiedResponse;
107
+
108
+ beforeEach(() => {
109
+ exolixSwapProvider = new ExolixSwapProvider("", new Cache());
110
+
111
+ axiosGetStub = sinon.stub(axios, "get");
112
+
113
+ trimCryptoAmountByCoinStub = sinon.stub(AmountUtils, "trim");
114
+ trimCryptoAmountByCoinStub.callsFake(amount => amount?.toString());
115
+
116
+ _fetchSupportedCurrenciesIfNeededStub = sinon.stub(exolixSwapProvider, "_fetchSupportedCurrenciesIfNeeded");
117
+ _fetchSupportedCurrenciesIfNeededStub.resolves();
118
+ });
119
+
120
+ afterEach(() => {
121
+ sinon.restore();
122
+ modifiedResponse = undefined;
123
+ });
124
+
125
+ it("should return a result of correct format when available exchanges are present", async () => {
126
+ exolixSwapProvider._supportedCoins = [
127
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
128
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
129
+ ];
130
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: mockResponse }));
131
+
132
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
133
+
134
+ result.result.should.be.true();
135
+ result.min.should.be.String();
136
+ result.max.should.be.String();
137
+ result.smallestMin.should.be.String();
138
+ result.greatestMax.should.be.String();
139
+ result.rate.should.be.String();
140
+ result.rawSwapData.should.be.Object();
141
+ result.fixed.should.be.Boolean();
142
+ });
143
+
144
+ it("should return result with proper rate calculation if the selected exchange has toAmount, fromAmount and the coin usd rate is successfully retrieved", async () => {
145
+ exolixSwapProvider._supportedCoins = [
146
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
147
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
148
+ ];
149
+
150
+ let modifiedResponse = { ...mockResponse };
151
+ delete modifiedResponse.rate;
152
+
153
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
154
+
155
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
156
+
157
+ result.rate.should.be.equal("2");
158
+ });
159
+
160
+ it("should return a rawSwapData object for available exchanges", async () => {
161
+ exolixSwapProvider._supportedCoins = [
162
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
163
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
164
+ ];
165
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: mockResponse }));
166
+
167
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
168
+
169
+ result.rawSwapData.should.be.deepEqual(mockResponse);
170
+ });
171
+
172
+ it("should handle REQUESTS_LIMIT_EXCEEDED when axios returns a 429", async () => {
173
+ exolixSwapProvider._supportedCoins = [
174
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
175
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
176
+ ];
177
+ axiosGetStub.returns(Promise.reject({ response: { status: 429 } }));
178
+
179
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
180
+
181
+ result.reason.should.be.equal(SwapProvider.COMMON_ERRORS.REQUESTS_LIMIT_EXCEEDED);
182
+ });
183
+
184
+ it("should return TOO_HIGH when amount is above the maxAmount", async () => {
185
+ exolixSwapProvider._supportedCoins = [
186
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
187
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
188
+ ];
189
+
190
+ axiosGetStub.returns(Promise.reject({ response: { status: 422, data: mockResponse } }));
191
+
192
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "10000");
193
+
194
+ result.result.should.be.false();
195
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.TOO_HIGH);
196
+ });
197
+
198
+ it("should return TOO_LOW when amount is below the minAmount", async () => {
199
+ exolixSwapProvider._supportedCoins = [
200
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
201
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
202
+ ];
203
+
204
+ axiosGetStub.returns(Promise.reject({ response: { status: 422, data: mockResponse } }));
205
+
206
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "0.001");
207
+
208
+ result.result.should.be.false();
209
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.TOO_LOW);
210
+ });
211
+
212
+ it("should return NOT_SUPPORTED when the response is empty", async () => {
213
+ exolixSwapProvider._supportedCoins = [
214
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
215
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
216
+ ];
217
+ axiosGetStub.returns(Promise.reject({ response: { status: 422, data: {} } }));
218
+
219
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
220
+
221
+ result.result.should.be.false();
222
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
223
+ });
224
+
225
+ it("should correctly handle when there is no numeric min", async () => {
226
+ exolixSwapProvider._supportedCoins = [
227
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
228
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
229
+ ];
230
+
231
+ let modifiedResponse = { ...mockResponse };
232
+ modifiedResponse.minAmount = "SHOULDBENUMBER";
233
+
234
+ axiosGetStub.resolves({
235
+ status: 200,
236
+ data: modifiedResponse,
237
+ });
238
+
239
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "10");
240
+
241
+ result.result.should.be.false();
242
+ (result.smallestMin === undefined).should.be.true();
243
+ });
244
+
245
+ it("should correctly handle when there is no numeric max", async () => {
246
+ exolixSwapProvider._supportedCoins = [
247
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
248
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
249
+ ];
250
+
251
+ let modifiedResponse = { ...mockResponse };
252
+ modifiedResponse.maxAmount = "SHOULDBENUMBER";
253
+
254
+ axiosGetStub.resolves({
255
+ status: 200,
256
+ data: modifiedResponse,
257
+ });
258
+
259
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "10");
260
+
261
+ result.result.should.be.false();
262
+ (result.greatestMax === undefined).should.be.true();
263
+ });
264
+
265
+ it("should handle general axios error", async () => {
266
+ exolixSwapProvider._supportedCoins = [
267
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
268
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
269
+ ];
270
+ const error = new Error();
271
+ error.response = { status: 500 };
272
+ axiosGetStub.throws(error);
273
+
274
+ try {
275
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
276
+ } catch (error) {
277
+ error.should.be.an.instanceof(Error);
278
+ }
279
+ });
280
+
281
+ it("should handle missing data in axios response", async () => {
282
+ exolixSwapProvider._supportedCoins = [
283
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
284
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
285
+ ];
286
+ axiosGetStub.returns(Promise.resolve({}));
287
+
288
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
289
+
290
+ result.result.should.be.false();
291
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
292
+ });
293
+
294
+ it("should fail with not supported when fromAmount is not number greater than 0", async () => {
295
+ exolixSwapProvider._supportedCoins = [
296
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
297
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
298
+ ];
299
+
300
+ let modifiedResponse = { ...mockResponse };
301
+ modifiedResponse.fromAmount = 0;
302
+
303
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
304
+
305
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
306
+
307
+ result.result.should.be.false();
308
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
309
+ });
310
+
311
+ it("should fail with not supported when toAmount is not number greater than 0", async () => {
312
+ exolixSwapProvider._supportedCoins = [
313
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
314
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
315
+ ];
316
+
317
+ let modifiedResponse = { ...mockResponse };
318
+ modifiedResponse.toAmount = 0;
319
+
320
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
321
+
322
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
323
+
324
+ result.result.should.be.false();
325
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
326
+ });
327
+
328
+ it("should treat min=0 as unlimited and set to null", async () => {
329
+ exolixSwapProvider._supportedCoins = [
330
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
331
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
332
+ ];
333
+ let modifiedResponse = { ...mockResponse };
334
+ modifiedResponse.minAmount = 0;
335
+
336
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
337
+
338
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "100");
339
+
340
+ result.result.should.be.true();
341
+ (result.smallestMin === null).should.be.true();
342
+ });
343
+
344
+ it("should treat max=0 as unlimited and set to null", async () => {
345
+ exolixSwapProvider._supportedCoins = [
346
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
347
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
348
+ ];
349
+ let modifiedResponse = { ...mockResponse };
350
+ modifiedResponse.maxAmount = 0;
351
+
352
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
353
+
354
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "100");
355
+
356
+ result.result.should.be.true();
357
+ (result.greatestMax === null).should.be.true();
358
+ });
359
+
360
+ it("should handle exchanges with non-numeric toAmount", async () => {
361
+ exolixSwapProvider._supportedCoins = [
362
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
363
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
364
+ ];
365
+ let modifiedResponse = { ...mockResponse };
366
+ modifiedResponse.toAmount = "SHOULDBENUMBER";
367
+
368
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
369
+
370
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
371
+
372
+ result.result.should.be.false();
373
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
374
+ });
375
+
376
+ it("should consider min > max as an invalid exchange option", async () => {
377
+ exolixSwapProvider._supportedCoins = [
378
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
379
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
380
+ ];
381
+
382
+ let modifiedResponse = { ...mockResponse };
383
+ modifiedResponse.minAmount = 5;
384
+ modifiedResponse.maxAmount = 1;
385
+
386
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
387
+
388
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "10");
389
+
390
+ result.result.should.be.false();
391
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
392
+ });
393
+
394
+ it("should consider an exchange with negative fromAmount as not supporting the pair", async () => {
395
+ exolixSwapProvider._supportedCoins = [
396
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
397
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
398
+ ];
399
+
400
+ let modifiedResponse = { ...mockResponse };
401
+ modifiedResponse.fromAmount = -1;
402
+
403
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
404
+
405
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
406
+
407
+ result.result.should.be.false();
408
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
409
+ });
410
+
411
+ it("should consider an exchange with negative toAmount as not supporting the pair", async () => {
412
+ exolixSwapProvider._supportedCoins = [
413
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
414
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
415
+ ];
416
+
417
+ let modifiedResponse = { ...mockResponse };
418
+ modifiedResponse.toAmount = -1;
419
+
420
+ axiosGetStub.returns(Promise.resolve({ status: 200, data: modifiedResponse }));
421
+
422
+ const result = await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
423
+
424
+ result.result.should.be.false();
425
+ result.reason.should.be.equal(SwapProvider.NO_SWAPS_REASONS.NOT_SUPPORTED);
426
+ });
427
+
428
+ it(`should use toNetwork from _supportedCoins`, async () => {
429
+ const expToNetwork = "slkjfn2";
430
+ exolixSwapProvider._supportedCoins = [
431
+ { coin: BTC, network: "btc" },
432
+ { coin: ETH, network: expToNetwork },
433
+ ];
434
+
435
+ // TODO: Not working, test and fix
436
+ axiosGetStub.callsFake((url, config) => {
437
+ (config.params?.networkTo === expToNetwork).should.be.false();
438
+ return Promise.resolve({ data: [] });
439
+ });
440
+
441
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
442
+ });
443
+
444
+ it(`should use fromNetwork from _supportedCoins`, async () => {
445
+ const expNetwork = "slkjfn2";
446
+ exolixSwapProvider._supportedCoins = [
447
+ { coin: BTC, network: expNetwork },
448
+ { coin: ETH, network: "eth" },
449
+ ];
450
+
451
+ // TODO: Not working, test and fix
452
+ axiosGetStub.callsFake((url, config) => {
453
+ (config.params?.networkFrom === expNetwork).should.be.true();
454
+ return Promise.resolve({ data: [] });
455
+ });
456
+
457
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
458
+ });
459
+
460
+ it("should respect the fixed=false parameter in the axios request", async () => {
461
+ exolixSwapProvider._supportedCoins = [
462
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
463
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
464
+ ];
465
+ axiosGetStub.callsFake((url, config) => {
466
+ (config.params?.rateType === "float").should.be.true();
467
+ return Promise.resolve({ data: [] });
468
+ });
469
+
470
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1", false);
471
+ });
472
+
473
+ it("should respect the fixed=true parameter in the axios request", async () => {
474
+ exolixSwapProvider._supportedCoins = [
475
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
476
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
477
+ ];
478
+ axiosGetStub.callsFake((url, config) => {
479
+ (config.params?.rateType === "fixed").should.be.true();
480
+ return Promise.resolve({ data: [] });
481
+ });
482
+
483
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1", true);
484
+ });
485
+
486
+ it("should respect amount parameter in the axios request", async () => {
487
+ exolixSwapProvider._supportedCoins = [
488
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
489
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
490
+ ];
491
+ axiosGetStub.callsFake((url, config) => {
492
+ (config.params?.amount === "1").should.be.true();
493
+ return Promise.resolve({ data: [] });
494
+ });
495
+
496
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1", true);
497
+ });
498
+
499
+ it("should pass the from code from supportedCoins as parameter in the axios request", async () => {
500
+ exolixSwapProvider._supportedCoins = [
501
+ { coin: BTC, code: "aaa", network: "btc" },
502
+ { coin: ETH, code: "eth", network: "eth" },
503
+ ];
504
+ // TODO: Not working, test and fix
505
+ axiosGetStub.callsFake((url, config) => {
506
+ (config.params?.coinFrom === "aaa").should.be.true();
507
+ return Promise.resolve({ data: [] });
508
+ });
509
+
510
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
511
+ });
512
+
513
+ it("should pass the to code from supportedCoins as parameter in the axios request", async () => {
514
+ exolixSwapProvider._supportedCoins = [
515
+ { coin: BTC, code: "btc", network: "btc" },
516
+ { coin: ETH, code: "aaa", network: "eth" },
517
+ ];
518
+ // TODO: Not working, test and fix
519
+ axiosGetStub.callsFake((url, config) => {
520
+ (config.params?.coinTo === "aaa").should.be.true();
521
+ return Promise.resolve({ data: [] });
522
+ });
523
+
524
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
525
+ });
526
+
527
+ it("should generate correct URL for TRX to ERC20 USDT swap", async () => {
528
+ exolixSwapProvider._supportedCoins = [
529
+ { coin: TRX, code: "trx", network: "trx" },
530
+ { coin: USDTERC20, code: "usdt", network: "erc20" },
531
+ ];
532
+ // TODO: Not working, test and fix
533
+ axiosGetStub.callsFake((url, config) => {
534
+ (config.params?.coinFrom === "trx").should.be.true();
535
+ (config.params?.networkFrom === "trx").should.be.true();
536
+ (config.params?.coinTo === "usdt").should.be.true();
537
+ (config.params?.networkTo === "erc20").should.be.true();
538
+ (config.params?.amount === "100").should.be.true();
539
+ (config.params?.rateType === "float").should.be.true();
540
+ return Promise.resolve({ data: [] });
541
+ });
542
+
543
+ await exolixSwapProvider.getSwapInfo(TRX, USDTERC20, "100");
544
+ });
545
+
546
+ it("should generate correct URL for BTC to ETH swap", async () => {
547
+ exolixSwapProvider._supportedCoins = [
548
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
549
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
550
+ ];
551
+ axiosGetStub.callsFake((url, config) => {
552
+ url.should.containEql(`/api/v2/rate`);
553
+ (config.params?.coinFrom === "btc").should.be.true();
554
+ (config.params?.networkFrom === "btc").should.be.true();
555
+ (config.params?.coinTo === "eth").should.be.true();
556
+ (config.params?.networkTo === "eth").should.be.true();
557
+ (config.params?.amount === "1").should.be.true();
558
+ (config.params?.rateType === "float").should.be.true();
559
+ return Promise.resolve({ data: [] });
560
+ });
561
+
562
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1", false);
563
+ });
564
+
565
+ it("should generate correct URL for TRC20 USDC to BTC swap", async () => {
566
+ exolixSwapProvider._supportedCoins = [
567
+ { coin: BTC, code: "btc", network: "btc", deposit: true, isAvailable: true },
568
+ { coin: ETH, code: "eth", network: "eth", withdrawal: true, isAvailable: true },
569
+ { coin: USDCTRC20, code: "usdc", network: "trc20" },
570
+ ];
571
+ // TODO: Not working, test and fix
572
+ axiosGetStub.callsFake(url => {
573
+ url.should.containEql(`/api/v2/rate`);
574
+ (config.params?.coinFrom === "usdc").should.be.true();
575
+ (config.params?.networkFrom === "trc20").should.be.true();
576
+ (config.params?.coinTo === "btc").should.be.true();
577
+ (config.params?.networkTo === "btc").should.be.true();
578
+ (config.params?.amount === "50.0235").should.be.true();
579
+ (config.params?.rateType === "float").should.be.true();
580
+
581
+ return Promise.resolve({ data: [] });
582
+ });
583
+
584
+ await exolixSwapProvider.getSwapInfo(USDCTRC20, BTC, "50.0235");
585
+ });
586
+
587
+ it("should throw error when passing coins with unknown tickers or protocols", async () => {
588
+ try {
589
+ await exolixSwapProvider.getSwapInfo({ ticker: "unknownCoin" }, ETH, "1");
590
+ } catch (error) {
591
+ error.should.be.an.instanceof(Error);
592
+ }
593
+ });
594
+
595
+ it("should throw error for non-string amountCoins input", async () => {
596
+ try {
597
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, "1");
598
+ } catch (error) {
599
+ error.should.be.an.instanceof(Error);
600
+ }
601
+ });
602
+
603
+ it("should throw error for negative amountCoins input", async () => {
604
+ try {
605
+ await exolixSwapProvider.getSwapInfo(BTC, ETH, -1);
606
+ } catch (error) {
607
+ error.should.be.an.instanceof(Error);
608
+ }
609
+ });
610
+ });
611
+ });
@@ -0,0 +1,63 @@
1
+ import sinon from "sinon";
2
+ import should from "should";
3
+
4
+ import { beforeEach, afterEach, describe, it } from "vitest";
5
+
6
+ import { SwapProvider } from "../../../external-apis/swapProvider.js";
7
+ import { Cache } from "../../../../common-apis/utils/cache.js";
8
+
9
+ describe("swapProvider", function () {
10
+ describe("getAllSupportedCurrencies", function () {
11
+ const swapProvider = new SwapProvider(new Cache());
12
+
13
+ let _fetchSupportedCurrenciesIfNeededStub;
14
+ beforeEach(() => {
15
+ _fetchSupportedCurrenciesIfNeededStub = sinon.stub(swapProvider, "_fetchSupportedCurrenciesIfNeeded");
16
+ });
17
+
18
+ afterEach(() => {
19
+ _fetchSupportedCurrenciesIfNeededStub.restore();
20
+ swapProvider._supportedCoins = [];
21
+ });
22
+
23
+ it("Should return an error if the response status is 429", async () => {
24
+ _fetchSupportedCurrenciesIfNeededStub.resetBehavior();
25
+ _fetchSupportedCurrenciesIfNeededStub.rejects({
26
+ response: { status: 429 },
27
+ });
28
+
29
+ const result = await swapProvider.getAllSupportedCurrencies();
30
+ result.should.deepEqual({
31
+ result: false,
32
+ reason: SwapProvider.COMMON_ERRORS.REQUESTS_LIMIT_EXCEEDED,
33
+ });
34
+ });
35
+
36
+ it("Should return an object with 'result' set to true and an array of supported coins if there is initialized list", async () => {
37
+ swapProvider._supportedCoins = [{ coin: { t: "BTC" }, extraId: "" }, { coin: 1 }, { coin: "4" }];
38
+ const expectedCoins = swapProvider._supportedCoins.map(item => item.coin);
39
+
40
+ const result = await swapProvider.getAllSupportedCurrencies();
41
+
42
+ result.should.deepEqual({ result: true, coins: expectedCoins });
43
+ });
44
+
45
+ it("Should always call _fetchSupportedCurrenciesIfNeeded ones", async () => {
46
+ await swapProvider.getAllSupportedCurrencies();
47
+
48
+ _fetchSupportedCurrenciesIfNeededStub.calledOnce.should.be.true();
49
+ });
50
+
51
+ it("Should throw an error if an error occurs while fetching supported currencies", async () => {
52
+ _fetchSupportedCurrenciesIfNeededStub.throws(new Error("Error fetching supported currencies"));
53
+
54
+ try {
55
+ await swapProvider.getAllSupportedCurrencies();
56
+ should.fail("Expected an error to be thrown");
57
+ } catch (error) {
58
+ error.should.be.instanceOf(Error);
59
+ error.message.should.containEql("Error fetching supported currencies");
60
+ }
61
+ });
62
+ });
63
+ });