实现登出
This commit is contained in:
@@ -27,10 +27,11 @@ import {
|
|||||||
useSidebar,
|
useSidebar,
|
||||||
} from "@/components/ui/sidebar"
|
} from "@/components/ui/sidebar"
|
||||||
import useSWR from "swr"
|
import useSWR from "swr"
|
||||||
import { UserApi } from "@/lib/api"
|
import { authApi, UserApi } from "@/lib/api"
|
||||||
import { Skeleton } from "./ui/skeleton"
|
import { Skeleton } from "./ui/skeleton"
|
||||||
import { toast } from "sonner"
|
import { toast } from "sonner"
|
||||||
import { useRouter } from "next/navigation"
|
import { useRouter } from "next/navigation"
|
||||||
|
import { ApiError } from "next/dist/server/api-utils"
|
||||||
|
|
||||||
export function NavUser({ }: {}) {
|
export function NavUser({ }: {}) {
|
||||||
const { isMobile } = useSidebar();
|
const { isMobile } = useSidebar();
|
||||||
@@ -41,7 +42,7 @@ export function NavUser({ }: {}) {
|
|||||||
() => UserApi.me(),
|
() => UserApi.me(),
|
||||||
{
|
{
|
||||||
onError: (error) => {
|
onError: (error) => {
|
||||||
if (`${error}`.includes('Unauthorized')) {
|
if (error.statusCode === 401) {
|
||||||
localStorage.removeItem('token');
|
localStorage.removeItem('token');
|
||||||
toast.info('登录凭证已失效,请重新登录');
|
toast.info('登录凭证已失效,请重新登录');
|
||||||
router.replace('/console/login');
|
router.replace('/console/login');
|
||||||
@@ -50,6 +51,16 @@ export function NavUser({ }: {}) {
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
async function logout() {
|
||||||
|
try {
|
||||||
|
await authApi.logout();
|
||||||
|
localStorage.removeItem('token');
|
||||||
|
toast.success('登出成功');
|
||||||
|
router.replace('/console/login');
|
||||||
|
} catch (error) {
|
||||||
|
toast.error('登出失败,请稍后再试');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<SidebarMenu>
|
<SidebarMenu>
|
||||||
@@ -124,7 +135,7 @@ export function NavUser({ }: {}) {
|
|||||||
修改密码
|
修改密码
|
||||||
</DropdownMenuItem>
|
</DropdownMenuItem>
|
||||||
<DropdownMenuSeparator />
|
<DropdownMenuSeparator />
|
||||||
<DropdownMenuItem>
|
<DropdownMenuItem onClick={logout}>
|
||||||
<LogOut />
|
<LogOut />
|
||||||
登出
|
登出
|
||||||
</DropdownMenuItem>
|
</DropdownMenuItem>
|
||||||
|
|||||||
@@ -1 +1,2 @@
|
|||||||
export * from './login';
|
export * from './login';
|
||||||
|
export * from './logout';
|
||||||
5
tone-page-web/lib/api/auth/logout.ts
Normal file
5
tone-page-web/lib/api/auth/logout.ts
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
import fetcher from "../fetcher";
|
||||||
|
|
||||||
|
export async function logout() {
|
||||||
|
return fetcher('/api/auth/logout', { method: 'POST' });
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user