From 7e3bef73772523539eacd77bb0f4f42d33374122 Mon Sep 17 00:00:00 2001 From: itsHenry <2671230065@qq.com> Date: Sun, 4 Aug 2024 12:34:24 +0800 Subject: [PATCH] feat: invalidate token on logout (#191) --- src/pages/manage/Header.tsx | 22 +++++++++++++++------- 1 file changed, 15 insertions(+), 7 deletions(-) diff --git a/src/pages/manage/Header.tsx b/src/pages/manage/Header.tsx index b9438e7093..2d04ce62a0 100644 --- a/src/pages/manage/Header.tsx +++ b/src/pages/manage/Header.tsx @@ -17,15 +17,26 @@ import { import { TiThMenu } from "solid-icons/ti" import { IoExit } from "solid-icons/io" import { SwitchColorMode, SwitchLanguageWhite } from "~/components" -import { useRouter, useT } from "~/hooks" +import { useFetch, useRouter, useT } from "~/hooks" import { SideMenu } from "./SideMenu" import { side_menu_items } from "./sidemenu_items" -import { changeToken, notify } from "~/utils" +import { changeToken, handleResp, notify, r } from "~/utils" +import { PResp } from "~/types" const { isOpen, onOpen, onClose } = createDisclosure() +const [logOutReqLoading, logOutReq] = useFetch( + (): PResp => r.get("/auth/logout"), +) const Header = () => { const t = useT() const { to } = useRouter() + const logOut = async () => { + handleResp(await logOutReq(), () => { + changeToken() + notify.success(t("manage.logout_success")) + to(`/@login?redirect=${encodeURIComponent(location.pathname)}`) + }) + } return ( { } - onClick={() => { - changeToken() - notify.success(t("manage.logout_success")) - to(`/@login?redirect=${encodeURIComponent(location.pathname)}`) - }} + loading={logOutReqLoading()} + onClick={logOut} size="sm" />