From e85112a7b1ef2259cf3fef672ce18d03c015edfd Mon Sep 17 00:00:00 2001 From: gimdogyun Date: Thu, 18 Jan 2024 20:55:44 +0900 Subject: [PATCH 1/5] refactor : rank Api querykey factor - #867 --- src/api/attendanceApi.ts | 39 ++++++++++++++++++- src/api/memberApi.ts | 13 ++++++- src/api/rankApi.ts | 45 ---------------------- src/pages/Game/Baseball/api/baseballApi.ts | 18 ++++++++- src/pages/rank/Rank.tsx | 9 ++--- 5 files changed, 69 insertions(+), 55 deletions(-) delete mode 100644 src/api/rankApi.ts diff --git a/src/api/attendanceApi.ts b/src/api/attendanceApi.ts index 098d433af..098a266f8 100644 --- a/src/api/attendanceApi.ts +++ b/src/api/attendanceApi.ts @@ -1,9 +1,17 @@ import { useQuery } from 'react-query'; import axios from 'axios'; import { DateTime } from 'luxon'; -import { CallenderChartInfo, TodayAttendInfo, TodayAttendPoint } from './dto'; +import { + AttendRankInfo, + CallenderChartInfo, + PageAndSize, + TodayAttendInfo, + TodayAttendPoint, + TodayAttendRank, +} from './dto'; const attendanceKeys = { + base: ['attendances'] as const, todayAttendancePoint: ['todayAttendancePoint'], todayAttendanceInfo: ({ memberId }: { memberId: number }) => ['todayAttendanceInfo', memberId], attendanceInfoList: ({ memberId, year }: { memberId: number; year: number }) => [ @@ -11,6 +19,8 @@ const attendanceKeys = { memberId, year, ], + todayAttendanceRank: (param: PageAndSize) => [...attendanceKeys.base, 'today-rank', param] as const, + continuousAttendanceRank: () => [...attendanceKeys.base, 'continuous-rank'] as const, }; const useGetTodayAttendancePointQuery = () => { @@ -36,4 +46,29 @@ const useGetAttendanceInfoListQuery = ({ memberId, year }: { memberId: number; y return useQuery(attendanceKeys.attendanceInfoList({ memberId, year }), fetcher); }; -export { useGetTodayAttendancePointQuery, useGetTodayAttendanceInfoQuery, useGetAttendanceInfoListQuery }; +const useGetTodayAttendanceRank = ({ page, size = 10 }: PageAndSize) => { + const fetcher = () => + axios + .get('/attendances/today-rank', { + params: { page, size }, + }) + .then(({ data }) => data); + + return useQuery(attendanceKeys.todayAttendanceRank({ page, size }), fetcher, { + keepPreviousData: true, + }); +}; + +const useGetContinuousAttendanceRank = () => { + const fetcher = () => axios.get('/attendances/continuous-rank').then(({ data }) => data); + + return useQuery(attendanceKeys.continuousAttendanceRank(), fetcher); +}; + +export { + useGetTodayAttendancePointQuery, + useGetTodayAttendanceInfoQuery, + useGetAttendanceInfoListQuery, + useGetTodayAttendanceRank, + useGetContinuousAttendanceRank, +}; diff --git a/src/api/memberApi.ts b/src/api/memberApi.ts index ded70c331..5568e97c8 100644 --- a/src/api/memberApi.ts +++ b/src/api/memberApi.ts @@ -4,10 +4,12 @@ import axios from 'axios'; import { PASSWORD } from '@constants/apiResponseMessage'; import { useApiError } from '@hooks/useGetApiError'; import { formatGeneration } from '@utils/converter'; -import { ProfileInfo, MemberDetailInfo } from './dto'; +import { ProfileInfo, MemberDetailInfo, PageAndSize, PointRank } from './dto'; const memberKeys = { + base: ['member'] as const, memberList: ['member', 'memberList'] as const, + pointRank: (param: PageAndSize) => [...memberKeys.base, 'point_rank', param] as const, }; const profileKeys = { profileInfo: (memberId: number) => ['profile', 'profileInfo', memberId] as const, @@ -191,6 +193,14 @@ const useDeleteMemberMutation = () => { }); }; +const useGetPointRank = ({ page, size = 10 }: PageAndSize) => { + const fetcher = () => axios.get('/members/point-rank', { params: { page, size } }).then(({ data }) => data); + + return useQuery(memberKeys.pointRank({ page, size }), fetcher, { + keepPreviousData: true, + }); +}; + export { useGetMembersQuery, useGetProfileQuery, @@ -204,4 +214,5 @@ export { useWithdrawalMutation, useEditMemberTypeMutation, useDeleteMemberMutation, + useGetPointRank, }; diff --git a/src/api/rankApi.ts b/src/api/rankApi.ts deleted file mode 100644 index fc82b869d..000000000 --- a/src/api/rankApi.ts +++ /dev/null @@ -1,45 +0,0 @@ -import { useQuery } from 'react-query'; -import axios from 'axios'; -import { AttendRankInfo, GameRankInfo, PageAndSize, PointRank, TodayAttendRank } from './dto'; - -const rankKeys = { - todayAttendanceRank: (param: PageAndSize) => ['today-attendance-rank', param] as const, - continuousAttendanceRank: ['continuous-attendance-rank'] as const, - pointRank: (param: PageAndSize) => ['point-rank', param] as const, - gameRank: ['game-rank'] as const, -}; - -const useGetTodayAttendanceRank = ({ page, size = 10 }: PageAndSize) => { - const fetcher = () => - axios - .get('/attendances/today-rank', { - params: { page, size }, - }) - .then(({ data }) => data); - - return useQuery(rankKeys.todayAttendanceRank({ page, size }), fetcher, { - keepPreviousData: true, - }); -}; - -const useGetContinuousAttendanceRank = () => { - const fetcher = () => axios.get('/attendances/continuous-rank').then(({ data }) => data); - - return useQuery(rankKeys.continuousAttendanceRank, fetcher); -}; - -const useGetPointRank = ({ page, size = 10 }: PageAndSize) => { - const fetcher = () => axios.get('/members/point-rank', { params: { page, size } }).then(({ data }) => data); - - return useQuery(rankKeys.pointRank({ page, size }), fetcher, { - keepPreviousData: true, - }); -}; - -const useGetGameRank = () => { - const fetcher = () => axios.get('/game/rank').then(({ data }) => data); - - return useQuery(rankKeys.gameRank, fetcher); -}; - -export { useGetTodayAttendanceRank, useGetContinuousAttendanceRank, useGetPointRank, useGetGameRank }; diff --git a/src/pages/Game/Baseball/api/baseballApi.ts b/src/pages/Game/Baseball/api/baseballApi.ts index b70d40326..24015290d 100644 --- a/src/pages/Game/Baseball/api/baseballApi.ts +++ b/src/pages/Game/Baseball/api/baseballApi.ts @@ -1,14 +1,17 @@ import toast from 'react-hot-toast'; import { useQuery, useMutation, useQueryClient } from 'react-query'; import axios from 'axios'; +import { GameRankInfo } from '@api/dto'; import { gameKeys } from '@api/gameApi'; import { useApiError } from '@hooks/useGetApiError'; import { GameInfo, GameResultInfo, GameStatus } from './baseballDto'; export const baseballKeys = { + base: ['game'] as const, game_info: ['game_info'] as const, status: ['status'] as const, result: ['result'] as const, + gameRank: () => [...baseballKeys.base, 'rank'] as const, }; const useGetGameInfoQuery = () => { @@ -69,4 +72,17 @@ const useGetResultQuery = () => { return useQuery(baseballKeys.result, fetcher); }; -export { useGetGameInfoQuery, useGetBaseBallStatusQuery, useGameStartMutation, useGuessMutation, useGetResultQuery }; +const useGetGameRank = () => { + const fetcher = () => axios.get('/game/rank').then(({ data }) => data); + + return useQuery(baseballKeys.gameRank(), fetcher); +}; + +export { + useGetGameInfoQuery, + useGetBaseBallStatusQuery, + useGameStartMutation, + useGuessMutation, + useGetResultQuery, + useGetGameRank, +}; diff --git a/src/pages/rank/Rank.tsx b/src/pages/rank/Rank.tsx index 1e4801b79..d5da97ac5 100644 --- a/src/pages/rank/Rank.tsx +++ b/src/pages/rank/Rank.tsx @@ -1,15 +1,12 @@ import React, { useState } from 'react'; import { Link } from 'react-router-dom'; import { Typography } from '@mui/material'; +import { useGetContinuousAttendanceRank, useGetTodayAttendanceRank } from '@api/attendanceApi'; import { AttendRankInfo, GameRankInfo } from '@api/dto'; -import { - useGetContinuousAttendanceRank, - useGetGameRank, - useGetPointRank, - useGetTodayAttendanceRank, -} from '@api/rankApi'; +import { useGetPointRank } from '@api/memberApi'; import usePagination from '@hooks/usePagination'; import { formatGeneration } from '@utils/converter'; +import { useGetGameRank } from '@pages/Game/Baseball/api/baseballApi'; import ServerAvatar from '@components/Avatar/ServerAvatar'; import OutlinedButton from '@components/Button/OutlinedButton'; import StandardTab from '@components/Tab/StandardTab'; From 887826992152d3e5707b1061120077efd22f7101 Mon Sep 17 00:00:00 2001 From: gimdogyun Date: Thu, 18 Jan 2024 21:08:20 +0900 Subject: [PATCH 2/5] =?UTF-8?q?refactor=20:=20params=20=EB=AC=B6=EA=B8=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - camelCase 변경 - params로 묶기 - #867 --- src/api/attendanceApi.ts | 8 +++++--- src/api/memberApi.ts | 6 ++++-- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/src/api/attendanceApi.ts b/src/api/attendanceApi.ts index 098a266f8..11f3167ba 100644 --- a/src/api/attendanceApi.ts +++ b/src/api/attendanceApi.ts @@ -19,8 +19,8 @@ const attendanceKeys = { memberId, year, ], - todayAttendanceRank: (param: PageAndSize) => [...attendanceKeys.base, 'today-rank', param] as const, - continuousAttendanceRank: () => [...attendanceKeys.base, 'continuous-rank'] as const, + todayAttendanceRank: (param: PageAndSize) => [...attendanceKeys.base, 'todayRank', param] as const, + continuousAttendanceRank: () => [...attendanceKeys.base, 'continuousRank'] as const, }; const useGetTodayAttendancePointQuery = () => { @@ -47,6 +47,8 @@ const useGetAttendanceInfoListQuery = ({ memberId, year }: { memberId: number; y }; const useGetTodayAttendanceRank = ({ page, size = 10 }: PageAndSize) => { + const params = { page, size }; + const fetcher = () => axios .get('/attendances/today-rank', { @@ -54,7 +56,7 @@ const useGetTodayAttendanceRank = ({ page, size = 10 }: PageAndSize) => { }) .then(({ data }) => data); - return useQuery(attendanceKeys.todayAttendanceRank({ page, size }), fetcher, { + return useQuery(attendanceKeys.todayAttendanceRank(params), fetcher, { keepPreviousData: true, }); }; diff --git a/src/api/memberApi.ts b/src/api/memberApi.ts index 5568e97c8..d9f89d276 100644 --- a/src/api/memberApi.ts +++ b/src/api/memberApi.ts @@ -9,7 +9,7 @@ import { ProfileInfo, MemberDetailInfo, PageAndSize, PointRank } from './dto'; const memberKeys = { base: ['member'] as const, memberList: ['member', 'memberList'] as const, - pointRank: (param: PageAndSize) => [...memberKeys.base, 'point_rank', param] as const, + pointRank: (param: PageAndSize) => [...memberKeys.base, 'pointRank', param] as const, }; const profileKeys = { profileInfo: (memberId: number) => ['profile', 'profileInfo', memberId] as const, @@ -194,9 +194,11 @@ const useDeleteMemberMutation = () => { }; const useGetPointRank = ({ page, size = 10 }: PageAndSize) => { + const params = { page, size }; + const fetcher = () => axios.get('/members/point-rank', { params: { page, size } }).then(({ data }) => data); - return useQuery(memberKeys.pointRank({ page, size }), fetcher, { + return useQuery(memberKeys.pointRank(params), fetcher, { keepPreviousData: true, }); }; From efc81d5405da11cde887228c516aed0e163b0251 Mon Sep 17 00:00:00 2001 From: gimdogyun Date: Thu, 18 Jan 2024 21:18:23 +0900 Subject: [PATCH 3/5] =?UTF-8?q?refactor=20:=20rank=20Api=20fetcher=20param?= =?UTF-8?q?s=20=EB=AC=B6=EA=B8=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - #867 --- src/api/attendanceApi.ts | 2 +- src/api/memberApi.ts | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/src/api/attendanceApi.ts b/src/api/attendanceApi.ts index 11f3167ba..72414bae0 100644 --- a/src/api/attendanceApi.ts +++ b/src/api/attendanceApi.ts @@ -52,7 +52,7 @@ const useGetTodayAttendanceRank = ({ page, size = 10 }: PageAndSize) => { const fetcher = () => axios .get('/attendances/today-rank', { - params: { page, size }, + params, }) .then(({ data }) => data); diff --git a/src/api/memberApi.ts b/src/api/memberApi.ts index d9f89d276..2bffdbb5f 100644 --- a/src/api/memberApi.ts +++ b/src/api/memberApi.ts @@ -196,7 +196,7 @@ const useDeleteMemberMutation = () => { const useGetPointRank = ({ page, size = 10 }: PageAndSize) => { const params = { page, size }; - const fetcher = () => axios.get('/members/point-rank', { params: { page, size } }).then(({ data }) => data); + const fetcher = () => axios.get('/members/point-rank', { params }).then(({ data }) => data); return useQuery(memberKeys.pointRank(params), fetcher, { keepPreviousData: true, From 47fbe5c49eaf5f2510dfcd8a6819ecc9dba8b507 Mon Sep 17 00:00:00 2001 From: gimdogyun Date: Thu, 18 Jan 2024 21:22:29 +0900 Subject: [PATCH 4/5] =?UTF-8?q?refactor=20:=20param=20->=20params=20?= =?UTF-8?q?=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - #867 --- src/api/memberApi.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/api/memberApi.ts b/src/api/memberApi.ts index 2bffdbb5f..1c02eb915 100644 --- a/src/api/memberApi.ts +++ b/src/api/memberApi.ts @@ -8,8 +8,8 @@ import { ProfileInfo, MemberDetailInfo, PageAndSize, PointRank } from './dto'; const memberKeys = { base: ['member'] as const, - memberList: ['member', 'memberList'] as const, - pointRank: (param: PageAndSize) => [...memberKeys.base, 'pointRank', param] as const, + memberList: () => [...memberKeys.base, 'memberList'] as const, + pointRank: (params: PageAndSize) => [...memberKeys.base, 'pointRank', params] as const, }; const profileKeys = { profileInfo: (memberId: number) => ['profile', 'profileInfo', memberId] as const, @@ -31,7 +31,7 @@ const useGetMembersQuery = ({ }; }); }); - return useQuery(memberKeys.memberList, fetcher, { + return useQuery(memberKeys.memberList(), fetcher, { onSuccess, }); }; @@ -177,7 +177,7 @@ const useEditMemberTypeMutation = () => { return useMutation(fetcher, { onSuccess: () => { - queryClient.invalidateQueries({ queryKey: memberKeys.memberList }); + queryClient.invalidateQueries({ queryKey: memberKeys.memberList() }); }, }); }; @@ -188,7 +188,7 @@ const useDeleteMemberMutation = () => { return useMutation(fetcher, { onSuccess: () => { - queryClient.invalidateQueries({ queryKey: memberKeys.memberList }); + queryClient.invalidateQueries({ queryKey: memberKeys.memberList() }); }, }); }; From 0a77ef85a95475ff191dc05dc78615befa8ce160 Mon Sep 17 00:00:00 2001 From: gimdogyun Date: Thu, 18 Jan 2024 21:26:03 +0900 Subject: [PATCH 5/5] =?UTF-8?q?refactor=20:=20param=20->=20params=20?= =?UTF-8?q?=EB=B3=80=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - #867 --- src/api/attendanceApi.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/api/attendanceApi.ts b/src/api/attendanceApi.ts index 72414bae0..46b9f28fa 100644 --- a/src/api/attendanceApi.ts +++ b/src/api/attendanceApi.ts @@ -19,7 +19,7 @@ const attendanceKeys = { memberId, year, ], - todayAttendanceRank: (param: PageAndSize) => [...attendanceKeys.base, 'todayRank', param] as const, + todayAttendanceRank: (params: PageAndSize) => [...attendanceKeys.base, 'todayRank', params] as const, continuousAttendanceRank: () => [...attendanceKeys.base, 'continuousRank'] as const, };