diff --git a/src/components/templates/MyPageTemplate/index.tsx b/src/components/templates/MyPageTemplate/index.tsx index a44f5882..2ec1632a 100644 --- a/src/components/templates/MyPageTemplate/index.tsx +++ b/src/components/templates/MyPageTemplate/index.tsx @@ -1,9 +1,10 @@ -import { TextButton } from "components/atoms"; +import { Text, TextButton } from "components/atoms"; import { Profile, MyPageMenu } from "components/organisms"; import { MyPageTemplateWrapper, ProfileContainer, - BackGroundWrapper + BackGroundWrapper, + LogoutWrapper, } from "./styled"; interface IMyPageTemplateProps { @@ -17,6 +18,8 @@ interface IMyPageTemplateProps { onProfileEditButtonClick: () => void; /** 메뉴 클릭 시 실행될 함수 */ onMenuClick: (pathname: string) => void; + /** 로그아웃 함수 */ + onLogout: () => void; } /** @@ -30,7 +33,8 @@ export const MyPageTemplate = ({ nickname, location, onProfileEditButtonClick, - onMenuClick + onMenuClick, + onLogout, }: IMyPageTemplateProps) => { return ( @@ -38,13 +42,16 @@ export const MyPageTemplate = ({ + + + ); }; diff --git a/src/components/templates/MyPageTemplate/styled.ts b/src/components/templates/MyPageTemplate/styled.ts index 017a5124..d34c3b64 100644 --- a/src/components/templates/MyPageTemplate/styled.ts +++ b/src/components/templates/MyPageTemplate/styled.ts @@ -2,8 +2,9 @@ import styled from "@emotion/styled"; import { TextButtonWrapper } from "components/atoms/Button/TextButton/styled"; import { ProfileWrapper, - ImageWrapper + ImageWrapper, } from "components/organisms/Profile/styled"; +import { ThemeType } from "styles/theme"; export const MyPageTemplateWrapper: ReturnType = styled.div` display: flex; @@ -49,7 +50,17 @@ export const ProfileContainer: ReturnType = styled.div` flex-direction: column; align-items: flex-start; `; + export const BackGroundWrapper: ReturnType = styled.div` background: #f4f6f9; padding: 1rem; `; + +export const LogoutWrapper: ReturnType = styled.div` + color: ${({ theme }: { theme: ThemeType }) => + theme.colors.grey_field_guide_but_deactivate}; + text-decoration: underline; + margin: 0 1rem; + cursor: pointer; + width: fit-content; +`; diff --git a/src/pages/MyPage.tsx b/src/pages/MyPage.tsx index a1b015ce..c718cfaa 100644 --- a/src/pages/MyPage.tsx +++ b/src/pages/MyPage.tsx @@ -1,8 +1,9 @@ import { useEffect, useCallback } from "react"; import { useNavigate } from "react-router-dom"; +import { Toast } from "components/atoms"; import { MyPageTemplate } from "components/templates"; import { useHeaderStore, useUserStore } from "stores"; -import { getUserProfile } from "services/apis"; +import { getUserProfile, oauthLogout } from "services/apis"; export const MyPage = () => { const { setTitle } = useHeaderStore(); @@ -28,7 +29,7 @@ export const MyPage = () => { setUser({ nickname: result.nickname || undefined, profile: result.imageUrl || undefined, - emdName: result.activityEmdName || undefined + emdName: result.activityEmdName || undefined, }); }) .catch(() => { @@ -36,6 +37,18 @@ export const MyPage = () => { }); }, []); + const handleLogout = useCallback(() => { + oauthLogout() + .then(() => { + setUser(null); + location.reload(); + }) + .catch((error) => { + Toast.show("잠시 후에 다시 시도해주세요.", 2000); + console.error("Logout failed", error); + }); + }, [navigate, setUser]); + return ( { location={user!.emdName as string} onProfileEditButtonClick={handleProfileEditButtonClick} onMenuClick={handleMenuClick} + onLogout={handleLogout} /> ); };