// Copyright 2006-2007 javascript-array.com

var timeout = 500;
var closetimer = 0;
var opentimer = 0;
var ddmenuitem = 0;
var lastid = 0;

// open hidden layer
function mopen(id) {
    // cancel close timer
    mcancelclosetime();

    // close old layer
    if (lastid != id && ddmenuitem) ddmenuitem.style.visibility = 'hidden';

    ddmenuitem = document.getElementById(id);
    opentimer = window.setTimeout(mshow, (timeout));
    lastid = id;
}

function mshow() {

    // get new layer and show it
    //ddmenuitem = document.getElementById(id);
    if (ddmenuitem) {

        ddmenuitem.style.visibility = 'visible';
    }
    window.clearTimeout(opentimer);
    opentimer = null;
}

// close shown layer
function mclose() {
    if (ddmenuitem) ddmenuitem.style.visibility = 'hidden';
    lastid = 0;
}

// go close timer
function mclosetime() {
    mcancelclosetime();
    closetimer = window.setTimeout(mclose, timeout);
    if (opentimer) {
        window.clearTimeout(opentimer);
        opentimer = null;
    }
}

// cancel close timer
function mcancelclosetime() {
    if (closetimer) {
        window.clearTimeout(closetimer);
        closetimer = null;
    }

}

// close layer when click-out
//document.onclick = mclose;

