From 39ffe6bf8098af57fb3e7e9aebf7c99598e0c057 Mon Sep 17 00:00:00 2001 From: Hariom Balhara Date: Mon, 2 Sep 2024 16:12:11 +0530 Subject: [PATCH] Fix unconfirmed bookings blocking slots being fetched for all troubleshooters (#16439) Co-authored-by: Udit Takkar <53316345+Udit-takkar@users.noreply.github.com> --- packages/core/getBusyTimes.ts | 36 ++++++++++++++++++----------------- 1 file changed, 19 insertions(+), 17 deletions(-) diff --git a/packages/core/getBusyTimes.ts b/packages/core/getBusyTimes.ts index 263ff90252d0f6..a4f479a76694e2 100644 --- a/packages/core/getBusyTimes.ts +++ b/packages/core/getBusyTimes.ts @@ -155,29 +155,31 @@ export async function getBusyTimes(params: { select: bookingsSelect, }); - const currentBookingsAllUsersQueryThree = prisma.booking.findMany({ - where: { - startTime: { lte: endTimeDate }, - endTime: { gte: startTimeDate }, - eventType: { - id: eventTypeId, - requiresConfirmation: true, - requiresConfirmationWillBlockSlot: true, - }, - status: { - in: [BookingStatus.PENDING], - }, - }, - select: bookingsSelect, - }); + const unconfirmedBookingsBlockingSlots = eventTypeId + ? prisma.booking.findMany({ + where: { + startTime: { lte: endTimeDate }, + endTime: { gte: startTimeDate }, + eventType: { + id: eventTypeId, + requiresConfirmation: true, + requiresConfirmationWillBlockSlot: true, + }, + status: { + in: [BookingStatus.PENDING], + }, + }, + select: bookingsSelect, + }) + : null; const [resultOne, resultTwo, resultThree] = await Promise.all([ currentBookingsAllUsersQueryOne, currentBookingsAllUsersQueryTwo, - currentBookingsAllUsersQueryThree, + unconfirmedBookingsBlockingSlots, ]); - bookings = [...resultOne, ...resultTwo, ...resultThree]; + bookings = [...resultOne, ...resultTwo, ...(resultThree ?? [])]; } const bookingSeatCountMap: { [x: string]: number } = {};