@rabbitio/ui-kit 1.0.0-beta.10 → 1.0.0-beta.100
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.
- package/.gitlab-ci.yml +29 -0
- package/.husky/commit-msg +19 -0
- package/.husky/pre-push +1 -0
- package/CHANGELOG.md +0 -0
- package/README.md +27 -18
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/clover.xml +21036 -0
- package/coverage/coverage-final.json +185 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +1271 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +196 -0
- package/coverage/ui-kit/index.html +116 -0
- package/coverage/ui-kit/index.js.html +88 -0
- package/coverage/ui-kit/src/common-apis/adapters/analyticsAdapters/googleAnalyticsAdapter.js.html +151 -0
- package/coverage/ui-kit/src/common-apis/adapters/analyticsAdapters/index.html +146 -0
- package/coverage/ui-kit/src/common-apis/adapters/analyticsAdapters/metrikaAdapter.js.html +172 -0
- package/coverage/ui-kit/src/common-apis/adapters/analyticsAdapters/mixpanelAdapter.js.html +199 -0
- package/coverage/ui-kit/src/common-apis/adapters/axiosAdapter.js.html +190 -0
- package/coverage/ui-kit/src/common-apis/adapters/index.html +131 -0
- package/coverage/ui-kit/src/common-apis/adapters/qrUtils.js.html +139 -0
- package/coverage/ui-kit/src/common-apis/external-apis/apiGroups.js.html +250 -0
- package/coverage/ui-kit/src/common-apis/external-apis/emailAPI.js.html +133 -0
- package/coverage/ui-kit/src/common-apis/external-apis/index.html +146 -0
- package/coverage/ui-kit/src/common-apis/external-apis/ipAddressProviders.js.html +352 -0
- package/coverage/ui-kit/src/common-apis/globalConstants.jsx.html +94 -0
- package/coverage/ui-kit/src/common-apis/index.html +116 -0
- package/coverage/ui-kit/src/common-apis/models/blockchain.js.html +115 -0
- package/coverage/ui-kit/src/common-apis/models/coin.js.html +829 -0
- package/coverage/ui-kit/src/common-apis/models/index.html +146 -0
- package/coverage/ui-kit/src/common-apis/models/protocol.js.html +100 -0
- package/coverage/ui-kit/src/common-apis/services/fiatCurrenciesService.js.html +544 -0
- package/coverage/ui-kit/src/common-apis/services/index.html +116 -0
- package/coverage/ui-kit/src/common-apis/utils/amountUtils.js.html +1234 -0
- package/coverage/ui-kit/src/common-apis/utils/cache.js.html +811 -0
- package/coverage/ui-kit/src/common-apis/utils/errorUtils.js.html +211 -0
- package/coverage/ui-kit/src/common-apis/utils/index.html +191 -0
- package/coverage/ui-kit/src/common-apis/utils/logging/index.html +131 -0
- package/coverage/ui-kit/src/common-apis/utils/logging/logger.js.html +208 -0
- package/coverage/ui-kit/src/common-apis/utils/logging/logsStorage.js.html +268 -0
- package/coverage/ui-kit/src/common-apis/utils/postponeExecution.js.html +118 -0
- package/coverage/ui-kit/src/common-apis/utils/rabbitTicker.js.html +157 -0
- package/coverage/ui-kit/src/common-apis/utils/safeStringify.js.html +235 -0
- package/coverage/ui-kit/src/index.html +116 -0
- package/coverage/ui-kit/src/index.js.html +376 -0
- package/coverage/ui-kit/src/robust-api-caller/cacheAndConcurrentRequestsResolver.js.html +1570 -0
- package/coverage/ui-kit/src/robust-api-caller/cachedRobustExternalApiCallerService.js.html +526 -0
- package/coverage/ui-kit/src/robust-api-caller/cancelProcessing.js.html +172 -0
- package/coverage/ui-kit/src/robust-api-caller/concurrentCalculationsMetadataHolder.js.html +310 -0
- package/coverage/ui-kit/src/robust-api-caller/externalApiProvider.js.html +553 -0
- package/coverage/ui-kit/src/robust-api-caller/externalServicesStatsCollector.js.html +319 -0
- package/coverage/ui-kit/src/robust-api-caller/index.html +206 -0
- package/coverage/ui-kit/src/robust-api-caller/robustExternalAPICallerService.js.html +997 -0
- package/coverage/ui-kit/src/swaps-lib/external-apis/exolixSwapProvider.js.html +1849 -0
- package/coverage/ui-kit/src/swaps-lib/external-apis/index.html +176 -0
- package/coverage/ui-kit/src/swaps-lib/external-apis/letsExchangeSwapProvider.js.html +1633 -0
- package/coverage/ui-kit/src/swaps-lib/external-apis/swapProvider.js.html +1825 -0
- package/coverage/ui-kit/src/swaps-lib/external-apis/swapspaceSwapProvider.js.html +1900 -0
- package/coverage/ui-kit/src/swaps-lib/external-apis/utils.js.html +130 -0
- package/coverage/ui-kit/src/swaps-lib/models/baseSwapCreationInfo.js.html +319 -0
- package/coverage/ui-kit/src/swaps-lib/models/existingSwap.js.html +514 -0
- package/coverage/ui-kit/src/swaps-lib/models/existingSwapWithFiatData.js.html +529 -0
- package/coverage/ui-kit/src/swaps-lib/models/index.html +176 -0
- package/coverage/ui-kit/src/swaps-lib/models/partner.js.html +166 -0
- package/coverage/ui-kit/src/swaps-lib/models/swapProviderCoinInfo.js.html +331 -0
- package/coverage/ui-kit/src/swaps-lib/services/index.html +116 -0
- package/coverage/ui-kit/src/swaps-lib/services/publicSwapService.js.html +1570 -0
- package/coverage/ui-kit/src/swaps-lib/utils/index.html +116 -0
- package/coverage/ui-kit/src/swaps-lib/utils/swapUtils.js.html +670 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/arrowIcon.jsx.html +124 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/arrowTosca.jsx.html +127 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/arrowWhite.jsx.html +127 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/darkRectangle.jsx.html +106 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/determinedError.jsx.html +439 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/failedValidationIcon.jsx.html +202 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/index.html +281 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/infoIcon.jsx.html +133 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/messageIcon.jsx.html +346 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/noticeQuestionIcon.jsx.html +247 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/successfulValidationIcon.jsx.html +163 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/supportDialogImage.jsx.html +268 -0
- package/coverage/ui-kit/src/ui-kit/assets/wrappedImages/walletIcon.jsx.html +151 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/AssetIcon/AssetIcon.jsx.html +256 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/AssetIcon/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/AssetSelection/AssetSelection.jsx.html +289 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/AssetSelection/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/BackgroundTitle/BackgroundTitle.jsx.html +187 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/BackgroundTitle/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/InformationMessage/InformationMessage.jsx.html +238 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/InformationMessage/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Input/Input.jsx.html +634 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Input/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/LoadingDots/LoadingDots.jsx.html +196 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/LoadingDots/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/NoticeIcon/NoticeIcon.jsx.html +277 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/NoticeIcon/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/QrCode/QrCode.jsx.html +217 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/QrCode/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/RateSelector/RateSelector.jsx.html +175 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/RateSelector/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/SupportChat/SupportChat.jsx.html +217 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/SupportChat/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Textarea/Textarea.jsx.html +529 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Textarea/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/TitleBox/TitleBox.jsx.html +508 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/TitleBox/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Tooltip/Tooltip.jsx.html +316 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Tooltip/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/TwoLinesOfText/LinesOfText.jsx.html +313 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/TwoLinesOfText/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Validation/Validation.jsx.html +202 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/Validation/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/Button/Button.jsx.html +733 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/Button/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/Close/Close.jsx.html +259 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/Close/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/LinkButton/LinkButton.jsx.html +433 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/LinkButton/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/RadioButtonWithText/RadioButtonWithText.jsx.html +415 -0
- package/coverage/ui-kit/src/ui-kit/components/atoms/buttons/RadioButtonWithText/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/AmountInput/AmountInput.jsx.html +1429 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/AmountInput/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/CoinPicker/CoinPicker.jsx.html +1474 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/CoinPicker/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/ColoredNotice/ColoredNotice.jsx.html +241 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/ColoredNotice/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/LineWithIconLink/LineWithIconLink.jsx.html +190 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/LineWithIconLink/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/LogoCarousel/LogoCarousel.jsx.html +307 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/LogoCarousel/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/SearchableCoinsList/SearchableCoinsList.jsx.html +496 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/SearchableCoinsList/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/TitledLineWithIconLink/TitledLineWithIconLink.jsx.html +181 -0
- package/coverage/ui-kit/src/ui-kit/components/molecules/TitledLineWithIconLink/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/CoinPickerDialogStep/CoinPickerDialogStep.jsx.html +283 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/CoinPickerDialogStep/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/Dialog/Dialog.jsx.html +1567 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/Dialog/DialogButtons/DialogButtons.jsx.html +481 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/Dialog/DialogButtons/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/Dialog/DialogStep/DialogStep.jsx.html +1747 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/Dialog/DialogStep/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/Dialog/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/SwapForm/SwapForm.jsx.html +4228 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/SwapForm/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/WaitlistSubscription/WaitlistSubscription.jsx.html +559 -0
- package/coverage/ui-kit/src/ui-kit/components/organisms/WaitlistSubscription/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/components/templates/DeterminedErrorDialogStep/DeterminedErrorDialogStep.jsx.html +316 -0
- package/coverage/ui-kit/src/ui-kit/components/templates/DeterminedErrorDialogStep/index.html +116 -0
- package/coverage/ui-kit/src/ui-kit/hooks/index.html +146 -0
- package/coverage/ui-kit/src/ui-kit/hooks/useCallHandlingErrors.js.html +166 -0
- package/coverage/ui-kit/src/ui-kit/hooks/useIsHydrated.js.html +121 -0
- package/coverage/ui-kit/src/ui-kit/hooks/useReferredState.js.html +157 -0
- package/coverage/ui-kit/src/ui-kit/utils/index.html +161 -0
- package/coverage/ui-kit/src/ui-kit/utils/inputValueProviders.js.html +235 -0
- package/coverage/ui-kit/src/ui-kit/utils/textUtils.js.html +139 -0
- package/coverage/ui-kit/src/ui-kit/utils/uiUtils.js.html +121 -0
- package/coverage/ui-kit/src/ui-kit/utils/urlQueryUtils.js.html +271 -0
- package/coverage/ui-kit/stories/atoms/BackgroundTitle.stories.jsx.html +202 -0
- package/coverage/ui-kit/stories/atoms/LinesOfText.stories.jsx.html +283 -0
- package/coverage/ui-kit/stories/atoms/LoadingDots.stories.jsx.html +226 -0
- package/coverage/ui-kit/stories/atoms/QrCode.stories.jsx.html +175 -0
- package/coverage/ui-kit/stories/atoms/RateSelector.stories.jsx.html +136 -0
- package/coverage/ui-kit/stories/atoms/Validation.stories.jsx.html +178 -0
- package/coverage/ui-kit/stories/atoms/buttons/Button.stories.jsx.html +883 -0
- package/coverage/ui-kit/stories/atoms/buttons/Close.stories.jsx.html +211 -0
- package/coverage/ui-kit/stories/atoms/buttons/LinkButton.stories.jsx.html +301 -0
- package/coverage/ui-kit/stories/atoms/buttons/index.html +146 -0
- package/coverage/ui-kit/stories/atoms/index.html +191 -0
- package/coverage/ui-kit/stories/molecules/AmountInput.stories.jsx.html +289 -0
- package/coverage/ui-kit/stories/molecules/CoinPicker.stories.jsx.html +322 -0
- package/coverage/ui-kit/stories/molecules/ColoredNotice.stories.jsx.html +178 -0
- package/coverage/ui-kit/stories/molecules/LineWithIconLink.stories.jsx.html +154 -0
- package/coverage/ui-kit/stories/molecules/LogoCarousel.stories.jsx.html +235 -0
- package/coverage/ui-kit/stories/molecules/TitledLineWithIconLink.stories.jsx.html +160 -0
- package/coverage/ui-kit/stories/molecules/index.html +191 -0
- package/coverage/ui-kit/stories/organisms/Dialog/Dialog.stories.jsx.html +523 -0
- package/coverage/ui-kit/stories/organisms/Dialog/DialogButtons/DialogButtons.stories.jsx.html +328 -0
- package/coverage/ui-kit/stories/organisms/Dialog/DialogButtons/index.html +116 -0
- package/coverage/ui-kit/stories/organisms/Dialog/DialogStep/DialogStep.stories.jsx.html +337 -0
- package/coverage/ui-kit/stories/organisms/Dialog/DialogStep/index.html +116 -0
- package/coverage/ui-kit/stories/organisms/Dialog/index.html +116 -0
- package/coverage/ui-kit/stories/organisms/WaitlistSubscription.stories.jsx.html +151 -0
- package/coverage/ui-kit/stories/organisms/index.html +116 -0
- package/coverage/ui-kit/stories/stubs/coins.jsx.html +6880 -0
- package/coverage/ui-kit/stories/stubs/exampleContent.jsx.html +145 -0
- package/coverage/ui-kit/stories/stubs/index.html +131 -0
- package/coverage/ui-kit/stories/templates/DeterminedErrorDialogStep.stories.jsx.html +190 -0
- package/coverage/ui-kit/stories/templates/index.html +116 -0
- package/coverage/ui-kit/storybook-static/230.7eace282.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/242.dda46cfa.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/312.6f62bbd9.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/341.57a15f57.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/374.99dab897.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/43.c12e28b8.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/450.d467c07c.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/506.07d46882.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/547.cc28f1fd.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/586.e7130528.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/595.2e40d981.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/607.3ea32459.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/609.097df435.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/797.c87cdf19.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/889.4a86fe2b.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/976.b5f1a5d4.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/996.07a638d5.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/AmountUtils-stories.e2f66b30.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-BackgroundTitle-stories.1a5386a1.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-LinesOfText-stories.b7c8f08a.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-LoadingDots-stories.5180c2f1.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-QrCode-stories.1581ad1e.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-RateSelector-stories.19c65c98.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-Validation-stories.d561b311.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-buttons-Button-stories.e8e6b930.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-buttons-Close-stories.0a902a7c.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/atoms-buttons-LinkButton-stories.10813be5.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/index.html +686 -0
- package/coverage/ui-kit/storybook-static/main.da938fde.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/molecules-AmountInput-stories.a703ba8d.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/molecules-ColoredNotice-stories.7a5d624e.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/molecules-LineWithIconLink-stories.b7f70ee2.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/molecules-LogoCarousel-stories.2ce1402f.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/molecules-TitledLineWithIconLink-stories.1383fe3f.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/organisms-Dialog-Dialog-stories.4e6da717.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/organisms-Dialog-DialogButtons-DialogButtons-stories.1d1f9803.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/organisms-Dialog-DialogStep-DialogStep-stories.74896048.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/organisms-WaitlistSubscription-stories.a7c49a29.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/dist/global.css.html +118 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/dist/index.html +116 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/@storybook/addon-backgrounds/dist/index.html +116 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/@storybook/addon-backgrounds/dist/preview.js.html +118 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/@storybook/components/dist/formatter-SWP5E3XI.mjs.html +118 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/@storybook/components/dist/index.html +116 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/buffer/index.html +116 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/buffer/index.js.html +118 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/markdown-to-jsx/dist/index.html +116 -0
- package/coverage/ui-kit/storybook-static/rabbitio/ui-kit/node_modules/markdown-to-jsx/dist/index.modern.js.html +118 -0
- package/coverage/ui-kit/storybook-static/runtime~main.795022f7.iframe.bundle.js.html +85 -0
- package/coverage/ui-kit/storybook-static/sb-addons/actions-9/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/actions-9/manager-bundle.js.html +94 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-backgrounds-2/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-backgrounds-2/manager-bundle.js.html +121 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-controls-1/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-controls-1/manager-bundle.js.html +274 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-measure-4/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-measure-4/manager-bundle.js.html +94 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-outline-5/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-outline-5/manager-bundle.js.html +94 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-toolbars-3/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/essentials-toolbars-3/manager-bundle.js.html +94 -0
- package/coverage/ui-kit/storybook-static/sb-addons/interactions-7/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/interactions-7/manager-bundle.js.html +121 -0
- package/coverage/ui-kit/storybook-static/sb-addons/links-0/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/links-0/manager-bundle.js.html +94 -0
- package/coverage/ui-kit/storybook-static/sb-addons/onboarding-6/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/onboarding-6/manager-bundle.js.html +1588 -0
- package/coverage/ui-kit/storybook-static/sb-addons/viewport-8/index.html +116 -0
- package/coverage/ui-kit/storybook-static/sb-addons/viewport-8/manager-bundle.js.html +94 -0
- package/coverage/ui-kit/storybook-static/sb-manager/WithTooltip-V3YHNWJZ-LVYLGZW2.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-manager/chunk-2IXBUOFS.js.html +106 -0
- package/coverage/ui-kit/storybook-static/sb-manager/chunk-INSKDKQB.js.html +1129 -0
- package/coverage/ui-kit/storybook-static/sb-manager/chunk-NGTUFCUO.js.html +112 -0
- package/coverage/ui-kit/storybook-static/sb-manager/chunk-UUEAOBSN.js.html +1303 -0
- package/coverage/ui-kit/storybook-static/sb-manager/chunk-ZEU7PDD3.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-manager/formatter-SWP5E3XI-7BGIK6BL.js.html +553 -0
- package/coverage/ui-kit/storybook-static/sb-manager/globals-module-info.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-manager/globals.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-manager/index.html +281 -0
- package/coverage/ui-kit/storybook-static/sb-manager/index.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-manager/runtime.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-manager/syntaxhighlighter-V7JZZA35-DXZCI2WR.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-preview/globals.js.html +88 -0
- package/coverage/ui-kit/storybook-static/sb-preview/index.html +131 -0
- package/coverage/ui-kit/storybook-static/sb-preview/runtime.js.html +421 -0
- package/coverage/ui-kit/storybook-static/templates-DeterminedErrorDialogStep-stories.3cc14214.iframe.bundle.js.html +85 -0
- package/dist/global.css +197 -0
- package/dist/global.css.map +1 -0
- package/dist/index.cjs +12420 -333
- package/dist/index.cjs.map +1 -1
- package/dist/index.css +2357 -8490
- package/dist/index.css.map +1 -1
- package/dist/index.modern.js +9558 -300
- package/dist/index.modern.js.map +1 -1
- package/dist/index.module.js +12325 -332
- package/dist/index.module.js.map +1 -1
- package/dist/index.umd.js +12411 -336
- package/dist/index.umd.js.map +1 -1
- package/package.json +35 -9
- package/raw +1000 -0
- package/src/common-apis/adapters/analyticsAdapters/googleAnalyticsAdapter.js +22 -0
- package/src/common-apis/adapters/analyticsAdapters/metrikaAdapter.js +29 -0
- package/src/common-apis/adapters/analyticsAdapters/mixpanelAdapter.js +38 -0
- package/src/common-apis/adapters/axiosAdapter.js +35 -0
- package/src/common-apis/adapters/qrUtils.js +18 -0
- package/src/common-apis/external-apis/apiGroups.js +55 -0
- package/src/common-apis/external-apis/emailAPI.js +16 -0
- package/src/common-apis/external-apis/ipAddressProviders.js +89 -0
- package/src/common-apis/globalConstants.jsx +3 -0
- package/src/common-apis/models/blockchain.js +10 -0
- package/src/common-apis/models/coin.js +248 -0
- package/src/common-apis/models/protocol.js +5 -0
- package/src/{common → common-apis/services}/fiatCurrenciesService.js +4 -12
- package/src/common-apis/tests/integration/external-apis/ipAddressProviders/getClientIpAddress.test.js +12 -0
- package/src/common-apis/tests/units/utils/amountUtils/composeRateText.test.js +152 -0
- package/src/{common → common-apis/utils}/amountUtils.js +100 -140
- package/src/common-apis/utils/cache.js +242 -0
- package/src/{common → common-apis/utils}/errorUtils.js +15 -0
- package/src/common-apis/utils/logging/logger.js +41 -0
- package/src/common-apis/utils/logging/logsStorage.js +61 -0
- package/src/common-apis/utils/postponeExecution.js +11 -0
- package/src/common-apis/utils/rabbitTicker.js +24 -0
- package/src/common-apis/utils/safeStringify.js +50 -0
- package/src/index.js +96 -9
- package/src/robust-api-caller/cacheAndConcurrentRequestsResolver.js +495 -0
- package/src/robust-api-caller/cachedRobustExternalApiCallerService.js +147 -0
- package/src/robust-api-caller/cancelProcessing.js +29 -0
- package/src/robust-api-caller/concurrentCalculationsMetadataHolder.js +75 -0
- package/src/robust-api-caller/externalApiProvider.js +156 -0
- package/src/robust-api-caller/externalServicesStatsCollector.js +78 -0
- package/src/robust-api-caller/robustExternalAPICallerService.js +304 -0
- package/src/robust-api-caller/tests/robustExternalAPICallerService/robustExternalAPICallerService/callExternalAPI/_performCallAttempt.test.js +533 -0
- package/src/robust-api-caller/tests/robustExternalAPICallerService/robustExternalAPICallerService/callExternalAPI/callExternalAPI.test.js +532 -0
- package/src/robust-api-caller/tests/robustExternalAPICallerService/robustExternalAPICallerService/constructor.test.js +19 -0
- package/src/swaps-lib/external-apis/exolixSwapProvider.js +588 -0
- package/src/swaps-lib/external-apis/letsExchangeSwapProvider.js +516 -0
- package/src/swaps-lib/external-apis/swapProvider.js +580 -0
- package/src/swaps-lib/external-apis/swapspaceSwapProvider.js +605 -0
- package/src/swaps-lib/external-apis/utils.js +15 -0
- package/src/swaps-lib/models/baseSwapCreationInfo.js +78 -0
- package/src/swaps-lib/models/existingSwap.js +143 -0
- package/src/swaps-lib/models/existingSwapWithFiatData.js +148 -0
- package/src/swaps-lib/models/partner.js +27 -0
- package/src/swaps-lib/models/swapProviderCoinInfo.js +82 -0
- package/src/swaps-lib/services/publicSwapService.js +495 -0
- package/src/swaps-lib/test/external-apis/exolixSwapProvider/_fetchSupportedCurrenciesIfNeeded.test.js +34 -0
- package/src/swaps-lib/test/external-apis/exolixSwapProvider/createSwap.test.js +1043 -0
- package/src/swaps-lib/test/external-apis/exolixSwapProvider/getSwapInfo.test.js +611 -0
- package/src/swaps-lib/test/external-apis/swapProvider/getAllSupportedCurrencies.test.js +63 -0
- package/src/swaps-lib/test/external-apis/swapProvider/getDepositCurrencies.test.js +73 -0
- package/src/swaps-lib/test/external-apis/swapProvider/getWithdrawalCurrencies.test.js +102 -0
- package/src/swaps-lib/test/external-apis/swapProvider/removeProtocolNameFromCoinName.test.js +152 -0
- package/src/swaps-lib/test/external-apis/swapspaceSwapProvider/_fetchSupportedCurrenciesIfNeeded.test.js +536 -0
- package/src/swaps-lib/test/external-apis/swapspaceSwapProvider/createSwap.test.js +1214 -0
- package/src/swaps-lib/test/external-apis/swapspaceSwapProvider/getSwapInfo.test.js +1743 -0
- package/src/swaps-lib/test/utils/swapUtils/safeHandleRequestsLimitExceeding.test.js +80 -0
- package/src/swaps-lib/utils/swapUtils.js +195 -0
- package/{styles → src/ui-kit/assets/styles}/_functions.scss +5 -0
- package/{styles → src/ui-kit/assets/styles}/_mixins.scss +2 -2
- package/{styles → src/ui-kit/assets/styles}/_placeholder.scss +3 -3
- package/{styles → src/ui-kit/assets/styles}/_variables.scss +17 -15
- package/src/ui-kit/assets/styles/fonts/NunitoSans-Bold.ttf +0 -0
- package/src/ui-kit/assets/styles/fonts/NunitoSans-ExtraBold.ttf +0 -0
- package/src/ui-kit/assets/styles/fonts/NunitoSans-Light.ttf +0 -0
- package/src/ui-kit/assets/styles/fonts/NunitoSans-Regular.ttf +0 -0
- package/src/ui-kit/assets/styles/fonts/NunitoSans-SemiBold.ttf +0 -0
- package/src/ui-kit/assets/styles/global.scss +171 -0
- package/src/ui-kit/assets/styles/index.scss +10 -0
- package/src/ui-kit/assets/wrappedImages/arrowIcon.jsx +13 -0
- package/src/ui-kit/assets/wrappedImages/arrowTosca.jsx +14 -0
- package/src/ui-kit/assets/wrappedImages/arrowWhite.jsx +14 -0
- package/src/ui-kit/assets/wrappedImages/darkRectangle.jsx +7 -0
- package/src/ui-kit/assets/wrappedImages/determinedError.jsx +118 -0
- package/src/ui-kit/assets/wrappedImages/failedValidationIcon.jsx +39 -0
- package/src/ui-kit/assets/wrappedImages/infoIcon.jsx +16 -0
- package/src/ui-kit/assets/wrappedImages/messageIcon.jsx +87 -0
- package/src/ui-kit/assets/wrappedImages/noticeQuestionIcon.jsx +54 -0
- package/src/ui-kit/assets/wrappedImages/successfulValidationIcon.jsx +26 -0
- package/src/ui-kit/assets/wrappedImages/supportDialogImage.jsx +61 -0
- package/src/ui-kit/assets/wrappedImages/walletIcon.jsx +22 -0
- package/src/ui-kit/components/atoms/AssetIcon/AssetIcon.jsx +57 -0
- package/src/{components → ui-kit/components}/atoms/AssetIcon/asset-icon.module.scss +1 -1
- package/src/ui-kit/components/atoms/AssetSelection/AssetSelection.jsx +68 -0
- package/src/ui-kit/components/atoms/AssetSelection/asset-selection.module.scss +56 -0
- package/src/ui-kit/components/atoms/BackgroundTitle/BackgroundTitle.jsx +34 -0
- package/src/ui-kit/components/atoms/BackgroundTitle/background-title.module.scss +52 -0
- package/src/ui-kit/components/atoms/InformationMessage/InformationMessage.jsx +51 -0
- package/src/ui-kit/components/atoms/InformationMessage/information-message.module.scss +38 -0
- package/src/ui-kit/components/atoms/Input/Input.jsx +183 -0
- package/src/ui-kit/components/atoms/Input/input.module.scss +107 -0
- package/src/{components → ui-kit/components}/atoms/LoadingDots/LoadingDots.jsx +8 -28
- package/src/{components → ui-kit/components}/atoms/LoadingDots/LoadingDots.module.scss +3 -2
- package/src/ui-kit/components/atoms/NoticeIcon/NoticeIcon.jsx +64 -0
- package/src/ui-kit/components/atoms/NoticeIcon/notice-icon.module.scss +14 -0
- package/src/ui-kit/components/atoms/QrCode/QrCode.jsx +44 -0
- package/src/ui-kit/components/atoms/QrCode/qr-code.module.scss +15 -0
- package/src/ui-kit/components/atoms/RateSelector/RateSelector.jsx +30 -0
- package/src/ui-kit/components/atoms/RateSelector/rate-selector.module.scss +47 -0
- package/src/{components → ui-kit/components}/atoms/SupportChat/SupportChat.jsx +5 -1
- package/src/ui-kit/components/atoms/Textarea/Textarea.jsx +148 -0
- package/src/ui-kit/components/atoms/Textarea/textarea.module.scss +71 -0
- package/src/ui-kit/components/atoms/TitleBox/TitleBox.jsx +141 -0
- package/src/ui-kit/components/atoms/TitleBox/title-box.module.scss +32 -0
- package/src/ui-kit/components/atoms/Tooltip/Tooltip.jsx +77 -0
- package/src/ui-kit/components/atoms/Tooltip/tooltip.module.scss +237 -0
- package/src/ui-kit/components/atoms/TwoLinesOfText/LinesOfText.jsx +76 -0
- package/src/ui-kit/components/atoms/TwoLinesOfText/lines-of-text.module.scss +65 -0
- package/src/ui-kit/components/atoms/Validation/Validation.jsx +39 -0
- package/src/ui-kit/components/atoms/Validation/validation.module.scss +19 -0
- package/src/{components → ui-kit/components}/atoms/buttons/Button/Button.jsx +26 -45
- package/src/{components → ui-kit/components}/atoms/buttons/Button/Button.module.scss +1 -1
- package/src/ui-kit/components/atoms/buttons/Close/Close.jsx +58 -0
- package/src/ui-kit/components/atoms/buttons/Close/close.module.scss +75 -0
- package/src/ui-kit/components/atoms/buttons/LinkButton/LinkButton.jsx +116 -0
- package/src/ui-kit/components/atoms/buttons/LinkButton/link-button.module.scss +53 -0
- package/src/ui-kit/components/atoms/buttons/RadioButtonWithText/RadioButtonWithText.jsx +110 -0
- package/src/ui-kit/components/atoms/buttons/RadioButtonWithText/radio-button-with-text.module.scss +86 -0
- package/src/ui-kit/components/molecules/AmountInput/AmountInput.jsx +448 -0
- package/src/ui-kit/components/molecules/AmountInput/amount-input.module.scss +233 -0
- package/src/ui-kit/components/molecules/CoinPicker/CoinPicker.jsx +463 -0
- package/src/ui-kit/components/molecules/CoinPicker/coin-picker.module.scss +207 -0
- package/src/ui-kit/components/molecules/ColoredNotice/ColoredNotice.jsx +52 -0
- package/src/ui-kit/components/molecules/ColoredNotice/colored-notice.module.scss +36 -0
- package/src/ui-kit/components/molecules/LineWithIconLink/LineWithIconLink.jsx +35 -0
- package/src/ui-kit/components/molecules/LineWithIconLink/line-with-icon-link.module.scss +25 -0
- package/src/ui-kit/components/molecules/LogoCarousel/LogoCarousel.jsx +74 -0
- package/src/ui-kit/components/molecules/LogoCarousel/logo-carousel.module.scss +106 -0
- package/src/ui-kit/components/molecules/SearchableCoinsList/SearchableCoinsList.jsx +137 -0
- package/src/ui-kit/components/molecules/TitledLineWithIconLink/TitledLineWithIconLink.jsx +32 -0
- package/src/ui-kit/components/organisms/CoinPickerDialogStep/CoinPickerDialogStep.jsx +66 -0
- package/src/ui-kit/components/organisms/Dialog/Dialog.jsx +494 -0
- package/src/ui-kit/components/organisms/Dialog/DialogButtons/DialogButtons.jsx +132 -0
- package/src/ui-kit/components/organisms/Dialog/DialogButtons/dialog-buttons.module.scss +25 -0
- package/src/ui-kit/components/organisms/Dialog/DialogStep/DialogStep.jsx +554 -0
- package/src/ui-kit/components/organisms/Dialog/DialogStep/dialog-step.module.scss +382 -0
- package/src/ui-kit/components/organisms/Dialog/dialog.module.scss +226 -0
- package/src/ui-kit/components/organisms/SwapForm/SwapForm.jsx +1381 -0
- package/src/ui-kit/components/organisms/SwapForm/swap-form.module.scss +134 -0
- package/src/ui-kit/components/organisms/WaitlistSubscription/WaitlistSubscription.jsx +158 -0
- package/src/ui-kit/components/templates/DeterminedErrorDialogStep/DeterminedErrorDialogStep.jsx +77 -0
- package/src/ui-kit/hooks/useCallHandlingErrors.js +27 -0
- package/src/ui-kit/hooks/useIsHydrated.js +12 -0
- package/src/ui-kit/hooks/useReferredState.js +24 -0
- package/src/ui-kit/tests/utils/inputValueProviders/provideFormatOfFloatValueByInputString.test.js +146 -0
- package/src/ui-kit/tests/utils/urlQueryUtils/getQueryParameterValues.test.js +65 -0
- package/src/ui-kit/tests/utils/urlQueryUtils/saveQueryParameterAndValues.test.js +104 -0
- package/src/ui-kit/utils/inputValueProviders.js +50 -0
- package/src/ui-kit/utils/textUtils.js +18 -0
- package/src/ui-kit/utils/uiUtils.js +12 -0
- package/src/ui-kit/utils/urlQueryUtils.js +62 -0
- package/stories/font.scss +40 -0
- package/stories/stubs/coins.jsx +2266 -0
- package/stories/stubs/exampleContent.jsx +20 -0
- package/src/components/atoms/AssetIcon/AssetIcon.jsx +0 -55
- package/styles/_global-classes.scss +0 -433
- package/styles/fonts/NunitoSans-Bold.ttf +0 -0
- package/styles/fonts/NunitoSans-ExtraBold.ttf +0 -0
- package/styles/fonts/NunitoSans-Light.ttf +0 -0
- package/styles/fonts/NunitoSans-Regular.ttf +0 -0
- package/styles/fonts/NunitoSans-SemiBold.ttf +0 -0
- package/styles/global-styles-index.scss +0 -74
- package/styles/index.scss +0 -33
- /package/{styles → src/ui-kit/assets/styles}/colors/_light-colors.scss +0 -0
- /package/{styles → src/ui-kit/assets/styles}/colors/_solid-colors.scss +0 -0
- /package/{styles → src/ui-kit/assets/styles}/size/_margin-size.scss +0 -0
- /package/{styles → src/ui-kit/assets/styles}/size/_padding-size.scss +0 -0
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import sinon from "sinon";
|
|
2
|
+
import should from "should";
|
|
3
|
+
|
|
4
|
+
import { beforeEach, afterEach, describe, it } from "vitest";
|
|
5
|
+
import BigNumber from "bignumber.js";
|
|
6
|
+
import { AmountUtils } from "../../../../utils/amountUtils.js";
|
|
7
|
+
|
|
8
|
+
describe("AmountUtils", function () {
|
|
9
|
+
let toIntegerStringStub;
|
|
10
|
+
|
|
11
|
+
beforeEach(function () {
|
|
12
|
+
toIntegerStringStub = sinon.stub(AmountUtils, "toIntegerString").callsFake(number => number.toFixed(0));
|
|
13
|
+
});
|
|
14
|
+
|
|
15
|
+
afterEach(function () {
|
|
16
|
+
toIntegerStringStub.restore();
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
describe("composeRateText", function () {
|
|
20
|
+
it("Should handle simple rate calculation", function () {
|
|
21
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.1");
|
|
22
|
+
|
|
23
|
+
result.should.equal("1 BTC ~ 0.10000000 ETH");
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
it("Should handle rate with strictRate set to true", function () {
|
|
27
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.1", 8, true);
|
|
28
|
+
|
|
29
|
+
result.should.equal("1 BTC = 0.10000000 ETH");
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
it("Should handle rate with high precision", function () {
|
|
33
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.12345678903422", 8);
|
|
34
|
+
|
|
35
|
+
result.should.equal("1 BTC ~ 0.12345678 ETH");
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
it("Should handle very small rates by scaling up", function () {
|
|
39
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.000000000000001", 8);
|
|
40
|
+
|
|
41
|
+
result.should.equal("100000000 BTC ~ 0.00000010 ETH");
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
it("Should handle large rates", function () {
|
|
45
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "1000000000000000", 8);
|
|
46
|
+
|
|
47
|
+
result.should.equal("1 BTC ~ 1000000000000000.00000000 ETH");
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
it("Should return '?' for invalid rate input", function () {
|
|
51
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "invalid");
|
|
52
|
+
|
|
53
|
+
result.should.equal("1 BTC ~ ? ETH");
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
it("Should return correct format for null rate", function () {
|
|
57
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", null);
|
|
58
|
+
|
|
59
|
+
result.should.equal("1 BTC ~ ? ETH");
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
it("Should ensure that toIntegerString is called with correct parameter", function () {
|
|
63
|
+
AmountUtils.composeRateText("BTC", "ETH", "0.1");
|
|
64
|
+
|
|
65
|
+
toIntegerStringStub.calledWith(BigNumber("1")).should.be.true();
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
it("Should handle rate with different rightCurrencyDigitsAfterDots", function () {
|
|
69
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.123456789", 5);
|
|
70
|
+
|
|
71
|
+
result.should.equal("1 BTC ~ 0.12345 ETH");
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
it("Should handle rate with max rightCurrencyDigitsAfterDots", function () {
|
|
75
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.123456789", 10);
|
|
76
|
+
|
|
77
|
+
result.should.equal("1 BTC ~ 0.1234567890 ETH");
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
it("Should ensure proper rounding of right amount", function () {
|
|
81
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.123456789", 4);
|
|
82
|
+
|
|
83
|
+
result.should.equal("1 BTC ~ 0.1234 ETH");
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
it("Should handle great rightCurrencyDigitsAfterDots", function () {
|
|
87
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.123456789", 20);
|
|
88
|
+
|
|
89
|
+
result.should.equal("1 BTC ~ 0.12345678900000000000 ETH");
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
it("Should handle empty rate", function () {
|
|
93
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "");
|
|
94
|
+
|
|
95
|
+
result.should.equal("1 BTC ~ ? ETH");
|
|
96
|
+
});
|
|
97
|
+
|
|
98
|
+
it("Should handle negative rate", function () {
|
|
99
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "-0.1");
|
|
100
|
+
|
|
101
|
+
result.should.equal("1 BTC ~ -0.10000000 ETH");
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
it("Should return proper result for rate equal to zero", function () {
|
|
105
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0");
|
|
106
|
+
|
|
107
|
+
result.should.equal("1 BTC ~ 0.00000000 ETH");
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
it("Should ensure that toIntegerString is called the correct number of times", function () {
|
|
111
|
+
AmountUtils.composeRateText("BTC", "ETH", "0.1");
|
|
112
|
+
|
|
113
|
+
toIntegerStringStub.callCount.should.equal(1);
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
it("Should handle rate with exponential notation", function () {
|
|
117
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "1e-8");
|
|
118
|
+
|
|
119
|
+
result.should.equal("1 BTC ~ 0.00000001 ETH");
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it("Should return correct format when rate has a lot of trailing zeros", function () {
|
|
123
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.1000000000000000000000");
|
|
124
|
+
|
|
125
|
+
result.should.equal("1 BTC ~ 0.10000000 ETH");
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it("Should handle zero rightCurrencyDigitsAfterDots", function () {
|
|
129
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.123456789", 0);
|
|
130
|
+
|
|
131
|
+
result.should.equal("100 BTC ~ 12 ETH");
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
it("Should handle negative rightCurrencyDigitsAfterDots", function () {
|
|
135
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "0.123456789", -1);
|
|
136
|
+
|
|
137
|
+
result.should.equal("1 BTC ~ 0.12345678 ETH");
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
it("Should handle rate input with trailing spaces", function () {
|
|
141
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", " 0.1 ");
|
|
142
|
+
|
|
143
|
+
result.should.equal("1 BTC ~ 0.10000000 ETH");
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
it("Should handle rate input in scientific notation", function () {
|
|
147
|
+
const result = AmountUtils.composeRateText("BTC", "ETH", "1e-5");
|
|
148
|
+
|
|
149
|
+
result.should.equal("1 BTC ~ 0.00001000 ETH");
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
});
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { BigNumber } from "bignumber.js";
|
|
2
2
|
|
|
3
|
-
import { FiatCurrenciesService } from "
|
|
3
|
+
import { FiatCurrenciesService } from "../services/fiatCurrenciesService.js";
|
|
4
4
|
import { improveAndRethrow } from "./errorUtils.js";
|
|
5
5
|
|
|
6
6
|
// TODO: [dev] return addCommasToAmountString internal method to encapsulate commas adding
|
|
@@ -38,54 +38,31 @@ export class AmountUtils {
|
|
|
38
38
|
try {
|
|
39
39
|
const params = { ...this.defaultFiatParams, ...passedParams };
|
|
40
40
|
|
|
41
|
-
if (
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
)
|
|
45
|
-
return "NULL";
|
|
46
|
-
|
|
47
|
-
const currencySymbol =
|
|
48
|
-
FiatCurrenciesService.getCurrencySymbolByCode(currencyCode);
|
|
49
|
-
const currencyDecimalCount =
|
|
50
|
-
FiatCurrenciesService.getCurrencyDecimalCountByCode(
|
|
51
|
-
currencyCode
|
|
52
|
-
);
|
|
41
|
+
if (this._checkIfAmountInvalid(amount, true) || typeof currencyCode !== "string") return "NULL";
|
|
42
|
+
|
|
43
|
+
const currencySymbol = FiatCurrenciesService.getCurrencySymbolByCode(currencyCode);
|
|
44
|
+
const currencyDecimalCount = FiatCurrenciesService.getCurrencyDecimalCountByCode(currencyCode);
|
|
53
45
|
|
|
54
|
-
const trimmedByMaxDigits =
|
|
55
|
-
currencyDecimalCount,
|
|
56
|
-
BigNumber
|
|
57
|
-
);
|
|
46
|
+
const trimmedByMaxDigits = params.collapsible
|
|
47
|
+
? BigNumber(amount).toFixed(currencyDecimalCount, BigNumber.ROUND_FLOOR)
|
|
48
|
+
: BigNumber(amount);
|
|
58
49
|
|
|
59
50
|
let processedAmount = BigNumber(trimmedByMaxDigits);
|
|
60
|
-
if (
|
|
61
|
-
params.collapsible &&
|
|
62
|
-
processedAmount.gte(BigNumber("1000000"))
|
|
63
|
-
) {
|
|
51
|
+
if (params.collapsible && processedAmount.gte(BigNumber("1000"))) {
|
|
64
52
|
processedAmount = this._collapseToMillionsAndFormat(
|
|
65
53
|
processedAmount,
|
|
66
54
|
this.collapsedDecimalCount,
|
|
67
55
|
params
|
|
68
56
|
);
|
|
69
57
|
} else {
|
|
70
|
-
const limitResult = this._limitTotalAmountLengthIfNeeded(
|
|
71
|
-
|
|
72
|
-
params
|
|
73
|
-
);
|
|
74
|
-
processedAmount = BigNumber(
|
|
75
|
-
limitResult.processedAmount
|
|
76
|
-
).toFormat(); // Adds commas to integer part
|
|
58
|
+
const limitResult = this._limitTotalAmountLengthIfNeeded(trimmedByMaxDigits, params);
|
|
59
|
+
processedAmount = BigNumber(limitResult.processedAmount).toFormat(); // Adds commas to integer part
|
|
77
60
|
}
|
|
78
61
|
|
|
79
62
|
// Add the currency code or currency symbol, if symbol is enabled and available
|
|
80
63
|
if (params.ticker) {
|
|
81
|
-
if (
|
|
82
|
-
|
|
83
|
-
params.enableCurrencySymbols
|
|
84
|
-
) {
|
|
85
|
-
processedAmount =
|
|
86
|
-
currencySymbol +
|
|
87
|
-
(currencySymbol.length > 1 ? " " : "") +
|
|
88
|
-
processedAmount;
|
|
64
|
+
if (typeof currencySymbol === "string" && params.enableCurrencySymbols) {
|
|
65
|
+
processedAmount = currencySymbol + (currencySymbol.length > 1 ? " " : "") + processedAmount;
|
|
89
66
|
} else {
|
|
90
67
|
processedAmount = processedAmount + " " + currencyCode;
|
|
91
68
|
}
|
|
@@ -104,6 +81,7 @@ export class AmountUtils {
|
|
|
104
81
|
limitTotalLength: true, // Limits the total amount length to maxTotalLength
|
|
105
82
|
extraSmallLength: false, // Limits the total amount length to extraSmallMaxTotalLength
|
|
106
83
|
periods: true, // Whether we add periods ("..") as suffix for trimmed numbers
|
|
84
|
+
numberPartsSeparator: true, // Whether we add separators e.g. for 1000000 -> 1,000,000
|
|
107
85
|
};
|
|
108
86
|
|
|
109
87
|
static cryptoWoTicker(amount, digits) {
|
|
@@ -132,6 +110,16 @@ export class AmountUtils {
|
|
|
132
110
|
});
|
|
133
111
|
}
|
|
134
112
|
|
|
113
|
+
static cryptoFullPureNumber(amount, digits) {
|
|
114
|
+
return this.crypto(amount, null, digits, {
|
|
115
|
+
ticker: false,
|
|
116
|
+
collapsible: false,
|
|
117
|
+
trim: false,
|
|
118
|
+
limitTotalLength: false,
|
|
119
|
+
numberPartsSeparator: false,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
|
|
135
123
|
/**
|
|
136
124
|
* Universal method for rendering of crypto amounts, taking into account the rules of
|
|
137
125
|
* the passed ticker. Requires the number of digits after period to be less of equal to
|
|
@@ -143,33 +131,19 @@ export class AmountUtils {
|
|
|
143
131
|
* @param passedParams {object} Formatting parameters
|
|
144
132
|
* @return {string} Formatted crypto amount string
|
|
145
133
|
*/
|
|
146
|
-
static crypto(
|
|
147
|
-
amount,
|
|
148
|
-
ticker,
|
|
149
|
-
digits = this.significantDecimalCount,
|
|
150
|
-
passedParams
|
|
151
|
-
) {
|
|
134
|
+
static crypto(amount, ticker, digits = this.significantDecimalCount, passedParams) {
|
|
152
135
|
try {
|
|
153
136
|
const params = { ...this.defaultCryptoParams, ...passedParams };
|
|
154
137
|
|
|
155
|
-
if (
|
|
156
|
-
this._checkIfAmountInvalid(amount) ||
|
|
157
|
-
(typeof ticker !== "string" && params.ticker)
|
|
158
|
-
)
|
|
159
|
-
return "NULL";
|
|
138
|
+
if (this._checkIfAmountInvalid(amount) || (typeof ticker !== "string" && params.ticker)) return "NULL";
|
|
160
139
|
|
|
161
140
|
let addPeriods = false;
|
|
162
141
|
|
|
163
142
|
const amountBigNumber = BigNumber(amount);
|
|
164
143
|
|
|
165
|
-
let processedAmount = amountBigNumber.toFixed(
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
);
|
|
169
|
-
processedAmount =
|
|
170
|
-
this.removeRedundantRightZerosFromNumberString(processedAmount);
|
|
171
|
-
const originalAmountDecimalPlaces =
|
|
172
|
-
BigNumber(processedAmount).decimalPlaces();
|
|
144
|
+
let processedAmount = amountBigNumber.toFixed(digits, BigNumber.ROUND_FLOOR);
|
|
145
|
+
processedAmount = this.removeRedundantRightZerosFromNumberString(processedAmount);
|
|
146
|
+
const originalAmountDecimalPlaces = BigNumber(processedAmount).decimalPlaces();
|
|
173
147
|
// Check decimal count and throw an error, if the amount has more decimal digits than supported by the asset
|
|
174
148
|
if (originalAmountDecimalPlaces > digits) {
|
|
175
149
|
const errorMessage = `An attempt to render a crypto value with too many digits after period was made: ${amount}, allowed digits: ${digits}. This is a no-op, since the logical and visually rendered values would differ, which is not acceptable for crypto amounts. Please trim the amount before rendering, using the trimCryptoAmountByCoin(amount, coin) method.`;
|
|
@@ -180,21 +154,13 @@ export class AmountUtils {
|
|
|
180
154
|
|
|
181
155
|
// Shortening the value to general significant number of digits after period
|
|
182
156
|
if (params.trim) {
|
|
183
|
-
processedAmount =
|
|
184
|
-
this.
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
BigNumber.ROUND_FLOOR
|
|
188
|
-
)
|
|
189
|
-
);
|
|
190
|
-
addPeriods =
|
|
191
|
-
originalAmountDecimalPlaces > this.significantDecimalCount;
|
|
157
|
+
processedAmount = this.removeRedundantRightZerosFromNumberString(
|
|
158
|
+
amountBigNumber.toFixed(this.significantDecimalCount, BigNumber.ROUND_FLOOR)
|
|
159
|
+
);
|
|
160
|
+
addPeriods = originalAmountDecimalPlaces > this.significantDecimalCount;
|
|
192
161
|
}
|
|
193
162
|
|
|
194
|
-
const limitResult = this._limitTotalAmountLengthIfNeeded(
|
|
195
|
-
processedAmount,
|
|
196
|
-
params
|
|
197
|
-
);
|
|
163
|
+
const limitResult = this._limitTotalAmountLengthIfNeeded(processedAmount, params);
|
|
198
164
|
processedAmount = limitResult.processedAmount;
|
|
199
165
|
addPeriods ||= limitResult.addPeriods;
|
|
200
166
|
|
|
@@ -207,7 +173,7 @@ export class AmountUtils {
|
|
|
207
173
|
params
|
|
208
174
|
);
|
|
209
175
|
wereMillionsCollapsed = true;
|
|
210
|
-
} else {
|
|
176
|
+
} else if (params.numberPartsSeparator) {
|
|
211
177
|
// Add separators to integer part of the amount
|
|
212
178
|
processedAmount = BigNumber(processedAmount).toFormat();
|
|
213
179
|
}
|
|
@@ -224,11 +190,7 @@ export class AmountUtils {
|
|
|
224
190
|
|
|
225
191
|
return processedAmount;
|
|
226
192
|
} catch (e) {
|
|
227
|
-
improveAndRethrow(
|
|
228
|
-
e,
|
|
229
|
-
"crypto",
|
|
230
|
-
`Passed: ${amount}, ${ticker}, ${digits}`
|
|
231
|
-
);
|
|
193
|
+
improveAndRethrow(e, "crypto", `Passed: ${amount}, ${ticker}, ${digits}`);
|
|
232
194
|
}
|
|
233
195
|
}
|
|
234
196
|
|
|
@@ -262,11 +224,13 @@ export class AmountUtils {
|
|
|
262
224
|
}
|
|
263
225
|
|
|
264
226
|
/**
|
|
227
|
+
* Returns integer part of number as a string.
|
|
228
|
+
*
|
|
265
229
|
* @param amount {BigNumber|number|string|null|undefined} The number value to be trimmed.
|
|
266
230
|
* HEX strings also allowed "0x..." and JS hex numbers
|
|
267
231
|
* @return {string|null}
|
|
268
232
|
*/
|
|
269
|
-
static
|
|
233
|
+
static toIntegerString(amount) {
|
|
270
234
|
return this.trim(amount, 0);
|
|
271
235
|
}
|
|
272
236
|
|
|
@@ -278,32 +242,39 @@ export class AmountUtils {
|
|
|
278
242
|
* @param params {object} params object
|
|
279
243
|
* @return {string} A shortened string, converted into "millions" format, if the amount exceeds 1 million
|
|
280
244
|
*/
|
|
281
|
-
static _collapseToMillionsAndFormat(
|
|
282
|
-
amountBigNumber,
|
|
283
|
-
decimalCount,
|
|
284
|
-
params = {}
|
|
285
|
-
) {
|
|
245
|
+
static _collapseToMillionsAndFormat(amountBigNumber, decimalCount, params = {}) {
|
|
286
246
|
try {
|
|
287
|
-
|
|
288
|
-
const
|
|
289
|
-
const
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
)
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
247
|
+
const thousand = BigNumber("1000");
|
|
248
|
+
const million = BigNumber("1000000");
|
|
249
|
+
const billion = BigNumber("1000000000");
|
|
250
|
+
const trillion = BigNumber("1000000000000");
|
|
251
|
+
|
|
252
|
+
let shortAmount;
|
|
253
|
+
let suffix = "";
|
|
254
|
+
|
|
255
|
+
if (amountBigNumber.gte(trillion)) {
|
|
256
|
+
shortAmount = amountBigNumber.div(trillion).toFixed(decimalCount, BigNumber.ROUND_FLOOR);
|
|
257
|
+
suffix = "T";
|
|
258
|
+
} else if (amountBigNumber.gte(billion)) {
|
|
259
|
+
shortAmount = amountBigNumber.div(billion).toFixed(decimalCount, BigNumber.ROUND_FLOOR);
|
|
260
|
+
suffix = "B";
|
|
261
|
+
} else if (amountBigNumber.gte(million)) {
|
|
262
|
+
shortAmount = amountBigNumber.div(million).toFixed(decimalCount, BigNumber.ROUND_FLOOR);
|
|
263
|
+
suffix = "M";
|
|
264
|
+
} else if (amountBigNumber.gte(thousand)) {
|
|
265
|
+
shortAmount = amountBigNumber.div(thousand).toFixed(decimalCount, BigNumber.ROUND_FLOOR);
|
|
266
|
+
suffix = "K";
|
|
267
|
+
} else {
|
|
268
|
+
shortAmount = amountBigNumber.toFixed(decimalCount, BigNumber.ROUND_FLOOR);
|
|
269
|
+
suffix = "";
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
const limitedResult = this._limitTotalAmountLengthIfNeeded(shortAmount, params);
|
|
273
|
+
const formattedAmount = BigNumber(limitedResult.processedAmount).toFormat();
|
|
274
|
+
|
|
275
|
+
return formattedAmount + suffix;
|
|
301
276
|
} catch (e) {
|
|
302
|
-
improveAndRethrow(
|
|
303
|
-
e,
|
|
304
|
-
"_collapseAmountAndFormat",
|
|
305
|
-
`Passed: ${amountBigNumber.toFixed()}, ${decimalCount}`
|
|
306
|
-
);
|
|
277
|
+
improveAndRethrow(e, "_collapseAmountAndFormat", `Passed: ${amountBigNumber.toFixed()}, ${decimalCount}`);
|
|
307
278
|
}
|
|
308
279
|
}
|
|
309
280
|
|
|
@@ -316,13 +287,10 @@ export class AmountUtils {
|
|
|
316
287
|
try {
|
|
317
288
|
let addPeriods = false;
|
|
318
289
|
if (params.limitTotalLength || params.extraSmallLength) {
|
|
319
|
-
const maxLength = params.extraSmallLength
|
|
320
|
-
? this.extraSmallMaxTotalLength
|
|
321
|
-
: this.maxTotalLength;
|
|
290
|
+
const maxLength = params.extraSmallLength ? this.extraSmallMaxTotalLength : this.maxTotalLength;
|
|
322
291
|
if (amountString.length > maxLength) {
|
|
323
292
|
const delta = amountString.length - maxLength;
|
|
324
|
-
const currentDecimalsCount =
|
|
325
|
-
BigNumber(amountString).decimalPlaces();
|
|
293
|
+
const currentDecimalsCount = BigNumber(amountString).decimalPlaces();
|
|
326
294
|
const newDecimalCount = currentDecimalsCount - delta;
|
|
327
295
|
amountString = BigNumber(amountString).toFixed(
|
|
328
296
|
newDecimalCount > 2 ? newDecimalCount : 2,
|
|
@@ -334,62 +302,58 @@ export class AmountUtils {
|
|
|
334
302
|
|
|
335
303
|
return { addPeriods: addPeriods, processedAmount: amountString };
|
|
336
304
|
} catch (e) {
|
|
337
|
-
improveAndRethrow(
|
|
338
|
-
e,
|
|
339
|
-
"_limitTotalAmountLengthIfNeeded",
|
|
340
|
-
`Passed: ${amountString}, ${params}`
|
|
341
|
-
);
|
|
305
|
+
improveAndRethrow(e, "_limitTotalAmountLengthIfNeeded", `Passed: ${amountString}, ${params}`);
|
|
342
306
|
}
|
|
343
307
|
}
|
|
344
308
|
|
|
345
309
|
/**
|
|
346
|
-
* Safely composes rate string (handles small/big rates)
|
|
310
|
+
* Safely composes rate string (handles small/big rates).
|
|
311
|
+
* Here we try to calculate a clear rate for the user. The difficulty is that the rate value can be pretty
|
|
312
|
+
* small as some coins have significantly higher price than the other. For such cases we calculate
|
|
313
|
+
* not the "1 <coin_A> is X <coin B>" but "Y <coin_A> is X <coin B>" where Y is one of the powers of 100.
|
|
347
314
|
*
|
|
348
315
|
* @param leftTicker {string}
|
|
349
316
|
* @param rightTicker {string}
|
|
350
317
|
* @param rate {number|string|BigNumber}
|
|
351
318
|
* @param [rightCurrencyDigitsAfterDots=8] {number}
|
|
319
|
+
* @param [strictRate=false] {boolean} true if the rate is strict and false if approximate
|
|
352
320
|
* @return {string}
|
|
353
321
|
*/
|
|
354
322
|
static composeRateText(
|
|
355
323
|
leftTicker,
|
|
356
324
|
rightTicker,
|
|
357
325
|
rate,
|
|
358
|
-
rightCurrencyDigitsAfterDots = this.significantDecimalCount
|
|
326
|
+
rightCurrencyDigitsAfterDots = this.significantDecimalCount,
|
|
327
|
+
strictRate = false
|
|
359
328
|
) {
|
|
360
329
|
try {
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
*/
|
|
330
|
+
if (rightCurrencyDigitsAfterDots < 0) {
|
|
331
|
+
rightCurrencyDigitsAfterDots = this.significantDecimalCount;
|
|
332
|
+
}
|
|
365
333
|
let leftNumber = BigNumber("1");
|
|
366
334
|
const multiplier = BigNumber("100");
|
|
367
335
|
const maxAttemptsToGetRate = 10;
|
|
368
336
|
let right = null;
|
|
369
337
|
const rateBigNumber = BigNumber(rate);
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
338
|
+
if (BigNumber(rate).eq("0")) {
|
|
339
|
+
right = BigNumber("0");
|
|
340
|
+
} else if (rate && (BigNumber.isBigNumber(rate) || !Number.isNaN(+rate))) {
|
|
341
|
+
for (let i = 0; i < maxAttemptsToGetRate; ++i) {
|
|
342
|
+
const rightNumberAttempt = rateBigNumber
|
|
343
|
+
.times(leftNumber)
|
|
344
|
+
.toFixed(rightCurrencyDigitsAfterDots, BigNumber.ROUND_FLOOR);
|
|
345
|
+
if (!BigNumber(rightNumberAttempt).eq(BigNumber("0"))) {
|
|
346
|
+
right = BigNumber(rightNumberAttempt);
|
|
347
|
+
break;
|
|
348
|
+
} else {
|
|
349
|
+
leftNumber = leftNumber.times(multiplier);
|
|
350
|
+
}
|
|
382
351
|
}
|
|
383
352
|
}
|
|
384
|
-
const leftAmountString = AmountUtils.
|
|
353
|
+
const leftAmountString = AmountUtils.toIntegerString(leftNumber);
|
|
385
354
|
const rightAmountString =
|
|
386
|
-
right != null
|
|
387
|
-
|
|
388
|
-
rightCurrencyDigitsAfterDots,
|
|
389
|
-
BigNumber.ROUND_FLOOR
|
|
390
|
-
)
|
|
391
|
-
: null;
|
|
392
|
-
return `${leftAmountString} ${leftTicker} ~ ${
|
|
355
|
+
right != null ? right.toFixed(rightCurrencyDigitsAfterDots, BigNumber.ROUND_FLOOR) : null;
|
|
356
|
+
return `${leftAmountString} ${leftTicker} ${strictRate ? "=" : "~"} ${
|
|
393
357
|
rightAmountString ?? "?"
|
|
394
358
|
} ${rightTicker}`;
|
|
395
359
|
} catch (e) {
|
|
@@ -413,11 +377,7 @@ export class AmountUtils {
|
|
|
413
377
|
|
|
414
378
|
return `${parts[0]}${right?.length ? `.${right}` : ""}`;
|
|
415
379
|
} catch (e) {
|
|
416
|
-
improveAndRethrow(
|
|
417
|
-
e,
|
|
418
|
-
"removeRedundantRightZerosFromNumberString",
|
|
419
|
-
`Passed: ${numberAsAString}`
|
|
420
|
-
);
|
|
380
|
+
improveAndRethrow(e, "removeRedundantRightZerosFromNumberString", `Passed: ${numberAsAString}`);
|
|
421
381
|
}
|
|
422
382
|
}
|
|
423
383
|
}
|