UNPKG

ng2-dnd

Version:

Angular 2 Drag-and-Drop without dependencies

105 lines 12.6 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 { AbstractComponent } from './abstract.component'; let DroppableComponent = class DroppableComponent extends AbstractComponent { constructor(elemRef, dragDropService, config, cdr) { super(elemRef, dragDropService, config, cdr); /** * Callback function called when the drop action completes correctly. * It is activated before the on-drag-success callback. */ this.onDropSuccess = new EventEmitter(); this.onDragEnter = new EventEmitter(); this.onDragOver = new EventEmitter(); this.onDragLeave = new EventEmitter(); this.dropEnabled = true; } set droppable(value) { this.dropEnabled = !!value; } set allowdrop(value) { this.allowDrop = value; } set dropzones(value) { this.dropZones = value; } /** * Drag allowed effect */ set effectallowed(value) { this.effectAllowed = value; } /** * Drag effect cursor */ set effectcursor(value) { this.effectCursor = value; } _onDragEnterCallback(event) { if (this._dragDropService.isDragged) { this._elem.classList.add(this._config.onDragEnterClass); this.onDragEnter.emit({ dragData: this._dragDropService.dragData, mouseEvent: event }); } } _onDragOverCallback(event) { if (this._dragDropService.isDragged) { this._elem.classList.add(this._config.onDragOverClass); this.onDragOver.emit({ dragData: this._dragDropService.dragData, mouseEvent: event }); } } ; _onDragLeaveCallback(event) { if (this._dragDropService.isDragged) { this._elem.classList.remove(this._config.onDragOverClass); this._elem.classList.remove(this._config.onDragEnterClass); this.onDragLeave.emit({ dragData: this._dragDropService.dragData, mouseEvent: event }); } } ; _onDropCallback(event) { let dataTransfer = event.dataTransfer; if (this._dragDropService.isDragged || (dataTransfer && dataTransfer.files)) { this.onDropSuccess.emit({ dragData: this._dragDropService.dragData, mouseEvent: event }); if (this._dragDropService.onDragSuccessCallback) { this._dragDropService.onDragSuccessCallback.emit({ dragData: this._dragDropService.dragData, mouseEvent: event }); } this._elem.classList.remove(this._config.onDragOverClass); this._elem.classList.remove(this._config.onDragEnterClass); } } }; __decorate([ Input("dropEnabled") ], DroppableComponent.prototype, "droppable", null); __decorate([ Output() ], DroppableComponent.prototype, "onDropSuccess", void 0); __decorate([ Output() ], DroppableComponent.prototype, "onDragEnter", void 0); __decorate([ Output() ], DroppableComponent.prototype, "onDragOver", void 0); __decorate([ Output() ], DroppableComponent.prototype, "onDragLeave", void 0); __decorate([ Input("allowDrop") ], DroppableComponent.prototype, "allowdrop", null); __decorate([ Input("dropZones") ], DroppableComponent.prototype, "dropzones", null); __decorate([ Input("effectAllowed") ], DroppableComponent.prototype, "effectallowed", null); __decorate([ Input("effectCursor") ], DroppableComponent.prototype, "effectcursor", null); DroppableComponent = __decorate([ Directive({ selector: '[dnd-droppable]' }) ], DroppableComponent); export { DroppableComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"droppable.component.js","sourceRoot":"","sources":["../../../src/droppable.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';\n\nimport {AbstractComponent} from './abstract.component';\nimport {DragDropConfig} from './dnd.config';\nimport {DragDropService, DragDropData} from './dnd.service';\n\n@Directive({ selector: '[dnd-droppable]' })\nexport class DroppableComponent extends AbstractComponent {\n\n    @Input(\"dropEnabled\") set droppable(value:boolean) {\n        this.dropEnabled = !!value;\n    }\n\n    /**\n     * Callback function called when the drop action completes correctly.\n     * It is activated before the on-drag-success callback.\n     */\n    @Output() onDropSuccess: EventEmitter<DragDropData> = new EventEmitter<DragDropData>();\n    @Output() onDragEnter: EventEmitter<DragDropData> = new EventEmitter<DragDropData>();\n    @Output() onDragOver: EventEmitter<DragDropData> = new EventEmitter<DragDropData>();\n    @Output() onDragLeave: EventEmitter<DragDropData> = new EventEmitter<DragDropData>();\n\n    @Input(\"allowDrop\") set allowdrop(value: (dropData: any) => boolean) {\n        this.allowDrop = value;\n    }\n\n    @Input(\"dropZones\") set dropzones(value:Array<string>) {\n        this.dropZones = value;\n    }\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    constructor(elemRef: ElementRef, dragDropService: DragDropService, config:DragDropConfig,\n        cdr:ChangeDetectorRef) {\n\n        super(elemRef, dragDropService, config, cdr);\n\n        this.dropEnabled = true;\n    }\n\n    _onDragEnterCallback(event: MouseEvent) {\n        if (this._dragDropService.isDragged) {\n            this._elem.classList.add(this._config.onDragEnterClass);\n            this.onDragEnter.emit({dragData: this._dragDropService.dragData, mouseEvent: event});\n        }\n    }\n\n    _onDragOverCallback (event: MouseEvent) {\n        if (this._dragDropService.isDragged) {\n            this._elem.classList.add(this._config.onDragOverClass);\n            this.onDragOver.emit({dragData: this._dragDropService.dragData, mouseEvent: event});\n        }\n    };\n\n    _onDragLeaveCallback (event: MouseEvent) {\n        if (this._dragDropService.isDragged) {\n            this._elem.classList.remove(this._config.onDragOverClass);\n            this._elem.classList.remove(this._config.onDragEnterClass);\n            this.onDragLeave.emit({dragData: this._dragDropService.dragData, mouseEvent: event});\n        }\n    };\n\n    _onDropCallback (event: MouseEvent) {\n        let dataTransfer = (event as any).dataTransfer;\n        if (this._dragDropService.isDragged || (dataTransfer && dataTransfer.files)) {\n            this.onDropSuccess.emit({dragData: this._dragDropService.dragData, mouseEvent: event});\n            if (this._dragDropService.onDragSuccessCallback) {\n                this._dragDropService.onDragSuccessCallback.emit({dragData: this._dragDropService.dragData, mouseEvent: event});\n            }\n            this._elem.classList.remove(this._config.onDragOverClass);\n            this._elem.classList.remove(this._config.onDragEnterClass);\n        }\n    }\n}\n"]}