UNPKG

angular-calendar-scheduler

Version:

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

58 lines 11.4 kB
import { MINUTES_IN_HOUR } from '../scheduler/utils/calendar-scheduler-utils'; export function addPeriod(dateAdapter, period, date, amount) { return { day: dateAdapter.addDays, week: dateAdapter.addWeeks, month: dateAdapter.addMonths }[period](date, amount); } export function subPeriod(dateAdapter, period, date, amount) { return { day: dateAdapter.subDays, week: dateAdapter.subWeeks, month: dateAdapter.subMonths }[period](date, amount); } export function startOfPeriod(dateAdapter, period, date) { return { day: dateAdapter.startOfDay, week: dateAdapter.startOfWeek, month: dateAdapter.startOfMonth }[period](date); } export function endOfPeriod(dateAdapter, period, date) { return { day: dateAdapter.endOfDay, week: dateAdapter.endOfWeek, month: dateAdapter.endOfMonth }[period](date); } export const trackByDayOrEvent = (index, event) => (event.event.id ? event.event.id : event.event); export const trackByHourColumn = (index, day) => day.hours[0] ? day.hours[0].segments[0].date.toISOString() : day; export const trackByHour = (index, hour) => hour.segments[0].date.toISOString(); export const trackByHourSegment = (index, segment) => segment.date.toISOString(); export function getMinimumEventHeightInMinutes(hourSegments, hourSegmentHeight) { return (MINUTES_IN_HOUR / (hourSegments * hourSegmentHeight)) * hourSegmentHeight; } export function getDefaultEventEnd(dateAdapter, event, minimumMinutes) { return event.end ? event.end : dateAdapter.addMinutes(event.start, minimumMinutes); } export function roundToNearest(amount, precision) { return Math.round(amount / precision) * precision; } export function getMinutesMoved(movedY, hourSegments, hourSegmentHeight, eventSnapSize) { const draggedInPixelsSnapSize = roundToNearest(movedY, eventSnapSize || hourSegmentHeight); const pixelAmountInMinutes = MINUTES_IN_HOUR / (hourSegments * hourSegmentHeight); return draggedInPixelsSnapSize * pixelAmountInMinutes; } export function isDraggedWithinPeriod(newStart, newEnd, period) { const end = newEnd || newStart; return ((period.start <= newStart && newStart <= period.end) || (period.start <= end && end <= period.end)); } export function shouldFireDroppedEvent(dropEvent, date, calendarId) { return (dropEvent.dropData && dropEvent.dropData.event && dropEvent.dropData.calendarId !== calendarId); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"ng://angular-calendar-scheduler/","sources":["modules/common/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    SchedulerViewPeriod,\r\n    SchedulerViewEvent,\r\n    SchedulerViewDay,\r\n    CalendarSchedulerEvent,\r\n    SchedulerViewHour,\r\n    SchedulerViewHourSegment\r\n} from '../scheduler/models';\r\nimport {\r\n    DayViewHour\r\n} from 'calendar-utils';\r\nimport {\r\n    CalendarView,\r\n    DateAdapter\r\n} from 'angular-calendar';\r\nimport { MINUTES_IN_HOUR } from '../scheduler/utils/calendar-scheduler-utils';\r\n\r\nexport function addPeriod(dateAdapter: DateAdapter, period: CalendarView, date: Date, amount: number): Date {\r\n    return {\r\n        day: dateAdapter.addDays,\r\n        week: dateAdapter.addWeeks,\r\n        month: dateAdapter.addMonths\r\n    }[period](date, amount);\r\n}\r\n\r\nexport function subPeriod(dateAdapter: DateAdapter, period: CalendarView, date: Date, amount: number): Date {\r\n    return {\r\n        day: dateAdapter.subDays,\r\n        week: dateAdapter.subWeeks,\r\n        month: dateAdapter.subMonths\r\n    }[period](date, amount);\r\n}\r\n\r\nexport function startOfPeriod(dateAdapter: DateAdapter, period: CalendarView, date: Date): Date {\r\n    return {\r\n        day: dateAdapter.startOfDay,\r\n        week: dateAdapter.startOfWeek,\r\n        month: dateAdapter.startOfMonth\r\n    }[period](date);\r\n}\r\n\r\nexport function endOfPeriod(dateAdapter: DateAdapter, period: CalendarView, date: Date): Date {\r\n    return {\r\n        day: dateAdapter.endOfDay,\r\n        week: dateAdapter.endOfWeek,\r\n        month: dateAdapter.endOfMonth\r\n    }[period](date);\r\n}\r\n\r\n\r\nexport const trackByDayOrEvent = (index: number, event: SchedulerViewEvent ) =>\r\n    (event.event.id ? event.event.id : event.event);\r\n\r\nexport const trackByHourColumn = (index: number, day: SchedulerViewDay) =>\r\n    day.hours[0] ? day.hours[0].segments[0].date.toISOString() : day;\r\n\r\nexport const trackByHour = (index: number, hour: DayViewHour | SchedulerViewHour) =>\r\n    hour.segments[0].date.toISOString();\r\n\r\nexport const trackByHourSegment = (index: number, segment: SchedulerViewHourSegment) =>\r\n    segment.date.toISOString();\r\n\r\n\r\nexport function getMinimumEventHeightInMinutes(hourSegments: number, hourSegmentHeight: number) {\r\n    return (MINUTES_IN_HOUR / (hourSegments * hourSegmentHeight)) * hourSegmentHeight;\r\n}\r\n\r\nexport function getDefaultEventEnd(dateAdapter: DateAdapter, event: CalendarSchedulerEvent, minimumMinutes: number): Date {\r\n    return event.end ? event.end : dateAdapter.addMinutes(event.start, minimumMinutes);\r\n}\r\n\r\nexport function roundToNearest(amount: number, precision: number): number {\r\n    return Math.round(amount / precision) * precision;\r\n}\r\n\r\nexport function getMinutesMoved(movedY: number, hourSegments: number, hourSegmentHeight: number, eventSnapSize: number): number {\r\n    const draggedInPixelsSnapSize = roundToNearest(movedY, eventSnapSize || hourSegmentHeight);\r\n    const pixelAmountInMinutes = MINUTES_IN_HOUR / (hourSegments * hourSegmentHeight);\r\n    return draggedInPixelsSnapSize * pixelAmountInMinutes;\r\n}\r\n\r\nexport function isDraggedWithinPeriod(newStart: Date, newEnd: Date, period: SchedulerViewPeriod): boolean {\r\n    const end = newEnd || newStart;\r\n    return (\r\n        (period.start <= newStart && newStart <= period.end) ||\r\n        (period.start <= end && end <= period.end)\r\n    );\r\n}\r\n\r\nexport function shouldFireDroppedEvent(dropEvent: { dropData?: { event?: CalendarSchedulerEvent; calendarId?: symbol } }, date: Date, calendarId: symbol): boolean {\r\n    return (\r\n        dropEvent.dropData &&\r\n        dropEvent.dropData.event &&\r\n        dropEvent.dropData.calendarId !== calendarId\r\n    );\r\n}\r\n"]}