UNPKG

ng2-dnd

Version:

Angular 2 Drag-and-Drop without dependencies

265 lines 35.9 kB
// Copyright (C) 2016-2020 Sergey Akopkokhyants // This project is licensed under the terms of the MIT license. // https://github.com/akserg/ng2-dnd import { __decorate } from "tslib"; import { Directive, Input, Output, EventEmitter } from '@angular/core'; import { FormArray } from '@angular/forms'; import { AbstractComponent, AbstractHandleComponent } from './abstract.component'; let SortableContainer = class SortableContainer extends AbstractComponent { constructor(elemRef, dragDropService, config, cdr, _sortableDataService) { super(elemRef, dragDropService, config, cdr); this._sortableDataService = _sortableDataService; this._sortableData = []; this.dragEnabled = false; } set draggable(value) { this.dragEnabled = !!value; } set sortableData(sortableData) { this._sortableData = sortableData; if (sortableData instanceof FormArray) { this.sortableHandler = new SortableFormArrayHandler(); } else { this.sortableHandler = new SortableArrayHandler(); } // this.dropEnabled = !!this._sortableData; // console.log("collection is changed, drop enabled: " + this.dropEnabled); } get sortableData() { return this._sortableData; } set dropzones(value) { this.dropZones = value; } _onDragEnterCallback(event) { if (this._sortableDataService.isDragged) { let item = this._sortableDataService.sortableContainer.getItemAt(this._sortableDataService.index); // Check does element exist in sortableData of this Container if (this.indexOf(item) === -1) { // Let's add it // console.log('Container._onDragEnterCallback. drag node [' + this._sortableDataService.index.toString() + '] over parent node'); // Remove item from previouse list this._sortableDataService.sortableContainer.removeItemAt(this._sortableDataService.index); if (this._sortableDataService.sortableContainer._sortableData.length === 0) { this._sortableDataService.sortableContainer.dropEnabled = true; } // Add item to new list this.insertItemAt(item, 0); this._sortableDataService.sortableContainer = this; this._sortableDataService.index = 0; } // Refresh changes in properties of container component this.detectChanges(); } } getItemAt(index) { return this.sortableHandler.getItemAt(this._sortableData, index); } indexOf(item) { return this.sortableHandler.indexOf(this._sortableData, item); } removeItemAt(index) { this.sortableHandler.removeItemAt(this._sortableData, index); } insertItemAt(item, index) { this.sortableHandler.insertItemAt(this._sortableData, item, index); } }; __decorate([ Input("dragEnabled") ], SortableContainer.prototype, "draggable", null); __decorate([ Input() ], SortableContainer.prototype, "sortableData", null); __decorate([ Input("dropZones") ], SortableContainer.prototype, "dropzones", null); SortableContainer = __decorate([ Directive({ selector: '[dnd-sortable-container]' }) ], SortableContainer); export { SortableContainer }; class SortableArrayHandler { getItemAt(sortableData, index) { return sortableData[index]; } indexOf(sortableData, item) { return sortableData.indexOf(item); } removeItemAt(sortableData, index) { sortableData.splice(index, 1); } insertItemAt(sortableData, item, index) { sortableData.splice(index, 0, item); } } class SortableFormArrayHandler { getItemAt(sortableData, index) { return sortableData.at(index); } indexOf(sortableData, item) { return sortableData.controls.indexOf(item); } removeItemAt(sortableData, index) { sortableData.removeAt(index); } insertItemAt(sortableData, item, index) { sortableData.insert(index, item); } } let SortableComponent = class SortableComponent extends AbstractComponent { constructor(elemRef, dragDropService, config, _sortableContainer, _sortableDataService, cdr) { super(elemRef, dragDropService, config, cdr); this._sortableContainer = _sortableContainer; this._sortableDataService = _sortableDataService; /** * Callback function called when the drag action ends with a valid drop action. * It is activated after the on-drop-success callback */ this.onDragSuccessCallback = new EventEmitter(); this.onDragStartCallback = new EventEmitter(); this.onDragOverCallback = new EventEmitter(); this.onDragEndCallback = new EventEmitter(); this.onDropSuccessCallback = new EventEmitter(); this.dropZones = this._sortableContainer.dropZones; this.dragEnabled = true; this.dropEnabled = true; } set draggable(value) { this.dragEnabled = !!value; } set droppable(value) { this.dropEnabled = !!value; } /** * Drag allowed effect */ set effectallowed(value) { this.effectAllowed = value; } /** * Drag effect cursor */ set effectcursor(value) { this.effectCursor = value; } _onDragStartCallback(event) { // console.log('_onDragStartCallback. dragging elem with index ' + this.index); this._sortableDataService.isDragged = true; this._sortableDataService.sortableContainer = this._sortableContainer; this._sortableDataService.index = this.index; this._sortableDataService.markSortable(this._elem); // Add dragData this._dragDropService.isDragged = true; this._dragDropService.dragData = this.dragData; this._dragDropService.onDragSuccessCallback = this.onDragSuccessCallback; // this.onDragStartCallback.emit(this._dragDropService.dragData); } _onDragOverCallback(event) { if (this._sortableDataService.isDragged && this._elem !== this._sortableDataService.elem) { // console.log('_onDragOverCallback. dragging elem with index ' + this.index); this._sortableDataService.sortableContainer = this._sortableContainer; this._sortableDataService.index = this.index; this._sortableDataService.markSortable(this._elem); this.onDragOverCallback.emit(this._dragDropService.dragData); } } _onDragEndCallback(event) { // console.log('_onDragEndCallback. end dragging elem with index ' + this.index); this._sortableDataService.isDragged = false; this._sortableDataService.sortableContainer = null; this._sortableDataService.index = null; this._sortableDataService.markSortable(null); // Add dragGata this._dragDropService.isDragged = false; this._dragDropService.dragData = null; this._dragDropService.onDragSuccessCallback = null; // this.onDragEndCallback.emit(this._dragDropService.dragData); } _onDragEnterCallback(event) { if (this._sortableDataService.isDragged) { this._sortableDataService.markSortable(this._elem); if ((this.index !== this._sortableDataService.index) || (this._sortableDataService.sortableContainer.sortableData !== this._sortableContainer.sortableData)) { // console.log('Component._onDragEnterCallback. drag node [' + this.index + '] over node [' + this._sortableDataService.index + ']'); // Get item let item = this._sortableDataService.sortableContainer.getItemAt(this._sortableDataService.index); // Remove item from previouse list this._sortableDataService.sortableContainer.removeItemAt(this._sortableDataService.index); if (this._sortableDataService.sortableContainer.sortableData.length === 0) { this._sortableDataService.sortableContainer.dropEnabled = true; } // Add item to new list this._sortableContainer.insertItemAt(item, this.index); if (this._sortableContainer.dropEnabled) { this._sortableContainer.dropEnabled = false; } this._sortableDataService.sortableContainer = this._sortableContainer; this._sortableDataService.index = this.index; this.detectChanges(); } } } _onDropCallback(event) { if (this._sortableDataService.isDragged) { // console.log('onDropCallback.onDropSuccessCallback.dragData', this._dragDropService.dragData); this.onDropSuccessCallback.emit(this._dragDropService.dragData); if (this._dragDropService.onDragSuccessCallback) { // console.log('onDropCallback.onDragSuccessCallback.dragData', this._dragDropService.dragData); this._dragDropService.onDragSuccessCallback.emit(this._dragDropService.dragData); } // Refresh changes in properties of container component this._sortableContainer.detectChanges(); } } }; __decorate([ Input('sortableIndex') ], SortableComponent.prototype, "index", void 0); __decorate([ Input("dragEnabled") ], SortableComponent.prototype, "draggable", null); __decorate([ Input("dropEnabled") ], SortableComponent.prototype, "droppable", null); __decorate([ Input() ], SortableComponent.prototype, "dragData", void 0); __decorate([ Input("effectAllowed") ], SortableComponent.prototype, "effectallowed", null); __decorate([ Input("effectCursor") ], SortableComponent.prototype, "effectcursor", null); __decorate([ Output("onDragSuccess") ], SortableComponent.prototype, "onDragSuccessCallback", void 0); __decorate([ Output("onDragStart") ], SortableComponent.prototype, "onDragStartCallback", void 0); __decorate([ Output("onDragOver") ], SortableComponent.prototype, "onDragOverCallback", void 0); __decorate([ Output("onDragEnd") ], SortableComponent.prototype, "onDragEndCallback", void 0); __decorate([ Output("onDropSuccess") ], SortableComponent.prototype, "onDropSuccessCallback", void 0); SortableComponent = __decorate([ Directive({ selector: '[dnd-sortable]' }) ], SortableComponent); export { SortableComponent }; let SortableHandleComponent = class SortableHandleComponent extends AbstractHandleComponent { constructor(elemRef, dragDropService, config, _Component, cdr) { super(elemRef, dragDropService, config, _Component, cdr); } }; SortableHandleComponent = __decorate([ Directive({ selector: '[dnd-sortable-handle]' }) ], SortableHandleComponent); export { SortableHandleComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sortable.component.js","sourceRoot":"","sources":["../../../src/sortable.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (C) 2016-2020 Sergey Akopkokhyants\n// This project is licensed under the terms of the MIT license.\n// https://github.com/akserg/ng2-dnd\n\nimport {ChangeDetectorRef} from '@angular/core';\nimport {Directive, Input, Output, EventEmitter, ElementRef} from '@angular/core';\nimport {FormArray} from '@angular/forms';\n\nimport {AbstractComponent, AbstractHandleComponent} from './abstract.component';\nimport {DragDropConfig} from './dnd.config';\nimport {DragDropService, DragDropSortableService} from './dnd.service';\n\n@Directive({ selector: '[dnd-sortable-container]' })\nexport class SortableContainer extends AbstractComponent {\n\n    @Input(\"dragEnabled\") set draggable(value:boolean) {\n        this.dragEnabled = !!value;\n    }\n\n    private _sortableData: Array<any>|FormArray = [];\n    private sortableHandler: SortableFormArrayHandler|SortableArrayHandler;\n\n    @Input() set sortableData(sortableData: Array<any>|FormArray) {\n        this._sortableData = sortableData;\n        if (sortableData instanceof FormArray) {\n            this.sortableHandler = new SortableFormArrayHandler();\n        } else {\n            this.sortableHandler = new SortableArrayHandler();\n        }\n        //\n        this.dropEnabled = !!this._sortableData;\n        // console.log(\"collection is changed, drop enabled: \" + this.dropEnabled);\n    }\n    get sortableData(): Array<any>|FormArray {\n        return this._sortableData;\n    }\n\n    @Input(\"dropZones\") set dropzones(value:Array<string>) {\n        this.dropZones = value;\n    }\n\n    constructor(elemRef: ElementRef, dragDropService: DragDropService, config:DragDropConfig, cdr:ChangeDetectorRef,\n        private _sortableDataService: DragDropSortableService) {\n\n        super(elemRef, dragDropService, config, cdr);\n        this.dragEnabled = false;\n    }\n\n    _onDragEnterCallback(event: Event) {\n        if (this._sortableDataService.isDragged) {\n            let item:any = this._sortableDataService.sortableContainer.getItemAt(this._sortableDataService.index);\n            // Check does element exist in sortableData of this Container\n            if (this.indexOf(item) === -1) {\n                // Let's add it\n                // console.log('Container._onDragEnterCallback. drag node [' + this._sortableDataService.index.toString() + '] over parent node');\n                // Remove item from previouse list\n                this._sortableDataService.sortableContainer.removeItemAt(this._sortableDataService.index);\n                if (this._sortableDataService.sortableContainer._sortableData.length === 0) {\n                    this._sortableDataService.sortableContainer.dropEnabled = true;\n                }\n                // Add item to new list\n                this.insertItemAt(item, 0);\n                this._sortableDataService.sortableContainer = this;\n                this._sortableDataService.index = 0;\n            }\n            // Refresh changes in properties of container component\n            this.detectChanges();\n        }\n    }\n\n    getItemAt(index: number): any {\n        return this.sortableHandler.getItemAt(this._sortableData, index);\n    }\n\n    indexOf(item: any): number {\n        return this.sortableHandler.indexOf(this._sortableData, item);\n    }\n\n    removeItemAt(index: number): void {\n        this.sortableHandler.removeItemAt(this._sortableData, index);\n    }\n\n    insertItemAt(item: any, index: number) {\n        this.sortableHandler.insertItemAt(this._sortableData, item, index);\n    }\n}\n\nclass SortableArrayHandler {\n    getItemAt(sortableData: any, index: number): any {\n        return sortableData[index];\n    }\n\n    indexOf(sortableData: any, item: any): number {\n        return sortableData.indexOf(item);\n    }\n\n    removeItemAt(sortableData: any, index: number) {\n        sortableData.splice(index, 1);\n    }\n\n    insertItemAt(sortableData: any, item: any, index: number) {\n        sortableData.splice(index, 0, item);\n    }\n}\n\nclass SortableFormArrayHandler {\n    getItemAt(sortableData: any, index: number): any {\n        return sortableData.at(index);\n    }\n\n    indexOf(sortableData: any, item: any): number {\n        return sortableData.controls.indexOf(item);\n    }\n\n    removeItemAt(sortableData: any, index: number) {\n        sortableData.removeAt(index);\n    }\n\n    insertItemAt(sortableData: any, item: any, index: number) {\n        sortableData.insert(index, item);\n    }\n}\n\n@Directive({ selector: '[dnd-sortable]' })\nexport class SortableComponent extends AbstractComponent {\n\n    @Input('sortableIndex') index: number;\n\n    @Input(\"dragEnabled\") set draggable(value:boolean) {\n        this.dragEnabled = !!value;\n    }\n\n    @Input(\"dropEnabled\") set droppable(value:boolean) {\n        this.dropEnabled = !!value;\n    }\n\n    /**\n     * The data that has to be dragged. It can be any JS object\n     */\n    @Input() dragData: any;\n\n    /**\n     * Drag allowed effect\n     */\n    @Input(\"effectAllowed\") set effectallowed(value: string) {\n        this.effectAllowed = value;\n    }\n\n    /**\n     * Drag effect cursor\n     */\n    @Input(\"effectCursor\") set effectcursor(value: string) {\n        this.effectCursor = value;\n    }\n\n    /**\n     * Callback function called when the drag action ends with a valid drop action.\n     * It is activated after the on-drop-success callback\n     */\n    @Output(\"onDragSuccess\") onDragSuccessCallback: EventEmitter<any> = new EventEmitter<any>();\n\n    @Output(\"onDragStart\") onDragStartCallback: EventEmitter<any> = new EventEmitter<any>();\n    @Output(\"onDragOver\") onDragOverCallback: EventEmitter<any> = new EventEmitter<any>();\n    @Output(\"onDragEnd\") onDragEndCallback: EventEmitter<any> = new EventEmitter<any>();\n    @Output(\"onDropSuccess\") onDropSuccessCallback: EventEmitter<any> = new EventEmitter<any>();\n\n    constructor(elemRef: ElementRef, dragDropService: DragDropService, config:DragDropConfig,\n        private _sortableContainer: SortableContainer,\n        private _sortableDataService: DragDropSortableService,\n        cdr:ChangeDetectorRef) {\n        super(elemRef, dragDropService, config, cdr);\n        this.dropZones = this._sortableContainer.dropZones;\n        this.dragEnabled = true;\n        this.dropEnabled = true;\n    }\n\n    _onDragStartCallback(event: Event) {\n        // console.log('_onDragStartCallback. dragging elem with index ' + this.index);\n        this._sortableDataService.isDragged = true;\n        this._sortableDataService.sortableContainer = this._sortableContainer;\n        this._sortableDataService.index = this.index;\n        this._sortableDataService.markSortable(this._elem);\n        // Add dragData\n        this._dragDropService.isDragged = true;\n        this._dragDropService.dragData = this.dragData;\n        this._dragDropService.onDragSuccessCallback = this.onDragSuccessCallback;\n        //\n        this.onDragStartCallback.emit(this._dragDropService.dragData);\n    }\n\n    _onDragOverCallback(event: Event) {\n        if (this._sortableDataService.isDragged && this._elem !== this._sortableDataService.elem) {\n            // console.log('_onDragOverCallback. dragging elem with index ' + this.index);\n            this._sortableDataService.sortableContainer = this._sortableContainer;\n            this._sortableDataService.index = this.index;\n            this._sortableDataService.markSortable(this._elem);\n            this.onDragOverCallback.emit(this._dragDropService.dragData);\n        }\n    }\n\n    _onDragEndCallback(event: Event) {\n        // console.log('_onDragEndCallback. end dragging elem with index ' + this.index);\n        this._sortableDataService.isDragged = false;\n        this._sortableDataService.sortableContainer = null;\n        this._sortableDataService.index = null;\n        this._sortableDataService.markSortable(null);\n        // Add dragGata\n        this._dragDropService.isDragged = false;\n        this._dragDropService.dragData = null;\n        this._dragDropService.onDragSuccessCallback = null;\n        //\n        this.onDragEndCallback.emit(this._dragDropService.dragData);\n    }\n\n    _onDragEnterCallback(event: Event) {\n        if (this._sortableDataService.isDragged) {\n            this._sortableDataService.markSortable(this._elem);\n            if ((this.index !== this._sortableDataService.index) ||\n                (this._sortableDataService.sortableContainer.sortableData !== this._sortableContainer.sortableData)) {\n                // console.log('Component._onDragEnterCallback. drag node [' + this.index + '] over node [' + this._sortableDataService.index + ']');\n                // Get item\n                let item:any = this._sortableDataService.sortableContainer.getItemAt(this._sortableDataService.index);\n                // Remove item from previouse list\n                this._sortableDataService.sortableContainer.removeItemAt(this._sortableDataService.index);\n                if (this._sortableDataService.sortableContainer.sortableData.length === 0) {\n                    this._sortableDataService.sortableContainer.dropEnabled = true;\n                }\n                // Add item to new list\n                this._sortableContainer.insertItemAt(item, this.index);\n                if (this._sortableContainer.dropEnabled) {\n                    this._sortableContainer.dropEnabled = false;\n                }\n                this._sortableDataService.sortableContainer = this._sortableContainer;\n                this._sortableDataService.index = this.index;\n                this.detectChanges();\n            }\n        }\n    }\n\n    _onDropCallback (event: Event) {\n        if (this._sortableDataService.isDragged) {\n            // console.log('onDropCallback.onDropSuccessCallback.dragData', this._dragDropService.dragData);\n            this.onDropSuccessCallback.emit(this._dragDropService.dragData);\n            if (this._dragDropService.onDragSuccessCallback) {\n                // console.log('onDropCallback.onDragSuccessCallback.dragData', this._dragDropService.dragData);\n                this._dragDropService.onDragSuccessCallback.emit(this._dragDropService.dragData);\n            }\n            // Refresh changes in properties of container component\n            this._sortableContainer.detectChanges();\n        }\n    }\n}\n\n@Directive({ selector: '[dnd-sortable-handle]' })\nexport class SortableHandleComponent extends AbstractHandleComponent {\n    constructor(elemRef: ElementRef, dragDropService: DragDropService, config:DragDropConfig, _Component: SortableComponent,\n        cdr:ChangeDetectorRef) {\n\n        super(elemRef, dragDropService, config, _Component, cdr);\n    }\n}\n"]}