mango-ui-v3/components/MarketMenuItem.tsx

117 lines
2.9 KiB
TypeScript
Raw Normal View History

2021-08-25 15:22:40 -07:00
import { useState } from 'react'
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
}
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]
const onHover = (open, action) => {
if (
2021-08-25 15:22:40 -07:00
(!open && action === 'onMouseEnter') ||
(open && action === 'onMouseLeave')
) {
2021-08-25 15:22:40 -07:00
setOpenState((openState) => !openState)
}
}
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-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
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
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)
? asPath.includes(m.name.slice(-4))
2021-08-25 15:22:40 -07:00
? 'text-th-primary'
: 'text-th-fgd-1'
: null
}`}
>
2021-08-25 15:22:40 -07:00
{m.name}
</a>
</Link>
))}
</div>
</div>
2021-08-25 15:22:40 -07:00
) : null}
</div>
</div>
)
}