diff --git a/src/components/NeedAuth/NeedAuth.tsx b/src/components/NeedAuth/NeedAuth.tsx new file mode 100644 index 000000000..60d7c1e03 --- /dev/null +++ b/src/components/NeedAuth/NeedAuth.tsx @@ -0,0 +1,30 @@ +import React from 'react'; +import { useNavigate } from 'react-router-dom'; +import { Role } from '@api/dto'; +import useCheckAuth from '@hooks/useCheckAuth'; +import ConfirmModal from '@components/Modal/ConfirmModal'; + +interface NeedLoginProps { + children: JSX.Element; + roles?: Role[]; +} + +const NeedAuth = ({ children, roles = [] }: NeedLoginProps) => { + const { checkIncludeOneOfAuths } = useCheckAuth(); + const navigate = useNavigate(); + + const onClose = () => { + navigate('/'); + }; + + if (checkIncludeOneOfAuths([...roles, 'ROLE_회장', 'ROLE_부회장'])) { + return children; + } + return ( + +

접근 권한이 없습니다

+
+ ); +}; + +export default NeedAuth; diff --git a/src/components/NeedAuth/NeedLogin.tsx b/src/components/NeedAuth/NeedLogin.tsx new file mode 100644 index 000000000..d8be796fb --- /dev/null +++ b/src/components/NeedAuth/NeedLogin.tsx @@ -0,0 +1,28 @@ +import React from 'react'; +import { useNavigate } from 'react-router-dom'; +import useCheckAuth from '@hooks/useCheckAuth'; +import ConfirmModal from '@components/Modal/ConfirmModal'; + +interface NeedLoginProps { + children: JSX.Element; +} + +const NeedLogin = ({ children }: NeedLoginProps) => { + const { checkLogin } = useCheckAuth(); + const navigate = useNavigate(); + + const onClose = () => { + navigate('/login'); + }; + + if (checkLogin()) { + return children; + } + return ( + +

로그인 후 이용해주세요

+
+ ); +}; + +export default NeedLogin; diff --git a/src/hooks/useCheckAuth.ts b/src/hooks/useCheckAuth.ts index 7eb5076e1..1b00a7ed7 100644 --- a/src/hooks/useCheckAuth.ts +++ b/src/hooks/useCheckAuth.ts @@ -6,6 +6,10 @@ import memberState from '@recoil/member.recoil'; const useCheckAuth = () => { const member: MemberInfo | null = useRecoilValue(memberState); + const checkLogin = useMemo(() => { + return () => member !== null; + }, [member]); + const checkAuth = useMemo(() => { return (requiredRole: Role) => member?.memberJobs?.includes(requiredRole); }, [member]); @@ -16,7 +20,7 @@ const useCheckAuth = () => { const checkIsMyId = (id: number) => member?.memberId === id; - return { checkAuth, checkIncludeOneOfAuths, checkIsMyId }; + return { checkLogin, checkAuth, checkIncludeOneOfAuths, checkIsMyId }; }; export default useCheckAuth; diff --git a/src/router/useMainRouter.tsx b/src/router/useMainRouter.tsx index 945b38e84..8d4813f06 100644 --- a/src/router/useMainRouter.tsx +++ b/src/router/useMainRouter.tsx @@ -22,6 +22,8 @@ import SeminarAttend from '@pages/senimarAttend/SenimarAttend'; import FitContainer from '@components/Layout/Container/FitContainer'; import FullContainer from '@components/Layout/Container/FullContainer'; import MainLayout from '@components/Layout/MainLayout'; +import NeedAuth from '@components/NeedAuth/NeedAuth'; +import NeedLogin from '@components/NeedAuth/NeedLogin'; const useMainRouter = () => useRoutes([ @@ -54,7 +56,11 @@ const useMainRouter = () => }, { path: 'profile/:memberId/*', - element: , + element: ( + + + + ), }, ], }, @@ -66,7 +72,11 @@ const useMainRouter = () => children: [ { path: 'dutyManage', - element: , + element: ( + + + + ), }, /* { path: 'electionManage', @@ -74,19 +84,35 @@ const useMainRouter = () => }, */ { path: 'libraryManage/*', - element: , + element: ( + + + + ), }, { path: 'seminarManage', - element: , + element: ( + + + + ), }, { path: 'activeMemberManage', - element: , + element: ( + + + + ), }, { path: 'meritManage', - element: , + element: ( + + + + ), }, ], }, @@ -95,29 +121,53 @@ const useMainRouter = () => children: [ { path: ':categoryName', - element: , + element: ( + + + + ), }, { path: 'write/:categoryName', - element: , + element: ( + + + + ), }, { path: 'view/:postId', - element: , + element: ( + + + + ), }, ], }, { path: 'study', - element: , + element: ( + + + + ), }, { path: 'library', - element: , + element: ( + + + + ), }, { path: 'seminar', - element: , + element: ( + + + + ), }, /* { path: 'election', @@ -125,11 +175,19 @@ const useMainRouter = () => }, */ { path: 'rank', - element: , + element: ( + + + + ), }, { path: 'game', - element: , + element: ( + + + + ), }, /* { path: 'ctf',