link-stack/metamigo-frontend/components/Auth.tsx

21 lines
550 B
TypeScript
Raw Normal View History

2023-02-13 12:41:30 +00:00
import { FC, PropsWithChildren, useEffect } from "react";
import { CircularProgress } from "@material-ui/core";
import { useSession } from "next-auth/react";
import { useRouter } from "next/router";
export const Auth: FC<PropsWithChildren> = ({ children }) => {
const router = useRouter();
const { data: session, status: loading } = useSession();
useEffect(() => {
if (!session && !loading) {
router.push("/login");
}
}, [session, loading]);
if (loading) {
return <CircularProgress />;
}
return <>{children}</>;
};