Files
Open-Assistant/website/src/components/AdminArea.tsx
T
2023-02-10 18:18:48 +09:00

23 lines
598 B
TypeScript

import { useRouter } from "next/router";
import { useSession } from "next-auth/react";
import { ReactNode, useEffect } from "react";
export const AdminArea = ({ children }: { children: ReactNode }) => {
const router = useRouter();
const { data: session, status } = useSession();
useEffect(() => {
if (status === "loading") {
return;
}
const role = session?.user.role;
if (role === "admin" || role === "moderator") {
return;
}
router.push("/");
}, [router, session, status]);
return <main>{status === "loading" ? "loading..." : children}</main>;
};