UNPKG

@catull/igniteui-angular

Version:

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

253 lines 21.1 kB
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"]}