2021-08-25 15:22:40 -07:00
|
|
|
import { useState } from 'react'
|
2021-07-17 06:49:52 -07:00
|
|
|
import { useRouter } from 'next/router'
|
|
|
|
import Link from 'next/link'
|
2021-07-18 07:17:52 -07:00
|
|
|
import {
|
|
|
|
BtcMonoIcon,
|
|
|
|
CopeMonoIcon,
|
|
|
|
DogeMonoIcon,
|
|
|
|
EthMonoIcon,
|
|
|
|
FidaMonoIcon,
|
|
|
|
FttMonoIcon,
|
|
|
|
MediaMonoIcon,
|
|
|
|
MerMonoIcon,
|
|
|
|
MngoMonoIcon,
|
|
|
|
RayMonoIcon,
|
|
|
|
SolMonoIcon,
|
|
|
|
SrmMonoIcon,
|
|
|
|
StepMonoIcon,
|
|
|
|
SushiMonoIcon,
|
|
|
|
UniMonoIcon,
|
2021-07-28 16:03:21 -07:00
|
|
|
UsdtMonoIcon,
|
2021-10-29 11:57:50 -07:00
|
|
|
AdaMonoIcon,
|
2021-11-19 12:15:32 -08:00
|
|
|
MsolMonoIcon,
|
2021-07-18 07:17:52 -07:00
|
|
|
} from './icons'
|
|
|
|
|
|
|
|
const symbolIcons = {
|
|
|
|
BtcMonoIcon,
|
|
|
|
CopeMonoIcon,
|
|
|
|
DogeMonoIcon,
|
|
|
|
EthMonoIcon,
|
|
|
|
FidaMonoIcon,
|
|
|
|
FttMonoIcon,
|
|
|
|
MediaMonoIcon,
|
|
|
|
MerMonoIcon,
|
|
|
|
MngoMonoIcon,
|
|
|
|
RayMonoIcon,
|
|
|
|
SolMonoIcon,
|
|
|
|
SrmMonoIcon,
|
|
|
|
StepMonoIcon,
|
|
|
|
SushiMonoIcon,
|
|
|
|
UniMonoIcon,
|
2021-07-28 16:03:21 -07:00
|
|
|
UsdtMonoIcon,
|
2021-10-29 11:57:50 -07:00
|
|
|
AdaMonoIcon,
|
2021-11-19 12:15:32 -08:00
|
|
|
MsolMonoIcon,
|
2021-07-18 07:17:52 -07:00
|
|
|
}
|
2021-07-17 06:49:52 -07:00
|
|
|
|
|
|
|
export default function MarketMenuItem({ menuTitle = '', linksArray = [] }) {
|
|
|
|
const { asPath } = useRouter()
|
|
|
|
const [openState, setOpenState] = useState(false)
|
|
|
|
|
2021-07-18 07:17:52 -07:00
|
|
|
const iconName = `${menuTitle.substr(0, 1)}${menuTitle
|
|
|
|
.substr(1, 4)
|
|
|
|
.toLowerCase()}MonoIcon`
|
|
|
|
const SymbolIcon = symbolIcons[iconName]
|
|
|
|
|
2021-07-17 06:49:52 -07:00
|
|
|
const onHover = (open, action) => {
|
|
|
|
if (
|
2021-08-25 15:22:40 -07:00
|
|
|
(!open && action === 'onMouseEnter') ||
|
|
|
|
(open && action === 'onMouseLeave')
|
2021-07-17 06:49:52 -07:00
|
|
|
) {
|
2021-08-25 15:22:40 -07:00
|
|
|
setOpenState((openState) => !openState)
|
2021-07-17 06:49:52 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2021-08-25 15:22:40 -07:00
|
|
|
<div className="relative">
|
|
|
|
<div
|
|
|
|
onMouseEnter={() => onHover(openState, 'onMouseEnter')}
|
|
|
|
onMouseLeave={() => onHover(openState, 'onMouseLeave')}
|
|
|
|
className="flex flex-col h-10"
|
|
|
|
>
|
|
|
|
<div className="flex items-center px-3 h-10 text-th-fgd-3 hover:text-th-primary focus:outline-none">
|
|
|
|
<SymbolIcon
|
|
|
|
className={`h-3.5 w-auto mr-1.5 ${
|
2021-11-19 12:51:01 -08:00
|
|
|
asPath.includes(`=${menuTitle}`) && 'text-th-primary'
|
2021-08-25 15:22:40 -07:00
|
|
|
}`}
|
|
|
|
/>
|
|
|
|
<span
|
|
|
|
className={`font-normal text-xs ${
|
2021-11-19 12:51:01 -08:00
|
|
|
asPath.includes(`=${menuTitle}`) && 'text-th-primary'
|
2021-08-25 15:22:40 -07:00
|
|
|
}`}
|
2021-07-17 06:49:52 -07:00
|
|
|
>
|
2021-08-25 15:22:40 -07:00
|
|
|
{menuTitle}
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
{openState ? (
|
|
|
|
<div className="absolute top-10 z-10">
|
|
|
|
<div className="relative bg-th-bkg-3 divide-y divide-th-fgd-4 px-3 rounded rounded-t-none">
|
|
|
|
{linksArray.map((m) => (
|
|
|
|
<Link
|
2021-11-14 10:37:02 -08:00
|
|
|
href={{
|
|
|
|
pathname: '/market',
|
|
|
|
query: { name: m.name },
|
|
|
|
}}
|
2021-08-25 15:22:40 -07:00
|
|
|
key={m.name}
|
2021-11-14 06:48:09 -08:00
|
|
|
shallow={true}
|
2021-08-25 15:22:40 -07:00
|
|
|
>
|
|
|
|
<a
|
2021-11-01 13:20:30 -07:00
|
|
|
className={`block py-2 text-th-fgd-1 text-xs hover:text-th-primary whitespace-nowrap ${
|
2021-08-25 15:22:40 -07:00
|
|
|
asPath.includes(menuTitle)
|
2021-11-14 10:37:02 -08:00
|
|
|
? asPath.includes(m.name.slice(-4))
|
2021-08-25 15:22:40 -07:00
|
|
|
? 'text-th-primary'
|
|
|
|
: 'text-th-fgd-1'
|
|
|
|
: null
|
|
|
|
}`}
|
2021-07-17 06:49:52 -07:00
|
|
|
>
|
2021-08-25 15:22:40 -07:00
|
|
|
{m.name}
|
|
|
|
</a>
|
|
|
|
</Link>
|
|
|
|
))}
|
|
|
|
</div>
|
2021-07-17 06:49:52 -07:00
|
|
|
</div>
|
2021-08-25 15:22:40 -07:00
|
|
|
) : null}
|
|
|
|
</div>
|
2021-07-17 06:49:52 -07:00
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|