UNPKG

@catull/igniteui-angular

Version:

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

300 lines 22.9 kB
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"]}