Skip to content

Commit

Permalink
Merge pull request #870 from KEEPER31337/feature/libraryApi_쿼리키_포맷_통일…
Browse files Browse the repository at this point in the history
…_#866

Feature/library api 쿼리키 포맷 통일 #866
  • Loading branch information
pipisebastian authored Jan 16, 2024
2 parents 7e4fbdd + d655605 commit 51767c6
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 43 deletions.
14 changes: 6 additions & 8 deletions src/api/dto.ts
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,11 @@ export type borrowStatus = '대출대기' | '반납대기' | '대출반려' | '

export type MemberType = '비회원' | '정회원' | '휴면회원' | '졸업' | '탈퇴';

export interface PageAndSize {
page?: number;
size?: number;
}

export interface MemberInfo {
memberId: number;
loginId: number;
Expand Down Expand Up @@ -94,11 +99,9 @@ export interface PageBlockInfo {
subtitleImages: Array<SubTitleImagesInfo>;
}

export interface BookListSearch {
export interface BookListSearch extends PageAndSize {
searchType?: 'title' | 'author' | 'all';
search?: string;
page?: number;
size?: number;
}

export interface BorrowInfoListSearch {
Expand Down Expand Up @@ -405,11 +408,6 @@ export interface TrendingPostInfo {
registerTime: string;
}

export interface PageAndSize {
page?: number;
size?: number;
}

export interface AttendRankInfo {
rank: number;
thumbnailPath?: string | null;
Expand Down
50 changes: 25 additions & 25 deletions src/api/libraryApi.ts
Original file line number Diff line number Diff line change
@@ -1,26 +1,34 @@
import { useQuery, useMutation, useQueryClient } from 'react-query';
import axios from 'axios';
import { BookInfo, BorrowedBookInfo, BookListSearch } from './dto';
import { BookInfo, BorrowedBookInfo, BookListSearch, PageAndSize } from './dto';

const libraryKeys = {
bookList: (param: BookListSearch) => ['library', 'bookList', param] as const,
borrowedBookList: ['library', 'borrowedBookList'] as const,
base: ['books'] as const,
bookList: (params: BookListSearch) => [...libraryKeys.base, params] as const,
borrowedBookList: (params: PageAndSize) => [...libraryKeys.base, 'bookBorrows', params] as const,
};

const useGetBookListQuery = ({ page, size = 6, searchType, search }: BookListSearch) => {
const params = { page, size, searchType, search };
const fetcher = () =>
axios.get('/books', { params: { page, size, searchType, search } }).then(({ data }) => {
axios.get('/books', { params }).then(({ data }) => {
const content = data.content.map(({ currentQuantity, totalQuantity, ...rest }: BookInfo) => ({
...rest,
bookQuantity: `${currentQuantity}/${totalQuantity}`,
}));
return { content, totalElement: data.totalElements, size: data.size };
});

return useQuery<{ content: BookInfo[]; totalElement: number; size: number }>(
libraryKeys.bookList({ page, size, searchType, search }),
fetcher,
);
return useQuery<{ content: BookInfo[]; totalElement: number; size: number }>(libraryKeys.bookList(params), fetcher);
};

const useGetBorrowedBookListQuery = ({ page, size }: PageAndSize) => {
const params = { page, size };
const fetcher = () =>
axios.get(`/books/book-borrows`, { params }).then(({ data }) => {
return { content: data.content, totalElement: data.totalElements };
});
return useQuery<{ content: BorrowedBookInfo[]; totalElement: number }>(libraryKeys.borrowedBookList(params), fetcher);
};

const useRequestBorrowBookMutation = () => {
Expand All @@ -30,58 +38,50 @@ const useRequestBorrowBookMutation = () => {
return useMutation(fetcher, {
onSuccess: () => {
queryClient.invalidateQueries({ queryKey: libraryKeys.bookList({}) });
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList });
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList({}) });
},
});
};

const useGetBookBorrowsQuery = ({ page, size }: { page: number; size: number }) => {
const fetcher = () =>
axios.get(`/books/book-borrows`, { params: { page, size } }).then(({ data }) => {
return { content: data.content, totalElement: data.totalElements };
});
return useQuery<{ content: BorrowedBookInfo[]; totalElement: number }>(libraryKeys.borrowedBookList, fetcher);
};

const useRequestReturnBookMutation = () => {
const queryClient = useQueryClient();
const fetcher = (selectedBookId: number) => axios.patch(`/books/borrows/${selectedBookId}/request-return`);

return useMutation(fetcher, {
onSuccess: () => {
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList });
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList({}) });
},
});
};

const useCancleReturnBookMutation = () => {
const useCancelReturnBookMutation = () => {
const queryClient = useQueryClient();
const fetcher = (selectedBookId: number) => axios.patch(`/books/borrows/${selectedBookId}/cancel-return`);

return useMutation(fetcher, {
onSuccess: () => {
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList });
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList({}) });
},
});
};

const useCancleBorrowBookMutation = () => {
const useCancelBorrowBookMutation = () => {
const queryClient = useQueryClient();

const fetcher = (selectedBookId: number) => axios.delete(`/books/borrows/${selectedBookId}/cancel-borrow`);

return useMutation(fetcher, {
onSuccess: () => {
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList });
queryClient.invalidateQueries({ queryKey: libraryKeys.borrowedBookList({}) });
},
});
};

export {
useGetBookListQuery,
useGetBorrowedBookListQuery,
useRequestBorrowBookMutation,
useGetBookBorrowsQuery,
useRequestReturnBookMutation,
useCancleReturnBookMutation,
useCancleBorrowBookMutation,
useCancelReturnBookMutation,
useCancelBorrowBookMutation,
};
4 changes: 2 additions & 2 deletions src/pages/Library/Library.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { useSearchParams } from 'react-router-dom';
import Typography from '@mui/material/Typography';
import { BookListSearch } from '@api/dto';
import { useGetExecutiveInfoQuery } from '@api/dutyManageApi';
import { useGetBookListQuery, useRequestBorrowBookMutation, useGetBookBorrowsQuery } from '@api/libraryApi';
import { useGetBookListQuery, useRequestBorrowBookMutation, useGetBorrowedBookListQuery } from '@api/libraryApi';
import { MEMBER_ROLE } from '@constants/member';
import usePagination from '@hooks/usePagination';
import StandardTablePagination from '@components/Pagination/StandardTablePagination';
Expand All @@ -25,7 +25,7 @@ const Library = () => {
const search = searchParams.get('search') as BookListSearch['search'];

const { data: bookListData } = useGetBookListQuery({ page, searchType, search });
const { data: borrowedBookListData } = useGetBookBorrowsQuery({ page: 0, size: MAX_BORROWABLE_BOOKS });
const { data: borrowedBookListData } = useGetBorrowedBookListQuery({ page: 0, size: MAX_BORROWABLE_BOOKS });
const { data: executiveInfos } = useGetExecutiveInfoQuery();
const { mutate: RequestBorrowBook } = useRequestBorrowBookMutation();

Expand Down
16 changes: 8 additions & 8 deletions src/pages/Profile/Tab/BookTab/BookTab.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,10 @@ import React from 'react';
import Typography from '@mui/material/Typography';
import { useGetExecutiveInfoQuery } from '@api/dutyManageApi';
import {
useGetBookBorrowsQuery,
useGetBorrowedBookListQuery,
useRequestReturnBookMutation,
useCancleReturnBookMutation,
useCancleBorrowBookMutation,
useCancelReturnBookMutation,
useCancelBorrowBookMutation,
} from '@api/libraryApi';
import { MEMBER_ROLE } from '@constants/member';
import BookCard from './Card/BookCard';
Expand All @@ -14,12 +14,12 @@ import BookGuide from './Guide/BookGuide';
const MAX_BORROWABLE_BOOKS = 5;

const BookTab = () => {
const { data: borrowedBookListData } = useGetBookBorrowsQuery({ page: 0, size: MAX_BORROWABLE_BOOKS });
const { data: borrowedBookListData } = useGetBorrowedBookListQuery({ page: 0, size: MAX_BORROWABLE_BOOKS });
const { data: executiveInfos } = useGetExecutiveInfoQuery();
const { mutate: requestReturnBookMutation } = useRequestReturnBookMutation();

const { mutate: cancleReturnBookMutation } = useCancleReturnBookMutation();
const { mutate: cancleBorrowBookMutation } = useCancleBorrowBookMutation();
const { mutate: cancelReturnBookMutation } = useCancelReturnBookMutation();
const { mutate: cancelBorrowBookMutation } = useCancelBorrowBookMutation();

const librarian = executiveInfos?.find((role) => role.jobName === MEMBER_ROLE.사서)?.realName || '';

Expand Down Expand Up @@ -66,8 +66,8 @@ const BookTab = () => {
<div className="flex flex-col space-y-4 overflow-y-auto">
{renderBookCard('대출중', requestReturnBookMutation)}
<div className="flex flex-row flex-wrap">
{renderBookCard('대출대기', cancleBorrowBookMutation)}
{renderBookCard('반납대기', cancleReturnBookMutation)}
{renderBookCard('대출대기', cancelBorrowBookMutation)}
{renderBookCard('반납대기', cancelReturnBookMutation)}
</div>
<div className="flex w-full flex-col items-center space-y-1">
{borrowLength === 0 && <Typography>대출대기가 없습니다</Typography>}
Expand Down

0 comments on commit 51767c6

Please sign in to comment.