@mintplayer/ng-bootstrap 13.1.21 → 13.1.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/_bootstrap.scss +0 -1
  2. package/esm2020/lib/components/context-menu/context-menu.directive.mjs +1 -2
  3. package/esm2020/lib/components/file-upload/component/file-upload.component.mjs +1 -2
  4. package/esm2020/lib/components/index.mjs +2 -1
  5. package/esm2020/lib/components/modal/service/modal.service.mjs +1 -2
  6. package/esm2020/lib/components/navbar/navbar/navbar.component.mjs +7 -4
  7. package/esm2020/lib/components/navbar/navbar-item/navbar-item.component.mjs +12 -6
  8. package/esm2020/lib/components/navbar/navbar-toggler/navbar-toggler.component.mjs +8 -5
  9. package/esm2020/lib/components/scheduler/components/index.mjs +2 -0
  10. package/esm2020/lib/components/scheduler/components/scheduler/scheduler.component.mjs +346 -0
  11. package/esm2020/lib/components/scheduler/enums/drag-operation.mjs +8 -0
  12. package/esm2020/lib/components/scheduler/index.mjs +3 -0
  13. package/esm2020/lib/components/scheduler/interfaces/drag-operation.mjs +2 -0
  14. package/esm2020/lib/components/scheduler/interfaces/preview-event.mjs +2 -0
  15. package/esm2020/lib/components/scheduler/interfaces/scheduler-event-part.mjs +2 -0
  16. package/esm2020/lib/components/scheduler/interfaces/scheduler-event-with-parts.mjs +2 -0
  17. package/esm2020/lib/components/scheduler/interfaces/scheduler-event.mjs +2 -0
  18. package/esm2020/lib/components/scheduler/interfaces/time-slot.mjs +2 -0
  19. package/esm2020/lib/components/scheduler/interfaces/timeline-track.mjs +2 -0
  20. package/esm2020/lib/components/scheduler/pipes/bs-seconds-timespan.pipe/bs-seconds-timespan.pipe.mjs +16 -0
  21. package/esm2020/lib/components/scheduler/pipes/bs-seconds-today-offset/bs-seconds-today-offset.pipe.mjs +20 -0
  22. package/esm2020/lib/components/scheduler/pipes/date-offset/date-offset.pipe.mjs +20 -0
  23. package/esm2020/lib/components/scheduler/pipes/day-of-week/day-of-week.pipe.mjs +22 -0
  24. package/esm2020/lib/components/scheduler/scheduler.module.mjs +38 -0
  25. package/esm2020/lib/components/scheduler/services/timeline/timeline.service.mjs +65 -0
  26. package/esm2020/lib/services/calendar-month/calendar-month.service.mjs +1 -1
  27. package/fesm2015/mintplayer-ng-bootstrap.mjs +526 -14
  28. package/fesm2015/mintplayer-ng-bootstrap.mjs.map +1 -1
  29. package/fesm2020/mintplayer-ng-bootstrap.mjs +526 -14
  30. package/fesm2020/mintplayer-ng-bootstrap.mjs.map +1 -1
  31. package/lib/components/index.d.ts +1 -0
  32. package/lib/components/navbar/navbar/navbar.component.d.ts +2 -1
  33. package/lib/components/navbar/navbar-item/navbar-item.component.d.ts +4 -2
  34. package/lib/components/navbar/navbar-toggler/navbar-toggler.component.d.ts +1 -1
  35. package/lib/components/scheduler/components/index.d.ts +1 -0
  36. package/lib/components/scheduler/components/scheduler/scheduler.component.d.ts +58 -0
  37. package/lib/components/scheduler/enums/drag-operation.d.ts +6 -0
  38. package/lib/components/scheduler/index.d.ts +2 -0
  39. package/lib/components/scheduler/interfaces/drag-operation.d.ts +6 -0
  40. package/lib/components/scheduler/interfaces/preview-event.d.ts +4 -0
  41. package/lib/components/scheduler/interfaces/scheduler-event-part.d.ts +6 -0
  42. package/lib/components/scheduler/interfaces/scheduler-event-with-parts.d.ts +6 -0
  43. package/lib/components/scheduler/interfaces/scheduler-event.d.ts +6 -0
  44. package/lib/components/scheduler/interfaces/time-slot.d.ts +4 -0
  45. package/lib/components/scheduler/interfaces/timeline-track.d.ts +5 -0
  46. package/lib/components/scheduler/pipes/bs-seconds-timespan.pipe/bs-seconds-timespan.pipe.d.ts +9 -0
  47. package/lib/components/scheduler/pipes/bs-seconds-today-offset/bs-seconds-today-offset.pipe.d.ts +9 -0
  48. package/lib/components/scheduler/pipes/date-offset/date-offset.pipe.d.ts +8 -0
  49. package/lib/components/scheduler/pipes/day-of-week/day-of-week.pipe.d.ts +9 -0
  50. package/lib/components/scheduler/scheduler.module.d.ts +12 -0
  51. package/lib/components/scheduler/services/timeline/timeline.service.d.ts +14 -0
  52. package/package.json +1 -1
@@ -0,0 +1,346 @@
1
+ import { Component, EventEmitter, HostListener, Input, Output, QueryList, ViewChildren } from '@angular/core';
2
+ import { BehaviorSubject, combineLatest, filter, map, Subject, take, takeUntil } from 'rxjs';
3
+ import { BsCalendarMonthService } from '../../../../services/calendar-month/calendar-month.service';
4
+ import { EDragOperation } from '../../enums/drag-operation';
5
+ import { BsTimelineService } from '../../services/timeline/timeline.service';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../../../services/calendar-month/calendar-month.service";
8
+ import * as i2 from "../../services/timeline/timeline.service";
9
+ import * as i3 from "@angular/common";
10
+ import * as i4 from "../../pipes/bs-seconds-today-offset/bs-seconds-today-offset.pipe";
11
+ import * as i5 from "../../pipes/bs-seconds-timespan.pipe/bs-seconds-timespan.pipe";
12
+ import * as i6 from "../../pipes/day-of-week/day-of-week.pipe";
13
+ export class BsSchedulerComponent {
14
+ constructor(calendarMonthService, timelineService) {
15
+ this.calendarMonthService = calendarMonthService;
16
+ this.timelineService = timelineService;
17
+ this.events$ = new BehaviorSubject([]);
18
+ this.previewEvent$ = new BehaviorSubject(null);
19
+ this.timeSlotDuration$ = new BehaviorSubject(1800);
20
+ this.mouseState$ = new BehaviorSubject(false);
21
+ this.hoveredTimeSlot$ = new BehaviorSubject(null);
22
+ this.destroyed$ = new Subject();
23
+ //#region UnitHeight
24
+ this.unitHeight$ = new BehaviorSubject(40);
25
+ this.unitHeightChange = new EventEmitter();
26
+ this.operation = null;
27
+ this.dragStartTimeslot = null;
28
+ const monday = this.calendarMonthService.getMondayBefore(new Date());
29
+ this.currentWeek$ = new BehaviorSubject(monday);
30
+ this.daysOfWeek$ = this.currentWeek$.pipe(map((weekMonday) => {
31
+ weekMonday.setHours(0);
32
+ weekMonday.setMinutes(0);
33
+ weekMonday.setSeconds(0);
34
+ weekMonday.setMilliseconds(0);
35
+ return Array.from(Array(7).keys()).map((x) => this.addDays(weekMonday, x));
36
+ }));
37
+ this.daysOfWeekWithTimestamps$ = this.daysOfWeek$
38
+ .pipe(map((daysOfWeek) => {
39
+ return { start: daysOfWeek[0].getTime(), end: daysOfWeek[daysOfWeek.length - 1].getTime() + 24 * 60 * 60 * 1000 };
40
+ }));
41
+ this.eventParts$ = this.events$.pipe(map((events) => events.map((ev) => this.timelineService.splitInParts(ev))));
42
+ this.eventPartsForThisWeek$ = combineLatest([
43
+ this.daysOfWeekWithTimestamps$,
44
+ this.eventParts$
45
+ .pipe(map(eventParts => eventParts.map(evp => evp.parts)))
46
+ .pipe(map(jaggedParts => {
47
+ return jaggedParts.reduce((flat, toFlatten) => flat.concat(toFlatten), []);
48
+ }))
49
+ ])
50
+ .pipe(map(([startAndEnd, eventParts]) => {
51
+ return eventParts.filter(eventPart => {
52
+ return !((eventPart.end.getTime() <= startAndEnd.start) || (eventPart.start.getTime() >= startAndEnd.end));
53
+ });
54
+ }));
55
+ this.previewEventParts$ = this.previewEvent$.pipe(map((event) => {
56
+ if (event) {
57
+ return this.timelineService.splitInParts(event);
58
+ }
59
+ else {
60
+ return null;
61
+ }
62
+ }));
63
+ this.previewEventPartsForThisWeek$ = combineLatest([this.daysOfWeekWithTimestamps$, this.previewEventParts$])
64
+ .pipe(map(([startAndEnd, previewEventParts]) => {
65
+ if (previewEventParts) {
66
+ return previewEventParts.parts.filter(eventPart => {
67
+ return !((eventPart.end.getTime() <= startAndEnd.start) || (eventPart.start.getTime() >= startAndEnd.end));
68
+ });
69
+ }
70
+ else {
71
+ return [];
72
+ }
73
+ }));
74
+ this.timelinedEventPartsForThisWeek$ = this.eventPartsForThisWeek$
75
+ .pipe(map(eventParts => {
76
+ // We'll only use the events for this week
77
+ const events = eventParts.map(ep => ep.event)
78
+ .filter((e, i, list) => list.indexOf(e) === i)
79
+ .filter((e) => !!e)
80
+ .map((e) => e);
81
+ const timeline = this.timelineService.getTimeline(events);
82
+ const result = timeline.map(track => {
83
+ return track.events.map(ev => {
84
+ return { event: ev, index: track.index };
85
+ });
86
+ })
87
+ .reduce((flat, toFlatten) => flat.concat(toFlatten), [])
88
+ .map((evi) => eventParts.filter(p => p.event === evi.event).map(p => {
89
+ return { part: p, index: evi.index };
90
+ }))
91
+ .reduce((flat, toFlatten) => flat.concat(toFlatten), []);
92
+ return {
93
+ total: timeline.length,
94
+ parts: result
95
+ };
96
+ }));
97
+ this.timeSlots$ = combineLatest([this.daysOfWeek$, this.timeSlotDuration$])
98
+ .pipe(map(([daysOfWeek, duration]) => {
99
+ const timeSlotsPerDay = Math.floor((60 * 60 * 24) / duration);
100
+ return Array.from(Array(timeSlotsPerDay).keys()).map((index) => {
101
+ const timeSlotStart = new Date(daysOfWeek[0]);
102
+ timeSlotStart.setSeconds(timeSlotStart.getSeconds() + index * duration);
103
+ const timeSlotEnd = new Date(timeSlotStart);
104
+ timeSlotEnd.setSeconds(timeSlotEnd.getSeconds() + duration);
105
+ return daysOfWeek.map((day) => {
106
+ const start = new Date(day);
107
+ start.setHours(timeSlotStart.getHours());
108
+ start.setMinutes(timeSlotStart.getMinutes());
109
+ start.setSeconds(timeSlotStart.getSeconds());
110
+ start.setMilliseconds(timeSlotStart.getMilliseconds());
111
+ const end = new Date(day);
112
+ end.setHours(timeSlotEnd.getHours());
113
+ end.setMinutes(timeSlotEnd.getMinutes());
114
+ end.setSeconds(timeSlotEnd.getSeconds());
115
+ end.setMilliseconds(timeSlotEnd.getMilliseconds());
116
+ return { start, end };
117
+ });
118
+ });
119
+ }));
120
+ this.unitHeight$
121
+ .pipe(takeUntil(this.destroyed$))
122
+ .subscribe((unitHeight) => {
123
+ this.unitHeightChange.emit(unitHeight);
124
+ });
125
+ }
126
+ get unitHeight() {
127
+ return this.unitHeight$.value;
128
+ }
129
+ set unitHeight(value) {
130
+ this.unitHeight$.next(value);
131
+ }
132
+ //#endregion
133
+ addDays(date, days) {
134
+ const result = new Date(date);
135
+ result.setDate(result.getDate() + days);
136
+ return result;
137
+ }
138
+ onPreviousWeek() {
139
+ this.currentWeek$
140
+ .pipe(map((w) => this.addDays(w, -7)), take(1))
141
+ .subscribe((w) => this.currentWeek$.next(w));
142
+ }
143
+ onNextWeek() {
144
+ this.currentWeek$
145
+ .pipe(map((w) => this.addDays(w, 7)), take(1))
146
+ .subscribe((w) => this.currentWeek$.next(w));
147
+ }
148
+ onCreateEvent(ev, slot) {
149
+ ev.preventDefault();
150
+ this.mouseState$.next(true);
151
+ this.dragStartTimeslot = slot;
152
+ this.operation = {
153
+ operation: EDragOperation.createEvent,
154
+ event: {
155
+ start: slot.start,
156
+ end: slot.end,
157
+ color: '#5AC8FA',
158
+ description: 'Test event',
159
+ }
160
+ };
161
+ this.previewEvent$.next({ start: slot.start, end: slot.end });
162
+ // this.events$.next([...this.events$.value, this.operation.event]);
163
+ }
164
+ onStartDragEvent(eventPart, ev) {
165
+ ev.preventDefault();
166
+ this.hoveredTimeSlot$.pipe(take(1)).subscribe((hoveredTimeSlot) => {
167
+ if (eventPart.event) {
168
+ this.dragStartTimeslot = hoveredTimeSlot;
169
+ this.operation = {
170
+ operation: EDragOperation.moveEvent,
171
+ event: eventPart.event,
172
+ };
173
+ this.previewEvent$.next({ start: eventPart.event.start, end: eventPart.event.end });
174
+ }
175
+ });
176
+ }
177
+ //#region hoveredTimeslot$
178
+ getHoveredTimeslot(ev, timeSlots) {
179
+ const hoveredSlots = this.timeSlotElements.filter((el) => {
180
+ const rct = el.nativeElement.getBoundingClientRect();
181
+ if (rct.left <= ev.x && ev.x <= rct.right && rct.top <= ev.y && ev.y <= rct.bottom) {
182
+ return true;
183
+ }
184
+ else {
185
+ return false;
186
+ }
187
+ });
188
+ if (!hoveredSlots || hoveredSlots.length === 0) {
189
+ return null;
190
+ }
191
+ const slotElement = hoveredSlots[0].nativeElement;
192
+ const strRow = slotElement.getAttribute('data-row');
193
+ if (!strRow) {
194
+ return null;
195
+ }
196
+ const row = parseInt(strRow);
197
+ const strColumn = slotElement.getAttribute('data-column');
198
+ if (!strColumn) {
199
+ return null;
200
+ }
201
+ const column = parseInt(strColumn);
202
+ const slot = timeSlots[row][column];
203
+ return slot;
204
+ }
205
+ onMousemove(ev) {
206
+ this.timeSlots$.pipe(take(1)).subscribe((timeSlots) => {
207
+ const hovered = this.getHoveredTimeslot(ev, timeSlots);
208
+ this.hoveredTimeSlot$.next(hovered);
209
+ if (this.operation) {
210
+ switch (this.operation.operation) {
211
+ case EDragOperation.createEvent:
212
+ {
213
+ if (this.operation.event && this.dragStartTimeslot && hovered && (this.operation.event.end.getTime() != hovered.end.getTime())) {
214
+ if (this.dragStartTimeslot.start.getTime() === hovered.start.getTime()) {
215
+ // 1 slot
216
+ }
217
+ else if (this.dragStartTimeslot.start.getTime() < hovered.start.getTime()) {
218
+ // Drag down
219
+ // this.operation.event.start = this.dragStartTimeslot.start;
220
+ // this.operation.event.end = hovered.end;
221
+ // this.events$.next(this.events$.value);
222
+ this.previewEvent$
223
+ .pipe(filter((ev) => !!ev && !!this.dragStartTimeslot))
224
+ .pipe(map((ev) => {
225
+ if (ev && this.dragStartTimeslot) {
226
+ ev.start = this.dragStartTimeslot.start;
227
+ ev.end = hovered.end;
228
+ }
229
+ return ev;
230
+ }))
231
+ .pipe(take(1))
232
+ .subscribe((ev) => this.previewEvent$.next(ev));
233
+ }
234
+ else if (this.dragStartTimeslot.start.getTime() > hovered.start.getTime()) {
235
+ // Drag up
236
+ // this.operation.event.start = hovered.start;
237
+ // this.operation.event.end = this.dragStartTimeslot.end;
238
+ // this.events$.next(this.events$.value);
239
+ this.previewEvent$
240
+ .pipe(filter((ev) => !!ev && !!this.dragStartTimeslot))
241
+ .pipe(map((ev) => {
242
+ if (ev && this.dragStartTimeslot) {
243
+ ev.start = hovered.start;
244
+ ev.end = this.dragStartTimeslot.end;
245
+ }
246
+ return ev;
247
+ }))
248
+ .pipe(take(1))
249
+ .subscribe((ev) => this.previewEvent$.next(ev));
250
+ }
251
+ }
252
+ }
253
+ break;
254
+ case EDragOperation.moveEvent:
255
+ {
256
+ if (hovered && this.dragStartTimeslot) {
257
+ // this.operation.event.start.setTime(this.operation.event.start.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());
258
+ // this.operation.event.end.setTime(this.operation.event.end.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());
259
+ // this.dragStartTimeslot = hovered;
260
+ // // this.events$.next(this.events$.value);
261
+ this.previewEvent$
262
+ .pipe(filter((ev) => !!ev && !!this.dragStartTimeslot))
263
+ .pipe(map((ev) => {
264
+ if (ev && this.dragStartTimeslot) {
265
+ ev.start.setTime(ev.start.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());
266
+ ev.end.setTime(ev.end.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());
267
+ this.dragStartTimeslot = hovered;
268
+ }
269
+ return ev;
270
+ }))
271
+ .pipe(take(1))
272
+ .subscribe((ev) => this.previewEvent$.next(ev));
273
+ }
274
+ }
275
+ break;
276
+ }
277
+ }
278
+ });
279
+ }
280
+ //#endregion
281
+ onMouseUp(ev) {
282
+ if (this.operation) {
283
+ switch (this.operation.operation) {
284
+ case EDragOperation.createEvent:
285
+ {
286
+ combineLatest([this.previewEvent$])
287
+ .pipe(take(1))
288
+ .subscribe(([previewEvent]) => {
289
+ if (previewEvent) {
290
+ this.operation = null;
291
+ this.dragStartTimeslot = null;
292
+ this.events$.next([...this.events$.value, {
293
+ start: previewEvent.start,
294
+ end: previewEvent.end,
295
+ color: '#F00',
296
+ description: 'New event'
297
+ }]);
298
+ this.previewEvent$.next(null);
299
+ }
300
+ });
301
+ }
302
+ break;
303
+ case EDragOperation.moveEvent:
304
+ {
305
+ this.previewEvent$
306
+ .pipe(filter((ev) => !!ev))
307
+ .pipe(take(1))
308
+ .subscribe((previewEvent) => {
309
+ if (this.operation && this.operation.event && previewEvent) {
310
+ this.operation.event.start = previewEvent.start;
311
+ this.operation.event.end = previewEvent.end;
312
+ this.operation = null;
313
+ this.dragStartTimeslot = null;
314
+ this.events$.next(this.events$.value);
315
+ this.previewEvent$.next(null);
316
+ }
317
+ });
318
+ }
319
+ break;
320
+ }
321
+ }
322
+ }
323
+ ngOnDestroy() {
324
+ this.destroyed$.next(true);
325
+ }
326
+ }
327
+ BsSchedulerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSchedulerComponent, deps: [{ token: i1.BsCalendarMonthService }, { token: i2.BsTimelineService }], target: i0.ɵɵFactoryTarget.Component });
328
+ BsSchedulerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsSchedulerComponent, selector: "bs-scheduler", inputs: { unitHeight: "unitHeight" }, outputs: { unitHeightChange: "unitHeightChange" }, host: { listeners: { "document:mousemove": "onMousemove($event)", "document:mouseup": "onMouseUp($event)" } }, viewQueries: [{ propertyName: "timeSlotElements", predicate: ["slot"], descendants: true }], ngImport: i0, template: "<div class=\"table d-flex w-100 overflow-y-auto\" [style.max-height.px]=\"null\">\n <div class=\"calendar-head\">\n <div class=\"w-100 d-flex flex-row\">\n <div class=\"d-flex calendar-left justify-content-between\">\n <button class=\"btn btn-default flex-start\" (click)=\"onPreviousWeek()\">&lt;</button>\n <button class=\"btn btn-default flex-end\" (click)=\"onNextWeek()\">&gt;</button>\n </div>\n <div class=\"flex-grow-1\" *ngFor=\"let day of (daysOfWeek$ | async)\">\n <span class=\"d-block col-form-label text-center\">\n {{ day | date: 'dd-MM-yyyy' }}\n </span>\n </div>\n </div>\n </div>\n <div class=\"calendar-body\">\n <div class=\"position-relative\">\n <!-- Timeslots -->\n <div *ngFor=\"let timeslots of (timeSlots$ | async); let i = index\" class=\"d-flex flex-row p-0 timeslot\" [style.height.px]=\"unitHeight$ | async\">\n <div class=\"calendar-cell calendar-left align-top py-0\">{{ timeslots[0].start | date: 'HH:mm:ss' }}</div>\n <div class=\"calendar-cell flex-grow-1\" *ngFor=\"let slot of timeslots; let j = index\" #slot (mousedown)=\"onCreateEvent($event, slot)\" [attr.data-row]=\"i\" [attr.data-column]=\"j\"></div>\n </div>\n \n <!-- Events -->\n <ng-container *ngIf=\"(timeSlotDuration$ | async) as timeSlotDuration\">\n <ng-container *ngIf=\"(timelinedEventPartsForThisWeek$ | async) as partData\">\n <div *ngFor=\"let eventPart of partData.parts\" class=\"event p-0\"\n [style.top.px]=\"(eventPart.part | bsSecondsTodayOffset) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.height.px]=\"(eventPart.part | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.left]=\"'calc(90px + ((100% - 90px) / 7 * ' + ((eventPart.part | dayOfWeek) - 1) + '))'\">\n <div class=\"event-inner\"\n [style.width]=\"'calc(100% / ' + partData.total + ')'\"\n [style.height.px]=\"(eventPart.part | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.margin-left]=\"'calc(100% / ' + partData.total + ' * ' + eventPart.index + ')'\"\n (mousedown)=\"onStartDragEvent(eventPart.part, $event)\">\n <div class=\"event-border\"></div>\n <ng-container *ngIf=\"eventPart.part.event\">\n <div class=\"event-bg\" [style.background-color]=\"eventPart.part.event.color\"></div>\n <div class=\"event-label\">{{ eventPart.part.event.description }}</div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"(previewEventPartsForThisWeek$ | async) as previewPartData\">\n <div *ngFor=\"let eventPart of previewPartData\" class=\"event preview p-0\"\n [style.top.px]=\"(eventPart | bsSecondsTodayOffset) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.height.px]=\"(eventPart | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.left]=\"'calc(90px + ((100% - 90px) / 7 * ' + ((eventPart | dayOfWeek) - 1) + '))'\">\n <div class=\"event-inner w-100\" [style.height.px]=\"(eventPart | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"></div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n</div>", styles: [":host{display:block}.table{flex-flow:column}.table .calendar-head{flex:0 0 auto}.table .calendar-head>div{padding-right:18px}.table .calendar-body{flex:1 1 auto;display:block;overflow-y:visible;overflow-x:hidden}.table .calendar-body .calendar-cell{border-right:1px solid #DEE2E6;border-bottom:1px solid #DEE2E6;cursor:default}.table .calendar-body .calendar-cell.hover{border-top-width:3px}.table .calendar-left{width:90px}.event{z-index:5;width:calc((100% - 90px) / 7);height:100px;overflow:hidden;position:absolute;-webkit-user-select:none;user-select:none;pointer-events:none}.event.preview{background:#666;opacity:.6}.event .event-border{background:black;top:0;left:0;bottom:3px;width:3px;position:absolute;z-index:10;opacity:.3}.event .event-inner{position:relative;left:0px;right:5px;top:0px;bottom:5px;cursor:move;pointer-events:all}.event .event-inner .event-bg{opacity:.5;width:calc(100% - 2px);margin:1px auto 1px 0;height:calc(100% - 3px);transition:opacity .15s ease-in-out}.event .event-inner .event-label{position:absolute;top:0;font-size:12px;font-weight:600;padding:4px}.event .event-inner:hover .event-bg{opacity:.7}\n"], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i3.AsyncPipe, "date": i3.DatePipe, "bsSecondsTodayOffset": i4.BsSecondsTodayOffsetPipe, "bsSecondsTimespan": i5.BsSecondsTimespanPipe, "dayOfWeek": i6.DayOfWeekPipe } });
329
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSchedulerComponent, decorators: [{
330
+ type: Component,
331
+ args: [{ selector: 'bs-scheduler', template: "<div class=\"table d-flex w-100 overflow-y-auto\" [style.max-height.px]=\"null\">\n <div class=\"calendar-head\">\n <div class=\"w-100 d-flex flex-row\">\n <div class=\"d-flex calendar-left justify-content-between\">\n <button class=\"btn btn-default flex-start\" (click)=\"onPreviousWeek()\">&lt;</button>\n <button class=\"btn btn-default flex-end\" (click)=\"onNextWeek()\">&gt;</button>\n </div>\n <div class=\"flex-grow-1\" *ngFor=\"let day of (daysOfWeek$ | async)\">\n <span class=\"d-block col-form-label text-center\">\n {{ day | date: 'dd-MM-yyyy' }}\n </span>\n </div>\n </div>\n </div>\n <div class=\"calendar-body\">\n <div class=\"position-relative\">\n <!-- Timeslots -->\n <div *ngFor=\"let timeslots of (timeSlots$ | async); let i = index\" class=\"d-flex flex-row p-0 timeslot\" [style.height.px]=\"unitHeight$ | async\">\n <div class=\"calendar-cell calendar-left align-top py-0\">{{ timeslots[0].start | date: 'HH:mm:ss' }}</div>\n <div class=\"calendar-cell flex-grow-1\" *ngFor=\"let slot of timeslots; let j = index\" #slot (mousedown)=\"onCreateEvent($event, slot)\" [attr.data-row]=\"i\" [attr.data-column]=\"j\"></div>\n </div>\n \n <!-- Events -->\n <ng-container *ngIf=\"(timeSlotDuration$ | async) as timeSlotDuration\">\n <ng-container *ngIf=\"(timelinedEventPartsForThisWeek$ | async) as partData\">\n <div *ngFor=\"let eventPart of partData.parts\" class=\"event p-0\"\n [style.top.px]=\"(eventPart.part | bsSecondsTodayOffset) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.height.px]=\"(eventPart.part | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.left]=\"'calc(90px + ((100% - 90px) / 7 * ' + ((eventPart.part | dayOfWeek) - 1) + '))'\">\n <div class=\"event-inner\"\n [style.width]=\"'calc(100% / ' + partData.total + ')'\"\n [style.height.px]=\"(eventPart.part | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.margin-left]=\"'calc(100% / ' + partData.total + ' * ' + eventPart.index + ')'\"\n (mousedown)=\"onStartDragEvent(eventPart.part, $event)\">\n <div class=\"event-border\"></div>\n <ng-container *ngIf=\"eventPart.part.event\">\n <div class=\"event-bg\" [style.background-color]=\"eventPart.part.event.color\"></div>\n <div class=\"event-label\">{{ eventPart.part.event.description }}</div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"(previewEventPartsForThisWeek$ | async) as previewPartData\">\n <div *ngFor=\"let eventPart of previewPartData\" class=\"event preview p-0\"\n [style.top.px]=\"(eventPart | bsSecondsTodayOffset) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.height.px]=\"(eventPart | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n [style.left]=\"'calc(90px + ((100% - 90px) / 7 * ' + ((eventPart | dayOfWeek) - 1) + '))'\">\n <div class=\"event-inner w-100\" [style.height.px]=\"(eventPart | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"></div>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n</div>", styles: [":host{display:block}.table{flex-flow:column}.table .calendar-head{flex:0 0 auto}.table .calendar-head>div{padding-right:18px}.table .calendar-body{flex:1 1 auto;display:block;overflow-y:visible;overflow-x:hidden}.table .calendar-body .calendar-cell{border-right:1px solid #DEE2E6;border-bottom:1px solid #DEE2E6;cursor:default}.table .calendar-body .calendar-cell.hover{border-top-width:3px}.table .calendar-left{width:90px}.event{z-index:5;width:calc((100% - 90px) / 7);height:100px;overflow:hidden;position:absolute;-webkit-user-select:none;user-select:none;pointer-events:none}.event.preview{background:#666;opacity:.6}.event .event-border{background:black;top:0;left:0;bottom:3px;width:3px;position:absolute;z-index:10;opacity:.3}.event .event-inner{position:relative;left:0px;right:5px;top:0px;bottom:5px;cursor:move;pointer-events:all}.event .event-inner .event-bg{opacity:.5;width:calc(100% - 2px);margin:1px auto 1px 0;height:calc(100% - 3px);transition:opacity .15s ease-in-out}.event .event-inner .event-label{position:absolute;top:0;font-size:12px;font-weight:600;padding:4px}.event .event-inner:hover .event-bg{opacity:.7}\n"] }]
332
+ }], ctorParameters: function () { return [{ type: i1.BsCalendarMonthService }, { type: i2.BsTimelineService }]; }, propDecorators: { timeSlotElements: [{
333
+ type: ViewChildren,
334
+ args: ['slot']
335
+ }], unitHeightChange: [{
336
+ type: Output
337
+ }], unitHeight: [{
338
+ type: Input
339
+ }], onMousemove: [{
340
+ type: HostListener,
341
+ args: ['document:mousemove', ['$event']]
342
+ }], onMouseUp: [{
343
+ type: HostListener,
344
+ args: ['document:mouseup', ['$event']]
345
+ }] } });
346
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scheduler.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/scheduler/components/scheduler/scheduler.component.ts","../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/scheduler/components/scheduler/scheduler.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AACrI,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,EAAc,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACzG,OAAO,EAAE,sBAAsB,EAAE,MAAM,4DAA4D,CAAC;AACpG,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAC;AAO5D,OAAO,EAAE,iBAAiB,EAAE,MAAM,0CAA0C,CAAC;;;;;;;;AAO7E,MAAM,OAAO,oBAAoB;IAC/B,YAAoB,oBAA4C,EAAU,eAAkC;QAAxF,yBAAoB,GAApB,oBAAoB,CAAwB;QAAU,oBAAe,GAAf,eAAe,CAAmB;QAwH5G,YAAO,GAAG,IAAI,eAAe,CAAmB,EAAE,CAAC,CAAC;QAKpD,kBAAa,GAAG,IAAI,eAAe,CAAsB,IAAI,CAAC,CAAC;QAO/D,sBAAiB,GAAG,IAAI,eAAe,CAAS,IAAI,CAAC,CAAC;QAEtD,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAClD,qBAAgB,GAAG,IAAI,eAAe,CAAkB,IAAI,CAAC,CAAC;QAC9D,eAAU,GAAG,IAAI,OAAO,EAAE,CAAC;QAI3B,oBAAoB;QACpB,gBAAW,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAC7B,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QA2B/D,cAAS,GAAyB,IAAI,CAAC;QACvC,sBAAiB,GAAoB,IAAI,CAAC;QAzKxC,MAAM,MAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QACrE,IAAI,CAAC,YAAY,GAAG,IAAI,eAAe,CAAO,MAAM,CAAC,CAAC;QAEtD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACvC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;YACjB,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YACvB,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACzB,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACzB,UAAU,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;YAC9B,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;QAC7E,CAAC,CAAC,CACH,CAAC;QAEF,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,WAAW;aAC9C,IAAI,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE;YACvB,OAAO,EAAE,KAAK,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,GAAG,EAAE,UAAU,CAAC,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,EAAE,CAAC;QACpH,CAAC,CAAC,CAAC,CAAC;QAEN,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAClC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAE,MAAM,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAC5E,CAAC;QAEF,IAAI,CAAC,sBAAsB,GAAG,aAAa,CAAC;YAC1C,IAAI,CAAC,yBAAyB;YAC9B,IAAI,CAAC,WAAW;iBACb,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;iBACzD,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;gBACtB,OAAO,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,CAAC;YAC7E,CAAC,CAAC,CAAC;SACJ,CAAC;aACD,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,UAAU,CAAC,EAAE,EAAE;YACtC,OAAO,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE;gBACnC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;YAC7G,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC,CAAC;QAEN,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAC/C,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;YACZ,IAAI,KAAK,EAAE;gBACT,OAAO,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;aAChD;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;QACH,CAAC,CAAC,CACH,CAAC;QACF,IAAI,CAAC,6BAA6B,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;aAC1G,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,iBAAiB,CAAC,EAAE,EAAE;YAC7C,IAAI,iBAAiB,EAAE;gBACrB,OAAO,iBAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE;oBAChD,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC7G,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,OAAO,EAAE,CAAC;aACX;QACH,CAAC,CAAC,CAAC,CAAC;QAEN,IAAI,CAAC,+BAA+B,GAAG,IAAI,CAAC,sBAAsB;aAC/D,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE;YACrB,0CAA0C;YAC1C,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC;iBAC1C,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;iBAC7C,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;iBAClB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAiB,CAAC,CAAC,CAAC;YACjC,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YAE1D,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;gBAClC,OAAO,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;oBAC3B,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC;gBAC3C,CAAC,CAAC,CAAC;YACL,CAAC,CAAC;iBACD,MAAM,CAAC,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC;iBACvD,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBAChE,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,CAAC;YACvC,CAAC,CAAC,CACH;iBACA,MAAM,CAAC,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,CAAC;YAEzD,OAAO;gBACL,KAAK,EAAE,QAAQ,CAAC,MAAM;gBACtB,KAAK,EAAE,MAAM;aACd,CAAC;QACJ,CAAC,CAAC,CAAC,CAAA;QAEL,IAAI,CAAC,UAAU,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;aACxE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,QAAQ,CAAC,EAAE,EAAE;YACnC,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,QAAQ,CAAC,CAAC;YAE9D,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC7D,MAAM,aAAa,GAAG,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC9C,aAAa,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,EAAE,GAAG,KAAK,GAAG,QAAQ,CAAC,CAAC;gBACxE,MAAM,WAAW,GAAG,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC;gBAC5C,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,EAAE,GAAG,QAAQ,CAAC,CAAC;gBAE5D,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;oBAC5B,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC;oBAC5B,KAAK,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC,CAAC;oBACzC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC,CAAC;oBAC7C,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,EAAE,CAAC,CAAC;oBAC7C,KAAK,CAAC,eAAe,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC,CAAC;oBAEvD,MAAM,GAAG,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC;oBAC1B,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC,CAAC;oBACrC,GAAG,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC,CAAC;oBACzC,GAAG,CAAC,UAAU,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC,CAAC;oBACzC,GAAG,CAAC,eAAe,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC,CAAC;oBAEnD,OAAiB,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;gBAClC,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QAEL,CAAC,CAAC,CAAC,CAAC;QAEN,IAAI,CAAC,WAAW;aACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aAChC,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE;YACxB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACzC,CAAC,CAAC,CAAA;IACN,CAAC;IAyBD,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;IAChC,CAAC;IACD,IAAoB,UAAU,CAAC,KAAa;QAC1C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IACD,YAAY;IAEJ,OAAO,CAAC,IAAU,EAAE,IAAY;QACtC,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC;QAC9B,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,CAAC;QACxC,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,YAAY;aACd,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;aAC9C,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,UAAU;QACR,IAAI,CAAC,YAAY;aACd,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;aAC7C,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;IACjD,CAAC;IAID,aAAa,CAAC,EAAc,EAAE,IAAc;QAC1C,EAAE,CAAC,cAAc,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,SAAS,GAAG;YACf,SAAS,EAAE,cAAc,CAAC,WAAW;YACrC,KAAK,EAAE;gBACL,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,GAAG,EAAE,IAAI,CAAC,GAAG;gBACb,KAAK,EAAE,SAAS;gBAChB,WAAW,EAAE,YAAY;aAC1B;SACF,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;QAE9D,oEAAoE;IACtE,CAAC;IAED,gBAAgB,CAAC,SAA6B,EAAE,EAAc;QAC5D,EAAE,CAAC,cAAc,EAAE,CAAC;QACpB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,eAAe,EAAE,EAAE;YAChE,IAAI,SAAS,CAAC,KAAK,EAAE;gBACnB,IAAI,CAAC,iBAAiB,GAAG,eAAe,CAAC;gBACzC,IAAI,CAAC,SAAS,GAAG;oBACf,SAAS,EAAE,cAAc,CAAC,SAAS;oBACnC,KAAK,EAAE,SAAS,CAAC,KAAK;iBACvB,CAAC;gBACF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,SAAS,CAAC,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;aACrF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,0BAA0B;IAClB,kBAAkB,CAAC,EAAc,EAAE,SAAuB;QAChE,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE;YACvD,MAAM,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YACrD,IAAI,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,GAAG,CAAC,KAAK,IAAI,GAAG,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,GAAG,CAAC,MAAM,EAAE;gBAClF,OAAO,IAAI,CAAC;aACb;iBAAM;gBACL,OAAO,KAAK,CAAC;aACd;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC9C,OAAO,IAAI,CAAC;SACb;QAED,MAAM,WAAW,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;QAElD,MAAM,MAAM,GAAG,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QACpD,IAAI,CAAC,MAAM,EAAE;YACX,OAAO,IAAI,CAAC;SACb;QACD,MAAM,GAAG,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;QAE7B,MAAM,SAAS,GAAG,WAAW,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAC1D,IAAI,CAAC,SAAS,EAAE;YACd,OAAO,IAAI,CAAC;SACb;QACD,MAAM,MAAM,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEnC,MAAM,IAAI,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;QACpC,OAAO,IAAI,CAAC;IACd,CAAC;IAGD,WAAW,CAAC,EAAc;QACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;YACpD,MAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,SAAS,CAAC,CAAC;YACvD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAEpC,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,QAAQ,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE;oBAChC,KAAK,cAAc,CAAC,WAAW;wBAAE;4BAC/B,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,IAAI,CAAC,iBAAiB,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,EAAE;gCAC9H,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE;oCACtE,SAAS;iCACV;qCAAM,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE;oCAC3E,YAAY;oCACZ,6DAA6D;oCAC7D,0CAA0C;oCAC1C,yCAAyC;oCACzC,IAAI,CAAC,aAAa;yCACf,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;yCACtD,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE;wCACf,IAAI,EAAE,IAAI,IAAI,CAAC,iBAAiB,EAAE;4CAChC,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;4CACxC,EAAE,CAAC,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;yCACtB;wCACD,OAAO,EAAE,CAAC;oCACZ,CAAC,CAAC,CAAC;yCACF,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;yCACb,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;iCACnD;qCAAM,IAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE;oCAC3E,UAAU;oCACV,8CAA8C;oCAC9C,yDAAyD;oCACzD,yCAAyC;oCACzC,IAAI,CAAC,aAAa;yCACf,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;yCACtD,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE;wCACf,IAAI,EAAE,IAAI,IAAI,CAAC,iBAAiB,EAAE;4CAChC,EAAE,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;4CACzB,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC;yCACrC;wCACD,OAAO,EAAE,CAAC;oCACZ,CAAC,CAAC,CAAC;yCACF,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;yCACb,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;iCACnD;6BACF;yBACF;wBAAC,MAAM;oBACR,KAAK,cAAc,CAAC,SAAS;wBAAE;4BAC7B,IAAI,OAAO,IAAI,IAAI,CAAC,iBAAiB,EAAE;gCACrC,+IAA+I;gCAC/I,2IAA2I;gCAC3I,oCAAoC;gCACpC,4CAA4C;gCAE5C,IAAI,CAAC,aAAa;qCACf,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;qCACtD,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE;oCACf,IAAI,EAAE,IAAI,IAAI,CAAC,iBAAiB,EAAE;wCAChC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;wCACxG,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;wCACpG,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC;qCAClC;oCACD,OAAO,EAAE,CAAC;gCACZ,CAAC,CAAC,CAAC;qCACF,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;qCACb,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;6BACnD;yBACF;wBAAC,MAAM;iBACT;aACF;QAEH,CAAC,CAAC,CAAC;IACL,CAAC;IACD,YAAY;IAGZ,SAAS,CAAC,EAAc;QACtB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,QAAQ,IAAI,CAAC,SAAS,CAAC,SAAS,EAAE;gBAChC,KAAK,cAAc,CAAC,WAAW;oBAAE;wBAC/B,aAAa,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;6BAChC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;6BACb,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC,EAAE,EAAE;4BAC5B,IAAI,YAAY,EAAE;gCAChB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;gCACtB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gCAC9B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;wCACxC,KAAK,EAAE,YAAY,CAAC,KAAK;wCACzB,GAAG,EAAE,YAAY,CAAC,GAAG;wCACrB,KAAK,EAAE,MAAM;wCACb,WAAW,EAAE,WAAW;qCACzB,CAAC,CAAC,CAAC;gCACJ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;6BAC/B;wBACH,CAAC,CAAC,CAAC;qBACN;oBAAC,MAAM;gBACR,KAAK,cAAc,CAAC,SAAS;oBAAE;wBAC7B,IAAI,CAAC,aAAa;6BACf,IAAI,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;6BAC1B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;6BACb,SAAS,CAAC,CAAC,YAAY,EAAE,EAAE;4BAC1B,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,YAAY,EAAE;gCAC1D,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC;gCAChD,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,GAAG,YAAY,CAAC,GAAG,CAAC;gCAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;gCACtB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;gCAC9B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gCACtC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;6BAC/B;wBACH,CAAC,CAAC,CAAC;qBACN;oBAAC,MAAM;aACT;SACF;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;;iHAlWU,oBAAoB;qGAApB,oBAAoB,yVCjBjC,uzHAqDM;2FDpCO,oBAAoB;kBALhC,SAAS;+BACE,cAAc;6IA+IF,gBAAgB;sBAArC,YAAY;uBAAC,MAAM;gBAIH,gBAAgB;sBAAhC,MAAM;gBAIa,UAAU;sBAA7B,KAAK;gBA2FN,WAAW;sBADV,YAAY;uBAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC;gBA4E9C,SAAS;sBADR,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, Output, QueryList, ViewChildren } from '@angular/core';\nimport { BehaviorSubject, combineLatest, filter, map, Observable, Subject, take, takeUntil } from 'rxjs';\nimport { BsCalendarMonthService } from '../../../../services/calendar-month/calendar-month.service';\nimport { EDragOperation } from '../../enums/drag-operation';\nimport { DragOperation } from '../../interfaces/drag-operation';\nimport { PreviewEvent } from '../../interfaces/preview-event';\nimport { SchedulerEvent } from '../../interfaces/scheduler-event';\nimport { SchedulerEventPart } from '../../interfaces/scheduler-event-part';\nimport { SchedulerEventWithParts } from '../../interfaces/scheduler-event-with-parts';\nimport { TimeSlot } from '../../interfaces/time-slot';\nimport { BsTimelineService } from '../../services/timeline/timeline.service';\n\n@Component({\n  selector: 'bs-scheduler',\n  templateUrl: './scheduler.component.html',\n  styleUrls: ['./scheduler.component.scss'],\n})\nexport class BsSchedulerComponent implements OnDestroy {\n  constructor(private calendarMonthService: BsCalendarMonthService, private timelineService: BsTimelineService) {\n    const monday = this.calendarMonthService.getMondayBefore(new Date());\n    this.currentWeek$ = new BehaviorSubject<Date>(monday);\n\n    this.daysOfWeek$ = this.currentWeek$.pipe(\n      map((weekMonday) => {\n        weekMonday.setHours(0);\n        weekMonday.setMinutes(0);\n        weekMonday.setSeconds(0);\n        weekMonday.setMilliseconds(0);\n        return Array.from(Array(7).keys()).map((x) => this.addDays(weekMonday, x));\n      })\n    );\n\n    this.daysOfWeekWithTimestamps$ = this.daysOfWeek$\n      .pipe(map((daysOfWeek) => {\n        return { start: daysOfWeek[0].getTime(), end: daysOfWeek[daysOfWeek.length - 1].getTime() + 24 * 60 * 60 * 1000 };\n      }));\n\n    this.eventParts$ = this.events$.pipe(\n      map((events) =>  events.map((ev) => this.timelineService.splitInParts(ev)))\n    );\n\n    this.eventPartsForThisWeek$ = combineLatest([\n      this.daysOfWeekWithTimestamps$,\n      this.eventParts$\n        .pipe(map(eventParts => eventParts.map(evp => evp.parts)))\n        .pipe(map(jaggedParts => {\n          return jaggedParts.reduce((flat, toFlatten) => flat.concat(toFlatten), []);\n        }))\n      ])\n      .pipe(map(([startAndEnd, eventParts]) => {\n        return eventParts.filter(eventPart => {\n          return !((eventPart.end.getTime() <= startAndEnd.start) || (eventPart.start.getTime() >= startAndEnd.end));\n        });\n      }));\n\n    this.previewEventParts$ = this.previewEvent$.pipe(\n      map((event) => {\n        if (event) {\n          return this.timelineService.splitInParts(event)\n        } else {\n          return null;\n        }\n      })\n    );\n    this.previewEventPartsForThisWeek$ = combineLatest([this.daysOfWeekWithTimestamps$, this.previewEventParts$])\n      .pipe(map(([startAndEnd, previewEventParts]) => {\n        if (previewEventParts) {\n          return previewEventParts.parts.filter(eventPart => {\n            return !((eventPart.end.getTime() <= startAndEnd.start) || (eventPart.start.getTime() >= startAndEnd.end));\n          });\n        } else {\n          return [];\n        }\n      }));\n\n    this.timelinedEventPartsForThisWeek$ = this.eventPartsForThisWeek$\n      .pipe(map(eventParts => {\n        // We'll only use the events for this week\n        const events = eventParts.map(ep => ep.event)\n          .filter((e, i, list) => list.indexOf(e) === i)\n          .filter((e) => !!e)\n          .map((e) => <SchedulerEvent>e);\n        const timeline = this.timelineService.getTimeline(events);\n\n        const result = timeline.map(track => {\n          return track.events.map(ev => {\n            return { event: ev, index: track.index };\n          });\n        })\n        .reduce((flat, toFlatten) => flat.concat(toFlatten), [])\n        .map((evi) => eventParts.filter(p => p.event === evi.event).map(p => {\n            return { part: p, index: evi.index };\n          })\n        )\n        .reduce((flat, toFlatten) => flat.concat(toFlatten), []);\n\n        return {\n          total: timeline.length,\n          parts: result\n        };\n      }))\n\n    this.timeSlots$ = combineLatest([this.daysOfWeek$, this.timeSlotDuration$])\n      .pipe(map(([daysOfWeek, duration]) => {\n        const timeSlotsPerDay = Math.floor((60 * 60 * 24) / duration);\n\n        return Array.from(Array(timeSlotsPerDay).keys()).map((index) => {\n          const timeSlotStart = new Date(daysOfWeek[0]);\n          timeSlotStart.setSeconds(timeSlotStart.getSeconds() + index * duration);\n          const timeSlotEnd = new Date(timeSlotStart);\n          timeSlotEnd.setSeconds(timeSlotEnd.getSeconds() + duration);\n\n          return daysOfWeek.map((day) => {\n            const start = new Date(day);\n            start.setHours(timeSlotStart.getHours());\n            start.setMinutes(timeSlotStart.getMinutes());\n            start.setSeconds(timeSlotStart.getSeconds());\n            start.setMilliseconds(timeSlotStart.getMilliseconds());\n\n            const end = new Date(day);\n            end.setHours(timeSlotEnd.getHours());\n            end.setMinutes(timeSlotEnd.getMinutes());\n            end.setSeconds(timeSlotEnd.getSeconds());\n            end.setMilliseconds(timeSlotEnd.getMilliseconds());\n\n            return <TimeSlot>{ start, end };\n          });\n        });\n\n      }));\n    \n    this.unitHeight$\n      .pipe(takeUntil(this.destroyed$))\n      .subscribe((unitHeight) => {\n        this.unitHeightChange.emit(unitHeight);\n      })\n  }\n\n  events$ = new BehaviorSubject<SchedulerEvent[]>([]);\n  eventParts$: Observable<SchedulerEventWithParts[]>;\n  eventPartsForThisWeek$: Observable<SchedulerEventPart[]>;\n  timelinedEventPartsForThisWeek$: Observable<{ total: number, parts: { part: SchedulerEventPart, index: number}[] }>;\n  \n  previewEvent$ = new BehaviorSubject<PreviewEvent | null>(null);\n  previewEventParts$: Observable<SchedulerEventWithParts | null>;\n  previewEventPartsForThisWeek$: Observable<SchedulerEventPart[]>;\n  \n  currentWeek$: BehaviorSubject<Date>;\n  daysOfWeek$: Observable<Date[]>;\n  daysOfWeekWithTimestamps$: Observable<{start: number, end: number}>;\n  timeSlotDuration$ = new BehaviorSubject<number>(1800);\n  timeSlots$: Observable<TimeSlot[][]>;\n  mouseState$ = new BehaviorSubject<boolean>(false);\n  hoveredTimeSlot$ = new BehaviorSubject<TimeSlot | null>(null);\n  destroyed$ = new Subject();\n\n  @ViewChildren('slot') timeSlotElements!: QueryList<ElementRef<HTMLDivElement>>;\n\n  //#region UnitHeight\n  unitHeight$ = new BehaviorSubject<number>(40);\n  @Output() public unitHeightChange = new EventEmitter<number>();\n  public get unitHeight() {\n    return this.unitHeight$.value;\n  }\n  @Input() public set unitHeight(value: number) {\n    this.unitHeight$.next(value);\n  }\n  //#endregion\n\n  private addDays(date: Date, days: number) {\n    const result = new Date(date);\n    result.setDate(result.getDate() + days);\n    return result;\n  }\n\n  onPreviousWeek() {\n    this.currentWeek$\n      .pipe(map((w) => this.addDays(w, -7)), take(1))\n      .subscribe((w) => this.currentWeek$.next(w));\n  }\n\n  onNextWeek() {\n    this.currentWeek$\n      .pipe(map((w) => this.addDays(w, 7)), take(1))\n      .subscribe((w) => this.currentWeek$.next(w));\n  }\n\n  operation: DragOperation | null = null;\n  dragStartTimeslot: TimeSlot | null = null;\n  onCreateEvent(ev: MouseEvent, slot: TimeSlot) {\n    ev.preventDefault();\n    this.mouseState$.next(true);\n    this.dragStartTimeslot = slot;\n    this.operation = {\n      operation: EDragOperation.createEvent,\n      event: {\n        start: slot.start,\n        end: slot.end,\n        color: '#5AC8FA',\n        description: 'Test event',\n      }\n    };\n    this.previewEvent$.next({ start: slot.start, end: slot.end });\n\n    // this.events$.next([...this.events$.value, this.operation.event]);\n  }\n\n  onStartDragEvent(eventPart: SchedulerEventPart, ev: MouseEvent) {\n    ev.preventDefault();\n    this.hoveredTimeSlot$.pipe(take(1)).subscribe((hoveredTimeSlot) => {\n      if (eventPart.event) {\n        this.dragStartTimeslot = hoveredTimeSlot;\n        this.operation = {\n          operation: EDragOperation.moveEvent,\n          event: eventPart.event,\n        };\n        this.previewEvent$.next({ start: eventPart.event.start, end: eventPart.event.end });\n      }\n    });\n  }\n\n  //#region hoveredTimeslot$\n  private getHoveredTimeslot(ev: MouseEvent, timeSlots: TimeSlot[][]) {\n    const hoveredSlots = this.timeSlotElements.filter((el) => {\n      const rct = el.nativeElement.getBoundingClientRect();\n      if (rct.left <= ev.x && ev.x <= rct.right && rct.top <= ev.y && ev.y <= rct.bottom) {\n        return true;\n      } else {\n        return false;\n      }\n    });\n\n    if (!hoveredSlots || hoveredSlots.length === 0) {\n      return null;\n    }\n\n    const slotElement = hoveredSlots[0].nativeElement;\n\n    const strRow = slotElement.getAttribute('data-row');\n    if (!strRow) {\n      return null;\n    }\n    const row = parseInt(strRow);\n\n    const strColumn = slotElement.getAttribute('data-column');\n    if (!strColumn) {\n      return null;\n    }\n    const column = parseInt(strColumn);\n\n    const slot = timeSlots[row][column];\n    return slot;\n  }\n\n  @HostListener('document:mousemove', ['$event'])\n  onMousemove(ev: MouseEvent) {\n    this.timeSlots$.pipe(take(1)).subscribe((timeSlots) => {\n      const hovered = this.getHoveredTimeslot(ev, timeSlots);\n      this.hoveredTimeSlot$.next(hovered);\n\n      if (this.operation) {\n        switch (this.operation.operation) {\n          case EDragOperation.createEvent: {\n            if (this.operation.event && this.dragStartTimeslot && hovered && (this.operation.event.end.getTime() != hovered.end.getTime())) {\n              if (this.dragStartTimeslot.start.getTime() === hovered.start.getTime()) {\n                // 1 slot\n              } else if (this.dragStartTimeslot.start.getTime() < hovered.start.getTime()) {\n                // Drag down\n                // this.operation.event.start = this.dragStartTimeslot.start;\n                // this.operation.event.end = hovered.end;\n                // this.events$.next(this.events$.value);\n                this.previewEvent$\n                  .pipe(filter((ev) => !!ev && !!this.dragStartTimeslot))\n                  .pipe(map((ev) => {\n                    if (ev && this.dragStartTimeslot) {\n                      ev.start = this.dragStartTimeslot.start;\n                      ev.end = hovered.end;\n                    }\n                    return ev;\n                  }))\n                  .pipe(take(1))\n                  .subscribe((ev) => this.previewEvent$.next(ev));\n              } else if (this.dragStartTimeslot.start.getTime() > hovered.start.getTime()) {\n                // Drag up\n                // this.operation.event.start = hovered.start;\n                // this.operation.event.end = this.dragStartTimeslot.end;\n                // this.events$.next(this.events$.value);\n                this.previewEvent$\n                  .pipe(filter((ev) => !!ev && !!this.dragStartTimeslot))\n                  .pipe(map((ev) => {\n                    if (ev && this.dragStartTimeslot) {\n                      ev.start = hovered.start;\n                      ev.end = this.dragStartTimeslot.end;\n                    }\n                    return ev;\n                  }))\n                  .pipe(take(1))\n                  .subscribe((ev) => this.previewEvent$.next(ev));\n              }\n            }\n          } break;\n          case EDragOperation.moveEvent: {\n            if (hovered && this.dragStartTimeslot) {\n              // this.operation.event.start.setTime(this.operation.event.start.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());\n              // this.operation.event.end.setTime(this.operation.event.end.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());\n              // this.dragStartTimeslot = hovered;\n              // // this.events$.next(this.events$.value);\n\n              this.previewEvent$\n                .pipe(filter((ev) => !!ev && !!this.dragStartTimeslot))\n                .pipe(map((ev) => {\n                  if (ev && this.dragStartTimeslot) {\n                    ev.start.setTime(ev.start.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());\n                    ev.end.setTime(ev.end.getTime() + hovered.start.getTime() - this.dragStartTimeslot.start.getTime());\n                    this.dragStartTimeslot = hovered;\n                  }\n                  return ev;\n                }))\n                .pipe(take(1))\n                .subscribe((ev) => this.previewEvent$.next(ev));\n            }\n          } break;\n        }\n      }\n\n    });\n  }\n  //#endregion\n\n  @HostListener('document:mouseup', ['$event'])\n  onMouseUp(ev: MouseEvent) {\n    if (this.operation) {\n      switch (this.operation.operation) {\n        case EDragOperation.createEvent: {\n          combineLatest([this.previewEvent$])\n            .pipe(take(1))\n            .subscribe(([previewEvent]) => {\n              if (previewEvent) {\n                this.operation = null;\n                this.dragStartTimeslot = null;\n                this.events$.next([...this.events$.value, {\n                  start: previewEvent.start,\n                  end: previewEvent.end,\n                  color: '#F00',\n                  description: 'New event'\n                }]);\n                this.previewEvent$.next(null);\n              }\n            });\n        } break;\n        case EDragOperation.moveEvent: {\n          this.previewEvent$\n            .pipe(filter((ev) => !!ev))\n            .pipe(take(1))\n            .subscribe((previewEvent) => {\n              if (this.operation && this.operation.event && previewEvent) {\n                this.operation.event.start = previewEvent.start;\n                this.operation.event.end = previewEvent.end;\n                this.operation = null;\n                this.dragStartTimeslot = null;\n                this.events$.next(this.events$.value);\n                this.previewEvent$.next(null);\n              }\n            });\n        } break;\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n}\n","<div class=\"table d-flex w-100 overflow-y-auto\" [style.max-height.px]=\"null\">\n    <div class=\"calendar-head\">\n        <div class=\"w-100 d-flex flex-row\">\n            <div class=\"d-flex calendar-left justify-content-between\">\n                <button class=\"btn btn-default flex-start\" (click)=\"onPreviousWeek()\">&lt;</button>\n                <button class=\"btn btn-default flex-end\" (click)=\"onNextWeek()\">&gt;</button>\n            </div>\n            <div class=\"flex-grow-1\" *ngFor=\"let day of (daysOfWeek$ | async)\">\n                <span class=\"d-block col-form-label text-center\">\n                    {{ day | date: 'dd-MM-yyyy' }}\n                </span>\n            </div>\n        </div>\n    </div>\n    <div class=\"calendar-body\">\n        <div class=\"position-relative\">\n            <!-- Timeslots -->\n            <div *ngFor=\"let timeslots of (timeSlots$ | async); let i = index\" class=\"d-flex flex-row p-0 timeslot\" [style.height.px]=\"unitHeight$ | async\">\n                <div class=\"calendar-cell calendar-left align-top py-0\">{{ timeslots[0].start | date: 'HH:mm:ss' }}</div>\n                <div class=\"calendar-cell flex-grow-1\" *ngFor=\"let slot of timeslots; let j = index\" #slot (mousedown)=\"onCreateEvent($event, slot)\" [attr.data-row]=\"i\" [attr.data-column]=\"j\"></div>\n            </div>\n            \n            <!-- Events -->\n            <ng-container *ngIf=\"(timeSlotDuration$ | async) as timeSlotDuration\">\n                <ng-container *ngIf=\"(timelinedEventPartsForThisWeek$ | async) as partData\">\n                    <div *ngFor=\"let eventPart of partData.parts\" class=\"event p-0\"\n                        [style.top.px]=\"(eventPart.part | bsSecondsTodayOffset) / timeSlotDuration * (unitHeight$ | async)!\"\n                        [style.height.px]=\"(eventPart.part | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n                        [style.left]=\"'calc(90px + ((100% - 90px) / 7 * ' + ((eventPart.part | dayOfWeek) - 1) + '))'\">\n                        <div class=\"event-inner\"\n                             [style.width]=\"'calc(100% / ' + partData.total + ')'\"\n                             [style.height.px]=\"(eventPart.part | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n                             [style.margin-left]=\"'calc(100% / ' + partData.total + ' * ' + eventPart.index + ')'\"\n                             (mousedown)=\"onStartDragEvent(eventPart.part, $event)\">\n                            <div class=\"event-border\"></div>\n                            <ng-container *ngIf=\"eventPart.part.event\">\n                                <div class=\"event-bg\" [style.background-color]=\"eventPart.part.event.color\"></div>\n                                <div class=\"event-label\">{{ eventPart.part.event.description }}</div>\n                            </ng-container>\n                        </div>\n                    </div>\n                </ng-container>\n                <ng-container *ngIf=\"(previewEventPartsForThisWeek$ | async) as previewPartData\">\n                    <div *ngFor=\"let eventPart of previewPartData\" class=\"event preview p-0\"\n                        [style.top.px]=\"(eventPart | bsSecondsTodayOffset) / timeSlotDuration * (unitHeight$ | async)!\"\n                        [style.height.px]=\"(eventPart | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"\n                        [style.left]=\"'calc(90px + ((100% - 90px) / 7 * ' + ((eventPart | dayOfWeek) - 1) + '))'\">\n                        <div class=\"event-inner w-100\" [style.height.px]=\"(eventPart | bsSecondsTimespan) / timeSlotDuration * (unitHeight$ | async)!\"></div>\n                    </div>\n                </ng-container>\n            </ng-container>\n        </div>\n    </div>\n</div>"]}
@@ -0,0 +1,8 @@
1
+ export var EDragOperation;
2
+ (function (EDragOperation) {
3
+ EDragOperation[EDragOperation["none"] = 0] = "none";
4
+ EDragOperation[EDragOperation["createEvent"] = 1] = "createEvent";
5
+ EDragOperation[EDragOperation["resizeEvent"] = 2] = "resizeEvent";
6
+ EDragOperation[EDragOperation["moveEvent"] = 3] = "moveEvent";
7
+ })(EDragOperation || (EDragOperation = {}));
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1vcGVyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvZW51bXMvZHJhZy1vcGVyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksY0FLWDtBQUxELFdBQVksY0FBYztJQUN0QixtREFBSSxDQUFBO0lBQ0osaUVBQVcsQ0FBQTtJQUNYLGlFQUFXLENBQUE7SUFDWCw2REFBUyxDQUFBO0FBQ2IsQ0FBQyxFQUxXLGNBQWMsS0FBZCxjQUFjLFFBS3pCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gRURyYWdPcGVyYXRpb24ge1xuICAgIG5vbmUsXG4gICAgY3JlYXRlRXZlbnQsXG4gICAgcmVzaXplRXZlbnQsXG4gICAgbW92ZUV2ZW50LFxufSJdfQ==
@@ -0,0 +1,3 @@
1
+ export * from './components';
2
+ export * from './scheduler.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL3NjaGVkdWxlci5tb2R1bGUnOyJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1vcGVyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvaW50ZXJmYWNlcy9kcmFnLW9wZXJhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRURyYWdPcGVyYXRpb24gfSBmcm9tIFwiLi4vZW51bXMvZHJhZy1vcGVyYXRpb25cIjtcbmltcG9ydCB7IFNjaGVkdWxlckV2ZW50IH0gZnJvbSBcIi4vc2NoZWR1bGVyLWV2ZW50XCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRHJhZ09wZXJhdGlvbiB7XG4gICAgb3BlcmF0aW9uOiBFRHJhZ09wZXJhdGlvbjtcbiAgICBldmVudDogU2NoZWR1bGVyRXZlbnQ7XG59Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy1ldmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL3NjaGVkdWxlci9pbnRlcmZhY2VzL3ByZXZpZXctZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgUHJldmlld0V2ZW50IHtcbiAgICBzdGFydDogRGF0ZTtcbiAgICBlbmQ6IERhdGU7XG59Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZWR1bGVyLWV2ZW50LXBhcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvaW50ZXJmYWNlcy9zY2hlZHVsZXItZXZlbnQtcGFydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2NoZWR1bGVyRXZlbnQgfSBmcm9tIFwiLi9zY2hlZHVsZXItZXZlbnRcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTY2hlZHVsZXJFdmVudFBhcnQge1xuICAgIHN0YXJ0OiBEYXRlO1xuICAgIGVuZDogRGF0ZTtcbiAgICBldmVudDogU2NoZWR1bGVyRXZlbnQgfCBudWxsO1xufSJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZWR1bGVyLWV2ZW50LXdpdGgtcGFydHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvaW50ZXJmYWNlcy9zY2hlZHVsZXItZXZlbnQtd2l0aC1wYXJ0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2NoZWR1bGVyRXZlbnQgfSBmcm9tIFwiLi9zY2hlZHVsZXItZXZlbnRcIjtcbmltcG9ydCB7IFNjaGVkdWxlckV2ZW50UGFydCB9IGZyb20gXCIuL3NjaGVkdWxlci1ldmVudC1wYXJ0XCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZWR1bGVyRXZlbnRXaXRoUGFydHMge1xuICAgIGV2ZW50OiBTY2hlZHVsZXJFdmVudDtcbiAgICBwYXJ0czogU2NoZWR1bGVyRXZlbnRQYXJ0W107XG59Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZWR1bGVyLWV2ZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvc2NoZWR1bGVyL2ludGVyZmFjZXMvc2NoZWR1bGVyLWV2ZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFNjaGVkdWxlckV2ZW50IHtcbiAgICBzdGFydDogRGF0ZTtcbiAgICBlbmQ6IERhdGU7XG4gICAgY29sb3I6IHN0cmluZztcbiAgICBkZXNjcmlwdGlvbjogc3RyaW5nO1xufSJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1zbG90LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvc2NoZWR1bGVyL2ludGVyZmFjZXMvdGltZS1zbG90LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFRpbWVTbG90IHtcbiAgICBzdGFydDogRGF0ZTtcbiAgICBlbmQ6IERhdGU7XG59Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZWxpbmUtdHJhY2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvaW50ZXJmYWNlcy90aW1lbGluZS10cmFjay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2NoZWR1bGVyRXZlbnQgfSBmcm9tIFwiLi9zY2hlZHVsZXItZXZlbnRcIjtcblxuZXhwb3J0IGludGVyZmFjZSBUaW1lbGluZVRyYWNrIHtcbiAgICBpbmRleDogbnVtYmVyO1xuICAgIGV2ZW50czogU2NoZWR1bGVyRXZlbnRbXTtcbn0iXX0=
@@ -0,0 +1,16 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class BsSecondsTimespanPipe {
4
+ transform(value) {
5
+ return (value.end.getTime() - value.start.getTime()) / 1000;
6
+ }
7
+ }
8
+ BsSecondsTimespanPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSecondsTimespanPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
9
+ BsSecondsTimespanPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSecondsTimespanPipe, name: "bsSecondsTimespan" });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSecondsTimespanPipe, decorators: [{
11
+ type: Pipe,
12
+ args: [{
13
+ name: 'bsSecondsTimespan'
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnMtc2Vjb25kcy10aW1lc3Bhbi5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvc2NoZWR1bGVyL3BpcGVzL2JzLXNlY29uZHMtdGltZXNwYW4ucGlwZS9icy1zZWNvbmRzLXRpbWVzcGFuLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBT3BELE1BQU0sT0FBTyxxQkFBcUI7SUFFaEMsU0FBUyxDQUFDLEtBQTBDO1FBQ2xELE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDOUQsQ0FBQzs7a0hBSlUscUJBQXFCO2dIQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFIakMsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsbUJBQW1CO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNjaGVkdWxlckV2ZW50IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9zY2hlZHVsZXItZXZlbnQnO1xuaW1wb3J0IHsgU2NoZWR1bGVyRXZlbnRQYXJ0IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9zY2hlZHVsZXItZXZlbnQtcGFydCc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ2JzU2Vjb25kc1RpbWVzcGFuJ1xufSlcbmV4cG9ydCBjbGFzcyBCc1NlY29uZHNUaW1lc3BhblBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcblxuICB0cmFuc2Zvcm0odmFsdWU6IFNjaGVkdWxlckV2ZW50UGFydCB8IFNjaGVkdWxlckV2ZW50KSB7XG4gICAgcmV0dXJuICh2YWx1ZS5lbmQuZ2V0VGltZSgpIC0gdmFsdWUuc3RhcnQuZ2V0VGltZSgpKSAvIDEwMDA7XG4gIH1cblxufVxuIl19
@@ -0,0 +1,20 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class BsSecondsTodayOffsetPipe {
4
+ transform(value) {
5
+ const today = new Date(value.start);
6
+ today.setHours(0);
7
+ today.setMinutes(0);
8
+ today.setSeconds(0);
9
+ return (value.start.getTime() - today.getTime()) / 1000;
10
+ }
11
+ }
12
+ BsSecondsTodayOffsetPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSecondsTodayOffsetPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
13
+ BsSecondsTodayOffsetPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSecondsTodayOffsetPipe, name: "bsSecondsTodayOffset" });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsSecondsTodayOffsetPipe, decorators: [{
15
+ type: Pipe,
16
+ args: [{
17
+ name: 'bsSecondsTodayOffset'
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnMtc2Vjb25kcy10b2RheS1vZmZzZXQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL3NjaGVkdWxlci9waXBlcy9icy1zZWNvbmRzLXRvZGF5LW9mZnNldC9icy1zZWNvbmRzLXRvZGF5LW9mZnNldC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQU9wRCxNQUFNLE9BQU8sd0JBQXdCO0lBRW5DLFNBQVMsQ0FBQyxLQUEwQztRQUNsRCxNQUFNLEtBQUssR0FBRyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDcEMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRTVELE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxHQUFHLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUMxRCxDQUFDOztxSEFQVSx3QkFBd0I7bUhBQXhCLHdCQUF3QjsyRkFBeEIsd0JBQXdCO2tCQUhwQyxJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxzQkFBc0I7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2NoZWR1bGVyRXZlbnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL3NjaGVkdWxlci1ldmVudCc7XG5pbXBvcnQgeyBTY2hlZHVsZXJFdmVudFBhcnQgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL3NjaGVkdWxlci1ldmVudC1wYXJ0JztcblxuQFBpcGUoe1xuICBuYW1lOiAnYnNTZWNvbmRzVG9kYXlPZmZzZXQnXG59KVxuZXhwb3J0IGNsYXNzIEJzU2Vjb25kc1RvZGF5T2Zmc2V0UGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuXG4gIHRyYW5zZm9ybSh2YWx1ZTogU2NoZWR1bGVyRXZlbnRQYXJ0IHwgU2NoZWR1bGVyRXZlbnQpIHtcbiAgICBjb25zdCB0b2RheSA9IG5ldyBEYXRlKHZhbHVlLnN0YXJ0KTtcbiAgICB0b2RheS5zZXRIb3VycygwKTsgdG9kYXkuc2V0TWludXRlcygwKTsgdG9kYXkuc2V0U2Vjb25kcygwKTtcblxuICAgIHJldHVybiAodmFsdWUuc3RhcnQuZ2V0VGltZSgpIC0gdG9kYXkuZ2V0VGltZSgpKSAvIDEwMDA7XG4gIH1cblxufVxuIl19
@@ -0,0 +1,20 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class DateOffsetPipe {
4
+ transform(value) {
5
+ const today = new Date(value.start);
6
+ today.setHours(0);
7
+ today.setMinutes(0);
8
+ today.setSeconds(0);
9
+ return (value.start.getTime() - today.getTime()) / 1000;
10
+ }
11
+ }
12
+ DateOffsetPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DateOffsetPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
13
+ DateOffsetPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DateOffsetPipe, name: "dateOffset" });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DateOffsetPipe, decorators: [{
15
+ type: Pipe,
16
+ args: [{
17
+ name: 'dateOffset'
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1vZmZzZXQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL3NjaGVkdWxlci9waXBlcy9kYXRlLW9mZnNldC9kYXRlLW9mZnNldC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQU1wRCxNQUFNLE9BQU8sY0FBYztJQUV6QixTQUFTLENBQUMsS0FBeUI7UUFDakMsTUFBTSxLQUFLLEdBQUcsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUU1RCxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsR0FBRyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDMUQsQ0FBQzs7MkdBUFUsY0FBYzt5R0FBZCxjQUFjOzJGQUFkLGNBQWM7a0JBSDFCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLFlBQVk7aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2NoZWR1bGVyRXZlbnRQYXJ0IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9zY2hlZHVsZXItZXZlbnQtcGFydCc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ2RhdGVPZmZzZXQnXG59KVxuZXhwb3J0IGNsYXNzIERhdGVPZmZzZXRQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG5cbiAgdHJhbnNmb3JtKHZhbHVlOiBTY2hlZHVsZXJFdmVudFBhcnQpIHtcbiAgICBjb25zdCB0b2RheSA9IG5ldyBEYXRlKHZhbHVlLnN0YXJ0KTtcbiAgICB0b2RheS5zZXRIb3VycygwKTsgdG9kYXkuc2V0TWludXRlcygwKTsgdG9kYXkuc2V0U2Vjb25kcygwKTtcblxuICAgIHJldHVybiAodmFsdWUuc3RhcnQuZ2V0VGltZSgpIC0gdG9kYXkuZ2V0VGltZSgpKSAvIDEwMDA7XG4gIH1cblxufVxuIl19
@@ -0,0 +1,22 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class DayOfWeekPipe {
4
+ transform(value) {
5
+ const dayOfWeek = value.start.getDay();
6
+ if (dayOfWeek === 0) {
7
+ return 7;
8
+ }
9
+ else {
10
+ return dayOfWeek;
11
+ }
12
+ }
13
+ }
14
+ DayOfWeekPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DayOfWeekPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
15
+ DayOfWeekPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DayOfWeekPipe, name: "dayOfWeek" });
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: DayOfWeekPipe, decorators: [{
17
+ type: Pipe,
18
+ args: [{
19
+ name: 'dayOfWeek'
20
+ }]
21
+ }] });
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF5LW9mLXdlZWsucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL3NjaGVkdWxlci9waXBlcy9kYXktb2Ytd2Vlay9kYXktb2Ytd2Vlay5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQU9wRCxNQUFNLE9BQU8sYUFBYTtJQUV4QixTQUFTLENBQUMsS0FBMEM7UUFDbEQsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUN2QyxJQUFJLFNBQVMsS0FBSyxDQUFDLEVBQUU7WUFDbkIsT0FBTyxDQUFDLENBQUM7U0FDVjthQUFNO1lBQ0wsT0FBTyxTQUFTLENBQUM7U0FDbEI7SUFDSCxDQUFDOzswR0FUVSxhQUFhO3dHQUFiLGFBQWE7MkZBQWIsYUFBYTtrQkFIekIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsV0FBVztpQkFDbEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTY2hlZHVsZXJFdmVudCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvc2NoZWR1bGVyLWV2ZW50JztcbmltcG9ydCB7IFNjaGVkdWxlckV2ZW50UGFydCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvc2NoZWR1bGVyLWV2ZW50LXBhcnQnO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdkYXlPZldlZWsnXG59KVxuZXhwb3J0IGNsYXNzIERheU9mV2Vla1BpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcblxuICB0cmFuc2Zvcm0odmFsdWU6IFNjaGVkdWxlckV2ZW50UGFydCB8IFNjaGVkdWxlckV2ZW50KSB7XG4gICAgY29uc3QgZGF5T2ZXZWVrID0gdmFsdWUuc3RhcnQuZ2V0RGF5KCk7XG4gICAgaWYgKGRheU9mV2VlayA9PT0gMCkge1xuICAgICAgcmV0dXJuIDc7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBkYXlPZldlZWs7XG4gICAgfVxuICB9XG5cbn1cbiJdfQ==