@ape.swap/bonds-sdk 3.1.8 → 3.1.9-test.3
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/dist/components/BondFilters/BondFilters.js +41 -0
- package/dist/components/BondFilters/BondFilters.js.map +1 -0
- package/dist/components/ChainOptionList/ChainOptionsButtons.js +35 -0
- package/dist/components/ChainOptionList/ChainOptionsButtons.js.map +1 -0
- package/dist/components/ChainOptionList/ChainOptionsList.js +41 -0
- package/dist/components/ChainOptionList/ChainOptionsList.js.map +1 -0
- package/dist/components/ChainOptionList/constants.js +11 -0
- package/dist/components/ChainOptionList/constants.js.map +1 -0
- package/dist/components/ChainOptionList/styles.js +54 -0
- package/dist/components/ChainOptionList/styles.js.map +1 -0
- package/dist/components/ConnectButton/AppKitButton.js +22 -0
- package/dist/components/ConnectButton/AppKitButton.js.map +1 -0
- package/dist/components/ConnectButton/RainbowKitButton.js +35 -0
- package/dist/components/ConnectButton/RainbowKitButton.js.map +1 -0
- package/dist/components/ConnectButton/index.js +26 -0
- package/dist/components/ConnectButton/index.js.map +1 -0
- package/dist/components/FavIcons/AddFavToken.js +34 -0
- package/dist/components/FavIcons/AddFavToken.js.map +1 -0
- package/dist/components/FavIcons/FavFilter.js +29 -0
- package/dist/components/FavIcons/FavFilter.js.map +1 -0
- package/dist/components/LoadingSpinner/index.js +50 -0
- package/dist/components/LoadingSpinner/index.js.map +1 -0
- package/dist/components/MenuSelect/MenuSelect.js +30 -0
- package/dist/components/MenuSelect/MenuSelect.js.map +1 -0
- package/dist/components/MenuSelect/RecommendationSelector.js +57 -0
- package/dist/components/MenuSelect/RecommendationSelector.js.map +1 -0
- package/dist/components/NetworkFilter/index.js +112 -0
- package/dist/components/NetworkFilter/index.js.map +1 -0
- package/dist/components/PlaceholderMonkey/index.js +31 -0
- package/dist/components/PlaceholderMonkey/index.js.map +1 -0
- package/dist/components/ProgressBar/ProgressBar.js +11 -0
- package/dist/components/ProgressBar/ProgressBar.js.map +1 -0
- package/dist/components/ProgressBar/ProgressBarWrapper.js +23 -0
- package/dist/components/ProgressBar/ProgressBarWrapper.js.map +1 -0
- package/dist/components/ProgressBar/styles.js +15 -0
- package/dist/components/ProgressBar/styles.js.map +1 -0
- package/dist/components/SafeHTMLComponent/index.js +30 -0
- package/dist/components/SafeHTMLComponent/index.js.map +1 -0
- package/dist/components/SlippageModal/index.js +70 -0
- package/dist/components/SlippageModal/index.js.map +1 -0
- package/dist/components/StepBubble/index.js +61 -0
- package/dist/components/StepBubble/index.js.map +1 -0
- package/dist/components/Toast/index.js +55 -0
- package/dist/components/Toast/index.js.map +1 -0
- package/dist/components/Toast/styles.js +30 -0
- package/dist/components/Toast/styles.js.map +1 -0
- package/dist/components/TokenInfoAndName/index.js +66 -0
- package/dist/components/TokenInfoAndName/index.js.map +1 -0
- package/dist/components/TokenSelectorModal/TokenRow.js +31 -0
- package/dist/components/TokenSelectorModal/TokenRow.js.map +1 -0
- package/dist/components/TokenSelectorModal/index.js +62 -0
- package/dist/components/TokenSelectorModal/index.js.map +1 -0
- package/dist/components/TokenSelectorPanel/index.js +55 -0
- package/dist/components/TokenSelectorPanel/index.js.map +1 -0
- package/dist/components/Tooltip/ButtonsRow.js +36 -0
- package/dist/components/Tooltip/ButtonsRow.js.map +1 -0
- package/dist/components/Tooltip/Tooltip.js +46 -0
- package/dist/components/Tooltip/Tooltip.js.map +1 -0
- package/dist/components/Tooltip/styles.js +32 -0
- package/dist/components/Tooltip/styles.js.map +1 -0
- package/dist/components/YouTooltip/YouTooltip.js +44 -0
- package/dist/components/YouTooltip/YouTooltip.js.map +1 -0
- package/dist/components/uikit-sdk/Button/Button.js +84 -0
- package/dist/components/uikit-sdk/Button/Button.js.map +1 -0
- package/dist/components/uikit-sdk/Button/IconButton.js +23 -0
- package/dist/components/uikit-sdk/Button/IconButton.js.map +1 -0
- package/dist/components/uikit-sdk/Button/styles.js +31 -0
- package/dist/components/uikit-sdk/Button/styles.js.map +1 -0
- package/dist/components/uikit-sdk/Button/types.js +39 -0
- package/dist/components/uikit-sdk/Button/types.js.map +1 -0
- package/dist/components/uikit-sdk/Checkbox/index.js +25 -0
- package/dist/components/uikit-sdk/Checkbox/index.js.map +1 -0
- package/dist/components/uikit-sdk/Checkbox/types.js +8 -0
- package/dist/components/uikit-sdk/Checkbox/types.js.map +1 -0
- package/dist/components/uikit-sdk/Flex/index.js +9 -0
- package/dist/components/uikit-sdk/Flex/index.js.map +1 -0
- package/dist/components/uikit-sdk/Input/Input.js +53 -0
- package/dist/components/uikit-sdk/Input/Input.js.map +1 -0
- package/dist/components/uikit-sdk/LoadingDots/index.js +41 -0
- package/dist/components/uikit-sdk/LoadingDots/index.js.map +1 -0
- package/dist/components/uikit-sdk/Modal/ModalHeader.js +13 -0
- package/dist/components/uikit-sdk/Modal/ModalHeader.js.map +1 -0
- package/dist/components/uikit-sdk/Modal/index.js +26 -0
- package/dist/components/uikit-sdk/Modal/index.js.map +1 -0
- package/dist/components/uikit-sdk/Modal/styles.js +47 -0
- package/dist/components/uikit-sdk/Modal/styles.js.map +1 -0
- package/dist/components/uikit-sdk/Select/Select.js +51 -0
- package/dist/components/uikit-sdk/Select/Select.js.map +1 -0
- package/dist/components/uikit-sdk/Select/SelectItem.js +20 -0
- package/dist/components/uikit-sdk/Select/SelectItem.js.map +1 -0
- package/dist/components/uikit-sdk/Select/styles.js +50 -0
- package/dist/components/uikit-sdk/Select/styles.js.map +1 -0
- package/dist/components/uikit-sdk/Select/types.d.ts +1 -1
- package/dist/components/uikit-sdk/Select/types.js +39 -0
- package/dist/components/uikit-sdk/Select/types.js.map +1 -0
- package/dist/components/uikit-sdk/Skeleton/index.js +16 -0
- package/dist/components/uikit-sdk/Skeleton/index.js.map +1 -0
- package/dist/components/uikit-sdk/Skeleton/styles.js +43 -0
- package/dist/components/uikit-sdk/Skeleton/styles.js.map +1 -0
- package/dist/components/uikit-sdk/Skeleton/types.js +13 -0
- package/dist/components/uikit-sdk/Skeleton/types.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/AbondFullLogo.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/AbondFullLogo.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/AbondSmallLogo.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/AbondSmallLogo.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/AccountMonkey.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/AccountMonkey.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/AllChains.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/AllChains.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ApebondLogo.js +19 -0
- package/dist/components/uikit-sdk/Svg/Icons/ApebondLogo.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ApeswapSmallLogo.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/ApeswapSmallLogo.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Arrow.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Arrow.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Audit.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Audit.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/BananaIcon.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/BananaIcon.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/BillsM1.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/BillsM1.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/BillsM2.js +19 -0
- package/dist/components/uikit-sdk/Svg/Icons/BillsM2.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/BillsM3.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/BillsM3.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Bridge.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Bridge.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Bubble.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Bubble.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Calculator.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Calculator.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Calendar.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Calendar.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Cancelled.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Cancelled.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Card.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Card.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Caret.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Caret.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Chain.js +10 -0
- package/dist/components/uikit-sdk/Svg/Icons/Chain.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Chart.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Chart.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Chat.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Chat.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Close.js +11 -0
- package/dist/components/uikit-sdk/Svg/Icons/Close.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Cog.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Cog.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Collapse.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Collapse.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Copy.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Copy.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Discord.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Discord.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/DiscordNew.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/DiscordNew.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Docs.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Docs.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/DocsV2.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/DocsV2.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Ellipse.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Ellipse.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Error.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Error.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Expand.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Expand.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Explorer.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Explorer.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/External.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/External.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Farcaster.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Farcaster.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Farm.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Farm.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Fav.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Fav.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/FilledURL.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/FilledURL.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Fire.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Fire.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/FirePink.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/FirePink.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Frame.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Frame.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/FullLogo.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/FullLogo.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Gnana.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Gnana.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/GreenShield.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/GreenShield.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Hamburger.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Hamburger.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/HamburgerClosed.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/HamburgerClosed.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Home.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Home.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Hot.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Hot.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Info.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Info.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/InfoSolid.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/InfoSolid.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Insight.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Insight.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Instagram.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Instagram.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Island.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Island.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/LanguageIcon.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/LanguageIcon.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/LineChart.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/LineChart.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/LiquidityIcon.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/LiquidityIcon.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Logout.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Logout.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Medium.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Medium.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/MenuSettings.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/MenuSettings.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Message.js +11 -0
- package/dist/components/uikit-sdk/Svg/Icons/Message.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Migrate.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Migrate.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Moon.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Moon.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/More.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/More.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/NFA.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/NFA.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/NavCaret.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/NavCaret.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/PlaceholderMonkey.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/PlaceholderMonkey.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/PlaceholderMonkeyAlt.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/PlaceholderMonkeyAlt.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Play.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Play.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Pool.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Pool.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Positions.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Positions.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ProfileDark.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/ProfileDark.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ProfileIcon.js +15 -0
- package/dist/components/uikit-sdk/Svg/Icons/ProfileIcon.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ProfileLight.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/ProfileLight.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Question.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Question.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/QuestionCircle.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/QuestionCircle.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/QuestionFill.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/QuestionFill.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Quiz.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Quiz.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Receipt.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Receipt.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Reddit.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Reddit.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Rocket.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Rocket.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ScrollTop.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/ScrollTop.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Search.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Search.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Send.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Send.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Settings.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Settings.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Share.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Share.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Sort.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Sort.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Star.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Star.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/StarFilled.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/StarFilled.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Success.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Success.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/SuccessOutline.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/SuccessOutline.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/SwapArrows.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/SwapArrows.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/SwitchArrows.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/SwitchArrows.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Tag.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Tag.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Telegram.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Telegram.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/TelegramNew.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/TelegramNew.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/TextLogo.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/TextLogo.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Tick.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Tick.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/TickShield.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/TickShield.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Timer.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Timer.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Trade.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Trade.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Trash.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Trash.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Twitter.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Twitter.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/URL.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/URL.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Vaults.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Vaults.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Verified.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/Verified.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Wallet.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Wallet.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Warning.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Warning.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Watch.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Watch.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/Website.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/Website.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/WebsiteNew.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/WebsiteNew.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/WhitepaperNew.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/WhitepaperNew.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/XNew.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/XNew.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/YellowQuestionMark.js +8 -0
- package/dist/components/uikit-sdk/Svg/Icons/YellowQuestionMark.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ZapArrow.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/ZapArrow.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/ZapIcon.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/ZapIcon.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/Icons/polygonNew.js +18 -0
- package/dist/components/uikit-sdk/Svg/Icons/polygonNew.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/index.js +515 -0
- package/dist/components/uikit-sdk/Svg/index.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/styles.js +14 -0
- package/dist/components/uikit-sdk/Svg/styles.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/ABOND.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/ABOND.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/ARBITRUM.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/ARBITRUM.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/AVAX.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/AVAX.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/BANANA.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/BANANA.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/BASE.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/BASE.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/BERA.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/BERA.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/BLAST.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/BLAST.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/BNB.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/BNB.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/BSC.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/BSC.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/CELO.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/CELO.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/CRONOS.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/CRONOS.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/CROSSFI.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/CROSSFI.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/ETH.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/ETH.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/FANTOM.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/FANTOM.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/GNANA.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/GNANA.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/GNOSIS.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/GNOSIS.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/GraphLinq.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/GraphLinq.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/INEVM.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/INEVM.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/IOTA.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/IOTA.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/KATANA.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/KATANA.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/LIGHTLINK.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/LIGHTLINK.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/LINEA.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/LINEA.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/MONAD.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/MONAD.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/OKX.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/OKX.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/OPTIMISM.js +10 -0
- package/dist/components/uikit-sdk/Svg/tokens/OPTIMISM.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/POLYGON.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/POLYGON.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/POLYGONZK.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/POLYGONZK.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/SONIC.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/SONIC.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/TLOS.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/TLOS.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/tokens/UNICHAIN.js +8 -0
- package/dist/components/uikit-sdk/Svg/tokens/UNICHAIN.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/types.js +183 -0
- package/dist/components/uikit-sdk/Svg/types.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/BinanceChain.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/BinanceChain.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Bitkeep.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Bitkeep.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Brave.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Brave.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Coinbase.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Coinbase.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/MadWallet.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/MadWallet.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/MathWallet.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/MathWallet.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Metamask.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Metamask.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Nabox.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Nabox.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/OKX.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/OKX.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/OntoWallet.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/OntoWallet.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/SafePalWallet.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/SafePalWallet.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/SocialLogin.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/SocialLogin.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/TokenPocket.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/TokenPocket.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/TorusWallet.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/TorusWallet.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/TrustWallet.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/TrustWallet.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Unstoppable.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/Unstoppable.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/WalletConnect.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/WalletConnect.js.map +1 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/WalletImage.js +8 -0
- package/dist/components/uikit-sdk/Svg/walletIcons/WalletImage.js.map +1 -0
- package/dist/components/uikit-sdk/SwiperDots/index.js +16 -0
- package/dist/components/uikit-sdk/SwiperDots/index.js.map +1 -0
- package/dist/components/uikit-sdk/Tag/ListTag.js +18 -0
- package/dist/components/uikit-sdk/Tag/ListTag.js.map +1 -0
- package/dist/components/uikit-sdk/Text/index.js +15 -0
- package/dist/components/uikit-sdk/Text/index.js.map +1 -0
- package/dist/components/uikit-sdk/Text/types.js +16 -0
- package/dist/components/uikit-sdk/Text/types.js.map +1 -0
- package/dist/components/uikit-sdk/Toggle/index.js +18 -0
- package/dist/components/uikit-sdk/Toggle/index.js.map +1 -0
- package/dist/components/uikit-sdk/Toggle/styles.js +22 -0
- package/dist/components/uikit-sdk/Toggle/styles.js.map +1 -0
- package/dist/components/uikit-sdk/TokenImage/index.js +57 -0
- package/dist/components/uikit-sdk/TokenImage/index.js.map +1 -0
- package/dist/components/uikit-sdk/TooltipBubble/index.js +65 -0
- package/dist/components/uikit-sdk/TooltipBubble/index.js.map +1 -0
- package/dist/components/uikit-sdk/TooltipBubble/styles.js +108 -0
- package/dist/components/uikit-sdk/TooltipBubble/styles.js.map +1 -0
- package/dist/components/uikit-sdk/TooltipBubble/types.js +12 -0
- package/dist/components/uikit-sdk/TooltipBubble/types.js.map +1 -0
- package/dist/config/abi/BOND_2_0_0.json.js +1065 -0
- package/dist/config/abi/BOND_2_0_0.json.js.map +1 -0
- package/dist/config/abi/BOND_2_4_0.json.js +2409 -0
- package/dist/config/abi/BOND_2_4_0.json.js.map +1 -0
- package/dist/config/abi/bondNft.json.js +959 -0
- package/dist/config/abi/bondNft.json.js.map +1 -0
- package/dist/config/abi/deposit.json.js +29 -0
- package/dist/config/abi/deposit.json.js.map +1 -0
- package/dist/config/abi/depositSig.json.js +39 -0
- package/dist/config/abi/depositSig.json.js.map +1 -0
- package/dist/config/abi/erc20.json.js +229 -0
- package/dist/config/abi/erc20.json.js.map +1 -0
- package/dist/config/abi/launchBond_v2_4_1.json.js +2358 -0
- package/dist/config/abi/launchBond_v2_4_1.json.js.map +1 -0
- package/dist/config/abi/lensContract.json.js +338 -0
- package/dist/config/abi/lensContract.json.js.map +1 -0
- package/dist/config/abi/multicallv2.json.js +151 -0
- package/dist/config/abi/multicallv2.json.js.map +1 -0
- package/dist/config/abi/price-getter-v3.json.js +853 -0
- package/dist/config/abi/price-getter-v3.json.js.map +1 -0
- package/dist/config/abi/usdtETH.json.js +704 -0
- package/dist/config/abi/usdtETH.json.js.map +1 -0
- package/dist/config/constants/addresses.js +61 -0
- package/dist/config/constants/addresses.js.map +1 -0
- package/dist/config/constants/chains.js +101 -0
- package/dist/config/constants/chains.js.map +1 -0
- package/dist/config/constants/networks.js +50 -0
- package/dist/config/constants/networks.js.map +1 -0
- package/dist/config/constants/queryKeys.js +28 -0
- package/dist/config/constants/queryKeys.js.map +1 -0
- package/dist/config/constants/tokens.js +669 -0
- package/dist/config/constants/tokens.js.map +1 -0
- package/dist/config/constants/tooltips.js +21 -0
- package/dist/config/constants/tooltips.js.map +1 -0
- package/dist/config/constants/variables.js +21 -0
- package/dist/config/constants/variables.js.map +1 -0
- package/dist/contexts/ModalContext.js +70 -0
- package/dist/contexts/ModalContext.js.map +1 -0
- package/dist/contexts/Popups.js +28 -0
- package/dist/contexts/Popups.js.map +1 -0
- package/dist/contexts/SwiperProvider.js +21 -0
- package/dist/contexts/SwiperProvider.js.map +1 -0
- package/dist/hooks/useDebounce.js +21 -0
- package/dist/hooks/useDebounce.js.map +1 -0
- package/dist/hooks/useIsMobile.js +22 -0
- package/dist/hooks/useIsMobile.js.map +1 -0
- package/dist/hooks/useModal.js +34 -0
- package/dist/hooks/useModal.js.map +1 -0
- package/dist/hooks/useMonitorTxHash.d.ts +1 -0
- package/dist/hooks/useMonitorTxHash.js +26 -0
- package/dist/hooks/useMonitorTxHash.js.map +1 -0
- package/dist/hooks/useSendReferenceId.js +22 -0
- package/dist/hooks/useSendReferenceId.js.map +1 -0
- package/dist/hooks/useSortedZapList.js +44 -0
- package/dist/hooks/useSortedZapList.js.map +1 -0
- package/dist/hooks/useSwiper.js +13 -0
- package/dist/hooks/useSwiper.js.map +1 -0
- package/dist/hooks/useTokenFromZapList.js +13 -0
- package/dist/hooks/useTokenFromZapList.js.map +1 -0
- package/dist/hooks/useTopTags.js +38 -0
- package/dist/hooks/useTopTags.js.map +1 -0
- package/dist/main.d.ts +1 -4
- package/dist/main.js +6 -98175
- package/dist/main.js.map +1 -0
- package/dist/providers/index.js +62 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/state/abtesting/useCookie.js +40 -0
- package/dist/state/abtesting/useCookie.js.map +1 -0
- package/dist/state/activeView/index.js +39 -0
- package/dist/state/activeView/index.js.map +1 -0
- package/dist/state/allowance/useAllowance.js +136 -0
- package/dist/state/allowance/useAllowance.js.map +1 -0
- package/dist/state/balance/useCurrencyBalance.js +39 -0
- package/dist/state/balance/useCurrencyBalance.js.map +1 -0
- package/dist/state/balance/useUserTokensBalance.js +79 -0
- package/dist/state/balance/useUserTokensBalance.js.map +1 -0
- package/dist/state/bondApiStats/useUserApiStats.js +25 -0
- package/dist/state/bondApiStats/useUserApiStats.js.map +1 -0
- package/dist/state/bonds/useBondNFTData.js +35 -0
- package/dist/state/bonds/useBondNFTData.js.map +1 -0
- package/dist/state/bonds/useBondsData.js +204 -0
- package/dist/state/bonds/useBondsData.js.map +1 -0
- package/dist/state/bonds/useBondsList.js +34 -0
- package/dist/state/bonds/useBondsList.js.map +1 -0
- package/dist/state/bonds/useGetBondRecommendations.js +23 -0
- package/dist/state/bonds/useGetBondRecommendations.js.map +1 -0
- package/dist/state/bonds/useHotBonds.js +51 -0
- package/dist/state/bonds/useHotBonds.js.map +1 -0
- package/dist/state/bonds/useTierProofSignature.js +45 -0
- package/dist/state/bonds/useTierProofSignature.js.map +1 -0
- package/dist/state/bonds/useUserBonds.js +70 -0
- package/dist/state/bonds/useUserBonds.js.map +1 -0
- package/dist/state/bonds/utils.js +105 -0
- package/dist/state/bonds/utils.js.map +1 -0
- package/dist/state/chainFilterOption/useChainFilterOption.js +34 -0
- package/dist/state/chainFilterOption/useChainFilterOption.js.map +1 -0
- package/dist/state/favoriteTokens/useFavoriteTokens.js +49 -0
- package/dist/state/favoriteTokens/useFavoriteTokens.js.map +1 -0
- package/dist/state/popups/usePopups.js +57 -0
- package/dist/state/popups/usePopups.js.map +1 -0
- package/dist/state/preTGEBonds/usePreTGEList.js +35 -0
- package/dist/state/preTGEBonds/usePreTGEList.js.map +1 -0
- package/dist/state/preTGEBonds/usePreTGEUserBonds.js +140 -0
- package/dist/state/preTGEBonds/usePreTGEUserBonds.js.map +1 -0
- package/dist/state/price/useCurrencyPrice.js +17 -0
- package/dist/state/price/useCurrencyPrice.js.map +1 -0
- package/dist/state/slippage/useSlippage.js +22 -0
- package/dist/state/slippage/useSlippage.js.map +1 -0
- package/dist/state/tiers/useTierPoints.js +110 -0
- package/dist/state/tiers/useTierPoints.js.map +1 -0
- package/dist/state/tokenPrices/useTokenPrices.js +183 -0
- package/dist/state/tokenPrices/useTokenPrices.js.map +1 -0
- package/dist/state/useSDKConfig.js +49 -0
- package/dist/state/useSDKConfig.js.map +1 -0
- package/dist/state/zap/getChainParam.js +54 -0
- package/dist/state/zap/getChainParam.js.map +1 -0
- package/dist/state/zap/useSoulZapBondQuote.js +148 -0
- package/dist/state/zap/useSoulZapBondQuote.js.map +1 -0
- package/dist/state/zap/useSoulZapTokenQuote.js +124 -0
- package/dist/state/zap/useSoulZapTokenQuote.js.map +1 -0
- package/dist/theme/base.js +125 -0
- package/dist/theme/base.js.map +1 -0
- package/dist/theme/colors.js +25 -0
- package/dist/theme/colors.js.map +1 -0
- package/dist/theme/components.js +365 -0
- package/dist/theme/components.js.map +1 -0
- package/dist/theme/index.js +12 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/utils/convertToTokenValue.js +27 -0
- package/dist/utils/convertToTokenValue.js.map +1 -0
- package/dist/utils/displayHelpers.js +168 -0
- package/dist/utils/displayHelpers.js.map +1 -0
- package/dist/utils/formatNumber.js +53 -0
- package/dist/utils/formatNumber.js.map +1 -0
- package/dist/utils/formatNumbers.js +66 -0
- package/dist/utils/formatNumbers.js.map +1 -0
- package/dist/utils/getBalanceNumber.js +11 -0
- package/dist/utils/getBalanceNumber.js.map +1 -0
- package/dist/utils/getDotPos.js +12 -0
- package/dist/utils/getDotPos.js.map +1 -0
- package/dist/utils/getNativeTicker.js +19 -0
- package/dist/utils/getNativeTicker.js.map +1 -0
- package/dist/utils/getTimePeriods.js +46 -0
- package/dist/utils/getTimePeriods.js.map +1 -0
- package/dist/utils/index.js +16 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/multicall.js +41 -0
- package/dist/utils/multicall.js.map +1 -0
- package/dist/utils/numbers.js +9 -0
- package/dist/utils/numbers.js.map +1 -0
- package/dist/utils/remove0xPrefix.js +9 -0
- package/dist/utils/remove0xPrefix.js.map +1 -0
- package/dist/utils/reportError.js +31 -0
- package/dist/utils/reportError.js.map +1 -0
- package/dist/utils/roundNumber.js +16 -0
- package/dist/utils/roundNumber.js.map +1 -0
- package/dist/utils/track.js +6 -0
- package/dist/utils/track.js.map +1 -0
- package/dist/views/Bonds/Bonds.js +145 -0
- package/dist/views/Bonds/Bonds.js.map +1 -0
- package/dist/views/Bonds/components/BannerTestnet/BannerTestnet.js +48 -0
- package/dist/views/Bonds/components/BannerTestnet/BannerTestnet.js.map +1 -0
- package/dist/views/Bonds/components/BondRows/BondRow.js +65 -0
- package/dist/views/Bonds/components/BondRows/BondRow.js.map +1 -0
- package/dist/views/Bonds/components/BondRows/BondRowsByChain.js +24 -0
- package/dist/views/Bonds/components/BondRows/BondRowsByChain.js.map +1 -0
- package/dist/views/Bonds/components/BondRows/BondRowsWithTitle.js +57 -0
- package/dist/views/Bonds/components/BondRows/BondRowsWithTitle.js.map +1 -0
- package/dist/views/Bonds/components/BondRows/ChainTitle.js +37 -0
- package/dist/views/Bonds/components/BondRows/ChainTitle.js.map +1 -0
- package/dist/views/Bonds/components/BondRows/ModalHandler.js +57 -0
- package/dist/views/Bonds/components/BondRows/ModalHandler.js.map +1 -0
- package/dist/views/Bonds/components/BondsMenu/BondsMenu.js +35 -0
- package/dist/views/Bonds/components/BondsMenu/BondsMenu.js.map +1 -0
- package/dist/views/Bonds/components/BonusComponents/BonusComponent.js +58 -0
- package/dist/views/Bonds/components/BonusComponents/BonusComponent.js.map +1 -0
- package/dist/views/Bonds/components/BonusComponents/BonusContainer.js +11 -0
- package/dist/views/Bonds/components/BonusComponents/BonusContainer.js.map +1 -0
- package/dist/views/Bonds/components/BonusComponents/BonusTable.js +53 -0
- package/dist/views/Bonds/components/BonusComponents/BonusTable.js.map +1 -0
- package/dist/views/Bonds/components/BuyAgainRow/index.js +93 -0
- package/dist/views/Bonds/components/BuyAgainRow/index.js.map +1 -0
- package/dist/views/Bonds/components/CheckURL/index.js +43 -0
- package/dist/views/Bonds/components/CheckURL/index.js.map +1 -0
- package/dist/views/Bonds/components/HotBondCards/HotBondCard.js +49 -0
- package/dist/views/Bonds/components/HotBondCards/HotBondCard.js.map +1 -0
- package/dist/views/Bonds/components/HotBondCards/index.d.ts +1 -1
- package/dist/views/Bonds/components/HotBondCards/index.js +72 -0
- package/dist/views/Bonds/components/HotBondCards/index.js.map +1 -0
- package/dist/views/Bonds/components/HotBondCards/styles.js +47 -0
- package/dist/views/Bonds/components/HotBondCards/styles.js.map +1 -0
- package/dist/views/Bonds/components/RecommendationCards/SmallRecommendationCard.js +26 -0
- package/dist/views/Bonds/components/RecommendationCards/SmallRecommendationCard.js.map +1 -0
- package/dist/views/Bonds/components/RecommendationCards/index.js +79 -0
- package/dist/views/Bonds/components/RecommendationCards/index.js.map +1 -0
- package/dist/views/Bonds/components/RecommendationCards/styles.js +24 -0
- package/dist/views/Bonds/components/RecommendationCards/styles.js.map +1 -0
- package/dist/views/Bonds/index.js +12 -0
- package/dist/views/Bonds/index.js.map +1 -0
- package/dist/views/Bonds/utils.js +124 -0
- package/dist/views/Bonds/utils.js.map +1 -0
- package/dist/views/BuyBond/BuyBond.js +352 -0
- package/dist/views/BuyBond/BuyBond.js.map +1 -0
- package/dist/views/BuyBond/BuyBondModal.js +23 -0
- package/dist/views/BuyBond/BuyBondModal.js.map +1 -0
- package/dist/views/BuyBond/components/BondCards.js +80 -0
- package/dist/views/BuyBond/components/BondCards.js.map +1 -0
- package/dist/views/BuyBond/components/BondModalHeader.js +80 -0
- package/dist/views/BuyBond/components/BondModalHeader.js.map +1 -0
- package/dist/views/BuyBond/components/BondModalMinTierHeader.js +32 -0
- package/dist/views/BuyBond/components/BondModalMinTierHeader.js.map +1 -0
- package/dist/views/BuyBond/components/Estimations.js +59 -0
- package/dist/views/BuyBond/components/Estimations.js.map +1 -0
- package/dist/views/BuyBond/components/ExpandedViewButton.js +36 -0
- package/dist/views/BuyBond/components/ExpandedViewButton.js.map +1 -0
- package/dist/views/BuyBond/components/GetUpToComponent/GetUpToComponent.js +63 -0
- package/dist/views/BuyBond/components/GetUpToComponent/GetUpToComponent.js.map +1 -0
- package/dist/views/BuyBond/components/NewRateModal/NewRateModal.js +53 -0
- package/dist/views/BuyBond/components/NewRateModal/NewRateModal.js.map +1 -0
- package/dist/views/BuyBond/components/NoBonusModal/NoBonusModal.js +35 -0
- package/dist/views/BuyBond/components/NoBonusModal/NoBonusModal.js.map +1 -0
- package/dist/views/BuyBond/components/ProjectDescription.js +37 -0
- package/dist/views/BuyBond/components/ProjectDescription.js.map +1 -0
- package/dist/views/BuyBond/findHighestTrueBondPrice.js +51 -0
- package/dist/views/BuyBond/findHighestTrueBondPrice.js.map +1 -0
- package/dist/views/BuyBond/index.js +12 -0
- package/dist/views/BuyBond/index.js.map +1 -0
- package/dist/views/FullBondsView/FullBondsView.js +31 -0
- package/dist/views/FullBondsView/FullBondsView.js.map +1 -0
- package/dist/views/FullBondsView/index.js +12 -0
- package/dist/views/FullBondsView/index.js.map +1 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/BondCards.js +71 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/BondCards.js.map +1 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/ParticipationSuccessful.js +76 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/ParticipationSuccessful.js.map +1 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/PreTGEBuyComponent.js +144 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/PreTGEBuyComponent.js.map +1 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/PreTGEModalHandler.js +36 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/PreTGEModalHandler.js.map +1 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/styles.js +42 -0
- package/dist/views/PreTGEBonds/components/BuyComponent/styles.js.map +1 -0
- package/dist/views/PreTGEBonds/components/PreTGEUserRows/PreTGEActions.js +115 -0
- package/dist/views/PreTGEBonds/components/PreTGEUserRows/PreTGEActions.js.map +1 -0
- package/dist/views/PreTGEBonds/components/PreTGEUserRows/PreTGEUserRow.js +50 -0
- package/dist/views/PreTGEBonds/components/PreTGEUserRows/PreTGEUserRow.js.map +1 -0
- package/dist/views/TransactionModal/TransactionModal.js +187 -0
- package/dist/views/TransactionModal/TransactionModal.js.map +1 -0
- package/dist/views/YourBonds/YourBonds.js +128 -0
- package/dist/views/YourBonds/YourBonds.js.map +1 -0
- package/dist/views/YourBonds/components/ClaimAll/ClaimAllModal.js +131 -0
- package/dist/views/YourBonds/components/ClaimAll/ClaimAllModal.js.map +1 -0
- package/dist/views/YourBonds/components/ClaimAll/index.js +35 -0
- package/dist/views/YourBonds/components/ClaimAll/index.js.map +1 -0
- package/dist/views/YourBonds/components/UserBondRow/index.js +109 -0
- package/dist/views/YourBonds/components/UserBondRow/index.js.map +1 -0
- package/dist/views/YourBonds/components/YourBondsMenu/YourBondsMenu.js +28 -0
- package/dist/views/YourBonds/components/YourBondsMenu/YourBondsMenu.js.map +1 -0
- package/dist/views/YourBonds/fetchBillsUser.js +110 -0
- package/dist/views/YourBonds/fetchBillsUser.js.map +1 -0
- package/dist/views/YourBonds/getBillNftData.js +55 -0
- package/dist/views/YourBonds/getBillNftData.js.map +1 -0
- package/dist/views/YourBonds/index.js +12 -0
- package/dist/views/YourBonds/index.js.map +1 -0
- package/dist/views/YourBondsModal/YourBondsModal.js +183 -0
- package/dist/views/YourBondsModal/YourBondsModal.js.map +1 -0
- package/dist/views/YourBondsModal/components/Recommendations/CardRecommendation.js +55 -0
- package/dist/views/YourBondsModal/components/Recommendations/CardRecommendation.js.map +1 -0
- package/dist/views/YourBondsModal/components/Recommendations/CardRecommendationsMobile.js +57 -0
- package/dist/views/YourBondsModal/components/Recommendations/CardRecommendationsMobile.js.map +1 -0
- package/dist/views/YourBondsModal/components/Recommendations/Recommendations.js +52 -0
- package/dist/views/YourBondsModal/components/Recommendations/Recommendations.js.map +1 -0
- package/dist/views/YourBondsModal/components/TransferBondModal/TransferAction.js +84 -0
- package/dist/views/YourBondsModal/components/TransferBondModal/TransferAction.js.map +1 -0
- package/dist/views/YourBondsModal/components/TransferBondModal/index.js +39 -0
- package/dist/views/YourBondsModal/components/TransferBondModal/index.js.map +1 -0
- package/dist/views/ZapModal/index.js +155 -0
- package/dist/views/ZapModal/index.js.map +1 -0
- package/package.json +11 -9
- package/dist/assets/output-2LTDuc8n.css +0 -174
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import BigNumber from 'bignumber.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Finds the highest TrueBondPrices element where userPoints is higher than points in the array.
|
|
5
|
+
* @param userPoints - The user's points as a string representing a BigNumber.
|
|
6
|
+
* @param bondData - Bond Data containing an array of TrueBondPrices to analyze.
|
|
7
|
+
* @returns The highest TrueBondPrices element where userPoints is higher than the item's points, or `undefined` if none matches.
|
|
8
|
+
*/
|
|
9
|
+
const findHighestTrueBondPrice = (userPoints, bondData) => {
|
|
10
|
+
if (!userPoints || !bondData || !bondData.trueBondPrices)
|
|
11
|
+
return undefined;
|
|
12
|
+
const userPointsBigNumber = new BigNumber(userPoints);
|
|
13
|
+
// Filter higher discounts that the user can't access
|
|
14
|
+
const eligiblePrices = bondData.trueBondPrices.filter((price) => userPointsBigNumber.gte(new BigNumber(price.points)));
|
|
15
|
+
if (!eligiblePrices || eligiblePrices.length === 0)
|
|
16
|
+
return undefined;
|
|
17
|
+
// Find the highest points among the eligible prices
|
|
18
|
+
return eligiblePrices.reduce((highest, current) => {
|
|
19
|
+
const highestPoints = new BigNumber(highest.points);
|
|
20
|
+
const currentPoints = new BigNumber(current.points);
|
|
21
|
+
return currentPoints.isGreaterThan(highestPoints) ? current : highest;
|
|
22
|
+
});
|
|
23
|
+
};
|
|
24
|
+
const findHighestTrueBondPrices = (userPoints, trueBondPrices) => {
|
|
25
|
+
if (!userPoints || !trueBondPrices)
|
|
26
|
+
return undefined;
|
|
27
|
+
const userPointsBigNumber = new BigNumber(userPoints);
|
|
28
|
+
// Filter higher discounts that the user can't access
|
|
29
|
+
const eligiblePrices = trueBondPrices.filter((price) => userPointsBigNumber.gte(new BigNumber(price.points)));
|
|
30
|
+
if (!eligiblePrices || eligiblePrices.length === 0)
|
|
31
|
+
return undefined;
|
|
32
|
+
// Find the highest points among the eligible prices
|
|
33
|
+
return eligiblePrices.reduce((highest, current) => {
|
|
34
|
+
const highestPoints = new BigNumber(highest.points);
|
|
35
|
+
const currentPoints = new BigNumber(current.points);
|
|
36
|
+
return currentPoints.isGreaterThan(highestPoints) ? current : highest;
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
/**
|
|
40
|
+
* Finds the TrueBondPrices element with the highest points in the array, regardless of user points.
|
|
41
|
+
* @param bondData - Bond Data containing an array of TrueBondPrices to analyze.
|
|
42
|
+
* @returns The TrueBondPrices element with the highest points, or `undefined` if no data is available.
|
|
43
|
+
*/
|
|
44
|
+
const findHighestTrueBondPriceUserAgnostic = (bondData) => {
|
|
45
|
+
if (!bondData?.trueBondPrices?.length)
|
|
46
|
+
return undefined;
|
|
47
|
+
return bondData.trueBondPrices.reduce((highest, current) => new BigNumber(current.points).isGreaterThan(new BigNumber(highest.points)) ? current : highest);
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
export { findHighestTrueBondPrice, findHighestTrueBondPriceUserAgnostic, findHighestTrueBondPrices };
|
|
51
|
+
//# sourceMappingURL=findHighestTrueBondPrice.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"findHighestTrueBondPrice.js","sources":["../../../src/views/BuyBond/findHighestTrueBondPrice.ts"],"sourcesContent":["import BigNumber from 'bignumber.js'\nimport { BondsData, TrueBondPrices } from '../../types/bonds' // Assuming the TrueBondPrices array comes from here\n\n/**\n * Finds the highest TrueBondPrices element where userPoints is higher than points in the array.\n * @param userPoints - The user's points as a string representing a BigNumber.\n * @param bondData - Bond Data containing an array of TrueBondPrices to analyze.\n * @returns The highest TrueBondPrices element where userPoints is higher than the item's points, or `undefined` if none matches.\n */\nexport const findHighestTrueBondPrice = (\n userPoints?: string | null,\n bondData?: BondsData,\n): TrueBondPrices | undefined => {\n if (!userPoints || !bondData || !bondData.trueBondPrices) return undefined\n\n const userPointsBigNumber = new BigNumber(userPoints)\n\n // Filter higher discounts that the user can't access\n const eligiblePrices = bondData.trueBondPrices.filter((price) => userPointsBigNumber.gte(new BigNumber(price.points)))\n if (!eligiblePrices || eligiblePrices.length === 0) return undefined\n\n // Find the highest points among the eligible prices\n return eligiblePrices.reduce((highest, current) => {\n const highestPoints = new BigNumber(highest.points)\n const currentPoints = new BigNumber(current.points)\n\n return currentPoints.isGreaterThan(highestPoints) ? current : highest\n })\n}\nexport const findHighestTrueBondPrices = (\n userPoints?: string | null,\n trueBondPrices?: TrueBondPrices[],\n): TrueBondPrices | undefined => {\n if (!userPoints || !trueBondPrices) return undefined\n\n const userPointsBigNumber = new BigNumber(userPoints)\n\n // Filter higher discounts that the user can't access\n const eligiblePrices = trueBondPrices.filter((price) => userPointsBigNumber.gte(new BigNumber(price.points)))\n if (!eligiblePrices || eligiblePrices.length === 0) return undefined\n\n // Find the highest points among the eligible prices\n return eligiblePrices.reduce((highest, current) => {\n const highestPoints = new BigNumber(highest.points)\n const currentPoints = new BigNumber(current.points)\n\n return currentPoints.isGreaterThan(highestPoints) ? current : highest\n })\n}\n\n/**\n * Finds the TrueBondPrices element with the highest points in the array, regardless of user points.\n * @param bondData - Bond Data containing an array of TrueBondPrices to analyze.\n * @returns The TrueBondPrices element with the highest points, or `undefined` if no data is available.\n */\nexport const findHighestTrueBondPriceUserAgnostic = (bondData?: BondsData): TrueBondPrices | undefined => {\n if (!bondData?.trueBondPrices?.length) return undefined\n\n return bondData.trueBondPrices.reduce((highest, current) =>\n new BigNumber(current.points).isGreaterThan(new BigNumber(highest.points)) ? current : highest,\n )\n}\n"],"names":[],"mappings":";;AAGA;;;;;AAKG;MACU,wBAAwB,GAAG,CACtC,UAA0B,EAC1B,QAAoB,KACU;IAC9B,IAAI,CAAC,UAAU,IAAI,CAAC,QAAQ,IAAI,CAAC,QAAQ,CAAC,cAAc;AAAE,QAAA,OAAO,SAAS;AAE1E,IAAA,MAAM,mBAAmB,GAAG,IAAI,SAAS,CAAC,UAAU,CAAC;;IAGrD,MAAM,cAAc,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,mBAAmB,CAAC,GAAG,CAAC,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;AACtH,IAAA,IAAI,CAAC,cAAc,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC;AAAE,QAAA,OAAO,SAAS;;IAGpE,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,OAAO,KAAI;QAChD,MAAM,aAAa,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC;QACnD,MAAM,aAAa,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC;AAEnD,QAAA,OAAO,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,GAAG,OAAO,GAAG,OAAO;AACvE,IAAA,CAAC,CAAC;AACJ;MACa,yBAAyB,GAAG,CACvC,UAA0B,EAC1B,cAAiC,KACH;AAC9B,IAAA,IAAI,CAAC,UAAU,IAAI,CAAC,cAAc;AAAE,QAAA,OAAO,SAAS;AAEpD,IAAA,MAAM,mBAAmB,GAAG,IAAI,SAAS,CAAC,UAAU,CAAC;;IAGrD,MAAM,cAAc,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,KAAK,KAAK,mBAAmB,CAAC,GAAG,CAAC,IAAI,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;AAC7G,IAAA,IAAI,CAAC,cAAc,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC;AAAE,QAAA,OAAO,SAAS;;IAGpE,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,OAAO,KAAI;QAChD,MAAM,aAAa,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC;QACnD,MAAM,aAAa,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC;AAEnD,QAAA,OAAO,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,GAAG,OAAO,GAAG,OAAO;AACvE,IAAA,CAAC,CAAC;AACJ;AAEA;;;;AAIG;AACI,MAAM,oCAAoC,GAAG,CAAC,QAAoB,KAAgC;AACvG,IAAA,IAAI,CAAC,QAAQ,EAAE,cAAc,EAAE,MAAM;AAAE,QAAA,OAAO,SAAS;AAEvD,IAAA,OAAO,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,OAAO,EAAE,OAAO,KACrD,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,OAAO,GAAG,OAAO,CAC/F;AACH;;;;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx } from 'theme-ui/jsx-runtime';
|
|
2
|
+
import Providers from '../../providers/index.js';
|
|
3
|
+
import { useSDKConfig } from '../../state/useSDKConfig.js';
|
|
4
|
+
import BuyBondModal from './BuyBondModal.js';
|
|
5
|
+
|
|
6
|
+
const BuyBondModalWithProviders = (props) => {
|
|
7
|
+
useSDKConfig(props);
|
|
8
|
+
return (jsx(Providers, { theme: props.theme, children: jsx(BuyBondModal, { ...props }) }));
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export { BuyBondModalWithProviders as default };
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/views/BuyBond/index.tsx"],"sourcesContent":["import React from 'react'\nimport Providers from '../../providers'\nimport { BuyBondProps } from './BuyBond'\nimport { SDKProps, useSDKConfig } from '../../state/useSDKConfig'\nimport BuyBondModal from './BuyBondModal'\n\ninterface Props extends SDKProps, BuyBondProps {}\n\nconst BuyBondModalWithProviders: React.FC<Props> = (props) => {\n useSDKConfig(props)\n\n return (\n <Providers theme={props.theme}>\n <BuyBondModal {...props} />\n </Providers>\n )\n}\n\nexport default BuyBondModalWithProviders\n"],"names":["_jsx"],"mappings":";;;;;AAQA,MAAM,yBAAyB,GAAoB,CAAC,KAAK,KAAI;IAC3D,YAAY,CAAC,KAAK,CAAC;AAEnB,IAAA,QACEA,GAAA,CAAC,SAAS,EAAA,EAAC,KAAK,EAAE,KAAK,CAAC,KAAK,EAAA,QAAA,EAC3BA,IAAC,YAAY,EAAA,EAAA,GAAK,KAAK,EAAA,CAAI,EAAA,CACjB;AAEhB;;;;"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'theme-ui/jsx-runtime';
|
|
2
|
+
import '../../components/uikit-sdk/Svg/types.js';
|
|
3
|
+
import 'theme-ui';
|
|
4
|
+
import Flex from '../../components/uikit-sdk/Flex/index.js';
|
|
5
|
+
import '../../components/uikit-sdk/Text/types.js';
|
|
6
|
+
import '../../components/uikit-sdk/Checkbox/types.js';
|
|
7
|
+
import '../../components/uikit-sdk/Skeleton/types.js';
|
|
8
|
+
import '../../components/uikit-sdk/Skeleton/styles.js';
|
|
9
|
+
import '../../components/uikit-sdk/TooltipBubble/index.js';
|
|
10
|
+
import 'react';
|
|
11
|
+
import 'framer-motion';
|
|
12
|
+
import '../../components/uikit-sdk/Button/types.js';
|
|
13
|
+
import '../../contexts/ModalContext.js';
|
|
14
|
+
import Toggle from '../../components/uikit-sdk/Toggle/index.js';
|
|
15
|
+
import '../../components/uikit-sdk/Select/types.js';
|
|
16
|
+
import YourBonds from '../YourBonds/YourBonds.js';
|
|
17
|
+
import Bonds from '../Bonds/Bonds.js';
|
|
18
|
+
import useActiveView from '../../state/activeView/index.js';
|
|
19
|
+
|
|
20
|
+
var BondsViewOptions;
|
|
21
|
+
(function (BondsViewOptions) {
|
|
22
|
+
BondsViewOptions["BONDSMARKET"] = "Bonds Market";
|
|
23
|
+
BondsViewOptions["YOURBONDS"] = "Your Bonds";
|
|
24
|
+
})(BondsViewOptions || (BondsViewOptions = {}));
|
|
25
|
+
const FullBondsView = () => {
|
|
26
|
+
const { activeView, handleToogle } = useActiveView();
|
|
27
|
+
return (jsxs("div", { className: "full-bonds-view-container", children: [jsx("div", { className: "toggle-container", children: jsx(Toggle, { options: [BondsViewOptions.BONDSMARKET, BondsViewOptions.YOURBONDS], activeOption: activeView, handleToggle: handleToogle }) }), jsx(Flex, { sx: { width: '100%' }, children: activeView === BondsViewOptions.BONDSMARKET ? jsx(Bonds, {}) : jsx(YourBonds, {}) })] }));
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
export { BondsViewOptions, FullBondsView as default };
|
|
31
|
+
//# sourceMappingURL=FullBondsView.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FullBondsView.js","sources":["../../../src/views/FullBondsView/FullBondsView.tsx"],"sourcesContent":["import React from 'react'\nimport { Flex, Toggle } from '../../components/uikit-sdk'\nimport YourBonds from '../YourBonds/YourBonds'\nimport Bonds from '../Bonds/Bonds'\nimport useActiveView from '../../state/activeView'\n\nexport enum BondsViewOptions {\n BONDSMARKET = 'Bonds Market',\n YOURBONDS = 'Your Bonds',\n}\n\nconst FullBondsView = () => {\n const { activeView, handleToogle } = useActiveView()\n\n return (\n <div className=\"full-bonds-view-container\">\n <div className=\"toggle-container\">\n <Toggle\n options={[BondsViewOptions.BONDSMARKET, BondsViewOptions.YOURBONDS]}\n activeOption={activeView}\n handleToggle={handleToogle}\n />\n </div>\n <Flex sx={{ width: '100%' }}>{activeView === BondsViewOptions.BONDSMARKET ? <Bonds /> : <YourBonds />}</Flex>\n </div>\n )\n}\n\nexport default FullBondsView\n"],"names":["_jsxs","_jsx"],"mappings":";;;;;;;;;;;;;;;;;;;IAMY;AAAZ,CAAA,UAAY,gBAAgB,EAAA;AAC1B,IAAA,gBAAA,CAAA,aAAA,CAAA,GAAA,cAA4B;AAC5B,IAAA,gBAAA,CAAA,WAAA,CAAA,GAAA,YAAwB;AAC1B,CAAC,EAHW,gBAAgB,KAAhB,gBAAgB,GAAA,EAAA,CAAA,CAAA;AAK5B,MAAM,aAAa,GAAG,MAAK;IACzB,MAAM,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,aAAa,EAAE;AAEpD,IAAA,QACEA,IAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,2BAA2B,EAAA,QAAA,EAAA,CACxCC,GAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAC,kBAAkB,EAAA,QAAA,EAC/BA,GAAA,CAAC,MAAM,EAAA,EACL,OAAO,EAAE,CAAC,gBAAgB,CAAC,WAAW,EAAE,gBAAgB,CAAC,SAAS,CAAC,EACnE,YAAY,EAAE,UAAU,EACxB,YAAY,EAAE,YAAY,EAAA,CAC1B,EAAA,CACE,EACNA,GAAA,CAAC,IAAI,EAAA,EAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,EAAA,QAAA,EAAG,UAAU,KAAK,gBAAgB,CAAC,WAAW,GAAGA,GAAA,CAAC,KAAK,KAAG,GAAGA,GAAA,CAAC,SAAS,EAAA,EAAA,CAAG,EAAA,CAAQ,CAAA,EAAA,CACzG;AAEV;;;;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx } from 'theme-ui/jsx-runtime';
|
|
2
|
+
import Providers from '../../providers/index.js';
|
|
3
|
+
import FullBondsView from './FullBondsView.js';
|
|
4
|
+
import { useSDKConfig } from '../../state/useSDKConfig.js';
|
|
5
|
+
|
|
6
|
+
const FullBondsViewWithProviders = (props) => {
|
|
7
|
+
useSDKConfig(props);
|
|
8
|
+
return (jsx(Providers, { theme: props?.theme, children: jsx(FullBondsView, {}) }));
|
|
9
|
+
};
|
|
10
|
+
|
|
11
|
+
export { FullBondsViewWithProviders as default };
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/views/FullBondsView/index.tsx"],"sourcesContent":["import React from 'react'\nimport Providers from '../../providers'\nimport FullBondsView from './FullBondsView'\nimport { SDKPropsDTO, useSDKConfig } from '../../state/useSDKConfig'\n\nconst FullBondsViewWithProviders: React.FC<SDKPropsDTO> = (props) => {\n useSDKConfig(props)\n return (\n <Providers theme={props?.theme}>\n <FullBondsView />\n </Providers>\n )\n}\n\nexport default FullBondsViewWithProviders\n"],"names":["_jsx"],"mappings":";;;;;AAKA,MAAM,0BAA0B,GAA0B,CAAC,KAAK,KAAI;IAClE,YAAY,CAAC,KAAK,CAAC;AACnB,IAAA,QACEA,GAAA,CAAC,SAAS,EAAA,EAAC,KAAK,EAAE,KAAK,EAAE,KAAK,YAC5BA,GAAA,CAAC,aAAa,EAAA,EAAA,CAAG,EAAA,CACP;AAEhB;;;;"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { jsxs, jsx, Fragment } from 'theme-ui/jsx-runtime';
|
|
2
|
+
import Svg from '../../../../components/uikit-sdk/Svg/index.js';
|
|
3
|
+
import Flex from '../../../../components/uikit-sdk/Flex/index.js';
|
|
4
|
+
import 'theme-ui';
|
|
5
|
+
import '../../../../components/uikit-sdk/Text/types.js';
|
|
6
|
+
import '../../../../components/uikit-sdk/Checkbox/types.js';
|
|
7
|
+
import '../../../../components/uikit-sdk/Skeleton/types.js';
|
|
8
|
+
import '../../../../components/uikit-sdk/Skeleton/styles.js';
|
|
9
|
+
import TooltipBubble from '../../../../components/uikit-sdk/TooltipBubble/index.js';
|
|
10
|
+
import 'react';
|
|
11
|
+
import 'framer-motion';
|
|
12
|
+
import '../../../../components/uikit-sdk/Button/types.js';
|
|
13
|
+
import '../../../../components/uikit-sdk/Svg/types.js';
|
|
14
|
+
import '../../../../contexts/ModalContext.js';
|
|
15
|
+
import '../../../FullBondsView/FullBondsView.js';
|
|
16
|
+
import '../../../../components/uikit-sdk/Select/types.js';
|
|
17
|
+
import getTimePeriods from '../../../../utils/getTimePeriods.js';
|
|
18
|
+
import { useIsMobile } from '../../../../hooks/useIsMobile.js';
|
|
19
|
+
|
|
20
|
+
const BondCards = ({ bond }) => {
|
|
21
|
+
const isMobile = useIsMobile();
|
|
22
|
+
const bonus = bond?.trueBondPrices?.[0].bonus ?? 0;
|
|
23
|
+
const airdropBonus = bond.airdropBonus ?? 0;
|
|
24
|
+
const bonusToUse = bonus + airdropBonus;
|
|
25
|
+
const initialRelease = (bond?.initialRelease ?? 0) * 100;
|
|
26
|
+
return (jsxs("div", { className: "bonds-cards", children: [jsxs("div", { className: "bond-card-block", sx: {
|
|
27
|
+
borderRadius: ['0px', '0px', '0px', 'normal'],
|
|
28
|
+
'&:first-of-type': {
|
|
29
|
+
borderTopRightRadius: 'normal',
|
|
30
|
+
borderTopLeftRadius: 'normal',
|
|
31
|
+
},
|
|
32
|
+
'&:last-of-type': {
|
|
33
|
+
borderBottomRightRadius: 'normal',
|
|
34
|
+
borderBottomLeftRadius: 'normal',
|
|
35
|
+
},
|
|
36
|
+
}, children: [jsxs(Flex, { className: "bond-card-title", sx: { alignItems: 'center' }, children: ["Bonus", jsx(TooltipBubble, { className: "tooltip-bubble", body: jsx(Flex, { children: "This is the percentage of additional tokens you\u2019ll get compared to buying at market price." }), width: "230px", placement: "bottomLeft", transformTip: "translate(-5%, -5%)", children: jsx("div", { className: "bond-card-tooltip", children: jsx(Svg, { icon: "questionCircle", width: "12px" }) }) })] }), jsxs(Flex, { sx: { color: 'success', alignItems: 'center' }, children: [bonusToUse?.toFixed(0), "%", bond.airdropTooltip && (jsx(TooltipBubble, { body: jsx(Fragment, { children: bond.airdropTooltip }), width: "230px", placement: isMobile ? 'bottomRight' : 'bottomLeft', transformTip: isMobile ? 'translate(9%, 6%)' : 'translate(-3%, 6%)', children: jsx(Flex, { sx: { width: '20px', height: '20px', alignItems: 'center', ml: '5px' }, children: jsx("img", { src: "https://res.cloudinary.com/dswmrqgwy/image/upload/v1750345773/airdrop_qvh4ow.png", alt: "airdrop-img", style: { width: '20px', height: '20px' } }) }) }))] })] }), jsxs("div", { className: "bond-card-block", sx: {
|
|
37
|
+
fontSize: '13px !important',
|
|
38
|
+
borderRadius: ['0px', '0px', '0px', 'normal'],
|
|
39
|
+
'&:first-of-type': {
|
|
40
|
+
borderTopRightRadius: 'normal',
|
|
41
|
+
borderTopLeftRadius: 'normal',
|
|
42
|
+
},
|
|
43
|
+
'&:last-of-type': {
|
|
44
|
+
borderBottomRightRadius: 'normal',
|
|
45
|
+
borderBottomLeftRadius: 'normal',
|
|
46
|
+
},
|
|
47
|
+
}, children: [jsxs(Flex, { className: "bond-card-title", children: ["TGE", jsx(TooltipBubble, { className: "tooltip-bubble", body: jsx(Flex, { children: "This is the date and time when this token will become officially live on-chain." }), width: "230px", placement: "bottomLeft", transformTip: "translate(-5%, -5%)", children: jsx("div", { className: "bond-card-tooltip", children: jsx(Svg, { icon: "questionCircle", width: "12px" }) }) })] }), bond.tgeString] }), jsxs("div", { className: "bond-card-block", sx: {
|
|
48
|
+
borderRadius: ['0px', '0px', '0px', 'normal'],
|
|
49
|
+
'&:first-of-type': {
|
|
50
|
+
borderTopRightRadius: 'normal',
|
|
51
|
+
borderTopLeftRadius: 'normal',
|
|
52
|
+
},
|
|
53
|
+
'&:last-of-type': {
|
|
54
|
+
borderBottomRightRadius: 'normal',
|
|
55
|
+
borderBottomLeftRadius: 'normal',
|
|
56
|
+
},
|
|
57
|
+
}, children: [jsxs("div", { className: "bond-card-title", children: ["Initial Release", jsx(TooltipBubble, { className: "tooltip-bubble", body: jsxs(Flex, { children: ["This is the percentage of tokens you can claim immediately on ", bond.tgeString, ". The rest follows the vesting schedule."] }), width: "230px", placement: "bottomLeft", transformTip: "translate(-5%, -5%)", children: jsx("div", { className: "bond-card-tooltip", children: jsx(Svg, { icon: "questionCircle", width: "12px" }) }) })] }), initialRelease, "%"] }), jsxs("div", { className: "bond-card-block", sx: {
|
|
58
|
+
borderRadius: ['0px', '0px', '0px', 'normal'],
|
|
59
|
+
'&:first-of-type': {
|
|
60
|
+
borderTopRightRadius: 'normal',
|
|
61
|
+
borderTopLeftRadius: 'normal',
|
|
62
|
+
},
|
|
63
|
+
'&:last-of-type': {
|
|
64
|
+
borderBottomRightRadius: 'normal',
|
|
65
|
+
borderBottomLeftRadius: 'normal',
|
|
66
|
+
},
|
|
67
|
+
}, children: [jsxs("div", { className: "bond-card-title", children: ["Vesting Terms", initialRelease !== 100 && (jsx(TooltipBubble, { className: "tooltip-bubble", body: jsxs(Flex, { children: ["Remaining tokens will vest linearly over ", getTimePeriods(bond?.vestingTerm ?? 0).months, " months after claiming the initial release."] }), width: "230px", placement: "bottomLeft", transformTip: "translate(-5%, -5%)", children: jsx("div", { className: "bond-card-tooltip", children: jsx(Svg, { icon: "questionCircle", width: "12px" }) }) }))] }), initialRelease === 100 ? `0 D` : `${getTimePeriods(bond?.vestingTerm ?? 0)?.months} Mo`] })] }));
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
export { BondCards as default };
|
|
71
|
+
//# sourceMappingURL=BondCards.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BondCards.js","sources":["../../../../../src/views/PreTGEBonds/components/BuyComponent/BondCards.tsx"],"sourcesContent":["import React from 'react'\nimport { Flex, Svg, TooltipBubble } from '../../../../components/uikit-sdk'\nimport getTimePeriods from '../../../../utils/getTimePeriods'\nimport { BondsData } from '../../../../types/bonds'\nimport { useIsMobile } from '../../../../hooks/useIsMobile'\n\nconst BondCards = ({ bond }: { bond: BondsData }) => {\n const isMobile = useIsMobile()\n const bonus = bond?.trueBondPrices?.[0].bonus ?? 0\n const airdropBonus = bond.airdropBonus ?? 0\n const bonusToUse = bonus + airdropBonus\n const initialRelease = (bond?.initialRelease ?? 0) * 100\n return (\n <div className=\"bonds-cards\">\n <div\n className=\"bond-card-block\"\n sx={{\n borderRadius: ['0px', '0px', '0px', 'normal'],\n '&:first-of-type': {\n borderTopRightRadius: 'normal',\n borderTopLeftRadius: 'normal',\n },\n\n '&:last-of-type': {\n borderBottomRightRadius: 'normal',\n borderBottomLeftRadius: 'normal',\n },\n }}\n >\n <Flex className=\"bond-card-title\" sx={{ alignItems: 'center' }}>\n Bonus\n <TooltipBubble\n className=\"tooltip-bubble\"\n body={\n <Flex>This is the percentage of additional tokens you’ll get compared to buying at market price.</Flex>\n }\n width=\"230px\"\n placement=\"bottomLeft\"\n transformTip=\"translate(-5%, -5%)\"\n >\n <div className=\"bond-card-tooltip\">\n <Svg icon=\"questionCircle\" width=\"12px\" />\n </div>\n </TooltipBubble>\n </Flex>\n <Flex sx={{ color: 'success', alignItems: 'center' }}>\n {bonusToUse?.toFixed(0)}%\n {bond.airdropTooltip && (\n <TooltipBubble\n body={<>{bond.airdropTooltip}</>}\n width=\"230px\"\n placement={isMobile ? 'bottomRight' : 'bottomLeft'}\n transformTip={isMobile ? 'translate(9%, 6%)' : 'translate(-3%, 6%)'}\n >\n <Flex sx={{ width: '20px', height: '20px', alignItems: 'center', ml: '5px' }}>\n <img\n src=\"https://res.cloudinary.com/dswmrqgwy/image/upload/v1750345773/airdrop_qvh4ow.png\"\n alt=\"airdrop-img\"\n style={{ width: '20px', height: '20px' }}\n />\n </Flex>\n </TooltipBubble>\n )}\n </Flex>\n </div>\n <div\n className=\"bond-card-block\"\n sx={{\n fontSize: '13px !important',\n borderRadius: ['0px', '0px', '0px', 'normal'],\n '&:first-of-type': {\n borderTopRightRadius: 'normal',\n borderTopLeftRadius: 'normal',\n },\n\n '&:last-of-type': {\n borderBottomRightRadius: 'normal',\n borderBottomLeftRadius: 'normal',\n },\n }}\n >\n <Flex className=\"bond-card-title\">\n TGE\n <TooltipBubble\n className=\"tooltip-bubble\"\n body={<Flex>This is the date and time when this token will become officially live on-chain.</Flex>}\n width=\"230px\"\n placement=\"bottomLeft\"\n transformTip=\"translate(-5%, -5%)\"\n >\n <div className=\"bond-card-tooltip\">\n <Svg icon=\"questionCircle\" width=\"12px\" />\n </div>\n </TooltipBubble>\n </Flex>\n {bond.tgeString}\n </div>\n <div\n className=\"bond-card-block\"\n sx={{\n borderRadius: ['0px', '0px', '0px', 'normal'],\n '&:first-of-type': {\n borderTopRightRadius: 'normal',\n borderTopLeftRadius: 'normal',\n },\n\n '&:last-of-type': {\n borderBottomRightRadius: 'normal',\n borderBottomLeftRadius: 'normal',\n },\n }}\n >\n <div className=\"bond-card-title\">\n Initial Release\n <TooltipBubble\n className=\"tooltip-bubble\"\n body={\n <Flex>\n This is the percentage of tokens you can claim immediately on {bond.tgeString}. The rest follows the\n vesting schedule.\n </Flex>\n }\n width=\"230px\"\n placement=\"bottomLeft\"\n transformTip=\"translate(-5%, -5%)\"\n >\n <div className=\"bond-card-tooltip\">\n <Svg icon=\"questionCircle\" width=\"12px\" />\n </div>\n </TooltipBubble>\n </div>\n {initialRelease}%\n </div>\n <div\n className=\"bond-card-block\"\n sx={{\n borderRadius: ['0px', '0px', '0px', 'normal'],\n '&:first-of-type': {\n borderTopRightRadius: 'normal',\n borderTopLeftRadius: 'normal',\n },\n\n '&:last-of-type': {\n borderBottomRightRadius: 'normal',\n borderBottomLeftRadius: 'normal',\n },\n }}\n >\n <div className=\"bond-card-title\">\n Vesting Terms\n {initialRelease !== 100 && (\n <TooltipBubble\n className=\"tooltip-bubble\"\n body={\n <Flex>\n Remaining tokens will vest linearly over {getTimePeriods(bond?.vestingTerm ?? 0).months} months after\n claiming the initial release.\n </Flex>\n }\n width=\"230px\"\n placement=\"bottomLeft\"\n transformTip=\"translate(-5%, -5%)\"\n >\n <div className=\"bond-card-tooltip\">\n <Svg icon=\"questionCircle\" width=\"12px\" />\n </div>\n </TooltipBubble>\n )}\n </div>\n {initialRelease === 100 ? `0 D` : `${getTimePeriods(bond?.vestingTerm ?? 0)?.months} Mo`}\n </div>\n </div>\n )\n}\n\nexport default BondCards\n"],"names":["_jsxs","_jsx","_Fragment"],"mappings":"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"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { jsxs, jsx } from 'theme-ui/jsx-runtime';
|
|
2
|
+
import useTokenPrices from '../../../../state/tokenPrices/useTokenPrices.js';
|
|
3
|
+
import Svg from '../../../../components/uikit-sdk/Svg/index.js';
|
|
4
|
+
import Flex from '../../../../components/uikit-sdk/Flex/index.js';
|
|
5
|
+
import Text from '../../../../components/uikit-sdk/Text/index.js';
|
|
6
|
+
import '../../../../components/uikit-sdk/Checkbox/types.js';
|
|
7
|
+
import 'theme-ui';
|
|
8
|
+
import '../../../../components/uikit-sdk/Skeleton/types.js';
|
|
9
|
+
import '../../../../components/uikit-sdk/Skeleton/styles.js';
|
|
10
|
+
import TooltipBubble from '../../../../components/uikit-sdk/TooltipBubble/index.js';
|
|
11
|
+
import Modal from '../../../../components/uikit-sdk/Modal/index.js';
|
|
12
|
+
import 'framer-motion';
|
|
13
|
+
import '../../../FullBondsView/FullBondsView.js';
|
|
14
|
+
import Button from '../../../../components/uikit-sdk/Button/Button.js';
|
|
15
|
+
import '../../../../components/uikit-sdk/Svg/types.js';
|
|
16
|
+
import '../../../../components/uikit-sdk/Button/types.js';
|
|
17
|
+
import 'react';
|
|
18
|
+
import '../../../../components/uikit-sdk/Select/types.js';
|
|
19
|
+
import ModalHeader from '../../../../components/uikit-sdk/Modal/ModalHeader.js';
|
|
20
|
+
import { getFirstNonZeroDigits } from '../../../../utils/roundNumber.js';
|
|
21
|
+
import getTimePeriods from '../../../../utils/getTimePeriods.js';
|
|
22
|
+
|
|
23
|
+
const ParticipationSuccessful = ({ onDismiss, bond, inputAmount, }) => {
|
|
24
|
+
const { data: tokenPrices } = useTokenPrices();
|
|
25
|
+
const principalTokenPrice = tokenPrices?.find((token) => token?.address?.toLowerCase() === bond?.lpToken?.address[bond?.chainId]?.toLowerCase())?.price;
|
|
26
|
+
const inputValue = parseFloat(inputAmount ?? '0');
|
|
27
|
+
const depositAmountUsd = inputValue * (principalTokenPrice ?? 0);
|
|
28
|
+
const initPrice = bond?.initPrice ?? 0;
|
|
29
|
+
const initialRelease = bond?.initialRelease ?? 0;
|
|
30
|
+
const userAllocation = depositAmountUsd / initPrice;
|
|
31
|
+
const userAllocationUsd = userAllocation * initPrice;
|
|
32
|
+
const finishTime = (bond?.redeemTime ?? 0) * 1000;
|
|
33
|
+
const finishDate = new Date(finishTime);
|
|
34
|
+
const month = finishDate.toLocaleDateString('en-US', { month: 'short' });
|
|
35
|
+
const getDayWithSuffix = (day) => {
|
|
36
|
+
if (day > 3 && day < 21)
|
|
37
|
+
return `${day}th`;
|
|
38
|
+
switch (day % 10) {
|
|
39
|
+
case 1:
|
|
40
|
+
return `${day}st`;
|
|
41
|
+
case 2:
|
|
42
|
+
return `${day}nd`;
|
|
43
|
+
case 3:
|
|
44
|
+
return `${day}rd`;
|
|
45
|
+
default:
|
|
46
|
+
return `${day}th`;
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
const day = finishDate.getDate();
|
|
50
|
+
const formattedFinishDate = `${month} ${getDayWithSuffix(day)} at 11 UTC.`;
|
|
51
|
+
const initialReleaseAmount = userAllocation * initialRelease;
|
|
52
|
+
const initialReleaseUsd = initialReleaseAmount * (bond?.initPrice ?? 0);
|
|
53
|
+
const vestedAmount = userAllocation * (1 - initialRelease);
|
|
54
|
+
const vestedAmountUsd = vestedAmount * (bond?.initPrice ?? 0);
|
|
55
|
+
return (jsxs(Modal, { children: [jsx(ModalHeader, { hideDivider: true }), jsxs(Flex, { sx: { flexDirection: 'column' }, children: [jsx(Flex, { sx: { width: '100%', justifyContent: 'center', mb: '15px' }, children: jsx(Text, { sx: { fontSize: '22px', fontWeight: 700 }, children: "Participation Successful" }) }), jsxs(Flex, { sx: {
|
|
56
|
+
fontSize: '14px',
|
|
57
|
+
fontWeight: 400,
|
|
58
|
+
flexDirection: 'column',
|
|
59
|
+
}, children: [jsxs(Flex, { sx: { width: '100%', justifyContent: 'space-between' }, children: [jsx(Flex, { sx: { fontSize: '12px', fontWeight: 400 }, children: "Your Deposit" }), jsxs(Flex, { sx: { fontSize: '12px', fontWeight: 400 }, children: [getFirstNonZeroDigits(inputValue, 2), " ", bond?.lpToken.symbol, jsxs(Flex, { sx: { color: 'textDisabledButton', ml: '5px' }, children: ["($", depositAmountUsd.toFixed(2), ")"] })] })] }), jsxs(Flex, { sx: { width: '100%', justifyContent: 'space-between', mt: '5px' }, children: [jsx(Flex, { sx: { fontSize: '12px', fontWeight: 400 }, children: "Your Allocation" }), jsxs(Flex, { sx: {
|
|
60
|
+
fontSize: '12px',
|
|
61
|
+
fontWeight: 500,
|
|
62
|
+
}, children: [getFirstNonZeroDigits(userAllocation, 2), " ", bond?.earnToken.symbol, jsxs(Flex, { sx: { color: 'textDisabledButton', ml: '5px' }, children: ["($", userAllocationUsd.toFixed(2), ")"] })] })] }), jsxs(Flex, { sx: { width: '100%', justifyContent: 'space-between', mt: '5px' }, children: [jsxs(Flex, { sx: { fontSize: '12px', fontWeight: 400 }, children: ["Initial Release", jsx(TooltipBubble, { placement: 'bottomLeft', transformTip: 'translate(-6%, 0%)', width: "250px", body: jsx(Flex, { sx: { justifyContent: 'center' }, children: `You'll be able to claim an initial release of ${initialRelease * 100}%
|
|
63
|
+
of your allocation on ${formattedFinishDate}` }), children: jsx(Flex, { sx: { alignItems: 'center', height: '100%', ml: '5px' }, children: jsx(Svg, { icon: "questionCircle", width: "12px" }) }) })] }), jsxs(Flex, { sx: {
|
|
64
|
+
fontSize: '12px',
|
|
65
|
+
fontWeight: 500,
|
|
66
|
+
}, children: [getFirstNonZeroDigits(initialReleaseAmount, 2), " ", bond?.earnToken.symbol, jsxs(Flex, { sx: {
|
|
67
|
+
color: 'textDisabledButton',
|
|
68
|
+
ml: '5px',
|
|
69
|
+
}, children: ["($", initialReleaseUsd.toFixed(2), ")"] })] })] }), jsxs(Flex, { sx: { width: '100%', justifyContent: 'space-between', mt: '5px' }, children: [jsxs(Flex, { sx: { fontSize: '12px', fontWeight: 400 }, children: ["Vested Tokens", jsx(TooltipBubble, { placement: 'bottomLeft', transformTip: 'translate(-6%, 0%)', width: "250px", body: jsx(Flex, { sx: { justifyContent: 'center' }, children: `Remaining tokens will vest linearly over ${getTimePeriods(bond.vestingTerm ?? 0).months} months after claiming the initial release.` }), children: jsx(Flex, { sx: { alignItems: 'center', height: '100%', ml: '5px' }, children: jsx(Svg, { icon: "questionCircle", width: "12px" }) }) })] }), jsxs(Flex, { sx: {
|
|
70
|
+
fontSize: '12px',
|
|
71
|
+
fontWeight: 500,
|
|
72
|
+
}, children: [getFirstNonZeroDigits(vestedAmount, 2), " ", bond?.earnToken.symbol, jsxs(Flex, { sx: { color: 'textDisabledButton', ml: '5px' }, children: ["($", vestedAmountUsd.toFixed(2), ")"] })] })] }), jsx(Flex, { sx: { mt: '10px' }, children: `Your purchased bond can be found under the "Your Bonds" tab.` })] }), jsx(Button, { onClick: onDismiss, sx: { fontSize: '16px', width: '100%', mt: '15px' }, children: "Close" })] })] }));
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export { ParticipationSuccessful as default };
|
|
76
|
+
//# sourceMappingURL=ParticipationSuccessful.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ParticipationSuccessful.js","sources":["../../../../../src/views/PreTGEBonds/components/BuyComponent/ParticipationSuccessful.tsx"],"sourcesContent":["import React from 'react'\nimport useTokenPrices from '../../../../state/tokenPrices/useTokenPrices'\nimport { Button, Flex, Modal, Svg, TooltipBubble, Text } from '../../../../components/uikit-sdk'\nimport ModalHeader from '../../../../components/uikit-sdk/Modal/ModalHeader'\nimport { getFirstNonZeroDigits } from '../../../../utils/roundNumber'\nimport getTimePeriods from '../../../../utils/getTimePeriods'\nimport { BondsData } from '../../../../types/bonds'\n\nconst ParticipationSuccessful = ({\n onDismiss,\n bond,\n inputAmount,\n}: {\n onDismiss?: () => void\n bond: BondsData\n inputAmount?: string\n}) => {\n const { data: tokenPrices } = useTokenPrices()\n const principalTokenPrice = tokenPrices?.find(\n (token) => token?.address?.toLowerCase() === bond?.lpToken?.address[bond?.chainId]?.toLowerCase(),\n )?.price\n const inputValue = parseFloat(inputAmount ?? '0')\n const depositAmountUsd = inputValue * (principalTokenPrice ?? 0)\n const initPrice = bond?.initPrice ?? 0\n const initialRelease = bond?.initialRelease ?? 0\n\n const userAllocation = depositAmountUsd / initPrice\n const userAllocationUsd = userAllocation * initPrice\n\n const finishTime = (bond?.redeemTime ?? 0) * 1000\n const finishDate = new Date(finishTime)\n const month = finishDate.toLocaleDateString('en-US', { month: 'short' })\n const getDayWithSuffix = (day: number) => {\n if (day > 3 && day < 21) return `${day}th`\n switch (day % 10) {\n case 1:\n return `${day}st`\n case 2:\n return `${day}nd`\n case 3:\n return `${day}rd`\n default:\n return `${day}th`\n }\n }\n const day = finishDate.getDate()\n const formattedFinishDate = `${month} ${getDayWithSuffix(day)} at 11 UTC.`\n const initialReleaseAmount = userAllocation * initialRelease\n const initialReleaseUsd = initialReleaseAmount * (bond?.initPrice ?? 0)\n\n const vestedAmount = userAllocation * (1 - initialRelease)\n const vestedAmountUsd = vestedAmount * (bond?.initPrice ?? 0)\n\n return (\n <Modal>\n <ModalHeader hideDivider />\n <Flex sx={{ flexDirection: 'column' }}>\n <Flex sx={{ width: '100%', justifyContent: 'center', mb: '15px' }}>\n <Text sx={{ fontSize: '22px', fontWeight: 700 }}>Participation Successful</Text>\n </Flex>\n <Flex\n sx={{\n fontSize: '14px',\n fontWeight: 400,\n flexDirection: 'column',\n }}\n >\n <Flex sx={{ width: '100%', justifyContent: 'space-between' }}>\n <Flex sx={{ fontSize: '12px', fontWeight: 400 }}>Your Deposit</Flex>\n <Flex sx={{ fontSize: '12px', fontWeight: 400 }}>\n {getFirstNonZeroDigits(inputValue, 2)} {bond?.lpToken.symbol}\n <Flex sx={{ color: 'textDisabledButton', ml: '5px' }}>(${depositAmountUsd.toFixed(2)})</Flex>\n </Flex>\n </Flex>\n <Flex sx={{ width: '100%', justifyContent: 'space-between', mt: '5px' }}>\n <Flex sx={{ fontSize: '12px', fontWeight: 400 }}>Your Allocation</Flex>\n <Flex\n sx={{\n fontSize: '12px',\n fontWeight: 500,\n }}\n >\n {getFirstNonZeroDigits(userAllocation, 2)} {bond?.earnToken.symbol}\n <Flex sx={{ color: 'textDisabledButton', ml: '5px' }}>(${userAllocationUsd.toFixed(2)})</Flex>\n </Flex>\n </Flex>\n <Flex sx={{ width: '100%', justifyContent: 'space-between', mt: '5px' }}>\n <Flex sx={{ fontSize: '12px', fontWeight: 400 }}>\n Initial Release\n <TooltipBubble\n placement={'bottomLeft'}\n transformTip={'translate(-6%, 0%)'}\n width=\"250px\"\n body={\n <Flex sx={{ justifyContent: 'center' }}>\n {`You'll be able to claim an initial release of ${initialRelease * 100}% \n of your allocation on ${formattedFinishDate}`}\n </Flex>\n }\n >\n <Flex sx={{ alignItems: 'center', height: '100%', ml: '5px' }}>\n <Svg icon=\"questionCircle\" width=\"12px\" />\n </Flex>\n </TooltipBubble>\n </Flex>\n <Flex\n sx={{\n fontSize: '12px',\n fontWeight: 500,\n }}\n >\n {getFirstNonZeroDigits(initialReleaseAmount, 2)} {bond?.earnToken.symbol}\n <Flex\n sx={{\n color: 'textDisabledButton',\n ml: '5px',\n }}\n >\n (${initialReleaseUsd.toFixed(2)})\n </Flex>\n </Flex>\n </Flex>\n <Flex sx={{ width: '100%', justifyContent: 'space-between', mt: '5px' }}>\n <Flex sx={{ fontSize: '12px', fontWeight: 400 }}>\n Vested Tokens\n <TooltipBubble\n placement={'bottomLeft'}\n transformTip={'translate(-6%, 0%)'}\n width=\"250px\"\n body={\n <Flex sx={{ justifyContent: 'center' }}>\n {`Remaining tokens will vest linearly over ${getTimePeriods(bond.vestingTerm ?? 0).months} months after claiming the initial release.`}\n </Flex>\n }\n >\n <Flex sx={{ alignItems: 'center', height: '100%', ml: '5px' }}>\n <Svg icon=\"questionCircle\" width=\"12px\" />\n </Flex>\n </TooltipBubble>\n </Flex>\n <Flex\n sx={{\n fontSize: '12px',\n fontWeight: 500,\n }}\n >\n {getFirstNonZeroDigits(vestedAmount, 2)} {bond?.earnToken.symbol}\n <Flex sx={{ color: 'textDisabledButton', ml: '5px' }}>(${vestedAmountUsd.toFixed(2)})</Flex>\n </Flex>\n </Flex>\n <Flex sx={{ mt: '10px' }}>{`Your purchased bond can be found under the \"Your Bonds\" tab.`}</Flex>\n </Flex>\n <Button onClick={onDismiss} sx={{ fontSize: '16px', width: '100%', mt: '15px' }}>\n Close\n </Button>\n </Flex>\n </Modal>\n )\n}\n\nexport default ParticipationSuccessful\n"],"names":["_jsxs","_jsx"],"mappings":"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"}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { jsx, jsxs, Fragment } from 'theme-ui/jsx-runtime';
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import BigNumber from 'bignumber.js';
|
|
4
|
+
import { styles } from './styles.js';
|
|
5
|
+
import { getBalanceNumber } from '../../../../utils/getBalanceNumber.js';
|
|
6
|
+
import Svg from '../../../../components/uikit-sdk/Svg/index.js';
|
|
7
|
+
import Flex from '../../../../components/uikit-sdk/Flex/index.js';
|
|
8
|
+
import Text from '../../../../components/uikit-sdk/Text/index.js';
|
|
9
|
+
import '../../../../components/uikit-sdk/Checkbox/types.js';
|
|
10
|
+
import 'theme-ui';
|
|
11
|
+
import '../../../../components/uikit-sdk/Skeleton/types.js';
|
|
12
|
+
import '../../../../components/uikit-sdk/Skeleton/styles.js';
|
|
13
|
+
import TooltipBubble from '../../../../components/uikit-sdk/TooltipBubble/index.js';
|
|
14
|
+
import Modal from '../../../../components/uikit-sdk/Modal/index.js';
|
|
15
|
+
import 'framer-motion';
|
|
16
|
+
import '../../../FullBondsView/FullBondsView.js';
|
|
17
|
+
import Button from '../../../../components/uikit-sdk/Button/Button.js';
|
|
18
|
+
import '../../../../components/uikit-sdk/Svg/types.js';
|
|
19
|
+
import '../../../../components/uikit-sdk/Button/types.js';
|
|
20
|
+
import '../../../../components/uikit-sdk/Select/types.js';
|
|
21
|
+
import ListTag from '../../../../components/uikit-sdk/Tag/ListTag.js';
|
|
22
|
+
import TokenSelectorPanel from '../../../../components/TokenSelectorPanel/index.js';
|
|
23
|
+
import useCurrencyBalance from '../../../../state/balance/useCurrencyBalance.js';
|
|
24
|
+
import { useAccount, useWriteContract } from 'wagmi';
|
|
25
|
+
import TokenImage from '../../../../components/uikit-sdk/TokenImage/index.js';
|
|
26
|
+
import ModalHeader from '../../../../components/uikit-sdk/Modal/ModalHeader.js';
|
|
27
|
+
import ProjectDescription from '../../../BuyBond/components/ProjectDescription.js';
|
|
28
|
+
import { TooltipText } from '../../../../config/constants/tooltips.js';
|
|
29
|
+
import { formatNumberSI } from '../../../../utils/formatNumber.js';
|
|
30
|
+
import BondCards from './BondCards.js';
|
|
31
|
+
import useBondsData from '../../../../state/bonds/useBondsData.js';
|
|
32
|
+
import useModal from '../../../../hooks/useModal.js';
|
|
33
|
+
import TransactionModal from '../../../TransactionModal/TransactionModal.js';
|
|
34
|
+
import { useApproval } from '../../../../state/allowance/useAllowance.js';
|
|
35
|
+
import launchBondsABI_V2_2_0 from '../../../../config/abi/launchBond_v2_4_1.json.js';
|
|
36
|
+
import ConnectButton from '../../../../components/ConnectButton/index.js';
|
|
37
|
+
import track from '../../../../utils/track.js';
|
|
38
|
+
|
|
39
|
+
const PreTGEBuyComponent = ({ bondAddress, bondChain, onDismiss, handlePurchasedBond, }) => {
|
|
40
|
+
const { data: preTGEBonds } = useBondsData();
|
|
41
|
+
const bond = preTGEBonds?.find((bond) => bond.contractAddress?.[bond.chainId]?.toLowerCase() === bondAddress.toLowerCase() && bond.chainId === bondChain);
|
|
42
|
+
// Hooks
|
|
43
|
+
const { address, chainId } = useAccount();
|
|
44
|
+
const { data: principalTokenBalance } = useCurrencyBalance(bond.lpToken, address, bond.chainId);
|
|
45
|
+
// Local state
|
|
46
|
+
const [inputValue, setInputValue] = useState('');
|
|
47
|
+
// Display Values
|
|
48
|
+
const raiseGoal = getBalanceNumber(new BigNumber(bond?.totalRaise ?? '0'), 18);
|
|
49
|
+
const totalPrincipalBilled = getBalanceNumber(new BigNumber(bond?.totalPrincipalBilled ?? '0'), 18);
|
|
50
|
+
const percentageSold = (totalPrincipalBilled * 100) / raiseGoal;
|
|
51
|
+
const tgePrice = bond?.tgePrice ?? 0;
|
|
52
|
+
const initPrice = bond?.initPrice ?? 0;
|
|
53
|
+
const inputValueToDisplay = parseFloat(inputValue).toFixed(2);
|
|
54
|
+
const inputValueToDisplayUSD = parseFloat(inputValueToDisplay) * parseFloat(bond?.principalTokenPrice ?? '0');
|
|
55
|
+
const youGet = parseFloat(inputValue) / initPrice;
|
|
56
|
+
const youGetUSD = youGet * tgePrice;
|
|
57
|
+
const bonusUSD = youGetUSD - inputValueToDisplayUSD;
|
|
58
|
+
const handleClose = () => {
|
|
59
|
+
if (typeof window !== 'undefined') {
|
|
60
|
+
window.history.pushState({}, '', `/bonds`);
|
|
61
|
+
}
|
|
62
|
+
onDismiss?.();
|
|
63
|
+
};
|
|
64
|
+
const [loading, setLoading] = useState(false);
|
|
65
|
+
const [buyTxHash, setHash] = useState('');
|
|
66
|
+
// Approve logic
|
|
67
|
+
const [approvalState, approveCallback] = useApproval(inputValue, bond.lpToken, bond?.contractAddress[bond.chainId], address, chainId);
|
|
68
|
+
const handleApprove = async () => {
|
|
69
|
+
return approveCallback().then(() => {
|
|
70
|
+
track({
|
|
71
|
+
event: 'approveBondClick',
|
|
72
|
+
chain: bondChain,
|
|
73
|
+
data: {
|
|
74
|
+
cat: bond?.billType,
|
|
75
|
+
bond: bond?.earnToken.symbol,
|
|
76
|
+
},
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
};
|
|
80
|
+
const { writeContractAsync } = useWriteContract();
|
|
81
|
+
const onBuyBill = async () => {
|
|
82
|
+
setLoading(true);
|
|
83
|
+
const amount = new BigNumber(inputValue)
|
|
84
|
+
.times(new BigNumber(10).pow(bond?.lpToken?.decimals?.[bond?.chainId] ?? 18))
|
|
85
|
+
.toString();
|
|
86
|
+
const maxPrice = new BigNumber(bond?.trueBondPrices?.[0].trueBondPrice ?? '0').times(102).div(100).toFixed(0);
|
|
87
|
+
const args = [amount, maxPrice, address];
|
|
88
|
+
await writeContractAsync({
|
|
89
|
+
address: bond?.contractAddress?.[bond.chainId],
|
|
90
|
+
abi: launchBondsABI_V2_2_0,
|
|
91
|
+
functionName: 'deposit',
|
|
92
|
+
args: args,
|
|
93
|
+
chain: bond.chainId,
|
|
94
|
+
account: address,
|
|
95
|
+
})
|
|
96
|
+
.then((hash) => {
|
|
97
|
+
setHash(hash);
|
|
98
|
+
handlePurchasedBond(hash, inputValue);
|
|
99
|
+
})
|
|
100
|
+
.finally(() => {
|
|
101
|
+
setLoading(false);
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
const [openTxModal] = useModal(jsx(TransactionModal, { txChain: bondChain, approvalState: approvalState, approveCallback: handleApprove, loadingTx: loading, txCallback: onBuyBill, bondData: bond, inputToken: bond.lpToken, inputValue: inputValue, depositAmount: inputValue, buyTxHash: buyTxHash, rateChanged: false }), false, true, 'transactionModal');
|
|
105
|
+
const { data: currencyBalanceString } = useCurrencyBalance(bond.lpToken, address, bond.chainId);
|
|
106
|
+
const exceedsBalance = parseFloat(inputValue) > parseFloat(currencyBalanceString ?? '0');
|
|
107
|
+
const saleStartTime = (bond?.initTime?.[bond.chainId] ?? 0) * 1000;
|
|
108
|
+
const saleFinishTime = (bond?.finishTime ?? 0) * 1000;
|
|
109
|
+
const now = new Date().getTime();
|
|
110
|
+
const saleHasStarted = now > saleStartTime;
|
|
111
|
+
const saleHasFinished = now > saleFinishTime || bond.finalized;
|
|
112
|
+
const error = !saleHasStarted
|
|
113
|
+
? `Sale hasn't started`
|
|
114
|
+
: saleHasFinished
|
|
115
|
+
? 'Sale Finished'
|
|
116
|
+
: exceedsBalance
|
|
117
|
+
? 'Exceeds balance'
|
|
118
|
+
: percentageSold > 99.9
|
|
119
|
+
? 'Soldout'
|
|
120
|
+
: !inputValue || parseFloat(inputValue) === 0
|
|
121
|
+
? 'Insert amount'
|
|
122
|
+
: !bond
|
|
123
|
+
? 'no bond'
|
|
124
|
+
: null;
|
|
125
|
+
return (jsxs(Modal, { onDismiss: handleClose, sx: { width: '740px' }, children: [jsx(ModalHeader, { onDismiss: handleClose, hideDivider: true }), jsx(Flex, { sx: styles.buyContainer, children: jsxs(Flex, { sx: styles.cardContainer, children: [jsx(Flex, { sx: { width: '100%', justifyContent: 'space-between' }, children: jsxs(Flex, { children: [jsxs(Flex, { children: [jsx(Flex, { className: "title-container bondicon", children: jsx(TokenImage, { symbol: bond.earnToken.symbol, size: 50, chain: bond.chainId }) }), jsxs(Flex, { className: "title-container bondname", children: [bond.earnToken.symbol, jsx(ListTag, { text: bond?.tags?.[0] })] })] }), jsxs(Flex, { sx: { flexDirection: 'column', ml: '15px' }, children: [jsxs(Flex, { className: "price-container price", children: ["$", bond.tgePrice] }), jsxs(Flex, { sx: { fontSize: '24px', fontWeight: 700 }, children: ["$", bond.initPrice] })] })] }) }), jsx(ProjectDescription, { description: bond.shortDescription, isProjectView: true }), jsx(BondCards, { bond: bond }), jsxs(Flex, { sx: { ...styles.infoRowsContainer, mt: '10px' }, children: [jsxs(Flex, { sx: styles.infoRow, children: [jsx(Text, { sx: styles.infoTitle, children: "You Spend:" }), jsxs(Text, { sx: styles.infoData, children: [isNaN(parseFloat(inputValueToDisplay)) ? 0 : inputValueToDisplay, " ", bond?.lpToken.symbol, " = $", isNaN(inputValueToDisplayUSD) ? '0' : inputValueToDisplayUSD.toFixed(2)] })] }), jsxs(Flex, { sx: styles.infoRow, children: [jsxs(Flex, { sx: { ...styles.infoTitle, alignItems: 'center' }, children: ["Bonus:", jsx(TooltipBubble, { className: "tooltip-bubble", body: jsx(Flex, { children: TooltipText.Premium }), width: "230px", placement: "bottomLeft", transformTip: "translate(-5%, 0%)", children: jsx(Flex, { className: "row-container premium-icon", children: jsx(Svg, { icon: "questionCircle", width: "12px" }) }) })] }), jsxs(Text, { sx: { ...styles.infoData, color: 'success' }, children: ["$", isNaN(bonusUSD) ? '0' : bonusUSD.toFixed(2)] })] }), jsxs(Flex, { sx: styles.infoRow, children: [jsx(Text, { sx: styles.infoTitle, children: "You Get:" }), jsxs(Text, { sx: styles.infoData, children: [isNaN(youGet) ? 0 : formatNumberSI(youGet, 0), " ", bond?.earnToken.symbol, " = $", isNaN(youGetUSD) ? '0' : youGetUSD.toFixed(2)] })] })] }), jsx(TokenSelectorPanel, { typedValue: inputValue, setTypedValue: setInputValue, selectedToken: bond?.lpToken, handleValueBtn: () => setInputValue(new BigNumber(principalTokenBalance ?? '0')?.toString()), handleCurrencySelect: () => null, chainId: bond?.chainId, enableZap: false, bondPrincipalToken: bond?.lpToken, tokenBalance: principalTokenBalance ?? undefined, selectedTokenPrice: parseFloat(bond?.principalTokenPrice ?? '0'), inputDisabled: false }), jsx(Flex, { sx: {
|
|
126
|
+
width: '100%',
|
|
127
|
+
background: '#DE62F366',
|
|
128
|
+
justifyContent: 'center',
|
|
129
|
+
mt: '10px',
|
|
130
|
+
borderRadius: 'normal',
|
|
131
|
+
p: '4px 10px',
|
|
132
|
+
fontSize: '12px',
|
|
133
|
+
fontWeight: 400,
|
|
134
|
+
}, children: bond.warningCard ? (bond.warningCard) : (jsxs(Fragment, { children: ["This is a Pre-TGE Bond - Tokens will be tradeable upon listing.", jsx(TooltipBubble, { className: "tooltip-bubble", body: jsx(Text, { sx: { textTransform: 'none' }, children: "Pre-TGE Bonds are a pre-sale for tokens before their Token Generation Event (TGE), when tokens are officially launched to the public." }), width: "315px", placement: "topRight", transformTip: "translate(9%, -10%)", children: jsx(Flex, { sx: { ml: '4px', minWidth: '14px' }, children: jsx(Svg, { icon: "questionCircle", width: 12 }) }) })] })) }), jsx(Flex, { sx: {
|
|
135
|
+
width: '100%',
|
|
136
|
+
mt: '10px',
|
|
137
|
+
justifyContent: 'space-between',
|
|
138
|
+
height: ['unset', 'unset', 'unset', '40px'],
|
|
139
|
+
flexDirection: ['column-reverse', 'column-reverse', 'column-reverse', 'row'],
|
|
140
|
+
}, children: !address ? (jsx(ConnectButton, {})) : (jsxs(Fragment, { children: [jsx(Flex, { sx: { width: ['100%', '100%', '100%', '45%'], justifyContent: 'center' }, children: jsxs(Button, { variant: "secondary", onClick: () => window.open(`/swap?outputCurrency=${bond?.lpToken?.address[bond?.chainId]}&outputChain=${bond?.chainId}`, '_blank'), fullWidth: true, children: ["Get ", bond?.lpToken?.symbol] }) }), error ? (jsx(Button, { disabled: true, fullWidth: true, sx: { ml: ['0', '0', '0', '10px'] }, children: error })) : (jsx(Button, { disabled: loading, load: loading, onClick: openTxModal, fullWidth: true, sx: { ml: ['0', '0', '0', '10px'] }, children: "Buy" }))] })) })] }) })] }));
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
export { PreTGEBuyComponent as default };
|
|
144
|
+
//# sourceMappingURL=PreTGEBuyComponent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PreTGEBuyComponent.js","sources":["../../../../../src/views/PreTGEBonds/components/BuyComponent/PreTGEBuyComponent.tsx"],"sourcesContent":["import React, { useState } from 'react'\nimport BigNumber from 'bignumber.js'\nimport { styles } from './styles'\nimport { getBalanceNumber } from '../../../../utils/getBalanceNumber'\nimport { Flex, Svg, Text, TooltipBubble, Button, ListTag, Modal } from '../../../../components/uikit-sdk'\nimport TokenSelectorPanel from '../../../../components/TokenSelectorPanel'\nimport useCurrencyBalance from '../../../../state/balance/useCurrencyBalance'\nimport { useAccount, useWriteContract } from 'wagmi'\nimport TokenImage from '../../../../components/uikit-sdk/TokenImage'\nimport ModalHeader from '../../../../components/uikit-sdk/Modal/ModalHeader'\nimport ProjectDescription from '../../../BuyBond/components/ProjectDescription'\nimport { TooltipText } from '../../../../config/constants/tooltips'\nimport { formatNumberSI } from '../../../../utils/formatNumber'\nimport BondCards from './BondCards'\nimport useBondsData from '../../../../state/bonds/useBondsData'\nimport useModal from '../../../../hooks/useModal'\nimport TransactionModal from '../../../TransactionModal/TransactionModal'\nimport { useApproval } from '../../../../state/allowance/useAllowance'\nimport { ChainId } from '@ape.swap/apeswap-lists'\nimport launchBondsABI_V2_2_0 from '../../../../config/abi/launchBond_v2_4_1.json'\nimport ConnectButton from '../../../../components/ConnectButton'\nimport track from '../../../../utils/track'\n\nconst PreTGEBuyComponent = ({\n bondAddress,\n bondChain,\n onDismiss,\n handlePurchasedBond,\n}: {\n bondAddress: string\n bondChain: number\n onDismiss?: () => void\n handlePurchasedBond: (hash: string, inputAmount: string) => void\n}) => {\n const { data: preTGEBonds } = useBondsData()\n const bond = preTGEBonds?.find(\n (bond) =>\n bond.contractAddress?.[bond.chainId]?.toLowerCase() === bondAddress.toLowerCase() && bond.chainId === bondChain,\n )!\n\n // Hooks\n const { address, chainId } = useAccount()\n const { data: principalTokenBalance } = useCurrencyBalance(bond.lpToken, address as string, bond.chainId)\n // Local state\n const [inputValue, setInputValue] = useState<string>('')\n\n // Display Values\n const raiseGoal = getBalanceNumber(new BigNumber(bond?.totalRaise ?? '0'), 18)\n const totalPrincipalBilled = getBalanceNumber(new BigNumber(bond?.totalPrincipalBilled ?? '0'), 18)\n const percentageSold = (totalPrincipalBilled * 100) / raiseGoal\n const tgePrice = bond?.tgePrice ?? 0\n const initPrice = bond?.initPrice ?? 0\n\n const inputValueToDisplay = parseFloat(inputValue).toFixed(2)\n const inputValueToDisplayUSD = parseFloat(inputValueToDisplay) * parseFloat(bond?.principalTokenPrice ?? '0')\n const youGet = parseFloat(inputValue) / initPrice\n const youGetUSD = youGet * tgePrice\n const bonusUSD = youGetUSD - inputValueToDisplayUSD\n\n const handleClose = () => {\n if (typeof window !== 'undefined') {\n window.history.pushState({}, '', `/bonds`)\n }\n onDismiss?.()\n }\n\n const [loading, setLoading] = useState<boolean>(false)\n const [buyTxHash, setHash] = useState<string>('')\n // Approve logic\n const [approvalState, approveCallback] = useApproval(\n inputValue,\n bond.lpToken,\n bond?.contractAddress[bond.chainId] as `0x${string}`,\n address as string,\n chainId as ChainId,\n )\n const handleApprove = async () => {\n return approveCallback().then(() => {\n track({\n event: 'approveBondClick',\n chain: bondChain,\n data: {\n cat: bond?.billType,\n bond: bond?.earnToken.symbol,\n },\n })\n })\n }\n const { writeContractAsync } = useWriteContract()\n const onBuyBill = async () => {\n setLoading(true)\n const amount = new BigNumber(inputValue)\n .times(new BigNumber(10).pow(bond?.lpToken?.decimals?.[bond?.chainId] ?? 18))\n .toString()\n const maxPrice = new BigNumber(bond?.trueBondPrices?.[0].trueBondPrice ?? '0').times(102).div(100).toFixed(0)\n const args = [amount, maxPrice, address]\n\n await writeContractAsync({\n address: bond?.contractAddress?.[bond.chainId] as `0x${string}`,\n abi: launchBondsABI_V2_2_0,\n functionName: 'deposit',\n args: args,\n chain: bond.chainId as any,\n account: address,\n })\n .then((hash) => {\n setHash(hash)\n handlePurchasedBond(hash, inputValue)\n })\n .finally(() => {\n setLoading(false)\n })\n }\n\n const [openTxModal] = useModal(\n <TransactionModal\n txChain={bondChain}\n approvalState={approvalState}\n approveCallback={handleApprove}\n loadingTx={loading}\n txCallback={onBuyBill}\n bondData={bond!}\n inputToken={bond.lpToken}\n inputValue={inputValue}\n depositAmount={inputValue}\n buyTxHash={buyTxHash}\n rateChanged={false}\n />,\n false,\n true,\n 'transactionModal',\n )\n\n const { data: currencyBalanceString } = useCurrencyBalance(bond.lpToken, address as string, bond.chainId)\n const exceedsBalance = parseFloat(inputValue) > parseFloat(currencyBalanceString ?? '0')\n const saleStartTime = (bond?.initTime?.[bond.chainId] ?? 0) * 1000\n const saleFinishTime = (bond?.finishTime ?? 0) * 1000\n const now = new Date().getTime()\n const saleHasStarted = now > saleStartTime\n const saleHasFinished = now > saleFinishTime || bond.finalized\n\n const error = !saleHasStarted\n ? `Sale hasn't started`\n : saleHasFinished\n ? 'Sale Finished'\n : exceedsBalance\n ? 'Exceeds balance'\n : percentageSold > 99.9\n ? 'Soldout'\n : !inputValue || parseFloat(inputValue) === 0\n ? 'Insert amount'\n : !bond\n ? 'no bond'\n : null\n\n return (\n <Modal onDismiss={handleClose} sx={{ width: '740px' }}>\n <ModalHeader onDismiss={handleClose} hideDivider />\n <Flex sx={styles.buyContainer}>\n <Flex sx={styles.cardContainer}>\n <Flex sx={{ width: '100%', justifyContent: 'space-between' }}>\n <Flex>\n <Flex>\n <Flex className=\"title-container bondicon\">\n <TokenImage symbol={bond.earnToken.symbol} size={50} chain={bond.chainId} />\n </Flex>\n <Flex className=\"title-container bondname\">\n {bond.earnToken.symbol}\n <ListTag text={bond?.tags?.[0]} />\n </Flex>\n </Flex>\n <Flex sx={{ flexDirection: 'column', ml: '15px' }}>\n <Flex className=\"price-container price\">${bond.tgePrice}</Flex>\n <Flex sx={{ fontSize: '24px', fontWeight: 700 }}>${bond.initPrice}</Flex>\n </Flex>\n </Flex>\n </Flex>\n <ProjectDescription description={bond.shortDescription} isProjectView />\n <BondCards bond={bond} />\n <Flex sx={{ ...styles.infoRowsContainer, mt: '10px' }}>\n <Flex sx={styles.infoRow}>\n <Text sx={styles.infoTitle}>You Spend:</Text>\n <Text sx={styles.infoData}>\n {isNaN(parseFloat(inputValueToDisplay)) ? 0 : inputValueToDisplay} {bond?.lpToken.symbol} = $\n {isNaN(inputValueToDisplayUSD) ? '0' : inputValueToDisplayUSD.toFixed(2)}\n </Text>\n </Flex>\n <Flex sx={styles.infoRow}>\n <Flex sx={{ ...styles.infoTitle, alignItems: 'center' }}>\n Bonus:\n <TooltipBubble\n className=\"tooltip-bubble\"\n body={<Flex>{TooltipText.Premium}</Flex>}\n width=\"230px\"\n placement=\"bottomLeft\"\n transformTip=\"translate(-5%, 0%)\"\n >\n <Flex className=\"row-container premium-icon\">\n <Svg icon=\"questionCircle\" width=\"12px\" />\n </Flex>\n </TooltipBubble>\n </Flex>\n <Text sx={{ ...styles.infoData, color: 'success' }}>${isNaN(bonusUSD) ? '0' : bonusUSD.toFixed(2)}</Text>\n </Flex>\n <Flex sx={styles.infoRow}>\n <Text sx={styles.infoTitle}>You Get:</Text>\n <Text sx={styles.infoData}>\n {isNaN(youGet) ? 0 : formatNumberSI(youGet, 0)} {bond?.earnToken.symbol} = $\n {isNaN(youGetUSD) ? '0' : youGetUSD.toFixed(2)}\n </Text>\n </Flex>\n </Flex>\n <TokenSelectorPanel\n typedValue={inputValue}\n setTypedValue={setInputValue}\n selectedToken={bond?.lpToken}\n handleValueBtn={() => setInputValue(new BigNumber(principalTokenBalance ?? '0')?.toString())}\n handleCurrencySelect={() => null}\n chainId={bond?.chainId}\n enableZap={false}\n bondPrincipalToken={bond?.lpToken}\n tokenBalance={principalTokenBalance ?? undefined}\n selectedTokenPrice={parseFloat(bond?.principalTokenPrice ?? '0')}\n inputDisabled={false}\n />\n <Flex\n sx={{\n width: '100%',\n background: '#DE62F366',\n justifyContent: 'center',\n mt: '10px',\n borderRadius: 'normal',\n p: '4px 10px',\n fontSize: '12px',\n fontWeight: 400,\n }}\n >\n {bond.warningCard ? (\n bond.warningCard\n ) : (\n <>\n This is a Pre-TGE Bond - Tokens will be tradeable upon listing.\n <TooltipBubble\n className=\"tooltip-bubble\"\n body={\n <Text sx={{ textTransform: 'none' }}>\n Pre-TGE Bonds are a pre-sale for tokens before their Token Generation Event (TGE), when tokens are\n officially launched to the public.\n </Text>\n }\n width=\"315px\"\n placement=\"topRight\"\n transformTip=\"translate(9%, -10%)\"\n >\n <Flex sx={{ ml: '4px', minWidth: '14px' }}>\n <Svg icon=\"questionCircle\" width={12} />\n </Flex>\n </TooltipBubble>\n </>\n )}\n </Flex>\n <Flex\n sx={{\n width: '100%',\n mt: '10px',\n justifyContent: 'space-between',\n height: ['unset', 'unset', 'unset', '40px'],\n flexDirection: ['column-reverse', 'column-reverse', 'column-reverse', 'row'],\n }}\n >\n {!address ? (\n <ConnectButton />\n ) : (\n <>\n <Flex sx={{ width: ['100%', '100%', '100%', '45%'], justifyContent: 'center' }}>\n <Button\n variant=\"secondary\"\n onClick={() =>\n window.open(\n `/swap?outputCurrency=${bond?.lpToken?.address[bond?.chainId]}&outputChain=${bond?.chainId}`,\n '_blank',\n )\n }\n fullWidth\n >\n Get {bond?.lpToken?.symbol}\n </Button>\n </Flex>\n {error ? (\n <Button disabled fullWidth sx={{ ml: ['0', '0', '0', '10px'] }}>\n {error}\n </Button>\n ) : (\n <Button\n disabled={loading}\n load={loading}\n onClick={openTxModal}\n fullWidth\n sx={{ ml: ['0', '0', '0', '10px'] }}\n >\n Buy\n </Button>\n )}\n </>\n )}\n </Flex>\n </Flex>\n </Flex>\n </Modal>\n )\n}\n\nexport default PreTGEBuyComponent\n"],"names":["_jsx","_jsxs","_Fragment"],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { jsx } from 'theme-ui/jsx-runtime';
|
|
2
|
+
import { useState, useEffect } from 'react';
|
|
3
|
+
import PreTGEBuyComponent from './PreTGEBuyComponent.js';
|
|
4
|
+
import useBondsData from '../../../../state/bonds/useBondsData.js';
|
|
5
|
+
import ParticipationSuccessful from './ParticipationSuccessful.js';
|
|
6
|
+
import { useMonitorTxHash } from '../../../../hooks/useMonitorTxHash.js';
|
|
7
|
+
|
|
8
|
+
/*
|
|
9
|
+
* Basically this is a handler that controls which Modal is displayed to the user.
|
|
10
|
+
* It will start by showing the buy modal and if a user purchases a bond, a inputAmount will be set, this will trigger the
|
|
11
|
+
* display of the ParticipationSuccessful modal
|
|
12
|
+
* */
|
|
13
|
+
const PreTGEModalHandler = ({ onDismiss, bondAddress, bondChain, }) => {
|
|
14
|
+
const { data: bonds } = useBondsData();
|
|
15
|
+
const [inputAmount, setInputAmount] = useState('');
|
|
16
|
+
const [buyTxHash, setBuyTxHash] = useState('');
|
|
17
|
+
const [bond, setBond] = useState();
|
|
18
|
+
const { data: txReceipt, isSuccess } = useMonitorTxHash(buyTxHash, bondChain);
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
if (inputAmount && bonds && txReceipt && isSuccess) {
|
|
21
|
+
const bond = bonds.find((bond) => bond?.contractAddress?.[bond.chainId]?.toLowerCase() === bondAddress?.toLowerCase() &&
|
|
22
|
+
bond?.chainId === bondChain);
|
|
23
|
+
setBond(bond);
|
|
24
|
+
}
|
|
25
|
+
}, [inputAmount, bonds, bondAddress, bondChain, txReceipt, isSuccess]);
|
|
26
|
+
return bond ? (jsx(ParticipationSuccessful, { bond: bond, inputAmount: inputAmount, onDismiss: onDismiss })) : (jsx(PreTGEBuyComponent, { bondAddress: bondAddress, bondChain: bondChain, handlePurchasedBond: (hash, inputAmount) => {
|
|
27
|
+
setInputAmount(inputAmount);
|
|
28
|
+
setBuyTxHash(hash);
|
|
29
|
+
}, onDismiss: () => {
|
|
30
|
+
// window.history.pushState({}, '', `${locationPath !== '/bonds' ? locationPath : '/bonds'}`)
|
|
31
|
+
onDismiss?.();
|
|
32
|
+
} }));
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
export { PreTGEModalHandler as default };
|
|
36
|
+
//# sourceMappingURL=PreTGEModalHandler.js.map
|