mirror of https://github.com/ghostfolio/ghostfolio
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
28 lines
781 B
28 lines
781 B
import { Directive, HostListener, Output, EventEmitter } from '@angular/core';
|
|
|
|
@Directive({
|
|
selector: '[gfFileDrop]'
|
|
})
|
|
export class FileDropDirective {
|
|
@Output() filesDropped = new EventEmitter<FileList>();
|
|
|
|
@HostListener('dragenter', ['$event']) onDragEnter(event: DragEvent) {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
}
|
|
|
|
@HostListener('dragover', ['$event']) onDragOver(event: DragEvent) {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
}
|
|
|
|
@HostListener('drop', ['$event']) onDrop(event: DragEvent) {
|
|
event.preventDefault();
|
|
event.stopPropagation();
|
|
|
|
// Prevent the browser's default behavior for handling the file drop
|
|
event.dataTransfer.dropEffect = 'copy';
|
|
|
|
this.filesDropped.emit(event.dataTransfer.files);
|
|
}
|
|
}
|
|
|