From 799bc5b8000699cf701e479f1508c889ee64c7a3 Mon Sep 17 00:00:00 2001 From: Clearsu Date: Thu, 16 Nov 2023 13:21:43 +0900 Subject: [PATCH] =?UTF-8?q?[Feat]=20=EB=AC=B4=ED=95=9C=EC=8A=A4=ED=81=AC?= =?UTF-8?q?=EB=A1=A4=20=EC=A0=9C=EB=84=A4=EB=A6=AD=20=ED=95=A8=EC=88=98=20?= =?UTF-8?q?#1092?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- utils/infinityScroll.ts | 34 ++++++++++++++++++++++++++++++++++ 1 file changed, 34 insertions(+) diff --git a/utils/infinityScroll.ts b/utils/infinityScroll.ts index 694574e2e..ae604aad1 100644 --- a/utils/infinityScroll.ts +++ b/utils/infinityScroll.ts @@ -53,3 +53,37 @@ export function InfinityScroll( } ); } + +interface PagenatedResponse { + totalPage: number; +} + +// 무한스크롤 제네릭 함수 +// Todo: 이 함수로 프로젝트 내 무한스크롤 모두 대체 +export function InfiniteScroll( + queryKey: string | string[], + fetchFunction: (page: number) => Promise, + errorCode: string +) { + const setError = useSetRecoilState(errorState); + return useInfiniteQuery( + queryKey, + ({ pageParam = 1 }) => fetchFunction(pageParam), + { + getNextPageParam: (lastPage, allPages) => { + const nextPage = allPages.length + 1; + return nextPage > lastPage.totalPage ? undefined : nextPage; + }, + onError: (e: unknown) => { + if (axios.isAxiosError(e)) { + setError(errorCode); + } else { + // axios에서 발생한 에러가 아닌 경우 + setError('JY03'); + } + }, + retry: 0, + keepPreviousData: true, + } + ); +}