From 2bd1a0298abcc6af8d1af0b722bae5e42ef422fe Mon Sep 17 00:00:00 2001 From: JitHoon Date: Fri, 17 Nov 2023 08:52:42 +0900 Subject: [PATCH] =?UTF-8?q?Feat:=20=EC=86=8C=EC=BC=93=20=EC=97=B0=EA=B2=B0?= =?UTF-8?q?=20=EB=A1=9C=EC=A7=81=20=EA=B0=9C=EC=84=A0=20#120?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Components/Chat/ChatRoom.tsx | 42 +++++++++++---------- app/chat/[id]/page.tsx | 72 ++++++++++++++++++++++++------------ 2 files changed, 72 insertions(+), 42 deletions(-) diff --git a/Components/Chat/ChatRoom.tsx b/Components/Chat/ChatRoom.tsx index eef7302..fe4683b 100644 --- a/Components/Chat/ChatRoom.tsx +++ b/Components/Chat/ChatRoom.tsx @@ -52,9 +52,11 @@ const ChatRoom = ({ fetchChatUsers(); }, [accessToken, chatId]); - // 'fetch-messages' 이벤트 등록 + // 'messages-to-client' 이벤트 등록 useEffect(() => { - if (socket?.connected) { + socket.off('messages-to-client'); + + if (socket.connected) { socket.emit('fetch-messages'); socket.on('messages-to-client', (messagesObject) => { @@ -63,33 +65,35 @@ const ChatRoom = ({ } return () => { - socket?.off('messages-to-client'); + socket.off('messages-to-client'); }; - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [socket.connected]); + }, [socket]); - // message-to-client 이벤트 등록 + // 'message-to-client' 이벤트 등록 useEffect(() => { - if (socket?.connected) { + socket.off('message-to-client'); + + if (socket.connected) { socket.on('message-to-client', (responseData) => { setMessages((prevMessages) => [...prevMessages, responseData]); }); } return () => { - socket?.off('message-to-client'); + socket.off('message-to-client'); }; - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [socket.connected]); + }, [socket]); - // join 이벤트 등록 + // 'join' 이벤트 등록 useEffect(() => { - if (socket?.connected) { + socket.off('join'); + + if (socket.connected) { socket.on('join', (responseData) => { setChatUsers([...chatUsers, ...responseData.users]); if (responseData.users[0] !== userId) { - Swal.fire(`${responseData.leaver} 님이 퇴장하셨습니다.`); + Swal.fire(`${responseData.users[0]} 님이 입장하셨습니다.`); } }); } @@ -97,12 +101,13 @@ const ChatRoom = ({ return () => { socket.off('join'); }; - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [chatUsers, socket.connected]); + }, [chatUsers, socket, userId]); // leave 이벤트 등록 useEffect(() => { - if (socket?.connected) { + socket.off('leave'); + + if (socket.connected) { socket.on('leave', (responseData) => { setChatUsers([...chatUsers, ...responseData.users]); @@ -115,13 +120,12 @@ const ChatRoom = ({ return () => { socket.off('leave'); }; - // eslint-disable-next-line react-hooks/exhaustive-deps - }, [chatUsers, socket.connected]); + }, [chatUsers, socket, userId]); // 서버로 메시지 전송 const sendMessage = () => { if (newMessage.trim() !== '') { - socket?.emit('message-to-server', newMessage); + socket.emit('message-to-server', newMessage); setNewMessage(''); } }; diff --git a/app/chat/[id]/page.tsx b/app/chat/[id]/page.tsx index b8d8d17..f9f6e4d 100644 --- a/app/chat/[id]/page.tsx +++ b/app/chat/[id]/page.tsx @@ -2,9 +2,9 @@ import { useSearchParams } from 'next/navigation'; import { getCookie } from '@/Components/Login/Cookie'; -import { io } from 'socket.io-client'; +import { io, Socket } from 'socket.io-client'; +import { useEffect, useState } from 'react'; import ChatRoom from '@/Components/Chat/ChatRoom'; -import { useEffect } from 'react'; const Chat = ({ params }: { params: { id: string } }) => { const chatId = params.id; @@ -12,31 +12,57 @@ const Chat = ({ params }: { params: { id: string } }) => { const privateValue = query?.get('isPrivate') as string; const accessToken = getCookie('accessToken'); - const socket = io(`https://fastcampus-chat.net/chat?chatId=${chatId}`, { - extraHeaders: { - Authorization: `Bearer ${accessToken}`, - serverId: process.env.NEXT_PUBLIC_SERVER_ID as string, - }, - }); + const [isConnect, setIsConnect] = useState(false); + const [chatSocket, setchatSocket] = useState(null); + + // 소켓 연결 시도 + useEffect(() => { + if (isConnect === true) return; + + const socket = io(`https://fastcampus-chat.net/chat?chatId=${chatId}`, { + extraHeaders: { + Authorization: `Bearer ${accessToken}`, + serverId: process.env.NEXT_PUBLIC_SERVER_ID as string, + }, + }); + + socket.off('connect'); + socket.off('connect_error'); + socket.off('disconnect'); + + socket.on('connect', () => { + setIsConnect(true); + setchatSocket(socket); + }); + + socket.on('disconnect', () => { + setchatSocket(null); + setIsConnect(false); + }); + + socket.on('connect_error', () => { + setchatSocket(null); + throw new Error(); + }); + }, [accessToken, isConnect, chatId]); useEffect(() => { return () => { - socket.disconnect(); + chatSocket?.disconnect(); }; - // eslint-disable-next-line react-hooks/exhaustive-deps - }, []); - - return ( - <> -
- -
- + }, [chatSocket]); + + return chatSocket ? ( +
+ +
+ ) : ( + <> ); };