UNPKG

@catull/igniteui-angular

Version:

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

185 lines 22.1 kB
import { __decorate, __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'; const ghostBackgroundClass = 'igx-grid__tr--ghost'; const gridCellClass = 'igx-grid__td'; const rowSelectedClass = 'igx-grid__tr--selected'; const cellSelectedClass = 'igx-grid__td--selected'; const cellActiveClass = 'igx-grid__td--active'; /** * @hidden */ let IgxRowDragDirective = class IgxRowDragDirective extends IgxDragDirective { constructor() { super(...arguments); this._rowDragStarted = false; this.transitionEndEvent = (evt) => { if (this.ghostElement) { this.ghostElement.removeEventListener('transitionend', this.transitionEndEvent, false); } this.endDragging(); }; } set data(val) { this.row = val; } get data() { return this.row; } onPointerDown(event) { event.preventDefault(); this._rowDragStarted = false; this._removeOnDestroy = false; super.onPointerDown(event); } onPointerMove(event) { super.onPointerMove(event); if (this._dragStarted && !this._rowDragStarted) { this._rowDragStarted = true; const 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((ev) => { if (ev.key === "Escape" /* ESCAPE */ || ev.key === "Esc" /* ESCAPE_IE */) { this._lastDropArea = false; this.onPointerUp(event); } }); } } onPointerUp(event) { if (!this._clicked) { return; } const args = { dragDirective: this, dragData: this.row, animation: false, owner: this.row.grid }; this.zone.run(() => { this.row.grid.onRowDragEnd.emit(args); }); const dropArea = this._lastDropArea; super.onPointerUp(event); if (!dropArea && this.ghostElement) { this.ghostElement.addEventListener('transitionend', this.transitionEndEvent, false); } else { this.endDragging(); } } createGhost(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.createGhost(pageX, pageY, this.row.nativeElement); // check if there is an expander icon and create the ghost at the corresponding position if (this.isHierarchicalGrid) { const row = this.row; if (row.expander) { const expanderWidth = row.expander.nativeElement.getBoundingClientRect().width; this._ghostHostX += expanderWidth; } } const ghost = this.ghostElement; const gridRect = this.row.grid.nativeElement.getBoundingClientRect(); const 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); const ghostCells = ghost.getElementsByClassName(gridCellClass); for (let index = 0; index < ghostCells.length; index++) { this.renderer.removeClass(ghostCells[index], cellSelectedClass); this.renderer.removeClass(ghostCells[index], cellActiveClass); } } _unsubscribe() { if (this.subscription$ && !this.subscription$.closed) { this.subscription$.unsubscribe(); } } endDragging() { this.onTransitionEnd(null); this.row.dragging = false; this.row.grid.rowDragging = false; this.row.grid.markForCheck(); this._unsubscribe(); } get isHierarchicalGrid() { return this.row.grid.nativeElement.tagName.toLowerCase() === 'igx-hierarchical-grid'; } }; __decorate([ Input('igxRowDrag'), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], IgxRowDragDirective.prototype, "data", null); IgxRowDragDirective = __decorate([ Directive({ selector: '[igxRowDrag]' }) ], IgxRowDragDirective); export { IgxRowDragDirective }; /** * @hidden */ let IgxDragIndicatorIconDirective = class IgxDragIndicatorIconDirective { }; IgxDragIndicatorIconDirective = __decorate([ Directive({ selector: '[igxDragIndicatorIcon]' }) ], IgxDragIndicatorIconDirective); export { IgxDragIndicatorIconDirective }; /** * @hidden */ let IgxRowDragGhostDirective = class IgxRowDragGhostDirective { constructor(templateRef) { this.templateRef = templateRef; } }; IgxRowDragGhostDirective.ctorParameters = () => [ { type: TemplateRef } ]; IgxRowDragGhostDirective = __decorate([ Directive({ selector: '[igxRowDragGhost]' }), __metadata("design:paramtypes", [TemplateRef]) ], IgxRowDragGhostDirective); export { IgxRowDragGhostDirective }; let IgxRowDragModule = class IgxRowDragModule { }; IgxRowDragModule = __decorate([ NgModule({ declarations: [IgxRowDragDirective, IgxDragIndicatorIconDirective, IgxRowDragGhostDirective], entryComponents: [], exports: [IgxRowDragDirective, IgxDragIndicatorIconDirective, IgxRowDragGhostDirective], imports: [] }) ], 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"]}