Обновить список файлов в 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% завершения загрузки.
Я хотел бы, чтобы список файлов обновлялся после полной загрузки всех файлов, а не до этого.
Кто-нибудь знает, как улучшить мой код?