el.xwx.moe/components/Modal/index.tsx

35 lines
1.3 KiB
TypeScript
Raw Normal View History

2023-05-01 05:07:01 -05:00
import { MouseEventHandler, ReactNode } from "react";
2023-03-28 02:31:50 -05:00
import ClickAwayHandler from "@/components/ClickAwayHandler";
2023-05-01 05:07:01 -05:00
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { faChevronLeft } from "@fortawesome/free-solid-svg-icons";
2023-03-28 02:31:50 -05:00
type Props = {
toggleModal: Function;
children: ReactNode;
className?: string;
2023-03-28 02:31:50 -05:00
};
export default function Modal({ toggleModal, className, children }: Props) {
2023-03-28 02:31:50 -05:00
return (
2023-08-01 15:20:05 -05:00
<div className="overflow-y-auto py-2 fixed top-0 bottom-0 right-0 left-0 bg-gray-500 bg-opacity-10 backdrop-blur-sm flex justify-center items-center fade-in z-30">
<ClickAwayHandler
onClickOutside={toggleModal}
2023-10-28 11:50:11 -05:00
className={`m-auto ${className || ""}`}
>
2023-08-14 22:25:25 -05:00
<div className="slide-up relative border-sky-100 dark:border-neutral-700 rounded-2xl border-solid border shadow-lg p-5 bg-white dark:bg-neutral-900">
2023-05-01 05:07:01 -05:00
<div
onClick={toggleModal as MouseEventHandler<HTMLDivElement>}
2023-08-14 22:25:25 -05:00
className="absolute top-5 left-5 inline-flex rounded-md cursor-pointer hover:bg-slate-200 hover:dark:bg-neutral-700 duration-100 z-20 p-2"
2023-05-01 05:07:01 -05:00
>
<FontAwesomeIcon
icon={faChevronLeft}
2023-08-22 17:34:46 -05:00
className="w-4 h-4 text-gray-500 dark:text-gray-300"
2023-05-01 05:07:01 -05:00
/>
</div>
2023-03-28 02:31:50 -05:00
{children}
</div>
</ClickAwayHandler>
</div>
);
}