mango-ui-v3/components/NavDropMenu.tsx

89 lines
2.7 KiB
TypeScript
Raw Normal View History

import { useRef, useState } from 'react'
import { Popover } from '@headlessui/react'
2022-02-09 19:33:43 -08:00
import { ChevronDownIcon } from '@heroicons/react/outline'
import Link from 'next/link'
2022-02-09 19:33:43 -08:00
type NavDropMenuProps = {
menuTitle: string | React.ReactNode
linksArray: [string, string, boolean][]
}
export default function NavDropMenu({
menuTitle = '',
linksArray = [],
}: NavDropMenuProps) {
const buttonRef = useRef(null)
const [openState, setOpenState] = useState(false)
const toggleMenu = () => {
setOpenState((openState) => !openState)
buttonRef?.current?.click()
}
const onHover = (open, action) => {
if (
(!open && !openState && action === 'onMouseEnter') ||
(open && openState && action === 'onMouseLeave')
) {
toggleMenu()
}
}
const handleClick = (open) => {
setOpenState(!open)
}
return (
<div className="">
<Popover className="relative">
{({ open }) => (
<div
onMouseEnter={() => onHover(open, 'onMouseEnter')}
onMouseLeave={() => onHover(open, 'onMouseLeave')}
className="flex flex-col"
>
2022-02-09 19:33:43 -08:00
<Popover.Button
className="h-10 text-th-fgd-1 hover:text-th-primary md:px-2 lg:px-4 focus:outline-none transition-none"
ref={buttonRef}
>
<div
2022-02-09 19:33:43 -08:00
className="flex items-center"
onClick={() => handleClick(open)}
>
<span className="font-bold">{menuTitle}</span>
2022-02-09 19:33:43 -08:00
<ChevronDownIcon
2021-07-18 07:17:52 -07:00
className="h-4 w-4 default-transition ml-1.5"
aria-hidden="true"
/>
</div>
</Popover.Button>
2021-07-18 07:17:52 -07:00
<Popover.Panel className="absolute top-10 z-10">
<div className="relative bg-th-bkg-2 divide-y divide-th-bkg-3 px-4 rounded">
{linksArray.map(([name, href, isExternal]) =>
!isExternal ? (
2021-07-18 07:17:52 -07:00
<Link href={href} key={href}>
<a className="block py-3 text-th-fgd-1 whitespace-nowrap hover:text-th-primary">
{name}
</a>
</Link>
) : (
<a
className="block py-3 text-th-fgd-1 whitespace-nowrap hover:text-th-primary"
href={href}
2021-07-18 07:17:52 -07:00
key={href}
target="_blank"
rel="noopener noreferrer"
>
{name}
</a>
)
)}
</div>
</Popover.Panel>
</div>
)}
</Popover>
</div>
)
}