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