2024-08-18 01:55:59 -05:00
|
|
|
import React, { ReactNode, useEffect } from "react";
|
|
|
|
import { Drawer as D } from "vaul";
|
2024-11-07 10:09:36 -06:00
|
|
|
import clsx from "clsx";
|
2024-08-18 01:55:59 -05:00
|
|
|
|
|
|
|
type Props = {
|
|
|
|
toggleDrawer: Function;
|
|
|
|
children: ReactNode;
|
|
|
|
className?: string;
|
|
|
|
dismissible?: boolean;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default function Drawer({
|
|
|
|
toggleDrawer,
|
|
|
|
className,
|
|
|
|
children,
|
|
|
|
dismissible = true,
|
|
|
|
}: Props) {
|
|
|
|
const [drawerIsOpen, setDrawerIsOpen] = React.useState(true);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (window.innerWidth >= 640) {
|
|
|
|
document.body.style.overflow = "hidden";
|
|
|
|
document.body.style.position = "relative";
|
|
|
|
return () => {
|
|
|
|
document.body.style.overflow = "auto";
|
|
|
|
document.body.style.position = "";
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
if (window.innerWidth < 640) {
|
|
|
|
return (
|
|
|
|
<D.Root
|
|
|
|
open={drawerIsOpen}
|
2024-11-07 10:09:36 -06:00
|
|
|
onClose={() => dismissible && setDrawerIsOpen(false)}
|
|
|
|
onAnimationEnd={(isOpen) => !isOpen && toggleDrawer()}
|
2024-08-18 01:55:59 -05:00
|
|
|
dismissible={dismissible}
|
|
|
|
>
|
|
|
|
<D.Portal>
|
|
|
|
<D.Overlay className="fixed inset-0 bg-black/40" />
|
2024-11-07 10:09:36 -06:00
|
|
|
<D.Content className="flex flex-col rounded-t-2xl mt-24 fixed bottom-0 left-0 right-0 z-30 h-[90%]">
|
|
|
|
<div
|
|
|
|
className={clsx(
|
|
|
|
"p-4 bg-base-100 rounded-t-2xl flex-1 border-neutral-content border-t overflow-y-auto",
|
|
|
|
className
|
|
|
|
)}
|
|
|
|
data-testid="mobile-modal-container"
|
|
|
|
>
|
|
|
|
<div data-testid="mobile-modal-slider" />
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</D.Content>
|
2024-08-18 01:55:59 -05:00
|
|
|
</D.Portal>
|
|
|
|
</D.Root>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
return (
|
|
|
|
<D.Root
|
|
|
|
open={drawerIsOpen}
|
2024-11-07 10:09:36 -06:00
|
|
|
onClose={() => dismissible && setDrawerIsOpen(false)}
|
|
|
|
onAnimationEnd={(isOpen) => !isOpen && toggleDrawer()}
|
2024-08-18 01:55:59 -05:00
|
|
|
dismissible={dismissible}
|
|
|
|
direction="right"
|
|
|
|
>
|
|
|
|
<D.Portal>
|
|
|
|
<D.Overlay className="fixed inset-0 bg-black/10 z-20" />
|
2024-11-07 10:09:36 -06:00
|
|
|
<D.Content className="bg-white flex flex-col h-full w-2/5 min-w-[30rem] mt-24 fixed bottom-0 right-0 z-40 !select-auto">
|
|
|
|
<div
|
|
|
|
className={clsx(
|
|
|
|
"p-4 bg-base-100 flex-1 border-neutral-content border-l overflow-y-auto",
|
|
|
|
className
|
|
|
|
)}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</div>
|
|
|
|
</D.Content>
|
2024-08-18 01:55:59 -05:00
|
|
|
</D.Portal>
|
|
|
|
</D.Root>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|