@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
300 lines • 22.9 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
*/
var IgxDayItemComponent = /** @class */ (function () {
function IgxDayItemComponent(elementRef) {
this.elementRef = elementRef;
this.hideOutsideDays = false;
this.isLastInRange = false;
this.isFirstInRange = false;
this.isWithinRange = false;
this.onDateSelection = new EventEmitter();
this._selected = false;
}
Object.defineProperty(IgxDayItemComponent.prototype, "selected", {
/**
* Returns boolean indicating if the day is selected
*
*/
get: function () {
return this._selected;
},
/**
* Selects the day
*/
set: function (value) {
this._selected = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isCurrentMonth", {
get: function () {
return this.date.isCurrentMonth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isPreviousMonth", {
get: function () {
return this.date.isPrevMonth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isNextMonth", {
get: function () {
return this.date.isNextMonth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "nativeElement", {
get: function () {
return this.elementRef.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isSelectedCSS", {
get: function () {
return (!this.isDisabled && this.selected);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isInactive", {
get: function () {
return this.date.isNextMonth || this.date.isPrevMonth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isHidden", {
get: function () {
return this.hideOutsideDays && this.isInactive;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isToday", {
get: function () {
var today = new Date(Date.now());
var date = this.date.date;
return (date.getFullYear() === today.getFullYear() &&
date.getMonth() === today.getMonth() &&
date.getDate() === today.getDate());
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isWeekend", {
get: function () {
var day = this.date.date.getDay();
return day === 0 || day === 6;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isDisabled", {
get: function () {
if (this.disabledDates === null) {
return false;
}
return isDateInRanges(this.date.date, this.disabledDates);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isOutOfRange", {
get: function () {
if (!this.outOfRangeDates) {
return false;
}
return isDateInRanges(this.date.date, this.outOfRangeDates);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isFocusable", {
get: function () {
return this.isCurrentMonth && !this.isHidden && !this.isDisabled && !this.isOutOfRange;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isWithinRangeCSS", {
get: function () {
return !this.isSingleSelection && this.isWithinRange;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isSpecial", {
get: function () {
if (this.specialDates === null) {
return false;
}
return isDateInRanges(this.date.date, this.specialDates);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "defaultCSS", {
get: function () {
return this.date.isCurrentMonth && !(this.isWeekend && this.selected);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isDisabledCSS", {
get: function () {
return this.isHidden || this.isDisabled || this.isOutOfRange;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "isSingleSelection", {
get: function () {
return this.selection !== CalendarSelection.RANGE;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDayItemComponent.prototype, "tabindex", {
get: function () {
return this.isDisabled || this.isHidden ? -1 : 0;
},
enumerable: true,
configurable: true
});
IgxDayItemComponent.prototype.onSelect = function () {
this.onDateSelection.emit(this.date);
};
IgxDayItemComponent.ctorParameters = function () { return [
{ 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);
return 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"]}