Обновить список файлов в Dropzone

У меня небольшая проблема с Dropzonejs.

У меня есть этот код:

Dropzone.options.dpzMultipleFiles = {
    dictDefaultMessage: "Przeciągnij pliki aby dodać",
    uploadMultiple: true,
    paramName: "file",
    maxFilesize: 50,
    maxFiles: 15,
    createImageThumbnails: true,
    acceptedFiles: ".png,.jpg,.jpeg",
    clickable: true,
    thumbnailWidth: 200,
    thumbnailHeight: 200,
    autoProcessQueue: true,

    init: function () {
        dpzMultipleFiles = this;
        $.ajax({
            url: '{{ pageTemplate.pageHeader.baseHref }}/SystemConfiguration/ShowFiles',
            type: 'get',
            dataType: 'json',
            cache: false,
            success: function (response) {
                $.each(response, function (key, value) {
                    dpzMultipleFiles.options.maxFiles = dpzMultipleFiles.options.maxFiles - 1;
                    var mockFile = {name: value.name, size: value.size}

                    dpzMultipleFiles.emit('addedfile', mockFile)
                    dpzMultipleFiles.emit('thumbnail', mockFile, value.path)
                    dpzMultipleFiles.emit('complete', mockFile)
                })
            },
            error: function (response) {
                alert('Nastąpił problem z JSON. Proszę o kontakt z administratorem serwisu.');
            }
        });


        this.on('completemultiple', function (file, json) {
            //$('.sortable').sortable('enable');
        });
        this.on("thumbnail", function (file, dataUrl) {
            $('.dz-image').last().find('img').attr({width: '100%', height: '100%'});
        }),


            this.on('success', function (file, json) {
                if (file.accepted == true) {

                    $('.dz-preview').remove();
                    this.removeAllFiles;
                }
            });
        this.on('successmultiple', function () {
            $('.dz-preview').remove()
            $.ajax({
                url: '{{ pageTemplate.pageHeader.baseHref }}/SystemConfiguration/ShowFiles',
                type: 'get',
                dataType: 'json',
                cache: false,
                success: function (response) {
                    $.each(response, function (key, value) {
                        var mockFile = {name: value.name, size: value.size}
                        dpzMultipleFiles.emit('addedfile', mockFile)
                        dpzMultipleFiles.emit('thumbnail', mockFile, value.path)
                        dpzMultipleFiles.emit('complete', mockFile)
                    });
                }
                ,
                error: function (response) {
                    alert('Nastąpił problem z JSON. Proszę o kontakt z administratorem serwisu.');
                }
            });
        })
        this.on("addedfile", function (file) {
            var removeButton = Dropzone.createElement("<button class='remove_file_dropzone'> Skasuj plik </button>");
            removeButton.addEventListener("click", function (e) {
                e.preventDefault();
                e.stopPropagation();

                $.ajax({
                    url: '{{ pageTemplate.pageHeader.baseHref }}/SystemConfiguration/RemoveFile/' + file.name,
                    dataType: 'text',
                    type: 'post',
                    cache: false,
                    data: $(this).serialize(),
                    success: function (data, textStatus, jQxhr) {
                        x = confirm('Czy napewno chcesz skasować ten plik?');
                        if (!x) return false;
                        dpzMultipleFiles.options.maxFiles = dpzMultipleFiles.options.maxFiles + 1;
                        $('.dz-preview').remove();
                        this.removeAllFiles;
                        $.ajax({
                            url: '{{ pageTemplate.pageHeader.baseHref }}/SystemConfiguration/ShowFiles',
                            type: 'get',
                            dataType: 'json',
                            cache: false,
                            success: function (response) {
                                $.each(response, function (key, value) {
                                    var mockFile = {name: value.name, size: value.size}
                                    dpzMultipleFiles.emit('addedfile', mockFile)
                                    dpzMultipleFiles.emit('thumbnail', mockFile, value.path)
                                    dpzMultipleFiles.emit('complete', mockFile)
                                });
                            }
                            ,
                            error: function (response) {
                                alert('Nastąpił problem z JSON. Proszę o kontakt z administratorem serwisu.');
                            }
                        });
                    }, error: function (jqXhr, textStatus, errorThrown) {
                        alert('Nastąpił problem z JSON. Proszę o kontakt z administratorem serwisu.');
                    }
                });
            });
            file.previewElement.appendChild(removeButton);
        });
        this.on("maxfilesexceeded", function (file) {
            this.removeFile(file);
        });
        this.on('resetFiles', function () {
            dpzMultipleFiles.removeAllFiles();
        });
        this.on('queuecomplete', function () {
            //$('.dz-preview').remove();
        });
        this.on('drop', function () {

        });
        this.on('complete', function () {
        });
    }
};


$(function () {
    $(".dropzone").sortable({
        items: '.dz-preview',
        cursor: 'move',
        opacity: 0.5,
        containment: '.dropzone',
        distance: 20,
        tolerance: 'pointer',
        update: function (event, ui) {
            $(".dz-filename span").each(function (index) {
                $.ajax({
                    url: '{{ pageTemplate.pageHeader.baseHref }}/SystemConfiguration/ChangeFileOrder/' + $(this).text() + "/" + index,
                    dataType: 'text',
                    type: 'post',
                    cache: false,
                    data: $(this).serialize(),
                    success: function (data, textStatus, jQxhr) {

                    }, error: function (jqXhr, textStatus, errorThrown) {
                        alert('Nastąpił problem z JSON. Proszę o kontakt z administratorem serwisu.');
                    }
                });
            });
        }
    });
});

Скрипт работает корректно на 100%:) Единственная проблема - обновить файлы. Список файлов обновляет меня до 100% завершения загрузки.

Я хотел бы, чтобы список файлов обновлялся после полной загрузки всех файлов, а не до этого.

Кто-нибудь знает, как улучшить мой код?

0 ответов

Другие вопросы по тегам