;(function($){

var $$;

$$ = $.fn.galleria = function($options) {

	if (!$$.hasCSS()) { return false; }

	$.historyInit($$.onPageLoad);

	var $defaults = {
		insert      : '.galleria_container',
		history     : true,
		clickNext   : true,
		onImage     : function(image,caption,thumb) {},
		onThumb     : function(thumb) {},
		onPrev		: function() {},
		onNext		: function() {},
		onPrevFast	: function() {},
		onNextFast	: function() {},
		preloads	: 3,
		fastSteps	: 3
	};
	var $opts = $.extend($defaults, $options);
	for (var i in $opts) {
		$.galleria[i]  = $opts[i];
	}
	var _insert = ($($opts.insert).is($opts.insert)) ? 
		$($opts.insert) : 
		jQuery(document.createElement('div')).insertBefore(this);
	var _div = $(document.createElement('div')).addClass('galleria_wrapper');
	var _span = $(document.createElement('span')).addClass('caption');
	_insert.addClass('galleria_container').append(_div).append(_span);
	return this.each(function(){
		$(this).addClass('galleria');
		$(this).children('li').each(function(i) {
			var _container = $(this);
			var _o = $.meta ? $.extend({}, $opts, _container.data()) : $opts;
			_o.clickNext = $(this).is(':only-child') ? false : _o.clickNext;
			var _a = $(this).find('a');
			var _img = $(this).children('img').css('display','none');
			
			// extract the original source
			var _src = _a.attr('href');
			
			// Added for faster loads
			if (i < _o.preloads) {
				$.galleria.queue.push(_src);
			}
			
			// find a title
			var _title = _a.attr('title');

			// check url and activate container if match
			if (_o.history && (window.location.hash && window.location.hash.replace(/\#/,'') == _src)) {
				_container.siblings('.active').removeClass('active');
				_container.addClass('active');
			}
			
			var _thumb = _a.find('img').addClass('thumb').css('display','none');
			_thumb.relToData();
			_a.replaceWith(_thumb);
			
			// center thumbnails.
			_thumb.css({
				marginLeft: (_thumb.width > 0 ? (-( _thumb.width() - _container.width() )/2) : 0), 
				marginTop: (_thumb.height > 0 ? (-( _thumb.height() - _container.height() )/2) : 0) 
			});
			
			// add the rel attribute
			_thumb.attr('rel',_src);
			
			// add the title attribute
			_thumb.attr('title',_title);
			
			// add the click functionality to the _thumb
			_thumb.click(function() {
				$.galleria.activate(_src);
			});
			_thumb.hover(
				function() { $(this).addClass('hover'); },
				function() { $(this).removeClass('hover'); }
			);
			_container.hover(
				function() { _container.addClass('hover'); },
				function() { _container.removeClass('hover'); }
			);
			_container.prepend(_thumb);
			_thumb.css('display','block');
			_o.onThumb(jQuery(_thumb));
			if (_container.hasClass('active')) {
				$.galleria.activate(_src);
			}
			_img.remove();								
		});
		
		// Added for faster loading. Init loading.
		var _first = $.galleria.nextInQueue();
		if (_first != null) {
			$.galleria.preload(_first);
		}
	});
};
$$.nextSelector = function(selector) {
	return $(selector).is(':last-child') ?
		   $(selector).siblings(':first-child') :
    	   $(selector).next();
    	   
};

$$.previousSelector = function(selector) {
	return $(selector).is(':first-child') ?
		   $(selector).siblings(':last-child') :
    	   $(selector).prev();
    	   
};

$$.stepSelector = function(selector, steps) {
	var _s = $(selector).parent().find('> li');
	var _i = _s.index(selector) + steps;
	var _l = _s.length;
	if (_i > (_l - 1)) {
		_i -= _l;
	} else if (_i < 0) {
		_i += _l;	
	}
	return $(selector).parent().find(':nth-child(' + (_i + 1) + ')');
};
$$.hasCSS = function()  {
	$('body').append(
		$(document.createElement('div')).attr('id','css_test')
		.css({ width:'1px', height:'1px', display:'none' })
	);
	var _v = ($('#css_test').width() != 1) ? false : true;
	$('#css_test').remove();
	return _v;
};

$$.onPageLoad = function(_src) {	

	var _wrapper = $('.galleria_wrapper');

	var _thumb = $('.galleria img[rel="'+_src+'"]');
	
	if (_src) {
		
		if ($.galleria.history) {
			window.location = window.location.href.replace(/\#.*/,'') + '#' + _src;
		}
		_thumb.parents('li').siblings('.active').removeClass('active');
		_thumb.parents('li').addClass('active');
	
		// define a new image
		// Modified for faster loads
		var _loader = $.galleria.loader;
		if (!$.galleria.isLoaded(_src) && _loader != null) {
			var _width = _thumb.data('width');
			var _height = _thumb.data('height');
			_wrapper.empty().append(_loader.css({ 
				'width' : _width + 'px',
				'height' : _height + 'px',
				'display' : 'none' }).fadeIn('fast'));
			_loader.children('img').css('marginTop', (_height/3) + 'px');
			_wrapper.siblings('.caption').empty();
			_wrapper.parent().siblings().hide();
		}
		var _img = $.galleria.loadImage(_src, function() {
			// empty the wrapper and insert the new image
			_wrapper.empty().append($(this));
	
			// insert the caption
			// Modified to allow html in captions
			_wrapper.siblings('.caption').html(_thumb.attr('title'));
			
			// fire the onImage function to customize the loaded image's features
			$.galleria.onImage($(this),_wrapper.siblings('.caption'),_thumb);
			
			// add clickable image helper
			if($.galleria.clickNext) {
				$(this).css('cursor','pointer').click(function() { $.galleria.next(); })
			}
			
			// Added to deal with weird resize bug in IE
			$(this).removeAttr('width');
			$(this).removeAttr('height');		
		}).addClass('replaced');
	} else {
		
		// clean up the container if none are active
		_wrapper.siblings().andSelf().empty();
		
		// remove active classes
		$('.galleria li.active').removeClass('active');
	}

	// place the source in the galleria.current variable
	$.galleria.current = _src;
};

$.extend({galleria : {
	current : '',
	onImage : function(){},
	activate : function(_src) { 
		if ($.galleria.history) {
			$.historyLoad(_src);
		} else {
			$$.onPageLoad(_src);
		}
	},
	// Added to enable fast stepping
	getByStepping : function(steps) {
		return $($$.stepSelector($('.galleria img[rel="'+$.galleria.current+'"]').parents('li'), steps)).find('img').attr('rel');
	},
	// Added for faster loads
	getNext : function() {
		return $($$.nextSelector($('.galleria img[rel="'+$.galleria.current+'"]').parents('li'))).find('img').attr('rel');
	},
	// Added to enable fast stepping
	nextFast : function() {
		if (!$.galleria.stopped) {
			$.galleria.activate($.galleria.getByStepping($.galleria.fastSteps));
			$.galleria.onNextFast();
		}
	},
	next : function() {		
		// Added to keep thumbnail scroller in sync with main image		
		if (!$.galleria.stopped) {
		
			// Modified to work with latest version of jQuery
			$.galleria.activate($.galleria.getNext());
			
			// Added additional callback
			$.galleria.onNext();
			
			// Added additional preloads
			var _next = $.galleria.getNext();
			if (!$.galleria.isLoaded(_next) && !$.galleria.isQueued(_next)) {
				$.galleria.queue.push(_next)
			}
			if ($.galleria.queue.length > 0) {
				$.galleria.preload($.galleria.nextInQueue());
			}
		}
	},
	getPrev : function() {
		return $($$.previousSelector($('.galleria img[rel="'+$.galleria.current+'"]').parents('li'))).find('img').attr('rel');
	},
	// Added to enable fast stepping
	prevFast : function() {
		if (!$.galleria.stopped) {
			$.galleria.activate($.galleria.getByStepping(-$.galleria.fastSteps));
			$.galleria.onPrevFast();
		}
	},
	prev : function() {
		// Added to keep thumbnail scroller in sync with main image				
		if (!$.galleria.stopped) {
		
			// Modified to work with latest version of jQuery
			$.galleria.activate($.galleria.getPrev());
			
			// Added additional callback
			$.galleria.onPrev();
			
			// Added additional preloads
			var _prev = $.galleria.getPrev();
			if (!$.galleria.isLoaded(_prev) && !$.galleria.isQueued(_prev)) {
				$.galleria.queue.push(_prev)
			}
			if ($.galleria.queue.length > 0) {
				$.galleria.preload($.galleria.nextInQueue());
			}
		}
	},	
	queue : new Array(),
	loaded : new Array(),
	isQueued : function(_src) {
		return $.inArray(_src, $.galleria.queue) > -1;	
	},
	isLoaded : function(_src) {
		return $.inArray(_src, $.galleria.loaded) > -1;
	},
	nextInQueue : function() {
		if ($.galleria.queue.length > 0) {
			var _next = $.galleria.queue.shift();
			if ($.galleria.isLoaded(_next)) {
				return $.galleria.nextInQueue();
			}
			return _next;
		}
		return null;
	},
	preload : function(_src) {
		return $.galleria.loadImage(_src, function() {				
			if ($.galleria.queue.length > 0) {
				var _next = $.galleria.nextInQueue();
				if (_next != null) {
					$.galleria.preload(_next);
				}
			}
		});
	},
	loadImage : function(_src, _onLoad) {
		$.galleria.loaded.push(_src);
		var _img = $(new Image());
		if (typeof _onLoad == 'function') {
			_img.load(_onLoad);
		}
		return _img.attr('src',_src);
	}, 
	// Added to keep thumbnail scroller in sync with main image	
	stopped : false,
	start : function() {
		$.galleria.stopped = false;
	},
	stop : function() {
		$.galleria.stopped = true;
	},
	loader : null
}
});

})(jQuery);
(function($) {
	$.fn.relToData = function() {
		var rel = this.attr('rel');
		var arr = rel.split(';;');	
		for (var i = 0; i < arr.length; i++) {
			var len = arr[i].length;
			if (len > 2) {
				var cIndex = arr[i].indexOf(':');
				if (cIndex > 0 && cIndex < len-2) {
					var key = arr[i].substring(0, cIndex);
					var val = arr[i].substring(cIndex+1, len);		
					this.data(key, val);
				}
			}
		}
	}
})(jQuery);
jQuery.extend({historyCurrentHash:undefined,historyCallback:undefined,historyInit:function(callback){jQuery.historyCallback=callback;var current_hash=location.hash;jQuery.historyCurrentHash=current_hash;if(jQuery.browser.msie){if(jQuery.historyCurrentHash==''){jQuery.historyCurrentHash='#'}$("body").prepend('<iframe id="jQuery_history" style="display: none;"></iframe>');var ihistory=$("#jQuery_history")[0];var iframe=ihistory.contentWindow.document;iframe.open();iframe.close();iframe.location.hash=current_hash}else if($.browser.safari){jQuery.historyBackStack=[];jQuery.historyBackStack.length=history.length;jQuery.historyForwardStack=[];jQuery.isFirst=true}jQuery.historyCallback(current_hash.replace(/^#/,''));setInterval(jQuery.historyCheck,100)},historyAddHistory:function(hash){jQuery.historyBackStack.push(hash);jQuery.historyForwardStack.length=0;this.isFirst=true},historyCheck:function(){if(jQuery.browser.msie){var ihistory=$("#jQuery_history")[0];var iframe=ihistory.contentDocument||ihistory.contentWindow.document;var current_hash=iframe.location.hash;if(current_hash!=jQuery.historyCurrentHash){location.hash=current_hash;jQuery.historyCurrentHash=current_hash;jQuery.historyCallback(current_hash.replace(/^#/,''))}}else if($.browser.safari){if(!jQuery.dontCheck){var historyDelta=history.length-jQuery.historyBackStack.length;if(historyDelta){jQuery.isFirst=false;if(historyDelta<0){for(var i=0;i<Math.abs(historyDelta);i++)jQuery.historyForwardStack.unshift(jQuery.historyBackStack.pop())}else{for(var i=0;i<historyDelta;i++)jQuery.historyBackStack.push(jQuery.historyForwardStack.shift())}var cachedHash=jQuery.historyBackStack[jQuery.historyBackStack.length-1];if(cachedHash!=undefined){jQuery.historyCurrentHash=location.hash;jQuery.historyCallback(cachedHash)}}else if(jQuery.historyBackStack[jQuery.historyBackStack.length-1]==undefined&&!jQuery.isFirst){if(document.URL.indexOf('#')>=0){jQuery.historyCallback(document.URL.split('#')[1])}else{var current_hash=location.hash;jQuery.historyCallback('')}jQuery.isFirst=true}}}else{var current_hash=location.hash;if(current_hash!=jQuery.historyCurrentHash){jQuery.historyCurrentHash=current_hash;jQuery.historyCallback(current_hash.replace(/^#/,''))}}},historyLoad:function(hash){var newhash;if(jQuery.browser.safari){newhash=hash}else{newhash='#'+hash;location.hash=newhash}jQuery.historyCurrentHash=newhash;if(jQuery.browser.msie){var ihistory=$("#jQuery_history")[0];var iframe=ihistory.contentWindow.document;iframe.open();iframe.close();iframe.location.hash=newhash;jQuery.historyCallback(hash)}else if(jQuery.browser.safari){jQuery.dontCheck=true;this.historyAddHistory(hash);var fn=function(){jQuery.dontCheck=false};window.setTimeout(fn,200);jQuery.historyCallback(hash);location.hash=newhash}else{jQuery.historyCallback(hash)}}});

