UNPKG

@catull/igniteui-angular

Version:

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

110 lines 14 kB
import { __decorate, __metadata, __param } from "tslib"; import { Directive, ElementRef, Inject, Input, NgZone, Output, OnInit, OnDestroy, } from '@angular/core'; import { DOCUMENT } from '@angular/common'; import { Subject, fromEvent, animationFrameScheduler, interval } from 'rxjs'; import { map, switchMap, takeUntil, throttle } from 'rxjs/operators'; /** * @hidden * @internal */ var IgxColumnResizerDirective = /** @class */ (function () { function IgxColumnResizerDirective(element, document, zone) { var _this = this; this.element = element; this.document = document; this.zone = zone; this.restrictHResizeMin = Number.MIN_SAFE_INTEGER; this.restrictHResizeMax = Number.MAX_SAFE_INTEGER; this.resizeEnd = new Subject(); this.resizeStart = new Subject(); this.resize = new Subject(); this._destroy = new Subject(); this.resizeStart.pipe(map(function (event) { return event.clientX; }), takeUntil(this._destroy), switchMap(function (offset) { return _this.resize.pipe(map(function (event) { return event.clientX - offset; }), takeUntil(_this.resizeEnd), takeUntil(_this._destroy)); })).subscribe(function (pos) { var left = _this._left + pos; var min = _this._left - _this.restrictHResizeMin; var max = _this._left + _this.restrictHResizeMax; _this.left = left < min ? min : left; if (left > max) { _this.left = max; } }); } IgxColumnResizerDirective.prototype.ngOnInit = function () { var _this = this; this.zone.runOutsideAngular(function () { fromEvent(_this.document.defaultView, 'mousemove').pipe(throttle(function () { return interval(0, animationFrameScheduler); }), takeUntil(_this._destroy)).subscribe(function (res) { return _this.onMousemove(res); }); fromEvent(_this.document.defaultView, 'mouseup').pipe(takeUntil(_this._destroy)) .subscribe(function (res) { return _this.onMouseup(res); }); }); }; IgxColumnResizerDirective.prototype.ngOnDestroy = function () { this._destroy.next(true); this._destroy.complete(); }; Object.defineProperty(IgxColumnResizerDirective.prototype, "left", { set: function (val) { var _this = this; requestAnimationFrame(function () { return _this.element.nativeElement.style.left = val + 'px'; }); }, enumerable: true, configurable: true }); Object.defineProperty(IgxColumnResizerDirective.prototype, "top", { set: function (val) { var _this = this; requestAnimationFrame(function () { return _this.element.nativeElement.style.top = val + 'px'; }); }, enumerable: true, configurable: true }); IgxColumnResizerDirective.prototype.onMouseup = function (event) { this.resizeEnd.next(event); this.resizeEnd.complete(); }; IgxColumnResizerDirective.prototype.onMousedown = function (event) { event.preventDefault(); var parent = this.element.nativeElement.parentElement.parentElement; this.left = this._left = event.clientX - parent.getBoundingClientRect().left; this.top = event.target.getBoundingClientRect().top - parent.getBoundingClientRect().top; this.resizeStart.next(event); }; IgxColumnResizerDirective.prototype.onMousemove = function (event) { event.preventDefault(); this.resize.next(event); }; IgxColumnResizerDirective.ctorParameters = function () { return [ { type: ElementRef }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }, { type: NgZone } ]; }; __decorate([ Input(), __metadata("design:type", Number) ], IgxColumnResizerDirective.prototype, "restrictHResizeMin", void 0); __decorate([ Input(), __metadata("design:type", Number) ], IgxColumnResizerDirective.prototype, "restrictHResizeMax", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxColumnResizerDirective.prototype, "resizeEnd", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxColumnResizerDirective.prototype, "resizeStart", void 0); __decorate([ Output(), __metadata("design:type", Object) ], IgxColumnResizerDirective.prototype, "resize", void 0); IgxColumnResizerDirective = __decorate([ Directive({ selector: '[igxResizer]' }), __param(1, Inject(DOCUMENT)), __metadata("design:paramtypes", [ElementRef, Object, NgZone]) ], IgxColumnResizerDirective); return IgxColumnResizerDirective; }()); export { IgxColumnResizerDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizer.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/resizing/resizer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    Inject,\n    Input,\n    NgZone,\n    Output,\n    OnInit,\n    OnDestroy,\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { Subject, fromEvent, animationFrameScheduler, interval } from 'rxjs';\nimport { map, switchMap, takeUntil, throttle } from 'rxjs/operators';\n\n/**\n * @hidden\n * @internal\n */\n@Directive({\n    selector: '[igxResizer]'\n})\nexport class IgxColumnResizerDirective implements OnInit, OnDestroy {\n\n    @Input()\n    public restrictHResizeMin: number = Number.MIN_SAFE_INTEGER;\n\n    @Input()\n    public restrictHResizeMax: number = Number.MAX_SAFE_INTEGER;\n\n    @Output()\n    public resizeEnd = new Subject<any>();\n\n    @Output()\n    public resizeStart = new Subject<any>();\n\n    @Output()\n    public resize = new Subject<any>();\n\n    private _left;\n    private _destroy = new Subject<boolean>();\n\n    constructor(public element: ElementRef, @Inject(DOCUMENT) public document, public zone: NgZone) {\n\n        this.resizeStart.pipe(\n            map((event) => event.clientX),\n            takeUntil(this._destroy),\n            switchMap((offset) => this.resize.pipe(\n                map((event) => event.clientX - offset),\n                takeUntil(this.resizeEnd),\n                takeUntil(this._destroy)\n            ))\n        ).subscribe((pos) => {\n\n            const left = this._left + pos;\n\n            const min = this._left - this.restrictHResizeMin;\n            const max = this._left + this.restrictHResizeMax;\n\n            this.left = left < min ? min : left;\n\n            if (left > max) {\n                this.left = max;\n            }\n        });\n\n    }\n\n    ngOnInit() {\n        this.zone.runOutsideAngular(() => {\n            fromEvent(this.document.defaultView, 'mousemove').pipe(\n                throttle(() => interval(0, animationFrameScheduler)),\n                takeUntil(this._destroy)\n            ).subscribe((res) => this.onMousemove(res));\n\n            fromEvent(this.document.defaultView, 'mouseup').pipe(takeUntil(this._destroy))\n                .subscribe((res) => this.onMouseup(res));\n        });\n    }\n\n    ngOnDestroy() {\n        this._destroy.next(true);\n        this._destroy.complete();\n    }\n\n    public set left(val) {\n        requestAnimationFrame(() => this.element.nativeElement.style.left = val + 'px');\n    }\n\n    public set top(val) {\n        requestAnimationFrame(() => this.element.nativeElement.style.top = val + 'px');\n    }\n\n    onMouseup(event) {\n        this.resizeEnd.next(event);\n        this.resizeEnd.complete();\n    }\n\n    onMousedown(event) {\n        event.preventDefault();\n        const parent = this.element.nativeElement.parentElement.parentElement;\n\n        this.left = this._left = event.clientX - parent.getBoundingClientRect().left;\n        this.top = event.target.getBoundingClientRect().top - parent.getBoundingClientRect().top;\n\n        this.resizeStart.next(event);\n    }\n\n    onMousemove(event) {\n        event.preventDefault();\n        this.resize.next(event);\n    }\n}\n"]}