/*
 * FancyBox - simple and fancy jQuery plugin
 * Examples and documentation at: http://fancy.klade.lv/
 * Version: 1.2.1 (13/03/2009)
 * Copyright (c) 2009 Janis Skarnelis
 * Licensed under the MIT License: http://en.wikipedia.org/wiki/MIT_License
 * Requires: jQuery v1.3+
*/
;(function($) {

	$.fn.fixPNG = function() {
		return this.each(function () {
			var image = $(this).css('backgroundImage');

			if (image.match(/^url\(["']?(.*\.png)["']?\)$/i)) {
				image = RegExp.$1;
				$(this).css({
					'backgroundImage': 'none',
					'filter': "progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true, sizingMethod=" + ($(this).css('backgroundRepeat') == 'no-repeat' ? 'crop' : 'scale') + ", src='" + image + "')"
				}).each(function () {
					var position = $(this).css('position');
					if (position != 'absolute' && position != 'relative')
						$(this).css('position', 'relative');
				});
			}
		});
	};
	var slideshow, slideshowstate, elem, opts, busy = false, imagePreloader = new Image, loadingTimer, loadingFrame = 1, imageRegExp = /\.(jpg|gif|png|bmp|jpeg)(.*)?$/i;
	var isIE = ($.browser.msie && parseInt($.browser.version.substr(0,1)) < 8);

	$.fn.fancybox = function(settings) {
		settings = $.extend({}, $.fn.fancybox.defaults, settings);
		var matchedGroup = this;

		function _initialize() {
			elem = this;
			opts = [];
			for(var k in settings) {
				opts[k] = settings[k];
			}


			_start();

			return false;
		};

		function _start() {
			if (busy) return;

			if ($.isFunction(opts.callbackOnStart)) {
				opts.callbackOnStart();
			}

			slideshowstate = false;

			if (slideshowstate) {
				$("#fancy_play").hide();

			} else {
				$("#fancy_stop").show();
			}

			opts.itemArray = [];
			opts.itemCurrent = 0;

			if (settings.itemArray.length > 0) {
				opts.itemArray = settings.itemArray;

				while ( opts.itemArray[ opts.itemCurrent ].href != elem.href ) {
					opts.itemCurrent++;
				}

			} else {

				var subGroup = $(matchedGroup);

				var item = {};

				for (var i = 0; i < subGroup.length; i++) {
					item = {href: subGroup[i].href, title: subGroup[i].title, desc: subGroup[i].desc};

					if ($(subGroup[i]).children("img:first").length) {
						item.orig = $(subGroup[i]).children("img:first");
					}

					opts.itemArray.push( item );
				}

				while ( opts.itemArray[ opts.itemCurrent ].href != elem.href ) {
					opts.itemCurrent++;
				}
			}

			if (opts.overlayShow) {
				if (isIE) {
					$('embed, object, select').css('visibility', 'hidden');
				}

				$("#fancy_overlay").css('opacity', opts.overlayOpacity).show();
			}

			_change_item();
			$("#fancy_close").show();
			if (slideshowstate) {
				$("#fancy_play").hide();
				$("#fancy_stop").show();
			} else {
				$("#fancy_play").show();
				$("#fancy_stop").hide();
			}
		};

		function _change_item() {
			$(document).unbind("keydown");
			$("#fancy_right, #fancy_left, #fancy_close, #fancy_title, #fancy_desc, #fancy_play, #fancy_stop").hide();

			var href = opts.itemArray[ opts.itemCurrent ].href;
			if (href.match(/#/)) {
				var target = window.location.href.split('#')[0]; target = href.replace(target, ''); target = target.substr(target.indexOf('#'));

				_set_content('<div id="fancy_div">' + $(target).html() + '</div>', opts.frameWidth, opts.frameHeight);

			} else if (href.match(imageRegExp)) {
				imagePreloader = new Image; imagePreloader.src = href;

				if (imagePreloader.complete) {
					_proceed_image();

				} else {
					$.fn.fancybox.showLoading();

					$(imagePreloader).unbind().bind('load', function() {
						$(".fancy_loading").hide();

						_proceed_image();
					});
				}

			 } else if (href.match("iframe") || elem.className.indexOf("iframe") >= 0) {
				_set_content('<iframe id="fancy_frame" onload="$.fn.fancybox.showIframe()" name="fancy_iframe' + Math.round(Math.random()*1000) + '" frameborder="0" hspace="0" src="' + href + '"></iframe>', opts.frameWidth, opts.frameHeight);

			} else {
				$.get(href, function(data) {
					_set_content( '<div id="fancy_ajax">' + data + '</div>', opts.frameWidth, opts.frameHeight );
				});
			}
		};

		function _proceed_image() {
		var descheight = 0;
			if (opts.imageScale) {
				var w = $.fn.fancybox.getViewport();

			if (opts.itemArray[ opts.itemCurrent ].desc !== undefined && opts.itemArray[ opts.itemCurrent ].desc.length > 0) {
				var descheight = 130;
			}

				var r = Math.min(Math.min(w[0] - 80, imagePreloader.width) / imagePreloader.width, Math.min(w[1] - 60 - descheight, imagePreloader.height) / imagePreloader.height);

				var width = Math.round(r * imagePreloader.width);
				var height = Math.round(r * imagePreloader.height);

			} else {
				var width = imagePreloader.width;
				var height = imagePreloader.height;
			}

			_set_content('<img alt="" id="fancy_img" src="' + imagePreloader.src + '" />', width, height);
		};

		function _preload_neighbor_images() {
			var href;

			if ((opts.itemArray.length -1) > opts.itemCurrent) {
				href = opts.itemArray[opts.itemCurrent + 1].href;
			} else {
				href = opts.itemArray[0].href;
			}

			if (href.match(imageRegExp)) {
				objNext = new Image();
				objNext.src = href;
			}

			if (opts.itemCurrent > 0) {
				href = opts.itemArray[opts.itemCurrent -1].href;
			} else {
				href = opts.itemArray[opts.itemArray.length - 1].href;
			}

			if (href.match(imageRegExp)) {
				objNext = new Image();
				objNext.src = href;
			}
		};

		function _set_content(value, width, height) {
			busy = true;

			var pad = opts.padding;

			if (isIE) {
				$("#fancy_content")[0].style.removeExpression("height");
				$("#fancy_content")[0].style.removeExpression("width");
			}

			if (pad > 0) {
				width	+= pad * 2;
				height	+= pad * 2;

				$("#fancy_content").css({
					'top'		: pad + 'px',
					'right'		: pad + 'px',
					'bottom'	: pad + 'px',
					'left'		: pad + 'px',
					'width'		: 'auto',
					'height'	: 'auto'
				});

				if (isIE) {
					$("#fancy_content")[0].style.setExpression('height',	'(this.parentNode.clientHeight - 20)');
					$("#fancy_content")[0].style.setExpression('width',		'(this.parentNode.clientWidth - 20)');
				}

			} else {
				$("#fancy_content").css({
					'top'		: 0,
					'right'		: 0,
					'bottom'	: 0,
					'left'		: 0,
					'width'		: '100%',
					'height'	: '100%'
				});
			}

			var w = $.fn.fancybox.getViewport();

			var itemLeft	= (width + 36)	> w[0] ? w[2] : (w[2] + Math.round((w[0] - width - 36) / 2));
			var itemTop		= (height + 50)	> w[1] ? w[3] : (w[3] + Math.round((w[1] - height - 50) / 2));

			if (opts.itemArray[ opts.itemCurrent ].desc !== undefined && opts.itemArray[ opts.itemCurrent ].desc.length > 0) {
				itemTop -= 40;
			}

			var itemOpts = {
				'left':		itemLeft,
				'top':		itemTop,
				'width':	width + 'px',
				'height':	height + 'px'
			};

			if ($("#fancy_outer").is(":visible")) {
				$("#fancy_bg").fadeOut("normal");
				$("#fancy_content").fadeOut("normal", function() {
					$("#fancy_content").empty();

					$("#fancy_outer").animate(itemOpts, opts.zoomSpeedChange, opts.easingChange, function() {
						$("#fancy_bg").fadeIn("normal");
						$("#fancy_content").append($(value)).fadeIn("normal", function() {
							_finish();
						});
					});
				});

			} else {

				if (opts.zoomSpeedIn > 0 && opts.itemArray[opts.itemCurrent].orig !== undefined) {
					$("#fancy_content").empty().append($(value));

					var orig_item	= opts.itemArray[opts.itemCurrent].orig;
					var orig_pos	= $.fn.fancybox.getPosition(orig_item);

					$("#fancy_outer").css({
						'left':		(orig_pos.left - 18) + 'px',
						'top':		(orig_pos.top  - 18) + 'px',
						'width':	$(orig_item).width(),
						'height':	$(orig_item).height()
					});

					if (opts.zoomOpacity) {
						itemOpts.opacity = 'show';
					}

					$("#fancy_outer").animate(itemOpts, opts.zoomSpeedIn, opts.easingIn, function() {
						setTimeout("_finish();",1000);
					});

				} else {

					$("#fancy_content").hide().empty().append($(value)).show();
					$("#fancy_outer").css(itemOpts).fadeIn("normal", function() {
						_finish();
					});
				}
			}
		};

		function _set_navigation() {
			if (opts.itemArray.length > 1) {
				$("#fancy_left, #fancy_left_ico").unbind().bind("click", function(e) {
					e.stopPropagation();
					if (opts.itemCurrent == 0) {
						opts.itemCurrent = opts.itemArray.length -1;
					} else {
						opts.itemCurrent--;
					}
					clearTimeout(slideshow);
					slideshowstate = false;
					$("#fancy_play").show();
					$("#fancy_stop").hide();
					_change_item();
					return false;
				});

				$("#fancy_left").show();

				$("#fancy_right, #fancy_right_ico").unbind().bind("click", function(e) {
					e.stopPropagation();
					if (opts.itemCurrent == ( opts.itemArray.length -1)) {
						opts.itemCurrent = 0;
					} else {
						opts.itemCurrent++;
					}
					clearTimeout(slideshow);
					slideshowstate = false;
					$("#fancy_play").show();
					$("#fancy_stop").hide();
					_change_item();
					return false;
				});

				$("#fancy_right").show();
			}
		};

		function _finish() {
			_set_navigation();

			_preload_neighbor_images();

			$(document).keydown(function(e) {
				if (e.keyCode == 27) {
					$.fn.fancybox.close();
					$(document).unbind("keydown");

				} else if(e.keyCode == 37 && opts.itemArray.length != 1) {
					if (opts.itemCurrent == 0) {
						opts.itemCurrent = opts.itemArray.length -1;
					} else {
						opts.itemCurrent--;
					}
					clearTimeout(slideshow);
					slideshowstate = false;
					$("#fancy_play").show();
					$("#fancy_stop").hide();
					_change_item();
					$(document).unbind("keydown");

				} else if(e.keyCode == 39 && opts.itemArray.length != 1) {
 					if (opts.itemCurrent == ( opts.itemArray.length -1)) {
						opts.itemCurrent = 0;
					} else {
						opts.itemCurrent++;
					}
					clearTimeout(slideshow);
					slideshowstate = false;
					$("#fancy_play").show();
					$("#fancy_stop").hide();
					_change_item();
					$(document).unbind("keydown");
				} else if(e.keyCode == 32 && opts.itemArray.length != 1) {
					if (slideshowstate) {
						clearTimeout(slideshow);
						$("#fancy_play").show();
						$("#fancy_stop").hide();
						slideshowstate = false;
					} else {
						slideshowstate = true;
						$("#fancy_play").hide();
						$("#fancy_stop").show();
						if (opts.itemCurrent == ( opts.itemArray.length -1)) {
							opts.itemCurrent = 0;
						} else {
							opts.itemCurrent++;
						}
						_change_item();
						$(document).unbind("keydown");
					}
				}
				
			});

		    $(document).bind("contextmenu",function(e){
		        return false;
		    });
			
			if (opts.centerOnScroll) {
				$(window).bind("resize scroll", $.fn.fancybox.scrollBox);
			} else {
				$("div#fancy_outer").css("position", "absolute");
			}

			if (opts.hideOnContentClick) {
				$("#fancy_wrap").click($.fn.fancybox.close);
			}

			$("#fancy_overlay, #fancy_close").bind("click", $.fn.fancybox.close);

			$("#fancy_outer").hover(function() {
				$("#fancy_close").show();
					if (slideshowstate) {
						$("#fancy_play").hide();
						$("#fancy_stop").show();
					} else {
						$("#fancy_play").show();
						$("#fancy_stop").hide();
					}
			}, function() {
				$("#fancy_close, #fancy_play, #fancy_stop").hide();
			});

			$('#fancy_outer').css("padding-bottom","33px");

			if (opts.itemArray[ opts.itemCurrent ].title !== undefined && opts.itemArray[ opts.itemCurrent ].title.length > 0) {
				$('#fancy_title div').html(opts.itemArray[ opts.itemCurrent ].title);
				$('#fancy_title').show();
			}

			if (opts.itemArray[ opts.itemCurrent ].desc !== undefined && opts.itemArray[ opts.itemCurrent ].desc.length > 0) {
				//var outerposition = $('#fancy_outer').position();
				//$('#fancy_outer').css("top", outerposition.top - 40);
				$('#fancy_desc').html(opts.itemArray[ opts.itemCurrent ].desc);
				$('#fancy_desc').show();
				$('#fancy_desc').css("top", $('#fancy_img').height() + 40);
				$('#fancy_outer').css("padding-bottom","100px");
			}

			if (opts.overlayShow && isIE) {
				$('embed, object, select', $('#fancy_content')).css('visibility', 'visible');
			}

			if ($.isFunction(opts.callbackOnShow)) {
				opts.callbackOnShow();
			}

			if(opts.itemArray.length > 1) {
				$("#fancy_play, #fancy_play_ico, #fancy_stop, #fancy_stop_ico").unbind().bind("click", function(e) {
					e.stopPropagation();
					if (slideshowstate) {
						clearTimeout(slideshow);
						$("#fancy_play").show();
						$("#fancy_stop").hide();
						slideshowstate = false;

					} else {
						slideshowstate = true;
						$("#fancy_play").hide();
						$("#fancy_stop").show();
						if (opts.itemCurrent == ( opts.itemArray.length -1)) {
							opts.itemCurrent = 0;
						} else {
							opts.itemCurrent++;
						}
						_change_item();
					}
					return false;
				});
			}

			busy = false;

			if(slideshowstate) {
				slideshow = setTimeout(function() {
					if (opts.itemCurrent == ( opts.itemArray.length -1)) {
							opts.itemCurrent = 0;
					} else {
							opts.itemCurrent++;
					}
					_change_item();
				},3000);
			}
		};

		return this.unbind('click').click(_initialize);
	};

	$.fn.fancybox.scrollBox = function() {
		var w = $.fn.fancybox.getViewport();
		
		if (opts.centerOnScroll && $("#fancy_outer").is(':visible')) {
			var ow	= $("#fancy_outer").outerWidth();
			var oh	= $("#fancy_outer").outerHeight();

			var pos	= {
				'top'	: (oh > w[1] ? w[3] : w[3] + Math.round((w[1] - oh) * 0.5)),
				'left'	: (ow > w[0] ? w[2] : w[2] + Math.round((w[0] - ow) * 0.5))
			};

			$("#fancy_outer").css(pos);

			$('#fancy_title').css({
				'top'	: pos.top	+ oh - 32,
				'left'	: pos.left	+ ((ow * 0.5) - ($('#fancy_title').width() * 0.5))
			});
		}
		
		if (IE6 && $("#fancy_overlay").is(':visible')) {
			$("#fancy_overlay").css({
				'height' : $(document).height()
			});
		}
		
		if ($("#fancy_loading").is(':visible')) {
			$("#fancy_loading").css({'left': ((w[0] - 40) * 0.5 + w[2]), 'top': ((w[1] - 40) * 0.5 + w[3])});
		}
	};

	$.fn.fancybox.showIframe = function() {
		$(".fancy_loading").hide();
		$("#fancy_frame").show();
	};

	$.fn.fancybox.getViewport = function() {
		return [$(window).width(), $(window).height(), $(document).scrollLeft(), $(document).scrollTop() ];
	};

	$.fn.fancybox.animateLoading = function() {
		if (!$("#fancy_loading").is(':visible')){
			clearInterval(loadingTimer);
			return;
		}

		$("#fancy_loading > div").css('top', (loadingFrame * -40) + 'px');

		loadingFrame = (loadingFrame + 1) % 12;
	};

	$.fn.fancybox.showLoading = function() {
		clearInterval(loadingTimer);

		var pos = $.fn.fancybox.getViewport();

		$("#fancy_loading").css({'left': ((pos[0] - 40) / 2 + pos[2]), 'top': ((pos[1] - 40) / 2 + pos[3])}).show();
		$("#fancy_loading").bind('click', $.fn.fancybox.close);

		loadingTimer = setInterval($.fn.fancybox.animateLoading, 66);
	};

	$.fn.fancybox.close = function() {
		busy = true;

		clearTimeout(slideshow);
		slideshowstate = false;

		$(imagePreloader).unbind();

		$("#fancy_overlay, #fancy_close, #fancy_play, #fancy_stop").unbind();

		if (opts.hideOnContentClick) {
			$("#fancy_wrap").unbind();
		}

		$("#fancy_close, .fancy_loading, #fancy_left, #fancy_right, #fancy_title, #fancy_desc, #fancy_play, #fancy_stop").hide();

		if (opts.centerOnScroll) {
			$(window).unbind("resize scroll");
		}

		__cleanup = function() {
			$("#fancy_overlay, #fancy_outer").hide();

			if (opts.centerOnScroll) {
				$(window).unbind("resize scroll");
			}

			$(document).unbind("keydown");

			if (isIE) {
				$('embed, object, select').css('visibility', 'visible');
			}

			if ($.isFunction(opts.callbackOnClose)) {
				opts.callbackOnClose();
			}

			busy = false;
		};

		if ($("#fancy_outer").is(":visible") !== false) {
			if (opts.zoomSpeedOut > 0 && opts.itemArray[opts.itemCurrent].orig !== undefined) {
				var orig_item	= opts.itemArray[opts.itemCurrent].orig;
				var orig_pos	= $.fn.fancybox.getPosition(orig_item);

				var itemOpts = {
					'left':		(orig_pos.left - 18) + 'px',
					'top': 		(orig_pos.top  - 18) + 'px',
					'width':	$(orig_item).width(),
					'height':	$(orig_item).height()
				};

				if (opts.zoomOpacity) {
					itemOpts.opacity = 'hide';
				}

				$("#fancy_outer").stop(false, true).animate(itemOpts, opts.zoomSpeedOut, opts.easingOut, __cleanup);

			} else {
				$("#fancy_outer").stop(false, true).fadeOut("fast", __cleanup);
			}

		} else {
			__cleanup();
		}

		return false;
	};

	$.fn.fancybox.build = function() {
		var html = '';

		html += '<div id="fancy_overlay"></div>';

		html += '<div id="fancy_wrap">';

		html += '<div class="fancy_loading" id="fancy_loading"><div></div></div>';

		html += '<div id="fancy_outer">';

		html += '<div id="fancy_inner">';

		html += '<div id="fancy_close"></div>';

		html += '<div id="fancy_play"></div>';

		html += '<div id="fancy_stop"></div>';

		html +=  '<div id="fancy_bg"><div class="fancy_bg fancy_bg_n"></div><div class="fancy_bg fancy_bg_ne"></div><div class="fancy_bg fancy_bg_e"></div><div class="fancy_bg fancy_bg_se"></div><div class="fancy_bg fancy_bg_s"></div><div class="fancy_bg fancy_bg_sw"></div><div class="fancy_bg fancy_bg_w"></div><div class="fancy_bg fancy_bg_nw"></div></div>';

		html +=  '<a href="javascript:;" id="fancy_left"><span class="fancy_ico" id="fancy_left_ico"></span></a><a href="javascript:;" id="fancy_right"><span class="fancy_ico" id="fancy_right_ico"></span></a>';

		html += '<div id="fancy_content"></div>';

		html += '<div id="fancy_image_protection"></div>';

		html +=  '<div id="fancy_title"></div>';

		html +=  '<div id="fancy_desc"></div>';

		html += '</div>';

		html += '</div>';

		html += '</div>';

		$(html).appendTo("body");

		$('<div id="fancy_title_main"></div>').appendTo('#fancy_title');

		if (isIE) {
			$("#fancy_inner").prepend('<iframe class="fancy_bigIframe" scrolling="no" frameborder="0"></iframe>');
			$("#fancy_play, #fancy_stop, #fancy_close, .fancy_bg, .fancy_title, .fancy_desc, .fancy_ico").fixPNG();
		}
	};

	$.fn.fancybox.defaults = {
		padding				:	10,
		imageScale			:	true,
		zoomOpacity			:	false,
		zoomSpeedIn			:	0,
		zoomSpeedOut		:	0,
		zoomSpeedChange		:	300,
		easingIn			:	'swing',
		easingOut			:	'swing',
		easingChange		:	'swing',
		frameWidth			:	425,
		frameHeight			:	355,
		overlayShow			:	true,
		overlayOpacity		:	0.3,
		hideOnContentClick	:	true,
		centerOnScroll		:	true,
		itemArray			:	[],
		callbackOnStart		:	null,
		callbackOnShow		:	null,
		callbackOnClose		:	null
	};

	$(document).ready(function() {
		$.fn.fancybox.build();
	});

})(jQuery);
