@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
253 lines • 21.1 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
*/
let IgxCalendarYearDirective = class IgxCalendarYearDirective {
constructor() {
this.onYearSelection = new EventEmitter();
}
get defaultCSS() {
return !this.isCurrentYear;
}
get currentCSS() {
return this.isCurrentYear;
}
get isCurrentYear() {
return this.date.getFullYear() === this.value.getFullYear();
}
onClick() {
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);
export { IgxCalendarYearDirective };
let IgxCalendarMonthDirective = class IgxCalendarMonthDirective {
constructor(elementRef) {
this.elementRef = elementRef;
this.onMonthSelection = new EventEmitter();
this.tabindex = 0;
}
get defaultCSS() {
return !this.isCurrentMonth;
}
get currentCSS() {
return this.isCurrentMonth;
}
get isCurrentMonth() {
return this.date.getMonth() === this.value.getMonth();
}
get nativeElement() {
return this.elementRef.nativeElement;
}
onClick() {
const date = new Date(this.value.getFullYear(), this.value.getMonth(), this.date.getDate());
this.onMonthSelection.emit(date);
}
};
IgxCalendarMonthDirective.ctorParameters = () => [
{ 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);
export { IgxCalendarMonthDirective };
/**
* @hidden
*/
let IgxCalendarHeaderTemplateDirective = class IgxCalendarHeaderTemplateDirective {
constructor(template) {
this.template = template;
}
};
IgxCalendarHeaderTemplateDirective.ctorParameters = () => [
{ type: TemplateRef }
];
IgxCalendarHeaderTemplateDirective = __decorate([
Directive({
selector: '[igxCalendarHeader]'
}),
__metadata("design:paramtypes", [TemplateRef])
], IgxCalendarHeaderTemplateDirective);
export { IgxCalendarHeaderTemplateDirective };
/**
* @hidden
*/
let IgxCalendarSubheaderTemplateDirective = class IgxCalendarSubheaderTemplateDirective {
constructor(template) {
this.template = template;
}
};
IgxCalendarSubheaderTemplateDirective.ctorParameters = () => [
{ type: TemplateRef }
];
IgxCalendarSubheaderTemplateDirective = __decorate([
Directive({
selector: '[igxCalendarSubheader]'
}),
__metadata("design:paramtypes", [TemplateRef])
], IgxCalendarSubheaderTemplateDirective);
export { IgxCalendarSubheaderTemplateDirective };
/**
* @hidden
*/
let IgxCalendarScrollMonthDirective = class IgxCalendarScrollMonthDirective {
constructor(element, zone) {
this.element = element;
this.zone = zone;
/**
* @hidden
*/
this.destroy$ = new Subject();
}
/**
* @hidden
*/
ngAfterViewInit() {
fromEvent(this.element.nativeElement, 'keyup').pipe(debounce(() => interval(100)), takeUntil(this.destroy$)).subscribe((event) => {
this.stopScroll(event);
});
this.zone.runOutsideAngular(() => {
fromEvent(this.element.nativeElement, 'keydown').pipe(tap((event) => {
if (event.key === " " /* SPACE */ || event.key === "Spacebar" /* SPACE_IE */ || event.key === "Enter" /* ENTER */) {
event.preventDefault();
event.stopPropagation();
}
}), debounce(() => interval(100)), takeUntil(this.destroy$)).subscribe((event) => {
if (event.key === " " /* SPACE */ || event.key === "Spacebar" /* SPACE_IE */ || event.key === "Enter" /* ENTER */) {
this.zone.run(() => this.startScroll(true));
}
});
});
}
/**
* @hidden
*/
ngOnDestroy() {
this.destroy$.next(true);
this.destroy$.complete();
}
/**
* @hidden
*/
onMouseDown() {
this.startScroll();
}
/**
* @hidden
*/
onMouseUp(event) {
this.stopScroll(event);
}
};
IgxCalendarScrollMonthDirective.ctorParameters = () => [
{ 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);
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"]}