mango-v4-ui/components/shared/SuccessParticles.tsx

175 lines
4.9 KiB
TypeScript
Raw Normal View History

2023-01-02 04:19:30 -08:00
import { PerpMarket, Serum3Market } from '@blockworks-foundation/mango-v4'
2022-11-24 18:39:14 -08:00
import { INITIAL_ANIMATION_SETTINGS } from '@components/settings/AnimationSettings'
2022-11-21 19:23:54 -08:00
import mangoStore from '@store/mangoStore'
import useJupiterMints from 'hooks/useJupiterMints'
2022-11-22 21:38:31 -08:00
import useLocalStorageState from 'hooks/useLocalStorageState'
2023-06-05 19:49:51 -07:00
import { useTheme } from 'next-themes'
2022-11-21 19:23:54 -08:00
import { useEffect, useMemo } from 'react'
import Particles from 'react-tsparticles'
2023-07-04 21:40:47 -07:00
import { ANIMATION_SETTINGS_KEY, CUSTOM_TOKEN_ICONS } from 'utils/constants'
2022-11-21 19:23:54 -08:00
2023-01-02 04:19:30 -08:00
const SuccessParticles = () => {
2022-11-21 19:23:54 -08:00
const { mangoTokens } = useJupiterMints()
2023-01-02 04:19:30 -08:00
const showForSwap = mangoStore((s) => s.successAnimation.swap)
2023-06-05 19:49:51 -07:00
const showForTheme = mangoStore((s) => s.successAnimation.theme)
2023-01-02 04:19:30 -08:00
const showForTrade = mangoStore((s) => s.successAnimation.trade)
2023-01-20 03:03:31 -08:00
const tradeType = mangoStore((s) => s.tradeForm.tradeType)
2023-06-06 22:00:59 -07:00
const themeData = mangoStore((s) => s.themeData)
2022-11-21 19:23:54 -08:00
const set = mangoStore((s) => s.set)
2022-11-22 21:38:31 -08:00
const [animationSettings] = useLocalStorageState(
ANIMATION_SETTINGS_KEY,
2023-07-21 11:47:53 -07:00
INITIAL_ANIMATION_SETTINGS,
2022-11-22 21:38:31 -08:00
)
2023-06-05 19:49:51 -07:00
const { theme } = useTheme()
2022-11-21 19:23:54 -08:00
const tokenLogo = useMemo(() => {
2023-01-02 04:19:30 -08:00
if (!mangoTokens.length) return ''
if (showForSwap) {
2023-07-04 21:40:47 -07:00
const tokenBank = mangoStore.getState().swap.outputBank
const tokenMint = tokenBank?.mint.toString()
const tokenSymbol = tokenBank?.name.toLowerCase()
const hasCustomIcon = tokenSymbol
? CUSTOM_TOKEN_ICONS[tokenSymbol]
: false
if (hasCustomIcon) {
return `/icons/${tokenSymbol}.svg`
} else {
return mangoTokens.find((t) => t.address === tokenMint)?.logoURI
}
2023-01-02 04:19:30 -08:00
}
2023-01-20 03:03:31 -08:00
if (showForTrade && tradeType === 'Market') {
2023-01-02 04:19:30 -08:00
const market = mangoStore.getState().selectedMarket.current
const side = mangoStore.getState().tradeForm.side
if (market instanceof Serum3Market) {
const symbol =
2023-07-04 21:40:47 -07:00
side === 'buy'
? market.name.split('/')[0].toLowerCase()
: market.name.split('/')[1].toLowerCase()
const hasCustomIcon = CUSTOM_TOKEN_ICONS[symbol]
if (hasCustomIcon) {
return `/icons/${symbol}.svg`
} else {
return mangoTokens.find((t) => t.symbol.toLowerCase() === symbol)
?.logoURI
}
2023-01-02 04:19:30 -08:00
}
if (market instanceof PerpMarket) {
2023-07-04 21:40:47 -07:00
const symbol =
side === 'buy' ? market.name.split('-')[0].toLowerCase() : 'usdc'
const hasCustomIcon = CUSTOM_TOKEN_ICONS[symbol]
if (hasCustomIcon) {
return `/icons/${symbol}.svg`
} else {
return mangoTokens.find((t) => t.symbol.toUpperCase() === symbol)
?.logoURI
}
2023-01-02 04:19:30 -08:00
}
}
2023-06-05 19:49:51 -07:00
if (showForTheme) {
2023-06-06 22:00:59 -07:00
return themeData.rainAnimationImagePath
2023-06-05 19:49:51 -07:00
}
}, [mangoTokens, showForSwap, showForTheme, showForTrade, theme])
2022-11-21 19:23:54 -08:00
useEffect(() => {
2023-01-02 04:19:30 -08:00
if (showForSwap) {
setTimeout(
() =>
set((s) => {
s.successAnimation.swap = false
}),
2023-07-21 11:47:53 -07:00
8000,
2023-01-02 04:19:30 -08:00
)
}
2023-06-05 19:49:51 -07:00
if (showForTheme) {
setTimeout(
() =>
set((s) => {
s.successAnimation.theme = false
}),
2023-07-23 04:06:29 -07:00
6000,
2023-06-05 19:49:51 -07:00
)
}
2023-01-02 04:19:30 -08:00
if (showForTrade) {
2022-11-21 19:23:54 -08:00
setTimeout(
() =>
set((s) => {
2023-01-02 04:19:30 -08:00
s.successAnimation.trade = false
2022-11-21 19:23:54 -08:00
}),
2023-07-21 11:47:53 -07:00
8000,
2022-11-21 19:23:54 -08:00
)
}
2023-06-05 19:49:51 -07:00
}, [showForSwap, showForTheme, showForTrade])
2022-11-21 19:23:54 -08:00
2023-06-05 19:49:51 -07:00
return (animationSettings['swap-success'] || showForTheme) &&
2023-01-02 04:19:30 -08:00
tokenLogo &&
2023-06-05 19:49:51 -07:00
(showForSwap || showForTrade || showForTheme) ? (
2022-11-21 19:23:54 -08:00
<Particles
id="tsparticles"
options={{
detectRetina: true,
particles: {
2022-11-23 21:04:33 -08:00
opacity: {
2022-11-21 19:23:54 -08:00
value: 0,
},
2022-11-23 21:04:33 -08:00
},
emitters: {
life: {
count: 30,
delay: 0,
duration: 0.1,
2022-11-21 19:23:54 -08:00
},
2022-11-23 21:04:33 -08:00
startCount: 0,
particles: {
shape: {
type: 'image',
options: {
image: {
src: tokenLogo,
width: 48,
height: 48,
},
2022-11-21 19:23:54 -08:00
},
},
2022-11-23 21:04:33 -08:00
rotate: {
value: 0,
random: true,
direction: 'clockwise',
animation: {
enable: true,
speed: 15,
sync: false,
},
},
opacity: {
value: 1,
},
size: {
value: 20,
random: false,
},
move: {
angle: 10,
attract: {
rotate: {
x: 600,
y: 1200,
},
},
direction: 'bottom',
enable: true,
speed: { min: 8, max: 16 },
outMode: 'destroy',
},
2022-11-21 19:23:54 -08:00
},
2022-11-22 21:38:31 -08:00
position: {
2022-11-23 21:04:33 -08:00
x: { random: true },
y: 0,
2022-11-22 21:38:31 -08:00
},
2022-11-21 19:23:54 -08:00
},
}}
/>
) : null
}
2023-01-02 04:19:30 -08:00
export default SuccessParticles