igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
228 lines • 16.5 kB
JavaScript
/**
* @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"]}