ngx-mat-tui-calendar 0.0.11 → 0.0.15
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.
- package/bundles/ngx-mat-tui-calendar.umd.js +1170 -13
- package/bundles/ngx-mat-tui-calendar.umd.js.map +1 -1
- package/esm2015/lib/calendar-editor-options.js +2 -0
- package/esm2015/lib/calendar-options.js +2 -0
- package/esm2015/lib/local-date.js +102 -0
- package/esm2015/lib/ngx-mat-tui-calendar-editor-dialog/ngx-mat-tui-calendar-editor-dialog.component.js +147 -0
- package/esm2015/lib/ngx-mat-tui-calendar-wrapper/ngx-mat-tui-calendar-wrapper.component.js +19 -0
- package/esm2015/lib/ngx-mat-tui-calendar.component.js +496 -16
- package/esm2015/lib/ngx-mat-tui-calendar.module.js +109 -4
- package/esm2015/public-api.js +4 -1
- package/fesm2015/ngx-mat-tui-calendar.js +852 -19
- package/fesm2015/ngx-mat-tui-calendar.js.map +1 -1
- package/lib/calendar-editor-options.d.ts +6 -0
- package/lib/calendar-options.d.ts +6 -0
- package/lib/local-date.d.ts +43 -0
- package/lib/ngx-mat-tui-calendar-editor-dialog/ngx-mat-tui-calendar-editor-dialog.component.d.ts +35 -0
- package/lib/ngx-mat-tui-calendar-wrapper/ngx-mat-tui-calendar-wrapper.component.d.ts +8 -0
- package/lib/ngx-mat-tui-calendar.component.d.ts +71 -4
- package/lib/ngx-mat-tui-calendar.module.d.ts +24 -1
- package/package.json +34 -9
- package/public-api.d.ts +3 -0
@@ -1,26 +1,506 @@
|
|
1
|
-
import { Component } from '@angular/core';
|
1
|
+
import { Component, Output, EventEmitter, Input } from '@angular/core';
|
2
|
+
import { MatDialogConfig } from '@angular/material/dialog';
|
3
|
+
import distinctColors from 'distinct-colors';
|
4
|
+
import { v4 as uuidv4 } from 'uuid';
|
5
|
+
import { faCalendarCheck, faTable, faColumns, faListAlt, faForward, faBackward, faCaretLeft, faCaretRight, } from '@fortawesome/free-solid-svg-icons';
|
6
|
+
import { default as Calendar, } from 'tui-calendar';
|
7
|
+
// project
|
8
|
+
import { LocalDate } from './local-date.js';
|
9
|
+
import { NgxMatTuiCalendarEditorDialogComponent } from './ngx-mat-tui-calendar-editor-dialog/ngx-mat-tui-calendar-editor-dialog.component';
|
2
10
|
import * as i0 from "@angular/core";
|
11
|
+
import * as i1 from "@angular/material/dialog";
|
12
|
+
import * as i2 from "@angular/material/toolbar";
|
13
|
+
import * as i3 from "@angular/material/button";
|
14
|
+
import * as i4 from "@fortawesome/angular-fontawesome";
|
15
|
+
import * as i5 from "@angular/material/button-toggle";
|
16
|
+
import * as i6 from "./ngx-mat-tui-calendar-wrapper/ngx-mat-tui-calendar-wrapper.component";
|
3
17
|
export class NgxMatTuiCalendarComponent {
|
4
|
-
constructor() {
|
18
|
+
constructor(dialog) {
|
19
|
+
this.dialog = dialog;
|
20
|
+
this.iconToday = faCalendarCheck;
|
21
|
+
// iconPrev = faCaretSquareLeft;
|
22
|
+
// iconNext = faCaretSquareRight;
|
23
|
+
this.iconPrev = faCaretLeft;
|
24
|
+
this.iconNext = faCaretRight;
|
25
|
+
this.iconLongPrev = faBackward;
|
26
|
+
this.iconLongNext = faForward;
|
27
|
+
this.iconByMonth = faTable;
|
28
|
+
this.iconByWeek = faColumns;
|
29
|
+
this.iconByDay = faListAlt;
|
30
|
+
this.userCreatedSchedule = new EventEmitter();
|
31
|
+
this.userUpdatedSchedule = new EventEmitter();
|
32
|
+
this.userDeletedSchedule = new EventEmitter();
|
33
|
+
// we slice off the first color since it is gray
|
34
|
+
this.colors = distinctColors({ lightMin: 70, count: 15 }).slice(1);
|
35
|
+
this.colorIndex = 0;
|
36
|
+
this.calendarId = uuidv4();
|
37
|
+
}
|
5
38
|
ngOnInit() {
|
39
|
+
this.createTUICalendar(null);
|
40
|
+
this.bindCallbacks();
|
41
|
+
}
|
42
|
+
ngOnChanges(changes) {
|
43
|
+
console.warn(changes);
|
44
|
+
if (this.calendar) {
|
45
|
+
if (changes.options) {
|
46
|
+
console.warn(`change.option:`, changes.options);
|
47
|
+
let options = changes.options.currentValue;
|
48
|
+
if (!options.theme) {
|
49
|
+
options.theme = this.getDefaultTheme();
|
50
|
+
}
|
51
|
+
console.warn(`TUI theme:`, options.theme);
|
52
|
+
this.calendar.setOptions(options.ioptions);
|
53
|
+
this.calendar.setTheme(options.theme);
|
54
|
+
this.calendar.render(true);
|
55
|
+
}
|
56
|
+
}
|
57
|
+
}
|
58
|
+
ngOnDestroy() {
|
59
|
+
this.calendar.destroy();
|
60
|
+
}
|
61
|
+
onCalendarLongPrev() {
|
62
|
+
let date = this.calendar.getDate().toDate();
|
63
|
+
let days = 0;
|
64
|
+
let months = 0;
|
65
|
+
let years = 0;
|
66
|
+
switch (this.calendar.getViewName()) {
|
67
|
+
case 'day':
|
68
|
+
days = -7;
|
69
|
+
break;
|
70
|
+
case 'week':
|
71
|
+
days = -28;
|
72
|
+
break;
|
73
|
+
case 'month':
|
74
|
+
years = -1;
|
75
|
+
break;
|
76
|
+
}
|
77
|
+
date.setFullYear(date.getFullYear() + years);
|
78
|
+
date.setMonth(date.getMonth() + months); // date class does the modular arithmetic
|
79
|
+
date.setDate(date.getDate() + days); // date class does the modular arithmetic
|
80
|
+
this.calendar.setDate(date);
|
81
|
+
}
|
82
|
+
onCalendarPrev() {
|
83
|
+
this.calendar.prev();
|
84
|
+
}
|
85
|
+
onCalendarToday() {
|
86
|
+
this.calendar.today();
|
87
|
+
}
|
88
|
+
onCalendarNext() {
|
89
|
+
this.calendar.next();
|
90
|
+
}
|
91
|
+
onCalendarLongNext() {
|
92
|
+
let date = this.calendar.getDate().toDate();
|
93
|
+
let days = 0;
|
94
|
+
let months = 0;
|
95
|
+
let years = 0;
|
96
|
+
switch (this.calendar.getViewName()) {
|
97
|
+
case 'day':
|
98
|
+
days = 7;
|
99
|
+
break;
|
100
|
+
case 'week':
|
101
|
+
days = 28;
|
102
|
+
break;
|
103
|
+
case 'month':
|
104
|
+
years = 1;
|
105
|
+
break;
|
106
|
+
}
|
107
|
+
date.setFullYear(date.getFullYear() + years);
|
108
|
+
date.setMonth(date.getMonth() + months); // date class does the modular arithmetic
|
109
|
+
date.setDate(date.getDate() + days); // date class does the modular arithmetic
|
110
|
+
this.calendar.setDate(date);
|
111
|
+
}
|
112
|
+
onMonthView() {
|
113
|
+
this.calendar.changeView('month');
|
114
|
+
}
|
115
|
+
onWeekView() {
|
116
|
+
this.calendar.changeView('week');
|
117
|
+
}
|
118
|
+
onDayView() {
|
119
|
+
this.calendar.changeView('day');
|
120
|
+
}
|
121
|
+
getDate() {
|
122
|
+
let date = this.calendar.getDate();
|
123
|
+
let str = date.toDate().toLocaleDateString("en-US", {
|
124
|
+
year: 'numeric',
|
125
|
+
month: 'short',
|
126
|
+
});
|
127
|
+
return str;
|
128
|
+
}
|
129
|
+
createTUICalendar(options) {
|
130
|
+
this.calendar = new Calendar('#calendar', this.prerocessOptions(options));
|
131
|
+
}
|
132
|
+
bindCallbacks() {
|
133
|
+
this.bindAfterRenderSchedule();
|
134
|
+
this.bindClickTimezonesCollapseBtn();
|
135
|
+
this.bindClickDayname();
|
136
|
+
this.bindClickMore();
|
137
|
+
this.bindClickSchedule();
|
138
|
+
this.bindBeforeCreateSchedule();
|
139
|
+
this.bindBeforeUpdateSchedule();
|
140
|
+
this.bindBeforeDeleteSchedule();
|
141
|
+
}
|
142
|
+
bindAfterRenderSchedule() {
|
143
|
+
let that = this;
|
144
|
+
this.calendar.on('afterRenderSchedule', function (event) {
|
145
|
+
// console.warn(`afterRenderSchedule`, event);
|
146
|
+
});
|
147
|
+
}
|
148
|
+
bindClickTimezonesCollapseBtn() {
|
149
|
+
let that = this;
|
150
|
+
this.calendar.on('clickTimezonesCollapseBtn', function (timezonesCollapsed) {
|
151
|
+
// console.warn(`clickTimezonesCollapseBtn`, timezonesCollapsed);
|
152
|
+
});
|
153
|
+
}
|
154
|
+
bindClickDayname() {
|
155
|
+
let that = this;
|
156
|
+
this.calendar.on('clickDayname', function (event) {
|
157
|
+
// console.warn(`clickDayname`, event);
|
158
|
+
});
|
159
|
+
}
|
160
|
+
bindClickMore() {
|
161
|
+
let that = this;
|
162
|
+
this.calendar.on('clickMore', function (event) {
|
163
|
+
// console.warn(`clickMore`, event);
|
164
|
+
});
|
165
|
+
}
|
166
|
+
bindClickSchedule() {
|
167
|
+
// only works if useDetailPopup: false,
|
168
|
+
let that = this;
|
169
|
+
this.calendar.on('clickSchedule', function (event) {
|
170
|
+
// console.warn(`clickSchedule`, event);
|
171
|
+
let schedule = Object.assign({}, event.schedule);
|
172
|
+
schedule.start = (new LocalDate(schedule.start)).toDate();
|
173
|
+
schedule.end = (new LocalDate(schedule.end)).toDate();
|
174
|
+
that.openPopupScheduleEditor(schedule);
|
175
|
+
});
|
176
|
+
}
|
177
|
+
bindBeforeCreateSchedule() {
|
178
|
+
let that = this;
|
179
|
+
this.calendar.on('beforeCreateSchedule', function (event) {
|
180
|
+
// console.log(`beforeCreateSchedule`, event);
|
181
|
+
let start = (new LocalDate(event.start)).toDate();
|
182
|
+
start.setHours(9);
|
183
|
+
let end = (new LocalDate(event.end)).toDate();
|
184
|
+
end.setHours(10);
|
185
|
+
that.openPopupScheduleEditor({
|
186
|
+
title: '',
|
187
|
+
start: start,
|
188
|
+
end: end,
|
189
|
+
id: null,
|
190
|
+
});
|
191
|
+
});
|
192
|
+
}
|
193
|
+
bindBeforeUpdateSchedule() {
|
194
|
+
let that = this;
|
195
|
+
this.calendar.on('beforeUpdateSchedule', function (event) {
|
196
|
+
// console.log(`beforeUpdateSchedule`, event);
|
197
|
+
that.updateScheduleAndNotifyParent(event);
|
198
|
+
});
|
199
|
+
}
|
200
|
+
bindBeforeDeleteSchedule() {
|
201
|
+
let that = this;
|
202
|
+
this.calendar.on('beforeDeleteSchedule', function (event) {
|
203
|
+
// console.log(`beforeDeleteSchedule`, event.schedule);
|
204
|
+
// console.log(`beforeDeleteSchedule`, event.schedule);
|
205
|
+
that.deleteScheduleAndNotifyParent({ id: event.schedule.id, calendarId: event.schedule.calendarId });
|
206
|
+
});
|
207
|
+
}
|
208
|
+
nextColor() {
|
209
|
+
let color = this.colors[this.colorIndex++].hex();
|
210
|
+
if (this.colorIndex >= this.colors.length)
|
211
|
+
this.colorIndex = 0;
|
212
|
+
return color;
|
213
|
+
}
|
214
|
+
createScheduleAndNotifyParent(args) {
|
215
|
+
let schedule = this.createSchedule(args);
|
216
|
+
this.userCreatedSchedule.emit(schedule);
|
217
|
+
return schedule;
|
218
|
+
}
|
219
|
+
createSchedules(schedules) {
|
220
|
+
let newSchedules = [];
|
221
|
+
for (let schedule of schedules) {
|
222
|
+
newSchedules.push(this.createSchedule(schedule));
|
223
|
+
}
|
224
|
+
return newSchedules;
|
225
|
+
}
|
226
|
+
createSchedule(args) {
|
227
|
+
// if (form.invalid) return;
|
228
|
+
// create a color
|
229
|
+
let color = this.nextColor();
|
230
|
+
// console.log(color);
|
231
|
+
// create an id
|
232
|
+
let id = (args.id == null) ? '' : args.id.toString();
|
233
|
+
if (id.length === 0) {
|
234
|
+
id = uuidv4();
|
235
|
+
}
|
236
|
+
let start = LocalDate.convertToJsDate(args.start);
|
237
|
+
let end = LocalDate.convertToJsDate(args.end);
|
238
|
+
let schedule = {
|
239
|
+
id,
|
240
|
+
calendarId: (args.calendarId == null) ? this.calendarId : args.calendarId,
|
241
|
+
title: args.title,
|
242
|
+
start: start,
|
243
|
+
end: end,
|
244
|
+
category: args.category,
|
245
|
+
isAllDay: args.isAllDay,
|
246
|
+
dueDateClass: '',
|
247
|
+
bgColor: color,
|
248
|
+
};
|
249
|
+
// console.log(`event-calendar.component.ts: createEvent:`, schedule);
|
250
|
+
this.calendar.createSchedules([schedule]);
|
251
|
+
return this.calendar.getSchedule(schedule.id, schedule.calendarId);
|
252
|
+
}
|
253
|
+
updateScheduleAndNotifyParent(args) {
|
254
|
+
let schedule = this.updateSchedule(args);
|
255
|
+
this.userUpdatedSchedule.emit(schedule);
|
256
|
+
return schedule;
|
257
|
+
}
|
258
|
+
updateSchedule(schedule) {
|
259
|
+
// console.log(`event-calendar.component.ts: updateSchedule:`, schedule);
|
260
|
+
let calendarId = (schedule.calendarId == null) ? this.calendarId : schedule.calendarId;
|
261
|
+
this.calendar.updateSchedule(schedule.id, calendarId, schedule, false);
|
262
|
+
return this.calendar.getSchedule(schedule.id, calendarId);
|
263
|
+
}
|
264
|
+
getSchedule(args) {
|
265
|
+
// console.log(`event-calendar.component.ts: getSchedule:`, schedule);
|
266
|
+
let calendarId = (args.calendarId == null) ? this.calendarId : args.calendarId;
|
267
|
+
return this.calendar.getSchedule(args.id, calendarId);
|
268
|
+
}
|
269
|
+
deleteScheduleAndNotifyParent(args) {
|
270
|
+
this.deleteSchedule(args);
|
271
|
+
let calendarId = (args.calendarId == null) ? this.calendarId : args.calendarId;
|
272
|
+
this.userDeletedSchedule.emit({ id: args.id, calendarId });
|
273
|
+
}
|
274
|
+
deleteSchedule(args) {
|
275
|
+
// console.log(`event-calendar.component.ts: deleteSchedule:`, schedule);
|
276
|
+
let calendarId = (args.calendarId == null) ? this.calendarId : args.calendarId;
|
277
|
+
this.calendar.deleteSchedule(args.id, calendarId, false);
|
278
|
+
}
|
279
|
+
deleteAllSchedules() {
|
280
|
+
this.calendar.clear();
|
281
|
+
}
|
282
|
+
openPopupScheduleEditor(schedule) {
|
283
|
+
// console.log('openPopupScheduleEditor: calevent:', schedule);
|
284
|
+
const dialogConfig = new MatDialogConfig();
|
285
|
+
dialogConfig.panelClass = this.options.themeClass;
|
286
|
+
console.warn(`options: `, this.options);
|
287
|
+
dialogConfig.data = { schedule, darkMode: this.options.darkMode, themeClass: this.options.themeClass };
|
288
|
+
dialogConfig.autoFocus = true;
|
289
|
+
const dialogRef = this.dialog.open(NgxMatTuiCalendarEditorDialogComponent, dialogConfig);
|
290
|
+
// const dialogRef = this.dialog.open(NgxMatTuiCalendarScheduleEditorDialogComponent, {
|
291
|
+
// data: schedule,
|
292
|
+
// });
|
293
|
+
dialogRef.afterClosed().subscribe((result) => {
|
294
|
+
// console.log('openPopupScheduleEditor: The dialog was closed', result);
|
295
|
+
this.calendar.render(true); // <-- so that selection is cleared
|
296
|
+
if (result && result.schedule) {
|
297
|
+
let schedule = result.schedule;
|
298
|
+
if (result.performDelete == true) {
|
299
|
+
// delete
|
300
|
+
// console.log(`openPopupScheduleEditor:afterCLosed: deleteSchedule`);
|
301
|
+
this.deleteScheduleAndNotifyParent({ id: schedule.id, calendarId: schedule.calendarId });
|
302
|
+
}
|
303
|
+
else if (schedule.id == null) {
|
304
|
+
// console.log(`openPopupScheduleEditor:afterCLosed: addSchedule`);
|
305
|
+
this.createScheduleAndNotifyParent(schedule);
|
306
|
+
}
|
307
|
+
else {
|
308
|
+
// console.log(`openPopupScheduleEditor:afterCLosed: updateSchedule`);
|
309
|
+
this.updateScheduleAndNotifyParent(schedule);
|
310
|
+
}
|
311
|
+
}
|
312
|
+
});
|
313
|
+
}
|
314
|
+
setOptions(options) {
|
315
|
+
this.calendar.setOptions(this.prerocessOptions(options));
|
316
|
+
}
|
317
|
+
prerocessOptions(options) {
|
318
|
+
let defs = this.getDefaultOptions();
|
319
|
+
if (options == null) {
|
320
|
+
options = defs;
|
321
|
+
}
|
322
|
+
else {
|
323
|
+
options = Object.assign(Object.assign({}, defs), options);
|
324
|
+
}
|
325
|
+
options.useCreationPopup = false;
|
326
|
+
options.useDetailPopup = false;
|
327
|
+
return options;
|
328
|
+
}
|
329
|
+
getDefaultOptions() {
|
330
|
+
return {
|
331
|
+
defaultView: 'month',
|
332
|
+
taskView: true,
|
333
|
+
useCreationPopup: false,
|
334
|
+
useDetailPopup: false,
|
335
|
+
theme: this.getDefaultTheme(),
|
336
|
+
template: {
|
337
|
+
monthDayname: function (dayname) {
|
338
|
+
return '<span class="calendar-week-dayname-name">' + dayname.label + '</span>';
|
339
|
+
}
|
340
|
+
},
|
341
|
+
week: {
|
342
|
+
// startDayOfWeek: undefined,
|
343
|
+
// daynames: undefined,
|
344
|
+
narrowWeekend: false,
|
345
|
+
// workweek: true,
|
346
|
+
showTimezoneCollapseButton: true,
|
347
|
+
timezonesCollapsed: true,
|
348
|
+
hourStart: 7,
|
349
|
+
hourEnd: 20,
|
350
|
+
},
|
351
|
+
};
|
352
|
+
}
|
353
|
+
getColor(name) {
|
354
|
+
const el = document.getElementById(`theme-${name}`);
|
355
|
+
if (el) {
|
356
|
+
const style = window.getComputedStyle(el, null);
|
357
|
+
console.warn(`color:`, style.color);
|
358
|
+
return style.color;
|
359
|
+
}
|
360
|
+
return '';
|
361
|
+
}
|
362
|
+
getDefaultTheme() {
|
363
|
+
function adjustHexOpacity(color, opacity) {
|
364
|
+
const r = parseInt(color.slice(1, 3), 16);
|
365
|
+
const g = parseInt(color.slice(3, 5), 16);
|
366
|
+
const b = parseInt(color.slice(5, 7), 16);
|
367
|
+
return 'rgba(' + r + ', ' + g + ', ' + b + ', ' + opacity + ')';
|
368
|
+
}
|
369
|
+
// default keys and styles
|
370
|
+
// TODO: apply Material Design Theme
|
371
|
+
let background = this.getColor("background");
|
372
|
+
let border = this.getColor("divider");
|
373
|
+
let borderLight = this.getColor("divider-light");
|
374
|
+
let shadow = this.getColor("divider");
|
375
|
+
let highlight = this.getColor("highlight");
|
376
|
+
let primary = this.getColor("primary");
|
377
|
+
let warn = this.getColor("warn");
|
378
|
+
let text = this.getColor("foreground");
|
379
|
+
let primaryShaded = this.getColor("primary-shaded");
|
380
|
+
// tui-full-calendar-weekday-schedule-title
|
381
|
+
//calendar-week-dayname-name
|
382
|
+
return {
|
383
|
+
'common.border': `1px solid ${border}`,
|
384
|
+
'common.backgroundColor': background,
|
385
|
+
'common.holiday.color': warn,
|
386
|
+
'common.saturday.color': text,
|
387
|
+
'common.dayname.color': text,
|
388
|
+
'common.today.color': '#0f0',
|
389
|
+
// creation guide style
|
390
|
+
'common.creationGuide.backgroundColor': primaryShaded,
|
391
|
+
'common.creationGuide.border': `1px solid ${highlight}`,
|
392
|
+
// month header 'dayname'
|
393
|
+
'month.dayname.height': '31px',
|
394
|
+
'month.dayname.borderLeft': `1px solid ${border}`,
|
395
|
+
'month.dayname.paddingLeft': '10px',
|
396
|
+
'month.dayname.paddingRight': '10px',
|
397
|
+
'month.dayname.backgroundColor': 'inherit',
|
398
|
+
'month.dayname.fontSize': '12px',
|
399
|
+
'month.dayname.fontWeight': 'normal',
|
400
|
+
'month.dayname.textAlign': 'left',
|
401
|
+
// month day grid cell 'day'
|
402
|
+
'month.holidayExceptThisMonth.color': 'rgba(255, 64, 64, 0.4)',
|
403
|
+
'month.dayExceptThisMonth.color': 'rgba(51, 51, 51, 0.4)',
|
404
|
+
'month.weekend.backgroundColor': 'inherit',
|
405
|
+
'month.day.fontSize': '14px',
|
406
|
+
'month.schedule.color': highlight,
|
407
|
+
// month schedule style
|
408
|
+
'month.schedule.borderRadius': '2px',
|
409
|
+
'month.schedule.height': '24px',
|
410
|
+
'month.schedule.marginTop': '2px',
|
411
|
+
'month.schedule.marginLeft': '8px',
|
412
|
+
'month.schedule.marginRight': '8px',
|
413
|
+
// month more view
|
414
|
+
'month.moreView.border': `1px solid ${border}`,
|
415
|
+
'month.moreView.boxShadow': `0 2px 6px 0 ${shadow}`,
|
416
|
+
'month.moreView.backgroundColor': background,
|
417
|
+
'month.moreView.paddingBottom': '17px',
|
418
|
+
'month.moreViewTitle.height': '44px',
|
419
|
+
'month.moreViewTitle.marginBottom': '12px',
|
420
|
+
'month.moreViewTitle.backgroundColor': 'inherit',
|
421
|
+
'month.moreViewTitle.borderBottom': 'none',
|
422
|
+
'month.moreViewTitle.padding': '12px 17px 0 17px',
|
423
|
+
'month.moreViewList.padding': '0 17px',
|
424
|
+
// week header 'dayname'
|
425
|
+
'week.dayname.height': '42px',
|
426
|
+
'week.dayname.borderTop': `1px solid ${border}`,
|
427
|
+
'week.dayname.borderBottom': `1px solid ${border}`,
|
428
|
+
'week.dayname.borderLeft': 'inherit',
|
429
|
+
'week.dayname.paddingLeft': '0',
|
430
|
+
'week.dayname.backgroundColor': 'inherit',
|
431
|
+
'week.dayname.textAlign': 'left',
|
432
|
+
'week.today.color': text,
|
433
|
+
'week.pastDay.color': borderLight,
|
434
|
+
// week vertical panel 'vpanel'
|
435
|
+
'week.vpanelSplitter.border': `1px solid ${border}`,
|
436
|
+
'week.vpanelSplitter.height': '3px',
|
437
|
+
// week daygrid 'daygrid'
|
438
|
+
'week.daygrid.borderRight': `1px solid ${border}`,
|
439
|
+
'week.daygrid.backgroundColor': background,
|
440
|
+
'week.daygridLeft.width': '72px',
|
441
|
+
'week.daygridLeft.backgroundColor': background,
|
442
|
+
'week.daygridLeft.paddingRight': '8px',
|
443
|
+
'week.daygridLeft.borderRight': `1px solid ${border}`,
|
444
|
+
'week.today.backgroundColor': primaryShaded,
|
445
|
+
'week.weekend.backgroundColor': 'inherit',
|
446
|
+
// week timegrid 'timegrid'
|
447
|
+
'week.timegridLeft.width': '72px',
|
448
|
+
'week.timegridLeft.backgroundColor': 'inherit',
|
449
|
+
'week.timegridLeft.borderRight': `1px solid ${border}`,
|
450
|
+
'week.timegridLeft.fontSize': '11px',
|
451
|
+
'week.timegridLeftTimezoneLabel.height': '40px',
|
452
|
+
'week.timegridLeftAdditionalTimezone.backgroundColor': background,
|
453
|
+
'week.timegridOneHour.height': '52px',
|
454
|
+
'week.timegridHalfHour.height': '26px',
|
455
|
+
'week.timegridHalfHour.borderBottom': 'none',
|
456
|
+
'week.timegridHorizontalLine.borderBottom': `1px solid ${border}`,
|
457
|
+
'week.timegrid.paddingRight': '8px',
|
458
|
+
'week.timegrid.borderRight': `1px solid ${border}`,
|
459
|
+
'week.timegridSchedule.borderRadius': '2px',
|
460
|
+
'week.timegridSchedule.paddingLeft': '2px',
|
461
|
+
// #515ce6 is a slate blue
|
462
|
+
'week.currentTime.color': highlight,
|
463
|
+
'week.currentTime.fontSize': '11px',
|
464
|
+
'week.currentTime.fontWeight': 'normal',
|
465
|
+
'week.pastTime.color': borderLight,
|
466
|
+
'week.pastTime.fontWeight': 'normal',
|
467
|
+
'week.futureTime.color': border,
|
468
|
+
'week.futureTime.fontWeight': 'normal',
|
469
|
+
'week.currentTimeLinePast.border': `1px dashed ${highlight}`,
|
470
|
+
'week.currentTimeLineBullet.backgroundColor': highlight,
|
471
|
+
'week.currentTimeLineToday.border': `1px solid ${highlight}`,
|
472
|
+
'week.currentTimeLineFuture.border': 'none',
|
473
|
+
// week creation guide style
|
474
|
+
'week.creationGuide.color': highlight,
|
475
|
+
'week.creationGuide.fontSize': '11px',
|
476
|
+
'week.creationGuide.fontWeight': 'bold',
|
477
|
+
// week daygrid schedule style
|
478
|
+
'week.dayGridSchedule.borderRadius': '2px',
|
479
|
+
'week.dayGridSchedule.height': '24px',
|
480
|
+
'week.dayGridSchedule.marginTop': '2px',
|
481
|
+
'week.dayGridSchedule.marginLeft': '8px',
|
482
|
+
'week.dayGridSchedule.marginRight': '8px'
|
483
|
+
};
|
6
484
|
}
|
7
485
|
}
|
8
|
-
NgxMatTuiCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: NgxMatTuiCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
9
|
-
NgxMatTuiCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: NgxMatTuiCalendarComponent, selector: "ngx-mat-tui-calendar", ngImport: i0, template:
|
10
|
-
<p>
|
11
|
-
ngx-mat-tui-calendar v0.0.11 works!
|
12
|
-
</p>
|
13
|
-
`, isInline: true });
|
486
|
+
NgxMatTuiCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: NgxMatTuiCalendarComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
487
|
+
NgxMatTuiCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.13", type: NgxMatTuiCalendarComponent, selector: "ngx-mat-tui-calendar", inputs: { options: "options" }, outputs: { userCreatedSchedule: "userCreatedSchedule", userUpdatedSchedule: "userUpdatedSchedule", userDeletedSchedule: "userDeletedSchedule" }, usesOnChanges: true, ngImport: i0, template: "<p>\r\n ngx-mat-tui-calendar v0.0.15 works!!!\r\n</p>\r\n<section class=\"content-container\">\r\n <!-- These divs are here so that we can read the theme colors for the tui theme -->\r\n <div id=\"theme-primary\"></div>\r\n <div id=\"theme-primary-shaded\"></div>\r\n <div id=\"theme-highlight\"></div>\r\n <div id=\"theme-accent\"></div>\r\n <div id=\"theme-warn\"></div>\r\n <div id=\"theme-foreground\"></div>\r\n <div id=\"theme-divider\"></div>\r\n <div id=\"theme-background\"></div>\r\n \r\n <div class=\"calendar-container\">\r\n <!-- calendar titlebar -->\r\n <mat-toolbar class=\"menu-bar\" color=\"primary\">\r\n <!-- <div style=\"align-self: center;display: flex;\r\n align-items: center;\r\n justify-content: flex-start;\"> -->\r\n <div style=\"display: flex;\r\n flex-direction: row;\r\n justify-content: space-between;\r\n width: 100%; \">\r\n <div class=\"left-div\">\r\n <!-- LEFT -->\r\n <button mat-button \r\n class=\"navigation-button\"\r\n style=\"margin-left: 0px; margin-right: 0px; font-size: 1.5rem !important;\" \r\n (click)=\"onCalendarLongPrev()\">\r\n <fa-icon [icon]=\"iconLongPrev\"></fa-icon>\r\n </button>\r\n <button mat-button \r\n class=\"navigation-button\" \r\n style=\"margin-left: 0px; margin-right: 0px; font-size: 2rem !important;\" \r\n (click)=\"onCalendarPrev()\">\r\n <fa-icon [icon]=\"iconPrev\"></fa-icon>\r\n </button>\r\n <button mat-button \r\n class=\"navigation-button\"\r\n style=\"margin-left: 0px; margin-right: 0px; font-size: 1.7rem !important;\" \r\n (click)=\"onCalendarToday()\">\r\n <fa-icon [icon]=\"iconToday\"></fa-icon>\r\n </button>\r\n <button mat-button \r\n class=\"navigation-button\" \r\n style=\"margin-left: 0px; margin-right: 0px; font-size: 2rem !important;\" \r\n (click)=\"onCalendarNext()\">\r\n <fa-icon [icon]=\"iconNext\"></fa-icon>\r\n </button>\r\n <button mat-button \r\n class=\"navigation-button\"\r\n style=\"margin-left: 0px; margin-right: 0px; font-size: 1.5rem !important;\" \r\n (click)=\"onCalendarLongNext()\">\r\n <fa-icon [icon]=\"iconLongNext\"></fa-icon>\r\n </button>\r\n </div>\r\n <div class=\"center-div\">\r\n <!-- CENTER -->\r\n <span class=\"event-calendar-title\">{{ getDate() }}</span>\r\n </div>\r\n <div class=\"right-div\">\r\n \r\n <!-- RIGHT -->\r\n <mat-button-toggle-group class=\"view-button\" value=\"month\" id=\"@+id/toggleButton\" layout_width=\"wrap_content\"\r\n layout_height=\"wrap_content\">\r\n <mat-button-toggle mat-button value=\"month\" class=\"view-button\" (click)=\"onMonthView()\">\r\n <fa-icon [icon]=\"iconByMonth\"></fa-icon>\r\n </mat-button-toggle>\r\n <mat-button-toggle mat-button value=\"week\" class=\"view-button\" (click)=\"onWeekView()\">\r\n <fa-icon [icon]=\"iconByWeek\"></fa-icon>\r\n </mat-button-toggle>\r\n <mat-button-toggle mat-button value=\"day\" class=\"view-button\" (click)=\"onDayView()\">\r\n <fa-icon [icon]=\"iconByDay\"></fa-icon>\r\n </mat-button-toggle>\r\n </mat-button-toggle-group>\r\n </div>\r\n </div>\r\n </mat-toolbar>\r\n <ngx-mat-tui-calendar-wrapper></ngx-mat-tui-calendar-wrapper>\r\n </div>\r\n \r\n </section>", styles: [".calendar-container{transform-origin:top left}.menu-bar{display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:2rem!important}.mat-button{font-size:1.1rem!important}.mat-button.navigation-button{padding:0;min-width:32px}.left-div{width:33%;float:left;display:flex;white-space:nowrap;vertical-align:middle}.center-div{width:33%;float:right;text-align:center;white-space:nowrap;vertical-align:middle}.event-calendar-title{font-size:2rem;vertical-align:middle}.right-div{width:33%;display:flex;white-space:nowrap;vertical-align:middle;flex-flow:row-reverse}@media screen and (max-width: 599px){.left-div{transform:scale(.75);transform-origin:center left}.center-div{transform:scale(.5)}.right-div{transform:scale(1);transform-origin:center right}.right-div .mat-button-toggle-group.view-button{font-size:1.1rem!important}.right-div ::ng-deep .mat-button-toggle-label-content{padding:0 8px!important}}.mat-button-toggle-group.view-button{height:36px;font-size:1.25rem!important}.view-button{align-items:center}::ng-deep .mat-button-toggle-label-content{padding:0 10px!important}\n"], components: [{ type: i2.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { type: i5.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-labelledby", "tabIndex", "appearance", "checked", "disabled", "id", "name", "aria-label", "value"], outputs: ["change"], exportAs: ["matButtonToggle"] }, { type: i6.NgxMatTuiCalendarWrapperComponent, selector: "ngx-mat-tui-calendar-wrapper" }], directives: [{ type: i5.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }] });
|
14
488
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.13", ngImport: i0, type: NgxMatTuiCalendarComponent, decorators: [{
|
15
489
|
type: Component,
|
16
490
|
args: [{
|
17
491
|
selector: 'ngx-mat-tui-calendar',
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
`,
|
23
|
-
styles: []
|
492
|
+
templateUrl: './ngx-mat-tui-calendar.component.html',
|
493
|
+
styleUrls: [
|
494
|
+
'./ngx-mat-tui-calendar.component.scss'
|
495
|
+
],
|
24
496
|
}]
|
25
|
-
}], ctorParameters: function () { return []; }
|
26
|
-
|
497
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }]; }, propDecorators: { userCreatedSchedule: [{
|
498
|
+
type: Output
|
499
|
+
}], userUpdatedSchedule: [{
|
500
|
+
type: Output
|
501
|
+
}], userDeletedSchedule: [{
|
502
|
+
type: Output
|
503
|
+
}], options: [{
|
504
|
+
type: Input
|
505
|
+
}] } });
|
506
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-mat-tui-calendar.component.js","sourceRoot":"","sources":["../../../../projects/ngx-mat-tui-calendar/src/lib/ngx-mat-tui-calendar.component.ts","../../../../projects/ngx-mat-tui-calendar/src/lib/ngx-mat-tui-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, OnInit, Output, EventEmitter, Input, OnChanges, SimpleChanges, OnDestroy, ViewEncapsulation } from '@angular/core';\r\nimport { MatDialog, MatDialogConfig, MatDialogRef } from '@angular/material/dialog';\r\n\r\nimport distinctColors from 'distinct-colors';\r\nimport { Color } from \"chroma-js\";\r\nimport { v4 as uuidv4 } from 'uuid';\r\n\r\nimport {\r\n  faCalendarCheck,\r\n  faCaretSquareLeft,\r\n  faCaretSquareRight,\r\n  faTable,\r\n  faColumns,\r\n  faList,\r\n  faListAlt,\r\n  faForward,\r\n  faFastBackward,\r\n  faBackward,\r\n  faCaretLeft,\r\n  faCaretRight,\r\n} from '@fortawesome/free-solid-svg-icons';\r\nimport {\r\n  default as Calendar,\r\n  ICalendarInfo,\r\n  IEventDateObject,\r\n  IEventMoreObject,\r\n  IEventObject,\r\n  IEventScheduleObject,\r\n  IOptions,\r\n  ISchedule,\r\n  ITheme,\r\n  ITimezone,\r\n  IWeekOptions,\r\n  TEventBeforeCreateSchedule,\r\n  TZDate,\r\n} from 'tui-calendar';\r\n\r\n// project \r\nimport { LocalDate } from './local-date.js';\r\nimport { NgxMatTuiCalendarEditorDialogComponent } from './ngx-mat-tui-calendar-editor-dialog/ngx-mat-tui-calendar-editor-dialog.component';\r\nimport { CalendarOptions } from './calendar-options';\r\nimport { CalendarEditorOptions } from './calendar-editor-options';\r\n\r\n@Component({\r\n  selector: 'ngx-mat-tui-calendar',\r\n  templateUrl: './ngx-mat-tui-calendar.component.html',\r\n  styleUrls: [\r\n    './ngx-mat-tui-calendar.component.scss'\r\n  ],\r\n})\r\nexport class NgxMatTuiCalendarComponent implements OnInit, OnChanges, OnDestroy {\r\n  iconToday = faCalendarCheck;\r\n  // iconPrev = faCaretSquareLeft;\r\n  // iconNext = faCaretSquareRight;\r\n  iconPrev = faCaretLeft;\r\n  iconNext = faCaretRight;\r\n  iconLongPrev = faBackward;\r\n  iconLongNext = faForward;\r\n  iconByMonth = faTable;\r\n  iconByWeek = faColumns;\r\n  iconByDay = faListAlt;\r\n\r\n  calendar: Calendar;  // the TUI Calendar Object\r\n  calendarId: string;\r\n  colors: Color[];\r\n  colorIndex: number;\r\n  @Output() userCreatedSchedule: EventEmitter<ISchedule> = new EventEmitter();\r\n  @Output() userUpdatedSchedule: EventEmitter<ISchedule> = new EventEmitter();\r\n  @Output() userDeletedSchedule: EventEmitter<ISchedule> = new EventEmitter();\r\n  @Input() options: CalendarOptions;\r\n\r\n  constructor(private dialog: MatDialog) {\r\n    // we slice off the first color since it is gray\r\n    this.colors = distinctColors({ lightMin: 70, count: 15 }).slice(1);\r\n    this.colorIndex = 0;\r\n    this.calendarId = uuidv4();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.createTUICalendar(null);\r\n    this.bindCallbacks();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    console.warn(changes);\r\n    if (this.calendar) {\r\n\r\n      if (changes.options) {\r\n        console.warn(`change.option:`, changes.options);\r\n        let options = changes.options.currentValue;\r\n        if (!options.theme) {\r\n          options.theme = this.getDefaultTheme();\r\n        }\r\n        console.warn(`TUI theme:`, options.theme);\r\n        this.calendar.setOptions(options.ioptions as IOptions);\r\n        this.calendar.setTheme(options.theme);\r\n        this.calendar.render(true);\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.calendar.destroy();\r\n  }\r\n\r\n  onCalendarLongPrev() {\r\n    let date: Date = (this.calendar.getDate() as TZDate).toDate();\r\n    let days = 0;\r\n    let months = 0;\r\n    let years = 0;\r\n    switch (this.calendar.getViewName()) {\r\n      case 'day':\r\n        days = -7;\r\n        break;\r\n      case 'week':\r\n        days = -28;\r\n        break;\r\n      case 'month':\r\n        years = -1;\r\n        break;\r\n    }\r\n    date.setFullYear(date.getFullYear() + years);\r\n    date.setMonth(date.getMonth() + months);  // date class does the modular arithmetic\r\n    date.setDate(date.getDate() + days);  // date class does the modular arithmetic\r\n    this.calendar.setDate(date);\r\n  }\r\n\r\n  onCalendarPrev() {\r\n    this.calendar.prev();\r\n  }\r\n\r\n  onCalendarToday() {\r\n    this.calendar.today();\r\n  }\r\n\r\n  onCalendarNext() {\r\n    this.calendar.next();\r\n  }\r\n\r\n  onCalendarLongNext() {\r\n    let date: Date = (this.calendar.getDate() as TZDate).toDate();\r\n    let days = 0;\r\n    let months = 0;\r\n    let years = 0;\r\n    switch (this.calendar.getViewName()) {\r\n      case 'day':\r\n        days = 7;\r\n        break;\r\n      case 'week':\r\n        days = 28;\r\n        break;\r\n      case 'month':\r\n        years = 1;\r\n        break;\r\n    }\r\n    date.setFullYear(date.getFullYear() + years);\r\n    date.setMonth(date.getMonth() + months);  // date class does the modular arithmetic\r\n    date.setDate(date.getDate() + days);  // date class does the modular arithmetic\r\n    this.calendar.setDate(date);\r\n  }\r\n\r\n\r\n  onMonthView() {\r\n    this.calendar.changeView('month');\r\n  }\r\n\r\n  onWeekView() {\r\n    this.calendar.changeView('week');\r\n  }\r\n\r\n  onDayView() {\r\n    this.calendar.changeView('day');\r\n  }\r\n\r\n\r\n  getDate() {\r\n    let date = this.calendar.getDate();\r\n    let str = date.toDate().toLocaleDateString(\"en-US\", {\r\n      year: 'numeric',\r\n      month: 'short',\r\n    });\r\n    return str;\r\n  }\r\n\r\n  createTUICalendar(options: IOptions) {\r\n    this.calendar = new Calendar('#calendar', this.prerocessOptions(options));\r\n  }\r\n\r\n\r\n  bindCallbacks() {\r\n    this.bindAfterRenderSchedule();\r\n    this.bindClickTimezonesCollapseBtn();\r\n    this.bindClickDayname();\r\n    this.bindClickMore();\r\n    this.bindClickSchedule();\r\n    this.bindBeforeCreateSchedule();\r\n    this.bindBeforeUpdateSchedule();\r\n    this.bindBeforeDeleteSchedule();\r\n  }\r\n\r\n  bindAfterRenderSchedule() {\r\n    let that = this;\r\n    this.calendar.on('afterRenderSchedule', function (event: { schedule: ISchedule }) {\r\n      // console.warn(`afterRenderSchedule`, event);\r\n    });\r\n  }\r\n\r\n  bindClickTimezonesCollapseBtn() {\r\n    let that = this;\r\n    this.calendar.on('clickTimezonesCollapseBtn', function (timezonesCollapsed: boolean) {\r\n      // console.warn(`clickTimezonesCollapseBtn`, timezonesCollapsed);\r\n    });\r\n  }\r\n\r\n\r\n  bindClickDayname() {\r\n    let that = this;\r\n    this.calendar.on('clickDayname', function (event: IEventDateObject) {\r\n      // console.warn(`clickDayname`, event);\r\n    });\r\n  }\r\n\r\n  bindClickMore() {\r\n    let that = this;\r\n    this.calendar.on('clickMore', function (event: IEventMoreObject) {\r\n      // console.warn(`clickMore`, event);\r\n    });\r\n  }\r\n\r\n  bindClickSchedule() {\r\n    // only works if useDetailPopup: false,\r\n    let that = this;\r\n    this.calendar.on('clickSchedule', function (event: IEventScheduleObject) {\r\n      // console.warn(`clickSchedule`, event);\r\n      let schedule: ISchedule = { ...event.schedule };\r\n      schedule.start = (new LocalDate(schedule.start)).toDate();\r\n      schedule.end = (new LocalDate(schedule.end)).toDate();\r\n      that.openPopupScheduleEditor(schedule);\r\n    });\r\n  }\r\n\r\n  bindBeforeCreateSchedule() {\r\n    let that = this;\r\n    this.calendar.on('beforeCreateSchedule', function (event: TEventBeforeCreateSchedule) {\r\n      // console.log(`beforeCreateSchedule`, event);\r\n      let start: Date = (new LocalDate(event.start)).toDate();\r\n      start.setHours(9);\r\n      let end: Date = (new LocalDate(event.end)).toDate();\r\n      end.setHours(10);\r\n      that.openPopupScheduleEditor({\r\n        title: '',\r\n        start: start,\r\n        end: end,\r\n        id: null,\r\n      } as ISchedule);\r\n    });\r\n  }\r\n\r\n  bindBeforeUpdateSchedule() {\r\n    let that = this;\r\n    this.calendar.on('beforeUpdateSchedule', function (event: IEventObject) {\r\n      // console.log(`beforeUpdateSchedule`, event);\r\n      that.updateScheduleAndNotifyParent(event);\r\n    });\r\n  }\r\n\r\n  bindBeforeDeleteSchedule() {\r\n    let that = this;\r\n    this.calendar.on('beforeDeleteSchedule', function (event: IEventScheduleObject) {\r\n      // console.log(`beforeDeleteSchedule`, event.schedule);\r\n      // console.log(`beforeDeleteSchedule`, event.schedule);\r\n      that.deleteScheduleAndNotifyParent({ id: event.schedule.id, calendarId: event.schedule.calendarId });\r\n    });\r\n  }\r\n\r\n  nextColor() {\r\n    let color = this.colors[this.colorIndex++].hex();\r\n    if (this.colorIndex >= this.colors.length) this.colorIndex = 0;\r\n    return color;\r\n  }\r\n\r\n  createScheduleAndNotifyParent(args: ISchedule) {\r\n    let schedule = this.createSchedule(args);\r\n    this.userCreatedSchedule.emit(schedule);\r\n    return schedule;\r\n  }\r\n\r\n  createSchedules(schedules: ISchedule[]) {\r\n    let newSchedules = [];\r\n    for (let schedule of schedules) {\r\n      newSchedules.push(this.createSchedule(schedule));\r\n    }\r\n    return newSchedules;\r\n  }\r\n\r\n  createSchedule(args: ISchedule): ISchedule {\r\n    // if (form.invalid) return;\r\n\r\n    // create a color\r\n    let color = this.nextColor();\r\n    // console.log(color);\r\n\r\n    // create an id\r\n    let id = (args.id == null) ? '' : args.id.toString();\r\n    if (id.length === 0) {\r\n      id = uuidv4();\r\n    }\r\n\r\n    let start: Date = LocalDate.convertToJsDate(args.start);\r\n    let end: Date = LocalDate.convertToJsDate(args.end);\r\n\r\n    let schedule: ISchedule = {\r\n      id,\r\n      calendarId: (args.calendarId == null) ? this.calendarId : args.calendarId,\r\n      title: args.title,\r\n      start: start,\r\n      end: end,\r\n      category: args.category,\r\n      isAllDay: args.isAllDay,\r\n      dueDateClass: '',\r\n      bgColor: color,\r\n    } as ISchedule\r\n    // console.log(`event-calendar.component.ts: createEvent:`, schedule);\r\n    this.calendar.createSchedules([schedule]);\r\n    return this.calendar.getSchedule(schedule.id, schedule.calendarId);\r\n  }\r\n\r\n  updateScheduleAndNotifyParent(args: ISchedule) {\r\n    let schedule = this.updateSchedule(args);\r\n    this.userUpdatedSchedule.emit(schedule);\r\n    return schedule;\r\n  }\r\n\r\n  updateSchedule(schedule: ISchedule) {\r\n    // console.log(`event-calendar.component.ts: updateSchedule:`, schedule);\r\n    let calendarId = (schedule.calendarId == null) ? this.calendarId : schedule.calendarId;\r\n    this.calendar.updateSchedule(schedule.id, calendarId, schedule, false);\r\n    return this.calendar.getSchedule(schedule.id, calendarId);\r\n  }\r\n\r\n  getSchedule(args: { id: string, calendarId: string }) {\r\n    // console.log(`event-calendar.component.ts: getSchedule:`, schedule);\r\n    let calendarId = (args.calendarId == null) ? this.calendarId : args.calendarId;\r\n    return this.calendar.getSchedule(args.id, calendarId);\r\n  }\r\n\r\n  deleteScheduleAndNotifyParent(args: { id: string, calendarId: string }) {\r\n    this.deleteSchedule(args);\r\n    let calendarId = (args.calendarId == null) ? this.calendarId : args.calendarId;\r\n    this.userDeletedSchedule.emit({ id: args.id, calendarId });\r\n  }\r\n\r\n  deleteSchedule(args: { id: string, calendarId: string }) {\r\n    // console.log(`event-calendar.component.ts: deleteSchedule:`, schedule);\r\n    let calendarId = (args.calendarId == null) ? this.calendarId : args.calendarId;\r\n    this.calendar.deleteSchedule(args.id, calendarId, false);\r\n  }\r\n\r\n  deleteAllSchedules() {\r\n    this.calendar.clear();\r\n  }\r\n\r\n  openPopupScheduleEditor(schedule: ISchedule) {\r\n    // console.log('openPopupScheduleEditor: calevent:', schedule);\r\n    const dialogConfig = new MatDialogConfig();\r\n    dialogConfig.panelClass = this.options.themeClass;\r\n    console.warn(`options: `, this.options);\r\n    dialogConfig.data = { schedule, darkMode: this.options.darkMode, themeClass: this.options.themeClass } as CalendarEditorOptions;\r\n    dialogConfig.autoFocus = true;\r\n    const dialogRef = this.dialog.open(NgxMatTuiCalendarEditorDialogComponent, dialogConfig);\r\n    // const dialogRef = this.dialog.open(NgxMatTuiCalendarScheduleEditorDialogComponent, {\r\n    //   data: schedule,\r\n    // });\r\n    dialogRef.afterClosed().subscribe((result: { schedule: ISchedule, performDelete: boolean }) => {\r\n      // console.log('openPopupScheduleEditor: The dialog was closed', result);\r\n      this.calendar.render(true);  // <-- so that selection is cleared\r\n      if (result && result.schedule) {\r\n        let schedule = result.schedule;\r\n        if (result.performDelete == true) {\r\n          // delete\r\n          // console.log(`openPopupScheduleEditor:afterCLosed: deleteSchedule`);\r\n          this.deleteScheduleAndNotifyParent({ id: schedule.id, calendarId: schedule.calendarId });\r\n        } else if (schedule.id == null) {\r\n          // console.log(`openPopupScheduleEditor:afterCLosed: addSchedule`);\r\n          this.createScheduleAndNotifyParent(schedule);\r\n        } else {\r\n          // console.log(`openPopupScheduleEditor:afterCLosed: updateSchedule`);\r\n          this.updateScheduleAndNotifyParent(schedule);\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  setOptions(options: IOptions) {\r\n    this.calendar.setOptions(this.prerocessOptions(options));\r\n  }\r\n\r\n  prerocessOptions(options: IOptions): IOptions {\r\n    let defs = this.getDefaultOptions();\r\n    if (options == null) {\r\n      options = defs;\r\n    } else {\r\n      options = { ...defs, ...options };\r\n    }\r\n    options.useCreationPopup = false;\r\n    options.useDetailPopup = false;\r\n    return options;\r\n  }\r\n\r\n\r\n  getDefaultOptions(): IOptions {\r\n    return {\r\n      defaultView: 'month',\r\n      taskView: true,\r\n      useCreationPopup: false,\r\n      useDetailPopup: false,\r\n      theme: this.getDefaultTheme(),\r\n      template: {\r\n        monthDayname: function (dayname) {\r\n          return '<span class=\"calendar-week-dayname-name\">' + dayname.label + '</span>';\r\n        }\r\n      },\r\n      week: {\r\n        // startDayOfWeek: undefined,\r\n        // daynames: undefined,\r\n        narrowWeekend: false,\r\n        // workweek: true,\r\n        showTimezoneCollapseButton: true,\r\n        timezonesCollapsed: true,\r\n        hourStart: 7,\r\n        hourEnd: 20,\r\n      } as IWeekOptions,\r\n    } as IOptions;\r\n\r\n  }\r\n\r\n  getColor(name: string): string {\r\n    const el = document.getElementById(`theme-${name}`);\r\n    if (el) {\r\n      const style = window.getComputedStyle(el, null);\r\n      console.warn(`color:`, style.color);\r\n      return style.color;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getDefaultTheme(): ITheme {\r\n    function adjustHexOpacity(color, opacity) {\r\n      const r = parseInt(color.slice(1, 3), 16);\r\n      const g = parseInt(color.slice(3, 5), 16);\r\n      const b = parseInt(color.slice(5, 7), 16);\r\n\r\n      return 'rgba(' + r + ', ' + g + ', ' + b + ', ' + opacity + ')';\r\n    }\r\n\r\n    // default keys and styles\r\n    // TODO: apply Material Design Theme \r\n    let background = this.getColor(\"background\");\r\n    let border = this.getColor(\"divider\");\r\n    let borderLight = this.getColor(\"divider-light\");\r\n    let shadow = this.getColor(\"divider\");\r\n    let highlight = this.getColor(\"highlight\");\r\n    let primary = this.getColor(\"primary\");\r\n    let warn = this.getColor(\"warn\");\r\n    let text = this.getColor(\"foreground\");\r\n    let primaryShaded = this.getColor(\"primary-shaded\");\r\n\r\n    // tui-full-calendar-weekday-schedule-title\r\n    //calendar-week-dayname-name\r\n    return {\r\n      'common.border': `1px solid ${border}`,\r\n      'common.backgroundColor': background,\r\n      'common.holiday.color': warn,\r\n      'common.saturday.color': text,\r\n      'common.dayname.color': text,\r\n      'common.today.color': '#0f0',\r\n\r\n      // creation guide style\r\n      'common.creationGuide.backgroundColor': primaryShaded,\r\n      'common.creationGuide.border': `1px solid ${highlight}`,\r\n\r\n      // month header 'dayname'\r\n      'month.dayname.height': '31px',\r\n      'month.dayname.borderLeft': `1px solid ${border}`,\r\n      'month.dayname.paddingLeft': '10px',\r\n      'month.dayname.paddingRight': '10px',\r\n      'month.dayname.backgroundColor': 'inherit',\r\n      'month.dayname.fontSize': '12px',\r\n      'month.dayname.fontWeight': 'normal',\r\n      'month.dayname.textAlign': 'left',\r\n\r\n      // month day grid cell 'day'\r\n      'month.holidayExceptThisMonth.color': 'rgba(255, 64, 64, 0.4)',\r\n      'month.dayExceptThisMonth.color': 'rgba(51, 51, 51, 0.4)',\r\n      'month.weekend.backgroundColor': 'inherit',\r\n      'month.day.fontSize': '14px',\r\n      'month.schedule.color': highlight,\r\n\r\n      // month schedule style\r\n      'month.schedule.borderRadius': '2px',\r\n      'month.schedule.height': '24px',\r\n      'month.schedule.marginTop': '2px',\r\n      'month.schedule.marginLeft': '8px',\r\n      'month.schedule.marginRight': '8px',\r\n\r\n      // month more view\r\n      'month.moreView.border': `1px solid ${border}`,\r\n      'month.moreView.boxShadow': `0 2px 6px 0 ${shadow}`,\r\n      'month.moreView.backgroundColor': background,\r\n      'month.moreView.paddingBottom': '17px',\r\n      'month.moreViewTitle.height': '44px',\r\n      'month.moreViewTitle.marginBottom': '12px',\r\n      'month.moreViewTitle.backgroundColor': 'inherit',\r\n      'month.moreViewTitle.borderBottom': 'none',\r\n      'month.moreViewTitle.padding': '12px 17px 0 17px',\r\n      'month.moreViewList.padding': '0 17px',\r\n\r\n      // week header 'dayname'\r\n      'week.dayname.height': '42px',\r\n      'week.dayname.borderTop': `1px solid ${border}`,\r\n      'week.dayname.borderBottom': `1px solid ${border}`,\r\n      'week.dayname.borderLeft': 'inherit',\r\n      'week.dayname.paddingLeft': '0',\r\n      'week.dayname.backgroundColor': 'inherit',\r\n      'week.dayname.textAlign': 'left',\r\n      'week.today.color': text,\r\n      'week.pastDay.color': borderLight,\r\n\r\n      // week vertical panel 'vpanel'\r\n      'week.vpanelSplitter.border': `1px solid ${border}`,\r\n      'week.vpanelSplitter.height': '3px',\r\n\r\n      // week daygrid 'daygrid'\r\n      'week.daygrid.borderRight': `1px solid ${border}`,\r\n      'week.daygrid.backgroundColor': background,\r\n\r\n      'week.daygridLeft.width': '72px',\r\n      'week.daygridLeft.backgroundColor': background,\r\n      'week.daygridLeft.paddingRight': '8px',\r\n      'week.daygridLeft.borderRight': `1px solid ${border}`,\r\n\r\n\r\n      'week.today.backgroundColor': primaryShaded,\r\n      'week.weekend.backgroundColor': 'inherit',\r\n\r\n      // week timegrid 'timegrid'\r\n      'week.timegridLeft.width': '72px',\r\n      'week.timegridLeft.backgroundColor': 'inherit',\r\n      'week.timegridLeft.borderRight': `1px solid ${border}`,\r\n      'week.timegridLeft.fontSize': '11px',\r\n      'week.timegridLeftTimezoneLabel.height': '40px',\r\n      'week.timegridLeftAdditionalTimezone.backgroundColor': background,\r\n\r\n      'week.timegridOneHour.height': '52px',\r\n      'week.timegridHalfHour.height': '26px',\r\n      'week.timegridHalfHour.borderBottom': 'none',\r\n      'week.timegridHorizontalLine.borderBottom': `1px solid ${border}`,\r\n\r\n      'week.timegrid.paddingRight': '8px',\r\n      'week.timegrid.borderRight': `1px solid ${border}`,\r\n      'week.timegridSchedule.borderRadius': '2px',\r\n      'week.timegridSchedule.paddingLeft': '2px',\r\n\r\n      // #515ce6 is a slate blue\r\n\r\n      'week.currentTime.color': highlight,\r\n      'week.currentTime.fontSize': '11px',\r\n      'week.currentTime.fontWeight': 'normal',\r\n\r\n      'week.pastTime.color': borderLight,\r\n      'week.pastTime.fontWeight': 'normal',\r\n\r\n      'week.futureTime.color': border,\r\n      'week.futureTime.fontWeight': 'normal',\r\n\r\n      'week.currentTimeLinePast.border': `1px dashed ${highlight}`,\r\n      'week.currentTimeLineBullet.backgroundColor': highlight,\r\n      'week.currentTimeLineToday.border': `1px solid ${highlight}`,\r\n      'week.currentTimeLineFuture.border': 'none',\r\n\r\n      // week creation guide style\r\n      'week.creationGuide.color': highlight,\r\n      'week.creationGuide.fontSize': '11px',\r\n      'week.creationGuide.fontWeight': 'bold',\r\n\r\n      // week daygrid schedule style\r\n      'week.dayGridSchedule.borderRadius': '2px',\r\n      'week.dayGridSchedule.height': '24px',\r\n      'week.dayGridSchedule.marginTop': '2px',\r\n      'week.dayGridSchedule.marginLeft': '8px',\r\n      'week.dayGridSchedule.marginRight': '8px'\r\n    } as ITheme;\r\n  }\r\n\r\n}\r\n","<p>\r\n    ngx-mat-tui-calendar v0.0.15 works!!!\r\n</p>\r\n<section class=\"content-container\">\r\n    <!-- These divs are here so that we can read the theme colors for the tui theme -->\r\n    <div id=\"theme-primary\"></div>\r\n    <div id=\"theme-primary-shaded\"></div>\r\n    <div id=\"theme-highlight\"></div>\r\n    <div id=\"theme-accent\"></div>\r\n    <div id=\"theme-warn\"></div>\r\n    <div id=\"theme-foreground\"></div>\r\n    <div id=\"theme-divider\"></div>\r\n    <div id=\"theme-background\"></div>\r\n  \r\n    <div class=\"calendar-container\">\r\n      <!-- calendar titlebar -->\r\n      <mat-toolbar class=\"menu-bar\" color=\"primary\">\r\n        <!-- <div style=\"align-self: center;display: flex;\r\n    align-items: center;\r\n    justify-content: flex-start;\"> -->\r\n        <div style=\"display: flex;\r\n      flex-direction: row;\r\n      justify-content: space-between;\r\n    width: 100%;  \">\r\n          <div class=\"left-div\">\r\n            <!-- LEFT -->\r\n            <button mat-button \r\n              class=\"navigation-button\"\r\n              style=\"margin-left: 0px; margin-right: 0px; font-size: 1.5rem !important;\" \r\n              (click)=\"onCalendarLongPrev()\">\r\n              <fa-icon [icon]=\"iconLongPrev\"></fa-icon>\r\n            </button>\r\n            <button mat-button \r\n              class=\"navigation-button\" \r\n              style=\"margin-left: 0px; margin-right: 0px; font-size: 2rem !important;\" \r\n              (click)=\"onCalendarPrev()\">\r\n              <fa-icon [icon]=\"iconPrev\"></fa-icon>\r\n            </button>\r\n            <button mat-button \r\n              class=\"navigation-button\"\r\n              style=\"margin-left: 0px; margin-right: 0px; font-size: 1.7rem !important;\" \r\n              (click)=\"onCalendarToday()\">\r\n              <fa-icon [icon]=\"iconToday\"></fa-icon>\r\n            </button>\r\n            <button mat-button \r\n              class=\"navigation-button\" \r\n              style=\"margin-left: 0px; margin-right: 0px; font-size: 2rem !important;\" \r\n              (click)=\"onCalendarNext()\">\r\n              <fa-icon [icon]=\"iconNext\"></fa-icon>\r\n            </button>\r\n            <button mat-button \r\n              class=\"navigation-button\"\r\n              style=\"margin-left: 0px; margin-right: 0px; font-size: 1.5rem !important;\" \r\n              (click)=\"onCalendarLongNext()\">\r\n              <fa-icon [icon]=\"iconLongNext\"></fa-icon>\r\n            </button>\r\n          </div>\r\n          <div class=\"center-div\">\r\n            <!-- CENTER -->\r\n            <span class=\"event-calendar-title\">{{ getDate() }}</span>\r\n          </div>\r\n          <div class=\"right-div\">\r\n  \r\n            <!-- RIGHT -->\r\n            <mat-button-toggle-group class=\"view-button\" value=\"month\" id=\"@+id/toggleButton\" layout_width=\"wrap_content\"\r\n              layout_height=\"wrap_content\">\r\n              <mat-button-toggle mat-button value=\"month\" class=\"view-button\" (click)=\"onMonthView()\">\r\n                <fa-icon [icon]=\"iconByMonth\"></fa-icon>\r\n              </mat-button-toggle>\r\n              <mat-button-toggle mat-button value=\"week\" class=\"view-button\" (click)=\"onWeekView()\">\r\n                <fa-icon [icon]=\"iconByWeek\"></fa-icon>\r\n              </mat-button-toggle>\r\n              <mat-button-toggle mat-button value=\"day\" class=\"view-button\" (click)=\"onDayView()\">\r\n                <fa-icon [icon]=\"iconByDay\"></fa-icon>\r\n              </mat-button-toggle>\r\n            </mat-button-toggle-group>\r\n          </div>\r\n        </div>\r\n      </mat-toolbar>\r\n      <ngx-mat-tui-calendar-wrapper></ngx-mat-tui-calendar-wrapper>\r\n    </div>\r\n  \r\n  </section>"]}
|