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} />
|
2022-02-18 14:24:06 -08:00
|
|
|
|
2022-02-09 03:42:00 -08:00
|
|
|
<button
|
|
|
|
className="font-normal flex items-center justify-between w-full"
|
|
|
|
onClick={() => selectMarket(market)}
|
|
|
|
>
|
|
|
|
<div
|
2022-02-18 14:24:06 -08:00
|
|
|
className={`flex items-center text-xs w-full whitespace-nowrap py-1.5 hover:text-th-primary ${
|
2022-02-09 03:42:00 -08:00
|
|
|
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
|