mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-12-31 11:09:04 +01:00
Update resumable js library
This commit is contained in:
parent
c831ce0128
commit
50bcfa593b
@ -48,6 +48,7 @@
|
||||
fileNameParameterName: 'resumableFilename',
|
||||
relativePathParameterName: 'resumableRelativePath',
|
||||
totalChunksParameterName: 'resumableTotalChunks',
|
||||
dragOverClass: 'dragover',
|
||||
throttleProgressCallbacks: 0.5,
|
||||
query:{},
|
||||
headers:{},
|
||||
@ -65,7 +66,7 @@
|
||||
getTarget:null,
|
||||
maxChunkRetries:100,
|
||||
chunkRetryInterval:undefined,
|
||||
permanentErrors:[400, 404, 409, 415, 500, 501],
|
||||
permanentErrors:[400, 401, 403, 404, 409, 415, 500, 501],
|
||||
maxFiles:undefined,
|
||||
withCredentials:false,
|
||||
xhrTimeout:0,
|
||||
@ -114,6 +115,13 @@
|
||||
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
|
||||
// catchAll(event, ...)
|
||||
@ -162,7 +170,7 @@
|
||||
if(typeof custom === 'function') {
|
||||
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;
|
||||
return(size + '-' + relativePath.replace(/[^0-9a-zA-Z_-]/img, ''));
|
||||
},
|
||||
@ -204,24 +212,40 @@
|
||||
var separator = target.indexOf('?') < 0 ? '?' : '&';
|
||||
var joinedParams = params.join('&');
|
||||
|
||||
return target + separator + joinedParams;
|
||||
if (joinedParams) target = target + separator + joinedParams;
|
||||
|
||||
return target;
|
||||
}
|
||||
};
|
||||
|
||||
var onDrop = function(event){
|
||||
$h.stopEvent(event);
|
||||
var onDrop = function(e){
|
||||
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)
|
||||
if (event.dataTransfer && event.dataTransfer.items) {
|
||||
loadFiles(event.dataTransfer.items, event);
|
||||
if (e.dataTransfer && e.dataTransfer.items) {
|
||||
loadFiles(e.dataTransfer.items, e);
|
||||
}
|
||||
//else handle them as files
|
||||
else if (event.dataTransfer && event.dataTransfer.files) {
|
||||
loadFiles(event.dataTransfer.files, event);
|
||||
else if (e.dataTransfer && e.dataTransfer.files) {
|
||||
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();
|
||||
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) {
|
||||
var dirReader = directory.createReader();
|
||||
dirReader.readEntries(function(entries){
|
||||
if(!entries.length){
|
||||
// empty directory, skip
|
||||
return cb();
|
||||
}
|
||||
// process all conversion callbacks, finally invoke own one
|
||||
processCallbacks(
|
||||
entries.map(function(entry){
|
||||
// bind all properties except for callback
|
||||
return processItem.bind(null, entry, path, items);
|
||||
}),
|
||||
cb
|
||||
);
|
||||
});
|
||||
var allEntries = [];
|
||||
|
||||
function readEntries () {
|
||||
dirReader.readEntries(function(entries){
|
||||
if (entries.length) {
|
||||
allEntries = allEntries.concat(entries);
|
||||
return readEntries();
|
||||
}
|
||||
|
||||
// process all conversion callbacks, finally invoke own one
|
||||
processCallbacks(
|
||||
allEntries.map(function(entry){
|
||||
// bind all properties except for callback
|
||||
return processItem.bind(null, entry, path, items);
|
||||
}),
|
||||
cb
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
readEntries();
|
||||
}
|
||||
|
||||
/**
|
||||
@ -323,7 +354,11 @@
|
||||
processCallbacks(
|
||||
Array.prototype.map.call(items, function(item){
|
||||
// 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(){
|
||||
if(files.length){
|
||||
@ -372,10 +407,10 @@
|
||||
// Allowing for both [extension, .extension, mime/type, mime/*]
|
||||
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
|
||||
(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
|
||||
))
|
||||
){
|
||||
@ -385,17 +420,17 @@
|
||||
}
|
||||
if (!fileTypeFound) {
|
||||
o.fileTypeErrorCallback(file, errorCount++);
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
if (typeof(o.minFileSize)!=='undefined' && file.size<o.minFileSize) {
|
||||
o.minFileSizeErrorCallback(file, errorCount++);
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
if (typeof(o.maxFileSize)!=='undefined' && file.size>o.maxFileSize) {
|
||||
o.maxFileSizeErrorCallback(file, errorCount++);
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
function addFile(uniqueIdentifier){
|
||||
@ -468,7 +503,7 @@
|
||||
break;
|
||||
case 'success':
|
||||
if(_error) return;
|
||||
$.resumableObj.fire('fileProgress', $); // it's at least progress
|
||||
$.resumableObj.fire('fileProgress', $, message); // it's at least progress
|
||||
if($.isComplete()) {
|
||||
$.resumableObj.fire('fileSuccess', $, message);
|
||||
}
|
||||
@ -606,6 +641,14 @@
|
||||
}
|
||||
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
|
||||
$.resumableObj.fire('chunkingStart', $);
|
||||
@ -629,6 +672,7 @@
|
||||
$.retries = 0;
|
||||
$.pendingRetry = false;
|
||||
$.preprocessState = 0; // 0 = unprocessed, 1 = processing, 2 = finished
|
||||
$.markComplete = false;
|
||||
|
||||
// Computed properties
|
||||
var chunkSize = $.getOpt('chunkSize');
|
||||
@ -861,6 +905,8 @@
|
||||
// if pending retry then that's effectively the same as actively uploading,
|
||||
// there might just be a slight delay before the retry starts
|
||||
return('uploading');
|
||||
} else if($.markComplete) {
|
||||
return 'success';
|
||||
} else if(!$.xhr) {
|
||||
return('pending');
|
||||
} else if($.xhr.readyState<4) {
|
||||
@ -871,7 +917,7 @@
|
||||
// HTTP 200, 201 (created)
|
||||
return('success');
|
||||
} 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');
|
||||
} else {
|
||||
// this should never happen, but we'll reset and queue a retry
|
||||
@ -888,7 +934,7 @@
|
||||
if(typeof(relative)==='undefined') relative = false;
|
||||
var factor = (relative ? ($.endByte-$.startByte)/$.fileObjSize : 1);
|
||||
if($.pendingRetry) return(0);
|
||||
if(!$.xhr || !$.xhr.status) factor*=.95;
|
||||
if((!$.xhr || !$.xhr.status) && !$.markComplete) factor*=.95;
|
||||
var s = $.status();
|
||||
switch(s){
|
||||
case 'success':
|
||||
@ -1007,8 +1053,9 @@
|
||||
if(typeof(domNodes.length)=='undefined') domNodes = [domNodes];
|
||||
|
||||
$h.each(domNodes, function(domNode) {
|
||||
domNode.addEventListener('dragover', preventDefault, false);
|
||||
domNode.addEventListener('dragenter', preventDefault, false);
|
||||
domNode.addEventListener('dragover', onDragOverEnter, false);
|
||||
domNode.addEventListener('dragenter', onDragOverEnter, false);
|
||||
domNode.addEventListener('dragleave', onDragLeave, false);
|
||||
domNode.addEventListener('drop', onDrop, false);
|
||||
});
|
||||
};
|
||||
@ -1016,8 +1063,9 @@
|
||||
if (typeof(domNodes.length) == 'undefined') domNodes = [domNodes];
|
||||
|
||||
$h.each(domNodes, function(domNode) {
|
||||
domNode.removeEventListener('dragover', preventDefault);
|
||||
domNode.removeEventListener('dragenter', preventDefault);
|
||||
domNode.removeEventListener('dragover', onDragOverEnter);
|
||||
domNode.removeEventListener('dragenter', onDragOverEnter);
|
||||
domNode.removeEventListener('dragleave', onDragLeave);
|
||||
domNode.removeEventListener('drop', onDrop);
|
||||
});
|
||||
};
|
||||
@ -1108,7 +1156,9 @@
|
||||
|
||||
// Node.js-style export for Node and Component
|
||||
if (typeof module != 'undefined') {
|
||||
// left here for backwards compatibility
|
||||
module.exports = Resumable;
|
||||
module.exports.Resumable = Resumable;
|
||||
} else if (typeof define === "function" && define.amd) {
|
||||
// AMD/requirejs: Define the module
|
||||
define(function(){
|
||||
|
Loading…
Reference in New Issue
Block a user