var timeout         = 500;
var closetimer		= 500;
var ddmenuitem      = 0;
var subclosetimer		= 500;
var ddsubmenuitem      = 0;
 
// open hidden layer
function mopen(id)
{	
	// cancel close timer
	mcancelclosetime();
 
	// close old layer
	if(ddmenuitem) ddmenuitem.style.visibility = 'hidden';
 
	// get new layer and show it
	ddmenuitem = document.getElementById(id);
	ddmenuitem.style.visibility = 'visible';
 
}
// close showed layer
function mclose()
{
	if(ddmenuitem) ddmenuitem.style.visibility = 'hidden';
}
 
// go close timer
function mclosetime()
{
	closetimer = window.setTimeout(mclose, timeout);
}
 
// cancel close timer
function mcancelclosetime()
{
	if(closetimer)
	{
		window.clearTimeout(closetimer);
		closetimer = null;
	}
}
 
// close layer when click-out
document.onclick = mclose; 


// open hidden layer
function msubopen(id)
{	
	// cancel close timer
	msubcancelclosetime();
 
	// close old layer
	if(ddsubmenuitem) ddsubmenuitem.style.visibility = 'hidden';
 
	// get new layer and show it
	ddsubmenuitem = document.getElementById(id);
	ddsubmenuitem.style.visibility = 'visible';
 
}
// close showed layer
function msubclose()
{
	if(ddsubmenuitem) ddsubmenuitem.style.visibility = 'hidden';
}
 
// go close timer
function msubclosetime()
{
	subclosetimer = window.setTimeout(msubclose, timeout);
}
 
// cancel close timer
function msubcancelclosetime()
{
	if(subclosetimer)
	{
		window.clearTimeout(subclosetimer);
		subclosetimer = null;
	}
}  
