import { PerpMarket, Serum3Market } from '@blockworks-foundation/mango-v4' import { INITIAL_ANIMATION_SETTINGS } from '@components/settings/AnimationSettings' import mangoStore from '@store/mangoStore' import useJupiterMints from 'hooks/useJupiterMints' import useLocalStorageState from 'hooks/useLocalStorageState' import { useTheme } from 'next-themes' import { useEffect, useMemo } from 'react' import Particles from 'react-tsparticles' import { ANIMATION_SETTINGS_KEY } from 'utils/constants' const SuccessParticles = () => { const { mangoTokens } = useJupiterMints() const showForSwap = mangoStore((s) => s.successAnimation.swap) const showForTheme = mangoStore((s) => s.successAnimation.theme) const showForTrade = mangoStore((s) => s.successAnimation.trade) const tradeType = mangoStore((s) => s.tradeForm.tradeType) const set = mangoStore((s) => s.set) const [animationSettings] = useLocalStorageState( ANIMATION_SETTINGS_KEY, INITIAL_ANIMATION_SETTINGS ) const { theme } = useTheme() const tokenLogo = useMemo(() => { if (!mangoTokens.length) return '' if (showForSwap) { const tokenMint = mangoStore.getState().swap.outputBank?.mint.toString() return mangoTokens.find((t) => t.address === tokenMint)?.logoURI } if (showForTrade && tradeType === 'Market') { const market = mangoStore.getState().selectedMarket.current const side = mangoStore.getState().tradeForm.side if (market instanceof Serum3Market) { const symbol = side === 'buy' ? market.name.split('/')[0] : market.name.split('/')[1] return mangoTokens.find((t) => t.symbol.toUpperCase() === symbol) ?.logoURI } if (market instanceof PerpMarket) { const symbol = side === 'buy' ? market.name.split('-')[0] : 'USDC' return ( mangoTokens.find((t) => t.symbol.toUpperCase() === symbol)?.logoURI || `/icons/${symbol.toLowerCase()}.svg` ) } } if (showForTheme) { return theme === 'Bonk' ? '/images/themes/bonk/bonk-animation-logo.png' : null } }, [mangoTokens, showForSwap, showForTheme, showForTrade, theme]) useEffect(() => { if (showForSwap) { setTimeout( () => set((s) => { s.successAnimation.swap = false }), 8000 ) } if (showForTheme) { setTimeout( () => set((s) => { s.successAnimation.theme = false }), 6000 ) } if (showForTrade) { setTimeout( () => set((s) => { s.successAnimation.trade = false }), 8000 ) } }, [showForSwap, showForTheme, showForTrade]) return (animationSettings['swap-success'] || showForTheme) && tokenLogo && (showForSwap || showForTrade || showForTheme) ? ( ) : null } export default SuccessParticles