var RollTip = {
    followMouse: true,
    offX: 12,
    offY: 12,
    // duration of clipping animation
    showAni: 300,
    hideAni: 200,
    ID: "rolltipDiv",
ready:false,timer:null,tip:null,init:function()
{var opok=(!window.opera||window.opera&&opera.buildNumber&&opera.buildNumber()>3800)?true:false;
if(document.createElement&&document.body&&typeof document.body.appendChild!="undefined"&&opok){var el=document.createElement("DIV");
el.id=this.ID;document.body.appendChild(el);
this.showMult=el.offsetWidth/this.showAni/this.showAni;this.hideMult=el.offsetWidth/this.hideAni/this.hideAni;
el.style.clip="rect(0, 0, 0, 0)";
el.style.visibility="visible";
this.ready=true;}},reveal:function(msg,e){
if(this.timer){
clearTimeout(this.timer);this.timer=0;
}
if(!this.rtready)return;this.tip=document.getElementById(this.ID);
this.writeTip("");this.writeTip(msg);viewport.getAll();
this.w=this.tip.offsetWidth;this.h=this.tip.offsetHeight;
this.startTime=(new Date()).getTime();this.positionTip(e);
if(this.followMouse)dw_event.add(document,"mousemove",this.trackMouse,true);
this.timer=setInterval("RollTip.rollOut()",10);},rollOut:function(){
var elapsed=(new Date()).getTime()-this.startTime;
if(elapsed<this.showAni){
var cv=this.w-Math.round(Math.pow(this.showAni-elapsed,2)*this.showMult);
this.clipTo(0,cv,this.h,0);}else{this.clipTo(0,this.w,this.h,0);
clearInterval(this.timer);
this.timer=0;}},conceal:function(){
if(this.timer){clearTimeout(this.timer);this.timer=0;}
this.startTime=(new Date()).getTime();
if(this.followMouse)dw_event.remove(document,"mousemove",this.trackMouse,true);
this.timer=setInterval("RollTip.rollUp()",10);},rollUp:function(){
var elapsed=(new Date()).getTime()-this.startTime;
if(elapsed<this.hideAni){var cv=Math.round(Math.pow(this.hideAni-elapsed,2)*this.hideMult);
this.clipTo(0,cv,this.h,0);}else{this.clipTo(0,0,this.h,0);
clearInterval(this.timer);
this.timer=0;this.tip=null;}},writeTip:function(msg){
if(this.tip&&typeof this.tip.innerHTML!="undefined")this.tip.innerHTML=msg;},clipTo:function(top,rt,btm,lft){
if(this.tip&&this.tip.style)this.tip.style.clip="rect("+top+"px, "+rt+"px, "+btm+"px, "+lft+"px)";}};
var dw_Inf={};
dw_Inf.fn=function(v){
return eval(v)};
RollTip.positionTip=function(e){
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;}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+"px";
this.tip.style.top=y+"px";};
dw_Inf.x0=function(){
dw_Inf.ready=true;
RollTip.rtready=true;
};
RollTip.trackMouse=function(e){
e=dw_event.DOMit(e);RollTip.positionTip(e);};
dw_Inf.x0();
