From a5e7f938692de271fab984a8be0e1eccf4756e7b Mon Sep 17 00:00:00 2001 From: HanJul_01 <129282275+Hanjuri@users.noreply.github.com> Date: Tue, 10 Sep 2024 00:46:13 +0900 Subject: [PATCH] =?UTF-8?q?feat:=EC=B9=B4=EC=B9=B4=EC=98=A4=EB=A1=9C?= =?UTF-8?q?=EA=B7=B8=EC=9D=B8=20=EA=B5=AC=ED=98=84=EC=A4=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .idea/inspectionProfiles/Project_Default.xml | 6 ++ .idea/jsLinters/eslint.xml | 6 ++ src/App.jsx | 4 ++ .../{JoinInfoPost.js => postMemberData.js} | 4 +- src/pages/chat/ChatList.jsx | 13 ++--- src/pages/chat/ChatMain.jsx | 6 +- src/pages/chat/ChatRoom.jsx | 4 +- .../chat/dummyChatData/dummyChatMessages1 | 29 ++++++++++ src/pages/chat/styled/ChatList.styled.js | 26 ++++++--- src/pages/chat/styled/ChatMain.styled.js | 9 +-- src/pages/join/JoinPage.jsx | 2 +- src/pages/join/KakaoLogin.jsx | 45 +++++++++++++-- src/pages/join/KakoRedirect.jsx | 57 +++++++++++++++++++ vite.config.js | 3 +- 14 files changed, 181 insertions(+), 33 deletions(-) create mode 100644 .idea/inspectionProfiles/Project_Default.xml create mode 100644 .idea/jsLinters/eslint.xml rename src/api/{JoinInfoPost.js => postMemberData.js} (84%) create mode 100644 src/pages/chat/dummyChatData/dummyChatMessages1 create mode 100644 src/pages/join/KakoRedirect.jsx diff --git a/.idea/inspectionProfiles/Project_Default.xml b/.idea/inspectionProfiles/Project_Default.xml new file mode 100644 index 0000000..03d9549 --- /dev/null +++ b/.idea/inspectionProfiles/Project_Default.xml @@ -0,0 +1,6 @@ + + + + \ No newline at end of file diff --git a/.idea/jsLinters/eslint.xml b/.idea/jsLinters/eslint.xml new file mode 100644 index 0000000..541945b --- /dev/null +++ b/.idea/jsLinters/eslint.xml @@ -0,0 +1,6 @@ + + + + + \ No newline at end of file diff --git a/src/App.jsx b/src/App.jsx index 1885062..bb4b2b6 100644 --- a/src/App.jsx +++ b/src/App.jsx @@ -14,6 +14,8 @@ import { PeopleDetailPage } from "./pages/PeopleDetailPage/PeopleDetailPage.jsx" import ChatPage from "./pages/chat/ChatPage"; import RTCPage from "./pages/VideoPage"; import KakaoLogin from "./pages/join/KakaoLogin.jsx"; +import KakaoRedirect from "./pages/join/KakoRedirect.jsx"; +import JoinPage from "./pages/join/JoinPage.jsx"; function App() { return ( @@ -24,6 +26,8 @@ function App() { } /> } /> } /> + } /> + } /> ); diff --git a/src/api/JoinInfoPost.js b/src/api/postMemberData.js similarity index 84% rename from src/api/JoinInfoPost.js rename to src/api/postMemberData.js index 3fff134..f109016 100644 --- a/src/api/JoinInfoPost.js +++ b/src/api/postMemberData.js @@ -2,7 +2,9 @@ import { instance } from "./instanceAuth"; // 설정된 Axios 인스턴스 임포트 export async function postMemberData(data) { - const url = `/api/auth/member?name=${encodeURIComponent(data.koreanName)}`; + const userName = localStorage.getItem('kakao_access_tocken') + const url = `/api/auth/member?name=${encodeURIComponent(data.koreaName)}`; + console.log(url); try { const response = await instance.post(url, data); // Axios 인스턴스 사용 diff --git a/src/pages/chat/ChatList.jsx b/src/pages/chat/ChatList.jsx index 4bb148e..9f548ab 100644 --- a/src/pages/chat/ChatList.jsx +++ b/src/pages/chat/ChatList.jsx @@ -1,19 +1,19 @@ import React from "react"; import * as styles from "./styled/ChatList.styled"; -import smile from "../../assets/images/smiles.png"; +import profileimg from "../../assets/dummyImages/peopleList2.png"; const ChatList = (props) => { const truncatedContent = - props.content.length > 20 - ? `${props.content.slice(0, 15)}...` + props.content.length > 15 + ? `${props.content.slice(0, 12)}...` : props.content; - console.log(props); + return ( - + {props.name} @@ -22,9 +22,6 @@ const ChatList = (props) => { {props.time} - - {props.alramcount} - ); diff --git a/src/pages/chat/ChatMain.jsx b/src/pages/chat/ChatMain.jsx index 5068062..a580a95 100644 --- a/src/pages/chat/ChatMain.jsx +++ b/src/pages/chat/ChatMain.jsx @@ -18,10 +18,10 @@ function ChatMain() { const fetchChatList = async () => { try { const response = await getChatList(nowUser); // 사용자 이름을 동적으로 설정 가능 - setChatList(response.data); - console.log('채팅방리스트', response); + setChatList(response); + console.log('채팅방리스트 불러오기 성공', response); } catch (error) { - console.error("Failed to fetch chat list", error); + console.error("채팅방리스트 불러오기 실패", error); } }; diff --git a/src/pages/chat/ChatRoom.jsx b/src/pages/chat/ChatRoom.jsx index 0152630..144de93 100644 --- a/src/pages/chat/ChatRoom.jsx +++ b/src/pages/chat/ChatRoom.jsx @@ -5,6 +5,7 @@ import * as styles from "./styled/ChatRoom.styled"; import Text from "../../components/Common/Text"; import ChatMessage from "./ChatMessage.jsx"; import { getChatMessages } from "../../api/ChatMessageCall.js"; +import dummyChatMessages from "./dummyChatData/dummyChatMessages1"; const ChatRoom = (props) => { const { uuid, name } = props; @@ -124,9 +125,8 @@ const ChatRoom = (props) => { >{name} - {Array.isArray(messages) && messages.map((each, id) => ( + {Array.isArray(dummyChatMessages) && dummyChatMessages.map((each, id) => ( props.fontSize || "17px"}; + font-size: ${(props) => props.fontSize || "15spx"}; margin-top: 5px; + width: 170px; `; export const TimeAlramWrapper = styled.div` diff --git a/src/pages/chat/styled/ChatMain.styled.js b/src/pages/chat/styled/ChatMain.styled.js index 0583283..8d4bfa1 100644 --- a/src/pages/chat/styled/ChatMain.styled.js +++ b/src/pages/chat/styled/ChatMain.styled.js @@ -28,23 +28,24 @@ export const Title = styled.h1` export const ChatWrapper = styled.div` width: 90%; height: 90%; - background-color: white; display: flex; flex-direction: row; jusitfy-content: center; align-items: center; - border-top: 3px solid black; - border-bottom: 3px solid black: + border-radius: 20px; + border: 4px solid #d3cba1; `; export const LeftWrapper = styled.div` width: 50%; height: 100%; - background-color: #fff9d9; + background-color: transparent; + border-right: 4px solid #d3cba1; overflow-y: auto; `; export const ChatListButton = styled.div``; export const RightWrapper = styled.div` width: 50%; height: 100%; + border-radius:20px; `; diff --git a/src/pages/join/JoinPage.jsx b/src/pages/join/JoinPage.jsx index 30d177e..ec8199a 100644 --- a/src/pages/join/JoinPage.jsx +++ b/src/pages/join/JoinPage.jsx @@ -2,7 +2,7 @@ import React, {useState} from "react"; import Layout from "../../components/Common/Layout"; import * as styles from "../join/styled/JoinPage.styled.js"; import Text from "@/components/Common/Text.jsx"; -import {postMemberData} from '../../api/JoinInfoPost.js' +import {postMemberData} from '../../api/postMemberData.js' import {ContentLineTitleWrapper} from "../join/styled/JoinPage.styled.js"; function JoinPage(){ diff --git a/src/pages/join/KakaoLogin.jsx b/src/pages/join/KakaoLogin.jsx index 80ae394..7bdd879 100644 --- a/src/pages/join/KakaoLogin.jsx +++ b/src/pages/join/KakaoLogin.jsx @@ -1,17 +1,50 @@ -import React from "react"; -import { useNavigate } from "react-router-dom"; +import React, { useEffect } from "react"; import Layout from "../../components/Common/Layout.jsx"; import MiniLayout from "../../components/Common/miniLayout.jsx"; import kakaologin from "../../assets/images/kakaologin.png"; +import { useNavigate } from "react-router-dom"; function KakaoLogin() { - const CLIENT_ID = import.meta.env.REACT_APP_KAKAO_CLIENT_ID; // 환경변수에 CLIENT_ID 설정 - const REDIRECT_URL = import.meta.env.REACT_APP_KAKAO_REDIRECT_URL; // 환경변수에 REDIRECT_URL 설정 + const CLIENT_ID = import.meta.env.VITE_KAKAO_CLIENT_ID; + const REDIRECT_URL = import.meta.env.VITE_KAKAO_REDIRECT_URI; + const navigate = useNavigate(); + + useEffect(() => { + const accessToken = localStorage.getItem("kakao_access_token"); + if (accessToken) { + alert("이미 로그인 되어있습니다!"); + navigate("/list"); + } + if (!window.Kakao) { + const script = document.createElement("script"); + script.src = "https://developers.kakao.com/sdk/js/kakao.js"; + script.async = true; + document.body.appendChild(script); + + script.onload = () => { + if (!window.Kakao.isInitialized()) { + window.Kakao.init(CLIENT_ID); + console.log("Kakao SDK initialized"); + } + }; + } else if (!window.Kakao.isInitialized()) { + window.Kakao.init(CLIENT_ID); + console.log("Kakao SDK initialized"); + } + }, [CLIENT_ID]); + + // 카카오 로그인 버튼 클릭시 인증 요청 const handleKakaoLogin = () => { + if (!window.Kakao.isInitialized()) { + console.error("Kakao SDK가 초기화되지 않았습니다."); + return; + } - const kakaoLoginUrl = `https://api.kaboo.site:8081/oauth2/authorization/kakao?client_id=${CLIENT_ID}&redirect_uri=${REDIRECT_URL}&response_type=code`; - window.location.href = kakaoLoginUrl; // URL로 리디렉션 + window.Kakao.Auth.authorize({ + redirectUri: REDIRECT_URL + }); + navigate("/join"); }; return ( diff --git a/src/pages/join/KakoRedirect.jsx b/src/pages/join/KakoRedirect.jsx new file mode 100644 index 0000000..4d724c7 --- /dev/null +++ b/src/pages/join/KakoRedirect.jsx @@ -0,0 +1,57 @@ +import React, { useEffect } from "react"; +import {useLocation, useNavigate} from "react-router-dom"; +import axios from "axios"; + +const KakaoRedirect = () => { + const location = useLocation(); + const navigate = useNavigate(); + + useEffect(() => { + + const searchParams = new URLSearchParams(location.search); + const code = searchParams.get("code"); + + if (code) { + console.log("인가 코드:", code); + // 백엔드로 넘겨주기 구현 필요! + getAccessToken(code); + } else { + console.error("카카오 로그인 실패: 인가 코드를 받지 못했습니다."); + } + }, [location]); + + // 인가 코드를 통해 토큰을 받아오는 함수 + const getAccessToken = async (code) => { + try { + const response = await axios.post( + `https://kauth.kakao.com/oauth/token`, + null, { + params: { + grant_type: "authorization_code", + client_id: import.meta.env.VITE_KAKAO_CLIENT_ID, + redirect_uri: import.meta.env.VITE_KAKAO_REDIRECT_URI, + code: code, + }, + headers: { + "Content-Type": "application/x-www-form-urlencoded", + } + } + ); + console.log("Access Token:", response.data.access_token); + // 받은 토큰을 localStorage 또는 백엔드로 전달 + localStorage.setItem("kakao_access_token", response.data.access_token); + navigate("/join") + + } catch (error) { + console.error("토큰 요청 실패:", error); + } + }; + + return ( +
+

카카오 로그인 중...

+
+ ); +}; + +export default KakaoRedirect; \ No newline at end of file diff --git a/vite.config.js b/vite.config.js index 6d32319..11695b8 100644 --- a/vite.config.js +++ b/vite.config.js @@ -12,4 +12,5 @@ export default defineConfig({ define: { global: 'window', // 글로벌 변수를 브라우저 환경에서 사용할 수 있도록 설정 }, -}); + +}); \ No newline at end of file