@netwin/angular-datetime-picker 19.0.0-rc.4 → 19.0.0-rc.5
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/README.md +27 -1
- package/assets/style/picker.min.css +1 -1
- package/fesm2022/netwin-angular-datetime-picker.mjs +4178 -1486
- package/fesm2022/netwin-angular-datetime-picker.mjs.map +1 -1
- package/lib/date-time/adapter/date-time-adapter.class.d.ts +19 -9
- package/lib/date-time/adapter/date-time-format.class.d.ts +12 -8
- package/lib/date-time/adapter/native-date-time-adapter.class.d.ts +16 -5
- package/lib/date-time/adapter/native-date-time-format.class.d.ts +3 -0
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.d.ts +15 -4
- package/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.d.ts +3 -0
- package/lib/date-time/calendar-body.component.d.ts +18 -13
- package/lib/date-time/calendar-month-view.component.d.ts +17 -12
- package/lib/date-time/calendar-multi-year-view.component.d.ts +12 -12
- package/lib/date-time/calendar-year-view.component.d.ts +7 -6
- package/lib/date-time/calendar.component.d.ts +37 -17
- package/lib/date-time/date-time-inline.component.d.ts +79 -156
- package/lib/date-time/date-time-picker-container.component.d.ts +131 -0
- package/lib/date-time/date-time-picker-input.directive.d.ts +172 -0
- package/lib/date-time/date-time-picker-intl.service.d.ts +6 -0
- package/lib/date-time/date-time-picker-trigger.directive.d.ts +23 -0
- package/lib/date-time/date-time-picker.animations.d.ts +8 -0
- package/lib/date-time/date-time-picker.component.d.ts +171 -0
- package/lib/date-time/date-time.class.d.ts +103 -0
- package/lib/date-time/date-time.module.d.ts +17 -11
- package/lib/date-time/numberedFixLen.pipe.d.ts +10 -0
- package/lib/date-time/timer-box.component.d.ts +4 -3
- package/lib/date-time/timer.component.d.ts +19 -16
- package/lib/dialog/dialog-config.class.d.ts +169 -0
- package/lib/dialog/dialog-container.component.d.ts +69 -0
- package/lib/dialog/dialog-ref.class.d.ts +51 -0
- package/lib/dialog/dialog.module.d.ts +11 -0
- package/lib/dialog/dialog.service.d.ts +76 -0
- package/lib/utils/index.d.ts +4 -0
- package/lib/utils/object.utils.d.ts +8 -0
- package/package.json +5 -7
- package/public_api.d.ts +16 -12
- package/esm2022/lib/date-time/adapter/date-time-adapter.class.mjs +0 -114
- package/esm2022/lib/date-time/adapter/date-time-format.class.mjs +0 -4
- package/esm2022/lib/date-time/adapter/native-date-time-adapter.class.mjs +0 -238
- package/esm2022/lib/date-time/adapter/native-date-time-format.class.mjs +0 -15
- package/esm2022/lib/date-time/adapter/native-date-time.module.mjs +0 -42
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-adapter.class.mjs +0 -215
- package/esm2022/lib/date-time/adapter/unix-timestamp-adapter/unix-timestamp-date-time-format.class.mjs +0 -15
- package/esm2022/lib/date-time/calendar-body.component.mjs +0 -137
- package/esm2022/lib/date-time/calendar-month-view.component.mjs +0 -420
- package/esm2022/lib/date-time/calendar-multi-year-view.component.mjs +0 -360
- package/esm2022/lib/date-time/calendar-year-view.component.mjs +0 -354
- package/esm2022/lib/date-time/calendar.component.mjs +0 -357
- package/esm2022/lib/date-time/date-time-inline.component.mjs +0 -463
- package/esm2022/lib/date-time/date-time-picker-intl.service.mjs +0 -55
- package/esm2022/lib/date-time/date-time.module.mjs +0 -59
- package/esm2022/lib/date-time/options-provider.mjs +0 -34
- package/esm2022/lib/date-time/timer-box.component.mjs +0 -130
- package/esm2022/lib/date-time/timer.component.mjs +0 -280
- package/esm2022/lib/types/date-view.mjs +0 -19
- package/esm2022/lib/types/index.mjs +0 -4
- package/esm2022/lib/types/picker-type.mjs +0 -2
- package/esm2022/lib/types/select-mode.mjs +0 -2
- package/esm2022/lib/utils/array.utils.mjs +0 -5
- package/esm2022/lib/utils/constants.mjs +0 -31
- package/esm2022/lib/utils/date.utils.mjs +0 -46
- package/esm2022/netwin-angular-datetime-picker.mjs +0 -5
- package/esm2022/public_api.mjs +0 -23
- package/lib/types/date-view.d.ts +0 -17
- package/lib/types/index.d.ts +0 -3
- package/lib/types/picker-type.d.ts +0 -7
- package/lib/types/select-mode.d.ts +0 -8
|
@@ -1,360 +0,0 @@
|
|
|
1
|
-
import { DOWN_ARROW, END, ENTER, HOME, LEFT_ARROW, PAGE_DOWN, PAGE_UP, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output, ViewChild } from '@angular/core';
|
|
3
|
-
import { CalendarCell, OwlCalendarBodyComponent } from './calendar-body.component';
|
|
4
|
-
import { OptionsTokens } from './options-provider';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "./date-time-picker-intl.service";
|
|
7
|
-
import * as i2 from "./adapter/date-time-adapter.class";
|
|
8
|
-
import * as i3 from "./calendar-body.component";
|
|
9
|
-
export class OwlMultiYearViewComponent {
|
|
10
|
-
get selectMode() {
|
|
11
|
-
return this._selectMode;
|
|
12
|
-
}
|
|
13
|
-
set selectMode(val) {
|
|
14
|
-
this._selectMode = val;
|
|
15
|
-
if (this.initiated) {
|
|
16
|
-
this.setSelectedYears();
|
|
17
|
-
this.cdRef.markForCheck();
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
get selected() {
|
|
21
|
-
return this._selected;
|
|
22
|
-
}
|
|
23
|
-
set selected(value) {
|
|
24
|
-
const oldSelected = this._selected;
|
|
25
|
-
value = this.dateTimeAdapter.deserialize(value);
|
|
26
|
-
this._selected = this.getValidDate(value);
|
|
27
|
-
if (!this.dateTimeAdapter.isSameDay(oldSelected, this._selected)) {
|
|
28
|
-
this.setSelectedYears();
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
get selecteds() {
|
|
32
|
-
return this._selecteds;
|
|
33
|
-
}
|
|
34
|
-
set selecteds(values) {
|
|
35
|
-
this._selecteds = values.map((v) => {
|
|
36
|
-
v = this.dateTimeAdapter.deserialize(v);
|
|
37
|
-
return this.getValidDate(v);
|
|
38
|
-
});
|
|
39
|
-
this.setSelectedYears();
|
|
40
|
-
}
|
|
41
|
-
get pickerMoment() {
|
|
42
|
-
return this._pickerMoment;
|
|
43
|
-
}
|
|
44
|
-
set pickerMoment(value) {
|
|
45
|
-
const oldMoment = this._pickerMoment;
|
|
46
|
-
value = this.dateTimeAdapter.deserialize(value);
|
|
47
|
-
this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();
|
|
48
|
-
if (oldMoment && this._pickerMoment && !this.isSameYearList(oldMoment, this._pickerMoment)) {
|
|
49
|
-
this.generateYearList();
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
get dateFilter() {
|
|
53
|
-
return this._dateFilter;
|
|
54
|
-
}
|
|
55
|
-
set dateFilter(filter) {
|
|
56
|
-
this._dateFilter = filter;
|
|
57
|
-
if (this.initiated) {
|
|
58
|
-
this.generateYearList();
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
get minDate() {
|
|
62
|
-
return this._minDate;
|
|
63
|
-
}
|
|
64
|
-
set minDate(value) {
|
|
65
|
-
value = this.dateTimeAdapter.deserialize(value);
|
|
66
|
-
this._minDate = this.getValidDate(value);
|
|
67
|
-
if (this.initiated) {
|
|
68
|
-
this.generateYearList();
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
get maxDate() {
|
|
72
|
-
return this._maxDate;
|
|
73
|
-
}
|
|
74
|
-
set maxDate(value) {
|
|
75
|
-
value = this.dateTimeAdapter.deserialize(value);
|
|
76
|
-
this._maxDate = this.getValidDate(value);
|
|
77
|
-
if (this.initiated) {
|
|
78
|
-
this.generateYearList();
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
get todayYear() {
|
|
82
|
-
return this._todayYear;
|
|
83
|
-
}
|
|
84
|
-
get years() {
|
|
85
|
-
return this._years;
|
|
86
|
-
}
|
|
87
|
-
get selectedYears() {
|
|
88
|
-
return this._selectedYears;
|
|
89
|
-
}
|
|
90
|
-
get isInSingleMode() {
|
|
91
|
-
return this.selectMode === 'single';
|
|
92
|
-
}
|
|
93
|
-
get isInRangeMode() {
|
|
94
|
-
return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';
|
|
95
|
-
}
|
|
96
|
-
get activeCell() {
|
|
97
|
-
if (this._pickerMoment) {
|
|
98
|
-
return this.dateTimeAdapter.getYear(this._pickerMoment) % (this.options.yearsPerRow * this.options.yearRows);
|
|
99
|
-
}
|
|
100
|
-
return undefined;
|
|
101
|
-
}
|
|
102
|
-
get tableHeader() {
|
|
103
|
-
if (this._years && this._years.length > 0) {
|
|
104
|
-
return `${this._years[0][0].displayValue} - ${this._years[this.options.yearRows - 1][this.options.yearsPerRow - 1].displayValue}`;
|
|
105
|
-
}
|
|
106
|
-
return undefined;
|
|
107
|
-
}
|
|
108
|
-
get prevButtonLabel() {
|
|
109
|
-
return this.pickerIntl.prevMultiYearLabel;
|
|
110
|
-
}
|
|
111
|
-
get nextButtonLabel() {
|
|
112
|
-
return this.pickerIntl.nextMultiYearLabel;
|
|
113
|
-
}
|
|
114
|
-
get owlDTCalendarMultiYearView() {
|
|
115
|
-
return true;
|
|
116
|
-
}
|
|
117
|
-
constructor(cdRef, pickerIntl, dateTimeAdapter, options) {
|
|
118
|
-
this.cdRef = cdRef;
|
|
119
|
-
this.pickerIntl = pickerIntl;
|
|
120
|
-
this.dateTimeAdapter = dateTimeAdapter;
|
|
121
|
-
this.options = options;
|
|
122
|
-
/**
|
|
123
|
-
* The select mode of the picker;
|
|
124
|
-
*/
|
|
125
|
-
this._selectMode = 'single';
|
|
126
|
-
this._selecteds = [];
|
|
127
|
-
this.initiated = false;
|
|
128
|
-
/**
|
|
129
|
-
* Callback to invoke when a new month is selected
|
|
130
|
-
*/
|
|
131
|
-
this.change = new EventEmitter();
|
|
132
|
-
/**
|
|
133
|
-
* Emits the selected year. This doesn't imply a change on the selected date
|
|
134
|
-
*/
|
|
135
|
-
this.yearSelected = new EventEmitter();
|
|
136
|
-
/** Emits when any date is activated. */
|
|
137
|
-
this.pickerMomentChange = new EventEmitter();
|
|
138
|
-
/** Emits when use keyboard enter to select a calendar cell */
|
|
139
|
-
this.keyboardEnter = new EventEmitter();
|
|
140
|
-
}
|
|
141
|
-
ngAfterContentInit() {
|
|
142
|
-
this._todayYear = this.dateTimeAdapter.getYear(this.dateTimeAdapter.now());
|
|
143
|
-
this.generateYearList();
|
|
144
|
-
this.initiated = true;
|
|
145
|
-
}
|
|
146
|
-
/**
|
|
147
|
-
* Handle a calendarCell selected
|
|
148
|
-
*/
|
|
149
|
-
selectCalendarCell(cell) {
|
|
150
|
-
this.selectYear(cell.value);
|
|
151
|
-
}
|
|
152
|
-
selectYear(year) {
|
|
153
|
-
this.yearSelected.emit(this.dateTimeAdapter.createDate(year, 0, 1));
|
|
154
|
-
const firstDateOfMonth = this.dateTimeAdapter.createDate(year, this.dateTimeAdapter.getMonth(this.pickerMoment), 1);
|
|
155
|
-
const daysInMonth = this.dateTimeAdapter.getNumDaysInMonth(firstDateOfMonth);
|
|
156
|
-
const selected = this.dateTimeAdapter.createDate(year, this.dateTimeAdapter.getMonth(this.pickerMoment), Math.min(daysInMonth, this.dateTimeAdapter.getDate(this.pickerMoment)), this.dateTimeAdapter.getHours(this.pickerMoment), this.dateTimeAdapter.getMinutes(this.pickerMoment), this.dateTimeAdapter.getSeconds(this.pickerMoment));
|
|
157
|
-
this.change.emit(selected);
|
|
158
|
-
}
|
|
159
|
-
/**
|
|
160
|
-
* Generate the previous year list
|
|
161
|
-
*/
|
|
162
|
-
prevYearList(event) {
|
|
163
|
-
this._pickerMoment = this.dateTimeAdapter.addCalendarYears(this.pickerMoment, -1 * this.options.yearsPerRow * this.options.yearRows);
|
|
164
|
-
this.generateYearList();
|
|
165
|
-
event.preventDefault();
|
|
166
|
-
}
|
|
167
|
-
/**
|
|
168
|
-
* Generate the next year list
|
|
169
|
-
*/
|
|
170
|
-
nextYearList(event) {
|
|
171
|
-
this._pickerMoment = this.dateTimeAdapter.addCalendarYears(this.pickerMoment, this.options.yearsPerRow * this.options.yearRows);
|
|
172
|
-
this.generateYearList();
|
|
173
|
-
event.preventDefault();
|
|
174
|
-
}
|
|
175
|
-
generateYearList() {
|
|
176
|
-
this._years = [];
|
|
177
|
-
const pickerMomentYear = this.dateTimeAdapter.getYear(this._pickerMoment);
|
|
178
|
-
const offset = pickerMomentYear % (this.options.yearsPerRow * this.options.yearRows);
|
|
179
|
-
for (let i = 0; i < this.options.yearRows; i++) {
|
|
180
|
-
const row = [];
|
|
181
|
-
for (let j = 0; j < this.options.yearsPerRow; j++) {
|
|
182
|
-
const year = pickerMomentYear - offset + (j + i * this.options.yearsPerRow);
|
|
183
|
-
const yearCell = this.createYearCell(year);
|
|
184
|
-
row.push(yearCell);
|
|
185
|
-
}
|
|
186
|
-
this._years.push(row);
|
|
187
|
-
}
|
|
188
|
-
return;
|
|
189
|
-
}
|
|
190
|
-
/** Whether the previous period button is enabled. */
|
|
191
|
-
previousEnabled() {
|
|
192
|
-
if (!this.minDate) {
|
|
193
|
-
return true;
|
|
194
|
-
}
|
|
195
|
-
return !this.minDate || !this.isSameYearList(this._pickerMoment, this.minDate);
|
|
196
|
-
}
|
|
197
|
-
/** Whether the next period button is enabled. */
|
|
198
|
-
nextEnabled() {
|
|
199
|
-
return !this.maxDate || !this.isSameYearList(this._pickerMoment, this.maxDate);
|
|
200
|
-
}
|
|
201
|
-
handleCalendarKeydown(event) {
|
|
202
|
-
let moment;
|
|
203
|
-
switch (event.keyCode) {
|
|
204
|
-
// minus 1 year
|
|
205
|
-
case LEFT_ARROW:
|
|
206
|
-
moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, -1);
|
|
207
|
-
this.pickerMomentChange.emit(moment);
|
|
208
|
-
break;
|
|
209
|
-
// add 1 year
|
|
210
|
-
case RIGHT_ARROW:
|
|
211
|
-
moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, 1);
|
|
212
|
-
this.pickerMomentChange.emit(moment);
|
|
213
|
-
break;
|
|
214
|
-
// minus 3 years
|
|
215
|
-
case UP_ARROW:
|
|
216
|
-
moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, -1 * this.options.yearsPerRow);
|
|
217
|
-
this.pickerMomentChange.emit(moment);
|
|
218
|
-
break;
|
|
219
|
-
// add 3 years
|
|
220
|
-
case DOWN_ARROW:
|
|
221
|
-
moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, this.options.yearsPerRow);
|
|
222
|
-
this.pickerMomentChange.emit(moment);
|
|
223
|
-
break;
|
|
224
|
-
// go to the first year of the year page
|
|
225
|
-
case HOME:
|
|
226
|
-
moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, -this.dateTimeAdapter.getYear(this._pickerMoment) % (this.options.yearsPerRow * this.options.yearRows));
|
|
227
|
-
this.pickerMomentChange.emit(moment);
|
|
228
|
-
break;
|
|
229
|
-
// go to the last year of the year page
|
|
230
|
-
case END:
|
|
231
|
-
moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, this.options.yearsPerRow * this.options.yearRows -
|
|
232
|
-
(this.dateTimeAdapter.getYear(this._pickerMoment) % (this.options.yearsPerRow * this.options.yearRows)) -
|
|
233
|
-
1);
|
|
234
|
-
this.pickerMomentChange.emit(moment);
|
|
235
|
-
break;
|
|
236
|
-
// minus 1 year page (or 10 year pages)
|
|
237
|
-
case PAGE_UP:
|
|
238
|
-
moment = this.dateTimeAdapter.addCalendarYears(this.pickerMoment, event.altKey ?
|
|
239
|
-
-10 * (this.options.yearsPerRow * this.options.yearRows)
|
|
240
|
-
: -1 * (this.options.yearsPerRow * this.options.yearRows));
|
|
241
|
-
this.pickerMomentChange.emit(moment);
|
|
242
|
-
break;
|
|
243
|
-
// add 1 year page (or 10 year pages)
|
|
244
|
-
case PAGE_DOWN:
|
|
245
|
-
moment = this.dateTimeAdapter.addCalendarYears(this.pickerMoment, event.altKey ?
|
|
246
|
-
10 * (this.options.yearsPerRow * this.options.yearRows)
|
|
247
|
-
: this.options.yearsPerRow * this.options.yearRows);
|
|
248
|
-
this.pickerMomentChange.emit(moment);
|
|
249
|
-
break;
|
|
250
|
-
case ENTER:
|
|
251
|
-
this.selectYear(this.dateTimeAdapter.getYear(this._pickerMoment));
|
|
252
|
-
this.keyboardEnter.emit();
|
|
253
|
-
break;
|
|
254
|
-
default:
|
|
255
|
-
return;
|
|
256
|
-
}
|
|
257
|
-
this.focusActiveCell();
|
|
258
|
-
event.preventDefault();
|
|
259
|
-
}
|
|
260
|
-
/**
|
|
261
|
-
* Creates an CalendarCell for the given year.
|
|
262
|
-
*/
|
|
263
|
-
createYearCell(year) {
|
|
264
|
-
const startDateOfYear = this.dateTimeAdapter.createDate(year, 0, 1);
|
|
265
|
-
const ariaLabel = this.dateTimeAdapter.getYearName(startDateOfYear);
|
|
266
|
-
const cellClass = `owl-dt-year-${year}`;
|
|
267
|
-
return new CalendarCell(year, year.toString(), ariaLabel, this.isYearEnabled(year), false, cellClass);
|
|
268
|
-
}
|
|
269
|
-
setSelectedYears() {
|
|
270
|
-
this._selectedYears = [];
|
|
271
|
-
if (this.isInSingleMode && this.selected) {
|
|
272
|
-
this._selectedYears[0] = this.dateTimeAdapter.getYear(this.selected);
|
|
273
|
-
}
|
|
274
|
-
if (this.isInRangeMode && this.selecteds) {
|
|
275
|
-
this._selectedYears = this.selecteds.map((selected) => {
|
|
276
|
-
if (this.dateTimeAdapter.isValid(selected)) {
|
|
277
|
-
return this.dateTimeAdapter.getYear(selected);
|
|
278
|
-
}
|
|
279
|
-
else {
|
|
280
|
-
return null;
|
|
281
|
-
}
|
|
282
|
-
});
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
/** Whether the given year is enabled. */
|
|
286
|
-
isYearEnabled(year) {
|
|
287
|
-
// disable if the year is greater than maxDate lower than minDate
|
|
288
|
-
if (year === undefined ||
|
|
289
|
-
year === null ||
|
|
290
|
-
(this.maxDate && year > this.dateTimeAdapter.getYear(this.maxDate)) ||
|
|
291
|
-
(this.minDate && year < this.dateTimeAdapter.getYear(this.minDate))) {
|
|
292
|
-
return false;
|
|
293
|
-
}
|
|
294
|
-
// enable if it reaches here and there's no filter defined
|
|
295
|
-
if (!this.dateFilter) {
|
|
296
|
-
return true;
|
|
297
|
-
}
|
|
298
|
-
const firstOfYear = this.dateTimeAdapter.createDate(year, 0, 1);
|
|
299
|
-
// If any date in the year is enabled count the year as enabled.
|
|
300
|
-
for (let date = firstOfYear; this.dateTimeAdapter.getYear(date) === year; date = this.dateTimeAdapter.addCalendarDays(date, 1)) {
|
|
301
|
-
if (this.dateFilter(date)) {
|
|
302
|
-
return true;
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
return false;
|
|
306
|
-
}
|
|
307
|
-
isSameYearList(date1, date2) {
|
|
308
|
-
return (Math.floor(this.dateTimeAdapter.getYear(date1) / (this.options.yearsPerRow * this.options.yearRows)) ===
|
|
309
|
-
Math.floor(this.dateTimeAdapter.getYear(date2) / (this.options.yearsPerRow * this.options.yearRows)));
|
|
310
|
-
}
|
|
311
|
-
/**
|
|
312
|
-
* Get a valid date object
|
|
313
|
-
*/
|
|
314
|
-
getValidDate(obj) {
|
|
315
|
-
return this.dateTimeAdapter.isDateInstance(obj) && this.dateTimeAdapter.isValid(obj) ? obj : null;
|
|
316
|
-
}
|
|
317
|
-
focusActiveCell() {
|
|
318
|
-
this.calendarBodyElm.focusActiveCell();
|
|
319
|
-
}
|
|
320
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlMultiYearViewComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.OwlDateTimeIntl }, { token: i2.DateTimeAdapter, optional: true }, { token: OptionsTokens.multiYear }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
321
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.10", type: OwlMultiYearViewComponent, selector: "owl-date-time-multi-year-view", inputs: { selectMode: "selectMode", selected: "selected", selecteds: "selecteds", pickerMoment: "pickerMoment", dateFilter: "dateFilter", minDate: "minDate", maxDate: "maxDate" }, outputs: { change: "change", yearSelected: "yearSelected", pickerMomentChange: "pickerMomentChange", keyboardEnter: "keyboardEnter" }, host: { properties: { "class.owl-dt-calendar-multi-year-view": "owlDTCalendarMultiYearView" }, classAttribute: "owl-dt-calendar-view" }, viewQueries: [{ propertyName: "calendarBodyElm", first: true, predicate: OwlCalendarBodyComponent, descendants: true, static: true }], ngImport: i0, template: "<button\n [attr.aria-label]=\"prevButtonLabel\"\n [disabled]=\"!previousEnabled()\"\n (click)=\"prevYearList($event)\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"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<table class=\"owl-dt-calendar-table owl-dt-calendar-multi-year-table\">\n <thead class=\"owl-dt-calendar-header\">\n <tr>\n <th colspan=\"3\">{{ tableHeader }}</th>\n </tr>\n </thead>\n <tbody\n [activeCell]=\"activeCell\"\n [cellRatio]=\"3 / 7\"\n [numCols]=\"3\"\n [rows]=\"years\"\n [selectMode]=\"selectMode\"\n [selectedValues]=\"selectedYears\"\n [todayValue]=\"todayYear\"\n (keydown)=\"handleCalendarKeydown($event)\"\n (select)=\"selectCalendarCell($event)\"\n owl-date-time-calendar-body\n role=\"grid\"></tbody>\n</table>\n<button\n [attr.aria-label]=\"nextButtonLabel\"\n [disabled]=\"!nextEnabled()\"\n (click)=\"nextYearList($event)\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"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", styles: [""], dependencies: [{ kind: "component", type: i3.OwlCalendarBodyComponent, selector: "[owl-date-time-calendar-body]", inputs: ["activeCell", "rows", "numCols", "cellRatio", "todayValue", "selectedValues", "selectMode"], outputs: ["select"], exportAs: ["owlDateTimeCalendarBody"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
322
|
-
}
|
|
323
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: OwlMultiYearViewComponent, decorators: [{
|
|
324
|
-
type: Component,
|
|
325
|
-
args: [{ selector: 'owl-date-time-multi-year-view', host: {
|
|
326
|
-
'[class.owl-dt-calendar-multi-year-view]': 'owlDTCalendarMultiYearView',
|
|
327
|
-
'class': 'owl-dt-calendar-view'
|
|
328
|
-
}, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n [attr.aria-label]=\"prevButtonLabel\"\n [disabled]=\"!previousEnabled()\"\n (click)=\"prevYearList($event)\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"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<table class=\"owl-dt-calendar-table owl-dt-calendar-multi-year-table\">\n <thead class=\"owl-dt-calendar-header\">\n <tr>\n <th colspan=\"3\">{{ tableHeader }}</th>\n </tr>\n </thead>\n <tbody\n [activeCell]=\"activeCell\"\n [cellRatio]=\"3 / 7\"\n [numCols]=\"3\"\n [rows]=\"years\"\n [selectMode]=\"selectMode\"\n [selectedValues]=\"selectedYears\"\n [todayValue]=\"todayYear\"\n (keydown)=\"handleCalendarKeydown($event)\"\n (select)=\"selectCalendarCell($event)\"\n owl-date-time-calendar-body\n role=\"grid\"></tbody>\n</table>\n<button\n [attr.aria-label]=\"nextButtonLabel\"\n [disabled]=\"!nextEnabled()\"\n (click)=\"nextYearList($event)\"\n class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n tabindex=\"0\"\n type=\"button\">\n <span\n class=\"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" }]
|
|
329
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.OwlDateTimeIntl }, { type: i2.DateTimeAdapter, decorators: [{
|
|
330
|
-
type: Optional
|
|
331
|
-
}] }, { type: undefined, decorators: [{
|
|
332
|
-
type: Inject,
|
|
333
|
-
args: [OptionsTokens.multiYear]
|
|
334
|
-
}] }], propDecorators: { selectMode: [{
|
|
335
|
-
type: Input
|
|
336
|
-
}], selected: [{
|
|
337
|
-
type: Input
|
|
338
|
-
}], selecteds: [{
|
|
339
|
-
type: Input
|
|
340
|
-
}], pickerMoment: [{
|
|
341
|
-
type: Input
|
|
342
|
-
}], dateFilter: [{
|
|
343
|
-
type: Input
|
|
344
|
-
}], minDate: [{
|
|
345
|
-
type: Input
|
|
346
|
-
}], maxDate: [{
|
|
347
|
-
type: Input
|
|
348
|
-
}], change: [{
|
|
349
|
-
type: Output
|
|
350
|
-
}], yearSelected: [{
|
|
351
|
-
type: Output
|
|
352
|
-
}], pickerMomentChange: [{
|
|
353
|
-
type: Output
|
|
354
|
-
}], keyboardEnter: [{
|
|
355
|
-
type: Output
|
|
356
|
-
}], calendarBodyElm: [{
|
|
357
|
-
type: ViewChild,
|
|
358
|
-
args: [OwlCalendarBodyComponent, { static: true }]
|
|
359
|
-
}] } });
|
|
360
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-multi-year-view.component.js","sourceRoot":"","sources":["../../../../../projects/picker/src/lib/date-time/calendar-multi-year-view.component.ts","../../../../../projects/picker/src/lib/date-time/calendar-multi-year-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  DOWN_ARROW,\n  END,\n  ENTER,\n  HOME,\n  LEFT_ARROW,\n  PAGE_DOWN,\n  PAGE_UP,\n  RIGHT_ARROW,\n  UP_ARROW\n} from '@angular/cdk/keycodes';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { SelectMode } from '../types';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { CalendarCell, OwlCalendarBodyComponent } from './calendar-body.component';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\nimport { Options, OptionsTokens } from './options-provider';\n\n@Component({\n  selector: 'owl-date-time-multi-year-view',\n  templateUrl: './calendar-multi-year-view.component.html',\n  styleUrls: ['./calendar-multi-year-view.component.scss'],\n  host: {\n    '[class.owl-dt-calendar-multi-year-view]': 'owlDTCalendarMultiYearView',\n    'class': 'owl-dt-calendar-view'\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class OwlMultiYearViewComponent<T> implements AfterContentInit {\n  /**\n   * The select mode of the picker;\n   */\n  private _selectMode: SelectMode = 'single';\n  @Input()\n  public get selectMode(): SelectMode {\n    return this._selectMode;\n  }\n\n  public set selectMode(val: SelectMode) {\n    this._selectMode = val;\n    if (this.initiated) {\n      this.setSelectedYears();\n      this.cdRef.markForCheck();\n    }\n  }\n\n  /** The currently selected date. */\n  private _selected: T | null;\n  @Input()\n  public get selected(): T | null {\n    return this._selected;\n  }\n\n  public set selected(value: T | null) {\n    const oldSelected = this._selected;\n    value = this.dateTimeAdapter.deserialize(value);\n    this._selected = this.getValidDate(value);\n\n    if (!this.dateTimeAdapter.isSameDay(oldSelected, this._selected)) {\n      this.setSelectedYears();\n    }\n  }\n\n  private _selecteds: Array<T> = [];\n  @Input()\n  public get selecteds(): Array<T> {\n    return this._selecteds;\n  }\n\n  public set selecteds(values: Array<T>) {\n    this._selecteds = values.map((v) => {\n      v = this.dateTimeAdapter.deserialize(v);\n      return this.getValidDate(v);\n    });\n    this.setSelectedYears();\n  }\n\n  private _pickerMoment: T | null;\n  @Input()\n  public get pickerMoment(): T | null {\n    return this._pickerMoment;\n  }\n\n  public set pickerMoment(value: T) {\n    const oldMoment = this._pickerMoment;\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();\n\n    if (oldMoment && this._pickerMoment && !this.isSameYearList(oldMoment, this._pickerMoment)) {\n      this.generateYearList();\n    }\n  }\n\n  /**\n   * A function used to filter which dates are selectable\n   */\n  private _dateFilter: (date: T) => boolean;\n  @Input()\n  public get dateFilter(): (date: T) => boolean {\n    return this._dateFilter;\n  }\n\n  public set dateFilter(filter: (date: T) => boolean) {\n    this._dateFilter = filter;\n    if (this.initiated) {\n      this.generateYearList();\n    }\n  }\n\n  /** The minimum selectable date. */\n  private _minDate: T | null;\n  @Input()\n  public get minDate(): T | null {\n    return this._minDate;\n  }\n\n  public set minDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._minDate = this.getValidDate(value);\n    if (this.initiated) {\n      this.generateYearList();\n    }\n  }\n\n  /** The maximum selectable date. */\n  private _maxDate: T | null;\n  @Input()\n  public get maxDate(): T | null {\n    return this._maxDate;\n  }\n\n  public set maxDate(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._maxDate = this.getValidDate(value);\n    if (this.initiated) {\n      this.generateYearList();\n    }\n  }\n\n  private _todayYear: number;\n  public get todayYear(): number {\n    return this._todayYear;\n  }\n\n  private _years: Array<Array<CalendarCell>>;\n  public get years(): Array<Array<CalendarCell>> {\n    return this._years;\n  }\n\n  private _selectedYears: Array<number>;\n  public get selectedYears(): Array<number> {\n    return this._selectedYears;\n  }\n\n  private initiated = false;\n\n  public get isInSingleMode(): boolean {\n    return this.selectMode === 'single';\n  }\n\n  public get isInRangeMode(): boolean {\n    return this.selectMode === 'range' || this.selectMode === 'rangeFrom' || this.selectMode === 'rangeTo';\n  }\n\n  public get activeCell(): number | undefined {\n    if (this._pickerMoment) {\n      return this.dateTimeAdapter.getYear(this._pickerMoment) % (this.options.yearsPerRow * this.options.yearRows);\n    }\n    return undefined;\n  }\n\n  public get tableHeader(): string | undefined {\n    if (this._years && this._years.length > 0) {\n      return `${this._years[0][0].displayValue} - ${this._years[this.options.yearRows - 1][this.options.yearsPerRow - 1].displayValue}`;\n    }\n    return undefined;\n  }\n\n  public get prevButtonLabel(): string {\n    return this.pickerIntl.prevMultiYearLabel;\n  }\n\n  public get nextButtonLabel(): string {\n    return this.pickerIntl.nextMultiYearLabel;\n  }\n\n  /**\n   * Callback to invoke when a new month is selected\n   */\n  @Output() public readonly change = new EventEmitter<T>();\n\n  /**\n   * Emits the selected year. This doesn't imply a change on the selected date\n   */\n  @Output() public readonly yearSelected = new EventEmitter<T>();\n\n  /** Emits when any date is activated. */\n  @Output() public readonly pickerMomentChange = new EventEmitter<T>();\n\n  /** Emits when use keyboard enter to select a calendar cell */\n  @Output() public readonly keyboardEnter = new EventEmitter<KeyboardEvent>();\n\n  /** The body of calendar table */\n  @ViewChild(OwlCalendarBodyComponent, { static: true })\n  public calendarBodyElm: OwlCalendarBodyComponent;\n\n  public get owlDTCalendarMultiYearView(): boolean {\n    return true;\n  }\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private pickerIntl: OwlDateTimeIntl,\n    @Optional() private dateTimeAdapter: DateTimeAdapter<T>,\n    @Inject(OptionsTokens.multiYear) private options: Options['multiYear']\n  ) {}\n\n  public ngAfterContentInit(): void {\n    this._todayYear = this.dateTimeAdapter.getYear(this.dateTimeAdapter.now());\n    this.generateYearList();\n    this.initiated = true;\n  }\n\n  /**\n   * Handle a calendarCell selected\n   */\n  public selectCalendarCell(cell: CalendarCell): void {\n    this.selectYear(cell.value);\n  }\n\n  private selectYear(year: number): void {\n    this.yearSelected.emit(this.dateTimeAdapter.createDate(year, 0, 1));\n    const firstDateOfMonth = this.dateTimeAdapter.createDate(year, this.dateTimeAdapter.getMonth(this.pickerMoment), 1);\n    const daysInMonth = this.dateTimeAdapter.getNumDaysInMonth(firstDateOfMonth);\n    const selected = this.dateTimeAdapter.createDate(\n      year,\n      this.dateTimeAdapter.getMonth(this.pickerMoment),\n      Math.min(daysInMonth, this.dateTimeAdapter.getDate(this.pickerMoment)),\n      this.dateTimeAdapter.getHours(this.pickerMoment),\n      this.dateTimeAdapter.getMinutes(this.pickerMoment),\n      this.dateTimeAdapter.getSeconds(this.pickerMoment)\n    );\n\n    this.change.emit(selected);\n  }\n\n  /**\n   * Generate the previous year list\n   */\n  public prevYearList(event: MouseEvent): void {\n    this._pickerMoment = this.dateTimeAdapter.addCalendarYears(\n      this.pickerMoment,\n      -1 * this.options.yearsPerRow * this.options.yearRows\n    );\n    this.generateYearList();\n    event.preventDefault();\n  }\n\n  /**\n   * Generate the next year list\n   */\n  public nextYearList(event: MouseEvent): void {\n    this._pickerMoment = this.dateTimeAdapter.addCalendarYears(\n      this.pickerMoment,\n      this.options.yearsPerRow * this.options.yearRows\n    );\n    this.generateYearList();\n    event.preventDefault();\n  }\n\n  public generateYearList(): void {\n    this._years = [];\n\n    const pickerMomentYear = this.dateTimeAdapter.getYear(this._pickerMoment);\n    const offset = pickerMomentYear % (this.options.yearsPerRow * this.options.yearRows);\n\n    for (let i = 0; i < this.options.yearRows; i++) {\n      const row = [];\n\n      for (let j = 0; j < this.options.yearsPerRow; j++) {\n        const year = pickerMomentYear - offset + (j + i * this.options.yearsPerRow);\n        const yearCell = this.createYearCell(year);\n        row.push(yearCell);\n      }\n\n      this._years.push(row);\n    }\n\n    return;\n  }\n\n  /** Whether the previous period button is enabled. */\n  public previousEnabled(): boolean {\n    if (!this.minDate) {\n      return true;\n    }\n    return !this.minDate || !this.isSameYearList(this._pickerMoment, this.minDate);\n  }\n\n  /** Whether the next period button is enabled. */\n  public nextEnabled(): boolean {\n    return !this.maxDate || !this.isSameYearList(this._pickerMoment, this.maxDate);\n  }\n\n  public handleCalendarKeydown(event: KeyboardEvent): void {\n    let moment;\n    switch (event.keyCode) {\n      // minus 1 year\n      case LEFT_ARROW:\n        moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, -1);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 1 year\n      case RIGHT_ARROW:\n        moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, 1);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // minus 3 years\n      case UP_ARROW:\n        moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, -1 * this.options.yearsPerRow);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 3 years\n      case DOWN_ARROW:\n        moment = this.dateTimeAdapter.addCalendarYears(this._pickerMoment, this.options.yearsPerRow);\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // go to the first year of the year page\n      case HOME:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this._pickerMoment,\n          -this.dateTimeAdapter.getYear(this._pickerMoment) % (this.options.yearsPerRow * this.options.yearRows)\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // go to the last year of the year page\n      case END:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this._pickerMoment,\n          this.options.yearsPerRow * this.options.yearRows -\n            (this.dateTimeAdapter.getYear(this._pickerMoment) % (this.options.yearsPerRow * this.options.yearRows)) -\n            1\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // minus 1 year page (or 10 year pages)\n      case PAGE_UP:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this.pickerMoment,\n          event.altKey ?\n            -10 * (this.options.yearsPerRow * this.options.yearRows)\n          : -1 * (this.options.yearsPerRow * this.options.yearRows)\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      // add 1 year page (or 10 year pages)\n      case PAGE_DOWN:\n        moment = this.dateTimeAdapter.addCalendarYears(\n          this.pickerMoment,\n          event.altKey ?\n            10 * (this.options.yearsPerRow * this.options.yearRows)\n          : this.options.yearsPerRow * this.options.yearRows\n        );\n        this.pickerMomentChange.emit(moment);\n        break;\n\n      case ENTER:\n        this.selectYear(this.dateTimeAdapter.getYear(this._pickerMoment));\n        this.keyboardEnter.emit();\n        break;\n\n      default:\n        return;\n    }\n\n    this.focusActiveCell();\n    event.preventDefault();\n  }\n\n  /**\n   * Creates an CalendarCell for the given year.\n   */\n  private createYearCell(year: number): CalendarCell {\n    const startDateOfYear = this.dateTimeAdapter.createDate(year, 0, 1);\n    const ariaLabel = this.dateTimeAdapter.getYearName(startDateOfYear);\n    const cellClass = `owl-dt-year-${year}`;\n    return new CalendarCell(year, year.toString(), ariaLabel, this.isYearEnabled(year), false, cellClass);\n  }\n\n  private setSelectedYears(): void {\n    this._selectedYears = [];\n\n    if (this.isInSingleMode && this.selected) {\n      this._selectedYears[0] = this.dateTimeAdapter.getYear(this.selected);\n    }\n\n    if (this.isInRangeMode && this.selecteds) {\n      this._selectedYears = this.selecteds.map((selected) => {\n        if (this.dateTimeAdapter.isValid(selected)) {\n          return this.dateTimeAdapter.getYear(selected);\n        } else {\n          return null;\n        }\n      });\n    }\n  }\n\n  /** Whether the given year is enabled. */\n  private isYearEnabled(year: number): boolean {\n    // disable if the year is greater than maxDate lower than minDate\n    if (\n      year === undefined ||\n      year === null ||\n      (this.maxDate && year > this.dateTimeAdapter.getYear(this.maxDate)) ||\n      (this.minDate && year < this.dateTimeAdapter.getYear(this.minDate))\n    ) {\n      return false;\n    }\n\n    // enable if it reaches here and there's no filter defined\n    if (!this.dateFilter) {\n      return true;\n    }\n\n    const firstOfYear = this.dateTimeAdapter.createDate(year, 0, 1);\n\n    // If any date in the year is enabled count the year as enabled.\n    for (\n      let date = firstOfYear;\n      this.dateTimeAdapter.getYear(date) === year;\n      date = this.dateTimeAdapter.addCalendarDays(date, 1)\n    ) {\n      if (this.dateFilter(date)) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  private isSameYearList(date1: T, date2: T): boolean {\n    return (\n      Math.floor(this.dateTimeAdapter.getYear(date1) / (this.options.yearsPerRow * this.options.yearRows)) ===\n      Math.floor(this.dateTimeAdapter.getYear(date2) / (this.options.yearsPerRow * this.options.yearRows))\n    );\n  }\n\n  /**\n   * Get a valid date object\n   */\n  private getValidDate(obj: unknown): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) && this.dateTimeAdapter.isValid(obj) ? obj : null;\n  }\n\n  private focusActiveCell(): void {\n    this.calendarBodyElm.focusActiveCell();\n  }\n}\n","<button\n  [attr.aria-label]=\"prevButtonLabel\"\n  [disabled]=\"!previousEnabled()\"\n  (click)=\"prevYearList($event)\"\n  class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n  tabindex=\"0\"\n  type=\"button\">\n  <span\n    class=\"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<table class=\"owl-dt-calendar-table owl-dt-calendar-multi-year-table\">\n  <thead class=\"owl-dt-calendar-header\">\n    <tr>\n      <th colspan=\"3\">{{ tableHeader }}</th>\n    </tr>\n  </thead>\n  <tbody\n    [activeCell]=\"activeCell\"\n    [cellRatio]=\"3 / 7\"\n    [numCols]=\"3\"\n    [rows]=\"years\"\n    [selectMode]=\"selectMode\"\n    [selectedValues]=\"selectedYears\"\n    [todayValue]=\"todayYear\"\n    (keydown)=\"handleCalendarKeydown($event)\"\n    (select)=\"selectCalendarCell($event)\"\n    owl-date-time-calendar-body\n    role=\"grid\"></tbody>\n</table>\n<button\n  [attr.aria-label]=\"nextButtonLabel\"\n  [disabled]=\"!nextEnabled()\"\n  (click)=\"nextYearList($event)\"\n  class=\"owl-dt-control-button owl-dt-control-arrow-button\"\n  tabindex=\"0\"\n  type=\"button\">\n  <span\n    class=\"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"]}
|