diff --git a/src/apis/domains/tickets/api.ts b/src/apis/domains/tickets/api.ts index 1590cc38..8cbb1f14 100644 --- a/src/apis/domains/tickets/api.ts +++ b/src/apis/domains/tickets/api.ts @@ -81,3 +81,23 @@ export const putTicketRefund = async ( return null; } }; + +// 예매자 삭제 (PUT) + +export type TicketDeleteRequest = components["schemas"]["TicketDeleteRequest"]; + +export const putTicketDelete = async ( + formData: TicketDeleteRequest +): Promise => { + try { + const response: AxiosResponse> = await put( + "tickets/delete", + formData + ); + + return response.data.data; + } catch (error) { + console.log("error", error); + return null; + } +}; diff --git a/src/apis/domains/tickets/queries.ts b/src/apis/domains/tickets/queries.ts index 1fbb3c29..3a26f50e 100644 --- a/src/apis/domains/tickets/queries.ts +++ b/src/apis/domains/tickets/queries.ts @@ -3,8 +3,10 @@ import { PatchFormDataProps } from "@typings/deleteBookerFormatProps"; import { getTicketReq, getTicketRetrieve, + putTicketDelete, putTicketRefund, putTicketUpdate, + TicketDeleteRequest, TicketRefundRequest, TicketUpdateRequest, } from "./api"; @@ -50,3 +52,16 @@ export const useTicketRefund = () => { }, }); }; + +// 예매자 삭제 여부 수정 API (PUT)를 위한 쿼리 작성 +export const useTicketDelete = () => { + const queryClient = new QueryClient(); + + return useMutation({ + mutationFn: (formData: TicketDeleteRequest) => putTicketDelete(formData), + onSuccess: (res) => { + queryClient.invalidateQueries({ queryKey: [QUERY_KEY.LIST, BOOKING_QUERY_KEY.BOOKING_LIST] }); + queryClient.refetchQueries({ queryKey: [QUERY_KEY.LIST, BOOKING_QUERY_KEY.BOOKING_LIST] }); + }, + }); +}; diff --git a/src/pages/ticketholderlist/TicketHolderList.tsx b/src/pages/ticketholderlist/TicketHolderList.tsx index 7dd86c7a..91c0c94c 100644 --- a/src/pages/ticketholderlist/TicketHolderList.tsx +++ b/src/pages/ticketholderlist/TicketHolderList.tsx @@ -1,4 +1,5 @@ import { + useTicketDelete, useTicketPatch, useTicketRefund, useTicketRetrive, @@ -141,7 +142,6 @@ const TicketHolderList = () => { }; // 환불 요청 - const { mutate: refundMutate, mutateAsync: refundMutateAsync, @@ -186,6 +186,51 @@ const TicketHolderList = () => { }, 1000); }; + // 취소 요청 + const { + mutate: deleteMutate, + mutateAsync: deleteMutateAsync, + isPending: deleteIsPending, + } = useTicketDelete(); + + const handlePaymentDeleteBtn = () => { + openConfirm({ + title: "예매자를 삭제하시겠어요?", + subTitle: "한 번 삭제한 예매자 정보는 다시 복구할 수 없어요.", + okText: "삭제하기", + noText: "아니요", + okCallback: () => { + handlePaymentDeleteAxiosFunc(); + // 혹시 테스트 과정에서 로그 확인을 위해 새로고침을 지운다면 아래 주석 해제 + // setStatus("DEFAULT"); + // setFilterList({ scheduleNumber: [], bookingStatus: [] }); + // setCheckedBookingId([]); + }, + noCallback: closeConfirm, + }); + }; + + const handlePaymentDeleteAxiosFunc = () => { + if (deleteIsPending) { + return; + } + // 취소 요청 PUT API 요청 + // bookingId만 전달 + const filteredPaymentData = paymentData.map(({ bookingId }) => ({ + bookingId: checkedBookingId.includes(bookingId) && bookingId, + })); + + deleteMutate({ + performanceId: Number(performanceId), + bookingList: filteredPaymentData, + }); + closeConfirm(); + showToast(); + setTimeout(() => { + window.location.reload(); + }, 1000); + }; + const actions = { PAYMENT: { text: "입금 처리하기", @@ -195,16 +240,14 @@ const TicketHolderList = () => { }, REFUND: { text: "환불 처리하기", - // TODO : 환불 처리 팝업 action: () => { handlePaymentRefundBtn(); }, }, DELETE: { text: "예매자 삭제하기", - // TODO : 예매자 삭제 팝업 action: () => { - setStatus("DEFAULT"), setFilterList({ scheduleNumber: [], bookingStatus: [] }); + handlePaymentDeleteBtn(); }, }, DEFAULT: {