Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Dropzonejs remove files without calling remove callback

Tags:

dropzone.js

I'm using Dropzonejs to upload files to use in my module. The way it works is you edit an item, you drag a file to the dropzone, the dropzone hides and you see a preview of the image. That preview is self-made and has a delete button to delete the image and nullify the column in the database.

To delete the files, the dropzone has a .on call for removedfile. This is put in a global function looking something like this (only with the important data for the question):

function createDropzone(removeCallback, id) {
    $('#' + id).dropzone({
        url: 'URL TO UPLOAD FILE',
        init: function() {
            var myDropzone = this;

            this.on('removedfile', function(file) {
                $.post('URL TO DELETE FILE', {file: file}, function(response) {
                    // handle delete
            } 
        },
    }
}

Now in this specific module when somebody uploads an image, it has to hide the dropzone element and show a custom preview element. However, if somebody wishes to delete the image, it has to remove the files from the dropzone AND run the click event when clicked on the delete icon by the custom preview.

The problem however is, if an image exists, it won't add the image to the dropzone and you will see the custom preview immediately. Thus, I cannot simply call the dropzone removeallfiles function, since the dropzone doesn't always contain the image. But when I call the removeallfiles function AND the event is called and an image is in the dropzone, it will try to remove the file twice.

Is there any way to remove all files from the dropzone without getting the removedfiles called?

(sorry if my explaination isn't well, it's still early in the morning, I can explain it better)

like image 815
Joshua Bakker Avatar asked Apr 24 '18 07:04

Joshua Bakker


1 Answers

I'm using Dropzone's addedfileevent to remove any non-final previous upload attempts, like this:

init: function() {
    var myDropzone = this;
    this.on('addedfile', function(file) {
        if (this.files.length > 1) {
            this.removeFile(this.files[0]);
        }
    });
}

Then on submit, I'm processing the files:

$('input[type="submit"]').on("click", function (e) {
    // Make sure that the form isn't actually being sent.
    if (myDropzone.getQueuedFiles().length > 0) {
        e.preventDefault();
        e.stopPropagation();
        myDropzone.processQueue();
    }
});

I hope it helps :)

like image 139
R.P. Avatar answered Oct 24 '22 19:10

R.P.