UNPKG

angular-calendar-scheduler

Version:

This project provide a scheduler view component for [mattlewis92/angular-calendar](https://github.com/mattlewis92/angular-calendar).

247 lines 44.4 kB
export var DAYS_OF_WEEK; (function (DAYS_OF_WEEK) { DAYS_OF_WEEK[DAYS_OF_WEEK["SUNDAY"] = 0] = "SUNDAY"; DAYS_OF_WEEK[DAYS_OF_WEEK["MONDAY"] = 1] = "MONDAY"; DAYS_OF_WEEK[DAYS_OF_WEEK["TUESDAY"] = 2] = "TUESDAY"; DAYS_OF_WEEK[DAYS_OF_WEEK["WEDNESDAY"] = 3] = "WEDNESDAY"; DAYS_OF_WEEK[DAYS_OF_WEEK["THURSDAY"] = 4] = "THURSDAY"; DAYS_OF_WEEK[DAYS_OF_WEEK["FRIDAY"] = 5] = "FRIDAY"; DAYS_OF_WEEK[DAYS_OF_WEEK["SATURDAY"] = 6] = "SATURDAY"; })(DAYS_OF_WEEK || (DAYS_OF_WEEK = {})); const DEFAULT_WEEKEND_DAYS = [ DAYS_OF_WEEK.SUNDAY, DAYS_OF_WEEK.SATURDAY ]; export const DAYS_IN_WEEK = 7; export const HOURS_IN_DAY = 24; export const MINUTES_IN_HOUR = 60; export const SECONDS_IN_DAY = 60 * 60 * 24; export const DEFAULT_HOUR_SEGMENT_HEIGHT_PX = 40; export const DEFAULT_EVENT_WIDTH_PERCENT = 100; export const DEFAULT_HOUR_SEGMENTS = 2; export function getSchedulerViewHourGrid(dateAdapter, args) { const viewDate = args.viewDate, hourSegments = args.hourSegments, dayStart = args.dayStart, dayEnd = args.dayEnd; const hours = []; const startOfView = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfDay(viewDate), dayStart.hour), dayStart.minute); const endOfView = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfMinute(dateAdapter.endOfDay(viewDate)), dayEnd.hour), dayEnd.minute); const segmentDuration = MINUTES_IN_HOUR / hourSegments; const startOfViewDay = dateAdapter.startOfDay(viewDate); const range = (start, end) => Array.from({ length: ((end + 1) - start) }, (v, k) => k + start); const hoursInView = range(dayStart.hour, dayEnd.hour); hoursInView.forEach((hour, i) => { const segments = []; for (let j = 0; j < hourSegments; j++) { const date = dateAdapter.addMinutes(dateAdapter.addHours(startOfViewDay, hour), j * segmentDuration); if (date >= startOfView && date < endOfView) { segments.push({ date: date, isStart: j === 0 }); } } if (segments.length > 0) { hours.push({ segments: segments }); } }); return hours; } export function getSchedulerView(dateAdapter, args) { let events = args.events || []; if (!events) { events = []; } const viewDate = args.viewDate; const weekStartsOn = args.weekStartsOn; const startsWithToday = args.startsWithToday; const excluded = args.excluded || []; const hourSegments = args.hourSegments || DEFAULT_HOUR_SEGMENTS; const hourSegmentHeight = args.hourSegmentHeight || DEFAULT_HOUR_SEGMENT_HEIGHT_PX; const eventWidth = args.eventWidth || DEFAULT_EVENT_WIDTH_PERCENT; const dayStart = args.dayStart, dayEnd = args.dayEnd; const startOfViewWeek = startsWithToday ? dateAdapter.startOfDay(viewDate) : dateAdapter.startOfWeek(viewDate, { weekStartsOn: weekStartsOn }); const endOfViewWeek = startsWithToday ? dateAdapter.addDays(dateAdapter.endOfDay(viewDate), 6) : dateAdapter.endOfWeek(viewDate, { weekStartsOn: weekStartsOn }); const eventsInWeek = getEventsInPeriod(dateAdapter, { events: events, periodStart: startOfViewWeek, periodEnd: endOfViewWeek }); const days = getSchedulerViewDays(dateAdapter, { viewDate: viewDate, weekStartsOn: weekStartsOn, startsWithToday: startsWithToday, excluded: excluded }); days.forEach((day) => { const startOfView = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfDay(day.date), dayStart.hour), dayStart.minute); const endOfView = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfMinute(dateAdapter.endOfDay(day.date)), dayEnd.hour), dayEnd.minute); const previousDayEvents = []; const eventsInDay = getEventsInPeriod(dateAdapter, { events: eventsInWeek, periodStart: startOfView, periodEnd: endOfView }); day.events = eventsInDay .sort((eventA, eventB) => eventA.start.valueOf() - eventB.start.valueOf()) .map((ev) => { const eventStart = ev.start; const eventEnd = ev.end || eventStart; const startsBeforeDay = eventStart < startOfView; const endsAfterDay = dateAdapter.addMinutes(eventEnd, -1) > endOfView; const hourHeightModifier = ((hourSegments * hourSegmentHeight) + 1) / MINUTES_IN_HOUR; // +1 for the 1px segment bottom border let top = 0; if (eventStart > startOfView) { top += dateAdapter.differenceInMinutes(eventStart, startOfView); } top *= hourHeightModifier; const startDate = startsBeforeDay ? startOfView : eventStart; const endDate = endsAfterDay ? endOfView : eventEnd; let height = dateAdapter.differenceInMinutes(endDate, startDate); if (!ev.end) { height = hourSegmentHeight; } else { height *= hourHeightModifier; } const bottom = top + height; const overlappingPreviousEvents = getOverLappingDayViewEvents(previousDayEvents, top, bottom); let left = 0; while (overlappingPreviousEvents.some(previousEvent => previousEvent.left === left)) { left += eventWidth; } const event = { event: ev, top: top, height: height, width: eventWidth, left: left, startsBeforeDay: startsBeforeDay, endsAfterDay: endsAfterDay, isProcessed: false }; previousDayEvents.push(event); return event; }); day.hours = getSchedulerViewHourGrid(dateAdapter, { viewDate: viewDate, hourSegments: hourSegments, dayStart: { hour: dayStart.hour, minute: dayStart.minute }, dayEnd: { hour: dayEnd.hour, minute: dayEnd.minute } }).map((hour) => { const date = new Date(day.date.getFullYear(), day.date.getMonth(), day.date.getDate(), hour.segments[0].date.getHours()); const startOfHour = new Date(day.date.getFullYear(), day.date.getMonth(), day.date.getDate(), hour.segments[0].date.getHours()); const endOfHour = dateAdapter.addMinutes(dateAdapter.addHours(startOfHour, 1), -1); const eventsInHour = getEventsInPeriod(dateAdapter, { events: eventsInDay, periodStart: startOfHour, periodEnd: endOfHour }); const segments = hour.segments.map((segment) => { segment.date = dateAdapter.setDate(dateAdapter.setMonth(dateAdapter.setYear(segment.date, day.date.getFullYear()), day.date.getMonth()), day.date.getDate()); const startOfSegment = segment.date; const endOfSegment = dateAdapter.addMinutes(segment.date, MINUTES_IN_HOUR / hourSegments); const eventsInSegment = getEventsInPeriod(dateAdapter, { events: eventsInHour, periodStart: startOfSegment, periodEnd: endOfSegment }); return { segment: segment, date: new Date(segment.date), events: eventsInSegment }; }); return { hour: hour, date: date, events: eventsInHour, segments: segments }; }); }); return { days: days, period: { events: eventsInWeek, start: startOfViewWeek, end: endOfViewWeek } }; } export function getSchedulerViewDays(dateAdapter, args) { const viewDate = args.viewDate; const weekStartsOn = args.weekStartsOn; const startsWithToday = args.startsWithToday; const excluded = args.excluded || []; const weekendDays = args.weekendDays || DEFAULT_WEEKEND_DAYS; const start = startsWithToday ? new Date(viewDate) : dateAdapter.startOfWeek(viewDate, { weekStartsOn: weekStartsOn }); const days = []; const loop = (i) => { const date = dateAdapter.addDays(start, i); if (!excluded.some((e) => date.getDay() === e)) { days.push(getSchedulerDay(dateAdapter, { date, weekendDays })); } }; for (let i = 0; i < DAYS_IN_WEEK; i++) { loop(i); } return days; } function getSchedulerDay(dateAdapter, args) { const date = args.date; const today = dateAdapter.startOfDay(new Date()); return { date: date, isPast: date < today, isToday: dateAdapter.isSameDay(date, today), isFuture: date >= dateAdapter.addDays(today, 1), isWeekend: args.weekendDays.indexOf(dateAdapter.getDay(date)) > -1, inMonth: dateAdapter.isSameMonth(date, today), hours: [] }; } function getEventsInPeriod(dateAdapter, args) { const events = args.events, periodStart = args.periodStart, periodEnd = args.periodEnd; return events.filter((event) => isEventInPeriod(dateAdapter, { event: event, periodStart: periodStart, periodEnd: periodEnd })); } function isEventInPeriod(dateAdapter, args) { const { isSameSecond } = dateAdapter; const event = args.event, periodStart = args.periodStart, periodEnd = args.periodEnd; const eventStart = event.start; const eventEnd = event.end || event.start; if (eventStart > periodStart && eventStart < periodEnd) { return true; } if (eventEnd > periodStart && eventEnd < periodEnd) { return true; } if (eventStart < periodStart && eventEnd > periodEnd) { return true; } if (isSameSecond(eventStart, periodStart) || isSameSecond(eventStart, periodEnd)) { return true; } if (isSameSecond(eventEnd, periodStart) || isSameSecond(eventEnd, periodEnd)) { return true; } return false; } function getOverLappingDayViewEvents(events, top, bottom) { return events.filter((previousEvent) => { const previousEventTop = previousEvent.top; const previousEventBottom = previousEvent.top + previousEvent.height; if (top < previousEventBottom && previousEventBottom < bottom) { return true; } else if (previousEventTop <= top && bottom <= previousEventBottom) { return true; } return false; }); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-scheduler-utils.js","sourceRoot":"ng://angular-calendar-scheduler/","sources":["modules/scheduler/utils/calendar-scheduler-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    CalendarSchedulerEvent,\r\n    SchedulerViewHour,\r\n    SchedulerViewDay,\r\n    SchedulerViewEvent,\r\n    SchedulerViewHourSegment,\r\n    SchedulerView,\r\n    SchedulerViewPeriod\r\n} from '../models';\r\nimport {\r\n    DayViewHour,\r\n    DayViewHourSegment\r\n} from 'calendar-utils';\r\nimport { DateAdapter } from 'angular-calendar';\r\n\r\n\r\nexport enum DAYS_OF_WEEK {\r\n    SUNDAY = 0,\r\n    MONDAY = 1,\r\n    TUESDAY = 2,\r\n    WEDNESDAY = 3,\r\n    THURSDAY = 4,\r\n    FRIDAY = 5,\r\n    SATURDAY = 6\r\n}\r\n\r\nconst DEFAULT_WEEKEND_DAYS: number[] = [\r\n    DAYS_OF_WEEK.SUNDAY,\r\n    DAYS_OF_WEEK.SATURDAY\r\n];\r\n\r\nexport const DAYS_IN_WEEK: number = 7;\r\nexport const HOURS_IN_DAY: number = 24;\r\nexport const MINUTES_IN_HOUR: number = 60;\r\nexport const SECONDS_IN_DAY: number = 60 * 60 * 24;\r\n\r\nexport const DEFAULT_HOUR_SEGMENT_HEIGHT_PX = 40;\r\nexport const DEFAULT_EVENT_WIDTH_PERCENT = 100;\r\nexport const DEFAULT_HOUR_SEGMENTS = 2;\r\n\r\nexport interface GetSchedulerViewHourGridArgs {\r\n    viewDate: Date;\r\n    hourSegments: number;\r\n    dayStart: {\r\n        hour: number;\r\n        minute: number;\r\n    };\r\n    dayEnd: {\r\n        hour: number;\r\n        minute: number;\r\n    };\r\n}\r\n\r\nexport function getSchedulerViewHourGrid(dateAdapter: DateAdapter, args: GetSchedulerViewHourGridArgs): DayViewHour[] {\r\n    const viewDate: Date = args.viewDate, hourSegments: number = args.hourSegments, dayStart: any = args.dayStart, dayEnd: any = args.dayEnd;\r\n    const hours: DayViewHour[] = [];\r\n\r\n    const startOfView: Date = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfDay(viewDate), dayStart.hour), dayStart.minute);\r\n    const endOfView: Date = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfMinute(dateAdapter.endOfDay(viewDate)), dayEnd.hour), dayEnd.minute);\r\n    const segmentDuration: number = MINUTES_IN_HOUR / hourSegments;\r\n    const startOfViewDay: Date = dateAdapter.startOfDay(viewDate);\r\n\r\n    const range = (start: number, end: number): number[] => Array.from({ length: ((end + 1) - start) }, (v, k) => k + start);\r\n    const hoursInView: number[] = range(dayStart.hour, dayEnd.hour);\r\n\r\n    hoursInView.forEach((hour: number, i: number) => {\r\n        const segments = [];\r\n        for (let j = 0; j < hourSegments; j++) {\r\n            const date = dateAdapter.addMinutes(dateAdapter.addHours(startOfViewDay, hour), j * segmentDuration);\r\n            if (date >= startOfView && date < endOfView) {\r\n                segments.push({\r\n                    date: date,\r\n                    isStart: j === 0\r\n                });\r\n            }\r\n        }\r\n        if (segments.length > 0) {\r\n            hours.push(<DayViewHour>{ segments: segments });\r\n        }\r\n    });\r\n    return hours;\r\n}\r\n\r\nexport interface GetSchedulerViewArgs {\r\n    events?: CalendarSchedulerEvent[];\r\n    viewDate: Date;\r\n    hourSegments: 1 | 2 | 4 | 6;\r\n    weekStartsOn: number;\r\n    startsWithToday: boolean;\r\n    dayStart: {\r\n        hour: number;\r\n        minute: number;\r\n    };\r\n    dayEnd: {\r\n        hour: number;\r\n        minute: number;\r\n    };\r\n    excluded?: number[];\r\n    eventWidth: number;\r\n    hourSegmentHeight: number;\r\n}\r\n\r\nexport function getSchedulerView(dateAdapter: DateAdapter, args: GetSchedulerViewArgs): SchedulerView {\r\n    let events: CalendarSchedulerEvent[] = args.events || [];\r\n    if (!events) { events = []; }\r\n\r\n    const viewDate: Date = args.viewDate;\r\n    const weekStartsOn: number = args.weekStartsOn;\r\n    const startsWithToday: boolean = args.startsWithToday;\r\n    const excluded: number[] = args.excluded || [];\r\n    const hourSegments: number = args.hourSegments || DEFAULT_HOUR_SEGMENTS;\r\n    const hourSegmentHeight: number = args.hourSegmentHeight || DEFAULT_HOUR_SEGMENT_HEIGHT_PX;\r\n    const eventWidth: number = args.eventWidth || DEFAULT_EVENT_WIDTH_PERCENT;\r\n    const dayStart: any = args.dayStart, dayEnd: any = args.dayEnd;\r\n\r\n    const startOfViewWeek: Date = startsWithToday ? dateAdapter.startOfDay(viewDate) : dateAdapter.startOfWeek(viewDate, { weekStartsOn: weekStartsOn });\r\n    const endOfViewWeek: Date = startsWithToday ? dateAdapter.addDays(dateAdapter.endOfDay(viewDate), 6) : dateAdapter.endOfWeek(viewDate, { weekStartsOn: weekStartsOn });\r\n\r\n    const eventsInWeek: CalendarSchedulerEvent[] = getEventsInPeriod(dateAdapter, {\r\n        events: events,\r\n        periodStart: startOfViewWeek,\r\n        periodEnd: endOfViewWeek\r\n    });\r\n\r\n    const days: SchedulerViewDay[] = getSchedulerViewDays(dateAdapter, {\r\n        viewDate: viewDate,\r\n        weekStartsOn: weekStartsOn,\r\n        startsWithToday: startsWithToday,\r\n        excluded: excluded\r\n    });\r\n    days.forEach((day: SchedulerViewDay) => {\r\n        const startOfView: Date = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfDay(day.date), dayStart.hour), dayStart.minute);\r\n        const endOfView: Date = dateAdapter.setMinutes(dateAdapter.setHours(dateAdapter.startOfMinute(dateAdapter.endOfDay(day.date)), dayEnd.hour), dayEnd.minute);\r\n        const previousDayEvents: SchedulerViewEvent[] = [];\r\n\r\n        const eventsInDay: CalendarSchedulerEvent[] = getEventsInPeriod(dateAdapter, {\r\n            events: eventsInWeek,\r\n            periodStart: startOfView,\r\n            periodEnd: endOfView\r\n        });\r\n\r\n        day.events = eventsInDay\r\n            .sort((eventA: CalendarSchedulerEvent, eventB: CalendarSchedulerEvent) => eventA.start.valueOf() - eventB.start.valueOf())\r\n            .map((ev: CalendarSchedulerEvent) => {\r\n                const eventStart: Date = ev.start;\r\n                const eventEnd: Date = ev.end || eventStart;\r\n                const startsBeforeDay: boolean = eventStart < startOfView;\r\n                const endsAfterDay: boolean = dateAdapter.addMinutes(eventEnd, -1) > endOfView;\r\n                const hourHeightModifier: number = ((hourSegments * hourSegmentHeight) + 1) / MINUTES_IN_HOUR; // +1 for the 1px segment bottom border\r\n\r\n                let top: number = 0;\r\n                if (eventStart > startOfView) {\r\n                    top += dateAdapter.differenceInMinutes(eventStart, startOfView);\r\n                }\r\n                top *= hourHeightModifier;\r\n\r\n                const startDate: Date = startsBeforeDay ? startOfView : eventStart;\r\n                const endDate: Date = endsAfterDay ? endOfView : eventEnd;\r\n                let height: number = dateAdapter.differenceInMinutes(endDate, startDate);\r\n                if (!ev.end) {\r\n                    height = hourSegmentHeight;\r\n                } else {\r\n                    height *= hourHeightModifier;\r\n                }\r\n\r\n                const bottom: number = top + height;\r\n                const overlappingPreviousEvents = getOverLappingDayViewEvents(\r\n                    previousDayEvents,\r\n                    top,\r\n                    bottom\r\n                );\r\n\r\n                let left: number = 0;\r\n                while (overlappingPreviousEvents.some(previousEvent => previousEvent.left === left)) {\r\n                    left += eventWidth;\r\n                }\r\n\r\n                const event: SchedulerViewEvent =\r\n                <SchedulerViewEvent>{\r\n                    event: ev,\r\n                    top: top,\r\n                    height: height,\r\n                    width: eventWidth,\r\n                    left: left,\r\n                    startsBeforeDay: startsBeforeDay,\r\n                    endsAfterDay: endsAfterDay,\r\n                    isProcessed: false\r\n                };\r\n\r\n                previousDayEvents.push(event);\r\n\r\n                return event;\r\n            });\r\n\r\n        day.hours = getSchedulerViewHourGrid(dateAdapter, {\r\n            viewDate: viewDate,\r\n            hourSegments: hourSegments,\r\n            dayStart: {\r\n                hour: dayStart.hour,\r\n                minute: dayStart.minute\r\n            },\r\n            dayEnd: {\r\n                hour: dayEnd.hour,\r\n                minute: dayEnd.minute\r\n            }\r\n        }).map((hour: DayViewHour) => {\r\n            const date: Date = new Date(day.date.getFullYear(), day.date.getMonth(), day.date.getDate(), hour.segments[0].date.getHours());\r\n\r\n            const startOfHour: Date = new Date(day.date.getFullYear(), day.date.getMonth(), day.date.getDate(), hour.segments[0].date.getHours());\r\n            const endOfHour: Date = dateAdapter.addMinutes(dateAdapter.addHours(startOfHour, 1), -1);\r\n\r\n            const eventsInHour: CalendarSchedulerEvent[] = getEventsInPeriod(dateAdapter, {\r\n                events: eventsInDay,\r\n                periodStart: startOfHour,\r\n                periodEnd: endOfHour\r\n            });\r\n\r\n            const segments: SchedulerViewHourSegment[] =\r\n                hour.segments.map((segment: DayViewHourSegment) => {\r\n                    segment.date = dateAdapter.setDate(dateAdapter.setMonth(dateAdapter.setYear(segment.date, day.date.getFullYear()), day.date.getMonth()), day.date.getDate());\r\n\r\n                    const startOfSegment: Date = segment.date;\r\n                    const endOfSegment: Date = dateAdapter.addMinutes(segment.date, MINUTES_IN_HOUR / hourSegments);\r\n\r\n                    const eventsInSegment: CalendarSchedulerEvent[] = getEventsInPeriod(dateAdapter, {\r\n                        events: eventsInHour,\r\n                        periodStart: startOfSegment,\r\n                        periodEnd: endOfSegment\r\n                    });\r\n\r\n                    return <SchedulerViewHourSegment>{\r\n                        segment: segment,\r\n                        date: new Date(segment.date),\r\n                        events: eventsInSegment\r\n                    };\r\n                });\r\n\r\n            return <SchedulerViewHour>{\r\n                hour: hour,\r\n                date: date,\r\n                events: eventsInHour,\r\n                segments: segments\r\n            };\r\n        });\r\n    });\r\n\r\n    return <SchedulerView>{\r\n        days: days,\r\n        period: <SchedulerViewPeriod>{\r\n            events: eventsInWeek,\r\n            start: startOfViewWeek,\r\n            end: endOfViewWeek\r\n        }\r\n    };\r\n}\r\n\r\nexport interface GetSchedulerViewDaysArgs {\r\n    viewDate: Date;\r\n    weekStartsOn: number;\r\n    startsWithToday: boolean;\r\n    excluded?: number[];\r\n    weekendDays?: number[];\r\n}\r\n\r\nexport function getSchedulerViewDays(dateAdapter: DateAdapter, args: GetSchedulerViewDaysArgs): SchedulerViewDay[] {\r\n    const viewDate: Date = args.viewDate;\r\n    const weekStartsOn: number = args.weekStartsOn;\r\n    const startsWithToday: boolean = args.startsWithToday;\r\n    const excluded: number[] = args.excluded || [];\r\n    const weekendDays: number[] = args.weekendDays || DEFAULT_WEEKEND_DAYS;\r\n\r\n    const start = startsWithToday ? new Date(viewDate) : dateAdapter.startOfWeek(viewDate, { weekStartsOn: weekStartsOn });\r\n    const days: SchedulerViewDay[] = [];\r\n    const loop = (i: number) => {\r\n        const date = dateAdapter.addDays(start, i);\r\n        if (!excluded.some((e: number) => date.getDay() === e)) {\r\n            days.push(getSchedulerDay(dateAdapter, { date, weekendDays }));\r\n        }\r\n    };\r\n    for (let i = 0; i < DAYS_IN_WEEK; i++) {\r\n        loop(i);\r\n    }\r\n    return days;\r\n}\r\n\r\nfunction getSchedulerDay(dateAdapter: DateAdapter, args: { date: Date, weekendDays: number[] }): SchedulerViewDay {\r\n    const date: Date = args.date;\r\n    const today: Date = dateAdapter.startOfDay(new Date());\r\n\r\n    return <SchedulerViewDay>{\r\n        date: date,\r\n        isPast: date < today,\r\n        isToday: dateAdapter.isSameDay(date, today),\r\n        isFuture: date >= dateAdapter.addDays(today, 1),\r\n        isWeekend: args.weekendDays.indexOf(dateAdapter.getDay(date)) > -1,\r\n        inMonth: dateAdapter.isSameMonth(date, today),\r\n        hours: []\r\n    };\r\n}\r\n\r\nexport interface GetEventsInPeriodArgs {\r\n    events: CalendarSchedulerEvent[];\r\n    periodStart: Date;\r\n    periodEnd: Date;\r\n}\r\n\r\nfunction getEventsInPeriod(dateAdapter: DateAdapter, args: GetEventsInPeriodArgs): CalendarSchedulerEvent[] {\r\n    const events: CalendarSchedulerEvent[] = args.events, periodStart: string | number | Date = args.periodStart, periodEnd: string | number | Date = args.periodEnd;\r\n    return events.filter((event) => isEventInPeriod(dateAdapter, { event: event, periodStart: periodStart, periodEnd: periodEnd }));\r\n}\r\n\r\ninterface IsEventInPeriodArgs {\r\n    event: CalendarSchedulerEvent;\r\n    periodStart: Date;\r\n    periodEnd: Date;\r\n}\r\n\r\n\r\nfunction isEventInPeriod(dateAdapter: DateAdapter, args: IsEventInPeriodArgs): boolean {\r\n    const { isSameSecond } = dateAdapter;\r\n    const event: CalendarSchedulerEvent = args.event, periodStart: string | number | Date = args.periodStart, periodEnd: string | number | Date = args.periodEnd;\r\n    const eventStart: Date = event.start;\r\n    const eventEnd: Date = event.end || event.start;\r\n\r\n    if (eventStart > periodStart && eventStart < periodEnd) {\r\n        return true;\r\n    }\r\n\r\n    if (eventEnd > periodStart && eventEnd < periodEnd) {\r\n        return true;\r\n    }\r\n\r\n    if (eventStart < periodStart && eventEnd > periodEnd) {\r\n        return true;\r\n    }\r\n\r\n    if (isSameSecond(eventStart, periodStart) || isSameSecond(eventStart, periodEnd)) {\r\n        return true;\r\n    }\r\n\r\n    if (isSameSecond(eventEnd, periodStart) || isSameSecond(eventEnd, periodEnd)) {\r\n        return true;\r\n    }\r\n\r\n    return false;\r\n}\r\n\r\n\r\nfunction getOverLappingDayViewEvents(events: SchedulerViewEvent[], top: number, bottom: number): SchedulerViewEvent[] {\r\n    return events.filter((previousEvent: SchedulerViewEvent) => {\r\n        const previousEventTop: number = previousEvent.top;\r\n        const previousEventBottom: number = previousEvent.top + previousEvent.height;\r\n\r\n        if (top < previousEventBottom && previousEventBottom < bottom) {\r\n            return true;\r\n        } else if (previousEventTop <= top && bottom <= previousEventBottom) {\r\n            return true;\r\n        }\r\n\r\n        return false;\r\n    });\r\n}\r\n"]}