Overnap

Merge branch 'develop' into feature/room

...@@ -23,7 +23,7 @@ ...@@ -23,7 +23,7 @@
23 "web-vitals": "^1.0.1" 23 "web-vitals": "^1.0.1"
24 }, 24 },
25 "scripts": { 25 "scripts": {
26 - "start": "npm run twcss && react-scripts start", 26 + "start": "npm run twcss && set PORT=3001 && react-scripts start",
27 "build": "npm run twcss && react-scripts build", 27 "build": "npm run twcss && react-scripts build",
28 "test": "react-scripts test", 28 "test": "react-scripts test",
29 "eject": "react-scripts eject", 29 "eject": "react-scripts eject",
......
...@@ -4,10 +4,15 @@ export interface MessageResponse<T> { ...@@ -4,10 +4,15 @@ export interface MessageResponse<T> {
4 result?: T; 4 result?: T;
5 } 5 }
6 6
7 +export interface RawMessage {
8 + type: string;
9 + message: any;
10 +}
11 +
7 export const MessageType = { 12 export const MessageType = {
8 LOGIN: "login", 13 LOGIN: "login",
9 - ROOM_LIST_REQUEST: "room_list_request", 14 + ROOM_LIST_REQUEST: "roomList",
10 - ROOM_JOIN: "room_join", 15 + ROOM_JOIN: "joinRoom",
11 ROOM_LEAVE: "room_leave", 16 ROOM_LEAVE: "room_leave",
12 ROOM_USER_UPDATE: "room_user_update", 17 ROOM_USER_UPDATE: "room_user_update",
13 ROOM_CHAT: "room_chat", 18 ROOM_CHAT: "room_chat",
......
1 -import React, { useContext } from 'react'; 1 +import React, { useCallback, useContext } from 'react';
2 import { useHistory } from 'react-router'; 2 import { useHistory } from 'react-router';
3 import SocketContext from '../../contexts/SocketContext'; 3 import SocketContext from '../../contexts/SocketContext';
4 -import { MessageResponse, MessageType } from '../common/types'; 4 +import { MessageResponse, MessageType, RawMessage } from '../common/types';
5 import { RoomData } from '../room/types'; 5 import { RoomData } from '../room/types';
6 import { Room } from './types'; 6 import { Room } from './types';
7 7
8 -interface RoomProps { 8 +interface RoomBlockProps {
9 room: Room 9 room: Room
10 } 10 }
11 11
12 -export const RoomInfo: React.FC<RoomProps> = ({ room }) => { 12 +export const RoomBlock: React.FC<RoomBlockProps> = ({ room }) => {
13 const history = useHistory(); 13 const history = useHistory();
14 const socket = useContext(SocketContext); 14 const socket = useContext(SocketContext);
15 - const joinRoom = () => { 15 + const joinRoom = useCallback(() => {
16 if (room.currentUsers < room.maxUsers) { 16 if (room.currentUsers < room.maxUsers) {
17 - socket.emit(MessageType.ROOM_JOIN, (response: MessageResponse<RoomData>) => { 17 + const rawMessage: RawMessage = {
18 + type: MessageType.ROOM_JOIN,
19 + message: { uuid: room.uuid }
20 + }
21 + socket.emit('msg', rawMessage, (response: MessageResponse<RoomData>) => {
18 if (response.ok) { 22 if (response.ok) {
19 history.push({ 23 history.push({
20 pathname: '/' + room.uuid, 24 pathname: '/' + room.uuid,
...@@ -27,7 +31,7 @@ export const RoomInfo: React.FC<RoomProps> = ({ room }) => { ...@@ -27,7 +31,7 @@ export const RoomInfo: React.FC<RoomProps> = ({ room }) => {
27 } else { 31 } else {
28 //TODO: 자리 꽉찼다는 MODAL 32 //TODO: 자리 꽉찼다는 MODAL
29 } 33 }
30 - } 34 + }, []);
31 35
32 return ( 36 return (
33 <button className={`flex items-center place-content-between m-2 w-5/6 37 <button className={`flex items-center place-content-between m-2 w-5/6
......
1 import React from 'react'; 1 import React from 'react';
2 import { io } from 'socket.io-client'; 2 import { io } from 'socket.io-client';
3 3
4 -export const socket = io('http://localhost/'); 4 +export const socket = io('http://localhost:3000/');
5 const SocketContext = React.createContext(socket); 5 const SocketContext = React.createContext(socket);
6 6
7 export const SocketProvider = SocketContext.Provider; 7 export const SocketProvider = SocketContext.Provider;
......
1 -import React, { useContext, useState } from 'react'; 1 +import React, { useCallback, useContext, useState } from 'react';
2 import { useHistory } from 'react-router'; 2 import { useHistory } from 'react-router';
3 import { Main } from '../components/common/Main'; 3 import { Main } from '../components/common/Main';
4 -import { MessageResponse, MessageType } from '../components/common/types'; 4 +import { MessageResponse, MessageType, RawMessage } from '../components/common/types';
5 import SocketContext from '../contexts/SocketContext'; 5 import SocketContext from '../contexts/SocketContext';
6 6
7 export const Login: React.FC = () => { 7 export const Login: React.FC = () => {
...@@ -9,15 +9,19 @@ export const Login: React.FC = () => { ...@@ -9,15 +9,19 @@ export const Login: React.FC = () => {
9 const socket = useContext(SocketContext); 9 const socket = useContext(SocketContext);
10 const [ username, setUsername ] = useState(""); 10 const [ username, setUsername ] = useState("");
11 11
12 - const login = () => { 12 + const login = useCallback(() => {
13 - socket.emit(MessageType.LOGIN, username, (response : MessageResponse<null>) => { 13 + const rawMessage: RawMessage = {
14 + type: MessageType.LOGIN,
15 + message: { username }
16 + }
17 + socket.emit('msg', rawMessage, (response : MessageResponse<undefined>) => {
14 if (response.ok) { 18 if (response.ok) {
15 history.push('/rooms'); 19 history.push('/rooms');
16 } else { 20 } else {
17 console.error('login error!'); // TODO: 팝업 에러? 21 console.error('login error!'); // TODO: 팝업 에러?
18 } 22 }
19 }); 23 });
20 - } 24 + }, []);
21 25
22 return ( 26 return (
23 <Main> 27 <Main>
......
1 -import React, { useContext, useEffect, useState } from 'react'; 1 +import React, { useCallback, useContext, useEffect, useState } from 'react';
2 import { Main } from '../components/common/Main'; 2 import { Main } from '../components/common/Main';
3 -import { MessageResponse, MessageType } from '../components/common/types'; 3 +import { MessageResponse, MessageType, RawMessage } from '../components/common/types';
4 -import { RoomInfo } from '../components/rooms/RoomInfo'; 4 +import { RoomBlock } from '../components/rooms/RoomBlock';
5 import { Room } from '../components/rooms/types'; 5 import { Room } from '../components/rooms/types';
6 import SocketContext from '../contexts/SocketContext'; 6 import SocketContext from '../contexts/SocketContext';
7 7
...@@ -9,41 +9,28 @@ export const Rooms: React.FC = () => { ...@@ -9,41 +9,28 @@ export const Rooms: React.FC = () => {
9 const socket = useContext(SocketContext); 9 const socket = useContext(SocketContext);
10 const [ rooms, setRooms ] = useState<Room[]>([]); 10 const [ rooms, setRooms ] = useState<Room[]>([]);
11 11
12 - // for test 12 + const refreshRooms = useCallback(() => {
13 - const testingRoom1: Room = { 13 + const rawMessage: RawMessage = {
14 - uuid: '23525', 14 + type: MessageType.ROOM_LIST_REQUEST,
15 - name: 'Hello World!', 15 + message: {}
16 - currentUsers: 3,
17 - maxUsers: 4
18 } 16 }
19 - const testingRoom2: Room = { 17 + socket.emit('msg', rawMessage, (response: MessageResponse<Room[]>) => {
20 - uuid: '235252134',
21 - name: 'Bonjour World!',
22 - currentUsers: 6,
23 - maxUsers: 6
24 - }
25 - useEffect(() => {
26 - setRooms([testingRoom1, testingRoom2]);
27 - // refreshRooms()
28 - }, []);
29 -
30 - const refreshRooms = () => {
31 - socket.emit(MessageType.ROOM_LIST_REQUEST, (response: MessageResponse<Room[]>) => {
32 if (response.ok) { 18 if (response.ok) {
33 setRooms(response.result!); 19 setRooms(response.result!);
34 } else { 20 } else {
35 // TODO: 에러 핸들링 21 // TODO: 에러 핸들링
36 console.log("방 목록을 수신하지 못함"); 22 console.log("방 목록을 수신하지 못함");
23 + console.log(response);
37 } 24 }
38 }); 25 });
39 - } 26 + }, []);
40 27
41 - // useEffect(refreshRooms, []); 28 + useEffect(refreshRooms, []);
42 29
43 return ( 30 return (
44 <Main> 31 <Main>
45 <div className='mt-auto w-screen flex flex-col items-center'> 32 <div className='mt-auto w-screen flex flex-col items-center'>
46 - {rooms.map((room) => (<RoomInfo key={room.uuid} room={room} />))} 33 + {rooms.map((room) => (<RoomBlock key={room.uuid} room={room} />))}
47 </div> 34 </div>
48 </Main> 35 </Main>
49 ) 36 )
......