/* * 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 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 = settings;			_start();			return false;		};		function _start() {			if (busy) return;			if ($.isFunction(opts.callbackOnStart)) {				opts.callbackOnStart();			}			opts.itemArray		= [];			opts.itemCurrent	= 0;			if (settings.itemArray.length > 0) {				opts.itemArray = settings.itemArray;			} else {				var item = {};				if (!elem.rel || elem.rel == '') {					var item = {href: elem.href, title: elem.title};					if ($(elem).children("img:first").length) {						item.orig = $(elem).children("img:first");					}					opts.itemArray.push( item );				} else {										var subGroup = $(matchedGroup).filter("a[rel=" + elem.rel + "]");					var item = {};					for (var i = 0; i < subGroup.length; i++) {						item = {href: subGroup[i].href, title: subGroup[i].title};						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();		};		function _change_item() {			$("#fancy_right, #fancy_left, #fancy_close, #fancy_title").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() {			if (opts.imageScale) {				var w = $.fn.fancybox.getViewport();				var r = Math.min(Math.min(w[0] - 36, imagePreloader.width) / imagePreloader.width, Math.min(w[1] - 60, 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() {			if ((opts.itemArray.length -1) > opts.itemCurrent) {				var href = opts.itemArray[opts.itemCurrent + 1].href;				if (href.match(imageRegExp)) {					objNext = new Image();					objNext.src = href;				}			}			if (opts.itemCurrent > 0) {				var href = opts.itemArray[opts.itemCurrent -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%'				});			}			if ($("#fancy_outer").is(":visible") && width == $("#fancy_outer").width() && height == $("#fancy_outer").height()) {				$("#fancy_content").fadeOut("fast", function() {					$("#fancy_content").empty().append($(value)).fadeIn("normal", function() {						_finish();					});				});				return;			}			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));			var itemOpts = {				'left':		itemLeft,				'top':		itemTop,				'width':	width + 'px',				'height':	height + 'px'			};			if ($("#fancy_outer").is(":visible")) {				$("#fancy_content").fadeOut("normal", function() {					$("#fancy_content").empty();					$("#fancy_outer").animate(itemOpts, opts.zoomSpeedChange, opts.easingChange, function() {						$("#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() {						_finish();					});				} else {					$("#fancy_content").hide().empty().append($(value)).show();					$("#fancy_outer").css(itemOpts).fadeIn("normal", function() {						_finish();					});				}			}		};		function _set_navigation() {			if (opts.itemCurrent != 0) {				$("#fancy_left, #fancy_left_ico").unbind().bind("click", function(e) {					e.stopPropagation();					opts.itemCurrent--;					_change_item();					return false;				});				$("#fancy_left").show();			}			if (opts.itemCurrent != ( opts.itemArray.length -1)) {				$("#fancy_right, #fancy_right_ico").unbind().bind("click", function(e) {					e.stopPropagation();					opts.itemCurrent++;					_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.itemCurrent != 0) {					opts.itemCurrent--;					_change_item();					$(document).unbind("keydown");				} else if(e.keyCode == 39 && opts.itemCurrent != (opts.itemArray.length - 1)) { 					opts.itemCurrent++;					_change_item();					$(document).unbind("keydown");				}			});			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_close").show();			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.overlayShow && isIE) {				$('embed, object, select', $('#fancy_content')).css('visibility', 'visible');			}			if ($.isFunction(opts.callbackOnShow)) {				opts.callbackOnShow();			}			busy = false;		};		return this.unbind('click').click(_initialize);	};	$.fn.fancybox.scrollBox = function() {		var pos = $.fn.fancybox.getViewport();		$("#fancy_outer").css('left', (($("#fancy_outer").width()	+ 36) > pos[0] ? pos[2] : pos[2] + Math.round((pos[0] - $("#fancy_outer").width()	- 36)	/ 2)));		$("#fancy_outer").css('top',  (($("#fancy_outer").height()	+ 50) > pos[1] ? pos[3] : pos[3] + Math.round((pos[1] - $("#fancy_outer").height()	- 50)	/ 2)));	};	$.fn.fancybox.getNumeric = function(el, prop) {		return parseInt($.curCSS(el.jquery?el[0]:el,prop,true))||0;	};	$.fn.fancybox.getPosition = function(el) {		var pos = el.offset();		pos.top	+= $.fn.fancybox.getNumeric(el, 'paddingTop');		pos.top	+= $.fn.fancybox.getNumeric(el, 'borderTopWidth');		pos.left += $.fn.fancybox.getNumeric(el, 'paddingLeft');		pos.left += $.fn.fancybox.getNumeric(el, 'borderLeftWidth');		return pos;	};	$.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;		$(imagePreloader).unbind();		$("#fancy_overlay, #fancy_close").unbind();		if (opts.hideOnContentClick) {			$("#fancy_wrap").unbind();		}		$("#fancy_close, .fancy_loading, #fancy_left, #fancy_right, #fancy_title").hide();		if (opts.centerOnScroll) {			$(window).unbind("resize scroll");		}		__cleanup = function() {			$("#fancy_overlay, #fancy_outer").hide();			if (opts.centerOnScroll) {				$(window).unbind("resize scroll");			}			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_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_title"></div>';		html += '</div>';		html += '</div>';		html += '</div>';		$(html).appendTo("body");		$('<table cellspacing="0" cellpadding="0" border="0"><tr><td class="fancy_title" id="fancy_title_left"></td><td class="fancy_title" id="fancy_title_main"><div></div></td><td class="fancy_title" id="fancy_title_right"></td></tr></table>').appendTo('#fancy_title');		if (isIE) {			$("#fancy_inner").prepend('<iframe class="fancy_bigIframe" scrolling="no" frameborder="0"></iframe>');			$("#fancy_close, .fancy_bg, .fancy_title, .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.8,		hideOnContentClick	:	true,		centerOnScroll		:	true,		itemArray			:	[],		callbackOnStart		:	null,		callbackOnShow		:	null,		callbackOnClose		:	null	};	$(document).ready(function() {		$.fn.fancybox.build();	});})(jQuery);