File Manager
/**
* jQuery 'onImagesLoaded' plugin v1.2.0 (Updated December 1, 2011)
* Fires callback functions when images have loaded within a particular selector.
*
* Copyright (c) Cirkuit Networks, Inc. (http://www.cirkuit.net), 2008-2011.
* Dual licensed under the MIT and GPL licenses:
* http://www.opensource.org/licenses/mit-license.php
* http://www.gnu.org/licenses/gpl.html
*
* For documentation and usage, visit "http://www.cirkuit.net/projects/jquery/onImagesLoad/"
*/
(function($){
$.fn.onImagesLoad = function(options){
//version 1.2.0 - if 'options' parameter is a function, treat it as the "all" callback
if(typeof(options)=="function"){
options = {
all : options
};
}
//merge in default options
var self = this;
self.opts = $.extend({}, $.fn.onImagesLoad.defaults, options);
//reverse compatibility function names
//version 1.2.0 - renamed "selectorCallback" to "all"
if(self.opts.selectorCallback && !self.opts.all){
self.opts.all = self.opts.selectorCallback;
}
//version 1.2.0 - renamed "itemCallback" to "each"
if(self.opts.itemCallback && !self.opts.each){
self.opts.each = self.opts.itemCallback;
}
self.bindEvents = function($imgs, container, callback){
if ($imgs.length === 0){ //no images were in selection. callback based on options
if (self.opts.callbackIfNoImagesExist && callback){ callback(container); }
}
else {
var loadedImages = [];
if (!$imgs.jquery){ $imgs = $($imgs); }
$imgs.each(function(i){
//webkit fix inspiration thanks to bmsterling: http://plugins.jquery.com/node/10312
var orgSrc = this.src;
if (!$.browser.msie) {
this.src = ""; //ie will do funky things if this is here (show the image as an X, only show half of the image, etc)
}
$(this)
.bind('error', function() { // error handling added by Georg Busch
if(typeof self.opts.onError == 'function')
self.opts.onError(this);
else
$(this).load();
})
.bind('load', function(){
if (jQuery.inArray(i, loadedImages) < 0){ //don't double count images
loadedImages.push(i); //keep a record of images we've seen
if (loadedImages.length == $imgs.length){
if (callback){ callback.call(container, container); }
}
}
})
;
if (!$.browser.msie) {
this.src = orgSrc; //needed for potential cached images
}
else if (this.complete || this.complete === undefined){ this.src = orgSrc; }
});
}
};
var imgAry = []; //only used if self.opts.all exists
self.each(function(){
if (self.opts.each){
var $imgs;
if (this.tagName == "IMG"){ $imgs = this; } //is an image
else { $imgs = $('img', this); } //contains image(s)
self.bindEvents($imgs, this, self.opts.each);
}
if (self.opts.all){
if (this.tagName == "IMG"){ imgAry.push(this); } //is an image
else { //contains image(s)
$('img', this).each(function(){ imgAry.push(this); });
}
}
});
if (self.opts.all){ self.bindEvents(imgAry, this, self.opts.all); }
return self.each(function(){}); //dont break the chain
};
//DEFAULT OPTOINS
$.fn.onImagesLoad.defaults = {
onError: null, // error handling if image cannot be loaded; added by Georg Busch
all: null, //function - the function to invoke when all images that $(yourSelector) encapsultaes have loaded (invoked only once per selector. see documentation)
each: null, //function - the function to invoke when each item that $(yourSelector) encapsultaes has loaded (invoked one or more times depending on selector. see documentation)
callbackIfNoImagesExist: false //boolean - if true, the callbacks will be invoked even if no images exist within $(yourSelector).
// if false, the callbacks will not be invoked if no images exist within $(yourSelector).
};
})(jQuery);
File Manager Version 1.0, Coded By Lucas
Email: hehe@yahoo.com