55 lines
1.3 KiB
TypeScript

"use client";
import { redirect } from "next/navigation";
import Link from "next/link";
import { signOut, useSession } from "next-auth/react";
import { useEffect, useState } from "react";
import axios from "axios";
export default function Home() {
const { data: session, status } = useSession();
const [previousUsername, setPreviousUsername] = useState<string>()
// if (status !== "authenticated") {
// redirect('/api/auth/signin?redirectUrl=/');
// }
useEffect(() => {
if (status !== "authenticated" || previousUsername == session.user?.name) {
return
}
setPreviousUsername(session.user?.name as string)
async function saveAccount() {
await axios.post("/api/account")
}
saveAccount().catch(console.error)
}, [])
return (
<main
style={{
display: "flex",
justifyContent: "center",
alignItems: "center",
height: "70vh",
}}
>
<div className="header">
{session && (
<Link href="#" onClick={() => signOut()} className="btn-signin">
Sign out
</Link>
)}
{!session && (
<Link href="/auth/login" className="btn-signin">
Sign in
</Link>
)}
</div>
</main>
);
}