UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

357 lines 36.3 kB
import { __decorate, __extends, __metadata, __values } from "tslib"; import { Component, Output, EventEmitter, Input, HostListener, ViewChildren, QueryList, HostBinding } from '@angular/core'; import { isDateInRanges } from '../../calendar/calendar'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { IgxDayItemComponent } from './day-item.component'; import { DateRangeType } from '../../core/dates'; import { IgxCalendarBaseDirective, CalendarSelection } from '../calendar-base'; import { isEqual } from '../../core/utils'; import { IgxDaysViewNavigationService } from './daysview-navigation.service'; var NEXT_ID = 0; var IgxDaysViewComponent = /** @class */ (function (_super) { __extends(IgxDaysViewComponent, _super); /** * @hidden */ function IgxDaysViewComponent(navService) { var _this = _super.call(this) || this; _this.navService = navService; /** * Sets/gets the `id` of the days view. * If not set, the `id` will have value `"igx-days-view-0"`. * ```html * <igx-days-view id="my-days-view"></igx-days-view> * ``` * ```typescript * let daysViewId = this.daysView.id; * ``` */ _this.id = "igx-days-view-" + NEXT_ID++; /** * @hidden */ _this.changeDaysView = false; /** * @hidden */ _this.onDateSelection = new EventEmitter(); /** * @hidden */ _this.onViewChanging = new EventEmitter(); /** * The default css class applied to the component. * * @hidden */ _this.styleClass = true; return _this; } IgxDaysViewComponent_1 = IgxDaysViewComponent; Object.defineProperty(IgxDaysViewComponent.prototype, "getCalendarMonth", { /** * @hidden */ get: function () { return this.calendarModel.monthdatescalendar(this.viewDate.getFullYear(), this.viewDate.getMonth(), true); }, enumerable: true, configurable: true }); /** * @hidden */ IgxDaysViewComponent.prototype.ngOnInit = function () { this.navService.monthView = this; }; /** * @hidden */ IgxDaysViewComponent.prototype.ngDoCheck = function () { if (!this.changeDaysView && this.dates) { this.disableOutOfRangeDates(); } }; /** * Returns the locale representation of the date in the days view. * * @hidden */ IgxDaysViewComponent.prototype.formattedDate = function (value) { if (this.formatViews.day) { return this.formatterDay.format(value); } return "" + value.getDate(); }; /** * @hidden */ IgxDaysViewComponent.prototype.generateWeekHeader = function () { var e_1, _a; var dayNames = []; var rv = this.calendarModel.monthdatescalendar(this.viewDate.getFullYear(), this.viewDate.getMonth())[0]; try { for (var rv_1 = __values(rv), rv_1_1 = rv_1.next(); !rv_1_1.done; rv_1_1 = rv_1.next()) { var day = rv_1_1.value; dayNames.push(this.formatterWeekday.format(day.date)); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (rv_1_1 && !rv_1_1.done && (_a = rv_1.return)) _a.call(rv_1); } finally { if (e_1) throw e_1.error; } } return dayNames; }; /** * @hidden */ IgxDaysViewComponent.prototype.rowTracker = function (index, item) { return "" + item[index].date.getMonth() + item[index].date.getDate(); }; /** * @hidden */ IgxDaysViewComponent.prototype.dateTracker = function (index, item) { return item.date.getMonth() + "--" + item.date.getDate(); }; /** * @hidden */ IgxDaysViewComponent.prototype.isCurrentMonth = function (value) { return this.viewDate.getMonth() === value.getMonth(); }; /** * @hidden */ IgxDaysViewComponent.prototype.isCurrentYear = function (value) { return this.viewDate.getFullYear() === value.getFullYear(); }; /** * @hidden */ IgxDaysViewComponent.prototype.isSelected = function (date) { var selectedDates; if (this.isDateDisabled(date.date) || !this.value || (Array.isArray(this.value) && this.value.length === 0)) { return false; } if (this.selection === CalendarSelection.SINGLE) { selectedDates = this.value; return this.getDateOnly(selectedDates).getTime() === date.date.getTime(); } selectedDates = this.value; if (this.selection === CalendarSelection.RANGE && selectedDates.length === 1) { return this.getDateOnly(selectedDates[0]).getTime() === date.date.getTime(); } if (this.selection === CalendarSelection.MULTI) { var start = this.getDateOnly(selectedDates[0]); var end = this.getDateOnly(selectedDates[selectedDates.length - 1]); if (this.isWithinRange(date.date, false, start, end)) { var currentDate = selectedDates.find(function (element) { return element.getTime() === date.date.getTime(); }); return !!currentDate; } else { return false; } } else { return this.isWithinRange(date.date, true); } }; /** * @hidden */ IgxDaysViewComponent.prototype.isLastInRange = function (date) { if (this.isSingleSelection || !this.value) { return false; } var dates = this.value; var lastDate = dates[dates.length - 1]; return isEqual(lastDate, date.date); }; /** * @hidden */ IgxDaysViewComponent.prototype.isFirstInRange = function (date) { if (this.isSingleSelection || !this.value) { return false; } return isEqual(this.value[0], date.date); }; /** * @hidden */ IgxDaysViewComponent.prototype.isWithinRange = function (date, checkForRange, min, max) { if (checkForRange && !(Array.isArray(this.value) && this.value.length > 1)) { return false; } min = min ? min : this.value[0]; max = max ? max : this.value[this.value.length - 1]; return isDateInRanges(date, [ { type: DateRangeType.Between, dateRange: [min, max] } ]); }; /** *@hidden */ IgxDaysViewComponent.prototype.focusActiveDate = function () { var date = this.dates.find(function (d) { return d.selected; }); if (!date) { date = this.dates.find(function (d) { return d.isToday; }); } if (date.isFocusable) { date.nativeElement.focus(); } }; /** * @hidden */ IgxDaysViewComponent.prototype.selectDay = function (event) { this.selectDateFromClient(event.date); this.onDateSelection.emit(event); this.onSelection.emit(this.selectedDates); }; /** * @hidden */ IgxDaysViewComponent.prototype.disableOutOfRangeDates = function () { var dateRange = []; this.dates.toArray().forEach(function (date) { if (!date.isCurrentMonth) { dateRange.push(date.date.date); } }); this.outOfRangeDates = [{ type: DateRangeType.Specific, dateRange: dateRange }]; }; /** * @hidden */ IgxDaysViewComponent.prototype.getFirstMonthView = function () { var monthView = this; while (monthView.prevMonthView) { monthView = monthView.prevMonthView; } return monthView; }; /** * @hidden */ IgxDaysViewComponent.prototype.getLastMonthView = function () { var monthView = this; while (monthView.nextMonthView) { monthView = monthView.nextMonthView; } return monthView; }; Object.defineProperty(IgxDaysViewComponent.prototype, "isSingleSelection", { /** * @hidden */ get: function () { return this.selection !== CalendarSelection.RANGE; }, enumerable: true, configurable: true }); /** * @hidden */ IgxDaysViewComponent.prototype.onKeydownArrow = function (event) { event.preventDefault(); event.stopPropagation(); this.navService.focusNextDate(event.target, event.key); }; /** * @hidden */ IgxDaysViewComponent.prototype.onKeydownHome = function (event) { event.preventDefault(); event.stopPropagation(); this.getFirstMonthView().navService.focusHomeDate(); }; /** * @hidden */ IgxDaysViewComponent.prototype.onKeydownEnd = function (event) { event.preventDefault(); event.stopPropagation(); this.getLastMonthView().navService.focusEndDate(); }; var IgxDaysViewComponent_1; IgxDaysViewComponent.ctorParameters = function () { return [ { type: IgxDaysViewNavigationService } ]; }; __decorate([ HostBinding('attr.id'), Input(), __metadata("design:type", Object) ], IgxDaysViewComponent.prototype, "id", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxDaysViewComponent.prototype, "changeDaysView", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxDaysViewComponent.prototype, "onDateSelection", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxDaysViewComponent.prototype, "onViewChanging", void 0); __decorate([ ViewChildren(IgxDayItemComponent, { read: IgxDayItemComponent }), __metadata("design:type", QueryList) ], IgxDaysViewComponent.prototype, "dates", void 0); __decorate([ HostBinding('class.igx-calendar'), __metadata("design:type", Object) ], IgxDaysViewComponent.prototype, "styleClass", void 0); __decorate([ HostListener('keydown.arrowleft', ['$event']), HostListener('keydown.arrowright', ['$event']), HostListener('keydown.arrowup', ['$event']), HostListener('keydown.arrowdown', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxDaysViewComponent.prototype, "onKeydownArrow", null); __decorate([ HostListener('keydown.home', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxDaysViewComponent.prototype, "onKeydownHome", null); __decorate([ HostListener('keydown.end', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxDaysViewComponent.prototype, "onKeydownEnd", null); IgxDaysViewComponent = IgxDaysViewComponent_1 = __decorate([ Component({ providers: [ { multi: true, provide: NG_VALUE_ACCESSOR, useExisting: IgxDaysViewComponent_1 }, { provide: IgxDaysViewNavigationService, useClass: IgxDaysViewNavigationService } ], selector: 'igx-days-view', template: "<div class=\"igx-calendar__body-row\">\n <span *ngFor=\"let dayName of generateWeekHeader()\" class=\"igx-calendar__label\">\n {{ dayName | titlecase }}\n </span>\n</div>\n\n<div *ngFor=\"let week of getCalendarMonth; last as isLast; index as i; trackBy: rowTracker\"\n class=\"igx-calendar__body-row\">\n <igx-day-item\n *ngFor=\"let day of week; trackBy: dateTracker\"\n [date]=\"day\"\n [selection]=\"selection\"\n [selected]=\"isSelected(day)\"\n [isLastInRange]=\"isLastInRange(day)\"\n [isFirstInRange]=\"isFirstInRange(day)\"\n [isWithinRange]=\"isWithinRange(day.date, true)\"\n [disabledDates]=\"disabledDates\"\n [specialDates]=\"specialDates\"\n [outOfRangeDates]=\"outOfRangeDates\"\n [hideOutsideDays]=\"hideOutsideDays\"\n (onDateSelection)=\"selectDay($event)\">\n {{ formattedDate(day.date) }}\n </igx-day-item>\n</div>\n" }), __metadata("design:paramtypes", [IgxDaysViewNavigationService]) ], IgxDaysViewComponent); return IgxDaysViewComponent; }(IgxCalendarBaseDirective)); export { IgxDaysViewComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"days-view.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/days-view/days-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Output,\n    EventEmitter,\n    Input,\n    HostListener,\n    ViewChildren,\n    QueryList,\n    HostBinding,\n    DoCheck,\n    OnInit\n} from '@angular/core';\nimport { ICalendarDate, isDateInRanges } from '../../calendar/calendar';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IgxDayItemComponent } from './day-item.component';\nimport { DateRangeDescriptor, DateRangeType } from '../../core/dates';\nimport { IgxCalendarBaseDirective, CalendarSelection } from '../calendar-base';\nimport { isEqual } from '../../core/utils';\nimport { IViewChangingEventArgs } from './days-view.interface';\nimport { IgxDaysViewNavigationService } from './daysview-navigation.service';\n\nlet NEXT_ID = 0;\n\n@Component({\n    providers: [\n        {\n            multi: true,\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: IgxDaysViewComponent\n        },\n        { provide: IgxDaysViewNavigationService, useClass: IgxDaysViewNavigationService }\n    ],\n    selector: 'igx-days-view',\n    templateUrl: 'days-view.component.html'\n})\nexport class IgxDaysViewComponent extends IgxCalendarBaseDirective implements DoCheck, OnInit {\n    /**\n     * Sets/gets the `id` of the days view.\n     * If not set, the `id` will have value `\"igx-days-view-0\"`.\n     * ```html\n     * <igx-days-view id=\"my-days-view\"></igx-days-view>\n     * ```\n     * ```typescript\n     * let daysViewId =  this.daysView.id;\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-days-view-${NEXT_ID++}`;\n\n    /**\n     * @hidden\n     */\n    @Input()\n    public changeDaysView = false;\n\n    /**\n     * @hidden\n     */\n    @Output()\n    public onDateSelection = new EventEmitter<ICalendarDate>();\n\n    /**\n     * @hidden\n     */\n    @Output()\n    public onViewChanging = new EventEmitter<IViewChangingEventArgs>();\n\n    /**\n     * @hidden\n     */\n    @ViewChildren(IgxDayItemComponent, { read: IgxDayItemComponent })\n    public dates: QueryList<IgxDayItemComponent>;\n\n    /**\n     * @hidden\n     */\n    public outOfRangeDates: DateRangeDescriptor[];\n\n    /**\n     * @hidden\n     */\n    public nextMonthView: IgxDaysViewComponent;\n\n    /**\n     * @hidden\n     */\n    public prevMonthView: IgxDaysViewComponent;\n\n    /**\n     * The default css class applied to the component.\n     *\n     * @hidden\n     */\n    @HostBinding('class.igx-calendar')\n    public styleClass = true;\n\n    /**\n     * @hidden\n     */\n    constructor(public navService: IgxDaysViewNavigationService) {\n        super();\n    }\n\n    /**\n     * @hidden\n     */\n    public get getCalendarMonth(): ICalendarDate[][] {\n        return this.calendarModel.monthdatescalendar(this.viewDate.getFullYear(), this.viewDate.getMonth(), true);\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnInit() {\n        this.navService.monthView = this;\n    }\n\n    /**\n     * @hidden\n     */\n    public ngDoCheck() {\n        if (!this.changeDaysView && this.dates) {\n            this.disableOutOfRangeDates();\n        }\n    }\n\n    /**\n     * Returns the locale representation of the date in the days view.\n     *\n     * @hidden\n     */\n    public formattedDate(value: Date): string {\n        if (this.formatViews.day) {\n            return this.formatterDay.format(value);\n        }\n        return `${value.getDate()}`;\n    }\n\n    /**\n     * @hidden\n     */\n    public generateWeekHeader(): string[] {\n        const dayNames = [];\n        const rv = this.calendarModel.monthdatescalendar(this.viewDate.getFullYear(), this.viewDate.getMonth())[0];\n        for (const day of rv) {\n            dayNames.push(this.formatterWeekday.format(day.date));\n        }\n\n        return dayNames;\n    }\n\n    /**\n     * @hidden\n     */\n    public rowTracker(index, item): string {\n        return `${item[index].date.getMonth()}${item[index].date.getDate()}`;\n    }\n\n    /**\n     * @hidden\n     */\n    public dateTracker(index, item): string {\n        return `${item.date.getMonth()}--${item.date.getDate()}`;\n    }\n\n    /**\n     * @hidden\n     */\n    public isCurrentMonth(value: Date): boolean {\n        return this.viewDate.getMonth() === value.getMonth();\n    }\n\n    /**\n     * @hidden\n     */\n    public isCurrentYear(value: Date): boolean {\n        return this.viewDate.getFullYear() === value.getFullYear();\n    }\n\n    /**\n     * @hidden\n     */\n    public isSelected(date: ICalendarDate): boolean {\n        let selectedDates: Date | Date[];\n        if (this.isDateDisabled(date.date) || !this.value ||\n            (Array.isArray(this.value) && this.value.length === 0)\n            )  {\n            return false;\n        }\n\n        if (this.selection === CalendarSelection.SINGLE) {\n            selectedDates = (this.value as Date);\n            return this.getDateOnly(selectedDates).getTime() === date.date.getTime();\n        }\n\n        selectedDates = (this.value as Date[]);\n        if (this.selection === CalendarSelection.RANGE && selectedDates.length === 1) {\n            return this.getDateOnly(selectedDates[0]).getTime() === date.date.getTime();\n        }\n\n        if (this.selection === CalendarSelection.MULTI) {\n            const start = this.getDateOnly(selectedDates[0]);\n            const end = this.getDateOnly(selectedDates[selectedDates.length - 1]);\n\n            if (this.isWithinRange(date.date, false, start, end)) {\n                const currentDate = selectedDates.find(element => element.getTime() === date.date.getTime());\n                return !!currentDate;\n            } else {\n                return false;\n            }\n\n        } else {\n            return this.isWithinRange(date.date, true);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public isLastInRange(date: ICalendarDate): boolean {\n        if (this.isSingleSelection || !this.value) {\n            return false;\n        }\n\n        const dates = this.value as Date[];\n        const lastDate = dates[dates.length - 1];\n        return isEqual(lastDate, date.date);\n    }\n\n    /**\n     * @hidden\n     */\n    public isFirstInRange(date: ICalendarDate): boolean {\n        if (this.isSingleSelection || !this.value) {\n            return false;\n        }\n\n        return isEqual((this.value as Date[])[0], date.date);\n    }\n\n    /**\n     * @hidden\n     */\n    public isWithinRange(date: Date, checkForRange: boolean, min?: Date, max?: Date): boolean {\n        if (checkForRange && !(Array.isArray(this.value) && this.value.length > 1)) {\n            return false;\n        }\n\n        min = min ? min : this.value[0];\n        max = max ? max : this.value[(this.value as Date[]).length - 1];\n\n        return isDateInRanges(date,\n            [\n                {\n                    type: DateRangeType.Between,\n                    dateRange: [min, max]\n                }\n            ]\n        );\n    }\n\n    /**\n     *@hidden\n     */\n    public focusActiveDate() {\n        let date = this.dates.find((d) => d.selected);\n\n        if (!date) {\n            date = this.dates.find((d) => d.isToday);\n        }\n\n        if (date.isFocusable) {\n            date.nativeElement.focus();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public selectDay(event) {\n        this.selectDateFromClient(event.date);\n        this.onDateSelection.emit(event);\n\n        this.onSelection.emit(this.selectedDates);\n    }\n\n    /**\n     * @hidden\n     */\n    private disableOutOfRangeDates() {\n        const dateRange = [];\n        this.dates.toArray().forEach((date) => {\n            if (!date.isCurrentMonth) {\n                dateRange.push(date.date.date);\n            }\n        });\n\n        this.outOfRangeDates = [{\n            type: DateRangeType.Specific,\n            dateRange: dateRange\n        }];\n    }\n\n    /**\n     * @hidden\n     */\n    public getFirstMonthView(): IgxDaysViewComponent {\n        let monthView = this as IgxDaysViewComponent;\n        while (monthView.prevMonthView) {\n            monthView = monthView.prevMonthView;\n        }\n        return monthView;\n    }\n\n    /**\n     * @hidden\n     */\n    private getLastMonthView(): IgxDaysViewComponent {\n        let monthView = this as IgxDaysViewComponent;\n        while (monthView.nextMonthView) {\n            monthView = monthView.nextMonthView;\n        }\n        return monthView;\n    }\n\n    /**\n     * @hidden\n     */\n    private get isSingleSelection(): boolean {\n        return this.selection !== CalendarSelection.RANGE;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowleft', ['$event'])\n    @HostListener('keydown.arrowright', ['$event'])\n    @HostListener('keydown.arrowup', ['$event'])\n    @HostListener('keydown.arrowdown', ['$event'])\n    public onKeydownArrow(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.navService.focusNextDate(event.target as HTMLElement, event.key);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.home', ['$event'])\n    public onKeydownHome(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.getFirstMonthView().navService.focusHomeDate();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.end', ['$event'])\n    public onKeydownEnd(event: KeyboardEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.getLastMonthView().navService.focusEndDate();\n    }\n}\n"]}