Files
moemail/app/components/auth/sign-button.tsx
T
beilunyang cc7e5003c5 feat: Init
2024-12-16 01:49:50 +08:00

44 lines
1.1 KiB
TypeScript

"use client"
import { Button } from "@/components/ui/button"
import Image from "next/image"
import { signIn, signOut, useSession } from "next-auth/react"
import { Github } from "lucide-react"
export function SignButton() {
const { data: session, status } = useSession()
const loading = status === "loading"
if (loading) {
return <div className="h-9" /> // 防止布局跳动
}
if (!session?.user) {
return (
<Button onClick={() => signIn("github", { callbackUrl: "/moe" })} className="gap-2">
<Github className="w-4 h-4" />
使 GitHub
</Button>
)
}
return (
<div className="flex items-center gap-4">
<div className="flex items-center gap-2">
{session.user.image && (
<Image
src={session.user.image}
alt={session.user.name || "用户头像"}
width={24}
height={24}
className="rounded-full"
/>
)}
<span className="text-sm">{session.user.name}</span>
</div>
<Button onClick={() => signOut({ callbackUrl: "/" })} variant="outline">
</Button>
</div>
)
}