From 105e540d62f8522e0f4d6c1d82661778921f89c8 Mon Sep 17 00:00:00 2001 From: "riho.takagi" Date: Mon, 7 Oct 2024 15:38:13 -0400 Subject: [PATCH] Fix finding rooom logic --- booking-app/app/api/syncCalendars/route.ts | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/booking-app/app/api/syncCalendars/route.ts b/booking-app/app/api/syncCalendars/route.ts index b04ff557..1f6b71ce 100644 --- a/booking-app/app/api/syncCalendars/route.ts +++ b/booking-app/app/api/syncCalendars/route.ts @@ -8,13 +8,21 @@ import { NextResponse } from "next/server"; const db = admin.firestore(); const areRoomIdsSame = (roomIds1: string, roomIds2: string): boolean => { - // Trim and split the room IDs, then sort both arrays - const sortedRoomIds1 = roomIds1.split(',').map(id => id.trim()).sort(); - const sortedRoomIds2 = roomIds2.split(',').map(id => id.trim()).sort(); + const toArray = (ids: string): string[] => { + return ids.includes(',') ? ids.split(',').map(id => id.trim()) : [ids.trim()]; + }; + + const sortedRoomIds1 = toArray(roomIds1).sort(); + const sortedRoomIds2 = toArray(roomIds2).sort(); - // Compare the two arrays - return sortedRoomIds1.length === sortedRoomIds2.length && - sortedRoomIds1.every((id, index) => id === sortedRoomIds2[index]); + console.log('Comparing room IDs:', { ids1: sortedRoomIds1, ids2: sortedRoomIds2 }); + + const areEqual = sortedRoomIds1.length === sortedRoomIds2.length && + sortedRoomIds1.every((id, index) => id === sortedRoomIds2[index]); + + console.log('Comparison result:', areEqual); + + return areEqual; }; const createBookingWithDefaults = ( partialBooking: Partial,