From 7927e3a2e11575cf0156179460f9b734573100e4 Mon Sep 17 00:00:00 2001 From: wjzlskxk Date: Sun, 30 Jun 2024 18:41:51 +0900 Subject: [PATCH] :zap: :: professordetail #8 --- .../home/matching/professorDetail/index.tsx | 4 +++- .../home/matching/professorDetail/style.ts | 7 +++++-- src/hooks/matching/useMatching.ts | 19 ++++++++++++++++++- src/queries/QueryKey.ts | 2 -- src/queries/matching/matching.query.ts | 8 ++++++++ .../matching/matchingRepository.ts | 3 +++ .../matching/matchingRepositoryImpl.ts | 10 ++++++++++ 7 files changed, 47 insertions(+), 6 deletions(-) create mode 100644 src/queries/matching/matching.query.ts create mode 100644 src/repositories/matching/matchingRepository.ts create mode 100644 src/repositories/matching/matchingRepositoryImpl.ts diff --git a/src/components/home/matching/professorDetail/index.tsx b/src/components/home/matching/professorDetail/index.tsx index b4eae6a..6447c2d 100644 --- a/src/components/home/matching/professorDetail/index.tsx +++ b/src/components/home/matching/professorDetail/index.tsx @@ -6,9 +6,11 @@ import Image from "next/image"; import Avartar from "src/asset/Avatar.svg"; import BestRecommandImg from "src/asset/BestRecommand.svg"; import useMatching from "@/hooks/matching/useMatching"; +import { useParams } from "next/navigation"; const index = () => { const { ...professor } = useMatching(); + const { id } = useParams(); const professorDetailList = professor.getProfessorDetail(); const schoolInfo = professorDetailList?.data.schoolName + @@ -32,7 +34,7 @@ const index = () => { 최다추천 이미지 - 채팅하기 + professor.postMatching(1)}>채팅하기 diff --git a/src/components/home/matching/professorDetail/style.ts b/src/components/home/matching/professorDetail/style.ts index 930cd96..a00db08 100644 --- a/src/components/home/matching/professorDetail/style.ts +++ b/src/components/home/matching/professorDetail/style.ts @@ -5,6 +5,9 @@ export const ProfessorDetailWrap = styled.div` width: 100%; height: 100vh; + max-width: 1920px; + max-height: 1080px; + display: flex; flex-direction: column; @@ -81,10 +84,10 @@ export const ChatButton = styled.button` background: ${theme.colors.new}; - border-radius: 12px; + border-radius: 15px; padding: 2%; - margin-right: 2%; + margin-right: 3%; display: flex; font-size: 1.6rem; diff --git a/src/hooks/matching/useMatching.ts b/src/hooks/matching/useMatching.ts index ccb7fda..eb18773 100644 --- a/src/hooks/matching/useMatching.ts +++ b/src/hooks/matching/useMatching.ts @@ -1,7 +1,11 @@ import { useGetProfileInfo } from "@/queries/profile/query"; import { useProfessorQuery } from "src/queries/professor/professor.query"; +import { usePostMatching } from "@/queries/matching/matching.query"; +import { useRouter } from "next/navigation"; +import dearToast from "@/libs/Swal/Swal"; const useMatching = () => { + const router = useRouter(); const getProfessorList = (page: number) => { const [{ data: professorList }] = useProfessorQuery(page); @@ -15,7 +19,20 @@ const useMatching = () => { return professorDetailData; }; - return { getProfessorList, getProfessorDetail }; + const postMatchingMuation = usePostMatching(); + + const postMatching = (subjectId: number) => { + postMatchingMuation.mutate(subjectId, { + onSuccess: () => { + router.push("/chat"); + }, + onError: () => { + dearToast.errorToast("알수없는 문제가 발생하였습니다."); + }, + }); + }; + + return { getProfessorList, getProfessorDetail, postMatching }; }; export default useMatching; diff --git a/src/queries/QueryKey.ts b/src/queries/QueryKey.ts index e0a93af..e7ad0e0 100644 --- a/src/queries/QueryKey.ts +++ b/src/queries/QueryKey.ts @@ -1,5 +1,3 @@ -import { profile } from "console"; - export const QUERY_KEYS = Object.freeze({ matching: { matching: "/matching", diff --git a/src/queries/matching/matching.query.ts b/src/queries/matching/matching.query.ts new file mode 100644 index 0000000..24e3a0e --- /dev/null +++ b/src/queries/matching/matching.query.ts @@ -0,0 +1,8 @@ +import { useMutation, useQueries } from "react-query"; +import { QUERY_KEYS } from "../QueryKey"; +import matchingRepositoryImpl from "../../repositories/matching/matchingRepositoryImpl"; + +export const usePostMatching = () => { + const mutation = useMutation((subjectId: number) => matchingRepositoryImpl.postMatching(subjectId)); + return mutation; +}; diff --git a/src/repositories/matching/matchingRepository.ts b/src/repositories/matching/matchingRepository.ts new file mode 100644 index 0000000..6814e20 --- /dev/null +++ b/src/repositories/matching/matchingRepository.ts @@ -0,0 +1,3 @@ +export interface matcingRepository { + postMatching(subjectId: number): Promise; +} diff --git a/src/repositories/matching/matchingRepositoryImpl.ts b/src/repositories/matching/matchingRepositoryImpl.ts new file mode 100644 index 0000000..f6f7c73 --- /dev/null +++ b/src/repositories/matching/matchingRepositoryImpl.ts @@ -0,0 +1,10 @@ +import { matcingRepository } from "./matchingRepository"; +import { dearV1Axios } from "@/libs/axios/customAxios"; + +class MatchingRepositoryImpl implements matcingRepository { + public async postMatching(subjectId: number): Promise { + await dearV1Axios.post("/matching", subjectId); + } +} + +export default new MatchingRepositoryImpl();