mirror of
https://github.com/beilunyang/moemail.git
synced 2025-12-24 11:30:51 +08:00
58 lines
1.7 KiB
TypeScript
58 lines
1.7 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 { useTranslations, useLocale } from "next-intl"
|
|
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 locale = useLocale()
|
|
const { data: session, status } = useSession()
|
|
const t = useTranslations("auth.signButton")
|
|
const loading = status === "loading"
|
|
|
|
if (loading) {
|
|
return <div className="h-9" />
|
|
}
|
|
|
|
if (!session?.user) {
|
|
return (
|
|
<Button onClick={() => router.push(`/${locale}/login`)} className={cn("gap-2", size === "lg" ? "px-8" : "")} size={size}>
|
|
<LogIn className={size === "lg" ? "w-5 h-5" : "w-4 h-4"} />
|
|
{t("login")}
|
|
</Button>
|
|
)
|
|
}
|
|
|
|
return (
|
|
<div className="flex items-center gap-y-4 gap-x-3 sm:gap-x-4">
|
|
<Link
|
|
href={`/${locale}/profile`}
|
|
className="flex items-center gap-2 hover:opacity-80 transition-opacity"
|
|
>
|
|
{session.user.image && (
|
|
<Image
|
|
src={session.user.image}
|
|
alt={session.user.name || t("userAvatar")}
|
|
width={24}
|
|
height={24}
|
|
className="rounded-full"
|
|
/>
|
|
)}
|
|
<span className="hidden sm:inline-block text-sm">{session.user.name}</span>
|
|
</Link>
|
|
<Button onClick={() => signOut({ callbackUrl: `/${locale}` })} variant="outline" className={cn("flex-shrink-0", size === "lg" ? "px-8" : "")} size={size}>
|
|
{t("logout")}
|
|
</Button>
|
|
</div>
|
|
)
|
|
}
|