@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
178 lines • 23.2 kB
JavaScript
import { __decorate, __extends, __metadata } from "tslib";
import { Directive, Input, OnDestroy, ElementRef, Renderer2, NgZone } from '@angular/core';
import { IgxColumnComponent } from '../columns/column.component';
import { DropPosition, IgxColumnMovingService } from './moving.service';
import { Subject, interval } from 'rxjs';
import { IgxColumnMovingDragDirective } from './moving.drag.directive';
import { takeUntil } from 'rxjs/operators';
import { IgxDropDirective } from '../../directives/drag-drop/drag-drop.directive';
import { IgxGridForOfDirective } from '../../directives/for-of/for_of.directive';
var IgxColumnMovingDropDirective = /** @class */ (function (_super) {
__extends(IgxColumnMovingDropDirective, _super);
function IgxColumnMovingDropDirective(elementRef, renderer, zone, cms) {
var _this = _super.call(this, elementRef, renderer, zone) || this;
_this.elementRef = elementRef;
_this.renderer = renderer;
_this.zone = zone;
_this.cms = cms;
_this._dropIndicator = null;
_this._lastDropIndicator = null;
_this._dragLeave = new Subject();
_this._dropIndicatorClass = 'igx-grid__th-drop-indicator--active';
return _this;
}
Object.defineProperty(IgxColumnMovingDropDirective.prototype, "data", {
set: function (val) {
if (val instanceof IgxColumnComponent) {
this._column = val;
}
if (val instanceof IgxGridForOfDirective) {
this._hVirtDir = val;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnMovingDropDirective.prototype, "column", {
get: function () {
return this._column;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnMovingDropDirective.prototype, "isDropTarget", {
get: function () {
return this._column && this._column.grid.hasMovableColumns && this.cms.column.movable &&
((!this._column.pinned && this.cms.column.disablePinning) || !this.cms.column.disablePinning);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnMovingDropDirective.prototype, "horizontalScroll", {
get: function () {
if (this._hVirtDir) {
return this._hVirtDir;
}
},
enumerable: true,
configurable: true
});
IgxColumnMovingDropDirective.prototype.ngOnDestroy = function () {
this._dragLeave.next(true);
this._dragLeave.complete();
};
IgxColumnMovingDropDirective.prototype.onDragOver = function (event) {
var drag = event.detail.owner;
if (!(drag instanceof IgxColumnMovingDragDirective)) {
return;
}
if (this.isDropTarget &&
this.cms.column !== this.column &&
this.cms.column.level === this.column.level &&
this.cms.column.parent === this.column.parent) {
if (this._lastDropIndicator) {
this.renderer.removeClass(this._dropIndicator, this._dropIndicatorClass);
}
var clientRect = this.elementRef.nativeElement.getBoundingClientRect();
var pos = clientRect.left + clientRect.width / 2;
var parent_1 = this.elementRef.nativeElement.parentElement;
if (event.detail.pageX < pos) {
this._dropPos = DropPosition.BeforeDropTarget;
this._lastDropIndicator = this._dropIndicator = parent_1.firstElementChild;
}
else {
this._dropPos = DropPosition.AfterDropTarget;
this._lastDropIndicator = this._dropIndicator = parent_1.lastElementChild;
}
if (this.cms.icon.innerText !== 'block') {
this.renderer.addClass(this._dropIndicator, this._dropIndicatorClass);
}
}
};
IgxColumnMovingDropDirective.prototype.onDragEnter = function (event) {
var _this = this;
var drag = event.detail.owner;
if (!(drag instanceof IgxColumnMovingDragDirective)) {
return;
}
if (this.column && this.cms.column.grid.id !== this.column.grid.id) {
this.cms.icon.innerText = 'block';
return;
}
if (this.isDropTarget &&
this.cms.column !== this.column &&
this.cms.column.level === this.column.level &&
this.cms.column.parent === this.column.parent) {
if (!this.column.pinned || (this.column.pinned && this.cms.column.pinned)) {
this.cms.icon.innerText = 'swap_horiz';
}
this.cms.icon.innerText = 'lock';
}
else {
this.cms.icon.innerText = 'block';
}
if (this.horizontalScroll) {
this.cms.icon.innerText = event.target.id === 'right' ? 'arrow_forward' : 'arrow_back';
interval(100).pipe(takeUntil(this._dragLeave)).subscribe(function () {
_this.cms.column.grid.wheelHandler();
event.target.id === 'right' ? _this.horizontalScroll.scrollPosition += 15 :
_this.horizontalScroll.scrollPosition -= 15;
});
}
};
IgxColumnMovingDropDirective.prototype.onDragLeave = function (event) {
var drag = event.detail.owner;
if (!(drag instanceof IgxColumnMovingDragDirective)) {
return;
}
this.cms.icon.innerText = 'block';
if (this._dropIndicator) {
this.renderer.removeClass(this._dropIndicator, this._dropIndicatorClass);
}
if (this.horizontalScroll) {
this._dragLeave.next(true);
}
};
IgxColumnMovingDropDirective.prototype.onDragDrop = function (event) {
event.preventDefault();
var drag = event.detail.owner;
if (!(drag instanceof IgxColumnMovingDragDirective)) {
return;
}
if (this.column && (this.cms.column.grid.id !== this.column.grid.id)) {
return;
}
if (this.horizontalScroll) {
this._dragLeave.next(true);
}
if (this.isDropTarget) {
var args = {
source: this.cms.column,
target: this.column
};
this.column.grid.moveColumn(this.cms.column, this.column, this._dropPos);
this.column.grid.draggedColumn = null;
this.column.grid.cdr.detectChanges();
}
};
IgxColumnMovingDropDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 },
{ type: NgZone },
{ type: IgxColumnMovingService }
]; };
__decorate([
Input('igxColumnMovingDrop'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxColumnMovingDropDirective.prototype, "data", null);
IgxColumnMovingDropDirective = __decorate([
Directive({
selector: '[igxColumnMovingDrop]'
}),
__metadata("design:paramtypes", [ElementRef, Renderer2, NgZone, IgxColumnMovingService])
], IgxColumnMovingDropDirective);
return IgxColumnMovingDropDirective;
}(IgxDropDirective));
export { IgxColumnMovingDropDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"moving.drop.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/moving/moving.drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnDestroy, ElementRef, Renderer2, NgZone } from '@angular/core';\nimport { IgxColumnComponent } from '../columns/column.component';\nimport { DropPosition, IgxColumnMovingService } from './moving.service';\nimport { Subject, interval } from 'rxjs';\nimport { IgxColumnMovingDragDirective } from './moving.drag.directive';\nimport { takeUntil } from 'rxjs/operators';\nimport { IgxDropDirective } from '../../directives/drag-drop/drag-drop.directive';\nimport { IgxGridForOfDirective } from '../../directives/for-of/for_of.directive';\n\n\n@Directive({\n    selector: '[igxColumnMovingDrop]'\n})\nexport class IgxColumnMovingDropDirective extends IgxDropDirective implements OnDestroy {\n\n    @Input('igxColumnMovingDrop')\n    set data(val: any) {\n        if (val instanceof IgxColumnComponent) {\n            this._column = val;\n        }\n\n        if (val instanceof IgxGridForOfDirective) {\n            this._hVirtDir = val;\n        }\n    }\n\n    get column(): IgxColumnComponent {\n        return this._column;\n    }\n\n    get isDropTarget(): boolean {\n        return this._column && this._column.grid.hasMovableColumns && this.cms.column.movable &&\n            ((!this._column.pinned && this.cms.column.disablePinning) || !this.cms.column.disablePinning);\n    }\n\n    get horizontalScroll(): any {\n        if (this._hVirtDir) {\n            return this._hVirtDir;\n        }\n    }\n\n    private _dropPos: DropPosition;\n    private _dropIndicator: any = null;\n    private _lastDropIndicator: any = null;\n    private _column: IgxColumnComponent;\n    private _hVirtDir: IgxGridForOfDirective<any>;\n    private _dragLeave = new Subject<boolean>();\n    private _dropIndicatorClass = 'igx-grid__th-drop-indicator--active';\n\n    constructor(private elementRef: ElementRef, private renderer: Renderer2, private zone: NgZone, private cms: IgxColumnMovingService) {\n        super(elementRef, renderer, zone);\n    }\n\n    public ngOnDestroy() {\n        this._dragLeave.next(true);\n        this._dragLeave.complete();\n    }\n\n    public onDragOver(event) {\n        const drag = event.detail.owner;\n        if (!(drag instanceof IgxColumnMovingDragDirective)) {\n            return;\n        }\n\n        if (this.isDropTarget &&\n            this.cms.column !== this.column &&\n            this.cms.column.level === this.column.level &&\n            this.cms.column.parent === this.column.parent) {\n\n            if (this._lastDropIndicator) {\n                this.renderer.removeClass(this._dropIndicator, this._dropIndicatorClass);\n            }\n\n            const clientRect = this.elementRef.nativeElement.getBoundingClientRect();\n            const pos = clientRect.left + clientRect.width / 2;\n\n            const parent = this.elementRef.nativeElement.parentElement;\n            if (event.detail.pageX < pos) {\n                this._dropPos = DropPosition.BeforeDropTarget;\n                this._lastDropIndicator = this._dropIndicator = parent.firstElementChild;\n            } else {\n                this._dropPos = DropPosition.AfterDropTarget;\n                this._lastDropIndicator = this._dropIndicator = parent.lastElementChild;\n            }\n\n            if (this.cms.icon.innerText !== 'block') {\n                this.renderer.addClass(this._dropIndicator, this._dropIndicatorClass);\n            }\n        }\n    }\n\n    public onDragEnter(event) {\n        const drag = event.detail.owner;\n        if (!(drag instanceof IgxColumnMovingDragDirective)) {\n            return;\n        }\n\n        if (this.column && this.cms.column.grid.id !== this.column.grid.id) {\n            this.cms.icon.innerText = 'block';\n            return;\n        }\n\n        if (this.isDropTarget &&\n            this.cms.column !== this.column &&\n            this.cms.column.level === this.column.level &&\n            this.cms.column.parent === this.column.parent) {\n\n                if (!this.column.pinned || (this.column.pinned && this.cms.column.pinned)) {\n                    this.cms.icon.innerText = 'swap_horiz';\n                }\n\n                this.cms.icon.innerText = 'lock';\n            } else {\n                this.cms.icon.innerText = 'block';\n            }\n\n            if (this.horizontalScroll) {\n                this.cms.icon.innerText = event.target.id === 'right' ? 'arrow_forward' : 'arrow_back';\n\n                interval(100).pipe(takeUntil(this._dragLeave)).subscribe(() => {\n                    this.cms.column.grid.wheelHandler();\n                    event.target.id === 'right' ? this.horizontalScroll.scrollPosition += 15 :\n                        this.horizontalScroll.scrollPosition -= 15;\n                });\n            }\n    }\n\n    public onDragLeave(event) {\n        const drag = event.detail.owner;\n        if (!(drag instanceof IgxColumnMovingDragDirective)) {\n            return;\n        }\n\n        this.cms.icon.innerText = 'block';\n\n        if (this._dropIndicator) {\n            this.renderer.removeClass(this._dropIndicator, this._dropIndicatorClass);\n        }\n\n        if (this.horizontalScroll) {\n            this._dragLeave.next(true);\n        }\n    }\n\n    public onDragDrop(event) {\n        event.preventDefault();\n        const drag = event.detail.owner;\n        if (!(drag instanceof IgxColumnMovingDragDirective)) {\n            return;\n        }\n\n        if (this.column && (this.cms.column.grid.id !== this.column.grid.id)) {\n            return;\n        }\n\n        if (this.horizontalScroll) {\n            this._dragLeave.next(true);\n        }\n\n        if (this.isDropTarget) {\n            const args = {\n                source: this.cms.column,\n                target: this.column\n            };\n\n            this.column.grid.moveColumn(this.cms.column, this.column, this._dropPos);\n\n            this.column.grid.draggedColumn = null;\n            this.column.grid.cdr.detectChanges();\n        }\n    }\n}\n"]}