igniteui-angular 17.2.0 → 17.2.1
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/esm2022/lib/calendar/month-picker/month-picker.component.mjs +224 -6
- package/esm2022/lib/core/utils.mjs +3 -1
- package/esm2022/lib/directives/button/button-base.mjs +39 -2
- package/esm2022/lib/directives/button/button.directive.mjs +2 -1
- package/esm2022/lib/directives/toggle/toggle.directive.mjs +18 -6
- package/fesm2022/igniteui-angular.mjs +276 -8
- package/fesm2022/igniteui-angular.mjs.map +1 -1
- package/lib/calendar/month-picker/month-picker.component.d.ts +83 -2
- package/lib/core/styles/components/button/_button-component.scss +16 -0
- package/lib/core/styles/components/button/_button-theme.scss +203 -273
- package/lib/core/styles/components/button-group/_button-group-theme.scss +314 -85
- package/lib/core/styles/components/icon-button/_icon-button-theme.scss +27 -51
- package/lib/core/styles/components/overlay/_overlay-component.scss +4 -0
- package/lib/core/styles/components/overlay/_overlay-theme.scss +17 -1
- package/lib/core/utils.d.ts +2 -0
- package/lib/directives/button/button-base.d.ts +21 -0
- package/lib/directives/toggle/toggle.directive.d.ts +5 -3
- package/package.json +2 -2
- package/styles/igniteui-angular-dark.css +1 -1
- package/styles/igniteui-angular.css +1 -1
- package/styles/igniteui-bootstrap-dark.css +1 -1
- package/styles/igniteui-bootstrap-light.css +1 -1
- package/styles/igniteui-dark-green.css +1 -1
- package/styles/igniteui-fluent-dark-excel.css +1 -1
- package/styles/igniteui-fluent-dark-word.css +1 -1
- package/styles/igniteui-fluent-dark.css +1 -1
- package/styles/igniteui-fluent-light-excel.css +1 -1
- package/styles/igniteui-fluent-light-word.css +1 -1
- package/styles/igniteui-fluent-light.css +1 -1
- package/styles/igniteui-indigo-dark.css +1 -1
- package/styles/igniteui-indigo-light.css +1 -1
- package/styles/maps/igniteui-angular-dark.css.map +1 -1
- package/styles/maps/igniteui-angular.css.map +1 -1
- package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
- package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
- package/styles/maps/igniteui-dark-green.css.map +1 -1
- package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
- package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
- package/styles/maps/igniteui-fluent-dark.css.map +1 -1
- package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
- package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
- package/styles/maps/igniteui-fluent-light.css.map +1 -1
- package/styles/maps/igniteui-indigo-dark.css.map +1 -1
- package/styles/maps/igniteui-indigo-light.css.map +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Component, HostListener, ViewChild, HostBinding, Input, } from "@angular/core";
|
|
2
|
-
import { NgIf, NgStyle, NgTemplateOutlet } from "@angular/common";
|
|
2
|
+
import { NgIf, NgStyle, NgTemplateOutlet, DatePipe } from "@angular/common";
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
4
|
import { IgxMonthsViewComponent } from "../months-view/months-view.component";
|
|
5
5
|
import { IgxYearsViewComponent } from "../years-view/years-view.component";
|
|
@@ -9,6 +9,7 @@ import { IgxCalendarView } from "../calendar";
|
|
|
9
9
|
import { CalendarDay } from "../common/model";
|
|
10
10
|
import { IgxCalendarBaseDirective } from "../calendar-base";
|
|
11
11
|
import { KeyboardNavigationService } from "../calendar.services";
|
|
12
|
+
import { formatToParts } from "../common/helpers";
|
|
12
13
|
import * as i0 from "@angular/core";
|
|
13
14
|
let NEXT_ID = 0;
|
|
14
15
|
export class IgxMonthPickerComponent extends IgxCalendarBaseDirective {
|
|
@@ -52,6 +53,26 @@ export class IgxMonthPickerComponent extends IgxCalendarBaseDirective {
|
|
|
52
53
|
this.viewDate = CalendarDay.from(this.viewDate).add('year', 15).native;
|
|
53
54
|
}
|
|
54
55
|
}
|
|
56
|
+
/**
|
|
57
|
+
* @hidden
|
|
58
|
+
* @internal
|
|
59
|
+
*/
|
|
60
|
+
onActiveViewDecadeKB(date, event, activeViewIdx) {
|
|
61
|
+
super.activeViewDecadeKB(event, activeViewIdx);
|
|
62
|
+
if (this.platform.isActivationKey(event)) {
|
|
63
|
+
this.viewDate = date;
|
|
64
|
+
this.wrapper.nativeElement.focus();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* @hidden
|
|
69
|
+
* @internal
|
|
70
|
+
*/
|
|
71
|
+
onActiveViewDecade(event, date, activeViewIdx) {
|
|
72
|
+
event.preventDefault();
|
|
73
|
+
super.activeViewDecade(activeViewIdx);
|
|
74
|
+
this.viewDate = date;
|
|
75
|
+
}
|
|
55
76
|
/**
|
|
56
77
|
* @hidden
|
|
57
78
|
*/
|
|
@@ -93,7 +114,8 @@ export class IgxMonthPickerComponent extends IgxCalendarBaseDirective {
|
|
|
93
114
|
selectYear(event) {
|
|
94
115
|
this.previousViewDate = this.viewDate;
|
|
95
116
|
this.viewDate = new Date(event.getFullYear(), event.getMonth(), event.getDate());
|
|
96
|
-
this.activeView = IgxCalendarView.
|
|
117
|
+
this.activeView = IgxCalendarView.Year;
|
|
118
|
+
this.wrapper.nativeElement.focus();
|
|
97
119
|
}
|
|
98
120
|
/**
|
|
99
121
|
* @hidden
|
|
@@ -140,13 +162,202 @@ export class IgxMonthPickerComponent extends IgxCalendarBaseDirective {
|
|
|
140
162
|
});
|
|
141
163
|
}
|
|
142
164
|
}
|
|
165
|
+
onMouseDown(event) {
|
|
166
|
+
event.stopPropagation();
|
|
167
|
+
this.wrapper.nativeElement.focus();
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* @hidden
|
|
171
|
+
* @internal
|
|
172
|
+
*/
|
|
173
|
+
set showActiveDay(value) {
|
|
174
|
+
this._showActiveDay = value;
|
|
175
|
+
this.cdr.detectChanges();
|
|
176
|
+
}
|
|
177
|
+
get showActiveDay() {
|
|
178
|
+
return this._showActiveDay;
|
|
179
|
+
}
|
|
180
|
+
get activeDescendant() {
|
|
181
|
+
if (this.activeView === 'month') {
|
|
182
|
+
return this.value?.getTime();
|
|
183
|
+
}
|
|
184
|
+
return this._activeDescendant ?? this.viewDate.getTime();
|
|
185
|
+
}
|
|
186
|
+
set activeDescendant(date) {
|
|
187
|
+
this._activeDescendant = date.getTime();
|
|
188
|
+
}
|
|
189
|
+
get isDefaultView() {
|
|
190
|
+
return this.activeView === IgxCalendarView.Year;
|
|
191
|
+
}
|
|
192
|
+
ngOnInit() {
|
|
193
|
+
this.activeView = IgxCalendarView.Year;
|
|
194
|
+
}
|
|
143
195
|
ngAfterViewInit() {
|
|
196
|
+
this.keyboardNavigation
|
|
197
|
+
.attachKeyboardHandlers(this.wrapper, this)
|
|
198
|
+
.set("ArrowUp", this.onArrowUp)
|
|
199
|
+
.set("ArrowDown", this.onArrowDown)
|
|
200
|
+
.set("ArrowLeft", this.onArrowLeft)
|
|
201
|
+
.set("ArrowRight", this.onArrowRight)
|
|
202
|
+
.set("Enter", this.onEnter)
|
|
203
|
+
.set(" ", this.onEnter)
|
|
204
|
+
.set("Home", this.onHome)
|
|
205
|
+
.set("End", this.onEnd)
|
|
206
|
+
.set("PageUp", this.handlePageUp)
|
|
207
|
+
.set("PageDown", this.handlePageDown);
|
|
208
|
+
this.wrapper.nativeElement.addEventListener('focus', (event) => this.onWrapperFocus(event));
|
|
209
|
+
this.wrapper.nativeElement.addEventListener('blur', (event) => this.onWrapperBlur(event));
|
|
144
210
|
this.activeView$.subscribe((view) => {
|
|
145
211
|
this.activeViewChanged.emit(view);
|
|
212
|
+
this.viewDateChanged.emit({
|
|
213
|
+
previousValue: this.previousViewDate,
|
|
214
|
+
currentValue: this.viewDate
|
|
215
|
+
});
|
|
146
216
|
});
|
|
147
217
|
}
|
|
218
|
+
onWrapperFocus(event) {
|
|
219
|
+
event.stopPropagation();
|
|
220
|
+
this.showActiveDay = true;
|
|
221
|
+
}
|
|
222
|
+
onWrapperBlur(event) {
|
|
223
|
+
event.stopPropagation();
|
|
224
|
+
this.showActiveDay = false;
|
|
225
|
+
this._onTouchedCallback();
|
|
226
|
+
}
|
|
227
|
+
handlePageUpDown(event, delta) {
|
|
228
|
+
event.preventDefault();
|
|
229
|
+
event.stopPropagation();
|
|
230
|
+
if (this.isDefaultView && event.shiftKey) {
|
|
231
|
+
this.viewDate = CalendarDay.from(this.viewDate).add('year', delta).native;
|
|
232
|
+
this.cdr.detectChanges();
|
|
233
|
+
}
|
|
234
|
+
else {
|
|
235
|
+
delta > 0 ? this.nextPage() : this.previousPage();
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
handlePageUp(event) {
|
|
239
|
+
this.handlePageUpDown(event, -1);
|
|
240
|
+
}
|
|
241
|
+
handlePageDown(event) {
|
|
242
|
+
this.handlePageUpDown(event, 1);
|
|
243
|
+
}
|
|
244
|
+
onArrowUp(event) {
|
|
245
|
+
if (this.isDefaultView) {
|
|
246
|
+
this.monthsView.onKeydownArrowUp(event);
|
|
247
|
+
}
|
|
248
|
+
if (this.isDecadeView) {
|
|
249
|
+
this.dacadeView.onKeydownArrowUp(event);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
onArrowDown(event) {
|
|
253
|
+
if (this.isDefaultView) {
|
|
254
|
+
this.monthsView.onKeydownArrowDown(event);
|
|
255
|
+
}
|
|
256
|
+
if (this.isDecadeView) {
|
|
257
|
+
this.dacadeView.onKeydownArrowDown(event);
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
onArrowLeft(event) {
|
|
261
|
+
if (this.isDefaultView) {
|
|
262
|
+
this.monthsView.onKeydownArrowLeft(event);
|
|
263
|
+
}
|
|
264
|
+
if (this.isDecadeView) {
|
|
265
|
+
this.dacadeView.onKeydownArrowLeft(event);
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
onArrowRight(event) {
|
|
269
|
+
if (this.isDefaultView) {
|
|
270
|
+
this.monthsView.onKeydownArrowRight(event);
|
|
271
|
+
}
|
|
272
|
+
if (this.isDecadeView) {
|
|
273
|
+
this.dacadeView.onKeydownArrowRight(event);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
onEnter(event) {
|
|
277
|
+
event.stopPropagation();
|
|
278
|
+
if (this.isDefaultView) {
|
|
279
|
+
this.monthsView.onKeydownEnter(event);
|
|
280
|
+
}
|
|
281
|
+
if (this.isDecadeView) {
|
|
282
|
+
this.dacadeView.onKeydownEnter(event);
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
onHome(event) {
|
|
286
|
+
event.stopPropagation();
|
|
287
|
+
if (this.isDefaultView) {
|
|
288
|
+
this.monthsView.onKeydownHome(event);
|
|
289
|
+
}
|
|
290
|
+
if (this.isDecadeView) {
|
|
291
|
+
this.dacadeView.onKeydownHome(event);
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
onEnd(event) {
|
|
295
|
+
event.stopPropagation();
|
|
296
|
+
if (this.isDefaultView) {
|
|
297
|
+
this.monthsView.onKeydownEnd(event);
|
|
298
|
+
}
|
|
299
|
+
if (this.isDecadeView) {
|
|
300
|
+
this.dacadeView.onKeydownEnd(event);
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
/**
|
|
304
|
+
* @hidden
|
|
305
|
+
* @internal
|
|
306
|
+
*/
|
|
307
|
+
ngOnDestroy() {
|
|
308
|
+
this.keyboardNavigation.detachKeyboardHandlers();
|
|
309
|
+
this.wrapper?.nativeElement.removeEventListener('focus', this.onWrapperFocus);
|
|
310
|
+
this.wrapper?.nativeElement.removeEventListener('blur', this.onWrapperBlur);
|
|
311
|
+
}
|
|
312
|
+
/**
|
|
313
|
+
* @hidden
|
|
314
|
+
* @internal
|
|
315
|
+
*/
|
|
316
|
+
getPrevYearDate(date) {
|
|
317
|
+
return CalendarDay.from(date).add('year', -1).native;
|
|
318
|
+
}
|
|
319
|
+
/**
|
|
320
|
+
* @hidden
|
|
321
|
+
* @internal
|
|
322
|
+
*/
|
|
323
|
+
getNextYearDate(date) {
|
|
324
|
+
return CalendarDay.from(date).add('year', 1).native;
|
|
325
|
+
}
|
|
326
|
+
/**
|
|
327
|
+
* Getter for the context object inside the calendar templates.
|
|
328
|
+
*
|
|
329
|
+
* @hidden
|
|
330
|
+
* @internal
|
|
331
|
+
*/
|
|
332
|
+
getContext(i) {
|
|
333
|
+
const date = CalendarDay.from(this.viewDate).add('month', i).native;
|
|
334
|
+
return this.generateContext(date, i);
|
|
335
|
+
}
|
|
336
|
+
/**
|
|
337
|
+
* Helper method building and returning the context object inside the calendar templates.
|
|
338
|
+
*
|
|
339
|
+
* @hidden
|
|
340
|
+
* @internal
|
|
341
|
+
*/
|
|
342
|
+
generateContext(value, i) {
|
|
343
|
+
const construct = (date, index) => ({
|
|
344
|
+
index: index,
|
|
345
|
+
date,
|
|
346
|
+
...formatToParts(date, this.locale, this.formatOptions, [
|
|
347
|
+
"era",
|
|
348
|
+
"year",
|
|
349
|
+
"month",
|
|
350
|
+
"day",
|
|
351
|
+
"weekday",
|
|
352
|
+
]),
|
|
353
|
+
});
|
|
354
|
+
const formatObject = Array.isArray(value)
|
|
355
|
+
? value.map((date, index) => construct(date, index))
|
|
356
|
+
: construct(value, i);
|
|
357
|
+
return { $implicit: formatObject };
|
|
358
|
+
}
|
|
148
359
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxMonthPickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
149
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: IgxMonthPickerComponent, isStandalone: true, selector: "igx-month-picker", inputs: { id: "id" }, host: { listeners: { "keydown.pageup": "previousPage($event)", "keydown.pagedown": "nextPage($event)" }, properties: { "attr.id": "this.id", "class.igx-month-picker": "this.styleClass" } }, providers: [
|
|
360
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", type: IgxMonthPickerComponent, isStandalone: true, selector: "igx-month-picker", inputs: { id: "id" }, host: { listeners: { "keydown.pageup": "previousPage($event)", "keydown.pagedown": "nextPage($event)", "mousedown": "onMouseDown($event)" }, properties: { "attr.id": "this.id", "class.igx-month-picker": "this.styleClass" } }, providers: [
|
|
150
361
|
{
|
|
151
362
|
multi: true,
|
|
152
363
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -156,7 +367,7 @@ export class IgxMonthPickerComponent extends IgxCalendarBaseDirective {
|
|
|
156
367
|
multi: false,
|
|
157
368
|
provide: KeyboardNavigationService
|
|
158
369
|
},
|
|
159
|
-
], viewQueries: [{ propertyName: "monthsView", first: true, predicate: ["months"], descendants: true, read: IgxMonthsViewComponent }, { propertyName: "dacadeView", first: true, predicate: ["decade"], descendants: true, read: IgxYearsViewComponent }, { propertyName: "daysView", first: true, predicate: ["days"], descendants: true, read: IgxDaysViewComponent }, { propertyName: "yearsBtn", first: true, predicate: ["yearsBtn"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--
|
|
370
|
+
], viewQueries: [{ propertyName: "wrapper", first: true, predicate: ["wrapper"], descendants: true }, { propertyName: "monthsView", first: true, predicate: ["months"], descendants: true, read: IgxMonthsViewComponent }, { propertyName: "dacadeView", first: true, predicate: ["decade"], descendants: true, read: IgxYearsViewComponent }, { propertyName: "daysView", first: true, predicate: ["days"], descendants: true, read: IgxDaysViewComponent }, { propertyName: "yearsBtn", first: true, predicate: ["yearsBtn"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!-- Previous arrow icon -->\n<ng-template #prevArrow let-obj>\n <igx-icon aria-hidden=\"true\">keyboard_arrow_left</igx-icon>\n</ng-template>\n\n<!-- Next arrow icon -->\n<ng-template #nextArrow let-obj>\n <igx-icon aria-hidden=\"true\">keyboard_arrow_right</igx-icon>\n</ng-template>\n\n<!-- Previous picker button -->\n<ng-template #prevPageButton let-obj>\n <div\n #prevPageBtn\n tabindex=\"0\"\n class=\"igx-calendar-picker__prev\"\n role=\"button\"\n [attr.aria-label]=\"prevNavLabel((getPrevYearDate(viewDate) | date: 'YYYY'))\"\n data-action=\"prev\"\n igxCalendarScrollPage\n (mousedown)=\"previousPage()\"\n (keydown)=\"changePageKB($event, false)\"\n >\n <ng-container *ngTemplateOutlet=\"prevArrow\"></ng-container>\n </div>\n</ng-template>\n\n<!-- Next picker button -->\n<ng-template #nextPageButton let-obj>\n <div\n #nextPageBtn\n tabindex=\"0\"\n class=\"igx-calendar-picker__next\"\n role=\"button\"\n [attr.aria-label]=\"nextNavLabel((getNextYearDate(viewDate) | date: 'YYYY'))\"\n data-action=\"next\"\n igxCalendarScrollPage\n (mousedown)=\"nextPage()\"\n (keydown)=\"changePageKB($event)\"\n >\n <ng-container *ngTemplateOutlet=\"nextArrow\"></ng-container>\n </div>\n</ng-template>\n\n<!-- Year -->\n<ng-template #defaultYear let-obj>\n <span *ngIf=\"activeView === 'year'\" class=\"igx-calendar__aria-off-screen\" aria-live=\"polite\">{{ formattedYear(obj.date) }}</span>\n <span\n #yearsBtn\n tabindex=\"0\"\n role=\"button\"\n [attr.aria-label]=\"(obj.date | date: 'yyyy') + ', ' + resourceStrings.igx_calendar_select_year\"\n (keydown)=\"onActiveViewDecadeKB(obj.date, $event, obj.index)\"\n (mousedown)=\"onActiveViewDecade($event, obj.date, obj.index)\"\n class=\"igx-calendar-picker__date\">\n {{ formattedYear(obj.date) }}\n </span>\n</ng-template>\n\n<!-- Decade -->\n<ng-template #defaultDecade>\n <span>{{ getDecadeRange().start }} - {{ getDecadeRange().end }}</span>\n</ng-template>\n\n<!-- PICKER IN MONTHS -->\n<ng-template #calendarYearPicker>\n <section class=\"igx-calendar-picker\">\n <div class=\"igx-calendar-picker__dates\">\n <ng-container\n *ngTemplateOutlet=\"defaultYear; context: getContext(0)\">\n </ng-container>\n </div>\n <div class=\"igx-calendar-picker__nav\">\n <ng-container *ngTemplateOutlet=\"prevPageButton\"></ng-container>\n <ng-container *ngTemplateOutlet=\"nextPageButton\"></ng-container>\n </div>\n </section>\n</ng-template>\n\n<!-- PICKER IN YEARS -->\n<ng-template #calendarDecadePicker>\n <section class=\"igx-calendar-picker\">\n <div class=\"igx-calendar-picker__dates\" aria-live=\"polite\">\n <ng-container\n *ngTemplateOutlet=\"defaultDecade;\">\n </ng-container>\n </div>\n <div class=\"igx-calendar-picker__nav\">\n <ng-container *ngTemplateOutlet=\"prevPageButton\"></ng-container>\n <ng-container *ngTemplateOutlet=\"nextPageButton\"></ng-container>\n </div>\n </section>\n</ng-template>\n\n<div\n #wrapper\n [tabIndex]=\"0\"\n class=\"igx-calendar__wrapper\"\n [attr.aria-activedescendant]=\"activeDescendant\"\n [attr.aria-multiselectable]=\"selection !== 'single'\"\n aria-labelledby=\"calendar-desc\"\n role=\"grid\"\n >\n <caption id=\"calendar-desc\" tabindex=\"-1\" class=\"igx-calendar__aria-off-screen\">\n {{ resourceStrings.igx_calendar_singular_single_selection}}\n </caption>\n\n <section class=\"igx-calendar__pickers\">\n <ng-container *ngIf=\"isDefaultView\">\n <ng-container *ngTemplateOutlet=\"calendarYearPicker\"></ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"isDecadeView\">\n <ng-container *ngTemplateOutlet=\"calendarDecadePicker\"></ng-container>\n </ng-container>\n </section>\n\n <section class=\"igx-calendar__body\">\n <ng-container *ngIf=\"isDefaultView\">\n <igx-months-view\n #months\n role=\"rowgroup\"\n [tabIndex]=\"-1\"\n [date]=\"viewDate\"\n [locale]=\"locale\"\n [formatView]=\"formatViews.month\"\n [monthFormat]=\"formatOptions.month\"\n [showActive]=\"showActiveDay\"\n [standalone]=\"false\"\n (swiperight)=\"previousPage()\"\n (swipeleft)=\"nextPage()\"\n (selected)=\"selectMonth($event)\"\n (pageChanged)=\"updateDate($event)\"\n (mousedown)=\"$event.preventDefault()\">\n >\n </igx-months-view>\n </ng-container>\n\n <ng-container *ngIf=\"isDecadeView\">\n <igx-years-view\n #decade\n role=\"rowgroup\"\n [tabIndex]=\"-1\"\n [date]=\"viewDate\"\n [locale]=\"locale\"\n [formatView]=\"formatViews.year\"\n [yearFormat]=\"formatOptions.year\"\n [showActive]=\"showActiveDay\"\n [standalone]=\"false\"\n (swiperight)=\"previousPage()\"\n (swipeleft)=\"nextPage()\"\n (selected)=\"selectYear($event)\"\n (pageChanged)=\"updateDate($event)\"\n (mousedown)=\"$event.preventDefault()\"\n >\n </igx-years-view>\n </ng-container>\n </section>\n</div>\n", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "component", type: IgxIconComponent, selector: "igx-icon", inputs: ["family", "active", "name"] }, { kind: "component", type: IgxMonthsViewComponent, selector: "igx-months-view", inputs: ["id", "standalone", "monthFormat", "formatView"] }, { kind: "component", type: IgxYearsViewComponent, selector: "igx-years-view", inputs: ["standalone", "yearFormat"] }] }); }
|
|
160
371
|
}
|
|
161
372
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: IgxMonthPickerComponent, decorators: [{
|
|
162
373
|
type: Component,
|
|
@@ -174,15 +385,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
174
385
|
NgIf,
|
|
175
386
|
NgStyle,
|
|
176
387
|
NgTemplateOutlet,
|
|
388
|
+
DatePipe,
|
|
177
389
|
IgxIconComponent,
|
|
178
390
|
IgxMonthsViewComponent,
|
|
179
391
|
IgxYearsViewComponent,
|
|
180
|
-
], template: "<!--
|
|
392
|
+
], template: "<!-- Previous arrow icon -->\n<ng-template #prevArrow let-obj>\n <igx-icon aria-hidden=\"true\">keyboard_arrow_left</igx-icon>\n</ng-template>\n\n<!-- Next arrow icon -->\n<ng-template #nextArrow let-obj>\n <igx-icon aria-hidden=\"true\">keyboard_arrow_right</igx-icon>\n</ng-template>\n\n<!-- Previous picker button -->\n<ng-template #prevPageButton let-obj>\n <div\n #prevPageBtn\n tabindex=\"0\"\n class=\"igx-calendar-picker__prev\"\n role=\"button\"\n [attr.aria-label]=\"prevNavLabel((getPrevYearDate(viewDate) | date: 'YYYY'))\"\n data-action=\"prev\"\n igxCalendarScrollPage\n (mousedown)=\"previousPage()\"\n (keydown)=\"changePageKB($event, false)\"\n >\n <ng-container *ngTemplateOutlet=\"prevArrow\"></ng-container>\n </div>\n</ng-template>\n\n<!-- Next picker button -->\n<ng-template #nextPageButton let-obj>\n <div\n #nextPageBtn\n tabindex=\"0\"\n class=\"igx-calendar-picker__next\"\n role=\"button\"\n [attr.aria-label]=\"nextNavLabel((getNextYearDate(viewDate) | date: 'YYYY'))\"\n data-action=\"next\"\n igxCalendarScrollPage\n (mousedown)=\"nextPage()\"\n (keydown)=\"changePageKB($event)\"\n >\n <ng-container *ngTemplateOutlet=\"nextArrow\"></ng-container>\n </div>\n</ng-template>\n\n<!-- Year -->\n<ng-template #defaultYear let-obj>\n <span *ngIf=\"activeView === 'year'\" class=\"igx-calendar__aria-off-screen\" aria-live=\"polite\">{{ formattedYear(obj.date) }}</span>\n <span\n #yearsBtn\n tabindex=\"0\"\n role=\"button\"\n [attr.aria-label]=\"(obj.date | date: 'yyyy') + ', ' + resourceStrings.igx_calendar_select_year\"\n (keydown)=\"onActiveViewDecadeKB(obj.date, $event, obj.index)\"\n (mousedown)=\"onActiveViewDecade($event, obj.date, obj.index)\"\n class=\"igx-calendar-picker__date\">\n {{ formattedYear(obj.date) }}\n </span>\n</ng-template>\n\n<!-- Decade -->\n<ng-template #defaultDecade>\n <span>{{ getDecadeRange().start }} - {{ getDecadeRange().end }}</span>\n</ng-template>\n\n<!-- PICKER IN MONTHS -->\n<ng-template #calendarYearPicker>\n <section class=\"igx-calendar-picker\">\n <div class=\"igx-calendar-picker__dates\">\n <ng-container\n *ngTemplateOutlet=\"defaultYear; context: getContext(0)\">\n </ng-container>\n </div>\n <div class=\"igx-calendar-picker__nav\">\n <ng-container *ngTemplateOutlet=\"prevPageButton\"></ng-container>\n <ng-container *ngTemplateOutlet=\"nextPageButton\"></ng-container>\n </div>\n </section>\n</ng-template>\n\n<!-- PICKER IN YEARS -->\n<ng-template #calendarDecadePicker>\n <section class=\"igx-calendar-picker\">\n <div class=\"igx-calendar-picker__dates\" aria-live=\"polite\">\n <ng-container\n *ngTemplateOutlet=\"defaultDecade;\">\n </ng-container>\n </div>\n <div class=\"igx-calendar-picker__nav\">\n <ng-container *ngTemplateOutlet=\"prevPageButton\"></ng-container>\n <ng-container *ngTemplateOutlet=\"nextPageButton\"></ng-container>\n </div>\n </section>\n</ng-template>\n\n<div\n #wrapper\n [tabIndex]=\"0\"\n class=\"igx-calendar__wrapper\"\n [attr.aria-activedescendant]=\"activeDescendant\"\n [attr.aria-multiselectable]=\"selection !== 'single'\"\n aria-labelledby=\"calendar-desc\"\n role=\"grid\"\n >\n <caption id=\"calendar-desc\" tabindex=\"-1\" class=\"igx-calendar__aria-off-screen\">\n {{ resourceStrings.igx_calendar_singular_single_selection}}\n </caption>\n\n <section class=\"igx-calendar__pickers\">\n <ng-container *ngIf=\"isDefaultView\">\n <ng-container *ngTemplateOutlet=\"calendarYearPicker\"></ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"isDecadeView\">\n <ng-container *ngTemplateOutlet=\"calendarDecadePicker\"></ng-container>\n </ng-container>\n </section>\n\n <section class=\"igx-calendar__body\">\n <ng-container *ngIf=\"isDefaultView\">\n <igx-months-view\n #months\n role=\"rowgroup\"\n [tabIndex]=\"-1\"\n [date]=\"viewDate\"\n [locale]=\"locale\"\n [formatView]=\"formatViews.month\"\n [monthFormat]=\"formatOptions.month\"\n [showActive]=\"showActiveDay\"\n [standalone]=\"false\"\n (swiperight)=\"previousPage()\"\n (swipeleft)=\"nextPage()\"\n (selected)=\"selectMonth($event)\"\n (pageChanged)=\"updateDate($event)\"\n (mousedown)=\"$event.preventDefault()\">\n >\n </igx-months-view>\n </ng-container>\n\n <ng-container *ngIf=\"isDecadeView\">\n <igx-years-view\n #decade\n role=\"rowgroup\"\n [tabIndex]=\"-1\"\n [date]=\"viewDate\"\n [locale]=\"locale\"\n [formatView]=\"formatViews.year\"\n [yearFormat]=\"formatOptions.year\"\n [showActive]=\"showActiveDay\"\n [standalone]=\"false\"\n (swiperight)=\"previousPage()\"\n (swipeleft)=\"nextPage()\"\n (selected)=\"selectYear($event)\"\n (pageChanged)=\"updateDate($event)\"\n (mousedown)=\"$event.preventDefault()\"\n >\n </igx-years-view>\n </ng-container>\n </section>\n</div>\n" }]
|
|
181
393
|
}], propDecorators: { id: [{
|
|
182
394
|
type: HostBinding,
|
|
183
395
|
args: ["attr.id"]
|
|
184
396
|
}, {
|
|
185
397
|
type: Input
|
|
398
|
+
}], wrapper: [{
|
|
399
|
+
type: ViewChild,
|
|
400
|
+
args: ["wrapper"]
|
|
186
401
|
}], styleClass: [{
|
|
187
402
|
type: HostBinding,
|
|
188
403
|
args: ["class.igx-month-picker"]
|
|
@@ -204,5 +419,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
204
419
|
}], nextPage: [{
|
|
205
420
|
type: HostListener,
|
|
206
421
|
args: ["keydown.pagedown", ["$event"]]
|
|
422
|
+
}], onMouseDown: [{
|
|
423
|
+
type: HostListener,
|
|
424
|
+
args: ['mousedown', ['$event']]
|
|
207
425
|
}] } });
|
|
208
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/calendar/month-picker/month-picker.component.ts","../../../../../../projects/igniteui-angular/src/lib/calendar/month-picker/month-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostListener,\n    ViewChild,\n    HostBinding,\n    Input,\n    ElementRef,\n    AfterViewInit,\n} from \"@angular/core\";\nimport { NgIf, NgStyle, NgTemplateOutlet } from \"@angular/common\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { IgxMonthsViewComponent } from \"../months-view/months-view.component\";\nimport { IgxYearsViewComponent } from \"../years-view/years-view.component\";\nimport { IgxDaysViewComponent } from \"../days-view/days-view.component\";\nimport { IgxIconComponent } from \"../../icon/icon.component\";\nimport { IgxCalendarView } from \"../calendar\";\nimport { CalendarDay } from \"../common/model\";\nimport { IgxCalendarBaseDirective } from \"../calendar-base\";\nimport { KeyboardNavigationService } from \"../calendar.services\";\n\nlet NEXT_ID = 0;\n@Component({\n    providers: [\n        {\n            multi: true,\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxMonthPickerComponent,\n        },\n        {\n            multi: false,\n            provide: KeyboardNavigationService\n        },\n    ],\n    selector: \"igx-month-picker\",\n    templateUrl: \"month-picker.component.html\",\n    standalone: true,\n    imports: [\n        NgIf,\n        NgStyle,\n        NgTemplateOutlet,\n        IgxIconComponent,\n        IgxMonthsViewComponent,\n        IgxYearsViewComponent,\n    ],\n})\nexport class IgxMonthPickerComponent extends IgxCalendarBaseDirective implements AfterViewInit {\n    /**\n     * Sets/gets the `id` of the month picker.\n     * If not set, the `id` will have value `\"igx-month-picker-0\"`.\n     */\n    @HostBinding(\"attr.id\")\n    @Input()\n    public id = `igx-month-picker-${NEXT_ID++}`;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding(\"class.igx-month-picker\")\n    public styleClass = true;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"months\", { read: IgxMonthsViewComponent })\n    public monthsView: IgxMonthsViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"decade\", { read: IgxYearsViewComponent })\n    public dacadeView: IgxYearsViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"days\", { read: IgxDaysViewComponent })\n    public daysView: IgxDaysViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"yearsBtn\")\n    public yearsBtn: ElementRef;\n\n    /**\n     * @hidden\n     */\n    @HostListener(\"keydown.pageup\", [\"$event\"])\n    public previousPage(event?: KeyboardEvent) {\n        event?.preventDefault();\n        this.previousViewDate = this.viewDate;\n\n        if (this.isDefaultView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', -1).native;\n        }\n\n        if (this.isDecadeView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', -15).native;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener(\"keydown.pagedown\", [\"$event\"])\n    public nextPage(event?: KeyboardEvent) {\n        event?.preventDefault();\n        this.previousViewDate = this.viewDate;\n\n        if (this.isDefaultView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', 1).native;\n        }\n\n        if (this.isDecadeView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', 15).native;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override activeViewDecadeKB(event: KeyboardEvent) {\n        super.activeViewDecadeKB(event);\n\n        if (event.key === this.platform.KEYMAP.ARROW_RIGHT) {\n            this.nextPage(event);\n        }\n\n        if (event.key === this.platform.KEYMAP.ARROW_LEFT) {\n            this.previousPage(event);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override activeViewDecade() {\n        super.activeViewDecade();\n\n        requestAnimationFrame(() => {\n            this.dacadeView.el.nativeElement.focus();\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public changePageKB(event: KeyboardEvent, next = true) {\n        if (this.platform.isActivationKey(event)) {\n            event.stopPropagation();\n\n            if (next) {\n                this.nextPage();\n            } else {\n                this.previousPage();\n            }\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public selectYear(event: Date) {\n        this.previousViewDate = this.viewDate;\n\n        this.viewDate = new Date(\n            event.getFullYear(),\n            event.getMonth(),\n            event.getDate(),\n        );\n\n        this.activeView = IgxCalendarView.Month;\n    }\n\n    /**\n     * @hidden\n     */\n    public selectMonth(event: Date) {\n        this.selectDate(event);\n        this.selected.emit(this.selectedDates);\n    }\n\n    /**\n     * Selects a date.\n     * ```typescript\n     *  this.monthPicker.selectDate(new Date(`2018-06-12`));\n     * ```\n     */\n    public override selectDate(value: Date) {\n        if (!value) {\n            return new Date();\n        }\n\n        super.selectDate(value);\n        this.viewDate = value;\n    }\n\n    /**\n     * @hidden\n     */\n    public getNextYear() {\n        return CalendarDay.from(this.viewDate).add('year', 1).year;\n    }\n\n    /**\n     * @hidden\n     */\n    public getPreviousYear() {\n        return CalendarDay.from(this.viewDate).add('year', -1).year;\n    }\n\n    /**\n     * @hidden\n     */\n    public updateDate(date: Date) {\n        this.previousViewDate = this.viewDate;\n        this.viewDate = CalendarDay.from(date).add('year', -this.activeViewIdx).native;\n\n        if (this.isDefaultView) {\n            this.viewDateChanged.emit({\n                previousValue: this.previousViewDate,\n                currentValue: this.viewDate,\n            });\n        }\n    }\n\n    public ngAfterViewInit() {\n        this.activeView$.subscribe((view) => {\n            this.activeViewChanged.emit(view);\n        });\n    }\n}\n","<!-- Picker Info -->\n\n<!-- Month -->\n<ng-template #defaultMonth>\n    <span\n        #yearsBtn\n        tabindex=\"0\"\n        aria-live=\"polite\"\n        class=\"igx-calendar-picker__date\"\n        (keydown)=\"activeViewDecadeKB($event)\"\n        (click)=\"activeViewDecade()\"\n    >\n        {{ formattedYear(viewDate) }}\n    </span>\n</ng-template>\n\n<!-- Years -->\n<ng-template #defaultYears>\n    <span>{{ getDecadeRange().start }}</span>\n    <span>&nbsp;-&nbsp;</span>\n    <span>{{ getDecadeRange().end }}</span>\n</ng-template>\n\n<!-- Picker Arrows -->\n\n<!-- Months -->\n<ng-template #calendarMonthPicker>\n    <section class=\"igx-calendar-picker\">\n        <div [style.width.%]=\"100\">\n            <ng-container *ngTemplateOutlet=\"defaultMonth\"></ng-container>\n        </div>\n        <div class=\"igx-calendar-picker__nav\">\n            <div\n                role=\"button\"\n                tabindex=\"0\"\n                class=\"igx-calendar-picker__prev\"\n                [attr.aria-label]=\"'Previous Year ' + getPreviousYear()\"\n                (click)=\"previousPage()\"\n                (keydown)=\"changePageKB($event, false)\"\n                data-action=\"prev\"\n            >\n                <igx-icon>keyboard_arrow_left</igx-icon>\n            </div>\n            <div\n                role=\"button\"\n                tabindex=\"0\"\n                class=\"igx-calendar-picker__next\"\n                [attr.aria-label]=\"'Next Year ' + getNextYear()\"\n                (click)=\"nextPage()\"\n                (keydown)=\"changePageKB($event)\"\n                data-action=\"next\"\n            >\n                <igx-icon>keyboard_arrow_right</igx-icon>\n            </div>\n        </div>\n    </section>\n</ng-template>\n\n<!-- Years -->\n<ng-template #calendarYearsPicker>\n    <section class=\"igx-calendar-picker\">\n        <div [style.width.%]=\"100\">\n            <ng-container *ngTemplateOutlet=\"defaultYears\"></ng-container>\n        </div>\n        <div class=\"igx-calendar-picker__nav\">\n            <div\n                tabindex=\"0\"\n                class=\"igx-calendar-picker__prev\"\n                role=\"button\"\n                data-action=\"prev\"\n                (click)=\"previousPage()\"\n                (keydown)=\"changePageKB($event, false)\"\n                data-action=\"prev\"\n            >\n                <igx-icon aria-hidden=\"true\">keyboard_arrow_left</igx-icon>\n            </div>\n            <div\n                tabindex=\"0\"\n                class=\"igx-calendar-picker__next\"\n                role=\"button\"\n                data-action=\"next\"\n                (click)=\"nextPage()\"\n                (keydown)=\"changePageKB($event)\"\n                data-action=\"next\"\n            >\n                <igx-icon aria-hidden=\"true\">keyboard_arrow_right</igx-icon>\n            </div>\n        </div>\n    </section>\n</ng-template>\n\n<!-- Outlets -->\n\n<!-- Months -->\n<div\n    *ngIf=\"isDefaultView\"\n    class=\"igx-months-view__body\"\n    (swiperight)=\"previousPage()\"\n    (swipeleft)=\"nextPage()\"\n>\n    <ng-container *ngTemplateOutlet=\"calendarMonthPicker\"></ng-container>\n    <igx-months-view\n        #months\n        [date]=\"viewDate\"\n        [locale]=\"locale\"\n        [formatView]=\"formatViews.month\"\n        [monthFormat]=\"formatOptions.month\"\n        (selected)=\"selectMonth($event)\"\n        (pageChanged)=\"updateDate($event)\"\n    >\n    </igx-months-view>\n</div>\n\n<!-- Years -->\n<div *ngIf=\"isDecadeView\">\n    <ng-container *ngTemplateOutlet=\"calendarYearsPicker\"></ng-container>\n    <igx-years-view\n        #decade\n        *ngIf=\"isDecadeView\"\n        [date]=\"viewDate\"\n        [locale]=\"locale\"\n        [formatView]=\"formatViews.year\"\n        [yearFormat]=\"formatOptions.year\"\n        (selected)=\"selectYear($event)\"\n        (pageChanged)=\"updateDate($event)\"\n    >\n    </igx-years-view>\n</div>\n"]}
|
|
426
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"month-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/calendar/month-picker/month-picker.component.ts","../../../../../../projects/igniteui-angular/src/lib/calendar/month-picker/month-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostListener,\n    ViewChild,\n    HostBinding,\n    Input,\n    ElementRef,\n    AfterViewInit,\n    OnDestroy,\n    OnInit,\n} from \"@angular/core\";\nimport { NgIf, NgStyle, NgTemplateOutlet, DatePipe } from \"@angular/common\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { IgxMonthsViewComponent } from \"../months-view/months-view.component\";\nimport { IgxYearsViewComponent } from \"../years-view/years-view.component\";\nimport { IgxDaysViewComponent } from \"../days-view/days-view.component\";\nimport { IgxIconComponent } from \"../../icon/icon.component\";\nimport { IgxCalendarView } from \"../calendar\";\nimport { CalendarDay } from \"../common/model\";\nimport { IgxCalendarBaseDirective } from \"../calendar-base\";\nimport { KeyboardNavigationService } from \"../calendar.services\";\nimport { formatToParts } from \"../common/helpers\";\n\nlet NEXT_ID = 0;\n@Component({\n    providers: [\n        {\n            multi: true,\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxMonthPickerComponent,\n        },\n        {\n            multi: false,\n            provide: KeyboardNavigationService\n        },\n    ],\n    selector: \"igx-month-picker\",\n    templateUrl: \"month-picker.component.html\",\n    standalone: true,\n    imports: [\n        NgIf,\n        NgStyle,\n        NgTemplateOutlet,\n        DatePipe,\n        IgxIconComponent,\n        IgxMonthsViewComponent,\n        IgxYearsViewComponent,\n    ],\n})\nexport class IgxMonthPickerComponent extends IgxCalendarBaseDirective implements OnInit, AfterViewInit, OnDestroy {\n    /**\n     * Sets/gets the `id` of the month picker.\n     * If not set, the `id` will have value `\"igx-month-picker-0\"`.\n     */\n    @HostBinding(\"attr.id\")\n    @Input()\n    public id = `igx-month-picker-${NEXT_ID++}`;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _activeDescendant: number;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    @ViewChild(\"wrapper\")\n    public wrapper: ElementRef;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding(\"class.igx-month-picker\")\n    public styleClass = true;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"months\", { read: IgxMonthsViewComponent })\n    public monthsView: IgxMonthsViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"decade\", { read: IgxYearsViewComponent })\n    public dacadeView: IgxYearsViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"days\", { read: IgxDaysViewComponent })\n    public daysView: IgxDaysViewComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(\"yearsBtn\")\n    public yearsBtn: ElementRef;\n\n    /**\n     * @hidden\n     */\n    @HostListener(\"keydown.pageup\", [\"$event\"])\n    public previousPage(event?: KeyboardEvent) {\n        event?.preventDefault();\n        this.previousViewDate = this.viewDate;\n\n        if (this.isDefaultView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', -1).native;\n        }\n\n        if (this.isDecadeView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', -15).native;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener(\"keydown.pagedown\", [\"$event\"])\n    public nextPage(event?: KeyboardEvent) {\n        event?.preventDefault();\n        this.previousViewDate = this.viewDate;\n\n        if (this.isDefaultView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', 1).native;\n        }\n\n        if (this.isDecadeView) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', 15).native;\n        }\n    }\n\n\t/**\n\t * @hidden\n\t * @internal\n\t */\n\tpublic onActiveViewDecadeKB(date: Date, event: KeyboardEvent, activeViewIdx: number) {\n\t\tsuper.activeViewDecadeKB(event, activeViewIdx);\n\n\t\tif (this.platform.isActivationKey(event)) {\n            this.viewDate = date;\n            this.wrapper.nativeElement.focus();\n\t\t}\n\t}\n\n\t/**\n\t * @hidden\n\t * @internal\n\t */\n\tpublic onActiveViewDecade(event: MouseEvent, date: Date, activeViewIdx: number): void {\n        event.preventDefault();\n\n\t\tsuper.activeViewDecade(activeViewIdx);\n        this.viewDate = date;\n\t}\n\n    /**\n     * @hidden\n     */\n    public override activeViewDecadeKB(event: KeyboardEvent) {\n        super.activeViewDecadeKB(event);\n\n        if (event.key === this.platform.KEYMAP.ARROW_RIGHT) {\n            this.nextPage(event);\n        }\n\n        if (event.key === this.platform.KEYMAP.ARROW_LEFT) {\n            this.previousPage(event);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override activeViewDecade() {\n        super.activeViewDecade();\n\n        requestAnimationFrame(() => {\n            this.dacadeView.el.nativeElement.focus();\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public changePageKB(event: KeyboardEvent, next = true) {\n        if (this.platform.isActivationKey(event)) {\n            event.stopPropagation();\n\n            if (next) {\n                this.nextPage();\n            } else {\n                this.previousPage();\n            }\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public selectYear(event: Date) {\n        this.previousViewDate = this.viewDate;\n\n        this.viewDate = new Date(\n            event.getFullYear(),\n            event.getMonth(),\n            event.getDate(),\n        );\n\n        this.activeView = IgxCalendarView.Year;\n        this.wrapper.nativeElement.focus();\n    }\n\n    /**\n     * @hidden\n     */\n    public selectMonth(event: Date) {\n        this.selectDate(event);\n        this.selected.emit(this.selectedDates);\n    }\n\n    /**\n     * Selects a date.\n     * ```typescript\n     *  this.monthPicker.selectDate(new Date(`2018-06-12`));\n     * ```\n     */\n    public override selectDate(value: Date) {\n        if (!value) {\n            return new Date();\n        }\n\n        super.selectDate(value);\n        this.viewDate = value;\n    }\n\n    /**\n     * @hidden\n     */\n    public getNextYear() {\n        return CalendarDay.from(this.viewDate).add('year', 1).year;\n    }\n\n    /**\n     * @hidden\n     */\n    public getPreviousYear() {\n        return CalendarDay.from(this.viewDate).add('year', -1).year;\n    }\n\n    /**\n     * @hidden\n     */\n    public updateDate(date: Date) {\n        this.previousViewDate = this.viewDate;\n        this.viewDate = CalendarDay.from(date).add('year', -this.activeViewIdx).native;\n\n        if (this.isDefaultView) {\n            this.viewDateChanged.emit({\n                previousValue: this.previousViewDate,\n                currentValue: this.viewDate,\n            });\n        }\n    }\n\n    @HostListener('mousedown', ['$event'])\n    protected onMouseDown(event: MouseEvent) {\n        event.stopPropagation();\n        this.wrapper.nativeElement.focus();\n    }\n\n    private _showActiveDay: boolean;\n\n\t/**\n\t * @hidden\n\t * @internal\n\t */\n    protected set showActiveDay(value: boolean) {\n        this._showActiveDay = value;\n        this.cdr.detectChanges();\n    }\n\n    protected get showActiveDay() {\n        return this._showActiveDay;\n    }\n\n    protected get activeDescendant(): number {\n        if (this.activeView === 'month') {\n            return (this.value as Date)?.getTime();\n        }\n\n        return this._activeDescendant ?? this.viewDate.getTime();\n    }\n\n    protected set activeDescendant(date: Date) {\n        this._activeDescendant = date.getTime();\n    }\n\n    public override get isDefaultView(): boolean {\n        return this.activeView === IgxCalendarView.Year;\n    }\n\n    public ngOnInit() {\n        this.activeView = IgxCalendarView.Year;\n    }\n\n    public ngAfterViewInit() {\n        this.keyboardNavigation\n            .attachKeyboardHandlers(this.wrapper, this)\n            .set(\"ArrowUp\", this.onArrowUp)\n            .set(\"ArrowDown\", this.onArrowDown)\n            .set(\"ArrowLeft\", this.onArrowLeft)\n            .set(\"ArrowRight\", this.onArrowRight)\n            .set(\"Enter\", this.onEnter)\n            .set(\" \", this.onEnter)\n            .set(\"Home\", this.onHome)\n            .set(\"End\", this.onEnd)\n            .set(\"PageUp\", this.handlePageUp)\n            .set(\"PageDown\", this.handlePageDown);\n\n        this.wrapper.nativeElement.addEventListener('focus', (event: FocusEvent) => this.onWrapperFocus(event));\n        this.wrapper.nativeElement.addEventListener('blur', (event: FocusEvent) => this.onWrapperBlur(event));\n\n        this.activeView$.subscribe((view) => {\n            this.activeViewChanged.emit(view);\n\n            this.viewDateChanged.emit({\n                previousValue: this.previousViewDate,\n                currentValue: this.viewDate\n            });\n        });\n    }\n\n    private onWrapperFocus(event: FocusEvent) {\n        event.stopPropagation();\n        this.showActiveDay = true;\n    }\n\n    private onWrapperBlur(event: FocusEvent) {\n        event.stopPropagation();\n\n        this.showActiveDay = false;\n        this._onTouchedCallback();\n    }\n\n    private handlePageUpDown(event: KeyboardEvent, delta: number) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        if (this.isDefaultView && event.shiftKey) {\n            this.viewDate = CalendarDay.from(this.viewDate).add('year', delta).native;\n            this.cdr.detectChanges();\n        } else {\n            delta > 0 ? this.nextPage() : this.previousPage();\n        }\n    }\n\n    private handlePageUp(event: KeyboardEvent) {\n        this.handlePageUpDown(event, -1);\n    }\n\n    private handlePageDown(event: KeyboardEvent) {\n        this.handlePageUpDown(event, 1);\n    }\n\n    private onArrowUp(event: KeyboardEvent) {\n        if (this.isDefaultView) {\n            this.monthsView.onKeydownArrowUp(event);\n        }\n\n        if (this.isDecadeView) {\n            this.dacadeView.onKeydownArrowUp(event);\n        }\n    }\n\n    private onArrowDown(event: KeyboardEvent) {\n        if (this.isDefaultView) {\n            this.monthsView.onKeydownArrowDown(event);\n        }\n\n        if (this.isDecadeView) {\n            this.dacadeView.onKeydownArrowDown(event);\n        }\n    }\n\n    private onArrowLeft(event: KeyboardEvent) {\n        if (this.isDefaultView) {\n            this.monthsView.onKeydownArrowLeft(event);\n        }\n\n        if (this.isDecadeView) {\n            this.dacadeView.onKeydownArrowLeft(event);\n        }\n    }\n\n    private onArrowRight(event: KeyboardEvent) {\n        if (this.isDefaultView) {\n            this.monthsView.onKeydownArrowRight(event);\n        }\n\n        if (this.isDecadeView) {\n            this.dacadeView.onKeydownArrowRight(event);\n        }\n    }\n\n    private onEnter(event: KeyboardEvent) {\n        event.stopPropagation();\n\n        if (this.isDefaultView) {\n            this.monthsView.onKeydownEnter(event);\n        }\n\n        if (this.isDecadeView) {\n            this.dacadeView.onKeydownEnter(event);\n        }\n    }\n\n    private onHome(event: KeyboardEvent) {\n        event.stopPropagation();\n        if (this.isDefaultView) {\n            this.monthsView.onKeydownHome(event);\n        }\n\n        if (this.isDecadeView) {\n            this.dacadeView.onKeydownHome(event);\n        }\n    }\n\n    private onEnd(event: KeyboardEvent) {\n        event.stopPropagation();\n        if (this.isDefaultView) {\n            this.monthsView.onKeydownEnd(event);\n        }\n\n        if (this.isDecadeView) {\n            this.dacadeView.onKeydownEnd(event);\n        }\n    }\n\n\t/**\n\t * @hidden\n\t * @internal\n\t */\n\tpublic ngOnDestroy(): void {\n        this.keyboardNavigation.detachKeyboardHandlers();\n        this.wrapper?.nativeElement.removeEventListener('focus', this.onWrapperFocus);\n        this.wrapper?.nativeElement.removeEventListener('blur', this.onWrapperBlur);\n\t}\n\n\t/**\n\t * @hidden\n\t * @internal\n\t */\n\tpublic getPrevYearDate(date: Date): Date {\n\t\treturn CalendarDay.from(date).add('year', -1).native;\n\t}\n\n\t/**\n\t * @hidden\n\t * @internal\n\t */\n\tpublic getNextYearDate(date: Date): Date {\n        return CalendarDay.from(date).add('year', 1).native;\n\t}\n\n\t/**\n\t * Getter for the context object inside the calendar templates.\n\t *\n\t * @hidden\n\t * @internal\n\t */\n\tpublic getContext(i: number) {\n        const date = CalendarDay.from(this.viewDate).add('month', i).native;\n\t\treturn this.generateContext(date, i);\n\t}\n\n\t/**\n\t * Helper method building and returning the context object inside the calendar templates.\n\t *\n\t * @hidden\n\t * @internal\n\t */\n\tprivate generateContext(value: Date | Date[], i?: number) {\n        const construct = (date: Date, index: number) => ({\n            index: index,\n            date,\n            ...formatToParts(date, this.locale, this.formatOptions, [\n                \"era\",\n                \"year\",\n                \"month\",\n                \"day\",\n                \"weekday\",\n            ]),\n        });\n\n        const formatObject = Array.isArray(value)\n            ? value.map((date, index) => construct(date, index))\n            : construct(value, i);\n\n        return { $implicit: formatObject };\n\t}\n}\n","<!-- Previous arrow icon -->\n<ng-template #prevArrow let-obj>\n    <igx-icon aria-hidden=\"true\">keyboard_arrow_left</igx-icon>\n</ng-template>\n\n<!-- Next arrow icon -->\n<ng-template #nextArrow let-obj>\n    <igx-icon aria-hidden=\"true\">keyboard_arrow_right</igx-icon>\n</ng-template>\n\n<!-- Previous picker button -->\n<ng-template #prevPageButton let-obj>\n    <div\n        #prevPageBtn\n        tabindex=\"0\"\n        class=\"igx-calendar-picker__prev\"\n        role=\"button\"\n        [attr.aria-label]=\"prevNavLabel((getPrevYearDate(viewDate) | date: 'YYYY'))\"\n        data-action=\"prev\"\n        igxCalendarScrollPage\n        (mousedown)=\"previousPage()\"\n        (keydown)=\"changePageKB($event, false)\"\n    >\n        <ng-container *ngTemplateOutlet=\"prevArrow\"></ng-container>\n    </div>\n</ng-template>\n\n<!-- Next picker button -->\n<ng-template #nextPageButton let-obj>\n    <div\n        #nextPageBtn\n        tabindex=\"0\"\n        class=\"igx-calendar-picker__next\"\n        role=\"button\"\n        [attr.aria-label]=\"nextNavLabel((getNextYearDate(viewDate) | date: 'YYYY'))\"\n        data-action=\"next\"\n        igxCalendarScrollPage\n        (mousedown)=\"nextPage()\"\n        (keydown)=\"changePageKB($event)\"\n    >\n        <ng-container *ngTemplateOutlet=\"nextArrow\"></ng-container>\n    </div>\n</ng-template>\n\n<!-- Year -->\n<ng-template #defaultYear let-obj>\n    <span *ngIf=\"activeView === 'year'\" class=\"igx-calendar__aria-off-screen\" aria-live=\"polite\">{{ formattedYear(obj.date) }}</span>\n    <span\n        #yearsBtn\n        tabindex=\"0\"\n        role=\"button\"\n        [attr.aria-label]=\"(obj.date | date: 'yyyy') + ', ' + resourceStrings.igx_calendar_select_year\"\n        (keydown)=\"onActiveViewDecadeKB(obj.date, $event, obj.index)\"\n        (mousedown)=\"onActiveViewDecade($event, obj.date, obj.index)\"\n        class=\"igx-calendar-picker__date\">\n        {{ formattedYear(obj.date) }}\n    </span>\n</ng-template>\n\n<!-- Decade -->\n<ng-template #defaultDecade>\n    <span>{{ getDecadeRange().start }} - {{ getDecadeRange().end }}</span>\n</ng-template>\n\n<!-- PICKER IN MONTHS -->\n<ng-template #calendarYearPicker>\n    <section class=\"igx-calendar-picker\">\n        <div class=\"igx-calendar-picker__dates\">\n            <ng-container\n                *ngTemplateOutlet=\"defaultYear; context: getContext(0)\">\n            </ng-container>\n        </div>\n        <div class=\"igx-calendar-picker__nav\">\n            <ng-container *ngTemplateOutlet=\"prevPageButton\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"nextPageButton\"></ng-container>\n        </div>\n    </section>\n</ng-template>\n\n<!-- PICKER IN YEARS -->\n<ng-template #calendarDecadePicker>\n    <section class=\"igx-calendar-picker\">\n        <div class=\"igx-calendar-picker__dates\" aria-live=\"polite\">\n            <ng-container\n                    *ngTemplateOutlet=\"defaultDecade;\">\n            </ng-container>\n        </div>\n        <div class=\"igx-calendar-picker__nav\">\n            <ng-container *ngTemplateOutlet=\"prevPageButton\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"nextPageButton\"></ng-container>\n        </div>\n    </section>\n</ng-template>\n\n<div\n    #wrapper\n    [tabIndex]=\"0\"\n    class=\"igx-calendar__wrapper\"\n    [attr.aria-activedescendant]=\"activeDescendant\"\n    [attr.aria-multiselectable]=\"selection !== 'single'\"\n    aria-labelledby=\"calendar-desc\"\n    role=\"grid\"\n    >\n    <caption id=\"calendar-desc\" tabindex=\"-1\" class=\"igx-calendar__aria-off-screen\">\n        {{ resourceStrings.igx_calendar_singular_single_selection}}\n    </caption>\n\n    <section class=\"igx-calendar__pickers\">\n        <ng-container *ngIf=\"isDefaultView\">\n            <ng-container *ngTemplateOutlet=\"calendarYearPicker\"></ng-container>\n        </ng-container>\n\n        <ng-container *ngIf=\"isDecadeView\">\n            <ng-container *ngTemplateOutlet=\"calendarDecadePicker\"></ng-container>\n        </ng-container>\n    </section>\n\n    <section class=\"igx-calendar__body\">\n        <ng-container *ngIf=\"isDefaultView\">\n            <igx-months-view\n                #months\n                role=\"rowgroup\"\n                [tabIndex]=\"-1\"\n                [date]=\"viewDate\"\n                [locale]=\"locale\"\n                [formatView]=\"formatViews.month\"\n                [monthFormat]=\"formatOptions.month\"\n                [showActive]=\"showActiveDay\"\n                [standalone]=\"false\"\n                (swiperight)=\"previousPage()\"\n                (swipeleft)=\"nextPage()\"\n                (selected)=\"selectMonth($event)\"\n                (pageChanged)=\"updateDate($event)\"\n                (mousedown)=\"$event.preventDefault()\">\n            >\n            </igx-months-view>\n        </ng-container>\n\n        <ng-container *ngIf=\"isDecadeView\">\n            <igx-years-view\n                #decade\n                role=\"rowgroup\"\n                [tabIndex]=\"-1\"\n                [date]=\"viewDate\"\n                [locale]=\"locale\"\n                [formatView]=\"formatViews.year\"\n                [yearFormat]=\"formatOptions.year\"\n                [showActive]=\"showActiveDay\"\n                [standalone]=\"false\"\n                (swiperight)=\"previousPage()\"\n                (swipeleft)=\"nextPage()\"\n                (selected)=\"selectYear($event)\"\n                (pageChanged)=\"updateDate($event)\"\n                (mousedown)=\"$event.preventDefault()\"\n            >\n            </igx-years-view>\n        </ng-container>\n    </section>\n</div>\n"]}
|