Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93

Warning: Undefined array key "page_file_edit_line" in /home/sportsfever/public_html/filemanger/edit_text_line.php on line 32
/home/sportsfe.../httpdocs/clone/wp-inclu.../js/plupload
File: plupload.js
* @static
[500] Fix | Delete
* @param {Object} obj DOM element to remove event listener(s) from.
[501] Fix | Delete
* @param {String} name Name of event listener to remove.
[502] Fix | Delete
* @param {Function|String} (optional) might be a callback or unique key to match.
[503] Fix | Delete
*/
[504] Fix | Delete
removeEvent: o.removeEvent,
[505] Fix | Delete
[506] Fix | Delete
/**
[507] Fix | Delete
* Remove all kind of events from the specified object
[508] Fix | Delete
*
[509] Fix | Delete
* @method removeAllEvents
[510] Fix | Delete
* @static
[511] Fix | Delete
* @param {Object} obj DOM element to remove event listeners from.
[512] Fix | Delete
* @param {String} (optional) unique key to match, when removing events.
[513] Fix | Delete
*/
[514] Fix | Delete
removeAllEvents: o.removeAllEvents,
[515] Fix | Delete
[516] Fix | Delete
/**
[517] Fix | Delete
* Cleans the specified name from national characters (diacritics). The result will be a name with only a-z, 0-9 and _.
[518] Fix | Delete
*
[519] Fix | Delete
* @method cleanName
[520] Fix | Delete
* @static
[521] Fix | Delete
* @param {String} s String to clean up.
[522] Fix | Delete
* @return {String} Cleaned string.
[523] Fix | Delete
*/
[524] Fix | Delete
cleanName : function(name) {
[525] Fix | Delete
var i, lookup;
[526] Fix | Delete
[527] Fix | Delete
// Replace diacritics
[528] Fix | Delete
lookup = [
[529] Fix | Delete
/[\300-\306]/g, 'A', /[\340-\346]/g, 'a',
[530] Fix | Delete
/\307/g, 'C', /\347/g, 'c',
[531] Fix | Delete
/[\310-\313]/g, 'E', /[\350-\353]/g, 'e',
[532] Fix | Delete
/[\314-\317]/g, 'I', /[\354-\357]/g, 'i',
[533] Fix | Delete
/\321/g, 'N', /\361/g, 'n',
[534] Fix | Delete
/[\322-\330]/g, 'O', /[\362-\370]/g, 'o',
[535] Fix | Delete
/[\331-\334]/g, 'U', /[\371-\374]/g, 'u'
[536] Fix | Delete
];
[537] Fix | Delete
[538] Fix | Delete
for (i = 0; i < lookup.length; i += 2) {
[539] Fix | Delete
name = name.replace(lookup[i], lookup[i + 1]);
[540] Fix | Delete
}
[541] Fix | Delete
[542] Fix | Delete
// Replace whitespace
[543] Fix | Delete
name = name.replace(/\s+/g, '_');
[544] Fix | Delete
[545] Fix | Delete
// Remove anything else
[546] Fix | Delete
name = name.replace(/[^a-z0-9_\-\.]+/gi, '');
[547] Fix | Delete
[548] Fix | Delete
return name;
[549] Fix | Delete
},
[550] Fix | Delete
[551] Fix | Delete
/**
[552] Fix | Delete
* Builds a full url out of a base URL and an object with items to append as query string items.
[553] Fix | Delete
*
[554] Fix | Delete
* @method buildUrl
[555] Fix | Delete
* @static
[556] Fix | Delete
* @param {String} url Base URL to append query string items to.
[557] Fix | Delete
* @param {Object} items Name/value object to serialize as a querystring.
[558] Fix | Delete
* @return {String} String with url + serialized query string items.
[559] Fix | Delete
*/
[560] Fix | Delete
buildUrl : function(url, items) {
[561] Fix | Delete
var query = '';
[562] Fix | Delete
[563] Fix | Delete
plupload.each(items, function(value, name) {
[564] Fix | Delete
query += (query ? '&' : '') + encodeURIComponent(name) + '=' + encodeURIComponent(value);
[565] Fix | Delete
});
[566] Fix | Delete
[567] Fix | Delete
if (query) {
[568] Fix | Delete
url += (url.indexOf('?') > 0 ? '&' : '?') + query;
[569] Fix | Delete
}
[570] Fix | Delete
[571] Fix | Delete
return url;
[572] Fix | Delete
},
[573] Fix | Delete
[574] Fix | Delete
/**
[575] Fix | Delete
* Formats the specified number as a size string for example 1024 becomes 1 KB.
[576] Fix | Delete
*
[577] Fix | Delete
* @method formatSize
[578] Fix | Delete
* @static
[579] Fix | Delete
* @param {Number} size Size to format as string.
[580] Fix | Delete
* @return {String} Formatted size string.
[581] Fix | Delete
*/
[582] Fix | Delete
formatSize : function(size) {
[583] Fix | Delete
[584] Fix | Delete
if (size === undef || /\D/.test(size)) {
[585] Fix | Delete
return plupload.translate('N/A');
[586] Fix | Delete
}
[587] Fix | Delete
[588] Fix | Delete
function round(num, precision) {
[589] Fix | Delete
return Math.round(num * Math.pow(10, precision)) / Math.pow(10, precision);
[590] Fix | Delete
}
[591] Fix | Delete
[592] Fix | Delete
var boundary = Math.pow(1024, 4);
[593] Fix | Delete
[594] Fix | Delete
// TB
[595] Fix | Delete
if (size > boundary) {
[596] Fix | Delete
return round(size / boundary, 1) + " " + plupload.translate('tb');
[597] Fix | Delete
}
[598] Fix | Delete
[599] Fix | Delete
// GB
[600] Fix | Delete
if (size > (boundary/=1024)) {
[601] Fix | Delete
return round(size / boundary, 1) + " " + plupload.translate('gb');
[602] Fix | Delete
}
[603] Fix | Delete
[604] Fix | Delete
// MB
[605] Fix | Delete
if (size > (boundary/=1024)) {
[606] Fix | Delete
return round(size / boundary, 1) + " " + plupload.translate('mb');
[607] Fix | Delete
}
[608] Fix | Delete
[609] Fix | Delete
// KB
[610] Fix | Delete
if (size > 1024) {
[611] Fix | Delete
return Math.round(size / 1024) + " " + plupload.translate('kb');
[612] Fix | Delete
}
[613] Fix | Delete
[614] Fix | Delete
return size + " " + plupload.translate('b');
[615] Fix | Delete
},
[616] Fix | Delete
[617] Fix | Delete
[618] Fix | Delete
/**
[619] Fix | Delete
* Parses the specified size string into a byte value. For example 10kb becomes 10240.
[620] Fix | Delete
*
[621] Fix | Delete
* @method parseSize
[622] Fix | Delete
* @static
[623] Fix | Delete
* @param {String|Number} size String to parse or number to just pass through.
[624] Fix | Delete
* @return {Number} Size in bytes.
[625] Fix | Delete
*/
[626] Fix | Delete
parseSize : o.parseSizeStr,
[627] Fix | Delete
[628] Fix | Delete
[629] Fix | Delete
/**
[630] Fix | Delete
* A way to predict what runtime will be choosen in the current environment with the
[631] Fix | Delete
* specified settings.
[632] Fix | Delete
*
[633] Fix | Delete
* @method predictRuntime
[634] Fix | Delete
* @static
[635] Fix | Delete
* @param {Object|String} config Plupload settings to check
[636] Fix | Delete
* @param {String} [runtimes] Comma-separated list of runtimes to check against
[637] Fix | Delete
* @return {String} Type of compatible runtime
[638] Fix | Delete
*/
[639] Fix | Delete
predictRuntime : function(config, runtimes) {
[640] Fix | Delete
var up, runtime;
[641] Fix | Delete
[642] Fix | Delete
up = new plupload.Uploader(config);
[643] Fix | Delete
runtime = o.Runtime.thatCan(up.getOption().required_features, runtimes || config.runtimes);
[644] Fix | Delete
up.destroy();
[645] Fix | Delete
return runtime;
[646] Fix | Delete
},
[647] Fix | Delete
[648] Fix | Delete
/**
[649] Fix | Delete
* Registers a filter that will be executed for each file added to the queue.
[650] Fix | Delete
* If callback returns false, file will not be added.
[651] Fix | Delete
*
[652] Fix | Delete
* Callback receives two arguments: a value for the filter as it was specified in settings.filters
[653] Fix | Delete
* and a file to be filtered. Callback is executed in the context of uploader instance.
[654] Fix | Delete
*
[655] Fix | Delete
* @method addFileFilter
[656] Fix | Delete
* @static
[657] Fix | Delete
* @param {String} name Name of the filter by which it can be referenced in settings.filters
[658] Fix | Delete
* @param {String} cb Callback - the actual routine that every added file must pass
[659] Fix | Delete
*/
[660] Fix | Delete
addFileFilter: function(name, cb) {
[661] Fix | Delete
fileFilters[name] = cb;
[662] Fix | Delete
}
[663] Fix | Delete
};
[664] Fix | Delete
[665] Fix | Delete
[666] Fix | Delete
plupload.addFileFilter('mime_types', function(filters, file, cb) {
[667] Fix | Delete
if (filters.length && !filters.regexp.test(file.name)) {
[668] Fix | Delete
this.trigger('Error', {
[669] Fix | Delete
code : plupload.FILE_EXTENSION_ERROR,
[670] Fix | Delete
message : plupload.translate('File extension error.'),
[671] Fix | Delete
file : file
[672] Fix | Delete
});
[673] Fix | Delete
cb(false);
[674] Fix | Delete
} else {
[675] Fix | Delete
cb(true);
[676] Fix | Delete
}
[677] Fix | Delete
});
[678] Fix | Delete
[679] Fix | Delete
[680] Fix | Delete
plupload.addFileFilter('max_file_size', function(maxSize, file, cb) {
[681] Fix | Delete
var undef;
[682] Fix | Delete
[683] Fix | Delete
maxSize = plupload.parseSize(maxSize);
[684] Fix | Delete
[685] Fix | Delete
// Invalid file size
[686] Fix | Delete
if (file.size !== undef && maxSize && file.size > maxSize) {
[687] Fix | Delete
this.trigger('Error', {
[688] Fix | Delete
code : plupload.FILE_SIZE_ERROR,
[689] Fix | Delete
message : plupload.translate('File size error.'),
[690] Fix | Delete
file : file
[691] Fix | Delete
});
[692] Fix | Delete
cb(false);
[693] Fix | Delete
} else {
[694] Fix | Delete
cb(true);
[695] Fix | Delete
}
[696] Fix | Delete
});
[697] Fix | Delete
[698] Fix | Delete
[699] Fix | Delete
plupload.addFileFilter('prevent_duplicates', function(value, file, cb) {
[700] Fix | Delete
if (value) {
[701] Fix | Delete
var ii = this.files.length;
[702] Fix | Delete
while (ii--) {
[703] Fix | Delete
// Compare by name and size (size might be 0 or undefined, but still equivalent for both)
[704] Fix | Delete
if (file.name === this.files[ii].name && file.size === this.files[ii].size) {
[705] Fix | Delete
this.trigger('Error', {
[706] Fix | Delete
code : plupload.FILE_DUPLICATE_ERROR,
[707] Fix | Delete
message : plupload.translate('Duplicate file error.'),
[708] Fix | Delete
file : file
[709] Fix | Delete
});
[710] Fix | Delete
cb(false);
[711] Fix | Delete
return;
[712] Fix | Delete
}
[713] Fix | Delete
}
[714] Fix | Delete
}
[715] Fix | Delete
cb(true);
[716] Fix | Delete
});
[717] Fix | Delete
[718] Fix | Delete
[719] Fix | Delete
/**
[720] Fix | Delete
@class Uploader
[721] Fix | Delete
@constructor
[722] Fix | Delete
[723] Fix | Delete
@param {Object} settings For detailed information about each option check documentation.
[724] Fix | Delete
@param {String|DOMElement} settings.browse_button id of the DOM element or DOM element itself to use as file dialog trigger.
[725] Fix | Delete
@param {String} settings.url URL of the server-side upload handler.
[726] Fix | Delete
@param {Number|String} [settings.chunk_size=0] Chunk size in bytes to slice the file into. Shorcuts with b, kb, mb, gb, tb suffixes also supported. `e.g. 204800 or "204800b" or "200kb"`. By default - disabled.
[727] Fix | Delete
@param {Boolean} [settings.send_chunk_number=true] Whether to send chunks and chunk numbers, or total and offset bytes.
[728] Fix | Delete
@param {String|DOMElement} [settings.container] id of the DOM element or DOM element itself that will be used to wrap uploader structures. Defaults to immediate parent of the `browse_button` element.
[729] Fix | Delete
@param {String|DOMElement} [settings.drop_element] id of the DOM element or DOM element itself to use as a drop zone for Drag-n-Drop.
[730] Fix | Delete
@param {String} [settings.file_data_name="file"] Name for the file field in Multipart formated message.
[731] Fix | Delete
@param {Object} [settings.filters={}] Set of file type filters.
[732] Fix | Delete
@param {Array} [settings.filters.mime_types=[]] List of file types to accept, each one defined by title and list of extensions. `e.g. {title : "Image files", extensions : "jpg,jpeg,gif,png"}`. Dispatches `plupload.FILE_EXTENSION_ERROR`
[733] Fix | Delete
@param {String|Number} [settings.filters.max_file_size=0] Maximum file size that the user can pick, in bytes. Optionally supports b, kb, mb, gb, tb suffixes. `e.g. "10mb" or "1gb"`. By default - not set. Dispatches `plupload.FILE_SIZE_ERROR`.
[734] Fix | Delete
@param {Boolean} [settings.filters.prevent_duplicates=false] Do not let duplicates into the queue. Dispatches `plupload.FILE_DUPLICATE_ERROR`.
[735] Fix | Delete
@param {String} [settings.flash_swf_url] URL of the Flash swf. (Not used in WordPress)
[736] Fix | Delete
@param {Object} [settings.headers] Custom headers to send with the upload. Hash of name/value pairs.
[737] Fix | Delete
@param {Number} [settings.max_retries=0] How many times to retry the chunk or file, before triggering Error event.
[738] Fix | Delete
@param {Boolean} [settings.multipart=true] Whether to send file and additional parameters as Multipart formated message.
[739] Fix | Delete
@param {Object} [settings.multipart_params] Hash of key/value pairs to send with every file upload.
[740] Fix | Delete
@param {Boolean} [settings.multi_selection=true] Enable ability to select multiple files at once in file dialog.
[741] Fix | Delete
@param {String|Object} [settings.required_features] Either comma-separated list or hash of required features that chosen runtime should absolutely possess.
[742] Fix | Delete
@param {Object} [settings.resize] Enable resizng of images on client-side. Applies to `image/jpeg` and `image/png` only. `e.g. {width : 200, height : 200, quality : 90, crop: true}`
[743] Fix | Delete
@param {Number} [settings.resize.width] If image is bigger, it will be resized.
[744] Fix | Delete
@param {Number} [settings.resize.height] If image is bigger, it will be resized.
[745] Fix | Delete
@param {Number} [settings.resize.quality=90] Compression quality for jpegs (1-100).
[746] Fix | Delete
@param {Boolean} [settings.resize.crop=false] Whether to crop images to exact dimensions. By default they will be resized proportionally.
[747] Fix | Delete
@param {String} [settings.runtimes="html5,html4"] Comma separated list of runtimes, that Plupload will try in turn, moving to the next if previous fails.
[748] Fix | Delete
@param {String} [settings.silverlight_xap_url] URL of the Silverlight xap. (Not used in WordPress)
[749] Fix | Delete
@param {Boolean} [settings.unique_names=false] If true will generate unique filenames for uploaded files.
[750] Fix | Delete
@param {Boolean} [settings.send_file_name=true] Whether to send file name as additional argument - 'name' (required for chunked uploads and some other cases where file name cannot be sent via normal ways).
[751] Fix | Delete
*/
[752] Fix | Delete
plupload.Uploader = function(options) {
[753] Fix | Delete
/**
[754] Fix | Delete
Fires when the current RunTime has been initialized.
[755] Fix | Delete
[756] Fix | Delete
@event Init
[757] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[758] Fix | Delete
*/
[759] Fix | Delete
[760] Fix | Delete
/**
[761] Fix | Delete
Fires after the init event incase you need to perform actions there.
[762] Fix | Delete
[763] Fix | Delete
@event PostInit
[764] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[765] Fix | Delete
*/
[766] Fix | Delete
[767] Fix | Delete
/**
[768] Fix | Delete
Fires when the option is changed in via uploader.setOption().
[769] Fix | Delete
[770] Fix | Delete
@event OptionChanged
[771] Fix | Delete
@since 2.1
[772] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[773] Fix | Delete
@param {String} name Name of the option that was changed
[774] Fix | Delete
@param {Mixed} value New value for the specified option
[775] Fix | Delete
@param {Mixed} oldValue Previous value of the option
[776] Fix | Delete
*/
[777] Fix | Delete
[778] Fix | Delete
/**
[779] Fix | Delete
Fires when the silverlight/flash or other shim needs to move.
[780] Fix | Delete
[781] Fix | Delete
@event Refresh
[782] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[783] Fix | Delete
*/
[784] Fix | Delete
[785] Fix | Delete
/**
[786] Fix | Delete
Fires when the overall state is being changed for the upload queue.
[787] Fix | Delete
[788] Fix | Delete
@event StateChanged
[789] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[790] Fix | Delete
*/
[791] Fix | Delete
[792] Fix | Delete
/**
[793] Fix | Delete
Fires when browse_button is clicked and browse dialog shows.
[794] Fix | Delete
[795] Fix | Delete
@event Browse
[796] Fix | Delete
@since 2.1.2
[797] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[798] Fix | Delete
*/
[799] Fix | Delete
[800] Fix | Delete
/**
[801] Fix | Delete
Fires for every filtered file before it is added to the queue.
[802] Fix | Delete
[803] Fix | Delete
@event FileFiltered
[804] Fix | Delete
@since 2.1
[805] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[806] Fix | Delete
@param {plupload.File} file Another file that has to be added to the queue.
[807] Fix | Delete
*/
[808] Fix | Delete
[809] Fix | Delete
/**
[810] Fix | Delete
Fires when the file queue is changed. In other words when files are added/removed to the files array of the uploader instance.
[811] Fix | Delete
[812] Fix | Delete
@event QueueChanged
[813] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[814] Fix | Delete
*/
[815] Fix | Delete
[816] Fix | Delete
/**
[817] Fix | Delete
Fires after files were filtered and added to the queue.
[818] Fix | Delete
[819] Fix | Delete
@event FilesAdded
[820] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[821] Fix | Delete
@param {Array} files Array of file objects that were added to queue by the user.
[822] Fix | Delete
*/
[823] Fix | Delete
[824] Fix | Delete
/**
[825] Fix | Delete
Fires when file is removed from the queue.
[826] Fix | Delete
[827] Fix | Delete
@event FilesRemoved
[828] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[829] Fix | Delete
@param {Array} files Array of files that got removed.
[830] Fix | Delete
*/
[831] Fix | Delete
[832] Fix | Delete
/**
[833] Fix | Delete
Fires just before a file is uploaded. Can be used to cancel the upload for the specified file
[834] Fix | Delete
by returning false from the handler.
[835] Fix | Delete
[836] Fix | Delete
@event BeforeUpload
[837] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[838] Fix | Delete
@param {plupload.File} file File to be uploaded.
[839] Fix | Delete
*/
[840] Fix | Delete
[841] Fix | Delete
/**
[842] Fix | Delete
Fires when a file is to be uploaded by the runtime.
[843] Fix | Delete
[844] Fix | Delete
@event UploadFile
[845] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[846] Fix | Delete
@param {plupload.File} file File to be uploaded.
[847] Fix | Delete
*/
[848] Fix | Delete
[849] Fix | Delete
/**
[850] Fix | Delete
Fires while a file is being uploaded. Use this event to update the current file upload progress.
[851] Fix | Delete
[852] Fix | Delete
@event UploadProgress
[853] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[854] Fix | Delete
@param {plupload.File} file File that is currently being uploaded.
[855] Fix | Delete
*/
[856] Fix | Delete
[857] Fix | Delete
/**
[858] Fix | Delete
Fires when file chunk is uploaded.
[859] Fix | Delete
[860] Fix | Delete
@event ChunkUploaded
[861] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[862] Fix | Delete
@param {plupload.File} file File that the chunk was uploaded for.
[863] Fix | Delete
@param {Object} result Object with response properties.
[864] Fix | Delete
@param {Number} result.offset The amount of bytes the server has received so far, including this chunk.
[865] Fix | Delete
@param {Number} result.total The size of the file.
[866] Fix | Delete
@param {String} result.response The response body sent by the server.
[867] Fix | Delete
@param {Number} result.status The HTTP status code sent by the server.
[868] Fix | Delete
@param {String} result.responseHeaders All the response headers as a single string.
[869] Fix | Delete
*/
[870] Fix | Delete
[871] Fix | Delete
/**
[872] Fix | Delete
Fires when a file is successfully uploaded.
[873] Fix | Delete
[874] Fix | Delete
@event FileUploaded
[875] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[876] Fix | Delete
@param {plupload.File} file File that was uploaded.
[877] Fix | Delete
@param {Object} result Object with response properties.
[878] Fix | Delete
@param {String} result.response The response body sent by the server.
[879] Fix | Delete
@param {Number} result.status The HTTP status code sent by the server.
[880] Fix | Delete
@param {String} result.responseHeaders All the response headers as a single string.
[881] Fix | Delete
*/
[882] Fix | Delete
[883] Fix | Delete
/**
[884] Fix | Delete
Fires when all files in a queue are uploaded.
[885] Fix | Delete
[886] Fix | Delete
@event UploadComplete
[887] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[888] Fix | Delete
@param {Array} files Array of file objects that was added to queue/selected by the user.
[889] Fix | Delete
*/
[890] Fix | Delete
[891] Fix | Delete
/**
[892] Fix | Delete
Fires when a error occurs.
[893] Fix | Delete
[894] Fix | Delete
@event Error
[895] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[896] Fix | Delete
@param {Object} error Contains code, message and sometimes file and other details.
[897] Fix | Delete
@param {Number} error.code The plupload error code.
[898] Fix | Delete
@param {String} error.message Description of the error (uses i18n).
[899] Fix | Delete
*/
[900] Fix | Delete
[901] Fix | Delete
/**
[902] Fix | Delete
Fires when destroy method is called.
[903] Fix | Delete
[904] Fix | Delete
@event Destroy
[905] Fix | Delete
@param {plupload.Uploader} uploader Uploader instance sending the event.
[906] Fix | Delete
*/
[907] Fix | Delete
var uid = plupload.guid()
[908] Fix | Delete
, settings
[909] Fix | Delete
, files = []
[910] Fix | Delete
, preferred_caps = {}
[911] Fix | Delete
, fileInputs = []
[912] Fix | Delete
, fileDrops = []
[913] Fix | Delete
, startTime
[914] Fix | Delete
, total
[915] Fix | Delete
, disabled = false
[916] Fix | Delete
, xhr
[917] Fix | Delete
;
[918] Fix | Delete
[919] Fix | Delete
[920] Fix | Delete
// Private methods
[921] Fix | Delete
function uploadNext() {
[922] Fix | Delete
var file, count = 0, i;
[923] Fix | Delete
[924] Fix | Delete
if (this.state == plupload.STARTED) {
[925] Fix | Delete
// Find first QUEUED file
[926] Fix | Delete
for (i = 0; i < files.length; i++) {
[927] Fix | Delete
if (!file && files[i].status == plupload.QUEUED) {
[928] Fix | Delete
file = files[i];
[929] Fix | Delete
if (this.trigger("BeforeUpload", file)) {
[930] Fix | Delete
file.status = plupload.UPLOADING;
[931] Fix | Delete
this.trigger("UploadFile", file);
[932] Fix | Delete
}
[933] Fix | Delete
} else {
[934] Fix | Delete
count++;
[935] Fix | Delete
}
[936] Fix | Delete
}
[937] Fix | Delete
[938] Fix | Delete
// All files are DONE or FAILED
[939] Fix | Delete
if (count == files.length) {
[940] Fix | Delete
if (this.state !== plupload.STOPPED) {
[941] Fix | Delete
this.state = plupload.STOPPED;
[942] Fix | Delete
this.trigger("StateChanged");
[943] Fix | Delete
}
[944] Fix | Delete
this.trigger("UploadComplete", files);
[945] Fix | Delete
}
[946] Fix | Delete
}
[947] Fix | Delete
}
[948] Fix | Delete
[949] Fix | Delete
[950] Fix | Delete
function calcFile(file) {
[951] Fix | Delete
file.percent = file.size > 0 ? Math.ceil(file.loaded / file.size * 100) : 100;
[952] Fix | Delete
calc();
[953] Fix | Delete
}
[954] Fix | Delete
[955] Fix | Delete
[956] Fix | Delete
function calc() {
[957] Fix | Delete
var i, file;
[958] Fix | Delete
[959] Fix | Delete
// Reset stats
[960] Fix | Delete
total.reset();
[961] Fix | Delete
[962] Fix | Delete
// Check status, size, loaded etc on all files
[963] Fix | Delete
for (i = 0; i < files.length; i++) {
[964] Fix | Delete
file = files[i];
[965] Fix | Delete
[966] Fix | Delete
if (file.size !== undef) {
[967] Fix | Delete
// We calculate totals based on original file size
[968] Fix | Delete
total.size += file.origSize;
[969] Fix | Delete
[970] Fix | Delete
// Since we cannot predict file size after resize, we do opposite and
[971] Fix | Delete
// interpolate loaded amount to match magnitude of total
[972] Fix | Delete
total.loaded += file.loaded * file.origSize / file.size;
[973] Fix | Delete
} else {
[974] Fix | Delete
total.size = undef;
[975] Fix | Delete
}
[976] Fix | Delete
[977] Fix | Delete
if (file.status == plupload.DONE) {
[978] Fix | Delete
total.uploaded++;
[979] Fix | Delete
} else if (file.status == plupload.FAILED) {
[980] Fix | Delete
total.failed++;
[981] Fix | Delete
} else {
[982] Fix | Delete
total.queued++;
[983] Fix | Delete
}
[984] Fix | Delete
}
[985] Fix | Delete
[986] Fix | Delete
// If we couldn't calculate a total file size then use the number of files to calc percent
[987] Fix | Delete
if (total.size === undef) {
[988] Fix | Delete
total.percent = files.length > 0 ? Math.ceil(total.uploaded / files.length * 100) : 0;
[989] Fix | Delete
} else {
[990] Fix | Delete
total.bytesPerSec = Math.ceil(total.loaded / ((+new Date() - startTime || 1) / 1000.0));
[991] Fix | Delete
total.percent = total.size > 0 ? Math.ceil(total.loaded / total.size * 100) : 0;
[992] Fix | Delete
}
[993] Fix | Delete
}
[994] Fix | Delete
[995] Fix | Delete
[996] Fix | Delete
function getRUID() {
[997] Fix | Delete
var ctrl = fileInputs[0] || fileDrops[0];
[998] Fix | Delete
if (ctrl) {
[999] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function