el.xwx.moe/components/Dropdown.tsx

51 lines
1.2 KiB
TypeScript
Raw Normal View History

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-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-11 08:55:36 -05:00
className={`${className} py-1 shadow-md border border-sky-100 bg-gray-50 rounded-md flex flex-col z-10`}
2023-03-22 18:11:54 -05:00
>
{items.map((e, i) => {
2023-03-22 22:06:15 -05:00
const inner = (
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-03-22 18:11:54 -05:00
return e.href ? (
<Link key={i} href={e.href}>
2023-03-22 22:06:15 -05:00
{inner}
2023-03-22 18:11:54 -05:00
</Link>
) : (
<div key={i} onClick={e.onClick}>
2023-03-22 22:06:15 -05:00
{inner}
2023-03-22 18:11:54 -05:00
</div>
);
})}
</ClickAwayHandler>
);
}