"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 useSWR from "swr" import { authApi, UserApi } from "@/lib/api" import { Skeleton } from "./ui/skeleton" import { toast } from "sonner" import { useRouter } from "next/navigation" import { ApiError } from "next/dist/server/api-utils" import SetPassword from "./nav-user/SetPassword" import { useState } from "react" export function NavUser({ }: {}) { const { isMobile } = useSidebar(); const router = useRouter(); const { data: user, isLoading, error } = useSWR( '/api/user/me', () => UserApi.me(), { onError: (error) => { if (error.statusCode === 401) { localStorage.removeItem('token'); toast.info('登录凭证已失效,请重新登录'); router.replace('/console/login'); } } } ); if (!isLoading && !error && !user) { router.replace('/console/login'); localStorage.removeItem('token'); toast.error('账户状态异常,请重新登录'); } 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}
} { isLoading &&
}
{ user &&
U
{user.nickname} {user.username}
} { isLoading &&
}
账户信息 setPasswordOpen(true)}> 修改密码 登出
) }