UNPKG

igniteui-angular

Version:

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

228 lines • 16.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter, HostBinding, ElementRef, HostListener } from '@angular/core'; import { isDateInRanges } from '../calendar'; import { CalendarSelection } from '../calendar-base'; /** * @hidden */ export class IgxDayItemComponent { /** * @param {?} elementRef */ constructor(elementRef) { this.elementRef = elementRef; this.onDateSelection = new EventEmitter(); this.tabindex = 0; this._selected = false; } /** * @return {?} */ get selected() { /** @type {?} */ const date = this.date.date; if (!this.value) { return; } if (this.selection === CalendarSelection.SINGLE) { this._selected = ((/** @type {?} */ (this.value))).getTime() === date.getTime(); } else { this._selected = ((/** @type {?} */ (this.value))) .some((each) => each.getTime() === date.getTime()); } return this._selected; } /** * @param {?} value * @return {?} */ set selected(value) { this._selected = value; } /** * @return {?} */ get isCurrentMonth() { return this.date.isCurrentMonth; } /** * @return {?} */ get isPreviousMonth() { return this.date.isPrevMonth; } /** * @return {?} */ get isNextMonth() { return this.date.isNextMonth; } /** * @return {?} */ get nativeElement() { return this.elementRef.nativeElement; } /** * @return {?} */ get isInactive() { return this.date.isNextMonth || this.date.isPrevMonth; } /** * @return {?} */ get isToday() { /** @type {?} */ const today = new Date(Date.now()); /** @type {?} */ const date = this.date.date; return (date.getFullYear() === today.getFullYear() && date.getMonth() === today.getMonth() && date.getDate() === today.getDate()); } /** * @return {?} */ get isWeekend() { /** @type {?} */ const day = this.date.date.getDay(); return day === 0 || day === 6; } /** * @return {?} */ get isDisabled() { if (this.disabledDates === null) { return false; } return isDateInRanges(this.date.date, this.disabledDates); } /** * @return {?} */ get isOutOfRange() { if (!this.outOfRangeDates) { return false; } return isDateInRanges(this.date.date, this.outOfRangeDates); } /** * @return {?} */ get isSpecial() { if (this.specialDates === null) { return false; } return isDateInRanges(this.date.date, this.specialDates); } /** * @return {?} */ get defaultCSS() { return this.date.isCurrentMonth && !(this.isWeekend && this.selected); } /** * @return {?} */ get isInactiveCSS() { return this.isInactive; } /** * @return {?} */ get isTodayCSS() { return this.isToday && !this.selected; } /** * @return {?} */ get isSelectedCSS() { return this.selected; } /** * @return {?} */ get isWeekendCSS() { return this.isWeekend; } /** * @return {?} */ get isDisabledCSS() { return this.isDisabled || this.isOutOfRange; } /** * @return {?} */ get isSpecialCSS() { return this.isSpecial; } /** * @return {?} */ onSelect() { this.onDateSelection.emit(this.date); } } IgxDayItemComponent.decorators = [ { type: Component, args: [{ selector: 'igx-day-item', template: "<ng-content></ng-content>\n" }] } ]; /** @nocollapse */ IgxDayItemComponent.ctorParameters = () => [ { type: ElementRef } ]; IgxDayItemComponent.propDecorators = { date: [{ type: Input }], selection: [{ type: Input }], value: [{ type: Input }], disabledDates: [{ type: Input }], outOfRangeDates: [{ type: Input }], specialDates: [{ type: Input }], onDateSelection: [{ type: Output }], tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }], defaultCSS: [{ type: HostBinding, args: ['class.igx-calendar__date',] }], isInactiveCSS: [{ type: HostBinding, args: ['class.igx-calendar__date--inactive',] }], isTodayCSS: [{ type: HostBinding, args: ['class.igx-calendar__date--current',] }], isSelectedCSS: [{ type: HostBinding, args: ['class.igx-calendar__date--selected',] }], isWeekendCSS: [{ type: HostBinding, args: ['class.igx-calendar__date--weekend',] }], isDisabledCSS: [{ type: HostBinding, args: ['class.igx-calendar__date--disabled',] }], isSpecialCSS: [{ type: HostBinding, args: ['class.igx-calendar__date--special',] }], onSelect: [{ type: HostListener, args: ['click',] }, { type: HostListener, args: ['keydown.enter',] }] }; if (false) { /** @type {?} */ IgxDayItemComponent.prototype.date; /** @type {?} */ IgxDayItemComponent.prototype.selection; /** @type {?} */ IgxDayItemComponent.prototype.value; /** @type {?} */ IgxDayItemComponent.prototype.disabledDates; /** @type {?} */ IgxDayItemComponent.prototype.outOfRangeDates; /** @type {?} */ IgxDayItemComponent.prototype.specialDates; /** @type {?} */ IgxDayItemComponent.prototype.onDateSelection; /** @type {?} */ IgxDayItemComponent.prototype.tabindex; /** * @type {?} * @private */ IgxDayItemComponent.prototype._selected; /** * @type {?} * @private */ IgxDayItemComponent.prototype.elementRef; } //# 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    @Input()\n    public value: Date | Date[];\n\n    @Input()\n    public disabledDates: DateRangeDescriptor[];\n\n    @Input()\n    public outOfRangeDates: DateRangeDescriptor[];\n\n    @Input()\n    public specialDates: DateRangeDescriptor[];\n\n    @Output()\n    public onDateSelection = new EventEmitter<ICalendarDate>();\n\n    public get selected(): boolean {\n        const date = this.date.date;\n\n        if (!this.value) {\n            return;\n        }\n\n        if (this.selection === CalendarSelection.SINGLE) {\n        this._selected = (this.value as Date).getTime() === date.getTime();\n        } else {\n        this._selected = (this.value as Date[])\n            .some((each) => each.getTime() === date.getTime());\n        }\n\n        return this._selected;\n    }\n\n    public set selected(value: boolean) {\n        this._selected = value;\n    }\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    public get isInactive(): boolean {\n        return this.date.isNextMonth || this.date.isPrevMonth;\n    }\n\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    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 isSpecial(): boolean {\n        if (this.specialDates === null) {\n            return false;\n        }\n\n        return isDateInRanges(this.date.date, this.specialDates);\n    }\n\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\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--inactive')\n    public get isInactiveCSS(): boolean {\n        return this.isInactive;\n    }\n\n    @HostBinding('class.igx-calendar__date--current')\n    public get isTodayCSS(): boolean {\n        return this.isToday && !this.selected;\n    }\n\n    @HostBinding('class.igx-calendar__date--selected')\n    public get isSelectedCSS(): boolean {\n        return this.selected;\n    }\n\n    @HostBinding('class.igx-calendar__date--weekend')\n    public get isWeekendCSS(): boolean {\n        return this.isWeekend;\n    }\n\n    @HostBinding('class.igx-calendar__date--disabled')\n    public get isDisabledCSS(): boolean {\n        return this.isDisabled || this.isOutOfRange;\n    }\n\n    @HostBinding('class.igx-calendar__date--special')\n    public get isSpecialCSS(): boolean {\n        return this.isSpecial;\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"]}