DOM = (document.getElementById)? true : false;
NN = (document.layers)? true : false;
IE = (document.all)? true : false;
if (IE) DOM=false;
//alert(DOM+' '+NN+' '+IE);

var showflag=false; // флаг показа
var id=null; // id таймера
var onname=""; // им€ видимого на данный момент элемента




function getRelLeft(which) {
	if (NN) {
		return document.layers[which].pageX;
	} else {
		var elem = (DOM)? document.getElementById(which) : document.all[which];
		var pos = elem.offsetLeft;
		while (elem.offsetParent != null) {
			elem = elem.offsetParent;
			pos += elem.offsetLeft;
			if (elem.tagName == 'BODY') break;
		} return pos;
	}
}

function getRelTop(which) {
	if (NN) {
		return document.layers[which].pageY;
	} else {
		var elem = (DOM)? document.getElementById(which) : document.all[which];
		var pos = elem.offsetTop;
		while (elem.offsetParent != null) {
			elem = elem.offsetParent;
			pos += elem.offsetTop;
			if (elem.tagName == 'BODY') break;
		} return pos;
	}
}

function mousePageXY(e)
{
  x = 0;
  y = 0;

  if (!e) e = window.event;

  if (e.pageX || e.pageY)
  {
    x = e.pageX;
    y = e.pageY;
  }
  else if (e.clientX || e.clientY)
  {
    x = e.clientX + (document.documentElement.scrollLeft || document.body.scrollLeft) - document.documentElement.clientLeft;
    y = e.clientY + (document.documentElement.scrollTop || document.body.scrollTop) - document.documentElement.clientTop;
  }
//alert (x);
  return {"x":x, "y":y};
  
}
document.onmousemove = function(e){mCur = mousePageXY(e);};
function showitem(name, item, content){ // name - id элемента x - смещение от начала меню

var div_container = document.getElementById('info');
div_container.innerHTML = content;

bodyWidth=document.body.clientWidth;
blockWidth=document.getElementById(name).clientWidth;

x=mCur.x;
y=mCur.y+15;

if ((blockWidth+x)>bodyWidth) {
  x=x-((blockWidth+x)-bodyWidth+10);
} 


killtimer(); // останавливаем таймер
if(showflag) hide2(); // пр€чем, если показывали другой элемент

if(NN){
document.layers[name].top=y;
document.layers[name].left=x; // вычисл€ем смещение
document.layers[name].visibility='show';

}

if(DOM){
document.getElementById(name).style.top=y;
document.getElementById(name).style.left=x; // вычисл€ем смещение
document.getElementById(name).style.visibility = "visible";
}

if(IE){
document.all[name].style.top=y;
document.all[name].style.left=x;
document.all[name].style.visibility='visible';
}

showflag=true;
onname=name; // элемент name показываетс€

}

function killtimer(){

if(id!=null){ // если таймер установлен

clearTimeout(id); // он обнул€етс€
id=null;
}
return true;
}

function hide2(){

if(id!=null) killtimer();

if(showflag){

if(NN) document.layers[onname].visibility='hide';
if(DOM) document.getElementById(onname).style.visibility='hidden';
if (IE) document.all[onname].style.visibility='hidden';
}

showflag=false;
onname="";

}

function reset(){ // функци€ закрыти€ элемента через полсекунды

killtimer();
id = setTimeout('hide()', 1000);
}



