import { useMutation } from "@tanstack/react-query"; import { SUCCESS_STATUS } from "@calcom/platform-constants"; import type { RemoveSelectedSlotInput, ApiResponse, ApiSuccessResponseWithoutData, ApiErrorResponse, } from "@calcom/platform-types"; import http from "../lib/http"; interface IUseDeleteSelectedSlot { onSuccess?: (res: ApiSuccessResponseWithoutData) => void; onError?: (err: ApiErrorResponse) => void; } export const useDeleteSelectedSlot = ( { onSuccess, onError }: IUseDeleteSelectedSlot = { onSuccess: () => { return; }, onError: () => { return; }, } ) => { const deletedSlot = useMutation({ mutationFn: (props: RemoveSelectedSlotInput) => { return http .delete("/slots/selected-slot", { params: props, }) .then((res) => { if (res.data.status === SUCCESS_STATUS) { return res.data; } throw new Error(res.data.error.message); }); }, onSuccess: (data) => { if (data.status === SUCCESS_STATUS) { onSuccess?.(data); } else { onError?.(data); } }, onError: (err) => { onError?.(err as ApiErrorResponse); }, }); return deletedSlot; };