"use client" import { ChevronsUpDown, KeyRound, LogOut, UserRoundCog, } from "lucide-react" import { Avatar, AvatarFallback, AvatarImage, } from "@/components/ui/avatar" import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuLabel, DropdownMenuSeparator, DropdownMenuTrigger, } from "@/components/ui/dropdown-menu" import { SidebarMenu, SidebarMenuButton, SidebarMenuItem, useSidebar, } from "@/components/ui/sidebar" import { authApi } from "@/lib/api" import { Skeleton } from "./ui/skeleton" import { toast } from "sonner" import { useRouter } from "next/navigation" import SetPassword from "./nav-user/SetPassword" import { useState } from "react" import { User } from "@/lib/types/user" export function NavUser({ user, isUserLoading }: { user: User | undefined, isUserLoading: boolean }) { const { isMobile } = useSidebar(); const router = useRouter(); async function logout() { try { await authApi.logout(); localStorage.removeItem('token'); toast.success('登出成功'); router.replace('/console/login'); } catch (error) { toast.error('登出失败,请稍后再试'); } } const [passwordOpen, setPasswordOpen] = useState(false); return ( <> { user && <> U
{user.nickname} {user.username}
} { isUserLoading &&
}
{ user &&
U
{user.nickname} {user.username}
} { isUserLoading &&
}
账户信息 setTimeout(() => { setPasswordOpen(true) }, 0)}> 修改密码 登出
) }