/*
 * FancyBox - simple jQuery plugin for fancy image zooming
 * Examples and documentation at: http://fancy.klade.lv/
 * Version: 1.2.0-beta-2 (04/02/2009)
 * Copyright (c) 2009 Janis Skarnelis
 * Licensed under the MIT License: http://www.opensource.org/licenses/mit-license.php
 * Requires: jQuery v1.3.1 or later
*/
;(function($) {

	function log() {
		if (window.console && window.console.log)
			window.console.log(arguments[0]);
	};
	
	var elem, opts, busy = false, imagePreloader = new Image, loadingTimer, loadingFrame = 1, imageRegExp = '[^\.]\.(jpg|jpeg|png|tiff|gif|bmp)\s*$';
    var isIE6 = ($.browser.msie && parseInt($.browser.version.substr(0,1)) < 7);
    
	$.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;
        	 
        	opts.itemArray		= [];
        	opts.itemCurrent	= 0;

        	if (settings.itemArray.length > 0) {
        		opts.itemArray = settings.itemArray;
        		
			} else if ( matchedGroup.length == 1 ) {
				var item = { href: elem.href, title: elem.title };
	
				if (opts.zoomSpeedIn > 0 || opts.zoomSpeedOut > 0) {
					var context = $(elem).children("img:first").length ? $(elem).children("img:first") : $(elem);
					
					item.orig = { 'width': context.width(), 'height': context.height(), 'pos': $.fn.fancybox.getPosition(context) };
				}
	   
				opts.itemArray.push( item );
	
			} else {
				var item = {};
				
				for (var i = 0; i < matchedGroup.length; i++) {
					item = {href: matchedGroup[i].href, title: matchedGroup[i].title};
					
					if (opts.zoomSpeedIn > 0 || opts.zoomSpeedOut > 0) {
						var context = $(matchedGroup[i]).children("img:first").length ? $(matchedGroup[i]).children("img:first") : $(matchedGroup[i]);
						
						item.orig = { 'width': context.width(), 'height': context.height(), 'pos': $.fn.fancybox.getPosition(context) };
					}
					
					opts.itemArray.push( item );
				}
			}

			while ( opts.itemArray[ opts.itemCurrent ].href != elem.href ) {
				opts.itemCurrent++;
			}
			
			if (opts.overlayShow) {
				
				if (isIE6) {
					$("#fancy_overlay").empty().prepend('<iframe class="fancy_bigIframe" scrolling="no" frameborder="0"></iframe>');
				}
				
				$("#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, '');

				_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 {
				_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);
			}
		};
		
		function _proceed_image() {

			if (opts.imageScale) {
				
				var w = $.fn.fancybox.getViewport();

				var r = Math.min(Math.min(w[0], imagePreloader.width) / imagePreloader.width, Math.min(w[1], imagePreloader.height) / imagePreloader.height);

				var ww = Math.round(r * imagePreloader.width);
				var hh = Math.round(r * imagePreloader.height);
	
			} else {
				var ww = imagePreloader.width;
				var hh = imagePreloader.height;
			}

			_set_content('<img alt="' + opts.itemArray[ opts.itemCurrent ].title + '" id="fancy_img" src="' + imagePreloader.src + '" />', ww, hh);
			
			_preload_neighbor_images();
		};

		function _preload_neighbor_images() {
			if ( (opts.itemArray.length -1) > opts.itemCurrent ) {
				objNext = new Image();
				objNext.src = opts.itemArray[opts.itemCurrent + 1].href;
			}
			
			if ( opts.itemCurrent > 0 ) {
				objPrev = new Image();
				objPrev.src = opts.itemArray[opts.itemCurrent -1].href;
			}
		};
		
		function _set_content(value, ww, hh) {

			var w	= $.fn.fancybox.getViewport();

			var itemLeft	= w[2] + Math.round((w[0] - ww)	/ 2) - 20;
			var itemTop		= w[3] + Math.round((w[1] - hh)	/ 2) - 20;

			var itemOpts = {
				'left':		itemLeft, 
				'top':		itemTop, 
				'width':	ww + 'px', 
				'height':	hh + 'px'	
			}

			if ($("#fancy_outer").is(":visible")) {
		
				if (ww == $("#fancy_content").width() && hh == $("#fancy_content").height()) {
					
					$("#fancy_content").fadeOut("fast", function() {

						$("#fancy_content").empty().append($(value)).fadeIn("fast", function() {
							_finish();
						});
					});
					
				} else {
					$("#fancy_content").fadeOut("fast", function() {

						$("#fancy_content").empty();

						$("#fancy_outer").animate(itemOpts, opts.zoomSpeedChange, "swing", function() {
							$("#fancy_content").append($(value)).fadeIn("fast", function() {
								_finish();
							});
						});
					});
				}
				
			} else {
				
				if (opts.zoomSpeedIn > 0) {

					$("#fancy_content").empty().append($(value));
					
					$("#fancy_outer").css({
						'left':		(opts.itemArray[opts.itemCurrent].orig.pos.left - 18) + 'px',
						'top': 		(opts.itemArray[opts.itemCurrent].orig.pos.top  - 18) + 'px',
						'width':	opts.itemArray[opts.itemCurrent].orig.width  + 'px',
						'height':	opts.itemArray[opts.itemCurrent].orig.height + 'px'

					});

					busy = true;
					
					$("#fancy_outer").animate(itemOpts, opts.zoomSpeedIn, function() {
						_finish();
					});
					
				} else {
					
					$("#fancy_content").empty().append($(value));
				
					busy = true;
						
					$("#fancy_outer").css(itemOpts).fadeIn("normal", function() {
						_finish();
					});
				}
			}
					
		};
		
		function _finish() {
	
			if ( opts.itemCurrent != 0 ) {
				$("#fancy_left").unbind().bind("click", function(e) {
					e.stopPropagation();
					
					opts.itemCurrent--;
					_change_item();
					
					return false;
				}).show();
			} else {
				$("#fancy_left").hide();
			}
			
			if ( opts.itemCurrent != ( opts.itemArray.length -1 ) ) {
				$("#fancy_right").unbind().bind("click", function(e) {
					e.stopPropagation();
					
					opts.itemCurrent++;
					_change_item();
					
					return false;
				}).show();
			} else {
				$("#fancy_right").hide();
			}
			
			$(document).keydown(function(event) {
				if (event.keyCode == 27) {
            		$.fn.fancybox.close();
            		$(document).unbind("keydown");

				} else if(event.keyCode == 37 && opts.itemCurrent != 0) {
            		opts.itemCurrent--;
					_change_item();
					$(document).unbind("keydown");

				} else if(event.keyCode == 39 && opts.itemCurrent != (opts.itemArray.length - 1)) {
            		opts.itemCurrent++;
					_change_item();
					$(document).unbind("keydown");
				}
			});
		

			if (opts.centerOnScroll) {
				$(window).scroll($.fn.fancybox.scrollBox);
			} else {
				$(window).unbind("scroll");
			}
			
			$(window).resize(function() {
				$.fn.fancybox.scrollBox();
			});
			
			if (opts.hideOnContentClick) {
				$("#fancy_wrap").click($.fn.fancybox.close);
			} else {
				$("#fancy_wrap").unbind();
			}
			
			$("#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.itemArray.length != 1){
				$('#fancy_counter').html("bilde "+(opts.itemCurrent+1)+" av "+opts.itemArray.length+"")
			}
			$('#fancy_counter').show();
				
			$.fn.fancybox.scrollBox();
			
			busy = false;
		}
		
		return this.unbind('click').click(_initialize);
	};
	
	
	$.fn.fancybox.scrollBox = function(el) {
		$("#fancy_outer").css('left', ($(document).scrollLeft() + Math.round(($(window).width() - $("#fancy_outer").width())	 / 2) - 20));
		$("#fancy_outer").css('top',  ($(document).scrollTop() + Math.round(($(window).height() - $("#fancy_outer").height()) / 2) - 20));
	};
	
	$.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() {
    	
    	$(imagePreloader).unbind();
    	
    	$("#fancy_close, #fancy_loading, #fancy_left, #fancy_right, #fancy_title").hide();
    	
    	if ($("#fancy_outer").is(":visible") !== false) {
    		
    		if (opts.zoomSpeedOut > 0 && opts.itemArray[opts.itemCurrent].orig !== undefined) {
    			
    			$("#fancy_outer").animate({
					'left':		(opts.itemArray[opts.itemCurrent].orig.pos.left - 18) + 'px',
					'top': 		(opts.itemArray[opts.itemCurrent].orig.pos.top  - 18) + 'px',
					'width':	opts.itemArray[opts.itemCurrent].orig.width  + 'px',
					'height':	opts.itemArray[opts.itemCurrent].orig.height + 'px'
				}, opts.zoomSpeedOut, "swing", function() {
					busy = false;

					$("#fancy_overlay, #fancy_outer").hide();
					
	    			$("#fancy_content").empty();
				});
					
			} else {
				
	    		busy = true;

	    		$("#fancy_outer").stop().fadeOut("fast", function() {
	    			busy = false;

	    			$("#fancy_overlay, #fancy_outer").hide();
					
	    			$("#fancy_content").empty();
				});
			}
			
    	} else {
    		$("#fancy_close, #fancy_loading, #fancy_left, #fancy_right, #fancy_overlay").hide();	
		}
    	
    	return false;
    };
	
	$.fn.fancybox.build = function() {
		var html = '';
		
		html += '<div id="fancy_overlay"></div>';
	
		html += '<div id="fancy_wrap">';
		
		html += '<div 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 += '<div id="fancy_content"></div>';

		html +=  '<a id="fancy_left" href="javascript:;"></a><a id="fancy_right" href="javascript:;"></a>';
		
		html +=  '<div id="fancy_counter"></div><div id="fancy_title"></div>';
		
		html += '</div>';
		
		html += '</div>';
	
		html += '</div>';

		$(html).appendTo("body");
		
		$('<table cellspacing="0" cellpadding="0" border="0"><tr><td id="fancy_title_left"></td><td id="fancy_title_main"><div></div></td><td id="fancy_title_right"></td></tr></table>').appendTo('#fancy_title');
		
		if (isIE6) {
			$("#fancy_inner").prepend('<iframe class="fancy_bigIframe" scrolling="no" frameborder="0"></iframe>');
		}
		
		if (jQuery.fn.pngFix) $(document).pngFix();

		$("#fancy_overlay, #fancy_bigIframe, #fancy_loading, #fancy_close").bind("click", $.fn.fancybox.close);
	};

	$.fn.fancybox.defaults = {
		imageScale			:	false,
		zoomOpacity			:	true,
		zoomSpeedIn			:	0,
		zoomSpeedOut		:	0,
		zoomSpeedChange		:	500,
		frameWidth			:	425,
		frameHeight			:	355,
		overlayShow			:	true,
		overlayOpacity		:	0.6,
		hideOnContentClick	:	false,
		centerOnScroll		:	true,
		itemArray			:	[]
	};
	
	$(document).ready(function() {
		$.fn.fancybox.build();
	});
	
})(jQuery);