el.xwx.moe/components/Dropdown.tsx

54 lines
1.9 KiB
TypeScript
Raw Normal View History

2023-04-23 08:26:39 -05:00
// Copyright (C) 2022-present Daniel31x13 <daniel31x13@gmail.com>
// This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 3.
// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
// You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
2023-03-22 18:11:54 -05:00
import Link from "next/link";
import React, { MouseEventHandler, ReactElement } from "react";
import ClickAwayHandler from "./ClickAwayHandler";
type MenuItem = {
name: string;
icon: ReactElement;
onClick?: MouseEventHandler;
href?: string;
};
type Props = {
onClickOutside: Function;
className?: string;
items: MenuItem[];
};
export default function ({ onClickOutside, className, items }: Props) {
return (
<ClickAwayHandler
onClickOutside={onClickOutside}
2023-04-23 08:26:39 -05:00
className={`${className} border border-sky-100 shadow-md mb-5 bg-gray-50 rounded-md flex flex-col`}
2023-03-22 18:11:54 -05:00
>
{items.map((e, i) => {
2023-03-22 22:06:15 -05:00
const inner = (
2023-03-25 09:17:34 -05:00
<div className="cursor-pointer rounded-md hover:bg-white hover:outline outline-sky-100 outline-1 duration-100">
<div className="flex items-center gap-2 p-2 rounded-md hover:opacity-60 duration-100">
2023-03-23 10:25:17 -05:00
{React.cloneElement(e.icon, {
className: "text-sky-500 w-5 h-5",
})}
<p className="text-sky-900">{e.name}</p>
</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>
);
}