@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
170 lines • 21.5 kB
JavaScript
import { __decorate, __extends, __metadata } from "tslib";
import { Directive, OnDestroy, Input, ElementRef, ViewContainerRef, NgZone, Renderer2, ChangeDetectorRef } from '@angular/core';
import { IgxDragDirective } from '../../directives/drag-drop/drag-drop.directive';
import { fromEvent } from 'rxjs';
import { IgxColumnMovingService } from './moving.service';
/**
* @hidden
* @internal
*/
var IgxColumnMovingDragDirective = /** @class */ (function (_super) {
__extends(IgxColumnMovingDragDirective, _super);
function IgxColumnMovingDragDirective(element, viewContainer, zone, renderer, cdr, cms) {
var _this = _super.call(this, cdr, element, viewContainer, zone, renderer) || this;
_this.element = element;
_this.viewContainer = viewContainer;
_this.zone = zone;
_this.renderer = renderer;
_this.cdr = cdr;
_this.cms = cms;
_this._ghostClass = 'igx-grid__drag-ghost-image';
_this.ghostImgIconClass = 'igx-grid__drag-ghost-image-icon';
_this.ghostImgIconGroupClass = 'igx-grid__drag-ghost-image-icon-group';
return _this;
}
Object.defineProperty(IgxColumnMovingDragDirective.prototype, "data", {
set: function (val) {
this._column = val;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnMovingDragDirective.prototype, "column", {
get: function () {
return this._column;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnMovingDragDirective.prototype, "draggable", {
get: function () {
return this.column && (this.column.movable || (this.column.groupable && !this.column.columnGroup));
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnMovingDragDirective.prototype, "icon", {
get: function () {
return this.cms.icon;
},
enumerable: true,
configurable: true
});
IgxColumnMovingDragDirective.prototype.ngOnDestroy = function () {
this._unsubscribe();
};
IgxColumnMovingDragDirective.prototype.onEscape = function (event) {
this.cms.cancelDrop = true;
this.onPointerUp(event);
};
IgxColumnMovingDragDirective.prototype.onPointerDown = function (event) {
var _this = this;
if (!this.draggable || event.target.getAttribute('draggable') === 'false') {
return;
}
event.preventDefault();
event.stopPropagation();
this._removeOnDestroy = false;
this.cms.column = this.column;
this.ghostClass = this._ghostClass;
_super.prototype.onPointerDown.call(this, event);
this.cms.isColumnMoving = true;
this.column.grid.cdr.detectChanges();
var args = {
source: this.column
};
this.column.grid.onColumnMovingStart.emit(args);
this.subscription$ = fromEvent(this.column.grid.document.defaultView, 'keydown').subscribe(function (ev) {
if (ev.key === "Escape" /* ESCAPE */ || ev.key === "Esc" /* ESCAPE_IE */) {
_this.onEscape(ev);
}
});
};
IgxColumnMovingDragDirective.prototype.onPointerMove = function (event) {
event.preventDefault();
_super.prototype.onPointerMove.call(this, event);
if (this._dragStarted && this.ghostElement && !this.column.grid.draggedColumn) {
this.column.grid.draggedColumn = this.column;
this.column.grid.cdr.detectChanges();
}
if (this.cms.isColumnMoving) {
var args = {
source: this.column,
cancel: false
};
this.column.grid.onColumnMoving.emit(args);
if (args.cancel) {
this.onEscape(event);
}
}
};
IgxColumnMovingDragDirective.prototype.onPointerUp = function (event) {
var _this = this;
// Run it explicitly inside the zone because sometimes onPointerUp executes after the code below.
this.zone.run(function () {
_super.prototype.onPointerUp.call(_this, event);
_this.cms.isColumnMoving = false;
_this.column.grid.draggedColumn = null;
_this.column.grid.cdr.detectChanges();
});
this._unsubscribe();
};
IgxColumnMovingDragDirective.prototype.createGhost = function (pageX, pageY) {
_super.prototype.createGhost.call(this, pageX, pageY);
this.ghostElement.style.height = null;
this.ghostElement.style.minWidth = null;
this.ghostElement.style.flexBasis = null;
this.ghostElement.style.position = null;
var icon = document.createElement('i');
var text = document.createTextNode('block');
icon.appendChild(text);
icon.classList.add('material-icons');
this.cms.icon = icon;
if (!this.column.columnGroup) {
this.renderer.addClass(icon, this.ghostImgIconClass);
this.ghostElement.insertBefore(icon, this.ghostElement.firstElementChild);
this.ghostLeft = this._ghostStartX = pageX - ((this.ghostElement.getBoundingClientRect().width / 3) * 2);
this.ghostTop = this._ghostStartY = pageY - ((this.ghostElement.getBoundingClientRect().height / 3) * 2);
}
else {
this.ghostElement.insertBefore(icon, this.ghostElement.childNodes[0]);
this.renderer.addClass(icon, this.ghostImgIconGroupClass);
this.ghostElement.children[0].style.paddingLeft = '0px';
this.ghostLeft = this._ghostStartX = pageX - ((this.ghostElement.getBoundingClientRect().width / 3) * 2);
this.ghostTop = this._ghostStartY = pageY - ((this.ghostElement.getBoundingClientRect().height / 3) * 2);
}
};
IgxColumnMovingDragDirective.prototype._unsubscribe = function () {
if (this.subscription$) {
this.subscription$.unsubscribe();
this.subscription$ = null;
}
};
IgxColumnMovingDragDirective.ctorParameters = function () { return [
{ type: ElementRef },
{ type: ViewContainerRef },
{ type: NgZone },
{ type: Renderer2 },
{ type: ChangeDetectorRef },
{ type: IgxColumnMovingService }
]; };
__decorate([
Input('igxColumnMovingDrag'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [Object])
], IgxColumnMovingDragDirective.prototype, "data", null);
IgxColumnMovingDragDirective = __decorate([
Directive({
selector: '[igxColumnMovingDrag]',
}),
__metadata("design:paramtypes", [ElementRef,
ViewContainerRef,
NgZone,
Renderer2,
ChangeDetectorRef,
IgxColumnMovingService])
], IgxColumnMovingDragDirective);
return IgxColumnMovingDragDirective;
}(IgxDragDirective));
export { IgxColumnMovingDragDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"moving.drag.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/moving/moving.drag.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnDestroy, Input, ElementRef, ViewContainerRef, NgZone, Renderer2, ChangeDetectorRef } from '@angular/core';\nimport { IgxDragDirective } from '../../directives/drag-drop/drag-drop.directive';\nimport { Subscription, fromEvent } from 'rxjs';\nimport { IgxColumnComponent } from '../columns/column.component';\nimport { KEYS } from '../../core/utils';\nimport { IgxColumnMovingService } from './moving.service';\n\n\n/**\n * @hidden\n * @internal\n */\n@Directive({\n    selector: '[igxColumnMovingDrag]',\n\n})\nexport class IgxColumnMovingDragDirective extends IgxDragDirective implements OnDestroy {\n\n    @Input('igxColumnMovingDrag')\n    set data(val) {\n        this._column = val;\n    }\n\n    get column() {\n        return this._column;\n    }\n\n    get draggable(): boolean {\n        return this.column && (this.column.movable || (this.column.groupable && !this.column.columnGroup));\n    }\n\n    public get icon(): HTMLElement {\n        return this.cms.icon;\n    }\n\n    private subscription$: Subscription;\n    private _column: IgxColumnComponent;\n    private _ghostClass = 'igx-grid__drag-ghost-image';\n    private ghostImgIconClass = 'igx-grid__drag-ghost-image-icon';\n    private ghostImgIconGroupClass = 'igx-grid__drag-ghost-image-icon-group';\n\n    constructor(\n        public element: ElementRef<HTMLElement>,\n        public viewContainer: ViewContainerRef,\n        public zone: NgZone,\n        public renderer: Renderer2,\n        public cdr: ChangeDetectorRef,\n        private cms: IgxColumnMovingService,\n    ) {\n        super(cdr, element, viewContainer, zone, renderer);\n    }\n\n    public ngOnDestroy() {\n        this._unsubscribe();\n    }\n\n    public onEscape(event) {\n        this.cms.cancelDrop = true;\n        this.onPointerUp(event);\n    }\n\n    public onPointerDown(event) {\n        if (!this.draggable || event.target.getAttribute('draggable') === 'false') {\n            return;\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n\n        this._removeOnDestroy = false;\n        this.cms.column = this.column;\n        this.ghostClass = this._ghostClass;\n\n        super.onPointerDown(event);\n\n        this.cms.isColumnMoving = true;\n        this.column.grid.cdr.detectChanges();\n\n        const args = {\n            source: this.column\n        };\n        this.column.grid.onColumnMovingStart.emit(args);\n\n        this.subscription$ = fromEvent(this.column.grid.document.defaultView, 'keydown').subscribe((ev: KeyboardEvent) => {\n            if (ev.key === KEYS.ESCAPE || ev.key === KEYS.ESCAPE_IE) {\n                this.onEscape(ev);\n            }\n        });\n    }\n\n    public onPointerMove(event) {\n        event.preventDefault();\n        super.onPointerMove(event);\n\n        if (this._dragStarted && this.ghostElement && !this.column.grid.draggedColumn) {\n            this.column.grid.draggedColumn = this.column;\n            this.column.grid.cdr.detectChanges();\n        }\n\n        if (this.cms.isColumnMoving) {\n            const args = {\n                source: this.column,\n                cancel: false\n            };\n            this.column.grid.onColumnMoving.emit(args);\n\n            if (args.cancel) {\n                this.onEscape(event);\n            }\n        }\n    }\n\n    public onPointerUp(event) {\n        // Run it explicitly inside the zone because sometimes onPointerUp executes after the code below.\n        this.zone.run(() => {\n            super.onPointerUp(event);\n\n            this.cms.isColumnMoving = false;\n            this.column.grid.draggedColumn = null;\n            this.column.grid.cdr.detectChanges();\n        });\n\n        this._unsubscribe();\n    }\n\n    protected createGhost(pageX, pageY) {\n        super.createGhost(pageX, pageY);\n\n        this.ghostElement.style.height = null;\n        this.ghostElement.style.minWidth = null;\n        this.ghostElement.style.flexBasis = null;\n        this.ghostElement.style.position = null;\n\n        const icon = document.createElement('i');\n        const text = document.createTextNode('block');\n        icon.appendChild(text);\n\n        icon.classList.add('material-icons');\n        this.cms.icon = icon;\n\n        if (!this.column.columnGroup) {\n            this.renderer.addClass(icon, this.ghostImgIconClass);\n\n            this.ghostElement.insertBefore(icon, this.ghostElement.firstElementChild);\n\n            this.ghostLeft = this._ghostStartX = pageX - ((this.ghostElement.getBoundingClientRect().width / 3) * 2);\n            this.ghostTop = this._ghostStartY = pageY - ((this.ghostElement.getBoundingClientRect().height / 3) * 2);\n        } else {\n            this.ghostElement.insertBefore(icon, this.ghostElement.childNodes[0]);\n\n            this.renderer.addClass(icon, this.ghostImgIconGroupClass);\n            this.ghostElement.children[0].style.paddingLeft = '0px';\n\n            this.ghostLeft = this._ghostStartX = pageX - ((this.ghostElement.getBoundingClientRect().width / 3) * 2);\n            this.ghostTop = this._ghostStartY = pageY - ((this.ghostElement.getBoundingClientRect().height / 3) * 2);\n        }\n    }\n\n    private _unsubscribe() {\n        if (this.subscription$) {\n            this.subscription$.unsubscribe();\n            this.subscription$ = null;\n        }\n    }\n}\n"]}