igniteui-angular 18.2.11 → 18.2.12

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.
@@ -1,5 +1,5 @@
1
1
  import { Component, HostListener, ViewChild, HostBinding, Input, } from "@angular/core";
2
- import { NgIf, NgStyle, NgTemplateOutlet, DatePipe } from "@angular/common";
2
+ import { NgIf, 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";
@@ -391,7 +391,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
391
391
  },
392
392
  ], selector: "igx-month-picker", standalone: true, imports: [
393
393
  NgIf,
394
- NgStyle,
395
394
  NgTemplateOutlet,
396
395
  DatePipe,
397
396
  IgxIconComponent,
@@ -431,4 +430,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
431
430
  type: HostListener,
432
431
  args: ['mousedown', ['$event']]
433
432
  }] } });
434
- //# 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        this.viewDateChanged.emit({\n            previousValue: this.previousViewDate,\n            currentValue: this.viewDate,\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        this.viewDateChanged.emit({\n            previousValue: this.previousViewDate,\n            currentValue: this.viewDate,\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\" family=\"default\" name=\"arrow_prev\"></igx-icon>\n</ng-template>\n\n<!-- Next arrow icon -->\n<ng-template #nextArrow let-obj>\n    <igx-icon aria-hidden=\"true\" family=\"default\" name=\"arrow_next\"></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"]}
433
+ //# 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,GAKR,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACnE,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;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;;AAElD,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;KAub5B;IA7ZG;;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,CAAC;YACrB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;QAC3E,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC;QAC5E,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;YACtB,aAAa,EAAE,IAAI,CAAC,gBAAgB;YACpC,YAAY,EAAE,IAAI,CAAC,QAAQ;SAC9B,CAAC,CAAC;IACP,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,CAAC;YACrB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;QAC1E,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC;QAC3E,CAAC;QAED,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;YACtB,aAAa,EAAE,IAAI,CAAC,gBAAgB;YACpC,YAAY,EAAE,IAAI,CAAC,QAAQ;SAC9B,CAAC,CAAC;IACP,CAAC;IAEJ;;;OAGG;IACI,oBAAoB,CAAC,IAAU,EAAE,KAAoB,EAAE,aAAqB;QAClF,KAAK,CAAC,kBAAkB,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;QAE/C,IAAI,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE,CAAC;YACjC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC7C,CAAC;IACF,CAAC;IAED;;;OAGG;IACI,kBAAkB,CAAC,KAAiB,EAAE,IAAU,EAAE,aAAqB;QACvE,KAAK,CAAC,cAAc,EAAE,CAAC;QAE7B,KAAK,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;QAChC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IAC5B,CAAC;IAEE;;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,CAAC;YACjD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACzB,CAAC;QAED,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;YAChD,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;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,CAAC;YACvC,KAAK,CAAC,eAAe,EAAE,CAAC;YAExB,IAAI,IAAI,EAAE,CAAC;gBACP,IAAI,CAAC,QAAQ,EAAE,CAAC;YACpB,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,YAAY,EAAE,CAAC;YACxB,CAAC;QACL,CAAC;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,IAAI,CAAC;QACvC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACvC,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,CAAC;YACT,OAAO,IAAI,IAAI,EAAE,CAAC;QACtB,CAAC;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,CAAC;YACrB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;gBACtB,aAAa,EAAE,IAAI,CAAC,gBAAgB;gBACpC,YAAY,EAAE,IAAI,CAAC,QAAQ;aAC9B,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAGS,WAAW,CAAC,KAAiB;QACnC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACvC,CAAC;IAIJ;;;OAGG;IACA,IAAc,aAAa,CAAC,KAAc;QACtC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED,IAAc,aAAa;QACvB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAED,IAAc,gBAAgB;QAC1B,IAAI,IAAI,CAAC,UAAU,KAAK,OAAO,EAAE,CAAC;YAC9B,OAAQ,IAAI,CAAC,KAAc,EAAE,OAAO,EAAE,CAAC;QAC3C,CAAC;QAED,OAAO,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;IAC7D,CAAC;IAED,IAAc,gBAAgB,CAAC,IAAU;QACrC,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAC5C,CAAC;IAED,IAAoB,aAAa;QAC7B,OAAO,IAAI,CAAC,UAAU,KAAK,eAAe,CAAC,IAAI,CAAC;IACpD,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,UAAU,GAAG,eAAe,CAAC,IAAI,CAAC;IAC3C,CAAC;IAEM,eAAe;QAClB,IAAI,CAAC,kBAAkB;aAClB,sBAAsB,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC;aAC1C,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC;aAC9B,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC;aAClC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC;aAClC,GAAG,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC;aACpC,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC;aAC1B,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC;aACtB,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC;aACxB,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC;aACtB,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC;aAChC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAE1C,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,KAAiB,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC;QACxG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,KAAiB,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;QAEtG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAChC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAElC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;gBACtB,aAAa,EAAE,IAAI,CAAC,gBAAgB;gBACpC,YAAY,EAAE,IAAI,CAAC,QAAQ;aAC9B,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,cAAc,CAAC,KAAiB;QACpC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAC9B,CAAC;IAEO,aAAa,CAAC,KAAiB;QACnC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAEO,gBAAgB,CAAC,KAAoB,EAAE,KAAa;QACxD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YACvC,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,MAAM,CAAC;YAC1E,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC7B,CAAC;aAAM,CAAC;YACJ,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;QACtD,CAAC;IACL,CAAC;IAEO,YAAY,CAAC,KAAoB;QACrC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;IACrC,CAAC;IAEO,cAAc,CAAC,KAAoB;QACvC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACpC,CAAC;IAEO,SAAS,CAAC,KAAoB;QAClC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC5C,CAAC;IACL,CAAC;IAEO,WAAW,CAAC,KAAoB;QACpC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC;IACL,CAAC;IAEO,WAAW,CAAC,KAAoB;QACpC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC9C,CAAC;IACL,CAAC;IAEO,YAAY,CAAC,KAAoB;QACrC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;QAC/C,CAAC;IACL,CAAC;IAEO,OAAO,CAAC,KAAoB;QAChC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QAC1C,CAAC;IACL,CAAC;IAEO,MAAM,CAAC,KAAoB;QAC/B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACzC,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACzC,CAAC;IACL,CAAC;IAEO,KAAK,CAAC,KAAoB;QAC9B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC;IACL,CAAC;IAEJ;;;OAGG;IACI,WAAW;QACX,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC;QACjD,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC9E,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;IACnF,CAAC;IAED;;;OAGG;IACI,eAAe,CAAC,IAAU;QAChC,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;IACtD,CAAC;IAED;;;OAGG;IACI,eAAe,CAAC,IAAU;QAC1B,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;IAC3D,CAAC;IAED;;;;;OAKG;IACI,UAAU,CAAC,CAAS;QACpB,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;QAC1E,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IACtC,CAAC;IAED;;;;;OAKG;IACK,eAAe,CAAC,KAAoB,EAAE,CAAU;QACjD,MAAM,SAAS,GAAG,CAAC,IAAU,EAAE,KAAa,EAAE,EAAE,CAAC,CAAC;YAC9C,KAAK,EAAE,KAAK;YACZ,IAAI;YACJ,GAAG,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE;gBACpD,KAAK;gBACL,MAAM;gBACN,OAAO;gBACP,KAAK;gBACL,SAAS;aACZ,CAAC;SACL,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;YACrC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YACpD,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAE1B,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC;IAC1C,CAAC;8GAldW,uBAAuB;kGAAvB,uBAAuB,uTAvBrB;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,gMA8C4B,sBAAsB,+FAMtB,qBAAqB,2FAMvB,oBAAoB,2IC9FnD,6nLA+JA,4CDtHQ,IAAI,6FACJ,gBAAgB,+IAChB,QAAQ,6CACR,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,gBAAgB;wBAChB,QAAQ;wBACR,gBAAgB;wBAChB,sBAAsB;wBACtB,qBAAqB;qBACxB;8BASM,EAAE;sBAFR,WAAW;uBAAC,SAAS;;sBACrB,KAAK;gBAcC,OAAO;sBADb,SAAS;uBAAC,SAAS;gBASb,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;gBAuBnC,QAAQ;sBADd,YAAY;uBAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC;gBAyJlC,WAAW;sBADpB,YAAY;uBAAC,WAAW,EAAE,CAAC,QAAQ,CAAC","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, 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        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        this.viewDateChanged.emit({\n            previousValue: this.previousViewDate,\n            currentValue: this.viewDate,\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        this.viewDateChanged.emit({\n            previousValue: this.previousViewDate,\n            currentValue: this.viewDate,\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\" family=\"default\" name=\"arrow_prev\"></igx-icon>\n</ng-template>\n\n<!-- Next arrow icon -->\n<ng-template #nextArrow let-obj>\n    <igx-icon aria-hidden=\"true\" family=\"default\" name=\"arrow_next\"></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"]}
@@ -1,6 +1,6 @@
1
1
  import { Component, Input, HostBinding, booleanAttribute, Inject, } from "@angular/core";
2
2
  import { IgxCalendarMonthDirective } from "../calendar.directives";
3
- import { NgFor, TitleCasePipe, DatePipe } from "@angular/common";
3
+ import { NgFor, TitleCasePipe } from "@angular/common";
4
4
  import { IgxCalendarViewDirective, DAY_INTERVAL_TOKEN, } from "../common/calendar-view.directive";
5
5
  import { NG_VALUE_ACCESSOR } from "@angular/forms";
6
6
  import { CalendarDay } from "../common/model";
@@ -85,6 +85,14 @@ export class IgxMonthsViewComponent extends IgxCalendarViewDirective {
85
85
  */
86
86
  this._monthFormat = "short";
87
87
  }
88
+ /**
89
+ * @hidden
90
+ */
91
+ onMouseDown() {
92
+ if (this.tabIndex !== -1) {
93
+ this.el.nativeElement.focus();
94
+ }
95
+ }
88
96
  /**
89
97
  * Returns the locale representation of the month in the months view.
90
98
  *
@@ -131,7 +139,7 @@ export class IgxMonthsViewComponent extends IgxCalendarViewDirective {
131
139
  provide: DAY_INTERVAL_TOKEN,
132
140
  useValue: "month",
133
141
  },
134
- ], usesInheritance: true, ngImport: i0, template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarMonth\n #item=\"igxCalendarMonth\"\n *ngFor=\"let month of range; trackBy: monthTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"month.getTime()\"\n [attr.aria-label]=\"formattedMonth(month).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [value]=\"month\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedMonth(month).formatted | titlecase }}\n </span>\n </span>\n</div>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: IgxCalendarMonthDirective, selector: "[igxCalendarMonth]", exportAs: ["igxCalendarMonth"] }, { kind: "pipe", type: TitleCasePipe, name: "titlecase" }] }); }
142
+ ], usesInheritance: true, ngImport: i0, template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarMonth\n #item=\"igxCalendarMonth\"\n *ngFor=\"let month of range; trackBy: monthTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"month.getTime()\"\n [attr.aria-label]=\"formattedMonth(month).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [value]=\"month\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n (mousedown)=\"onMouseDown()\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedMonth(month).formatted | titlecase }}\n </span>\n </span>\n</div>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: IgxCalendarMonthDirective, selector: "[igxCalendarMonth]", exportAs: ["igxCalendarMonth"] }, { kind: "pipe", type: TitleCasePipe, name: "titlecase" }] }); }
135
143
  }
136
144
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxMonthsViewComponent, decorators: [{
137
145
  type: Component,
@@ -145,7 +153,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
145
153
  provide: DAY_INTERVAL_TOKEN,
146
154
  useValue: "month",
147
155
  },
148
- ], selector: "igx-months-view", standalone: true, imports: [NgFor, IgxCalendarMonthDirective, TitleCasePipe, DatePipe], template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarMonth\n #item=\"igxCalendarMonth\"\n *ngFor=\"let month of range; trackBy: monthTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"month.getTime()\"\n [attr.aria-label]=\"formattedMonth(month).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [value]=\"month\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedMonth(month).formatted | titlecase }}\n </span>\n </span>\n</div>\n" }]
156
+ ], selector: "igx-months-view", standalone: true, imports: [NgFor, IgxCalendarMonthDirective, TitleCasePipe], template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarMonth\n #item=\"igxCalendarMonth\"\n *ngFor=\"let month of range; trackBy: monthTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"month.getTime()\"\n [attr.aria-label]=\"formattedMonth(month).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [value]=\"month\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n (mousedown)=\"onMouseDown()\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedMonth(month).formatted | titlecase }}\n </span>\n </span>\n</div>\n" }]
149
157
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: undefined, decorators: [{
150
158
  type: Inject,
151
159
  args: [DAY_INTERVAL_TOKEN]
@@ -168,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
168
176
  type: Input,
169
177
  args: [{ transform: booleanAttribute }]
170
178
  }] } });
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"months-view.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/calendar/months-view/months-view.component.ts","../../../../../../projects/igniteui-angular/src/lib/calendar/months-view/months-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    HostBinding,\n    ElementRef,\n    booleanAttribute,\n    Inject,\n} from \"@angular/core\";\nimport { IgxCalendarMonthDirective } from \"../calendar.directives\";\nimport { NgFor, TitleCasePipe, DatePipe } from \"@angular/common\";\nimport {\n    IgxCalendarViewDirective,\n    DAY_INTERVAL_TOKEN,\n} from \"../common/calendar-view.directive\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { CalendarDay } from \"../common/model\";\nimport type { DayInterval } from \"../common/model\";\nimport { calendarRange } from \"../common/helpers\";\n\nlet NEXT_ID = 0;\n\n@Component({\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxMonthsViewComponent,\n            multi: true,\n        },\n        {\n            provide: DAY_INTERVAL_TOKEN,\n            useValue: \"month\",\n        },\n    ],\n    selector: \"igx-months-view\",\n    templateUrl: \"months-view.component.html\",\n    standalone: true,\n    imports: [NgFor, IgxCalendarMonthDirective, TitleCasePipe, DatePipe],\n})\nexport class IgxMonthsViewComponent extends IgxCalendarViewDirective implements ControlValueAccessor {\n    #standalone = true;\n\n    /**\n     * Sets/gets the `id` of the months view.\n     * If not set, the `id` will have value `\"igx-months-view-0\"`.\n     * ```html\n     * <igx-months-view id=\"my-months-view\"></igx-months-view>\n     * ```\n     * ```typescript\n     * let monthsViewId =  this.monthsView.id;\n     * ```\n     *\n     * @memberof IgxMonthsViewComponent\n     */\n    @HostBinding(\"attr.id\")\n    @Input()\n    public id = `igx-months-view-${NEXT_ID++}`;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding(\"class.igx-calendar-view\")\n    public readonly viewClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @Input()\n    @HostBinding(\"class.igx-calendar-view--standalone\")\n    public get standalone() {\n        return this.#standalone;\n    }\n\n    public set standalone(value: boolean) {\n        this.#standalone = value;\n    }\n\n    /**\n     * Gets the month format option of the months view.\n     * ```typescript\n     * let monthFormat = this.monthsView.monthFormat.\n     * ```\n     */\n    @Input()\n    public get monthFormat(): any {\n        return this._monthFormat;\n    }\n\n    /**\n     * Sets the month format option of the months view.\n     * ```html\n     * <igx-months-view> [monthFormat]=\"short'\"</igx-months-view>\n     * ```\n     *\n     * @memberof IgxMonthsViewComponent\n     */\n    public set monthFormat(value: any) {\n        this._monthFormat = value;\n        this.initFormatter();\n    }\n\n    /**\n     * Gets/sets whether the view should be rendered\n     * according to the locale and format, if any.\n     */\n    @Input({ transform: booleanAttribute })\n    public override formatView = true;\n\n    /**\n     * Returns an array of date objects which are then used to\n     * properly render the month names.\n     *\n     * Used in the template of the component\n     *\n     * @hidden @internal\n     */\n    public get range(): Date[] {\n        const start = CalendarDay.from(this.date).set({ date: 1, month: 0 });\n        const end = start.add(this.dayInterval, 12);\n\n        return Array.from(\n            calendarRange({ start, end, unit: this.dayInterval }),\n        ).map((m) => m.native);\n    }\n\n    /**\n     * @hidden\n     */\n    private _monthFormat = \"short\";\n\n    constructor(\n        public el: ElementRef,\n        @Inject(DAY_INTERVAL_TOKEN) dayInterval: DayInterval,\n    ) {\n        super(dayInterval);\n    }\n\n    /**\n     * Returns the locale representation of the month in the months view.\n     *\n     * @hidden\n     */\n    public formattedMonth(value: Date): { long: string; formatted: string } {\n        const rawFormatter = new Intl.DateTimeFormat(this.locale, {\n            month: \"long\",\n            year: \"numeric\",\n        });\n\n        if (this.formatView) {\n            return {\n                long: rawFormatter.format(value),\n                formatted: this._formatter.format(value),\n            };\n        }\n\n        return {\n            long: rawFormatter.format(value),\n            formatted: `${value.getMonth()}`,\n        };\n    }\n\n    /**\n     * @hidden\n     */\n    public monthTracker(_: number, item: Date): string {\n        return `${item.getMonth()}}`;\n    }\n\n    /**\n     * @hidden\n     */\n    protected initFormatter() {\n        this._formatter = new Intl.DateTimeFormat(this._locale, {\n            month: this.monthFormat,\n        });\n    }\n}\n","<div class=\"igx-calendar-view__items\" role=\"row\">\n    <span\n        igxCalendarMonth\n        #item=\"igxCalendarMonth\"\n        *ngFor=\"let month of range; trackBy: monthTracker\"\n        class=\"igx-calendar-view__item\"\n        role=\"gridcell\"\n        [attr.id]=\"month.getTime()\"\n        [attr.aria-label]=\"formattedMonth(month).long\"\n        [attr.aria-selected]=\"item.isSelected\"\n        [value]=\"month\"\n        [date]=\"date\"\n        [showActive]=\"showActive\"\n        (itemSelection)=\"selectDate($event)\"\n    >\n        <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n            {{ formattedMonth(month).formatted | titlecase }}\n        </span>\n    </span>\n</div>\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"months-view.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/calendar/months-view/months-view.component.ts","../../../../../../projects/igniteui-angular/src/lib/calendar/months-view/months-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    HostBinding,\n    ElementRef,\n    booleanAttribute,\n    Inject,\n} from \"@angular/core\";\nimport { IgxCalendarMonthDirective } from \"../calendar.directives\";\nimport { NgFor, TitleCasePipe } from \"@angular/common\";\nimport {\n    IgxCalendarViewDirective,\n    DAY_INTERVAL_TOKEN,\n} from \"../common/calendar-view.directive\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { CalendarDay } from \"../common/model\";\nimport type { DayInterval } from \"../common/model\";\nimport { calendarRange } from \"../common/helpers\";\n\nlet NEXT_ID = 0;\n\n@Component({\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxMonthsViewComponent,\n            multi: true,\n        },\n        {\n            provide: DAY_INTERVAL_TOKEN,\n            useValue: \"month\",\n        },\n    ],\n    selector: \"igx-months-view\",\n    templateUrl: \"months-view.component.html\",\n    standalone: true,\n    imports: [NgFor, IgxCalendarMonthDirective, TitleCasePipe],\n})\nexport class IgxMonthsViewComponent extends IgxCalendarViewDirective implements ControlValueAccessor {\n    #standalone = true;\n\n    /**\n     * Sets/gets the `id` of the months view.\n     * If not set, the `id` will have value `\"igx-months-view-0\"`.\n     * ```html\n     * <igx-months-view id=\"my-months-view\"></igx-months-view>\n     * ```\n     * ```typescript\n     * let monthsViewId =  this.monthsView.id;\n     * ```\n     *\n     * @memberof IgxMonthsViewComponent\n     */\n    @HostBinding(\"attr.id\")\n    @Input()\n    public id = `igx-months-view-${NEXT_ID++}`;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding(\"class.igx-calendar-view\")\n    public readonly viewClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @Input()\n    @HostBinding(\"class.igx-calendar-view--standalone\")\n    public get standalone() {\n        return this.#standalone;\n    }\n\n    public set standalone(value: boolean) {\n        this.#standalone = value;\n    }\n\n    /**\n     * Gets the month format option of the months view.\n     * ```typescript\n     * let monthFormat = this.monthsView.monthFormat.\n     * ```\n     */\n    @Input()\n    public get monthFormat(): any {\n        return this._monthFormat;\n    }\n\n    /**\n     * Sets the month format option of the months view.\n     * ```html\n     * <igx-months-view> [monthFormat]=\"short'\"</igx-months-view>\n     * ```\n     *\n     * @memberof IgxMonthsViewComponent\n     */\n    public set monthFormat(value: any) {\n        this._monthFormat = value;\n        this.initFormatter();\n    }\n\n    /**\n     * Gets/sets whether the view should be rendered\n     * according to the locale and format, if any.\n     */\n    @Input({ transform: booleanAttribute })\n    public override formatView = true;\n\n    /**\n     * Returns an array of date objects which are then used to\n     * properly render the month names.\n     *\n     * Used in the template of the component\n     *\n     * @hidden @internal\n     */\n    public get range(): Date[] {\n        const start = CalendarDay.from(this.date).set({ date: 1, month: 0 });\n        const end = start.add(this.dayInterval, 12);\n\n        return Array.from(\n            calendarRange({ start, end, unit: this.dayInterval }),\n        ).map((m) => m.native);\n    }\n\n    /**\n     * @hidden\n     */\n    private _monthFormat = \"short\";\n\n    constructor(\n        public el: ElementRef,\n        @Inject(DAY_INTERVAL_TOKEN) dayInterval: DayInterval,\n    ) {\n        super(dayInterval);\n    }\n\n    /**\n     * @hidden\n     */\n    protected onMouseDown() {\n        if (this.tabIndex !== -1) {\n            this.el.nativeElement.focus();\n        }\n    }\n\n    /**\n     * Returns the locale representation of the month in the months view.\n     *\n     * @hidden\n     */\n    public formattedMonth(value: Date): { long: string; formatted: string } {\n        const rawFormatter = new Intl.DateTimeFormat(this.locale, {\n            month: \"long\",\n            year: \"numeric\",\n        });\n\n        if (this.formatView) {\n            return {\n                long: rawFormatter.format(value),\n                formatted: this._formatter.format(value),\n            };\n        }\n\n        return {\n            long: rawFormatter.format(value),\n            formatted: `${value.getMonth()}`,\n        };\n    }\n\n    /**\n     * @hidden\n     */\n    public monthTracker(_: number, item: Date): string {\n        return `${item.getMonth()}}`;\n    }\n\n    /**\n     * @hidden\n     */\n    protected initFormatter() {\n        this._formatter = new Intl.DateTimeFormat(this._locale, {\n            month: this.monthFormat,\n        });\n    }\n}\n","<div class=\"igx-calendar-view__items\" role=\"row\">\n    <span\n        igxCalendarMonth\n        #item=\"igxCalendarMonth\"\n        *ngFor=\"let month of range; trackBy: monthTracker\"\n        class=\"igx-calendar-view__item\"\n        role=\"gridcell\"\n        [attr.id]=\"month.getTime()\"\n        [attr.aria-label]=\"formattedMonth(month).long\"\n        [attr.aria-selected]=\"item.isSelected\"\n        [value]=\"month\"\n        [date]=\"date\"\n        [showActive]=\"showActive\"\n        (itemSelection)=\"selectDate($event)\"\n        (mousedown)=\"onMouseDown()\"\n    >\n        <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n            {{ formattedMonth(month).formatted | titlecase }}\n        </span>\n    </span>\n</div>\n"]}
@@ -106,6 +106,14 @@ export class IgxYearsViewComponent extends IgxCalendarViewDirective {
106
106
  year: this.yearFormat,
107
107
  });
108
108
  }
109
+ /**
110
+ * @hidden
111
+ */
112
+ onMouseDown() {
113
+ if (this.tabIndex !== -1) {
114
+ this.el.nativeElement.focus();
115
+ }
116
+ }
109
117
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxYearsViewComponent, deps: [{ token: i0.ElementRef }, { token: DAY_INTERVAL_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
110
118
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: IgxYearsViewComponent, isStandalone: true, selector: "igx-years-view", inputs: { standalone: "standalone", yearFormat: "yearFormat" }, host: { properties: { "class.igx-calendar-view": "this.viewClass", "class.igx-calendar-view--standalone": "this.standalone" } }, providers: [
111
119
  {
@@ -117,7 +125,7 @@ export class IgxYearsViewComponent extends IgxCalendarViewDirective {
117
125
  provide: DAY_INTERVAL_TOKEN,
118
126
  useValue: "year",
119
127
  },
120
- ], usesInheritance: true, ngImport: i0, template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarYear\n #item=\"igxCalendarYear\"\n *ngFor=\"let year of range; trackBy: yearTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"year.getTime()\"\n [attr.aria-label]=\"formattedYear(year).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [attr.aria-current]=\"item.isCurrent\"\n [value]=\"year\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedYear(year).formatted }}\n </span>\n </span>\n</div>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: IgxCalendarYearDirective, selector: "[igxCalendarYear]", exportAs: ["igxCalendarYear"] }] }); }
128
+ ], usesInheritance: true, ngImport: i0, template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarYear\n #item=\"igxCalendarYear\"\n *ngFor=\"let year of range; trackBy: yearTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"year.getTime()\"\n [attr.aria-label]=\"formattedYear(year).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [attr.aria-current]=\"item.isCurrent\"\n [value]=\"year\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n (mousedown)=\"onMouseDown()\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedYear(year).formatted }}\n </span>\n </span>\n</div>\n", dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: IgxCalendarYearDirective, selector: "[igxCalendarYear]", exportAs: ["igxCalendarYear"] }] }); }
121
129
  }
122
130
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxYearsViewComponent, decorators: [{
123
131
  type: Component,
@@ -131,7 +139,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
131
139
  provide: DAY_INTERVAL_TOKEN,
132
140
  useValue: "year",
133
141
  },
134
- ], selector: "igx-years-view", standalone: true, imports: [NgFor, IgxCalendarYearDirective], template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarYear\n #item=\"igxCalendarYear\"\n *ngFor=\"let year of range; trackBy: yearTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"year.getTime()\"\n [attr.aria-label]=\"formattedYear(year).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [attr.aria-current]=\"item.isCurrent\"\n [value]=\"year\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedYear(year).formatted }}\n </span>\n </span>\n</div>\n" }]
142
+ ], selector: "igx-years-view", standalone: true, imports: [NgFor, IgxCalendarYearDirective], template: "<div class=\"igx-calendar-view__items\" role=\"row\">\n <span\n igxCalendarYear\n #item=\"igxCalendarYear\"\n *ngFor=\"let year of range; trackBy: yearTracker\"\n class=\"igx-calendar-view__item\"\n role=\"gridcell\"\n [attr.id]=\"year.getTime()\"\n [attr.aria-label]=\"formattedYear(year).long\"\n [attr.aria-selected]=\"item.isSelected\"\n [attr.aria-current]=\"item.isCurrent\"\n [value]=\"year\"\n [date]=\"date\"\n [showActive]=\"showActive\"\n (itemSelection)=\"selectDate($event)\"\n (mousedown)=\"onMouseDown()\"\n >\n <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n {{ formattedYear(year).formatted }}\n </span>\n </span>\n</div>\n" }]
135
143
  }], ctorParameters: () => [{ type: i0.ElementRef }, { type: undefined, decorators: [{
136
144
  type: Inject,
137
145
  args: [DAY_INTERVAL_TOKEN]
@@ -146,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
146
154
  }], yearFormat: [{
147
155
  type: Input
148
156
  }] } });
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"years-view.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/calendar/years-view/years-view.component.ts","../../../../../../projects/igniteui-angular/src/lib/calendar/years-view/years-view.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,KAAK,EACL,WAAW,EAEX,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAClE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EACH,wBAAwB,EACxB,kBAAkB,GACrB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;;AAmBlD,MAAM,OAAO,qBAAsB,SAAQ,wBAAwB;IAC/D,WAAW,CAAQ;IAUnB;;OAEG;IACH,IAEQ,UAAU;QACd,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAEJ,IAAW,UAAU,CAAC,KAAc;QAC7B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC7B,CAAC;IAYD;;;;;OAKG;IACH,IACW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAED;;;;;;;OAOG;IACH,IAAW,UAAU,CAAC,KAAU;QAC5B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAED;;;;;;;OAOG;IACH,IAAW,KAAK;QACZ,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,KAAK,GAAG,IAAI,WAAW,CAAC;YAC1B,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,aAAa;YAChE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;SAC9B,CAAC,CAAC;QACH,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAE5D,OAAO,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,GAAG,CACxE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAClB,CAAC;IACN,CAAC;IAED,YACW,EAAc,EACO,WAAwB;QAEpD,KAAK,CAAC,WAAW,CAAC,CAAC;QAHZ,OAAE,GAAF,EAAE,CAAY;QA/EzB,gBAAW,GAAG,IAAI,CAAC;QAEnB;;;;WAIG;QAEa,cAAS,GAAG,IAAI,CAAC;QAejC;;WAEG;QACK,gBAAW,GAAG,SAAS,CAAC;QAEhC;;WAEG;QACK,kBAAa,GAAG,EAAE,CAAC;IAoD3B,CAAC;IAED;;;;OAIG;IACI,aAAa,CAAC,KAAW;QAC5B,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QAE/E,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO;gBACH,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC;gBAChC,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC;aAC3C,CAAA;QACL,CAAC;QAED,OAAO;YACH,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC;YAChC,SAAS,EAAE,GAAG,KAAK,CAAC,WAAW,EAAE,EAAE;SACtC,CAAA;IACL,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,CAAS,EAAE,IAAU;QACpC,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC;IACpC,CAAC;IAED;;OAEG;IACO,aAAa;QACnB,IAAI,CAAC,UAAU,GAAG,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAE;YACpD,IAAI,EAAE,IAAI,CAAC,UAAU;SACxB,CAAC,CAAC;IACP,CAAC;8GAzHQ,qBAAqB,4CAiFlB,kBAAkB;kGAjFrB,qBAAqB,8PAhBnB;YACP;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,qBAAqB;gBAClC,KAAK,EAAE,IAAI;aACd;YACD;gBACI,OAAO,EAAE,kBAAkB;gBAC3B,QAAQ,EAAE,MAAM;aACnB;SACJ,iDC7BL,qvBAqBA,4CDYc,KAAK,mHAAE,wBAAwB;;2FAEhC,qBAAqB;kBAjBjC,SAAS;gCACK;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,uBAAuB;4BAClC,KAAK,EAAE,IAAI;yBACd;wBACD;4BACI,OAAO,EAAE,kBAAkB;4BAC3B,QAAQ,EAAE,MAAM;yBACnB;qBACJ,YACS,gBAAgB,cAEd,IAAI,WACP,CAAC,KAAK,EAAE,wBAAwB,CAAC;;0BAmFrC,MAAM;2BAAC,kBAAkB;yCAxEd,SAAS;sBADxB,WAAW;uBAAC,yBAAyB;gBAQ9B,UAAU;sBAFjB,KAAK;;sBACR,WAAW;uBAAC,qCAAqC;gBA0BpC,UAAU;sBADpB,KAAK","sourcesContent":["import {\n    Component,\n    Input,\n    HostBinding,\n    ElementRef,\n    Inject,\n} from \"@angular/core\";\nimport { IgxCalendarYearDirective } from \"../calendar.directives\";\nimport { NgFor } from \"@angular/common\";\nimport {\n    IgxCalendarViewDirective,\n    DAY_INTERVAL_TOKEN,\n} from \"../common/calendar-view.directive\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { CalendarDay } from \"../common/model\";\nimport type { DayInterval } from \"../common/model\";\nimport { calendarRange } from \"../common/helpers\";\n\n@Component({\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxYearsViewComponent,\n            multi: true,\n        },\n        {\n            provide: DAY_INTERVAL_TOKEN,\n            useValue: \"year\",\n        },\n    ],\n    selector: \"igx-years-view\",\n    templateUrl: \"years-view.component.html\",\n    standalone: true,\n    imports: [NgFor, IgxCalendarYearDirective],\n})\nexport class IgxYearsViewComponent extends IgxCalendarViewDirective implements ControlValueAccessor {\n    #standalone = true;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding(\"class.igx-calendar-view\")\n    public readonly viewClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @Input()\n\t@HostBinding('class.igx-calendar-view--standalone')\n\tpublic get standalone() {\n        return this.#standalone;\n    }\n\n\tpublic set standalone(value: boolean) {\n        this.#standalone = value;\n    }\n\n    /**\n     * @hidden\n     */\n    private _yearFormat = \"numeric\";\n\n    /**\n     * @hidden\n     */\n    private _yearsPerPage = 15;\n\n    /**\n     * Gets the year format option of the years view.\n     * ```typescript\n     * let yearFormat = this.yearsView.yearFormat.\n     * ```\n     */\n    @Input()\n    public get yearFormat(): any {\n        return this._yearFormat;\n    }\n\n    /**\n     * Sets the year format option of the years view.\n     * ```html\n     * <igx-years-view [yearFormat]=\"numeric\"></igx-years-view>\n     * ```\n     *\n     * @memberof IgxYearsViewComponent\n     */\n    public set yearFormat(value: any) {\n        this._yearFormat = value;\n        this.initFormatter();\n    }\n\n    /**\n     * Returns an array of date objects which are then used to properly\n     * render the years.\n     *\n     * Used in the template of the component.\n     *\n     * @hidden @internal\n     */\n    public get range(): Date[] {\n        const year = this.date.getFullYear();\n        const start = new CalendarDay({\n            year: Math.floor(year / this._yearsPerPage) * this._yearsPerPage,\n            month: this.date.getMonth(),\n        });\n        const end = start.add(this.dayInterval, this._yearsPerPage);\n\n        return Array.from(calendarRange({ start, end, unit: this.dayInterval })).map(\n            (m) => m.native,\n        );\n    }\n\n    constructor(\n        public el: ElementRef,\n        @Inject(DAY_INTERVAL_TOKEN) dayInterval: DayInterval,\n    ) {\n        super(dayInterval);\n    }\n\n    /**\n     * Returns the locale representation of the year in the years view.\n     *\n     * @hidden\n     */\n    public formattedYear(value: Date): {long: string, formatted: string} {\n        const rawFormatter = new Intl.DateTimeFormat(this.locale, { year: 'numeric' });\n\n        if (this.formatView) {\n            return {\n                long: rawFormatter.format(value),\n                formatted: this._formatter.format(value)\n            }\n        }\n\n        return {\n            long: rawFormatter.format(value),\n            formatted: `${value.getFullYear()}`\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public yearTracker(_: number, item: Date): string {\n        return `${item.getFullYear()}}`;\n    }\n\n    /**\n     * @hidden\n     */\n    protected initFormatter() {\n        this._formatter = new Intl.DateTimeFormat(this._locale, {\n            year: this.yearFormat,\n        });\n    }\n}\n","<div class=\"igx-calendar-view__items\" role=\"row\">\n    <span\n        igxCalendarYear\n        #item=\"igxCalendarYear\"\n        *ngFor=\"let year of range; trackBy: yearTracker\"\n        class=\"igx-calendar-view__item\"\n        role=\"gridcell\"\n        [attr.id]=\"year.getTime()\"\n        [attr.aria-label]=\"formattedYear(year).long\"\n        [attr.aria-selected]=\"item.isSelected\"\n        [attr.aria-current]=\"item.isCurrent\"\n        [value]=\"year\"\n        [date]=\"date\"\n        [showActive]=\"showActive\"\n        (itemSelection)=\"selectDate($event)\"\n    >\n        <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n            {{ formattedYear(year).formatted }}\n        </span>\n    </span>\n</div>\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"years-view.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/calendar/years-view/years-view.component.ts","../../../../../../projects/igniteui-angular/src/lib/calendar/years-view/years-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    HostBinding,\n    ElementRef,\n    Inject,\n} from \"@angular/core\";\nimport { IgxCalendarYearDirective } from \"../calendar.directives\";\nimport { NgFor } from \"@angular/common\";\nimport {\n    IgxCalendarViewDirective,\n    DAY_INTERVAL_TOKEN,\n} from \"../common/calendar-view.directive\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { CalendarDay } from \"../common/model\";\nimport type { DayInterval } from \"../common/model\";\nimport { calendarRange } from \"../common/helpers\";\n\n@Component({\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxYearsViewComponent,\n            multi: true,\n        },\n        {\n            provide: DAY_INTERVAL_TOKEN,\n            useValue: \"year\",\n        },\n    ],\n    selector: \"igx-years-view\",\n    templateUrl: \"years-view.component.html\",\n    standalone: true,\n    imports: [NgFor, IgxCalendarYearDirective],\n})\nexport class IgxYearsViewComponent extends IgxCalendarViewDirective implements ControlValueAccessor {\n    #standalone = true;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding(\"class.igx-calendar-view\")\n    public readonly viewClass = true;\n\n    /**\n     * @hidden @internal\n     */\n    @Input()\n\t@HostBinding('class.igx-calendar-view--standalone')\n\tpublic get standalone() {\n        return this.#standalone;\n    }\n\n\tpublic set standalone(value: boolean) {\n        this.#standalone = value;\n    }\n\n    /**\n     * @hidden\n     */\n    private _yearFormat = \"numeric\";\n\n    /**\n     * @hidden\n     */\n    private _yearsPerPage = 15;\n\n    /**\n     * Gets the year format option of the years view.\n     * ```typescript\n     * let yearFormat = this.yearsView.yearFormat.\n     * ```\n     */\n    @Input()\n    public get yearFormat(): any {\n        return this._yearFormat;\n    }\n\n    /**\n     * Sets the year format option of the years view.\n     * ```html\n     * <igx-years-view [yearFormat]=\"numeric\"></igx-years-view>\n     * ```\n     *\n     * @memberof IgxYearsViewComponent\n     */\n    public set yearFormat(value: any) {\n        this._yearFormat = value;\n        this.initFormatter();\n    }\n\n    /**\n     * Returns an array of date objects which are then used to properly\n     * render the years.\n     *\n     * Used in the template of the component.\n     *\n     * @hidden @internal\n     */\n    public get range(): Date[] {\n        const year = this.date.getFullYear();\n        const start = new CalendarDay({\n            year: Math.floor(year / this._yearsPerPage) * this._yearsPerPage,\n            month: this.date.getMonth(),\n        });\n        const end = start.add(this.dayInterval, this._yearsPerPage);\n\n        return Array.from(calendarRange({ start, end, unit: this.dayInterval })).map(\n            (m) => m.native,\n        );\n    }\n\n    constructor(\n        public el: ElementRef,\n        @Inject(DAY_INTERVAL_TOKEN) dayInterval: DayInterval,\n    ) {\n        super(dayInterval);\n    }\n\n    /**\n     * Returns the locale representation of the year in the years view.\n     *\n     * @hidden\n     */\n    public formattedYear(value: Date): {long: string, formatted: string} {\n        const rawFormatter = new Intl.DateTimeFormat(this.locale, { year: 'numeric' });\n\n        if (this.formatView) {\n            return {\n                long: rawFormatter.format(value),\n                formatted: this._formatter.format(value)\n            }\n        }\n\n        return {\n            long: rawFormatter.format(value),\n            formatted: `${value.getFullYear()}`\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public yearTracker(_: number, item: Date): string {\n        return `${item.getFullYear()}}`;\n    }\n\n    /**\n     * @hidden\n     */\n    protected initFormatter() {\n        this._formatter = new Intl.DateTimeFormat(this._locale, {\n            year: this.yearFormat,\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    protected onMouseDown() {\n        if (this.tabIndex !== -1) {\n            this.el.nativeElement.focus();\n        }\n    }\n}\n","<div class=\"igx-calendar-view__items\" role=\"row\">\n    <span\n        igxCalendarYear\n        #item=\"igxCalendarYear\"\n        *ngFor=\"let year of range; trackBy: yearTracker\"\n        class=\"igx-calendar-view__item\"\n        role=\"gridcell\"\n        [attr.id]=\"year.getTime()\"\n        [attr.aria-label]=\"formattedYear(year).long\"\n        [attr.aria-selected]=\"item.isSelected\"\n        [attr.aria-current]=\"item.isCurrent\"\n        [value]=\"year\"\n        [date]=\"date\"\n        [showActive]=\"showActive\"\n        (itemSelection)=\"selectDate($event)\"\n        (mousedown)=\"onMouseDown()\"\n    >\n        <span class=\"igx-calendar-view__item-inner\" aria-hidden=\"true\">\n            {{ formattedYear(year).formatted }}\n        </span>\n    </span>\n</div>\n"]}