forked from extern/egroupware
Update resumable js library
This commit is contained in:
parent
c831ce0128
commit
50bcfa593b
@ -48,6 +48,7 @@
|
|||||||
fileNameParameterName: 'resumableFilename',
|
fileNameParameterName: 'resumableFilename',
|
||||||
relativePathParameterName: 'resumableRelativePath',
|
relativePathParameterName: 'resumableRelativePath',
|
||||||
totalChunksParameterName: 'resumableTotalChunks',
|
totalChunksParameterName: 'resumableTotalChunks',
|
||||||
|
dragOverClass: 'dragover',
|
||||||
throttleProgressCallbacks: 0.5,
|
throttleProgressCallbacks: 0.5,
|
||||||
query:{},
|
query:{},
|
||||||
headers:{},
|
headers:{},
|
||||||
@ -65,7 +66,7 @@
|
|||||||
getTarget:null,
|
getTarget:null,
|
||||||
maxChunkRetries:100,
|
maxChunkRetries:100,
|
||||||
chunkRetryInterval:undefined,
|
chunkRetryInterval:undefined,
|
||||||
permanentErrors:[400, 404, 409, 415, 500, 501],
|
permanentErrors:[400, 401, 403, 404, 409, 415, 500, 501],
|
||||||
maxFiles:undefined,
|
maxFiles:undefined,
|
||||||
withCredentials:false,
|
withCredentials:false,
|
||||||
xhrTimeout:0,
|
xhrTimeout:0,
|
||||||
@ -114,6 +115,13 @@
|
|||||||
else { return $opt.defaults[o]; }
|
else { return $opt.defaults[o]; }
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
$.indexOf = function(array, obj) {
|
||||||
|
if (array.indexOf) { return array.indexOf(obj); }
|
||||||
|
for (var i = 0; i < array.length; i++) {
|
||||||
|
if (array[i] === obj) { return i; }
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
// EVENTS
|
// EVENTS
|
||||||
// catchAll(event, ...)
|
// catchAll(event, ...)
|
||||||
@ -162,7 +170,7 @@
|
|||||||
if(typeof custom === 'function') {
|
if(typeof custom === 'function') {
|
||||||
return custom(file, event);
|
return custom(file, event);
|
||||||
}
|
}
|
||||||
var relativePath = file.webkitRelativePath||file.fileName||file.name; // Some confusion in different versions of Firefox
|
var relativePath = file.webkitRelativePath||file.relativePath||file.fileName||file.name; // Some confusion in different versions of Firefox
|
||||||
var size = file.size;
|
var size = file.size;
|
||||||
return(size + '-' + relativePath.replace(/[^0-9a-zA-Z_-]/img, ''));
|
return(size + '-' + relativePath.replace(/[^0-9a-zA-Z_-]/img, ''));
|
||||||
},
|
},
|
||||||
@ -204,24 +212,40 @@
|
|||||||
var separator = target.indexOf('?') < 0 ? '?' : '&';
|
var separator = target.indexOf('?') < 0 ? '?' : '&';
|
||||||
var joinedParams = params.join('&');
|
var joinedParams = params.join('&');
|
||||||
|
|
||||||
return target + separator + joinedParams;
|
if (joinedParams) target = target + separator + joinedParams;
|
||||||
|
|
||||||
|
return target;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
var onDrop = function(event){
|
var onDrop = function(e){
|
||||||
$h.stopEvent(event);
|
e.currentTarget.classList.remove($.getOpt('dragOverClass'));
|
||||||
|
$h.stopEvent(e);
|
||||||
|
|
||||||
//handle dropped things as items if we can (this lets us deal with folders nicer in some cases)
|
//handle dropped things as items if we can (this lets us deal with folders nicer in some cases)
|
||||||
if (event.dataTransfer && event.dataTransfer.items) {
|
if (e.dataTransfer && e.dataTransfer.items) {
|
||||||
loadFiles(event.dataTransfer.items, event);
|
loadFiles(e.dataTransfer.items, e);
|
||||||
}
|
}
|
||||||
//else handle them as files
|
//else handle them as files
|
||||||
else if (event.dataTransfer && event.dataTransfer.files) {
|
else if (e.dataTransfer && e.dataTransfer.files) {
|
||||||
loadFiles(event.dataTransfer.files, event);
|
loadFiles(e.dataTransfer.files, e);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
var preventDefault = function(e) {
|
var onDragLeave = function(e){
|
||||||
|
e.currentTarget.classList.remove($.getOpt('dragOverClass'));
|
||||||
|
};
|
||||||
|
var onDragOverEnter = function(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
var dt = e.dataTransfer;
|
||||||
|
if ($.indexOf(dt.types, "Files") >= 0) { // only for file drop
|
||||||
|
e.stopPropagation();
|
||||||
|
dt.dropEffect = "copy";
|
||||||
|
dt.effectAllowed = "copy";
|
||||||
|
e.currentTarget.classList.add($.getOpt('dragOverClass'));
|
||||||
|
} else { // not work on IE/Edge....
|
||||||
|
dt.dropEffect = "none";
|
||||||
|
dt.effectAllowed = "none";
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -293,20 +317,27 @@
|
|||||||
*/
|
*/
|
||||||
function processDirectory (directory, path, items, cb) {
|
function processDirectory (directory, path, items, cb) {
|
||||||
var dirReader = directory.createReader();
|
var dirReader = directory.createReader();
|
||||||
dirReader.readEntries(function(entries){
|
var allEntries = [];
|
||||||
if(!entries.length){
|
|
||||||
// empty directory, skip
|
function readEntries () {
|
||||||
return cb();
|
dirReader.readEntries(function(entries){
|
||||||
}
|
if (entries.length) {
|
||||||
// process all conversion callbacks, finally invoke own one
|
allEntries = allEntries.concat(entries);
|
||||||
processCallbacks(
|
return readEntries();
|
||||||
entries.map(function(entry){
|
}
|
||||||
// bind all properties except for callback
|
|
||||||
return processItem.bind(null, entry, path, items);
|
// process all conversion callbacks, finally invoke own one
|
||||||
}),
|
processCallbacks(
|
||||||
cb
|
allEntries.map(function(entry){
|
||||||
);
|
// bind all properties except for callback
|
||||||
});
|
return processItem.bind(null, entry, path, items);
|
||||||
|
}),
|
||||||
|
cb
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
readEntries();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -323,7 +354,11 @@
|
|||||||
processCallbacks(
|
processCallbacks(
|
||||||
Array.prototype.map.call(items, function(item){
|
Array.prototype.map.call(items, function(item){
|
||||||
// bind all properties except for callback
|
// bind all properties except for callback
|
||||||
return processItem.bind(null, item, "", files);
|
var entry = item;
|
||||||
|
if('function' === typeof item.webkitGetAsEntry){
|
||||||
|
entry = item.webkitGetAsEntry();
|
||||||
|
}
|
||||||
|
return processItem.bind(null, entry, "", files);
|
||||||
}),
|
}),
|
||||||
function(){
|
function(){
|
||||||
if(files.length){
|
if(files.length){
|
||||||
@ -372,10 +407,10 @@
|
|||||||
// Allowing for both [extension, .extension, mime/type, mime/*]
|
// Allowing for both [extension, .extension, mime/type, mime/*]
|
||||||
var extension = ((o.fileType[index].match(/^[^.][^/]+$/)) ? '.' : '') + o.fileType[index];
|
var extension = ((o.fileType[index].match(/^[^.][^/]+$/)) ? '.' : '') + o.fileType[index];
|
||||||
|
|
||||||
if ((fileName.substr(-1 * extension.length) === extension) ||
|
if ((fileName.substr(-1 * extension.length).toLowerCase() === extension) ||
|
||||||
//If MIME type, check for wildcard or if extension matches the files tiletype
|
//If MIME type, check for wildcard or if extension matches the files tiletype
|
||||||
(extension.indexOf('/') !== -1 && (
|
(extension.indexOf('/') !== -1 && (
|
||||||
(extension.indexOf('*') !== -1 && fileType.substr(0, extension.indexOf('*')) === extension.substr(0, extension.indexOf('*'))) ||
|
(extension.indexOf('*') !== -1 && fileType.substr(0, extension.indexOf('*')) === extension.substr(0, extension.indexOf('*'))) ||
|
||||||
fileType === extension
|
fileType === extension
|
||||||
))
|
))
|
||||||
){
|
){
|
||||||
@ -385,17 +420,17 @@
|
|||||||
}
|
}
|
||||||
if (!fileTypeFound) {
|
if (!fileTypeFound) {
|
||||||
o.fileTypeErrorCallback(file, errorCount++);
|
o.fileTypeErrorCallback(file, errorCount++);
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (typeof(o.minFileSize)!=='undefined' && file.size<o.minFileSize) {
|
if (typeof(o.minFileSize)!=='undefined' && file.size<o.minFileSize) {
|
||||||
o.minFileSizeErrorCallback(file, errorCount++);
|
o.minFileSizeErrorCallback(file, errorCount++);
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
if (typeof(o.maxFileSize)!=='undefined' && file.size>o.maxFileSize) {
|
if (typeof(o.maxFileSize)!=='undefined' && file.size>o.maxFileSize) {
|
||||||
o.maxFileSizeErrorCallback(file, errorCount++);
|
o.maxFileSizeErrorCallback(file, errorCount++);
|
||||||
return false;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
function addFile(uniqueIdentifier){
|
function addFile(uniqueIdentifier){
|
||||||
@ -468,7 +503,7 @@
|
|||||||
break;
|
break;
|
||||||
case 'success':
|
case 'success':
|
||||||
if(_error) return;
|
if(_error) return;
|
||||||
$.resumableObj.fire('fileProgress', $); // it's at least progress
|
$.resumableObj.fire('fileProgress', $, message); // it's at least progress
|
||||||
if($.isComplete()) {
|
if($.isComplete()) {
|
||||||
$.resumableObj.fire('fileSuccess', $, message);
|
$.resumableObj.fire('fileSuccess', $, message);
|
||||||
}
|
}
|
||||||
@ -584,7 +619,7 @@
|
|||||||
$.preprocessFinished = function(){
|
$.preprocessFinished = function(){
|
||||||
$.preprocessState = 2;
|
$.preprocessState = 2;
|
||||||
$.upload();
|
$.upload();
|
||||||
};
|
};
|
||||||
$.upload = function () {
|
$.upload = function () {
|
||||||
var found = false;
|
var found = false;
|
||||||
if ($.isPaused() === false) {
|
if ($.isPaused() === false) {
|
||||||
@ -606,6 +641,14 @@
|
|||||||
}
|
}
|
||||||
return(found);
|
return(found);
|
||||||
}
|
}
|
||||||
|
$.markChunksCompleted = function (chunkNumber) {
|
||||||
|
if (!$.chunks || $.chunks.length <= chunkNumber) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (var num = 0; num < chunkNumber; num++) {
|
||||||
|
$.chunks[num].markComplete = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
// Bootstrap and return
|
// Bootstrap and return
|
||||||
$.resumableObj.fire('chunkingStart', $);
|
$.resumableObj.fire('chunkingStart', $);
|
||||||
@ -629,6 +672,7 @@
|
|||||||
$.retries = 0;
|
$.retries = 0;
|
||||||
$.pendingRetry = false;
|
$.pendingRetry = false;
|
||||||
$.preprocessState = 0; // 0 = unprocessed, 1 = processing, 2 = finished
|
$.preprocessState = 0; // 0 = unprocessed, 1 = processing, 2 = finished
|
||||||
|
$.markComplete = false;
|
||||||
|
|
||||||
// Computed properties
|
// Computed properties
|
||||||
var chunkSize = $.getOpt('chunkSize');
|
var chunkSize = $.getOpt('chunkSize');
|
||||||
@ -861,6 +905,8 @@
|
|||||||
// if pending retry then that's effectively the same as actively uploading,
|
// if pending retry then that's effectively the same as actively uploading,
|
||||||
// there might just be a slight delay before the retry starts
|
// there might just be a slight delay before the retry starts
|
||||||
return('uploading');
|
return('uploading');
|
||||||
|
} else if($.markComplete) {
|
||||||
|
return 'success';
|
||||||
} else if(!$.xhr) {
|
} else if(!$.xhr) {
|
||||||
return('pending');
|
return('pending');
|
||||||
} else if($.xhr.readyState<4) {
|
} else if($.xhr.readyState<4) {
|
||||||
@ -871,7 +917,7 @@
|
|||||||
// HTTP 200, 201 (created)
|
// HTTP 200, 201 (created)
|
||||||
return('success');
|
return('success');
|
||||||
} else if($h.contains($.getOpt('permanentErrors'), $.xhr.status) || $.retries >= $.getOpt('maxChunkRetries')) {
|
} else if($h.contains($.getOpt('permanentErrors'), $.xhr.status) || $.retries >= $.getOpt('maxChunkRetries')) {
|
||||||
// HTTP 415/500/501, permanent error
|
// HTTP 400, 404, 409, 415, 500, 501 (permanent error)
|
||||||
return('error');
|
return('error');
|
||||||
} else {
|
} else {
|
||||||
// this should never happen, but we'll reset and queue a retry
|
// this should never happen, but we'll reset and queue a retry
|
||||||
@ -888,7 +934,7 @@
|
|||||||
if(typeof(relative)==='undefined') relative = false;
|
if(typeof(relative)==='undefined') relative = false;
|
||||||
var factor = (relative ? ($.endByte-$.startByte)/$.fileObjSize : 1);
|
var factor = (relative ? ($.endByte-$.startByte)/$.fileObjSize : 1);
|
||||||
if($.pendingRetry) return(0);
|
if($.pendingRetry) return(0);
|
||||||
if(!$.xhr || !$.xhr.status) factor*=.95;
|
if((!$.xhr || !$.xhr.status) && !$.markComplete) factor*=.95;
|
||||||
var s = $.status();
|
var s = $.status();
|
||||||
switch(s){
|
switch(s){
|
||||||
case 'success':
|
case 'success':
|
||||||
@ -1007,8 +1053,9 @@
|
|||||||
if(typeof(domNodes.length)=='undefined') domNodes = [domNodes];
|
if(typeof(domNodes.length)=='undefined') domNodes = [domNodes];
|
||||||
|
|
||||||
$h.each(domNodes, function(domNode) {
|
$h.each(domNodes, function(domNode) {
|
||||||
domNode.addEventListener('dragover', preventDefault, false);
|
domNode.addEventListener('dragover', onDragOverEnter, false);
|
||||||
domNode.addEventListener('dragenter', preventDefault, false);
|
domNode.addEventListener('dragenter', onDragOverEnter, false);
|
||||||
|
domNode.addEventListener('dragleave', onDragLeave, false);
|
||||||
domNode.addEventListener('drop', onDrop, false);
|
domNode.addEventListener('drop', onDrop, false);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@ -1016,8 +1063,9 @@
|
|||||||
if (typeof(domNodes.length) == 'undefined') domNodes = [domNodes];
|
if (typeof(domNodes.length) == 'undefined') domNodes = [domNodes];
|
||||||
|
|
||||||
$h.each(domNodes, function(domNode) {
|
$h.each(domNodes, function(domNode) {
|
||||||
domNode.removeEventListener('dragover', preventDefault);
|
domNode.removeEventListener('dragover', onDragOverEnter);
|
||||||
domNode.removeEventListener('dragenter', preventDefault);
|
domNode.removeEventListener('dragenter', onDragOverEnter);
|
||||||
|
domNode.removeEventListener('dragleave', onDragLeave);
|
||||||
domNode.removeEventListener('drop', onDrop);
|
domNode.removeEventListener('drop', onDrop);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@ -1108,7 +1156,9 @@
|
|||||||
|
|
||||||
// Node.js-style export for Node and Component
|
// Node.js-style export for Node and Component
|
||||||
if (typeof module != 'undefined') {
|
if (typeof module != 'undefined') {
|
||||||
|
// left here for backwards compatibility
|
||||||
module.exports = Resumable;
|
module.exports = Resumable;
|
||||||
|
module.exports.Resumable = Resumable;
|
||||||
} else if (typeof define === "function" && define.amd) {
|
} else if (typeof define === "function" && define.amd) {
|
||||||
// AMD/requirejs: Define the module
|
// AMD/requirejs: Define the module
|
||||||
define(function(){
|
define(function(){
|
||||||
|
Loading…
Reference in New Issue
Block a user