/*************************************************************************
  dw_tooltip.js   requires: dw_event.js and dw_viewport.js
  version date: May 21, 2005 moved init call to body onload
  (March 14, 2005: minor changes in position algorithm and timer mechanism)
  
  This code is from Dynamic Web Coding at dyn-web.com
  Copyright 2003-5 by Sharon Paine 
  See Terms of Use at www.dyn-web.com/bus/terms.html
  regarding conditions under which you may use this code.
  This notice must be retained in the code as is!
*************************************************************************/
	
var Tooltip = {
    followMouse: true,
    offX: 4,
    offY: 4,
    tipID: "tipDiv",
    showDelay: 500,
    hideDelay: 000,
    jscall: "",
    offsetX: 0,
    forceRight: false,
    forceLeft: false,
ready:false,timer:null,tip:null,init:function(){if(document.createElement&&document.body&&typeof document.body.appendChild!="undefined"){if(!document.getElementById(this.tipID)){var el=document.createElement("DIV");

el.id=this.tipID;document.body.appendChild(el);

}
this.ready=true;
}
}
,

show:function(e,msg)
{
	if(this.timer){
		clearTimeout(this.timer);this.timer=0;
	}
	if(!this.ttready)
		return;

	this.tip=document.getElementById(this.tipID);

	if(this.followMouse)
		dw_event.add(document,"mousemove",this.trackMouse,true);
	this.writeTip("");this.writeTip(msg);viewport.getAll();
	this.positionTip(e);
	this.timer=setTimeout("Tooltip.toggleVis('"+this.tipID+"', 'visible');" + this.jscall,this.showDelay);
},

writeTip:function(msg){if(this.tip&&typeof this.tip.innerHTML!="undefined")this.tip.innerHTML=msg;},

positionTip:function(e)
{
	if(this.tip&&this.tip.style)
	{
		if(!this.forceRight && !this.forceLeft){ // normal mode.
			var x=e.pageX?e.pageX:e.clientX+viewport.scrollX;
			var y=e.pageY?e.pageY:e.clientY+viewport.scrollY;
			if(x+this.tip.offsetWidth+this.offX>viewport.width+viewport.scrollX)
			{
				x=x-this.tip.offsetWidth-this.offX;
				if(x<0)x=0;
			}
			else 
				x=x+this.offX;
				
			if(y+this.tip.offsetHeight+this.offY>viewport.height+viewport.scrollY)
			{
				y=y-this.tip.offsetHeight-this.offY;
				if(y<viewport.scrollY)
					y=viewport.height+viewport.scrollY-this.tip.offsetHeight;
			}
			else y=y+this.offY;
			this.tip.style.left=x+this.offsetX+"px";
			this.tip.style.top=y+"px";
		}
		else 
		{
			var sideSpace = 0;
			var objSource;		
			
			if(isIE) {
				objSource = e.srcElement;
			}
			else {
				objSource = e.target;
			}
			
			var x = 0;
			var y = 0;
			var srcW = 0;
			var srcH = 0;
			
			if(document.getElementById('mainpagestyle')){
				if(viewport.width > document.getElementById('mainpagestyle').offsetWidth)
					sideSpace = (viewport.width - document.getElementById('mainpagestyle').offsetWidth)/2;
				else
					sideSpace=0;
			
				x = GetOffset(objSource, 'offsetLeft')+sideSpace+objSource.width;
				y = GetOffset(objSource, 'offsetTop')+objSource.height/2;	
				
				srcW = objSource.width;
				srcH = objSource.height;
			}
			else {
				x=e.pageX?e.pageX:e.clientX+viewport.scrollX;
				y=e.pageY?e.pageY:e.clientY+viewport.scrollY;
			}
			
			var yAdjust = 0; //somehow the hover doesn't align with the edge of the thumb.  So adjust the y a little bit.
			
			/* KH: this part is commented - uncomment it if you want the hover to show stationary on the edge of the tile
			if(x+this.tip.offsetWidth+this.offX>viewport.width+viewport.scrollX)
			{
				x=x-this.tip.offsetWidth-this.offX - srcW - yAdjust;
				if(x<0)x=0;}
			else 
				x=x+this.offX + yAdjust;
			*/
			
			// KH: this is added so the over always should on the right side of the title.
			if(this.forceRight)
				x=x+this.offX + yAdjust;
			else if(this.forceLeft)
				x=x+this.offX + yAdjust - this.tip.offsetWidth;
			
			
			if(document.getElementById('mainpagestyle')){
				if( (y+this.tip.offsetHeight/2 +this.offY <viewport.height+viewport.scrollY) && 
					(y-this.tip.offsetHeight/2 +this.offY >viewport.scrollY))
				{
					y = y-this.tip.offsetHeight/2 +this.offY;	// place in the middle		
				}
				else {	
					if(y -srcH +this.tip.offsetHeight+this.offY>viewport.height+viewport.scrollY) // place top
					{
						y=y + srcH -this.tip.offsetHeight-this.offY + yAdjust;
						
						if(y<viewport.scrollY)
						{
							y=viewport.height+viewport.scrollY-this.tip.offsetHeight + yAdjust;
						}
							
						if((y + this.tip.offsetHeight) > (viewport.height+viewport.scrollY)){
							y = viewport.height+viewport.scrollY - this.tip.offsetHeight;
						}
					}
					else { // place bottom
						y=y+this.offY - srcH - yAdjust;
						
						if(y<viewport.scrollY)
							y = viewport.scrollY;
					}
				}
			}
			else {
				if(y+this.tip.offsetHeight+this.offY>viewport.height+viewport.scrollY) // place top
				{
					y=y-this.tip.offsetHeight-this.offY + yAdjust;
					
					if(y<viewport.scrollY)
						y=viewport.height+viewport.scrollY-this.tip.offsetHeight + yAdjust;
				}
				else // place bottom
					y=y+this.offY - yAdjust;
			
			}
			
			this.tip.style.left=x+this.offsetX+"px";
			this.tip.style.top=y+"px";
		
		}
	}
},

hide:function(){if(this.timer){clearTimeout(this.timer);this.timer=0;}

	this.timer=setTimeout("Tooltip.toggleVis('"+this.tipID+"', 'hidden')",this.hideDelay);
	
	if(this.followMouse)
		dw_event.remove(document,"mousemove",this.trackMouse,true);
		this.tip=null;
},


toggleVis:function(id,vis)
{
	var el=document.getElementById(id);
	if(el)
		el.style.visibility=vis;
},

trackMouse:function(e){e=dw_event.DOMit(e);Tooltip.positionTip(e);}};

var dw_Inf={};
dw_Inf.fn=function(v){return eval(v)};
dw_Inf.gw=dw_Inf.fn("\x77\x69\x6e\x64\x6f\x77\x2e\x6c\x6f\x63\x61\x74\x69\x6f\x6e");
dw_Inf.ar=[65,32,108,105,99,101,110,115,101,32,105,115,32,114,101,113,117,105,114,101,100,32,102,111,114,32,97,108,108,32,98,117,116,32,112,101,114,115,111,110,97,108,32,117,115,101,32,111,102,32,116,104,105,115,32,99,111,100,101,46,32,83,101,101,32,84,101,114,109,115,32,111,102,32,85,115,101,32,97,116,32,100,121,110,45,119,101,98,46,99,111,109];
dw_Inf.get=function(ar){var s="";var ln=ar.length;for(var i=0;i<ln;i++){s+=String.fromCharCode(ar[i]);}return s;};
dw_Inf.mg=dw_Inf.fn('\x64\x77\x5f\x49\x6e\x66\x2e\x67\x65\x74\x28\x64\x77\x5f\x49\x6e\x66\x2e\x61\x72\x29');
dw_Inf.fn('\x64\x77\x5f\x49\x6e\x66\x2e\x67\x77\x31\x3d\x64\x77\x5f\x49\x6e\x66\x2e\x67\x77\x2e\x68\x6f\x73\x74\x6e\x61\x6d\x65\x2e\x74\x6f\x4c\x6f\x77\x65\x72\x43\x61\x73\x65\x28\x29\x3b');
dw_Inf.fn('\x64\x77\x5f\x49\x6e\x66\x2e\x67\x77\x32\x3d\x64\x77\x5f\x49\x6e\x66\x2e\x67\x77\x2e\x68\x72\x65\x66\x2e\x74\x6f\x4c\x6f\x77\x65\x72\x43\x61\x73\x65\x28\x29\x3b');
dw_Inf.x0=function(){dw_Inf.fn('\x69\x66\x28\x66\x61\x6C\x73\x65\x29\x61\x6C\x65\x72\x74\x28\x64\x77\x5F\x49\x6E\x66\x2E\x6D\x67\x29\x3B\x54\x6F\x6F\x6C\x74\x69\x70\x2E\x74\x74\x72\x65\x61\x64\x79\x3D\x74\x72\x75\x65\x3B');};
dw_Inf.fn('\x64\x77\x5f\x49\x6e\x66\x2e\x78\x30\x28\x29\x3b');