UNPKG

@catull/igniteui-angular

Version:

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

205 lines 23.4 kB
import { __decorate, __extends, __metadata } from "tslib"; import { Directive, Input, OnDestroy, NgModule, TemplateRef } from '@angular/core'; import { IgxDragDirective } from '../directives/drag-drop/drag-drop.directive'; import { fromEvent } from 'rxjs'; var ghostBackgroundClass = 'igx-grid__tr--ghost'; var gridCellClass = 'igx-grid__td'; var rowSelectedClass = 'igx-grid__tr--selected'; var cellSelectedClass = 'igx-grid__td--selected'; var cellActiveClass = 'igx-grid__td--active'; /** * @hidden */ var IgxRowDragDirective = /** @class */ (function (_super) { __extends(IgxRowDragDirective, _super); function IgxRowDragDirective() { var _this = _super !== null && _super.apply(this, arguments) || this; _this._rowDragStarted = false; _this.transitionEndEvent = function (evt) { if (_this.ghostElement) { _this.ghostElement.removeEventListener('transitionend', _this.transitionEndEvent, false); } _this.endDragging(); }; return _this; } Object.defineProperty(IgxRowDragDirective.prototype, "data", { get: function () { return this.row; }, set: function (val) { this.row = val; }, enumerable: true, configurable: true }); IgxRowDragDirective.prototype.onPointerDown = function (event) { event.preventDefault(); this._rowDragStarted = false; this._removeOnDestroy = false; _super.prototype.onPointerDown.call(this, event); }; IgxRowDragDirective.prototype.onPointerMove = function (event) { var _this = this; _super.prototype.onPointerMove.call(this, event); if (this._dragStarted && !this._rowDragStarted) { this._rowDragStarted = true; var args = { dragDirective: this, dragData: this.row, cancel: false, owner: this.row.grid }; this.row.grid.onRowDragStart.emit(args); if (args.cancel) { this.ghostElement.parentNode.removeChild(this.ghostElement); this.ghostElement = null; this._dragStarted = false; this._clicked = false; return; } this.row.dragging = true; this.row.grid.rowDragging = true; this.row.grid.markForCheck(); this.subscription$ = fromEvent(this.row.grid.document.defaultView, 'keydown').subscribe(function (ev) { if (ev.key === "Escape" /* ESCAPE */ || ev.key === "Esc" /* ESCAPE_IE */) { _this._lastDropArea = false; _this.onPointerUp(event); } }); } }; IgxRowDragDirective.prototype.onPointerUp = function (event) { var _this = this; if (!this._clicked) { return; } var args = { dragDirective: this, dragData: this.row, animation: false, owner: this.row.grid }; this.zone.run(function () { _this.row.grid.onRowDragEnd.emit(args); }); var dropArea = this._lastDropArea; _super.prototype.onPointerUp.call(this, event); if (!dropArea && this.ghostElement) { this.ghostElement.addEventListener('transitionend', this.transitionEndEvent, false); } else { this.endDragging(); } }; IgxRowDragDirective.prototype.createGhost = function (pageX, pageY) { this.row.grid.endEdit(true); this.row.grid.markForCheck(); this.ghostContext = { $implicit: this.row.rowData, data: this.row.rowData, grid: this.row.grid }; _super.prototype.createGhost.call(this, pageX, pageY, this.row.nativeElement); // check if there is an expander icon and create the ghost at the corresponding position if (this.isHierarchicalGrid) { var row = this.row; if (row.expander) { var expanderWidth = row.expander.nativeElement.getBoundingClientRect().width; this._ghostHostX += expanderWidth; } } var ghost = this.ghostElement; var gridRect = this.row.grid.nativeElement.getBoundingClientRect(); var rowRect = this.row.nativeElement.getBoundingClientRect(); ghost.style.overflow = 'hidden'; ghost.style.width = gridRect.width + 'px'; ghost.style.height = rowRect.height + 'px'; this.renderer.addClass(ghost, ghostBackgroundClass); this.renderer.removeClass(ghost, rowSelectedClass); var ghostCells = ghost.getElementsByClassName(gridCellClass); for (var index = 0; index < ghostCells.length; index++) { this.renderer.removeClass(ghostCells[index], cellSelectedClass); this.renderer.removeClass(ghostCells[index], cellActiveClass); } }; IgxRowDragDirective.prototype._unsubscribe = function () { if (this.subscription$ && !this.subscription$.closed) { this.subscription$.unsubscribe(); } }; IgxRowDragDirective.prototype.endDragging = function () { this.onTransitionEnd(null); this.row.dragging = false; this.row.grid.rowDragging = false; this.row.grid.markForCheck(); this._unsubscribe(); }; Object.defineProperty(IgxRowDragDirective.prototype, "isHierarchicalGrid", { get: function () { return this.row.grid.nativeElement.tagName.toLowerCase() === 'igx-hierarchical-grid'; }, enumerable: true, configurable: true }); __decorate([ Input('igxRowDrag'), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], IgxRowDragDirective.prototype, "data", null); IgxRowDragDirective = __decorate([ Directive({ selector: '[igxRowDrag]' }) ], IgxRowDragDirective); return IgxRowDragDirective; }(IgxDragDirective)); export { IgxRowDragDirective }; /** * @hidden */ var IgxDragIndicatorIconDirective = /** @class */ (function () { function IgxDragIndicatorIconDirective() { } IgxDragIndicatorIconDirective = __decorate([ Directive({ selector: '[igxDragIndicatorIcon]' }) ], IgxDragIndicatorIconDirective); return IgxDragIndicatorIconDirective; }()); export { IgxDragIndicatorIconDirective }; /** * @hidden */ var IgxRowDragGhostDirective = /** @class */ (function () { function IgxRowDragGhostDirective(templateRef) { this.templateRef = templateRef; } IgxRowDragGhostDirective.ctorParameters = function () { return [ { type: TemplateRef } ]; }; IgxRowDragGhostDirective = __decorate([ Directive({ selector: '[igxRowDragGhost]' }), __metadata("design:paramtypes", [TemplateRef]) ], IgxRowDragGhostDirective); return IgxRowDragGhostDirective; }()); export { IgxRowDragGhostDirective }; var IgxRowDragModule = /** @class */ (function () { function IgxRowDragModule() { } IgxRowDragModule = __decorate([ NgModule({ declarations: [IgxRowDragDirective, IgxDragIndicatorIconDirective, IgxRowDragGhostDirective], entryComponents: [], exports: [IgxRowDragDirective, IgxDragIndicatorIconDirective, IgxRowDragGhostDirective], imports: [] }) ], IgxRowDragModule); return IgxRowDragModule; }()); export { IgxRowDragModule }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row-drag.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/row-drag.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, Input, OnDestroy, NgModule, TemplateRef } from '@angular/core';\nimport { IgxDragDirective } from '../directives/drag-drop/drag-drop.directive';\nimport { KEYS } from '../core/utils';\nimport { fromEvent, Subscription } from 'rxjs';\nimport { IgxRowDirective, IgxGridBaseDirective } from './grid';\nimport { IRowDragStartEventArgs, IRowDragEndEventArgs } from './common/events';\nimport { GridType } from './common/grid.interface';\nimport { IgxHierarchicalRowComponent } from './hierarchical-grid/hierarchical-row.component';\n\n\nconst ghostBackgroundClass = 'igx-grid__tr--ghost';\nconst gridCellClass = 'igx-grid__td';\nconst rowSelectedClass = 'igx-grid__tr--selected';\nconst cellSelectedClass = 'igx-grid__td--selected';\nconst cellActiveClass = 'igx-grid__td--active';\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxRowDrag]'\n})\nexport class IgxRowDragDirective extends IgxDragDirective implements OnDestroy {\n    private row: IgxRowDirective<IgxGridBaseDirective & GridType>;\n    private subscription$: Subscription;\n    private _rowDragStarted = false;\n\n    @Input('igxRowDrag')\n    set data(val) {\n        this.row = val;\n    }\n\n    get data() {\n        return this.row;\n    }\n\n    public onPointerDown(event) {\n        event.preventDefault();\n        this._rowDragStarted = false;\n        this._removeOnDestroy = false;\n        super.onPointerDown(event);\n    }\n\n    public onPointerMove(event) {\n        super.onPointerMove(event);\n        if (this._dragStarted && !this._rowDragStarted) {\n            this._rowDragStarted = true;\n            const args: IRowDragStartEventArgs = {\n                dragDirective: this,\n                dragData: this.row,\n                cancel: false,\n                owner: this.row.grid\n            };\n\n            this.row.grid.onRowDragStart.emit(args);\n            if (args.cancel) {\n                this.ghostElement.parentNode.removeChild(this.ghostElement);\n                this.ghostElement = null;\n                this._dragStarted = false;\n                this._clicked = false;\n                return;\n            }\n            this.row.dragging = true;\n            this.row.grid.rowDragging = true;\n            this.row.grid.markForCheck();\n\n            this.subscription$ = fromEvent(this.row.grid.document.defaultView, 'keydown').subscribe((ev: KeyboardEvent) => {\n                if (ev.key === KEYS.ESCAPE || ev.key === KEYS.ESCAPE_IE) {\n                    this._lastDropArea = false;\n                    this.onPointerUp(event);\n                }\n            });\n        }\n    }\n\n    public onPointerUp(event) {\n\n        if (!this._clicked) {\n            return;\n        }\n\n        const args: IRowDragEndEventArgs = {\n            dragDirective: this,\n            dragData: this.row,\n            animation: false,\n            owner: this.row.grid\n        };\n        this.zone.run(() => {\n            this.row.grid.onRowDragEnd.emit(args);\n        });\n\n        const dropArea = this._lastDropArea;\n        super.onPointerUp(event);\n        if (!dropArea && this.ghostElement) {\n            this.ghostElement.addEventListener('transitionend', this.transitionEndEvent, false);\n        }   else {\n            this.endDragging();\n        }\n    }\n\n    protected createGhost(pageX, pageY) {\n        this.row.grid.endEdit(true);\n        this.row.grid.markForCheck();\n        this.ghostContext = {\n            $implicit: this.row.rowData,\n            data: this.row.rowData,\n            grid: this.row.grid\n        };\n        super.createGhost(pageX, pageY, this.row.nativeElement);\n\n        // check if there is an expander icon and create the ghost at the corresponding position\n        if (this.isHierarchicalGrid) {\n            const row = this.row as IgxHierarchicalRowComponent;\n            if (row.expander) {\n                const expanderWidth = row.expander.nativeElement.getBoundingClientRect().width;\n                this._ghostHostX += expanderWidth;\n            }\n        }\n\n        const ghost = this.ghostElement;\n\n        const gridRect = this.row.grid.nativeElement.getBoundingClientRect();\n        const rowRect = this.row.nativeElement.getBoundingClientRect();\n        ghost.style.overflow = 'hidden';\n        ghost.style.width = gridRect.width + 'px';\n        ghost.style.height = rowRect.height + 'px';\n\n        this.renderer.addClass(ghost, ghostBackgroundClass);\n        this.renderer.removeClass(ghost, rowSelectedClass);\n\n        const ghostCells = ghost.getElementsByClassName(gridCellClass);\n        for (let index = 0; index < ghostCells.length; index++) {\n            this.renderer.removeClass(ghostCells[index], cellSelectedClass);\n            this.renderer.removeClass(ghostCells[index], cellActiveClass);\n        }\n    }\n\n    private _unsubscribe() {\n        if (this.subscription$ && !this.subscription$.closed) {\n            this.subscription$.unsubscribe();\n        }\n    }\n\n    private endDragging() {\n        this.onTransitionEnd(null);\n        this.row.dragging = false;\n        this.row.grid.rowDragging = false;\n        this.row.grid.markForCheck();\n        this._unsubscribe();\n    }\n\n    private transitionEndEvent = (evt?) => {\n        if (this.ghostElement) {\n            this.ghostElement.removeEventListener('transitionend', this.transitionEndEvent, false);\n        }\n        this.endDragging();\n    }\n\n    private get isHierarchicalGrid() {\n        return this.row.grid.nativeElement.tagName.toLowerCase() === 'igx-hierarchical-grid';\n    }\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxDragIndicatorIcon]'\n})\n\nexport class IgxDragIndicatorIconDirective {\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxRowDragGhost]'\n})\n\nexport class IgxRowDragGhostDirective  {\n    constructor(public templateRef: TemplateRef<any>) { }\n}\n\n@NgModule({\n    declarations: [IgxRowDragDirective, IgxDragIndicatorIconDirective, IgxRowDragGhostDirective],\n    entryComponents: [],\n    exports: [IgxRowDragDirective, IgxDragIndicatorIconDirective, IgxRowDragGhostDirective],\n    imports: []\n})\n\nexport class IgxRowDragModule {\n}\n"]}