/***********************************************
* Cool DHTML tooltip script- © Dynamic Drive DHTML code library (www.dynamicdrive.com)
* This notice MUST stay intact for legal use
* Visit Dynamic Drive at http://www.dynamicdrive.com/ for full source code
***********************************************/
/*******************
* Letyn's comments 21.2.2007
* 1) It is necessary to put somewhere in the HTML page - eg: <div id="dhtmltooltip"></div>
* 2) Set style for tooltip eg:
*   #dhtmltooltip{
*    position: absolute;
*    width: 150px;
*    border: 2px solid black;
*    padding: 2px;
*    background-color: lightyellow;
*    visibility: hidden;
*    z-index: 100;
*  }
* 3) Use tooltip in the page eg: 
* <DIV onMouseover="ddrivetip('This DIV \'<br />has a tip!', '#EFEFEF')" onMouseout="hideddrivetip()">Some text here. Some text here.</div>
* 
* Note ddrivetip(thetext, thecolor, thewidth) has to optional parameters (color and width of the object)
*******************/

var offsetxpoint=10 //Customize x offset of tooltip
var offsetypoint=-20 //Customize y offset of tooltip
var ie=document.all
var ns6=document.getElementById && !document.all
var enabletip=false
var drivetipheader = '<div class="dhtmltooltipTop"></div><div class="dhtmltooltipIn">';
var drivetipfooter = '</div><div class="dhtmltooltipBottom"></div>';
var isIE7 = false;
var tooltipPreview = 0;

if (window.XMLHttpRequest) {
 if(ie){
  //IE7
   isIE7 = true;
   //offsetxpoint = -240;
 }else{
  //mozilla, safari, opera 9…etc
 }
} else {
  // IE6, older browsers
}

function gettipobj(){
    return document.all? document.all["dhtmltooltip"] : document.getElementById? document.getElementById("dhtmltooltip") : ""
}

function ietruebody(){
if (ie||ns6)
return (document.compatMode && document.compatMode!="BackCompat")? document.documentElement : document.body
}

function ddrivetip(thetext, thecolor, thewidth){
var tipobj = gettipobj();
if (ns6||ie){
if (typeof thewidth!="undefined") tipobj.style.width=thewidth+"px"
if (typeof thecolor!="undefined" && thecolor!="") tipobj.style.backgroundColor=thecolor
tipobj.innerHTML=drivetipheader+thetext+drivetipfooter;
enabletip=true
return false
}
}

function positiontip(e){
var tipobj = gettipobj();
if (enabletip){
var curX=(ns6)?e.pageX : event.clientX+ietruebody().scrollLeft;
var curY=(ns6)?e.pageY : event.clientY+ietruebody().scrollTop;
//Find out how close the mouse is to the corner of the window
var rightedge=ie&&!window.opera? ietruebody().clientWidth-event.clientX-offsetxpoint : window.innerWidth-e.clientX-offsetxpoint-20
var bottomedge=ie&&!window.opera? ietruebody().clientHeight-event.clientY-offsetypoint : window.innerHeight-e.clientY-offsetypoint-20

var leftedge=(offsetxpoint<0)? offsetxpoint*(-1) : -1000

//if the horizontal distance isn't enough to accomodate the width of the context menu
if (rightedge<tipobj.offsetWidth)
//move the horizontal position of the menu to the left by it's width
tipobj.style.left=ie? ietruebody().scrollLeft+event.clientX-tipobj.offsetWidth+"px" : window.pageXOffset+e.clientX-tipobj.offsetWidth+"px"
else if (curX<leftedge)
tipobj.style.left="5px"
else
//position the horizontal position of the menu where the mouse is positioned
tipobj.style.left=curX+offsetxpoint+"px"

var vertical_classname = '';
//same concept with the vertical position
if (bottomedge<tipobj.offsetHeight){
  tipobj.style.top=ie? ietruebody().scrollTop+event.clientY-tipobj.offsetHeight-offsetypoint+"px" : window.pageYOffset+e.clientY-tipobj.offsetHeight-offsetypoint+"px";
  vertical_classname = 'showTop';
}else{
  tipobj.style.top=curY+offsetypoint+"px";
}
tipobj.className = vertical_classname;
tipobj.style.visibility="visible"
}
}

function hideddrivetip(){
var tipobj = gettipobj();
if (ns6||ie){
enabletip=false
tipobj.style.visibility="hidden"
tipobj.style.left="-1000px"
tipobj.style.backgroundColor=''
tipobj.style.width=''
}
}

document.onmousemove=positiontip