2023-03-22 18:11:54 -05:00
|
|
|
import Link from "next/link";
|
2023-05-27 22:21:35 -05:00
|
|
|
import React, { MouseEventHandler } from "react";
|
2023-03-22 18:11:54 -05:00
|
|
|
import ClickAwayHandler from "./ClickAwayHandler";
|
|
|
|
|
2023-05-27 22:21:35 -05:00
|
|
|
type MenuItem =
|
|
|
|
| {
|
|
|
|
name: string;
|
|
|
|
onClick: MouseEventHandler;
|
|
|
|
href?: string;
|
|
|
|
}
|
|
|
|
| {
|
|
|
|
name: string;
|
|
|
|
onClick?: MouseEventHandler;
|
|
|
|
href: string;
|
2023-06-20 22:40:45 -05:00
|
|
|
}
|
|
|
|
| undefined;
|
2023-03-22 18:11:54 -05:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
onClickOutside: Function;
|
|
|
|
className?: string;
|
|
|
|
items: MenuItem[];
|
|
|
|
};
|
|
|
|
|
2023-05-27 22:21:35 -05:00
|
|
|
export default function Dropdown({ onClickOutside, className, items }: Props) {
|
2023-03-22 18:11:54 -05:00
|
|
|
return (
|
|
|
|
<ClickAwayHandler
|
|
|
|
onClickOutside={onClickOutside}
|
2023-06-20 13:38:16 -05:00
|
|
|
className={`${className} py-1 shadow-md border border-sky-100 bg-gray-50 rounded-md flex flex-col z-20`}
|
2023-03-22 18:11:54 -05:00
|
|
|
>
|
|
|
|
{items.map((e, i) => {
|
2023-06-20 22:40:45 -05:00
|
|
|
const inner = e && (
|
2023-05-27 22:21:35 -05:00
|
|
|
<div className="cursor-pointer rounded-md">
|
2023-05-28 17:06:49 -05:00
|
|
|
<div className="flex items-center gap-2 py-1 px-2 hover:bg-slate-200 duration-100">
|
2023-05-27 22:21:35 -05:00
|
|
|
<p className="text-sky-900 select-none">{e.name}</p>
|
2023-03-23 10:25:17 -05:00
|
|
|
</div>
|
2023-03-22 22:06:15 -05:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
|
2023-06-20 22:40:45 -05:00
|
|
|
return e && e.href ? (
|
2023-03-22 18:11:54 -05:00
|
|
|
<Link key={i} href={e.href}>
|
2023-03-22 22:06:15 -05:00
|
|
|
{inner}
|
2023-03-22 18:11:54 -05:00
|
|
|
</Link>
|
|
|
|
) : (
|
2023-06-20 22:40:45 -05:00
|
|
|
e && (
|
|
|
|
<div key={i} onClick={e.onClick}>
|
|
|
|
{inner}
|
|
|
|
</div>
|
|
|
|
)
|
2023-03-22 18:11:54 -05:00
|
|
|
);
|
|
|
|
})}
|
|
|
|
</ClickAwayHandler>
|
|
|
|
);
|
|
|
|
}
|