From 7e6dc551fe39ca4849d6fdd4947663249ffc7907 Mon Sep 17 00:00:00 2001 From: Jealous Date: Tue, 7 Jan 2025 22:19:53 +0800 Subject: [PATCH] fix(request): abort obj request after going to new path --- src/hooks/usePath.ts | 14 ++++++++++++-- src/utils/api.ts | 15 +++++++++++---- 2 files changed, 23 insertions(+), 6 deletions(-) diff --git a/src/hooks/usePath.ts b/src/hooks/usePath.ts index fe93febff..da4fe163f 100644 --- a/src/hooks/usePath.ts +++ b/src/hooks/usePath.ts @@ -22,6 +22,7 @@ import { useRouter } from "./useRouter" let first_fetch = true +let cancelObj: Canceler let cancelList: Canceler export function addOrUpdateQuery( key: string, @@ -79,7 +80,15 @@ export const resetGlobalPage = () => { } export const usePath = () => { const { pathname, to } = useRouter() - const [, getObj] = useFetch((path: string) => fsGet(path, password())) + const [, getObj] = useFetch((path: string) => + fsGet( + path, + password(), + new axios.CancelToken((c) => { + cancelObj = c + }), + ), + ) const pagination = getPagination() if (pagination.type === "pagination" && getQueryVariable("page")) { globalPage = parseInt(getQueryVariable("page")) @@ -102,7 +111,7 @@ export const usePath = () => { page.index, page.size, arg?.force, - new axios.CancelToken(function executor(c) { + new axios.CancelToken((c) => { cancelList = c }), ) @@ -127,6 +136,7 @@ export const usePath = () => { // if not, fetch get then determine if it is dir or file const handlePathChange = (path: string, rp?: boolean, force?: boolean) => { log(`handle [${path}] change`) + cancelObj?.() cancelList?.() retry_pass = rp ?? false handleErr("") diff --git a/src/utils/api.ts b/src/utils/api.ts index bd7bb34a4..31bb4f4d2 100644 --- a/src/utils/api.ts +++ b/src/utils/api.ts @@ -13,11 +13,18 @@ import { r } from "." export const fsGet = ( path: string = "/", password = "", + cancelToken?: CancelToken, ): Promise => { - return r.post("/fs/get", { - path: path, - password: password, - }) + return r.post( + "/fs/get", + { + path: path, + password: password, + }, + { + cancelToken: cancelToken, + }, + ) } export const fsList = ( path: string = "/",