From caf3025626805e5f750147caf466621d58601428 Mon Sep 17 00:00:00 2001 From: ewinkite <139189610+ewinkite@users.noreply.github.com> Date: Fri, 26 Jan 2024 16:18:03 +0900 Subject: [PATCH] =?UTF-8?q?=E2=9C=A8=20feat=20:=20=EC=97=90=EB=9F=AC=20?= =?UTF-8?q?=EC=88=98=EC=A0=95=20=EB=B0=8F=20=EB=A1=9C=EA=B7=B8=EC=9D=B8=20?= =?UTF-8?q?=EB=AA=A8=EB=8B=AC=20=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/chat/api.ts | 13 ++-- components/roomInfo/footer/index.tsx | 109 ++++++++++++++++++--------- 2 files changed, 80 insertions(+), 42 deletions(-) diff --git a/api/chat/api.ts b/api/chat/api.ts index 7c7eac3e..9eda1495 100644 --- a/api/chat/api.ts +++ b/api/chat/api.ts @@ -1,3 +1,4 @@ +import axios from 'axios'; import { apiClient } from '../user/apiClient'; import { apiChatClient } from './apiChatClient'; @@ -30,12 +31,12 @@ export const createChatRoom = async ( productId: number, token: string, ) => { - const data = await apiChatClient.post( - '/v1/chat/room/create', + const data = await axios.post( + 'https://catchroom.xyz/v1/chat/room/create', { - buyerId, - sellerId, - productId, + buyerId: buyerId, + sellerId: sellerId, + productId: productId, }, { headers: { @@ -46,8 +47,6 @@ export const createChatRoom = async ( ); const result = await data.data.data.chatRoomNumber; - console.log(result); - console.log(buyerId, sellerId, productId); return result; }; diff --git a/components/roomInfo/footer/index.tsx b/components/roomInfo/footer/index.tsx index 1a438bd9..63af9c9d 100644 --- a/components/roomInfo/footer/index.tsx +++ b/components/roomInfo/footer/index.tsx @@ -1,6 +1,6 @@ 'use client'; -import React from 'react'; +import React, { useState } from 'react'; import { Button } from '@material-tailwind/react'; // import { useRoomItem } from '@/api/room-info/query'; import { useRecoilState } from 'recoil'; @@ -10,11 +10,14 @@ import { useParams, useRouter } from 'next/navigation'; import { createChatRoom } from '@/api/chat/api'; import { useRoomItem } from '@/api/room-info/query'; import { useCookies } from 'react-cookie'; +import Modal from '@/components/common/modal'; // 판매자 유무에 따른 버튼노출 처리 필요 // 현재 헤더의 화면전환 버튼을 이용한 전역상태로 바뀌는 중 const FooterComponent = () => { const [viewerState] = useRecoilState(viewerTestButton); + const [open, setOpen] = useState(false); + const [cookies] = useCookies(); const accessToken = cookies.accessToken; @@ -27,54 +30,90 @@ const FooterComponent = () => { //채팅방 생성 const createChat = async () => { - const chatRoomId: number = await createChatRoom( - sellerId, - buyerId, - Number(id), - accessToken, - ); - router.push(`/chat/${chatRoomId}`); + if (accessToken === undefined) { + setOpen(true); + } else { + const chatRoomId = await createChatRoom( + buyerId, + sellerId, + Number(id), + accessToken, + ); + console.log(chatRoomId); + router.push(`/chat/${chatRoomId}`); + } + }; + + const handleModalOpen = () => { + setOpen((prev) => !prev); + }; + + const onCancel = () => { + handleModalOpen(); + }; + + const onConfirm = () => { + handleModalOpen(); + router.push('/login'); }; const handlePurchaseClick = () => { - router.push(`/order/${id}`); + if (accessToken === undefined) { + setOpen(true); + } else { + router.push(`/order/${id}`); + } }; const buttonClass = 'font-pretend h-full rounded-[4px] text-t1 font-semibold shadow-none'; return ( -