Skip to content

Commit

Permalink
Feat: 로그아웃 상태에서 페이지 접근시 로그인 페이지로 리다이렉트 하는 커스텀 훅 구현 및 적용
Browse files Browse the repository at this point in the history
  • Loading branch information
김보민 authored and 김보민 committed Jul 23, 2024
1 parent 5b73fff commit 904ad51
Show file tree
Hide file tree
Showing 7 changed files with 34 additions and 10 deletions.
15 changes: 15 additions & 0 deletions hooks/useAuthRedirect.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
import { useRouter } from 'next/router';
import { useEffect } from 'react';
import { usePopup } from './usePopup';
import useLoginState from './useLoginState';

export default function useAuthRedirect() {
const router = useRouter();

useEffect(() => {
const refreshToken = localStorage.getItem('refreshToken');
if (!refreshToken) {
router.push('/login');
}
}, [router]);
}
3 changes: 3 additions & 0 deletions pages/calendar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import { darkModeState } from '@/states/themeState';
import { InitialPageMeta } from '@/components/MetaData/MetaData';
import { GetServerSideProps } from 'next';
import { SSRMetaProps } from '@/components/MetaData/MetaData.type';
import useAuthRedirect from '@/hooks/useAuthRedirect';

export const getServerSideProps: GetServerSideProps = async () => {
const OGTitle = '예약현황 | GLOBALNOMAD';
Expand All @@ -32,6 +33,8 @@ export default function CalendarPage({ OGTitle, OGUrl }: SSRMetaProps) {
const [activityId, setActivityId] = useState<number | null>(null);
const [isOpen, setIsOpen] = useRecoilState(sideNavigationState);
const [isDarkMode, setIsDarkMode] = useRecoilState(darkModeState);
// 로그아웃 상태에서 페이지 접근시 로그인 페이지로 redirect
useAuthRedirect();

const openSideNavigation = () => {
setIsOpen(!isOpen);
Expand Down
3 changes: 3 additions & 0 deletions pages/myactivity/edit.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import { getActivityInfo } from '../api/activities/apiactivities';
import { GetServerSideProps } from 'next';
import { InitialPageMeta } from '@/components/MetaData/MetaData';
import { SSRMetaProps } from '@/components/MetaData/MetaData.type';
import useAuthRedirect from '@/hooks/useAuthRedirect';

export const getServerSideProps: GetServerSideProps = async () => {
const OGTitle = '내 체험 수정 | GLOBALNOMAD';
Expand All @@ -20,6 +21,8 @@ export const getServerSideProps: GetServerSideProps = async () => {

function EditMyActivity({ OGTitle, OGUrl }: SSRMetaProps) {
const { query } = useRouter();
// 로그아웃 상태에서 페이지 접근시 로그인 페이지로 redirect
useAuthRedirect();
const id = Number(query.activityId);
const { data: activityData } = useQuery<getActivityInfoResponse>({
queryKey: ['activityDetailsEdit', id],
Expand Down
3 changes: 3 additions & 0 deletions pages/myactivity/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import { darkModeState } from '@/states/themeState';
import { InitialPageMeta } from '@/components/MetaData/MetaData';
import { GetServerSideProps } from 'next';
import { SSRMetaProps } from '@/components/MetaData/MetaData.type';
import useAuthRedirect from '@/hooks/useAuthRedirect';

export const getServerSideProps: GetServerSideProps = async () => {
const OGTitle = '내 체험 관리 | GLOBALNOMAD';
Expand All @@ -34,6 +35,8 @@ function MyActivity({ OGTitle, OGUrl }: SSRMetaProps) {
useMyActivityList();
const [isOpen, setIsOpen] = useRecoilState(sideNavigationState);
const [isDarkMode, setIsDarkMode] = useRecoilState(darkModeState);
// 로그아웃 상태에서 페이지 접근시 로그인 페이지로 redirect
useAuthRedirect();

const openSideNavigation = () => {
setIsOpen(!isOpen);
Expand Down
4 changes: 4 additions & 0 deletions pages/myactivity/register.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import { InitialPageMeta } from '@/components/MetaData/MetaData';
import { SSRMetaProps } from '@/components/MetaData/MetaData.type';
import RegisterForm from '@/components/MyActivity/Register/RegisterForm';
import useAuthRedirect from '@/hooks/useAuthRedirect';
import { GetServerSideProps } from 'next';

export const getServerSideProps: GetServerSideProps = async () => {
Expand All @@ -15,6 +16,9 @@ export const getServerSideProps: GetServerSideProps = async () => {
};

function RegisterActivity({ OGTitle, OGUrl }: SSRMetaProps) {
// 로그아웃 상태에서 페이지 접근시 로그인 페이지로 redirect
useAuthRedirect();

return (
<>
<InitialPageMeta title={OGTitle} url={OGUrl} />
Expand Down
13 changes: 3 additions & 10 deletions pages/mypage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { SSRMetaProps } from '@/components/MetaData/MetaData.type';
import MyPageInput from '@/components/MyPageInput/MyPageInput';
import SidenNavigation from '@/components/SideNavigation/SideNavigation';
import SidenNavigationMobile from '@/components/SideNavigation/SideNavigationMobile';
import useAuthRedirect from '@/hooks/useAuthRedirect';
import useLoginState from '@/hooks/useLoginState';
import { useSideNavigation } from '@/hooks/useSideNavigation';
import { GetServerSideProps } from 'next';
Expand All @@ -24,16 +25,8 @@ export default function MyPage({ OGTitle, OGUrl }: SSRMetaProps) {
const route = useRouter();
const { isLoggedIn } = useLoginState();
const { isOpen } = useSideNavigation();

useEffect(() => {
if (!isLoggedIn) {
route.push('/login');
}
}, [isLoggedIn, route]);

if (!isLoggedIn) {
return null;
}
// 로그아웃 상태에서 페이지 접근시 로그인 페이지로 redirect
useAuthRedirect();

return (
<>
Expand Down
3 changes: 3 additions & 0 deletions pages/reservation.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import { darkModeState } from '@/states/themeState';
import { InitialPageMeta } from '@/components/MetaData/MetaData';
import { GetServerSideProps } from 'next';
import { SSRMetaProps } from '@/components/MetaData/MetaData.type';
import useAuthRedirect from '@/hooks/useAuthRedirect';

export const getServerSideProps: GetServerSideProps = async () => {
const OGTitle = '예약내역 | GLOBALNOMAD';
Expand All @@ -40,6 +41,8 @@ export default function MyReservationPage({ OGTitle, OGUrl }: SSRMetaProps) {
useReservationList(filterOption);
const [isOpen, setIsOpen] = useRecoilState(sideNavigationState);
const [isDarkMode, setIsDarkMode] = useRecoilState(darkModeState);
// 로그아웃 상태에서 페이지 접근시 로그인 페이지로 redirect
useAuthRedirect();

const openSideNavigation = () => {
setIsOpen(!isOpen);
Expand Down

0 comments on commit 904ad51

Please sign in to comment.