2023-12-17 03:08:12 -06:00
|
|
|
import React, { MouseEventHandler, ReactNode } from "react";
|
2023-03-28 02:31:50 -05:00
|
|
|
import ClickAwayHandler from "@/components/ClickAwayHandler";
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
toggleModal: Function;
|
|
|
|
children: ReactNode;
|
2023-06-09 17:31:14 -05:00
|
|
|
className?: string;
|
2023-03-28 02:31:50 -05:00
|
|
|
};
|
|
|
|
|
2023-06-09 17:31:14 -05:00
|
|
|
export default function Modal({ toggleModal, className, children }: Props) {
|
2023-03-28 02:31:50 -05:00
|
|
|
return (
|
2023-12-06 23:33:05 -06:00
|
|
|
<div className="overflow-y-auto pt-2 sm:py-2 fixed top-0 bottom-0 right-0 left-0 bg-black bg-opacity-10 backdrop-blur-sm flex justify-center items-center fade-in z-30">
|
2023-06-09 17:31:14 -05:00
|
|
|
<ClickAwayHandler
|
|
|
|
onClickOutside={toggleModal}
|
2023-12-06 23:33:05 -06:00
|
|
|
className={`w-full mt-auto sm:m-auto sm:w-11/12 sm:max-w-2xl ${
|
|
|
|
className || ""
|
|
|
|
}`}
|
2023-06-09 17:31:14 -05:00
|
|
|
>
|
2023-12-06 23:33:05 -06:00
|
|
|
<div className="slide-up mt-auto sm:m-auto relative border-neutral-content rounded-t-2xl sm:rounded-2xl border-t sm:border shadow-2xl p-5 bg-base-100">
|
2023-05-01 05:07:01 -05:00
|
|
|
<div
|
|
|
|
onClick={toggleModal as MouseEventHandler<HTMLDivElement>}
|
2023-12-17 03:08:12 -06:00
|
|
|
className="absolute top-4 right-3 btn btn-sm outline-none btn-circle btn-ghost z-10"
|
2023-05-01 05:07:01 -05:00
|
|
|
>
|
2023-12-17 03:08:12 -06:00
|
|
|
<i
|
|
|
|
className="bi-x text-neutral text-2xl"
|
|
|
|
></i>
|
2023-05-01 05:07:01 -05:00
|
|
|
</div>
|
2023-03-28 02:31:50 -05:00
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</ClickAwayHandler>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|