mango-ui-v3/components/MarketsModal.tsx

142 lines
5.3 KiB
TypeScript
Raw Normal View History

2021-08-16 11:00:04 -07:00
import React from 'react'
2021-07-18 07:17:52 -07:00
import Link from 'next/link'
import { EyeIcon, EyeOffIcon } from '@heroicons/react/outline'
2021-08-31 05:46:47 -07:00
import { ChevronRightIcon } from '@heroicons/react/solid'
2021-07-18 07:17:52 -07:00
import Modal from './Modal'
import useLocalStorageState from '../hooks/useLocalStorageState'
2021-08-01 05:48:15 -07:00
import useMangoStore from '../stores/useMangoStore'
import { formatUsdValue } from '../utils'
2021-07-18 07:17:52 -07:00
import { LinkButton } from './Button'
import { useTranslation } from 'next-i18next'
2021-07-18 07:17:52 -07:00
const MarketsModal = ({
isOpen,
markets,
onClose,
}: {
isOpen: boolean
markets: Array<any>
2021-08-01 05:48:15 -07:00
onClose?: (x?) => void
2021-07-18 07:17:52 -07:00
}) => {
const { t } = useTranslation('common')
2021-08-16 11:00:04 -07:00
const mangoGroup = useMangoStore((s) => s.selectedMangoGroup.current)
const mangoCache = useMangoStore((s) => s.selectedMangoGroup.cache)
2021-07-18 07:17:52 -07:00
const [hiddenMarkets, setHiddenMarkets] = useLocalStorageState(
'hiddenMarkets',
[]
)
const handleHideShowMarket = (asset) => {
if (hiddenMarkets.includes(asset)) {
setHiddenMarkets(hiddenMarkets.filter((m) => m !== asset))
} else {
setHiddenMarkets(hiddenMarkets.concat(asset))
}
}
return (
2021-08-16 10:59:44 -07:00
<Modal isOpen={isOpen} onClose={onClose}>
2021-07-18 07:17:52 -07:00
<div className="flex items-end justify-between pb-3 pt-2">
<div className="text-lg font-bold text-th-fgd-1">{t('markets')}</div>
2021-08-31 05:46:47 -07:00
{hiddenMarkets.length === 0 ? (
<LinkButton
className="mb-0.5 hidden text-xs font-normal text-th-fgd-3 disabled:cursor-not-allowed disabled:text-th-fgd-4 disabled:no-underline md:block"
2021-08-31 05:46:47 -07:00
// disabled={hiddenMarkets.length === 0}
onClick={() =>
setHiddenMarkets(markets.map((mkt) => mkt.baseAsset))
}
>
{t('hide-all')}
2021-08-31 05:46:47 -07:00
</LinkButton>
) : (
<LinkButton
className="mb-0.5 hidden text-xs font-normal text-th-fgd-3 disabled:cursor-not-allowed disabled:text-th-fgd-4 disabled:no-underline md:block"
2021-08-31 05:46:47 -07:00
// disabled={hiddenMarkets.length === 0}
onClick={() => setHiddenMarkets([])}
>
{t('show-all')}
2021-08-31 05:46:47 -07:00
</LinkButton>
)}
2021-07-18 07:17:52 -07:00
</div>
2021-11-19 19:43:31 -08:00
{markets.map((mkt) => (
2021-08-16 11:00:04 -07:00
<div key={mkt.baseAsset}>
<div className="flex items-center justify-between bg-th-bkg-3 px-2.5 py-2">
2021-07-18 07:17:52 -07:00
<div className="flex items-center">
<img
alt=""
2021-08-16 11:00:04 -07:00
src={`/assets/icons/${mkt.baseAsset.toLowerCase()}.svg`}
className={`mr-2.5 h-5 w-auto`}
2021-07-18 07:17:52 -07:00
/>
2021-08-16 11:00:04 -07:00
<span className="text-th-fgd-2">{mkt.baseAsset}</span>
2021-07-18 07:17:52 -07:00
</div>
<div className="hidden md:flex">
2021-08-31 05:46:47 -07:00
{hiddenMarkets.includes(mkt.baseAsset) ? (
<EyeOffIcon
className="default-transition h-4 w-4 cursor-pointer text-th-fgd-4 hover:text-th-fgd-3"
2021-08-31 05:46:47 -07:00
onClick={() => handleHideShowMarket(mkt.baseAsset)}
/>
) : (
<EyeIcon
className="default-transition h-4 w-4 cursor-pointer text-th-primary hover:text-th-primary-dark"
2021-08-31 05:46:47 -07:00
onClick={() => handleHideShowMarket(mkt.baseAsset)}
/>
)}
</div>
2021-07-18 07:17:52 -07:00
</div>
2021-08-31 05:46:47 -07:00
{/* <div className="bg-[rgba(255,255,255,0.1)] flex items-center justify-between px-2.5 py-0.5 text-th-fgd-3">
<StyledColumnHeader>Markets</StyledColumnHeader>
2021-07-18 07:17:52 -07:00
<div className="flex justify-between">
2021-08-31 05:46:47 -07:00
<StyledColumnHeader className="pr-5 text-right w-20">
2021-07-18 07:17:52 -07:00
Price
</StyledColumnHeader>
2021-08-31 05:46:47 -07:00
<StyledColumnHeader className="text-right w-20">
2021-07-18 07:17:52 -07:00
24h Change
</StyledColumnHeader>
<StyledColumnHeader className="text-right w-20">
24h Vol
2021-08-31 05:46:47 -07:00
</StyledColumnHeader>
2021-07-18 07:17:52 -07:00
</div>
2021-08-31 05:46:47 -07:00
</div> */}
<div className="divide-y divide-th-bkg-4">
{mkt.markets.map((m) => (
2021-07-18 07:17:52 -07:00
<div
2021-08-31 05:46:47 -07:00
className={`flex items-center justify-between px-2.5 text-xs`}
2021-07-18 07:17:52 -07:00
key={m.name}
>
2022-01-31 09:48:48 -08:00
<Link href={`/?name=${m.name}`} key={m.name}>
2021-07-18 07:17:52 -07:00
<a
className="default-transition flex h-12 w-full cursor-pointer items-center justify-between text-th-fgd-2 hover:text-th-primary"
2021-07-18 07:17:52 -07:00
onClick={onClose}
>
{m.name}
2021-08-31 05:46:47 -07:00
<div className="flex items-center">
<span className="w-20 text-right">
2022-03-29 06:02:29 -07:00
{mangoGroup && mangoCache
? formatUsdValue(
mangoGroup
.getPrice(m.marketIndex, mangoCache)
.toNumber()
)
: null}
2021-08-31 05:46:47 -07:00
</span>
{/* <span className="text-th-green text-right w-20">
+2.44%
</span>
<span className="text-th-fgd-3 text-right w-20">
$233m
</span> */}
<ChevronRightIcon className="ml-1 h-4 w-5 text-th-fgd-2" />
2021-08-31 05:46:47 -07:00
</div>
2021-07-18 07:17:52 -07:00
</a>
</Link>
</div>
))}
</div>
</div>
))}
</Modal>
)
}
export default React.memo(MarketsModal)