Files
moemail/app/components/auth/sign-button.tsx

55 lines
1.5 KiB
TypeScript

"use client"
import { Button } from "@/components/ui/button"
import Image from "next/image"
import { signOut, useSession } from "next-auth/react"
import { LogIn } from "lucide-react"
import { useRouter } from 'next/navigation'
import Link from "next/link"
import { cn } from "@/lib/utils"
interface SignButtonProps {
size?: "default" | "lg"
}
export function SignButton({ size = "default" }: SignButtonProps) {
const router = useRouter()
const { data: session, status } = useSession()
const loading = status === "loading"
if (loading) {
return <div className="h-9" />
}
if (!session?.user) {
return (
<Button onClick={() => router.push('/login')} className={cn("gap-2", size === "lg" ? "px-8" : "")} size={size}>
<LogIn className={size === "lg" ? "w-5 h-5" : "w-4 h-4"} />
/
</Button>
)
}
return (
<div className="flex items-center gap-4">
<Link
href="/profile"
className="flex items-center gap-2 hover:opacity-80 transition-opacity"
>
{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>
</Link>
<Button onClick={() => signOut({ callbackUrl: "/" })} variant="outline" className={cn("flex-shrink-0", size === "lg" ? "px-8" : "")} size={size}>
</Button>
</div>
)
}