@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
110 lines • 14 kB
JavaScript
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"]}