/**
* hoverIntent r5 // 2007.03.27 // jQuery 1.1.2+
* <http://cherne.net/brian/resources/jquery.hoverIntent.html>
* 
* @param  f  onMouseOver function || An object with configuration options
* @param  g  onMouseOut function  || Nothing (use configuration options object)
* @author    Brian Cherne <brian@cherne.net>
*/
(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);
