mango-ui-v3/components/MarketNavItem.tsx

82 lines
2.4 KiB
TypeScript
Raw Normal View History

2022-02-09 02:55:54 -08:00
import { FunctionComponent, RefObject } from 'react'
import { useRouter } from 'next/router'
import { initialMarket } from './SettingsModal'
import { FavoriteMarketButton } from './TradeNavMenu'
import useMangoStore from '../stores/useMangoStore'
import { getWeights } from '@blockworks-foundation/mango-client'
interface MarketNavItemProps {
market: any
2022-02-17 19:32:48 -08:00
onClick?: () => void
2022-02-09 02:55:54 -08:00
buttonRef?: RefObject<HTMLElement>
}
const MarketNavItem: FunctionComponent<MarketNavItemProps> = ({
market,
2022-02-17 19:32:48 -08:00
onClick,
2022-02-09 02:55:54 -08:00
buttonRef,
}) => {
const { asPath } = useRouter()
const router = useRouter()
const mangoGroup = useMangoStore((s) => s.selectedMangoGroup.current)
const marketInfo = useMangoStore((s) => s.marketInfo)
const mktInfo = marketInfo.find((info) => info.name === market.name)
const selectMarket = (market) => {
buttonRef?.current?.click()
router.push(`/?name=${market.name}`, undefined, { shallow: true })
2022-02-17 19:32:48 -08:00
if (onClick) {
onClick()
2022-02-09 02:55:54 -08:00
}
}
const getMarketLeverage = (market) => {
if (!mangoGroup) return 1
const ws = getWeights(mangoGroup, market.marketIndex, 'Init')
const w = market.name.includes('PERP')
? ws.perpAssetWeight
: ws.spotAssetWeight
return Math.round((100 * -1) / (w.toNumber() - 1)) / 100
}
return (
<div className="text-th-fgd-3">
2022-02-09 03:42:00 -08:00
<div className="flex items-center">
<FavoriteMarketButton market={market} />
<button
className="font-normal flex items-center justify-between w-full"
onClick={() => selectMarket(market)}
>
<div
className={`flex items-center text-xs hover:text-th-primary w-full whitespace-nowrap ${
asPath.includes(market.name) ||
(asPath === '/' && initialMarket.name === market.name)
? 'text-th-primary'
: 'text-th-fgd-1'
}`}
>
<span className="ml-2">{market.name}</span>
<span className="ml-1.5 text-xs text-th-fgd-4">
{getMarketLeverage(market)}x
</span>
</div>
2022-02-09 02:55:54 -08:00
<div
className={`text-xs ${
mktInfo
? mktInfo.change24h >= 0
? 'text-th-green'
: 'text-th-red'
: 'text-th-fgd-4'
}`}
>
2022-02-13 15:10:18 -08:00
{mktInfo ? `${(mktInfo.change24h * 100).toFixed(1)}%` : '?'}
2022-02-09 02:55:54 -08:00
</div>
2022-02-09 03:42:00 -08:00
</button>
2022-02-09 02:55:54 -08:00
</div>
</div>
)
}
export default MarketNavItem