231 lines
8.4 KiB
JavaScript
231 lines
8.4 KiB
JavaScript
/** This file is part of KCFinder project
|
|
*
|
|
* @desc Upload files using drag and drop
|
|
* @package KCFinder
|
|
* @version 3.12
|
|
* @author Forum user (updated by Pavel Tzonkov)
|
|
* @copyright 2010-2014 KCFinder Project
|
|
* @license http://opensource.org/licenses/GPL-3.0 GPLv3
|
|
* @license http://opensource.org/licenses/LGPL-3.0 LGPLv3
|
|
* @link http://kcfinder.sunhater.com
|
|
*/
|
|
|
|
_.initDropUpload = function() {
|
|
if ((typeof XMLHttpRequest == "undefined") ||
|
|
(typeof document.addEventListener == "undefined") ||
|
|
(typeof File == "undefined") ||
|
|
(typeof FileReader == "undefined")
|
|
)
|
|
return;
|
|
|
|
if (!XMLHttpRequest.prototype.sendAsBinary) {
|
|
XMLHttpRequest.prototype.sendAsBinary = function(datastr) {
|
|
var ords = Array.prototype.map.call(datastr, function(x) {
|
|
return x.charCodeAt(0) & 0xff;
|
|
}),
|
|
ui8a = new Uint8Array(ords);
|
|
this.send(ui8a.buffer);
|
|
}
|
|
}
|
|
|
|
var uploadQueue = [],
|
|
uploadInProgress = false,
|
|
filesCount = 0,
|
|
errors = [],
|
|
files = $('#files'),
|
|
folders = $('div.folder > a'),
|
|
boundary = "------multipartdropuploadboundary" + (new Date).getTime(),
|
|
currentFile,
|
|
|
|
filesDragOver = function(e) {
|
|
if (e.preventDefault) e.preventDefault();
|
|
$('#files').addClass('drag');
|
|
return false;
|
|
},
|
|
|
|
filesDragEnter = function(e) {
|
|
if (e.preventDefault) e.preventDefault();
|
|
return false;
|
|
},
|
|
|
|
filesDragLeave = function(e) {
|
|
if (e.preventDefault) e.preventDefault();
|
|
$('#files').removeClass('drag');
|
|
return false;
|
|
},
|
|
|
|
filesDrop = function(e) {
|
|
if (e.preventDefault) e.preventDefault();
|
|
if (e.stopPropagation) e.stopPropagation();
|
|
$('#files').removeClass('drag');
|
|
if (!$('#folders span.current').first().parent().data('writable')) {
|
|
_.alert("Cannot write to upload folder.");
|
|
return false;
|
|
}
|
|
filesCount += e.dataTransfer.files.length;
|
|
for (var i = 0; i < e.dataTransfer.files.length; i++) {
|
|
var file = e.dataTransfer.files[i];
|
|
file.thisTargetDir = _.dir;
|
|
uploadQueue.push(file);
|
|
}
|
|
processUploadQueue();
|
|
return false;
|
|
},
|
|
|
|
folderDrag = function(e) {
|
|
if (e.preventDefault) e.preventDefault();
|
|
return false;
|
|
},
|
|
|
|
folderDrop = function(e, dir) {
|
|
if (e.preventDefault) e.preventDefault();
|
|
if (e.stopPropagation) e.stopPropagation();
|
|
if (!$(dir).data('writable')) {
|
|
_.alert(_.label("Cannot write to upload folder."));
|
|
return false;
|
|
}
|
|
filesCount += e.dataTransfer.files.length;
|
|
for (var i = 0; i < e.dataTransfer.files.length; i++) {
|
|
var file = e.dataTransfer.files[i];
|
|
file.thisTargetDir = $(dir).data('path');
|
|
uploadQueue.push(file);
|
|
}
|
|
processUploadQueue();
|
|
return false;
|
|
};
|
|
|
|
files.get(0).removeEventListener('dragover', filesDragOver, false);
|
|
files.get(0).removeEventListener('dragenter', filesDragEnter, false);
|
|
files.get(0).removeEventListener('dragleave', filesDragLeave, false);
|
|
files.get(0).removeEventListener('drop', filesDrop, false);
|
|
|
|
files.get(0).addEventListener('dragover', filesDragOver, false);
|
|
files.get(0).addEventListener('dragenter', filesDragEnter, false);
|
|
files.get(0).addEventListener('dragleave', filesDragLeave, false);
|
|
files.get(0).addEventListener('drop', filesDrop, false);
|
|
|
|
folders.each(function() {
|
|
var folder = this,
|
|
|
|
dragOver = function(e) {
|
|
$(folder).children('span.folder').addClass('context');
|
|
return folderDrag(e);
|
|
},
|
|
|
|
dragLeave = function(e) {
|
|
$(folder).children('span.folder').removeClass('context');
|
|
return folderDrag(e);
|
|
},
|
|
|
|
drop = function(e) {
|
|
$(folder).children('span.folder').removeClass('context');
|
|
return folderDrop(e, folder);
|
|
};
|
|
|
|
this.removeEventListener('dragover', dragOver, false);
|
|
this.removeEventListener('dragenter', folderDrag, false);
|
|
this.removeEventListener('dragleave', dragLeave, false);
|
|
this.removeEventListener('drop', drop, false);
|
|
|
|
this.addEventListener('dragover', dragOver, false);
|
|
this.addEventListener('dragenter', folderDrag, false);
|
|
this.addEventListener('dragleave', dragLeave, false);
|
|
this.addEventListener('drop', drop, false);
|
|
});
|
|
|
|
function updateProgress(evt) {
|
|
var progress = evt.lengthComputable
|
|
? Math.round((evt.loaded * 100) / evt.total) + '%'
|
|
: Math.round(evt.loaded / 1024) + " KB";
|
|
$('#loading').html(_.label("Uploading file {number} of {count}... {progress}", {
|
|
number: filesCount - uploadQueue.length,
|
|
count: filesCount,
|
|
progress: progress
|
|
}));
|
|
}
|
|
|
|
function processUploadQueue() {
|
|
if (uploadInProgress)
|
|
return false;
|
|
|
|
if (uploadQueue && uploadQueue.length) {
|
|
var file = uploadQueue.shift();
|
|
currentFile = file;
|
|
$('#loading').html(_.label("Uploading file {number} of {count}... {progress}", {
|
|
number: filesCount - uploadQueue.length,
|
|
count: filesCount,
|
|
progress: ""
|
|
})).show();
|
|
|
|
var reader = new FileReader();
|
|
reader.thisFileName = file.name;
|
|
reader.thisFileType = file.type;
|
|
reader.thisFileSize = file.size;
|
|
reader.thisTargetDir = file.thisTargetDir;
|
|
|
|
reader.onload = function(evt) {
|
|
uploadInProgress = true;
|
|
|
|
var postbody = '--' + boundary + '\r\nContent-Disposition: form-data; name="upload[]"';
|
|
if (evt.target.thisFileName)
|
|
postbody += '; filename="' + $.$.utf8encode(evt.target.thisFileName) + '"';
|
|
postbody += '\r\n';
|
|
if (evt.target.thisFileSize)
|
|
postbody += "Content-Length: " + evt.target.thisFileSize + "\r\n";
|
|
postbody += "Content-Type: " + evt.target.thisFileType + "\r\n\r\n" + evt.target.result + "\r\n--" + boundary + '\r\nContent-Disposition: form-data; name="dir"\r\n\r\n' + $.$.utf8encode(evt.target.thisTargetDir) + "\r\n--" + boundary + "\r\n--" + boundary + "--\r\n";
|
|
|
|
var xhr = new XMLHttpRequest();
|
|
xhr.thisFileName = evt.target.thisFileName;
|
|
|
|
if (xhr.upload) {
|
|
xhr.upload.thisFileName = evt.target.thisFileName;
|
|
xhr.upload.addEventListener("progress", updateProgress, false);
|
|
}
|
|
xhr.open('post', _.getURL('upload'), true);
|
|
xhr.setRequestHeader('Content-Type', "multipart/form-data; boundary=" + boundary);
|
|
//xhr.setRequestHeader('Content-Length', postbody.length);
|
|
|
|
xhr.onload = function(e) {
|
|
$('#loading').hide();
|
|
if (_.dir == reader.thisTargetDir)
|
|
_.fadeFiles();
|
|
uploadInProgress = false;
|
|
processUploadQueue();
|
|
if (xhr.responseText.substr(0, 1) != "/")
|
|
errors[errors.length] = xhr.responseText;
|
|
};
|
|
|
|
xhr.sendAsBinary(postbody);
|
|
};
|
|
|
|
reader.onerror = function(evt) {
|
|
$('#loading').hide();
|
|
uploadInProgress = false;
|
|
processUploadQueue();
|
|
errors[errors.length] = _.label("Failed to upload {filename}!", {
|
|
filename: evt.target.thisFileName
|
|
});
|
|
};
|
|
|
|
reader.readAsBinaryString(file);
|
|
|
|
} else {
|
|
filesCount = 0;
|
|
var loop = setInterval(function() {
|
|
if (uploadInProgress) return;
|
|
boundary = "------multipartdropuploadboundary" + (new Date).getTime();
|
|
uploadQueue = [];
|
|
clearInterval(loop);
|
|
if (currentFile.thisTargetDir == _.dir)
|
|
_.refresh();
|
|
if (errors.length) {
|
|
errors = errors.join("\n");
|
|
if (errors.replace(/^\s+/g, "").replace(/\s+$/g, "").length)
|
|
_.alert(errors);
|
|
errors = [];
|
|
}
|
|
}, 333);
|
|
}
|
|
}
|
|
};
|