/* 
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
(function($){
    $.fn.hoverIntent=function(f,g){
        var cfg={
            sensitivity:7,
            interval:100,
            timeout:0
        };

        cfg=$.extend(cfg,g?{
            over:f,
            out:g
        }:f);
        var cX,cY,pX,pY;
        var track=function(ev){
            cX=ev.pageX;
            cY=ev.pageY;
        };

        var compare=function(ev,ob){
            ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);
            if((Math.abs(pX-cX)+Math.abs(pY-cY))<cfg.sensitivity){
                $(ob).unbind("mousemove",track);
                ob.hoverIntent_s=1;
                return cfg.over.apply(ob,[ev]);
            }else{
                pX=cX;
                pY=cY;
                ob.hoverIntent_t=setTimeout(function(){
                    compare(ev,ob);
                },cfg.interval);
            }
        };

    var delay=function(ev,ob){
        ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);
        ob.hoverIntent_s=0;
        return cfg.out.apply(ob,[ev]);
    };

    var handleHover=function(e){
        var p=(e.type=="mouseover"?e.fromElement:e.toElement)||e.relatedTarget;
        while(p&&p!=this){
            try{
                p=p.parentNode;
            }catch(e){
                p=this;
            }
        }
        if(p==this){
        return false;
    }
    var ev=jQuery.extend({},e);
    var ob=this;
    if(ob.hoverIntent_t){
        ob.hoverIntent_t=clearTimeout(ob.hoverIntent_t);
    }
    if(e.type=="mouseover"){
        pX=ev.pageX;
        pY=ev.pageY;
        $(ob).bind("mousemove",track);
        if(ob.hoverIntent_s!=1){
            ob.hoverIntent_t=setTimeout(function(){
                compare(ev,ob);
            },cfg.interval);
        }
    }else{
    $(ob).unbind("mousemove",track);
    if(ob.hoverIntent_s==1){
        ob.hoverIntent_t=setTimeout(function(){
            delay(ev,ob);
        },cfg.timeout);
    }
}
};

return this.mouseover(handleHover).mouseout(handleHover);
};

})(jQuery);


$(document).ready(function(){
    function megaHoverOver(){
        $(this).find("a").addClass('mouseOver').stop().fadeTo('fast',1).show();
        $(this).find(".sub").stop().fadeTo('fast',1).show();
        (function($){
            jQuery.fn.calcSubWidth=function(){
                rowWidth=0;
                $(this).find("ul").each(function(){
                    rowWidth+=$(this).width();
                });
            };

        })(jQuery);
        if($(this).find(".row").length>0){
            var biggestRow=0;
            $(this).find(".row").each(function(){
                $(this).calcSubWidth();
                if(rowWidth>biggestRow){
                    biggestRow=rowWidth;
                }
            });
            $(this).find(".sub").css({
                'width':biggestRow
            });
            $(this).find(".row:last").css({
                'margin':'0'
            });
            if(($(this).position().left+$(this).find(".sub").width())>($("#Toolbar_Links").width()+$("#Toolbar_Links").position().left)){
                $(this).find(".sub").css({
                    'left':'0'
                });
                newPosition=$(this).find(".sub").width()-$(this).find(".sub").width()-$(this).find(".sub").width()+117;
                $(this).find(".sub").css({
                    'left':newPosition
                });
            }
        }else{
            $(this).calcSubWidth();
            $(this).find(".sub").css({
                'width':rowWidth
            });
            if(($(this).position().left+$(this).find(".sub").width())>($("#Toolbar_Links").width()+$("#Toolbar_Links").position().left)){
                $(this).find(".sub").css({
                    'left':'0'
                });
                newPosition=$(this).find(".sub").width()-$(this).find(".sub").width()-$(this).find(".sub").width()+117;
                $(this).find(".sub").css({
                    'left':newPosition
                });
            }
        }
    }
    function megaHoverOut(){
        $(this).find("a").removeClass('mouseOver');
        $(this).find(".sub").stop().fadeTo('fast',0,function(){
            $(this).hide();
        });
    }
    var config={
        sensitivity:2,
        interval:50,
        over:megaHoverOver,
        timeout:100,
        out:megaHoverOut
    };

    $("ul.topnav li .sub").css({
        'opacity':'0'
    });
    $("ul.topnav li").hoverIntent(config);





    $('#search input').keydown(function(e) {
        if (e.keyCode == 13) {
            moduleSearch();
        }
    });

    function moduleSearch() {
        pathArray = location.pathname.split( '/' );

        url = location.protocol + "//" + location.host + "/";

        url += 'index.php?route=product/search';

        var filter_keyword = $('#filter_keyword').val();

        if (filter_keyword) {
            url += '&keyword=' + encodeURIComponent(filter_keyword);
        }

        window.location = url;
    }

    $('.switcher').bind('click', function() {
        $(this).find('.option').slideToggle('fast');
    });
    $('.switcher').bind('mouseleave', function() {
        $(this).find('.option').slideUp('fast');
    });
});
