/*
 * FancyBox - simple jQuery plugin for fancy image zooming
 * Examples and documentation at: http://fancy.klade.lv/
 * Version: 1.2.0-beta-3 (11/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($) {
 
    $.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|jpeg|png|tiff|gif|bmp)\s*(.*)?$';
    var isIE6 = ($.browser.msie && parseInt($.browser.version.substr(0,1)) < 7);
    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;
 
            opts.itemArray      = [];
            opts.itemCurrent    = 0;
 
            if (settings.itemArray.length > 0) {
                opts.itemArray = settings.itemArray;
 
            } else {
                var item = {};
 
                for (var i = 0; i < matchedGroup.length; i++) {
                    item = {href: matchedGroup[i].href, title: matchedGroup[i].title};
 
                    if ($(matchedGroup[i]).children("img:first").length) {
                        item.orig = $(matchedGroup[i]).children("img:first");
                    }
                    else {item.orig = $(matchedGroup[i]);} 
                    
                    opts.itemArray.push( item );
                }
            }
 
            while ( opts.itemArray[ opts.itemCurrent ].href != elem.href ) {
                opts.itemCurrent++;
            }
 
            if (opts.overlayShow) {
                if (isIE6) {
                    $('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 (opts.el) {href = $(opts.el).attr('href');} // !!!!
            if (!href) { sAction = $(opts.itemArray[ opts.itemCurrent ].orig).parent().parent().attr('action');} else {sAction = '';}// !!!!
            if (sAction) { // !!!! begin
                sIframeUrl = sAction + '?' + $(opts.itemArray[ opts.itemCurrent ].orig).parent().parent().serialize();
                if($('input:checkbox[name=agb]:checked').val() != 1)
                {
                    _set_content('<div id="fancy_div">' + $('#frameErrorMsg').html() + '</div>', opts.frameWidth, opts.frameHeight);
                }
                else
                {
                    _set_content('<iframe id="fancy_frame" onload="jQuery.fn.fancybox.showIframe()" name="fancy_iframe' + Math.round(Math.random()*1000) + '" frameborder="0" hspace="0" src="' + sIframeUrl + '"></iframe>', opts.frameWidth, opts.frameHeight);
                }
            } else // !!!! end
            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 if ( href.match("popup")) { /// !!!! orig: iframe -> popup
                _set_content('<iframe id="fancy_frame" onload="jQuery.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 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="" id="fancy_img" src="' + imagePreloader.src + '" />', ww, hh);
 
            _preload_neighbor_images();
        };
 
        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, ww, hh) {
            
            
            if (isIE) {
                $("#fancy_content")[0].style.removeExpression("height");
                $("#fancy_content")[0].style.removeExpression("width");
            }
            
            var w = $.fn.fancybox.getViewport();
 
            var itemLeft    = (ww + 36) > w[0] ? w[2] : w[2] + Math.round((w[0] - ww - 36)  / 2);
            var itemTop     = (hh + 50) > w[1] ? w[3] : w[3] + Math.round((w[1] - hh - 50)  / 2);

            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, opts.easingChange, function() {
                            $("#fancy_content").append($(value)).fadeIn("fast", function() {
                                _finish();
                            });
                        });
                    });
                }
 
            } else {
                if (opts.el) {opts.itemArray[opts.itemCurrent].orig = $(opts.el + ' img');} // !!!!
                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_item   = opts.itemArray[opts.itemCurrent].orig.attr('id') ? $('#' + opts.itemArray[opts.itemCurrent].orig.attr('id')) : orig_item; // !!!!
                    var orig_pos    = $.fn.fancybox.getPosition(orig_item);
                    
                    $("#fancy_outer").css({
                        'left':     (orig_pos.left - 24) + 'px',
                        'top':      (orig_pos.top  - 24) + 'px',
                        'width':    $(orig_item).width(),
                        'height':   $(orig_item).height()
                    });

                    busy = true;

                    if (opts.zoomOpacity) {
                        itemOpts.opacity = 'show';
                    }
 
                    $("#fancy_outer").animate(itemOpts, opts.zoomSpeedIn, opts.easingIn, function() {
                        _finish();
                    });
 
                } else {
 
                    $("#fancy_content").empty().append($(value));
 
                    busy = true;
 
                    $("#fancy_outer").css(itemOpts).fadeIn("normal", function() {
                        _finish();
                    });
                }
            }
        };
 
        function _set_navigation() {
          if($("#fancy_frame").length) {return;} // !!!!
            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();
            }
        };
 
        function _finish() {
            _set_navigation();
 
            $(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);
            } else {
                $("#fancy_wrap").unbind();
            }
            
            $("#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(typeof opts.onLoad == "function")
            {
                opts.onLoad();
            }
 
            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() {
           ///alert($('body').scrollTop())
        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() {
    
        if (opts.fancyLoading && opts.itemArray[opts.itemCurrent].orig !== undefined && $("#fancy_outer").is(":visible") !== true) {
            var orig_item   = opts.itemArray[opts.itemCurrent].orig;
            var orig_pos    = $.fn.fancybox.getPosition(orig_item);
 
            $('<div class="fancy_loading" id="fancy_loading_overlay"></div>').css({
                'top'       : orig_pos.top,
                'left'      : orig_pos.left,
                'width'     : $(orig_item).width(),
                'height'    : $(orig_item).height(),
                'opacity'   : 0.5
                
            }).appendTo("body");
            
            $('<div class="fancy_loading" id="fancy_loading_icon"></div>').css({
                'top'       : orig_pos.top + (($(orig_item).height() / 2) - 8),
                'left'      : orig_pos.left + (($(orig_item).width() / 2) - 8)
            }).appendTo("body");
            
            return;
        }
        
        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) {
 
            busy = true;
 
            if (opts.zoomSpeedOut > 0 && opts.itemArray[opts.itemCurrent].orig !== undefined) {
 
                var orig_item   = opts.itemArray[opts.itemCurrent].orig;
                var orig_item   = opts.itemArray[opts.itemCurrent].orig.attr('id') ? $('#' + opts.itemArray[opts.itemCurrent].orig.attr('id')) : orig_item; // !!!!
                var orig_pos    = $.fn.fancybox.getPosition(orig_item);
 
                var itemOpts = {
                    'left':     (orig_pos.left - 24) + 'px',
                    'top':      (orig_pos.top  - 24) + 'px',
                    'width':    $(orig_item).width(),
                    'height':   $(orig_item).height()
                }
 
                if (opts.zoomOpacity) {
                    itemOpts.opacity = 'hide';
                }
 
                $("#fancy_outer").animate(itemOpts, opts.zoomSpeedOut, opts.easingOut, function() {
                    busy = false;
 
                    $("#fancy_overlay, #fancy_outer").hide();
 
                    if (isIE6) {
                        $('embed, object, select').css({ 'visibility' : 'visible'});
                    }
                });
 
            } else {
                $("#fancy_outer").stop().fadeOut("fast", function() {
                    busy = false;
 
                    $("#fancy_overlay, #fancy_outer").hide();
 
                    if (isIE6) {
                        $('embed, object, select').css({ 'visibility' : 'visible'});
                    }
                });
            }
 
        } else {
            $("#fancy_overlay, #fancy_outer").hide();
        }
        if(typeof opts.onClose == "function")
        {
            opts.onClose();
        }
            
        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) {
            if("https:" == document.location.protocol)
            {
                $("#fancy_inner").prepend('<iframe class="fancy_bigIframe" scrolling="no" frameborder="0" src="' + sSslBaseUrl + 'images/blank.gif" ></iframe>');
            }
            else
            {
                $("#fancy_inner").prepend('<iframe class="fancy_bigIframe" scrolling="no" frameborder="0"></iframe>');
            }
            $("#fancy_close, .fancy_bg, .fancy_title, .fancy_ico, #fancy_loading div").fixPNG();
        }
    };
 
    $.fn.fancybox.defaults = {
        imageScale          :   true,
        zoomOpacity         :   false,
        zoomSpeedIn         :   0,
        zoomSpeedOut        :   0,
        zoomSpeedChange     :   300,
        easingIn            :   'linear',
        easingOut           :   'linear',
        easingChange        :   'linear',
        frameWidth          :   425,
        frameHeight         :   355,
        overlayShow         :   true,
        overlayOpacity      :   0.3,
        hideOnContentClick  :   false,
        centerOnScroll      :   true,
        itemArray           :   [],
        fancyLoading        :   false,
        onLoad: function(){},
        onClose: function(){}
    };
 
    $(document).ready(function() {
        $.fn.fancybox.build();
    });
 
})(jQuery);