igniteui-angular 17.2.0-rc.1 → 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.
Files changed (44) hide show
  1. package/esm2022/lib/calendar/month-picker/month-picker.component.mjs +224 -6
  2. package/esm2022/lib/core/utils.mjs +3 -1
  3. package/esm2022/lib/directives/button/button-base.mjs +39 -2
  4. package/esm2022/lib/directives/button/button.directive.mjs +2 -1
  5. package/esm2022/lib/directives/toggle/toggle.directive.mjs +18 -6
  6. package/fesm2022/igniteui-angular.mjs +276 -8
  7. package/fesm2022/igniteui-angular.mjs.map +1 -1
  8. package/lib/calendar/month-picker/month-picker.component.d.ts +83 -2
  9. package/lib/core/styles/components/button/_button-component.scss +16 -0
  10. package/lib/core/styles/components/button/_button-theme.scss +203 -273
  11. package/lib/core/styles/components/button-group/_button-group-theme.scss +314 -85
  12. package/lib/core/styles/components/icon-button/_icon-button-theme.scss +27 -51
  13. package/lib/core/styles/components/overlay/_overlay-component.scss +4 -0
  14. package/lib/core/styles/components/overlay/_overlay-theme.scss +17 -1
  15. package/lib/core/utils.d.ts +2 -0
  16. package/lib/directives/button/button-base.d.ts +21 -0
  17. package/lib/directives/toggle/toggle.directive.d.ts +5 -3
  18. package/package.json +3 -3
  19. package/styles/igniteui-angular-dark.css +1 -1
  20. package/styles/igniteui-angular.css +1 -1
  21. package/styles/igniteui-bootstrap-dark.css +1 -1
  22. package/styles/igniteui-bootstrap-light.css +1 -1
  23. package/styles/igniteui-dark-green.css +1 -1
  24. package/styles/igniteui-fluent-dark-excel.css +1 -1
  25. package/styles/igniteui-fluent-dark-word.css +1 -1
  26. package/styles/igniteui-fluent-dark.css +1 -1
  27. package/styles/igniteui-fluent-light-excel.css +1 -1
  28. package/styles/igniteui-fluent-light-word.css +1 -1
  29. package/styles/igniteui-fluent-light.css +1 -1
  30. package/styles/igniteui-indigo-dark.css +1 -1
  31. package/styles/igniteui-indigo-light.css +1 -1
  32. package/styles/maps/igniteui-angular-dark.css.map +1 -1
  33. package/styles/maps/igniteui-angular.css.map +1 -1
  34. package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
  35. package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
  36. package/styles/maps/igniteui-dark-green.css.map +1 -1
  37. package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
  38. package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
  39. package/styles/maps/igniteui-fluent-dark.css.map +1 -1
  40. package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
  41. package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
  42. package/styles/maps/igniteui-fluent-light.css.map +1 -1
  43. package/styles/maps/igniteui-indigo-dark.css.map +1 -1
  44. 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.Month;
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: "<!-- 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", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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"] }] }); }
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: "<!-- 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" }]
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":"AAAA,OAAO,EACH,SAAS,EACT,YAAY,EACZ,SAAS,EACT,WAAW,EACX,KAAK,GAGR,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEnD,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AACxE,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,wBAAwB,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;;AAEjE,IAAI,OAAO,GAAG,CAAC,CAAC;AAyBhB,MAAM,OAAO,uBAAwB,SAAQ,wBAAwB;IAxBrE;;QAyBI;;;WAGG;QAGI,OAAE,GAAG,oBAAoB,OAAO,EAAE,EAAE,CAAC;QAE5C;;;;WAIG;QAEI,eAAU,GAAG,IAAI,CAAC;KA6K5B;IAnJG;;OAEG;IAEI,YAAY,CAAC,KAAqB;QACrC,KAAK,EAAE,cAAc,EAAE,CAAC;QACxB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC;QAEtC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;SAC1E;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC;SAC3E;IACL,CAAC;IAED;;OAEG;IAEI,QAAQ,CAAC,KAAqB;QACjC,KAAK,EAAE,cAAc,EAAE,CAAC;QACxB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC;QAEtC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;SACzE;QAED,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC;SAC1E;IACL,CAAC;IAED;;OAEG;IACa,kBAAkB,CAAC,KAAoB;QACnD,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEhC,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE;YAChD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACxB;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE;YAC/C,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;SAC5B;IACL,CAAC;IAED;;OAEG;IACa,gBAAgB;QAC5B,KAAK,CAAC,gBAAgB,EAAE,CAAC;QAEzB,qBAAqB,CAAC,GAAG,EAAE;YACvB,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC7C,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACI,YAAY,CAAC,KAAoB,EAAE,IAAI,GAAG,IAAI;QACjD,IAAI,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;YACtC,KAAK,CAAC,eAAe,EAAE,CAAC;YAExB,IAAI,IAAI,EAAE;gBACN,IAAI,CAAC,QAAQ,EAAE,CAAC;aACnB;iBAAM;gBACH,IAAI,CAAC,YAAY,EAAE,CAAC;aACvB;SACJ;IACL,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,KAAW;QACzB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC;QAEtC,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CACpB,KAAK,CAAC,WAAW,EAAE,EACnB,KAAK,CAAC,QAAQ,EAAE,EAChB,KAAK,CAAC,OAAO,EAAE,CAClB,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG,eAAe,CAAC,KAAK,CAAC;IAC5C,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAW;QAC1B,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC3C,CAAC;IAED;;;;;OAKG;IACa,UAAU,CAAC,KAAW;QAClC,IAAI,CAAC,KAAK,EAAE;YACR,OAAO,IAAI,IAAI,EAAE,CAAC;SACrB;QAED,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED;;OAEG;IACI,WAAW;QACd,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/D,CAAC;IAED;;OAEG;IACI,eAAe;QAClB,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAChE,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,IAAU;QACxB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC;QAE/E,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;gBACtB,aAAa,EAAE,IAAI,CAAC,gBAAgB;gBACpC,YAAY,EAAE,IAAI,CAAC,QAAQ;aAC9B,CAAC,CAAC;SACN;IACL,CAAC;IAEM,eAAe;QAClB,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAChC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACP,CAAC;8GA3LQ,uBAAuB;kGAAvB,uBAAuB,mRAvBrB;YACP;gBACI,KAAK,EAAE,IAAI;gBACX,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,uBAAuB;aACvC;YACD;gBACI,KAAK,EAAE,KAAK;gBACZ,OAAO,EAAE,yBAAyB;aACrC;SACJ,2GAiC4B,sBAAsB,+FAMtB,qBAAqB,2FAMvB,oBAAoB,2IC9EnD,s6HAgIA,4CD1FQ,IAAI,6FAEJ,gBAAgB,oJAChB,gBAAgB,2FAChB,sBAAsB,uHACtB,qBAAqB;;2FAGhB,uBAAuB;kBAxBnC,SAAS;gCACK;wBACP;4BACI,KAAK,EAAE,IAAI;4BACX,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,yBAAyB;yBACvC;wBACD;4BACI,KAAK,EAAE,KAAK;4BACZ,OAAO,EAAE,yBAAyB;yBACrC;qBACJ,YACS,kBAAkB,cAEhB,IAAI,WACP;wBACL,IAAI;wBACJ,OAAO;wBACP,gBAAgB;wBAChB,gBAAgB;wBAChB,sBAAsB;wBACtB,qBAAqB;qBACxB;8BASM,EAAE;sBAFR,WAAW;uBAAC,SAAS;;sBACrB,KAAK;gBASC,UAAU;sBADhB,WAAW;uBAAC,wBAAwB;gBAO9B,UAAU;sBADhB,SAAS;uBAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE;gBAO9C,UAAU;sBADhB,SAAS;uBAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,qBAAqB,EAAE;gBAO7C,QAAQ;sBADd,SAAS;uBAAC,MAAM,EAAE,EAAE,IAAI,EAAE,oBAAoB,EAAE;gBAO1C,QAAQ;sBADd,SAAS;uBAAC,UAAU;gBAOd,YAAY;sBADlB,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;gBAkBnC,QAAQ;sBADd,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC","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"]}