@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
223 lines • 19.1 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Input, Output, EventEmitter, HostBinding, ElementRef, HostListener } from '@angular/core';
import { isDateInRanges } from '../calendar';
import { CalendarSelection } from '../calendar-base';
/**
*@hidden
*/
let IgxDayItemComponent = class IgxDayItemComponent {
constructor(elementRef) {
this.elementRef = elementRef;
this.hideOutsideDays = false;
this.isLastInRange = false;
this.isFirstInRange = false;
this.isWithinRange = false;
this.onDateSelection = new EventEmitter();
this._selected = false;
}
/**
* Returns boolean indicating if the day is selected
*
*/
get selected() {
return this._selected;
}
/**
* Selects the day
*/
set selected(value) {
this._selected = value;
}
get isCurrentMonth() {
return this.date.isCurrentMonth;
}
get isPreviousMonth() {
return this.date.isPrevMonth;
}
get isNextMonth() {
return this.date.isNextMonth;
}
get nativeElement() {
return this.elementRef.nativeElement;
}
get isSelectedCSS() {
return (!this.isDisabled && this.selected);
}
get isInactive() {
return this.date.isNextMonth || this.date.isPrevMonth;
}
get isHidden() {
return this.hideOutsideDays && this.isInactive;
}
get isToday() {
const today = new Date(Date.now());
const date = this.date.date;
return (date.getFullYear() === today.getFullYear() &&
date.getMonth() === today.getMonth() &&
date.getDate() === today.getDate());
}
get isWeekend() {
const day = this.date.date.getDay();
return day === 0 || day === 6;
}
get isDisabled() {
if (this.disabledDates === null) {
return false;
}
return isDateInRanges(this.date.date, this.disabledDates);
}
get isOutOfRange() {
if (!this.outOfRangeDates) {
return false;
}
return isDateInRanges(this.date.date, this.outOfRangeDates);
}
get isFocusable() {
return this.isCurrentMonth && !this.isHidden && !this.isDisabled && !this.isOutOfRange;
}
get isWithinRangeCSS() {
return !this.isSingleSelection && this.isWithinRange;
}
get isSpecial() {
if (this.specialDates === null) {
return false;
}
return isDateInRanges(this.date.date, this.specialDates);
}
get defaultCSS() {
return this.date.isCurrentMonth && !(this.isWeekend && this.selected);
}
get isDisabledCSS() {
return this.isHidden || this.isDisabled || this.isOutOfRange;
}
get isSingleSelection() {
return this.selection !== CalendarSelection.RANGE;
}
get tabindex() {
return this.isDisabled || this.isHidden ? -1 : 0;
}
onSelect() {
this.onDateSelection.emit(this.date);
}
};
IgxDayItemComponent.ctorParameters = () => [
{ type: ElementRef }
];
__decorate([
Input(),
__metadata("design:type", Object)
], IgxDayItemComponent.prototype, "date", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxDayItemComponent.prototype, "selection", void 0);
__decorate([
Input(),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxDayItemComponent.prototype, "selected", null);
__decorate([
Input(),
__metadata("design:type", Array)
], IgxDayItemComponent.prototype, "disabledDates", void 0);
__decorate([
Input(),
__metadata("design:type", Array)
], IgxDayItemComponent.prototype, "outOfRangeDates", void 0);
__decorate([
Input(),
__metadata("design:type", Array)
], IgxDayItemComponent.prototype, "specialDates", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxDayItemComponent.prototype, "hideOutsideDays", void 0);
__decorate([
Input(),
HostBinding('class.igx-calendar__date--last'),
__metadata("design:type", Object)
], IgxDayItemComponent.prototype, "isLastInRange", void 0);
__decorate([
Input(),
HostBinding('class.igx-calendar__date--first'),
__metadata("design:type", Object)
], IgxDayItemComponent.prototype, "isFirstInRange", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxDayItemComponent.prototype, "isWithinRange", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxDayItemComponent.prototype, "onDateSelection", void 0);
__decorate([
HostBinding('class.igx-calendar__date--selected'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isSelectedCSS", null);
__decorate([
HostBinding('class.igx-calendar__date--inactive'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isInactive", null);
__decorate([
HostBinding('class.igx-calendar__date--hidden'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isHidden", null);
__decorate([
HostBinding('class.igx-calendar__date--current'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isToday", null);
__decorate([
HostBinding('class.igx-calendar__date--weekend'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isWeekend", null);
__decorate([
HostBinding('class.igx-calendar__date--range'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isWithinRangeCSS", null);
__decorate([
HostBinding('class.igx-calendar__date--special'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isSpecial", null);
__decorate([
HostBinding('class.igx-calendar__date'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "defaultCSS", null);
__decorate([
HostBinding('class.igx-calendar__date--disabled'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isDisabledCSS", null);
__decorate([
HostBinding('class.igx-calendar__date--single'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "isSingleSelection", null);
__decorate([
HostBinding('attr.tabindex'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxDayItemComponent.prototype, "tabindex", null);
__decorate([
HostListener('click'),
HostListener('keydown.enter'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], IgxDayItemComponent.prototype, "onSelect", null);
IgxDayItemComponent = __decorate([
Component({
selector: 'igx-day-item',
template: "<span class=\"igx-calendar__date-content\">\n <ng-content></ng-content>\n</span>\n"
}),
__metadata("design:paramtypes", [ElementRef])
], IgxDayItemComponent);
export { IgxDayItemComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"day-item.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/days-view/day-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, HostBinding, ElementRef, HostListener } from '@angular/core';\nimport { ICalendarDate, isDateInRanges } from '../calendar';\nimport { DateRangeDescriptor } from '../../core/dates';\nimport { CalendarSelection } from '../calendar-base';\n\n/**\n *@hidden\n*/\n@Component({\n    selector: 'igx-day-item',\n    templateUrl: 'day-item.component.html'\n})\nexport class IgxDayItemComponent {\n    @Input()\n    public date: ICalendarDate;\n\n    @Input()\n    public selection: string;\n\n    /**\n     * Returns boolean indicating if the day is selected\n     *\n     */\n    @Input()\n    public get selected(): any {\n        return this._selected;\n    }\n\n    /**\n     * Selects the day\n     */\n    public set selected(value: any) {\n        this._selected = value;\n    }\n\n    @Input()\n    public disabledDates: DateRangeDescriptor[];\n\n    @Input()\n    public outOfRangeDates: DateRangeDescriptor[];\n\n    @Input()\n    public specialDates: DateRangeDescriptor[];\n\n    @Input()\n    public hideOutsideDays = false;\n\n    @Input()\n    @HostBinding('class.igx-calendar__date--last')\n    public isLastInRange = false;\n\n    @Input()\n    @HostBinding('class.igx-calendar__date--first')\n    public isFirstInRange = false;\n\n    @Input()\n    public isWithinRange = false;\n\n    @Output()\n    public onDateSelection = new EventEmitter<ICalendarDate>();\n\n    public get isCurrentMonth(): boolean {\n        return this.date.isCurrentMonth;\n    }\n\n    public get isPreviousMonth(): boolean {\n        return this.date.isPrevMonth;\n    }\n\n    public get isNextMonth(): boolean {\n        return this.date.isNextMonth;\n    }\n\n    public get nativeElement() {\n        return this.elementRef.nativeElement;\n    }\n\n    @HostBinding('class.igx-calendar__date--selected')\n    public get isSelectedCSS(): boolean {\n        return (!this.isDisabled && this.selected);\n    }\n\n    @HostBinding('class.igx-calendar__date--inactive')\n    public get isInactive(): boolean {\n        return this.date.isNextMonth || this.date.isPrevMonth;\n    }\n\n    @HostBinding('class.igx-calendar__date--hidden')\n    public get isHidden(): boolean {\n        return this.hideOutsideDays && this.isInactive;\n    }\n\n    @HostBinding('class.igx-calendar__date--current')\n    public get isToday(): boolean {\n        const today = new Date(Date.now());\n        const date = this.date.date;\n        return (date.getFullYear() === today.getFullYear() &&\n            date.getMonth() === today.getMonth() &&\n            date.getDate() === today.getDate()\n        );\n    }\n\n    @HostBinding('class.igx-calendar__date--weekend')\n    public get isWeekend(): boolean {\n        const day = this.date.date.getDay();\n        return day === 0 || day === 6;\n    }\n\n    public get isDisabled(): boolean {\n        if (this.disabledDates === null) {\n            return false;\n        }\n\n        return isDateInRanges(this.date.date, this.disabledDates);\n    }\n\n    public get isOutOfRange(): boolean {\n        if (!this.outOfRangeDates) {\n            return false;\n        }\n\n        return isDateInRanges(this.date.date, this.outOfRangeDates);\n    }\n\n    public get isFocusable(): boolean {\n        return this.isCurrentMonth && !this.isHidden && !this.isDisabled && !this.isOutOfRange;\n    }\n\n    @HostBinding('class.igx-calendar__date--range')\n    public get isWithinRangeCSS(): boolean {\n        return !this.isSingleSelection && this.isWithinRange;\n    }\n\n    @HostBinding('class.igx-calendar__date--special')\n    public get isSpecial(): boolean {\n        if (this.specialDates === null) {\n            return false;\n        }\n\n        return isDateInRanges(this.date.date, this.specialDates);\n    }\n\n    @HostBinding('class.igx-calendar__date')\n    public get defaultCSS(): boolean {\n        return this.date.isCurrentMonth && !(this.isWeekend && this.selected);\n    }\n\n    @HostBinding('class.igx-calendar__date--disabled')\n    public get isDisabledCSS(): boolean {\n        return this.isHidden || this.isDisabled || this.isOutOfRange;\n    }\n\n    @HostBinding('class.igx-calendar__date--single')\n    public get isSingleSelection(): boolean {\n        return this.selection !== CalendarSelection.RANGE;\n    }\n\n    @HostBinding('attr.tabindex')\n    public get tabindex(): number {\n        return this.isDisabled || this.isHidden ? -1 : 0;\n    }\n\n    private _selected = false;\n\n    constructor(private elementRef: ElementRef) { }\n\n    @HostListener('click')\n    @HostListener('keydown.enter')\n    public onSelect() {\n        this.onDateSelection.emit(this.date);\n    }\n}\n"]}