From 270451cf7833221ba6763e0cf247262d7c2d20aa Mon Sep 17 00:00:00 2001 From: Lawrene Jang Date: Fri, 18 Oct 2024 14:28:54 +0900 Subject: [PATCH 1/2] =?UTF-8?q?=F0=9F=90=9B=20fix:=20update=20not=20found?= =?UTF-8?q?=20lecture=20align?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/app/page.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/app/page.tsx b/src/app/page.tsx index b6e2e7f..7ccbd1e 100755 --- a/src/app/page.tsx +++ b/src/app/page.tsx @@ -364,7 +364,7 @@ const Home = () => { 조회 수 많은 추천 클래스를 소개할게요! -
+
{renderPickLectureList()}
From 6bb0a9cf13b3274ad07f1ba109ecfd8eb123a9e8 Mon Sep 17 00:00:00 2001 From: Lawrene Jang Date: Fri, 18 Oct 2024 14:56:18 +0900 Subject: [PATCH 2/2] =?UTF-8?q?=F0=9F=90=9B=20fix:=20update=20qa=20bug=20f?= =?UTF-8?q?ix?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/app/page.tsx | 27 +++++++++++++++++++ .../Header/HeaderFeatures/HeaderFeatures.tsx | 2 +- 2 files changed, 28 insertions(+), 1 deletion(-) diff --git a/src/app/page.tsx b/src/app/page.tsx index 7ccbd1e..6453590 100755 --- a/src/app/page.tsx +++ b/src/app/page.tsx @@ -26,11 +26,14 @@ import { ChipStatus } from "@/shared/ui/Chip/Chip"; import { LoginUserInfo } from "@/entities/user/model/user"; import Map from "@/features/map/ui/Map/Map"; import MapSkeleton from "@/features/map/ui/MapSkeleton/MapSkeleton"; +import { deleteCookie } from "cookies-next"; import { useCarouselApi } from "@/shared/lib/useCarouselApi"; import { useGeoLocation } from "@/shared/lib/useGeolocation"; +import useGetLoginUserInfo from "@/entities/user/api/useGetLoginUserInfo"; import useHomeLectureList from "@/entities/lecture/api/useHomeLectureList"; import useLocationLectureList from "@/entities/lecture/api/useLocationLectureList"; import useLoginedUserStore from "@/shared/store/user"; +import { useQueryClient } from "@tanstack/react-query"; import { useRouter } from "next/navigation"; const Home = () => { @@ -79,6 +82,10 @@ const Home = () => { const { loginedUser: loginedUserState, setLoginedUser: setLoginedUserStore } = useLoginedUserStore(); + const queryClient = useQueryClient(); + const { data: loginUserData, isSuccess: isLoginUserSuccess } = + useGetLoginUserInfo(); + const { data: locationLectureListData, isLoading: isLocationLectureListLoading, @@ -91,6 +98,8 @@ const Home = () => { data: homeLectureList, isLoading, isSuccess, + isError, + error, refetch, } = useHomeLectureList({ page: lectureSize.page, @@ -101,6 +110,15 @@ const Home = () => { const router = useRouter(); + const { setLoginedUser } = useLoginedUserStore(); + + // FIXME: 유저 정보 업데이트를 여기서 하는게 맞는지.. + useEffect(() => { + if (isLoginUserSuccess) { + setLoginedUser(loginUserData.data.data); + } + }, []); + useEffect(() => { if ( geolocation.curLocation && @@ -148,6 +166,14 @@ const Home = () => { setPickLectureListData(pickLectureListData); setMarkerLectureListData(markerLectureListData); } + if (isError) { + // TODO: 임시 방편 쿠키 만료 됐을 때 유효한지 체크 후 재발급 해주는 API 필요 + if (error.message === "Request failed with status code 401") { + deleteCookie("accessToken"); + deleteCookie("refreshToken"); + queryClient.clear(); + } + } }, [ user, homeLectureList, @@ -155,6 +181,7 @@ const Home = () => { homeLectureList?.data.markerClasses, homeLectureList?.data.pickClasses, isSuccess, + isError, ]); useEffect(() => { diff --git a/src/shared/ui/Header/HeaderFeatures/HeaderFeatures.tsx b/src/shared/ui/Header/HeaderFeatures/HeaderFeatures.tsx index 370d55e..50a6518 100755 --- a/src/shared/ui/Header/HeaderFeatures/HeaderFeatures.tsx +++ b/src/shared/ui/Header/HeaderFeatures/HeaderFeatures.tsx @@ -123,7 +123,7 @@ const HeaderFeatures = () => { ) { return (
- +