@netwin/angular-datetime-picker 1.0.0-rc.3

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 (79) hide show
  1. package/README.md +225 -0
  2. package/assets/style/picker.min.css +1 -0
  3. package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +120 -0
  4. package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +7 -0
  5. package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +253 -0
  6. package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +16 -0
  7. package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +45 -0
  8. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +228 -0
  9. package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +16 -0
  10. package/esm2022/lib/date-time/calendar-body.component.mjs +146 -0
  11. package/esm2022/lib/date-time/calendar-month-view.component.mjs +436 -0
  12. package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +366 -0
  13. package/esm2022/lib/date-time/calendar-year-view.component.mjs +362 -0
  14. package/esm2022/lib/date-time/calendar.component.mjs +368 -0
  15. package/esm2022/lib/date-time/date-time-inline.component.mjs +293 -0
  16. package/esm2022/lib/date-time/date-time-picker-container.component.mjs +405 -0
  17. package/esm2022/lib/date-time/date-time-picker-input.directive.mjs +598 -0
  18. package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +62 -0
  19. package/esm2022/lib/date-time/date-time-picker-trigger.directive.mjs +64 -0
  20. package/esm2022/lib/date-time/date-time-picker.animations.mjs +21 -0
  21. package/esm2022/lib/date-time/date-time-picker.component.mjs +564 -0
  22. package/esm2022/lib/date-time/date-time.class.mjs +176 -0
  23. package/esm2022/lib/date-time/date-time.module.mjs +83 -0
  24. package/esm2022/lib/date-time/numberedFixLen.pipe.mjs +28 -0
  25. package/esm2022/lib/date-time/options-provider.mjs +34 -0
  26. package/esm2022/lib/date-time/timer-box.component.mjs +140 -0
  27. package/esm2022/lib/date-time/timer.component.mjs +279 -0
  28. package/esm2022/lib/dialog/dialog-config.class.mjs +59 -0
  29. package/esm2022/lib/dialog/dialog-container.component.mjs +232 -0
  30. package/esm2022/lib/dialog/dialog-ref.class.mjs +134 -0
  31. package/esm2022/lib/dialog/dialog.module.mjs +26 -0
  32. package/esm2022/lib/dialog/dialog.service.mjs +228 -0
  33. package/esm2022/lib/utils/array.utils.mjs +12 -0
  34. package/esm2022/lib/utils/constants.mjs +34 -0
  35. package/esm2022/lib/utils/date.utils.mjs +49 -0
  36. package/esm2022/lib/utils/index.mjs +5 -0
  37. package/esm2022/lib/utils/object.utils.mjs +26 -0
  38. package/esm2022/netwin-angular-datetime-picker.mjs +5 -0
  39. package/esm2022/public_api.mjs +25 -0
  40. package/fesm2022/netwin-angular-datetime-picker.mjs +5751 -0
  41. package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -0
  42. package/index.d.ts +5 -0
  43. package/lib/date-time/adapter/date-time-adapter.class.d.ts +193 -0
  44. package/lib/date-time/adapter/date-time-format.class.d.ts +15 -0
  45. package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +72 -0
  46. package/lib/date-time/adapter/native-date-time-format.class.d.ts +5 -0
  47. package/lib/date-time/adapter/native-date-time.module.d.ts +12 -0
  48. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +67 -0
  49. package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +5 -0
  50. package/lib/date-time/calendar-body.component.d.ts +79 -0
  51. package/lib/date-time/calendar-month-view.component.d.ts +141 -0
  52. package/lib/date-time/calendar-multi-year-view.component.d.ts +107 -0
  53. package/lib/date-time/calendar-year-view.component.d.ts +120 -0
  54. package/lib/date-time/calendar.component.d.ts +154 -0
  55. package/lib/date-time/date-time-inline.component.d.ts +102 -0
  56. package/lib/date-time/date-time-picker-container.component.d.ts +130 -0
  57. package/lib/date-time/date-time-picker-input.directive.d.ts +164 -0
  58. package/lib/date-time/date-time-picker-intl.service.d.ts +51 -0
  59. package/lib/date-time/date-time-picker-trigger.directive.d.ts +23 -0
  60. package/lib/date-time/date-time-picker.animations.d.ts +8 -0
  61. package/lib/date-time/date-time-picker.component.d.ts +173 -0
  62. package/lib/date-time/date-time.class.d.ts +103 -0
  63. package/lib/date-time/date-time.module.d.ts +23 -0
  64. package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
  65. package/lib/date-time/options-provider.d.ts +23 -0
  66. package/lib/date-time/timer-box.component.d.ts +42 -0
  67. package/lib/date-time/timer.component.d.ts +131 -0
  68. package/lib/dialog/dialog-config.class.d.ts +169 -0
  69. package/lib/dialog/dialog-container.component.d.ts +58 -0
  70. package/lib/dialog/dialog-ref.class.d.ts +51 -0
  71. package/lib/dialog/dialog.module.d.ts +11 -0
  72. package/lib/dialog/dialog.service.d.ts +76 -0
  73. package/lib/utils/array.utils.d.ts +5 -0
  74. package/lib/utils/constants.d.ts +19 -0
  75. package/lib/utils/date.utils.d.ts +12 -0
  76. package/lib/utils/index.d.ts +4 -0
  77. package/lib/utils/object.utils.d.ts +11 -0
  78. package/package.json +51 -0
  79. package/public_api.d.ts +24 -0
@@ -0,0 +1,368 @@
1
+ /**
2
+ * calendar.component
3
+ */
4
+ import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';
5
+ import { Subscription } from 'rxjs';
6
+ import { take } from 'rxjs/operators';
7
+ import { OWL_DATE_TIME_FORMATS } from './adapter/date-time-format.class';
8
+ import { DateView } from './date-time.class';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "./date-time-picker-intl.service";
11
+ import * as i2 from "./adapter/date-time-adapter.class";
12
+ import * as i3 from "@angular/common";
13
+ import * as i4 from "@angular/cdk/a11y";
14
+ import * as i5 from "./calendar-multi-year-view.component";
15
+ import * as i6 from "./calendar-year-view.component";
16
+ import * as i7 from "./calendar-month-view.component";
17
+ export class OwlCalendarComponent {
18
+ get minDate() {
19
+ return this._minDate;
20
+ }
21
+ set minDate(value) {
22
+ value = this.dateTimeAdapter.deserialize(value);
23
+ value = this.getValidDate(value);
24
+ this._minDate =
25
+ value ?
26
+ this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(value), this.dateTimeAdapter.getMonth(value), this.dateTimeAdapter.getDate(value))
27
+ : null;
28
+ }
29
+ get maxDate() {
30
+ return this._maxDate;
31
+ }
32
+ set maxDate(value) {
33
+ value = this.dateTimeAdapter.deserialize(value);
34
+ value = this.getValidDate(value);
35
+ this._maxDate =
36
+ value ?
37
+ this.dateTimeAdapter.createDate(this.dateTimeAdapter.getYear(value), this.dateTimeAdapter.getMonth(value), this.dateTimeAdapter.getDate(value))
38
+ : null;
39
+ }
40
+ get pickerMoment() {
41
+ return this._pickerMoment;
42
+ }
43
+ set pickerMoment(value) {
44
+ value = this.dateTimeAdapter.deserialize(value);
45
+ this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();
46
+ }
47
+ get selected() {
48
+ return this._selected;
49
+ }
50
+ set selected(value) {
51
+ value = this.dateTimeAdapter.deserialize(value);
52
+ this._selected = this.getValidDate(value);
53
+ }
54
+ get selecteds() {
55
+ return this._selecteds;
56
+ }
57
+ set selecteds(values) {
58
+ this._selecteds = values.map((v) => {
59
+ v = this.dateTimeAdapter.deserialize(v);
60
+ return this.getValidDate(v);
61
+ });
62
+ }
63
+ get periodButtonText() {
64
+ return this.isMonthView ?
65
+ this.dateTimeAdapter.format(this.pickerMoment, this.dateTimeFormats.monthYearLabel)
66
+ : this.dateTimeAdapter.getYearName(this.pickerMoment);
67
+ }
68
+ get periodButtonLabel() {
69
+ return this.isMonthView ? this.pickerIntl.switchToMultiYearViewLabel : this.pickerIntl.switchToMonthViewLabel;
70
+ }
71
+ get prevButtonLabel() {
72
+ if (this._currentView === DateView.MONTH) {
73
+ return this.pickerIntl.prevMonthLabel;
74
+ }
75
+ else if (this._currentView === DateView.YEAR) {
76
+ return this.pickerIntl.prevYearLabel;
77
+ }
78
+ else {
79
+ return null;
80
+ }
81
+ }
82
+ get nextButtonLabel() {
83
+ if (this._currentView === DateView.MONTH) {
84
+ return this.pickerIntl.nextMonthLabel;
85
+ }
86
+ else if (this._currentView === DateView.YEAR) {
87
+ return this.pickerIntl.nextYearLabel;
88
+ }
89
+ else {
90
+ return null;
91
+ }
92
+ }
93
+ get currentView() {
94
+ return this._currentView;
95
+ }
96
+ set currentView(view) {
97
+ this._currentView = view;
98
+ this.moveFocusOnNextTick = true;
99
+ }
100
+ get isInSingleMode() {
101
+ return this.selectMode === 'single';
102
+ }
103
+ get isInRangeMode() {
104
+ return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';
105
+ }
106
+ get showControlArrows() {
107
+ return this._currentView !== DateView.MULTI_YEARS;
108
+ }
109
+ get isMonthView() {
110
+ return this._currentView === DateView.MONTH;
111
+ }
112
+ /**
113
+ * Bind class 'owl-dt-calendar' to host
114
+ * */
115
+ get owlDTCalendarClass() {
116
+ return true;
117
+ }
118
+ constructor(elmRef, pickerIntl, ngZone, cdRef, dateTimeAdapter, dateTimeFormats) {
119
+ this.elmRef = elmRef;
120
+ this.pickerIntl = pickerIntl;
121
+ this.ngZone = ngZone;
122
+ this.cdRef = cdRef;
123
+ this.dateTimeAdapter = dateTimeAdapter;
124
+ this.dateTimeFormats = dateTimeFormats;
125
+ this.DateView = DateView;
126
+ this._selecteds = [];
127
+ /**
128
+ * The view that the calendar should start in.
129
+ */
130
+ this.startView = DateView.MONTH;
131
+ /**
132
+ * Whether to should only the year and multi-year views.
133
+ */
134
+ this.yearOnly = false;
135
+ /**
136
+ * Whether to should only the multi-year view.
137
+ */
138
+ this.multiyearOnly = false;
139
+ /** Emits when the currently picker moment changes. */
140
+ this.pickerMomentChange = new EventEmitter();
141
+ /** Emits when the selected date changes. */
142
+ this.dateClicked = new EventEmitter();
143
+ /** Emits when the currently selected date changes. */
144
+ this.selectedChange = new EventEmitter();
145
+ /** Emits when any date is selected. */
146
+ this.userSelection = new EventEmitter();
147
+ /**
148
+ * Emits the selected year. This doesn't imply a change on the selected date
149
+ * */
150
+ this.yearSelected = new EventEmitter();
151
+ /**
152
+ * Emits the selected month. This doesn't imply a change on the selected date
153
+ * */
154
+ this.monthSelected = new EventEmitter();
155
+ this.intlChangesSub = Subscription.EMPTY;
156
+ /**
157
+ * Used for scheduling that focus should be moved to the active cell on the next tick.
158
+ * We need to schedule it, rather than do it immediately, because we have to wait
159
+ * for Angular to re-evaluate the view children.
160
+ */
161
+ this.moveFocusOnNextTick = false;
162
+ /**
163
+ * Date filter for the month and year view
164
+ */
165
+ this.dateFilterForViews = (date) => {
166
+ return (!!date &&
167
+ (!this.dateFilter || this.dateFilter(date)) &&
168
+ (!this.minDate || this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&
169
+ (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0));
170
+ };
171
+ this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {
172
+ this.cdRef.markForCheck();
173
+ });
174
+ }
175
+ ngAfterContentInit() {
176
+ this._currentView = this.startView;
177
+ }
178
+ ngAfterViewChecked() {
179
+ if (this.moveFocusOnNextTick) {
180
+ this.moveFocusOnNextTick = false;
181
+ this.focusActiveCell();
182
+ }
183
+ }
184
+ ngOnDestroy() {
185
+ this.intlChangesSub.unsubscribe();
186
+ }
187
+ /**
188
+ * Toggle between month view and year view
189
+ */
190
+ toggleViews() {
191
+ let nextView = null;
192
+ if (this._currentView === DateView.MONTH) {
193
+ nextView = DateView.MULTI_YEARS;
194
+ }
195
+ else {
196
+ if (this.multiyearOnly) {
197
+ nextView = DateView.MULTI_YEARS;
198
+ }
199
+ else if (this.yearOnly) {
200
+ nextView = this._currentView === DateView.YEAR ? DateView.MULTI_YEARS : DateView.YEAR;
201
+ }
202
+ else {
203
+ nextView = DateView.MONTH;
204
+ }
205
+ }
206
+ this.currentView = nextView;
207
+ }
208
+ /**
209
+ * Handles user clicks on the previous button.
210
+ * */
211
+ previousClicked() {
212
+ this.pickerMoment =
213
+ this.isMonthView ?
214
+ this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1)
215
+ : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, -1);
216
+ this.pickerMomentChange.emit(this.pickerMoment);
217
+ }
218
+ /**
219
+ * Handles user clicks on the next button.
220
+ * */
221
+ nextClicked() {
222
+ this.pickerMoment =
223
+ this.isMonthView ?
224
+ this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1)
225
+ : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, 1);
226
+ this.pickerMomentChange.emit(this.pickerMoment);
227
+ }
228
+ dateSelected(date) {
229
+ if (!this.dateFilterForViews(date)) {
230
+ return;
231
+ }
232
+ this.dateClicked.emit(date);
233
+ this.selectedChange.emit(date);
234
+ /*if ((this.isInSingleMode && !this.dateTimeAdapter.isSameDay(date, this.selected)) ||
235
+ this.isInRangeMode) {
236
+ this.selectedChange.emit(date);
237
+ }*/
238
+ }
239
+ /**
240
+ * Change the pickerMoment value and switch to a specific view
241
+ */
242
+ goToDateInView(date, view) {
243
+ this.handlePickerMomentChange(date);
244
+ if ((!this.yearOnly && !this.multiyearOnly) ||
245
+ (this.multiyearOnly && view !== DateView.MONTH && view !== DateView.YEAR) ||
246
+ (this.yearOnly && view !== DateView.MONTH)) {
247
+ this.currentView = view;
248
+ }
249
+ return;
250
+ }
251
+ /**
252
+ * Change the pickerMoment value
253
+ */
254
+ handlePickerMomentChange(date) {
255
+ this.pickerMoment = this.dateTimeAdapter.clampDate(date, this.minDate, this.maxDate);
256
+ this.pickerMomentChange.emit(this.pickerMoment);
257
+ return;
258
+ }
259
+ userSelected() {
260
+ this.userSelection.emit();
261
+ }
262
+ /**
263
+ * Whether the previous period button is enabled.
264
+ */
265
+ prevButtonEnabled() {
266
+ return !this.minDate || !this.isSameView(this.pickerMoment, this.minDate);
267
+ }
268
+ /**
269
+ * Whether the next period button is enabled.
270
+ */
271
+ nextButtonEnabled() {
272
+ return !this.maxDate || !this.isSameView(this.pickerMoment, this.maxDate);
273
+ }
274
+ /**
275
+ * Focus to the host element
276
+ * */
277
+ focusActiveCell() {
278
+ this.ngZone.runOutsideAngular(() => {
279
+ this.ngZone.onStable
280
+ .asObservable()
281
+ .pipe(take(1))
282
+ .subscribe(() => {
283
+ this.elmRef.nativeElement.querySelector('.owl-dt-calendar-cell-active').focus();
284
+ });
285
+ });
286
+ }
287
+ selectYearInMultiYearView(normalizedYear) {
288
+ this.yearSelected.emit(normalizedYear);
289
+ }
290
+ selectMonthInYearView(normalizedMonth) {
291
+ this.monthSelected.emit(normalizedMonth);
292
+ }
293
+ /**
294
+ * Whether the two dates represent the same view in the current view mode (month or year).
295
+ */
296
+ isSameView(date1, date2) {
297
+ if (this._currentView === DateView.MONTH) {
298
+ return !!(date1 &&
299
+ date2 &&
300
+ this.dateTimeAdapter.getYear(date1) === this.dateTimeAdapter.getYear(date2) &&
301
+ this.dateTimeAdapter.getMonth(date1) === this.dateTimeAdapter.getMonth(date2));
302
+ }
303
+ else if (this._currentView === DateView.YEAR) {
304
+ return !!(date1 && date2 && this.dateTimeAdapter.getYear(date1) === this.dateTimeAdapter.getYear(date2));
305
+ }
306
+ else {
307
+ return false;
308
+ }
309
+ }
310
+ /**
311
+ * Get a valid date object
312
+ */
313
+ getValidDate(obj) {
314
+ return this.dateTimeAdapter.isDateInstance(obj) && this.dateTimeAdapter.isValid(obj) ? obj : null;
315
+ }
316
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlCalendarComponent, deps: [{ token: i0.ElementRef }, { token: i1.OwlDateTimeIntl }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: i2.DateTimeAdapter, optional: true }, { token: OWL_DATE_TIME_FORMATS, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
317
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: OwlCalendarComponent, selector: "owl-date-time-calendar", inputs: { minDate: "minDate", maxDate: "maxDate", pickerMoment: "pickerMoment", selected: "selected", selecteds: "selecteds", dateFilter: "dateFilter", firstDayOfWeek: "firstDayOfWeek", selectMode: "selectMode", startView: "startView", yearOnly: "yearOnly", multiyearOnly: "multiyearOnly", hideOtherMonths: "hideOtherMonths" }, outputs: { pickerMomentChange: "pickerMomentChange", dateClicked: "dateClicked", selectedChange: "selectedChange", userSelection: "userSelection", yearSelected: "yearSelected", monthSelected: "monthSelected" }, host: { properties: { "class.owl-dt-calendar": "owlDTCalendarClass" } }, exportAs: ["owlDateTimeCalendar"], ngImport: i0, template: "<div class=\"owl-dt-calendar-control\">\n <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n <button\n [attr.aria-label]=\"prevButtonLabel\"\n [disabled]=\"!prevButtonEnabled()\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n (click)=\"previousClicked()\"\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"100%\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n version=\"1.1\"\n viewBox=\"0 0 250.738 250.738\"\n width=\"100%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546 c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681 l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n style=\"fill-rule: evenodd; clip-rule: evenodd\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n <div class=\"owl-dt-calendar-control-content\">\n <button\n [attr.aria-label]=\"periodButtonLabel\"\n (click)=\"toggleViews()\"\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\">\n {{ periodButtonText }}\n\n <span\n [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n class=\"owl-dt-control-button-arrow\">\n <!-- <editor-fold desc=\"SVG Arrow\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"50%\"\n style=\"enable-background: new 0 0 292.362 292.362\"\n version=\"1.1\"\n viewBox=\"0 0 292.362 292.362\"\n width=\"50%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <g>\n <path\n d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\" />\n </g>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </span>\n </button>\n </div>\n <button\n [attr.aria-label]=\"nextButtonLabel\"\n [disabled]=\"!nextButtonEnabled()\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n (click)=\"nextClicked()\"\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n version=\"1.1\"\n viewBox=\"0 0 250.738 250.738\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n C197.237,120.447,195.534,115.448,191.75,111.689z\"\n style=\"fill-rule: evenodd; clip-rule: evenodd\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n</div>\n<div\n [ngSwitch]=\"currentView\"\n cdkMonitorSubtreeFocus\n class=\"owl-dt-calendar-main\"\n tabindex=\"-1\">\n <owl-date-time-month-view\n *ngSwitchCase=\"DateView.MONTH\"\n [dateFilter]=\"dateFilter\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [hideOtherMonths]=\"hideOtherMonths\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [pickerMoment]=\"pickerMoment\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (selectedChange)=\"dateSelected($event)\"\n (userSelection)=\"userSelected()\"></owl-date-time-month-view>\n\n <owl-date-time-year-view\n *ngSwitchCase=\"DateView.YEAR\"\n [dateFilter]=\"dateFilter\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [pickerMoment]=\"pickerMoment\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n (change)=\"goToDateInView($event, DateView.MONTH)\"\n (keyboardEnter)=\"focusActiveCell()\"\n (monthSelected)=\"selectMonthInYearView($event)\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"></owl-date-time-year-view>\n\n <owl-date-time-multi-year-view\n *ngSwitchCase=\"DateView.MULTI_YEARS\"\n [dateFilter]=\"dateFilter\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [pickerMoment]=\"pickerMoment\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n (change)=\"goToDateInView($event, DateView.YEAR)\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (yearSelected)=\"selectYearInMultiYearView($event)\"></owl-date-time-multi-year-view>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.CdkMonitorFocus, selector: "[cdkMonitorElementFocus], [cdkMonitorSubtreeFocus]", outputs: ["cdkFocusChange"], exportAs: ["cdkMonitorFocus"] }, { kind: "component", type: i5.OwlMultiYearViewComponent, selector: "owl-date-time-multi-year-view", inputs: ["selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["change", "yearSelected", "pickerMomentChange", "keyboardEnter"] }, { kind: "component", type: i6.OwlYearViewComponent, selector: "owl-date-time-year-view", inputs: ["selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["change", "monthSelected", "pickerMomentChange", "keyboardEnter"], exportAs: ["owlMonthView"] }, { kind: "component", type: i7.OwlMonthViewComponent, selector: "owl-date-time-month-view", inputs: ["hideOtherMonths", "firstDayOfWeek", "selectMode", "selected", "selecteds", "pickerMoment", "dateFilter", "minDate", "maxDate"], outputs: ["selectedChange", "userSelection", "pickerMomentChange"], exportAs: ["owlYearView"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
318
+ }
319
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: OwlCalendarComponent, decorators: [{
320
+ type: Component,
321
+ args: [{ selector: 'owl-date-time-calendar', exportAs: 'owlDateTimeCalendar', host: {
322
+ '[class.owl-dt-calendar]': 'owlDTCalendarClass'
323
+ }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"owl-dt-calendar-control\">\n <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n <button\n [attr.aria-label]=\"prevButtonLabel\"\n [disabled]=\"!prevButtonEnabled()\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n (click)=\"previousClicked()\"\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"100%\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n version=\"1.1\"\n viewBox=\"0 0 250.738 250.738\"\n width=\"100%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546 c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681 l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n style=\"fill-rule: evenodd; clip-rule: evenodd\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n <div class=\"owl-dt-calendar-control-content\">\n <button\n [attr.aria-label]=\"periodButtonLabel\"\n (click)=\"toggleViews()\"\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\">\n {{ periodButtonText }}\n\n <span\n [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n class=\"owl-dt-control-button-arrow\">\n <!-- <editor-fold desc=\"SVG Arrow\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n height=\"50%\"\n style=\"enable-background: new 0 0 292.362 292.362\"\n version=\"1.1\"\n viewBox=\"0 0 292.362 292.362\"\n width=\"50%\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <g>\n <path\n d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\" />\n </g>\n </svg>\n <!-- </editor-fold> -->\n </span>\n </span>\n </button>\n </div>\n <button\n [attr.aria-label]=\"nextButtonLabel\"\n [disabled]=\"!nextButtonEnabled()\"\n [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n (click)=\"nextClicked()\"\n class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"owl-dt-control-content owl-dt-control-button-content\"\n tabindex=\"-1\">\n <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n <svg\n xml:space=\"preserve\"\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n style=\"enable-background: new 0 0 250.738 250.738\"\n version=\"1.1\"\n viewBox=\"0 0 250.738 250.738\"\n x=\"0px\"\n xmlns=\"http://www.w3.org/2000/svg\"\n y=\"0px\">\n <path\n d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n C197.237,120.447,195.534,115.448,191.75,111.689z\"\n style=\"fill-rule: evenodd; clip-rule: evenodd\" />\n </svg>\n <!-- </editor-fold> -->\n </span>\n </button>\n</div>\n<div\n [ngSwitch]=\"currentView\"\n cdkMonitorSubtreeFocus\n class=\"owl-dt-calendar-main\"\n tabindex=\"-1\">\n <owl-date-time-month-view\n *ngSwitchCase=\"DateView.MONTH\"\n [dateFilter]=\"dateFilter\"\n [firstDayOfWeek]=\"firstDayOfWeek\"\n [hideOtherMonths]=\"hideOtherMonths\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [pickerMoment]=\"pickerMoment\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (selectedChange)=\"dateSelected($event)\"\n (userSelection)=\"userSelected()\"></owl-date-time-month-view>\n\n <owl-date-time-year-view\n *ngSwitchCase=\"DateView.YEAR\"\n [dateFilter]=\"dateFilter\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [pickerMoment]=\"pickerMoment\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n (change)=\"goToDateInView($event, DateView.MONTH)\"\n (keyboardEnter)=\"focusActiveCell()\"\n (monthSelected)=\"selectMonthInYearView($event)\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"></owl-date-time-year-view>\n\n <owl-date-time-multi-year-view\n *ngSwitchCase=\"DateView.MULTI_YEARS\"\n [dateFilter]=\"dateFilter\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [pickerMoment]=\"pickerMoment\"\n [selectMode]=\"selectMode\"\n [selected]=\"selected\"\n [selecteds]=\"selecteds\"\n (change)=\"goToDateInView($event, DateView.YEAR)\"\n (keyboardEnter)=\"focusActiveCell()\"\n (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n (yearSelected)=\"selectYearInMultiYearView($event)\"></owl-date-time-multi-year-view>\n</div>\n" }]
324
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.OwlDateTimeIntl }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: i2.DateTimeAdapter, decorators: [{
325
+ type: Optional
326
+ }] }, { type: undefined, decorators: [{
327
+ type: Optional
328
+ }, {
329
+ type: Inject,
330
+ args: [OWL_DATE_TIME_FORMATS]
331
+ }] }], propDecorators: { minDate: [{
332
+ type: Input
333
+ }], maxDate: [{
334
+ type: Input
335
+ }], pickerMoment: [{
336
+ type: Input
337
+ }], selected: [{
338
+ type: Input
339
+ }], selecteds: [{
340
+ type: Input
341
+ }], dateFilter: [{
342
+ type: Input
343
+ }], firstDayOfWeek: [{
344
+ type: Input
345
+ }], selectMode: [{
346
+ type: Input
347
+ }], startView: [{
348
+ type: Input
349
+ }], yearOnly: [{
350
+ type: Input
351
+ }], multiyearOnly: [{
352
+ type: Input
353
+ }], hideOtherMonths: [{
354
+ type: Input
355
+ }], pickerMomentChange: [{
356
+ type: Output
357
+ }], dateClicked: [{
358
+ type: Output
359
+ }], selectedChange: [{
360
+ type: Output
361
+ }], userSelection: [{
362
+ type: Output
363
+ }], yearSelected: [{
364
+ type: Output
365
+ }], monthSelected: [{
366
+ type: Output
367
+ }] } });
368
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/calendar.component.ts","../../../../../projects/picker/src/lib/date-time/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * calendar.component\n */\n\nimport {\n  AfterContentInit,\n  AfterViewChecked,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n  Output\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { take } from 'rxjs/operators';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { OWL_DATE_TIME_FORMATS, OwlDateTimeFormats } from './adapter/date-time-format.class';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\nimport { DateView, DateViewType, SelectMode } from './date-time.class';\n\n@Component({\n  selector: 'owl-date-time-calendar',\n  exportAs: 'owlDateTimeCalendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n  host: {\n    '[class.owl-dt-calendar]': 'owlDTCalendarClass'\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlCalendarComponent<T> implements AfterContentInit, AfterViewChecked, OnDestroy {\n  DateView = DateView;\n\n  @Input()\n  get minDate(): T | null {\n    return this._minDate;\n  }\n\n  set minDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n\n    this._minDate =\n      value ?\n        this.dateTimeAdapter.createDate(\n          this.dateTimeAdapter.getYear(value),\n          this.dateTimeAdapter.getMonth(value),\n          this.dateTimeAdapter.getDate(value)\n        )\n      : null;\n  }\n\n  @Input()\n  get maxDate(): T | null {\n    return this._maxDate;\n  }\n\n  set maxDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    value = this.getValidDate(value);\n\n    this._maxDate =\n      value ?\n        this.dateTimeAdapter.createDate(\n          this.dateTimeAdapter.getYear(value),\n          this.dateTimeAdapter.getMonth(value),\n          this.dateTimeAdapter.getDate(value)\n        )\n      : null;\n  }\n\n  @Input()\n  get pickerMoment() {\n    return this._pickerMoment;\n  }\n\n  set pickerMoment(value: T) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();\n  }\n\n  @Input()\n  get selected(): T | null {\n    return this._selected;\n  }\n\n  set selected(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._selected = this.getValidDate(value);\n  }\n\n  @Input()\n  get selecteds(): Array<T> {\n    return this._selecteds;\n  }\n\n  set selecteds(values: Array<T>) {\n    this._selecteds = values.map((v) => {\n      v = this.dateTimeAdapter.deserialize(v);\n      return this.getValidDate(v);\n    });\n  }\n\n  get periodButtonText(): string {\n    return this.isMonthView ?\n        this.dateTimeAdapter.format(this.pickerMoment, this.dateTimeFormats.monthYearLabel)\n      : this.dateTimeAdapter.getYearName(this.pickerMoment);\n  }\n\n  get periodButtonLabel(): string {\n    return this.isMonthView ? this.pickerIntl.switchToMultiYearViewLabel : this.pickerIntl.switchToMonthViewLabel;\n  }\n\n  get prevButtonLabel(): string {\n    if (this._currentView === DateView.MONTH) {\n      return this.pickerIntl.prevMonthLabel;\n    } else if (this._currentView === DateView.YEAR) {\n      return this.pickerIntl.prevYearLabel;\n    } else {\n      return null;\n    }\n  }\n\n  get nextButtonLabel(): string {\n    if (this._currentView === DateView.MONTH) {\n      return this.pickerIntl.nextMonthLabel;\n    } else if (this._currentView === DateView.YEAR) {\n      return this.pickerIntl.nextYearLabel;\n    } else {\n      return null;\n    }\n  }\n\n  get currentView(): DateViewType {\n    return this._currentView;\n  }\n\n  set currentView(view: DateViewType) {\n    this._currentView = view;\n    this.moveFocusOnNextTick = true;\n  }\n\n  get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  get isInRangeMode(): boolean {\n    return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';\n  }\n\n  get showControlArrows(): boolean {\n    return this._currentView !== DateView.MULTI_YEARS;\n  }\n\n  get isMonthView() {\n    return this._currentView === DateView.MONTH;\n  }\n\n  /**\n   * Bind class 'owl-dt-calendar' to host\n   * */\n  get owlDTCalendarClass(): boolean {\n    return true;\n  }\n\n  constructor(\n    private elmRef: ElementRef,\n    private pickerIntl: OwlDateTimeIntl,\n    private ngZone: NgZone,\n    private cdRef: ChangeDetectorRef,\n    @Optional() private dateTimeAdapter: DateTimeAdapter<T>,\n    @Optional()\n    @Inject(OWL_DATE_TIME_FORMATS)\n    private dateTimeFormats: OwlDateTimeFormats\n  ) {\n    this.intlChangesSub = this.pickerIntl.changes.subscribe(() => {\n      this.cdRef.markForCheck();\n    });\n  }\n\n  /**\n   * Date filter for the month and year view\n   * */\n  @Input()\n  dateFilter: (date: T) => boolean;\n\n  /**\n   * Set the first day of week\n   */\n  @Input()\n  firstDayOfWeek: number;\n\n  /** The minimum selectable date. */\n  private _minDate: T | null;\n\n  /** The maximum selectable date. */\n  private _maxDate: T | null;\n\n  /** The current picker moment */\n  private _pickerMoment: T;\n\n  @Input()\n  selectMode: SelectMode;\n\n  /** The currently selected moment. */\n  private _selected: T | null;\n\n  private _selecteds: Array<T> = [];\n\n  /**\n   * The view that the calendar should start in.\n   */\n  @Input()\n  startView: DateViewType = DateView.MONTH;\n\n  /**\n   * Whether to should only the year and multi-year views.\n   */\n  @Input()\n  yearOnly = false;\n\n  /**\n   * Whether to should only the multi-year view.\n   */\n  @Input()\n  multiyearOnly = false;\n\n  /**\n   * Whether to hide dates in other months at the start or end of the current month.\n   * */\n  @Input()\n  hideOtherMonths: boolean;\n\n  /** Emits when the currently picker moment changes. */\n  @Output()\n  pickerMomentChange = new EventEmitter<T>();\n\n  /** Emits when the selected date changes. */\n  @Output()\n  readonly dateClicked = new EventEmitter<T>();\n\n  /** Emits when the currently selected date changes. */\n  @Output()\n  readonly selectedChange = new EventEmitter<T>();\n\n  /** Emits when any date is selected. */\n  @Output()\n  readonly userSelection = new EventEmitter<void>();\n\n  /**\n   * Emits the selected year. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly yearSelected = new EventEmitter<T>();\n\n  /**\n   * Emits the selected month. This doesn't imply a change on the selected date\n   * */\n  @Output()\n  readonly monthSelected = new EventEmitter<T>();\n\n  private _currentView: DateViewType;\n\n  private intlChangesSub = Subscription.EMPTY;\n\n  /**\n   * Used for scheduling that focus should be moved to the active cell on the next tick.\n   * We need to schedule it, rather than do it immediately, because we have to wait\n   * for Angular to re-evaluate the view children.\n   */\n  private moveFocusOnNextTick = false;\n\n  /**\n   * Date filter for the month and year view\n   */\n  public dateFilterForViews = (date: T) => {\n    return (\n      !!date &&\n      (!this.dateFilter || this.dateFilter(date)) &&\n      (!this.minDate || this.dateTimeAdapter.compare(date, this.minDate) >= 0) &&\n      (!this.maxDate || this.dateTimeAdapter.compare(date, this.maxDate) <= 0)\n    );\n  };\n\n  public ngAfterContentInit(): void {\n    this._currentView = this.startView;\n  }\n\n  public ngAfterViewChecked() {\n    if (this.moveFocusOnNextTick) {\n      this.moveFocusOnNextTick = false;\n      this.focusActiveCell();\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.intlChangesSub.unsubscribe();\n  }\n\n  /**\n   * Toggle between month view and year view\n   */\n  public toggleViews(): void {\n    let nextView = null;\n    if (this._currentView === DateView.MONTH) {\n      nextView = DateView.MULTI_YEARS;\n    } else {\n      if (this.multiyearOnly) {\n        nextView = DateView.MULTI_YEARS;\n      } else if (this.yearOnly) {\n        nextView = this._currentView === DateView.YEAR ? DateView.MULTI_YEARS : DateView.YEAR;\n      } else {\n        nextView = DateView.MONTH;\n      }\n    }\n    this.currentView = nextView;\n  }\n\n  /**\n   * Handles user clicks on the previous button.\n   * */\n  public previousClicked(): void {\n    this.pickerMoment =\n      this.isMonthView ?\n        this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, -1)\n      : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, -1);\n\n    this.pickerMomentChange.emit(this.pickerMoment);\n  }\n\n  /**\n   * Handles user clicks on the next button.\n   * */\n  public nextClicked(): void {\n    this.pickerMoment =\n      this.isMonthView ?\n        this.dateTimeAdapter.addCalendarMonths(this.pickerMoment, 1)\n      : this.dateTimeAdapter.addCalendarYears(this.pickerMoment, 1);\n\n    this.pickerMomentChange.emit(this.pickerMoment);\n  }\n\n  public dateSelected(date: T): void {\n    if (!this.dateFilterForViews(date)) {\n      return;\n    }\n\n    this.dateClicked.emit(date);\n    this.selectedChange.emit(date);\n\n    /*if ((this.isInSingleMode && !this.dateTimeAdapter.isSameDay(date, this.selected)) ||\n            this.isInRangeMode) {\n            this.selectedChange.emit(date);\n        }*/\n  }\n\n  /**\n   * Change the pickerMoment value and switch to a specific view\n   */\n  public goToDateInView(date: T, view: DateViewType): void {\n    this.handlePickerMomentChange(date);\n    if (\n      (!this.yearOnly && !this.multiyearOnly) ||\n      (this.multiyearOnly && view !== DateView.MONTH && view !== DateView.YEAR) ||\n      (this.yearOnly && view !== DateView.MONTH)\n    ) {\n      this.currentView = view;\n    }\n    return;\n  }\n\n  /**\n   * Change the pickerMoment value\n   */\n  public handlePickerMomentChange(date: T): void {\n    this.pickerMoment = this.dateTimeAdapter.clampDate(date, this.minDate, this.maxDate);\n    this.pickerMomentChange.emit(this.pickerMoment);\n    return;\n  }\n\n  public userSelected(): void {\n    this.userSelection.emit();\n  }\n\n  /**\n   * Whether the previous period button is enabled.\n   */\n  public prevButtonEnabled(): boolean {\n    return !this.minDate || !this.isSameView(this.pickerMoment, this.minDate);\n  }\n\n  /**\n   * Whether the next period button is enabled.\n   */\n  public nextButtonEnabled(): boolean {\n    return !this.maxDate || !this.isSameView(this.pickerMoment, this.maxDate);\n  }\n\n  /**\n   * Focus to the host element\n   * */\n  public focusActiveCell() {\n    this.ngZone.runOutsideAngular(() => {\n      this.ngZone.onStable\n        .asObservable()\n        .pipe(take(1))\n        .subscribe(() => {\n          this.elmRef.nativeElement.querySelector('.owl-dt-calendar-cell-active').focus();\n        });\n    });\n  }\n\n  public selectYearInMultiYearView(normalizedYear: T): void {\n    this.yearSelected.emit(normalizedYear);\n  }\n\n  public selectMonthInYearView(normalizedMonth: T): void {\n    this.monthSelected.emit(normalizedMonth);\n  }\n\n  /**\n   * Whether the two dates represent the same view in the current view mode (month or year).\n   */\n  private isSameView(date1: T, date2: T): boolean {\n    if (this._currentView === DateView.MONTH) {\n      return !!(\n        date1 &&\n        date2 &&\n        this.dateTimeAdapter.getYear(date1) === this.dateTimeAdapter.getYear(date2) &&\n        this.dateTimeAdapter.getMonth(date1) === this.dateTimeAdapter.getMonth(date2)\n      );\n    } else if (this._currentView === DateView.YEAR) {\n      return !!(date1 && date2 && this.dateTimeAdapter.getYear(date1) === this.dateTimeAdapter.getYear(date2));\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Get a valid date object\n   */\n  private getValidDate(obj: any): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) && this.dateTimeAdapter.isValid(obj) ? obj : null;\n  }\n}\n","<div class=\"owl-dt-calendar-control\">\n  <!-- focus when keyboard tab (http://kizu.ru/en/blog/keyboard-only-focus/#x) -->\n  <button\n    [attr.aria-label]=\"prevButtonLabel\"\n    [disabled]=\"!prevButtonEnabled()\"\n    [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n    (click)=\"previousClicked()\"\n    class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n    tabindex=\"0\"\n    type=\"button\">\n    <span\n      class=\"owl-dt-control-content owl-dt-control-button-content\"\n      tabindex=\"-1\">\n      <!-- <editor-fold desc=\"SVG Arrow Left\"> -->\n      <svg\n        xml:space=\"preserve\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        height=\"100%\"\n        style=\"enable-background: new 0 0 250.738 250.738\"\n        version=\"1.1\"\n        viewBox=\"0 0 250.738 250.738\"\n        width=\"100%\"\n        x=\"0px\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        y=\"0px\">\n        <path\n          d=\"M96.633,125.369l95.053-94.533c7.101-7.055,7.101-18.492,0-25.546   c-7.1-7.054-18.613-7.054-25.714,0L58.989,111.689c-3.784,3.759-5.487,8.759-5.238,13.68c-0.249,4.922,1.454,9.921,5.238,13.681   l106.983,106.398c7.101,7.055,18.613,7.055,25.714,0c7.101-7.054,7.101-18.491,0-25.544L96.633,125.369z\"\n          style=\"fill-rule: evenodd; clip-rule: evenodd\" />\n      </svg>\n      <!-- </editor-fold> -->\n    </span>\n  </button>\n  <div class=\"owl-dt-calendar-control-content\">\n    <button\n      [attr.aria-label]=\"periodButtonLabel\"\n      (click)=\"toggleViews()\"\n      class=\"owl-dt-control owl-dt-control-button owl-dt-control-period-button\"\n      tabindex=\"0\"\n      type=\"button\">\n      <span\n        class=\"owl-dt-control-content owl-dt-control-button-content\"\n        tabindex=\"-1\">\n        {{ periodButtonText }}\n\n        <span\n          [style.transform]=\"'rotate(' + (isMonthView ? 0 : 180) + 'deg)'\"\n          class=\"owl-dt-control-button-arrow\">\n          <!-- <editor-fold desc=\"SVG Arrow\"> -->\n          <svg\n            xml:space=\"preserve\"\n            xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            height=\"50%\"\n            style=\"enable-background: new 0 0 292.362 292.362\"\n            version=\"1.1\"\n            viewBox=\"0 0 292.362 292.362\"\n            width=\"50%\"\n            x=\"0px\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            y=\"0px\">\n            <g>\n              <path\n                d=\"M286.935,69.377c-3.614-3.617-7.898-5.424-12.848-5.424H18.274c-4.952,0-9.233,1.807-12.85,5.424\n                                C1.807,72.998,0,77.279,0,82.228c0,4.948,1.807,9.229,5.424,12.847l127.907,127.907c3.621,3.617,7.902,5.428,12.85,5.428\n                                s9.233-1.811,12.847-5.428L286.935,95.074c3.613-3.617,5.427-7.898,5.427-12.847C292.362,77.279,290.548,72.998,286.935,69.377z\" />\n            </g>\n          </svg>\n          <!-- </editor-fold> -->\n        </span>\n      </span>\n    </button>\n  </div>\n  <button\n    [attr.aria-label]=\"nextButtonLabel\"\n    [disabled]=\"!nextButtonEnabled()\"\n    [style.visibility]=\"showControlArrows ? 'visible' : 'hidden'\"\n    (click)=\"nextClicked()\"\n    class=\"owl-dt-control owl-dt-control-button owl-dt-control-arrow-button\"\n    tabindex=\"0\"\n    type=\"button\">\n    <span\n      class=\"owl-dt-control-content owl-dt-control-button-content\"\n      tabindex=\"-1\">\n      <!-- <editor-fold desc=\"SVG Arrow Right\"> -->\n      <svg\n        xml:space=\"preserve\"\n        xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n        style=\"enable-background: new 0 0 250.738 250.738\"\n        version=\"1.1\"\n        viewBox=\"0 0 250.738 250.738\"\n        x=\"0px\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        y=\"0px\">\n        <path\n          d=\"M191.75,111.689L84.766,5.291c-7.1-7.055-18.613-7.055-25.713,0\n                    c-7.101,7.054-7.101,18.49,0,25.544l95.053,94.534l-95.053,94.533c-7.101,7.054-7.101,18.491,0,25.545\n                    c7.1,7.054,18.613,7.054,25.713,0L191.75,139.05c3.784-3.759,5.487-8.759,5.238-13.681\n                    C197.237,120.447,195.534,115.448,191.75,111.689z\"\n          style=\"fill-rule: evenodd; clip-rule: evenodd\" />\n      </svg>\n      <!-- </editor-fold> -->\n    </span>\n  </button>\n</div>\n<div\n  [ngSwitch]=\"currentView\"\n  cdkMonitorSubtreeFocus\n  class=\"owl-dt-calendar-main\"\n  tabindex=\"-1\">\n  <owl-date-time-month-view\n    *ngSwitchCase=\"DateView.MONTH\"\n    [dateFilter]=\"dateFilter\"\n    [firstDayOfWeek]=\"firstDayOfWeek\"\n    [hideOtherMonths]=\"hideOtherMonths\"\n    [maxDate]=\"maxDate\"\n    [minDate]=\"minDate\"\n    [pickerMoment]=\"pickerMoment\"\n    [selectMode]=\"selectMode\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (selectedChange)=\"dateSelected($event)\"\n    (userSelection)=\"userSelected()\"></owl-date-time-month-view>\n\n  <owl-date-time-year-view\n    *ngSwitchCase=\"DateView.YEAR\"\n    [dateFilter]=\"dateFilter\"\n    [maxDate]=\"maxDate\"\n    [minDate]=\"minDate\"\n    [pickerMoment]=\"pickerMoment\"\n    [selectMode]=\"selectMode\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    (change)=\"goToDateInView($event, DateView.MONTH)\"\n    (keyboardEnter)=\"focusActiveCell()\"\n    (monthSelected)=\"selectMonthInYearView($event)\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"></owl-date-time-year-view>\n\n  <owl-date-time-multi-year-view\n    *ngSwitchCase=\"DateView.MULTI_YEARS\"\n    [dateFilter]=\"dateFilter\"\n    [maxDate]=\"maxDate\"\n    [minDate]=\"minDate\"\n    [pickerMoment]=\"pickerMoment\"\n    [selectMode]=\"selectMode\"\n    [selected]=\"selected\"\n    [selecteds]=\"selecteds\"\n    (change)=\"goToDateInView($event, DateView.YEAR)\"\n    (keyboardEnter)=\"focusActiveCell()\"\n    (pickerMomentChange)=\"handlePickerMomentChange($event)\"\n    (yearSelected)=\"selectYearInMultiYearView($event)\"></owl-date-time-multi-year-view>\n</div>\n"]}