el.xwx.moe/layouts/SettingsLayout.tsx

74 lines
2.0 KiB
TypeScript
Raw Normal View History

import SettingsSidebar from "@/components/SettingsSidebar";
2023-12-17 03:32:33 -06:00
import React, { ReactNode, useEffect, useState } from "react";
import { useRouter } from "next/router";
import ClickAwayHandler from "@/components/ClickAwayHandler";
import Link from "next/link";
2023-10-23 09:45:48 -05:00
import useWindowDimensions from "@/hooks/useWindowDimensions";
interface Props {
children: ReactNode;
}
export default function SettingsLayout({ children }: Props) {
const router = useRouter();
const [sidebar, setSidebar] = useState(false);
2023-10-23 09:45:48 -05:00
const { width } = useWindowDimensions();
useEffect(() => {
setSidebar(false);
}, [width]);
useEffect(() => {
setSidebar(false);
}, [router]);
const toggleSidebar = () => {
setSidebar(!sidebar);
};
return (
<>
2023-10-18 16:50:55 -05:00
<div className="flex max-w-screen-md mx-auto">
2023-10-19 00:37:00 -05:00
<div className="hidden lg:block fixed h-screen">
<SettingsSidebar />
</div>
2023-11-20 11:48:41 -06:00
<div className="w-full min-h-screen p-5 lg:ml-64">
<div className="gap-2 inline-flex mr-3">
<div
onClick={toggleSidebar}
2023-11-27 15:38:38 -06:00
className="text-neutral btn btn-square btn-sm btn-ghost lg:hidden"
>
2023-12-17 22:32:33 -06:00
<i className="bi-list text-2xl leading-none"></i>
</div>
<Link
href="/dashboard"
2023-11-27 15:38:38 -06:00
className="text-neutral btn btn-square btn-sm btn-ghost"
>
2023-12-17 22:32:33 -06:00
<i className="bi-chevron-left text-xl"></i>
</Link>
</div>
2023-10-18 16:50:55 -05:00
{children}
{sidebar ? (
2023-11-25 04:54:43 -06:00
<div className="fixed top-0 bottom-0 right-0 left-0 bg-black bg-opacity-10 backdrop-blur-sm flex items-center fade-in z-30">
<ClickAwayHandler
className="h-full"
onClickOutside={toggleSidebar}
>
<div className="slide-right h-full shadow-lg">
<SettingsSidebar />
</div>
</ClickAwayHandler>
</div>
) : null}
</div>
</div>
</>
);
}