UNPKG

@catull/igniteui-angular

Version:

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

287 lines 23.6 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 */ 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"]}