@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
287 lines • 23.6 kB
JavaScript
import { __decorate, __metadata } from "tslib";
/**
* This file contains all the directives used by the @link IgxCalendarComponent.
* Except for the directives which are used for templating the calendar itself
* you should generally not use them directly.
* @preferred
*/
import { Directive, EventEmitter, HostBinding, HostListener, Input, Output, TemplateRef, ElementRef, AfterViewInit, OnDestroy, NgZone } from '@angular/core';
import { fromEvent, Subject, interval } from 'rxjs';
import { takeUntil, debounce, tap } from 'rxjs/operators';
/**
* @hidden
*/
var IgxCalendarYearDirective = /** @class */ (function () {
function IgxCalendarYearDirective() {
this.onYearSelection = new EventEmitter();
}
Object.defineProperty(IgxCalendarYearDirective.prototype, "defaultCSS", {
get: function () {
return !this.isCurrentYear;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxCalendarYearDirective.prototype, "currentCSS", {
get: function () {
return this.isCurrentYear;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxCalendarYearDirective.prototype, "isCurrentYear", {
get: function () {
return this.date.getFullYear() === this.value.getFullYear();
},
enumerable: true,
configurable: true
});
IgxCalendarYearDirective.prototype.onClick = function () {
this.onYearSelection.emit(this.value);
};
__decorate([
Input('igxCalendarYear'),
__metadata("design:type", Date)
], IgxCalendarYearDirective.prototype, "value", void 0);
__decorate([
Input(),
__metadata("design:type", Date)
], IgxCalendarYearDirective.prototype, "date", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxCalendarYearDirective.prototype, "onYearSelection", void 0);
__decorate([
HostBinding('class.igx-calendar__year'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxCalendarYearDirective.prototype, "defaultCSS", null);
__decorate([
HostBinding('class.igx-calendar__year--current'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxCalendarYearDirective.prototype, "currentCSS", null);
__decorate([
HostListener('click'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], IgxCalendarYearDirective.prototype, "onClick", null);
IgxCalendarYearDirective = __decorate([
Directive({
selector: '[igxCalendarYear]'
})
], IgxCalendarYearDirective);
return IgxCalendarYearDirective;
}());
export { IgxCalendarYearDirective };
var IgxCalendarMonthDirective = /** @class */ (function () {
function IgxCalendarMonthDirective(elementRef) {
this.elementRef = elementRef;
this.onMonthSelection = new EventEmitter();
this.tabindex = 0;
}
Object.defineProperty(IgxCalendarMonthDirective.prototype, "defaultCSS", {
get: function () {
return !this.isCurrentMonth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxCalendarMonthDirective.prototype, "currentCSS", {
get: function () {
return this.isCurrentMonth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxCalendarMonthDirective.prototype, "isCurrentMonth", {
get: function () {
return this.date.getMonth() === this.value.getMonth();
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxCalendarMonthDirective.prototype, "nativeElement", {
get: function () {
return this.elementRef.nativeElement;
},
enumerable: true,
configurable: true
});
IgxCalendarMonthDirective.prototype.onClick = function () {
var date = new Date(this.value.getFullYear(), this.value.getMonth(), this.date.getDate());
this.onMonthSelection.emit(date);
};
IgxCalendarMonthDirective.ctorParameters = function () { return [
{ type: ElementRef }
]; };
__decorate([
Input('igxCalendarMonth'),
__metadata("design:type", Date)
], IgxCalendarMonthDirective.prototype, "value", void 0);
__decorate([
Input(),
__metadata("design:type", Date)
], IgxCalendarMonthDirective.prototype, "date", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxCalendarMonthDirective.prototype, "index", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxCalendarMonthDirective.prototype, "onMonthSelection", void 0);
__decorate([
HostBinding('attr.tabindex'),
__metadata("design:type", Object)
], IgxCalendarMonthDirective.prototype, "tabindex", void 0);
__decorate([
HostBinding('class.igx-calendar__month'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxCalendarMonthDirective.prototype, "defaultCSS", null);
__decorate([
HostBinding('class.igx-calendar__month--current'),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [])
], IgxCalendarMonthDirective.prototype, "currentCSS", null);
__decorate([
HostListener('click'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], IgxCalendarMonthDirective.prototype, "onClick", null);
IgxCalendarMonthDirective = __decorate([
Directive({
selector: '[igxCalendarMonth]'
}),
__metadata("design:paramtypes", [ElementRef])
], IgxCalendarMonthDirective);
return IgxCalendarMonthDirective;
}());
export { IgxCalendarMonthDirective };
/**
* @hidden
*/
var IgxCalendarHeaderTemplateDirective = /** @class */ (function () {
function IgxCalendarHeaderTemplateDirective(template) {
this.template = template;
}
IgxCalendarHeaderTemplateDirective.ctorParameters = function () { return [
{ type: TemplateRef }
]; };
IgxCalendarHeaderTemplateDirective = __decorate([
Directive({
selector: '[igxCalendarHeader]'
}),
__metadata("design:paramtypes", [TemplateRef])
], IgxCalendarHeaderTemplateDirective);
return IgxCalendarHeaderTemplateDirective;
}());
export { IgxCalendarHeaderTemplateDirective };
/**
* @hidden
*/
var IgxCalendarSubheaderTemplateDirective = /** @class */ (function () {
function IgxCalendarSubheaderTemplateDirective(template) {
this.template = template;
}
IgxCalendarSubheaderTemplateDirective.ctorParameters = function () { return [
{ type: TemplateRef }
]; };
IgxCalendarSubheaderTemplateDirective = __decorate([
Directive({
selector: '[igxCalendarSubheader]'
}),
__metadata("design:paramtypes", [TemplateRef])
], IgxCalendarSubheaderTemplateDirective);
return IgxCalendarSubheaderTemplateDirective;
}());
export { IgxCalendarSubheaderTemplateDirective };
/**
* @hidden
*/
var IgxCalendarScrollMonthDirective = /** @class */ (function () {
function IgxCalendarScrollMonthDirective(element, zone) {
this.element = element;
this.zone = zone;
/**
* @hidden
*/
this.destroy$ = new Subject();
}
/**
* @hidden
*/
IgxCalendarScrollMonthDirective.prototype.ngAfterViewInit = function () {
var _this = this;
fromEvent(this.element.nativeElement, 'keyup').pipe(debounce(function () { return interval(100); }), takeUntil(this.destroy$)).subscribe(function (event) {
_this.stopScroll(event);
});
this.zone.runOutsideAngular(function () {
fromEvent(_this.element.nativeElement, 'keydown').pipe(tap(function (event) {
if (event.key === " " /* SPACE */ || event.key === "Spacebar" /* SPACE_IE */ || event.key === "Enter" /* ENTER */) {
event.preventDefault();
event.stopPropagation();
}
}), debounce(function () { return interval(100); }), takeUntil(_this.destroy$)).subscribe(function (event) {
if (event.key === " " /* SPACE */ || event.key === "Spacebar" /* SPACE_IE */ || event.key === "Enter" /* ENTER */) {
_this.zone.run(function () { return _this.startScroll(true); });
}
});
});
};
/**
* @hidden
*/
IgxCalendarScrollMonthDirective.prototype.ngOnDestroy = function () {
this.destroy$.next(true);
this.destroy$.complete();
};
/**
* @hidden
*/
IgxCalendarScrollMonthDirective.prototype.onMouseDown = function () {
this.startScroll();
};
/**
* @hidden
*/
IgxCalendarScrollMonthDirective.prototype.onMouseUp = function (event) {
this.stopScroll(event);
};
IgxCalendarScrollMonthDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: NgZone }
]; };
__decorate([
Input(),
__metadata("design:type", Function)
], IgxCalendarScrollMonthDirective.prototype, "startScroll", void 0);
__decorate([
Input(),
__metadata("design:type", Function)
], IgxCalendarScrollMonthDirective.prototype, "stopScroll", void 0);
__decorate([
HostListener('mousedown'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], IgxCalendarScrollMonthDirective.prototype, "onMouseDown", null);
__decorate([
HostListener('mouseup', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [MouseEvent]),
__metadata("design:returntype", void 0)
], IgxCalendarScrollMonthDirective.prototype, "onMouseUp", null);
IgxCalendarScrollMonthDirective = __decorate([
Directive({
selector: '[igxCalendarScrollMonth]'
}),
__metadata("design:paramtypes", [ElementRef, NgZone])
], IgxCalendarScrollMonthDirective);
return IgxCalendarScrollMonthDirective;
}());
export { IgxCalendarScrollMonthDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.directives.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/calendar/calendar.directives.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * This file contains all the directives used by the @link IgxCalendarComponent.\n * Except for the directives which are used for templating the calendar itself\n * you should generally not use them directly.\n * @preferred\n */\nimport {\n    Directive,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Input,\n    Output,\n    TemplateRef,\n    ElementRef,\n    AfterViewInit,\n    OnDestroy,\n    NgZone\n} from '@angular/core';\nimport { fromEvent, Subject, interval } from 'rxjs';\nimport { takeUntil, debounce, tap } from 'rxjs/operators';\nimport { KEYS } from '../core/utils';\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxCalendarYear]'\n})\nexport class IgxCalendarYearDirective {\n\n    @Input('igxCalendarYear')\n    public value: Date;\n\n    @Input()\n    public date: Date;\n\n    @Output()\n    public onYearSelection = new EventEmitter<Date>();\n\n    @HostBinding('class.igx-calendar__year')\n    public get defaultCSS(): boolean {\n        return !this.isCurrentYear;\n    }\n\n    @HostBinding('class.igx-calendar__year--current')\n    public get currentCSS(): boolean {\n        return this.isCurrentYear;\n    }\n\n    public get isCurrentYear(): boolean {\n        return this.date.getFullYear() === this.value.getFullYear();\n    }\n\n    @HostListener('click')\n    public onClick() {\n        this.onYearSelection.emit(this.value);\n    }\n}\n\n@Directive({\n    selector: '[igxCalendarMonth]'\n})\nexport class IgxCalendarMonthDirective {\n\n    @Input('igxCalendarMonth')\n    public value: Date;\n\n    @Input()\n    public date: Date;\n\n    @Input()\n    public index;\n\n    @Output()\n    public onMonthSelection = new EventEmitter<Date>();\n\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n    @HostBinding('class.igx-calendar__month')\n    public get defaultCSS(): boolean {\n        return !this.isCurrentMonth;\n    }\n\n    @HostBinding('class.igx-calendar__month--current')\n    public get currentCSS(): boolean {\n        return this.isCurrentMonth;\n    }\n\n    public get isCurrentMonth(): boolean {\n        return this.date.getMonth() === this.value.getMonth();\n    }\n\n    public get nativeElement() {\n        return this.elementRef.nativeElement;\n    }\n\n    constructor(public elementRef: ElementRef) {}\n\n    @HostListener('click')\n    public onClick() {\n        const date = new Date(this.value.getFullYear(), this.value.getMonth(), this.date.getDate());\n        this.onMonthSelection.emit(date);\n    }\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxCalendarHeader]'\n})\nexport class IgxCalendarHeaderTemplateDirective {\n\n    constructor(public template: TemplateRef<any>) {}\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxCalendarSubheader]'\n})\nexport class IgxCalendarSubheaderTemplateDirective {\n    constructor(public template: TemplateRef<any>) {}\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxCalendarScrollMonth]'\n})\nexport class IgxCalendarScrollMonthDirective implements AfterViewInit, OnDestroy {\n\n    /**\n     * A callback function to be invoked when month increment/decrement starts.\n     * @hidden\n     */\n    @Input()\n    public startScroll: (keydown?: boolean) => {};\n\n    /**\n     * A callback function to be invoked when month increment/decrement stops.\n     * @hidden\n     */\n    @Input()\n    public stopScroll: (event: any) => {};\n\n    /**\n     * @hidden\n     */\n    private destroy$ = new Subject<boolean>();\n\n    constructor(private element: ElementRef, private zone: NgZone) { }\n\n    /**\n     * @hidden\n     */\n    public ngAfterViewInit() {\n\n        fromEvent(this.element.nativeElement, 'keyup').pipe(\n            debounce(() => interval(100)),\n            takeUntil(this.destroy$)\n        ).subscribe((event: KeyboardEvent) => {\n            this.stopScroll(event);\n        });\n\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.element.nativeElement, 'keydown').pipe(\n                tap((event: KeyboardEvent) => {\n                    if (event.key === KEYS.SPACE || event.key === KEYS.SPACE_IE || event.key === KEYS.ENTER) {\n                        event.preventDefault();\n                        event.stopPropagation();\n                    }\n                }),\n                debounce(() => interval(100)),\n                takeUntil(this.destroy$)\n            ).subscribe((event: KeyboardEvent) => {\n                if (event.key === KEYS.SPACE || event.key === KEYS.SPACE_IE || event.key === KEYS.ENTER) {\n                    this.zone.run(() => this.startScroll(true));\n                }\n            });\n        });\n\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy() {\n        this.destroy$.next(true);\n        this.destroy$.complete();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mousedown')\n    public onMouseDown() {\n        this.startScroll();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mouseup', ['$event'])\n    public onMouseUp(event: MouseEvent) {\n        this.stopScroll(event);\n    }\n}\n"]}