f4ea385c7f
* WIP * Fix for team availability with time offsets * Prevent empty schedule from opening up everything * When no utcOffset or timeZone's are given, default to 0 utcOffset (UTC) * timeZone should not be part of getUserAvailability * Prevents {days:[X],startTime:0,endTime:0} error entry * Added getAggregateWorkingHours() (#3913) * Added test for getAggregateWorkingHours * Timezone isn't used here anymore * fix: developer docs url (#3914) * fix: developer docs url added * chore : remove / * chore : import url Co-authored-by: Zach Waterfield <zlwaterfield@gmail.com> Co-authored-by: Peer Richelsen <peeroke@gmail.com> * Test fixes * Reinstate prisma (generate only) and few comments * Test fixes * Skipping getSchedule again * Added await to expect() as it involves async logic causing the promise to timeout * Test cleanup * Update jest.config.ts Co-authored-by: Alan <alannnc@gmail.com> Co-authored-by: Alex van Andel <me@alexvanandel.com> Co-authored-by: Udit Takkar <53316345+Udit-takkar@users.noreply.github.com> Co-authored-by: Zach Waterfield <zlwaterfield@gmail.com> Co-authored-by: Peer Richelsen <peeroke@gmail.com>
46 lines
1.7 KiB
TypeScript
46 lines
1.7 KiB
TypeScript
import { SchedulingType } from "@prisma/client";
|
|
|
|
import type { WorkingHours } from "@calcom/types/schedule";
|
|
|
|
/**
|
|
* This function gets team members working hours and busy slots,
|
|
* offsets them to UTC and intersects them for collective events.
|
|
**/
|
|
export const getAggregateWorkingHours = (
|
|
usersWorkingHoursAndBusySlots: Omit<
|
|
Awaited<ReturnType<Awaited<typeof import("./getUserAvailability")>["getUserAvailability"]>>,
|
|
"currentSeats"
|
|
>[],
|
|
schedulingType: SchedulingType | null
|
|
): WorkingHours[] => {
|
|
if (schedulingType !== SchedulingType.COLLECTIVE) {
|
|
return usersWorkingHoursAndBusySlots.flatMap((s) => s.workingHours);
|
|
}
|
|
return usersWorkingHoursAndBusySlots.reduce((currentWorkingHours: WorkingHours[], s) => {
|
|
const updatedWorkingHours: typeof currentWorkingHours = [];
|
|
|
|
s.workingHours.forEach((workingHour) => {
|
|
const sameDayWorkingHours = currentWorkingHours.filter((compare) =>
|
|
compare.days.find((day) => workingHour.days.includes(day))
|
|
);
|
|
if (!sameDayWorkingHours.length) {
|
|
updatedWorkingHours.push(workingHour); // the first day is always added.
|
|
return;
|
|
}
|
|
// days are overlapping when different users are involved, instead of adding we now need to subtract
|
|
updatedWorkingHours.push(
|
|
...sameDayWorkingHours.map((compare) => {
|
|
const intersect = workingHour.days.filter((day) => compare.days.includes(day));
|
|
return {
|
|
days: intersect,
|
|
startTime: Math.max(workingHour.startTime, compare.startTime),
|
|
endTime: Math.min(workingHour.endTime, compare.endTime),
|
|
};
|
|
})
|
|
);
|
|
});
|
|
|
|
return updatedWorkingHours;
|
|
}, []);
|
|
};
|