@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
334 lines • 33.9 kB
JavaScript
var IgxDaysViewComponent_1;
import { __decorate, __metadata } 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';
let NEXT_ID = 0;
let IgxDaysViewComponent = IgxDaysViewComponent_1 = class IgxDaysViewComponent extends IgxCalendarBaseDirective {
/**
* @hidden
*/
constructor(navService) {
super();
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;
}
/**
* @hidden
*/
get getCalendarMonth() {
return this.calendarModel.monthdatescalendar(this.viewDate.getFullYear(), this.viewDate.getMonth(), true);
}
/**
* @hidden
*/
ngOnInit() {
this.navService.monthView = this;
}
/**
* @hidden
*/
ngDoCheck() {
if (!this.changeDaysView && this.dates) {
this.disableOutOfRangeDates();
}
}
/**
* Returns the locale representation of the date in the days view.
*
* @hidden
*/
formattedDate(value) {
if (this.formatViews.day) {
return this.formatterDay.format(value);
}
return `${value.getDate()}`;
}
/**
* @hidden
*/
generateWeekHeader() {
const dayNames = [];
const rv = this.calendarModel.monthdatescalendar(this.viewDate.getFullYear(), this.viewDate.getMonth())[0];
for (const day of rv) {
dayNames.push(this.formatterWeekday.format(day.date));
}
return dayNames;
}
/**
* @hidden
*/
rowTracker(index, item) {
return `${item[index].date.getMonth()}${item[index].date.getDate()}`;
}
/**
* @hidden
*/
dateTracker(index, item) {
return `${item.date.getMonth()}--${item.date.getDate()}`;
}
/**
* @hidden
*/
isCurrentMonth(value) {
return this.viewDate.getMonth() === value.getMonth();
}
/**
* @hidden
*/
isCurrentYear(value) {
return this.viewDate.getFullYear() === value.getFullYear();
}
/**
* @hidden
*/
isSelected(date) {
let 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) {
const start = this.getDateOnly(selectedDates[0]);
const end = this.getDateOnly(selectedDates[selectedDates.length - 1]);
if (this.isWithinRange(date.date, false, start, end)) {
const currentDate = selectedDates.find(element => element.getTime() === date.date.getTime());
return !!currentDate;
}
else {
return false;
}
}
else {
return this.isWithinRange(date.date, true);
}
}
/**
* @hidden
*/
isLastInRange(date) {
if (this.isSingleSelection || !this.value) {
return false;
}
const dates = this.value;
const lastDate = dates[dates.length - 1];
return isEqual(lastDate, date.date);
}
/**
* @hidden
*/
isFirstInRange(date) {
if (this.isSingleSelection || !this.value) {
return false;
}
return isEqual(this.value[0], date.date);
}
/**
* @hidden
*/
isWithinRange(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
*/
focusActiveDate() {
let date = this.dates.find((d) => d.selected);
if (!date) {
date = this.dates.find((d) => d.isToday);
}
if (date.isFocusable) {
date.nativeElement.focus();
}
}
/**
* @hidden
*/
selectDay(event) {
this.selectDateFromClient(event.date);
this.onDateSelection.emit(event);
this.onSelection.emit(this.selectedDates);
}
/**
* @hidden
*/
disableOutOfRangeDates() {
const dateRange = [];
this.dates.toArray().forEach((date) => {
if (!date.isCurrentMonth) {
dateRange.push(date.date.date);
}
});
this.outOfRangeDates = [{
type: DateRangeType.Specific,
dateRange: dateRange
}];
}
/**
* @hidden
*/
getFirstMonthView() {
let monthView = this;
while (monthView.prevMonthView) {
monthView = monthView.prevMonthView;
}
return monthView;
}
/**
* @hidden
*/
getLastMonthView() {
let monthView = this;
while (monthView.nextMonthView) {
monthView = monthView.nextMonthView;
}
return monthView;
}
/**
* @hidden
*/
get isSingleSelection() {
return this.selection !== CalendarSelection.RANGE;
}
/**
* @hidden
*/
onKeydownArrow(event) {
event.preventDefault();
event.stopPropagation();
this.navService.focusNextDate(event.target, event.key);
}
/**
* @hidden
*/
onKeydownHome(event) {
event.preventDefault();
event.stopPropagation();
this.getFirstMonthView().navService.focusHomeDate();
}
/**
* @hidden
*/
onKeydownEnd(event) {
event.preventDefault();
event.stopPropagation();
this.getLastMonthView().navService.focusEndDate();
}
};
IgxDaysViewComponent.ctorParameters = () => [
{ 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);
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"]}