123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231 |
- /** 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();
- _.refreshDir($('div.folder > a > span.folder').parent());
- 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);
- }
- }
- };
|