2021-08-01 05:48:15 -07:00
|
|
|
import React, { useEffect } from 'react'
|
2021-07-18 07:17:52 -07:00
|
|
|
import styled from '@emotion/styled'
|
|
|
|
import Link from 'next/link'
|
|
|
|
import { EyeIcon, EyeOffIcon } from '@heroicons/react/outline'
|
|
|
|
import Modal from './Modal'
|
|
|
|
import useLocalStorageState from '../hooks/useLocalStorageState'
|
2021-08-01 05:48:15 -07:00
|
|
|
import useMangoStore from '../stores/useMangoStore'
|
2021-07-18 07:17:52 -07:00
|
|
|
import { LinkButton } from './Button'
|
|
|
|
|
|
|
|
const StyledColumnHeader = styled.span`
|
|
|
|
font-size: 0.6rem;
|
|
|
|
`
|
|
|
|
|
|
|
|
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 [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="font-bold text-lg text-th-fgd-1">Markets</div>
|
|
|
|
<LinkButton
|
|
|
|
className="font-normal mb-0.5 text-th-fgd-3 text-xs disabled:cursor-not-allowed disabled:no-underline disabled:text-th-fgd-4"
|
|
|
|
disabled={hiddenMarkets.length === 0}
|
|
|
|
onClick={() => setHiddenMarkets([])}
|
|
|
|
>
|
|
|
|
Show all in Nav
|
|
|
|
</LinkButton>
|
|
|
|
</div>
|
|
|
|
{markets.map((m) => (
|
|
|
|
<div key={m.baseAsset}>
|
|
|
|
<div className="bg-th-bkg-3 flex items-center justify-between p-2 rounded">
|
|
|
|
<div className="flex items-center">
|
|
|
|
<img
|
|
|
|
alt=""
|
|
|
|
src={`/assets/icons/${m.baseAsset.toLowerCase()}.svg`}
|
|
|
|
className={`h-5 mr-2.5 w-auto`}
|
|
|
|
/>
|
|
|
|
<span className="text-th-fgd-2">{m.baseAsset}</span>
|
|
|
|
</div>
|
|
|
|
{hiddenMarkets.includes(m.baseAsset) ? (
|
|
|
|
<EyeOffIcon
|
|
|
|
className="cursor-pointer default-transition h-5 text-th-fgd-4 w-5 hover:text-th-fgd-3"
|
|
|
|
onClick={() => handleHideShowMarket(m.baseAsset)}
|
|
|
|
/>
|
|
|
|
) : (
|
|
|
|
<EyeIcon
|
|
|
|
className="cursor-pointer default-transition h-5 text-th-primary w-5 hover:text-th-primary-dark"
|
|
|
|
onClick={() => handleHideShowMarket(m.baseAsset)}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</div>
|
2021-07-20 07:21:58 -07:00
|
|
|
<div className="flex items-center justify-between pt-2.5 px-2.5 text-th-fgd-3">
|
2021-07-18 07:17:52 -07:00
|
|
|
<StyledColumnHeader>Market</StyledColumnHeader>
|
|
|
|
<div className="flex justify-between">
|
|
|
|
<StyledColumnHeader className="text-right w-20">
|
|
|
|
Price
|
|
|
|
</StyledColumnHeader>
|
|
|
|
<StyledColumnHeader className="text-right w-20">
|
|
|
|
24h Change
|
|
|
|
</StyledColumnHeader>
|
|
|
|
<StyledColumnHeader className="text-right w-20">
|
|
|
|
24h Vol
|
|
|
|
</StyledColumnHeader>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div className="divide-y divide-th-bkg-3">
|
|
|
|
{m.markets.map((m, i) => (
|
|
|
|
<div
|
|
|
|
className={`flex items-center justify-between p-2.5 text-xs ${
|
|
|
|
i === 0 && 'pt-1'
|
|
|
|
}`}
|
|
|
|
key={m.name}
|
|
|
|
>
|
|
|
|
<Link
|
|
|
|
href={`/${
|
|
|
|
m.name.slice(-4) === 'PERP' ? 'perp' : 'spot'
|
|
|
|
}/${m.name.slice(0, -5)}`}
|
|
|
|
key={m.name}
|
|
|
|
>
|
|
|
|
<a
|
|
|
|
className="cursor-pointer default-transition text-th-fgd-2 hover:text-th-primary"
|
|
|
|
onClick={onClose}
|
|
|
|
>
|
|
|
|
{m.name}
|
|
|
|
</a>
|
|
|
|
</Link>
|
|
|
|
<div className="flex justify-between">
|
|
|
|
<span className="text-th-fgd-2 text-right w-20">$10,000</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>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
))}
|
|
|
|
</Modal>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default React.memo(MarketsModal)
|