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
JavaScript
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"]}