/*************************************************************************
 ** mmMenu.js 20 MAR 2002 Version 6.0                                   **
 ** Andy Finnell, March 2002                                            **
 ** Copyright (c) 2000-2002 Macromedia, Inc.                            **
 **                                                                     **
 ** Based on menu.js                                                    **
 ** by gary smith, July 1997                                            **
 ** Copyright (c) 1997-1999 Netscape Communications Corp.               **
 **                                                                     **
 ** Netscape grants you a royalty free license to use or modify this    **
 ** software provided that this copyright notice appears on all copies. **
 ** This software is provided "AS IS," without a warranty of any kind.  **
 ************************************************************************/

function Menu(label, mw, mh, fnt, fs, fclr, fhclr, bg, bgh, halgn, valgn, pad, space, to, sx, sy, srel, opq, vert, idt, aw, ah) {
    this.version = "020320 [Menu; mm_menu.js]";
    this.type = "Menu";
    this.menuWidth = mw;
    this.menuItemHeight = mh;
    this.fontFamily = fnt;
    this.fontSize = fs;
    this.fontWeight = "plain";
    this.fontColor = fclr;
    this.fontColorHilite = fhclr;
    this.bgColor = "#6495DE";
    this.menuBorder = 1;
    this.menuBgOpaque=opq;
    this.menuItemBorder = 1;
    this.menuItemIndent = idt;
    this.menuItemBgColor = bg;
    this.menuItemVAlign = valgn;
    this.menuItemHAlign = halgn;
    this.menuItemPadding = pad;
    this.menuItemSpacing = space;
    this.menuLiteBgColor = "#ffffff";
    this.menuBorderBgColor = "#777777";
    this.menuHiliteBgColor = bgh;
    this.menuContainerBgColor = "#cccccc";
    this.childMenuIcon = "arrows.gif";
    this.submenuXOffset = sx;
    this.submenuYOffset = sy;
    this.submenuRelativeToItem = srel;
    this.vertical = vert;
    this.items = new Array();
    this.actions = new Array();
    this.childMenus = new Array();
    this.hideOnMouseOut = true;
    this.hideTimeout = to;
    this.addMenuItem = addMenuItem;
    this.writeMenus = writeMenus;
    this.showMenu = showMenu;
    this.onMenuItemOver = onMenuItemOver;
    this.onMenuItemAction = onMenuItemAction;
    this.hideMenu = hideMenu;
    this.hideChildMenu = hideChildMenu;
    if (!window.menus) window.menus = new Array();
    this.label = " " + label;
    window.menus[this.label] = this;
    window.menus[window.menus.length] = this;
    if (!window.activeMenus) window.activeMenus = new Array();
}

function addMenuItem(label, action) {
    this.items[this.items.length] = label;
    this.actions[this.actions.length] = action;
}

function find(item) {
  if (window.mmIsOpera ) return(document.getElementById(item));
  if (document.all) return(document.all[item]);
  if (document.getElementById) return(document.getElementById(item));
  return(false);
}

function writeMenus(container) {
    if (window.triedToWriteMenus) return;
    var agt = navigator.userAgent.toLowerCase();
    window.mmIsOpera = agt.indexOf("opera") != -1;
    if (!container && document.layers) {
        window.delayWriteMenus = this.writeMenus;
        var timer = setTimeout('delayWriteMenus()', 500);
        container = new Layer(100);
        clearTimeout(timer);
    } else if (document.all || document.hasChildNodes || window.mmIsOpera) {
        document.writeln('<span id="menuContainer"></span>');
        container = find("menuContainer");
    }

    window.hideMenuTimer = null;
    if (!container) return;	
    window.triedToWriteMenus = true; 
    container.isContainer = true;
    container.menus = new Array();
    for (var i=0; i<window.menus.length; i++) container.menus[i] = window.menus[i];
    window.menus.length = 0;
    var countMenus = 0;
    var countItems = 0;
    var top = 0;
    var content = '';
    var lrs = false;
    var theStat = "";
    var tsc = 0;
    if (document.layers) lrs = true;
    for (var i=0; i<container.menus.length; i++, countMenus++) {
        var aMenu = container.menus[i];
        if (aMenu.bgImageUp || !aMenu.menuBgOpaque) {
            aMenu.menuBorder = 0;
            aMenu.menuItemBorder = 0;
        }
        if (lrs) {
            var menuLayer = new Layer(100, container);
            var lite = new Layer(100, menuLayer);
            lite.top = aMenu.menuBorder;
            lite.left = aMenu.menuBorder;
            var body = new Layer(100, lite);
            body.top = aMenu.menuBorder;
            body.left = aMenu.menuBorder;
        } else {
            content += ''+
            '<div id="menuLayer'+ countMenus +'" style="position:absolute;z-index:1;left:10px;top:'+ (i * 100) +'px;visibility:hidden;color:' +  aMenu.menuBorderBgColor + ';">\n'+
            '  <div id="menuLite'+ countMenus +'" style="position:absolute;z-index:1;left:'+ aMenu.menuBorder +'px;top:'+ aMenu.menuBorder +'px;visibility:hide;" onmouseout="mouseoutMenu();">\n'+
            '	 <div id="menuFg'+ countMenus +'" style="position:absolute;left:'+ aMenu.menuBorder +'px;top:'+ aMenu.menuBorder +'px;visibility:hide;">\n'+
	    '';
	}
        var x=i;
        for (var i=0; i<aMenu.items.length; i++) {
            var item = aMenu.items[i];
            var childMenu = false;
            var defaultHeight = aMenu.fontSize+2*aMenu.menuItemPadding;
            if (item.label) {
                item = item.label;
                childMenu = true;
	    }
	    aMenu.menuItemHeight = aMenu.menuItemHeight || defaultHeight;
	    var itemProps = '';
	    if (aMenu.fontFamily != '') itemProps += 'font-family:' + aMenu.fontFamily +';';
	    itemProps += 'font-weight:' + aMenu.fontWeight + ';fontSize:' + aMenu.fontSize + 'px;';
	    if (aMenu.fontStyle) itemProps += 'font-style:' + aMenu.fontStyle + ';';
	    if (document.all || window.mmIsOpera) itemProps += 'font-size:' + aMenu.fontSize + 'px;" onmouseover="onMenuItemOver(null,this);" onclick="onMenuItemAction(null,this);';
            else if (!document.layers) {
               itemProps += 'font-size:' + aMenu.fontSize + 'px;';
	    }
	    var l;
	    if (lrs) {
                var lw = aMenu.menuWidth;
                if (aMenu.menuItemHAlign == 'right') lw -= aMenu.menuItemPadding;
                l = new Layer(lw,body);
	    }
	    var itemLeft = 0;
	    var itemTop = i*aMenu.menuItemHeight;
	    if (!aMenu.vertical) {
	        itemLeft = i*aMenu.menuWidth;
	        itemTop = 0;
	    }
	    var dTag = '<div id="menuItem'+ countItems +'" style="position:absolute;left:' + itemLeft + 'px;top:'+ itemTop +'px;'+ itemProps +'">';
	    var dClose = '</div>'
	    if (aMenu.bgImageUp) dTag = '<div id="menuItem'+ countItems +'" style="background:url('+aMenu.bgImageUp+');position:absolute;left:' + itemLeft + 'px;top:'+ itemTop +'px;'+ itemProps +'">';

            var left = 0, top = 0, right = 0, bottom = 0;
            left = 1 + aMenu.menuItemPadding + aMenu.menuItemIndent;
            right = left + aMenu.menuWidth - 2*aMenu.menuItemPadding - aMenu.menuItemIndent;
            if (aMenu.menuItemVAlign == 'top') top = aMenu.menuItemPadding;
            if (aMenu.menuItemVAlign == 'bottom') top = aMenu.menuItemHeight-aMenu.fontSize-1-aMenu.menuItemPadding;
            if (aMenu.menuItemVAlign == 'middle') top = ((aMenu.menuItemHeight/2)-(aMenu.fontSize/2)-1);
            bottom = aMenu.menuItemHeight - 2*aMenu.menuItemPadding;
            var textProps = 'position:absolute;left:' + left + 'px;top:' + top + 'px;';
            if (lrs) {
                textProps +=itemProps + 'right:' + right + ';bottom:' + bottom + ';';
	        dTag = "";
	        dClose = "";
	    }
	
            if (document.all && !window.mmIsOpera) {
                item = '<div align="' + aMenu.menuItemHAlign + '">' + item + '</div>';
            } else if (lrs) {
                item = '<div style="text-align:' + aMenu.menuItemHAlign + ';">' + item + '</div>';
            } else {
                var hitem = null;
                if (aMenu.menuItemHAlign != 'left') {
                    if (window.mmIsOpera) {
                        var operaWidth = aMenu.menuItemHAlign == 'center' ? -(aMenu.menuWidth-2*aMenu.menuItemPadding) : (aMenu.menuWidth-6*aMenu.menuItemPadding);
                        hitem = '<div id="menuItemHilite' + countItems + 'Shim" style="position:absolute;top:1px;left:' + aMenu.menuItemPadding + 'px;width:' + operaWidth + 'px;text-align:' 
                                + aMenu.menuItemHAlign + ';visibility:visible;">' + item + '</div>';
                        item = '<div id="menuItemText' + countItems + 'Shim" style="position:absolute;top:1px;left:' + aMenu.menuItemPadding + 'px;width:' + operaWidth + 'px;text-align:' 
                                + aMenu.menuItemHAlign + ';visibility:visible;">' + item + '</div>';
		    } else {
		        hitem = '<div id="menuItemHilite' + countItems + 'Shim" style="position:absolute;top:1px;left:1px;right:-' + (left+aMenu.menuWidth-3*aMenu.menuItemPadding) + 'px;text-align:' 
                                + aMenu.menuItemHAlign + ';visibility:visible;">' + item + '</div>';
                        item = '<div id="menuItemText' + countItems + 'Shim" style="position:absolute;top:1px;left:1px;right:-' + (left+aMenu.menuWidth-3*aMenu.menuItemPadding) + 'px;text-align:' 
                                + aMenu.menuItemHAlign + ';visibility:visible;">' + item + '</div>';
	            }
                } else hitem = null;
	    }
            
            if (document.all && !window.mmIsOpera) item = '<div id="menuItemShim' + countItems + '" style="position:absolute;left:0px;top:0px;">' + item + '</div>';
            var dText = '<div id="menuItemText'+ countItems +'" style="' + textProps + 'color:'+ aMenu.fontColor +';">'+ item +'&nbsp</div>\n'
                        + '<div id="menuItemHilite'+ countItems +'" style="' + textProps + 'color:'+ aMenu.fontColorHilite +';visibility:hidden;">' 
                        + (hitem||item) +'&nbsp</div>';
            if (childMenu) content += ( dTag + dText + '<div id="childMenu'+ countItems +'" style="position:absolute;left:0px;top:3px;"><img src="'+ aMenu.childMenuIcon +'"></div>\n' + dClose);
            else content += ( dTag + dText + dClose);
            if (lrs) {
                l.document.open("text/html");
                l.document.writeln(content);
                l.document.close();	
                content = '';
                theStat += "-";
	        tsc++;
                if (tsc > 50) {
		    tsc = 0;
	            theStat = "";
	        }
                status = theStat;
	    }
            countItems++;  
        }
        if (lrs) {
            var focusItem = new Layer(100, body);
            focusItem.visiblity="hidden";
            focusItem.document.open("text/html");
            focusItem.document.writeln("&nbsp;");
            focusItem.document.close();	
        } else {
            content += '	  <div id="focusItem'+ countMenus +'" style="position:absolute;left:0px;top:0px;visibility:hide;" onclick="onMenuItemAction(null,this);">&nbsp;</div>\n';
            content += '   </div>\n  </div>\n</div>\n';
        }
        i=x;
    }
    if (document.layers) {		
        container.clip.width = window.innerWidth;
        container.clip.height = window.innerHeight;
        container.onmouseout = mouseoutMenu;
        container.menuContainerBgColor = this.menuContainerBgColor;
        for (var i=0; i<container.document.layers.length; i++) {
            proto = container.menus[i];
       	    var aMenu = container.document.layers[i];
            container.menus[i].menuLayer = aMenu;
            container.menus[i].menuLayer.Menu = container.menus[i];
            container.menus[i].menuLayer.Menu.container = container;
            var body = aMenu.document.layers[0].document.layers[0];
            body.clip.width = proto.menuWidth || body.clip.width;
            body.clip.height = proto.menuHeight || body.clip.height;
            for (var n=0; n<body.document.layers.length-1; n++) {
                var l = body.document.layers[n];
                l.Menu = container.menus[i];
                l.menuHiliteBgColor = proto.menuHiliteBgColor;
                l.document.bgColor = proto.menuItemBgColor;
                l.saveColor = proto.menuItemBgColor;
                l.onmouseover = proto.onMenuItemOver;
                l.onclick = proto.onMenuItemAction;
                l.mmaction = container.menus[i].actions[n];
                l.focusItem = body.document.layers[body.document.layers.length-1];
                l.clip.width = proto.menuWidth || body.clip.width;
                l.clip.height = proto.menuItemHeight || l.clip.height;
	        if (n>0) {
	    	    if (l.Menu.vertical) l.top = body.document.layers[n-1].top + body.document.layers[n-1].clip.height + proto.menuItemBorder + proto.menuItemSpacing;
	    	    else l.left = body.document.layers[n-1].left + body.document.layers[n-1].clip.width + proto.menuItemBorder + proto.menuItemSpacing;
	        }
	        l.hilite = l.document.layers[1];
	        if (proto.bgImageUp) l.background.src = proto.bgImageUp;
	        l.document.layers[1].isHilite = true;
	        if (l.document.layers.length > 2) {
	    	    l.childMenu = container.menus[i].items[n].menuLayer;
	    	    l.document.layers[2].left = l.clip.width - 13;
	    	    l.document.layers[2].top = (l.clip.height / 2) - 4;
	    	    l.document.layers[2].clip.left += 3;
	    	    l.Menu.childMenus[l.Menu.childMenus.length] = l.childMenu;
	        }
	    }
	    if (proto.menuBgOpaque) body.document.bgColor = proto.bgColor;
	    if (proto.vertical) {
	        body.clip.width  = l.clip.width + proto.menuBorder;
	        body.clip.height = l.top + l.clip.height +proto.menuBorder;
            } else {
                body.clip.height  = l.clip.height +proto.menuBorder;
                body.clip.width = l.left + l.clip.width + proto.menuBorder;
                if (body.clip.width > window.innerWidth) body.clip.width = window.innerWidth;
	    }
	    var focusItem = body.document.layers[n];
	    focusItem.clip.width = body.clip.width;
	    focusItem.Menu = l.Menu;
	    focusItem.top = -30;
	    focusItem.captureEvents(Event.MOUSEDOWN);
	    focusItem.onmousedown = onMenuItemDown;
	    if (proto.menuBgOpaque) aMenu.document.bgColor = proto.menuBorderBgColor;
	    var lite = aMenu.document.layers[0];
	    if (proto.menuBgOpaque) lite.document.bgColor = proto.menuLiteBgColor;
            lite.clip.width = body.clip.width + 1;
            lite.clip.height = body.clip.height + 1;
            aMenu.clip.width = body.clip.width + (proto.menuBorder * 3) ;
            aMenu.clip.height = body.clip.height + (proto.menuBorder * 3);
        }
    } else {
        if ((!document.all) && (container.hasChildNodes) && !window.mmIsOpera) {
            container.innerHTML=content;
        } else {
            container.document.open("text/html");
            container.document.writeln(content);
            container.document.close();	
      	}
        if (!find("menuLayer0")) return;
        var menuCount = 0;
        for (var x=0; x<container.menus.length; x++) {
            var menuLayer = find("menuLayer" + x);
            container.menus[x].menuLayer = "menuLayer" + x;
            menuLayer.Menu = container.menus[x];
            menuLayer.Menu.container = "menuLayer" + x;
            menuLayer.style.zindex = 1;
            var s = menuLayer.style;
            s.pixeltop = -300;
            s.pixelleft = -300;
            s.top = '-300px';
            s.left = '-300px';
               
            var aMenu = container.menus[x];
            aMenu.menuItemWidth = aMenu.menuWidth || aMenu.menuIEWidth || 140;
            if (aMenu.menuBgOpaque) menuLayer.style.backgroundColor = aMenu.menuBorderBgColor;
            var top = 0;
            var left = 0;
            aMenu.menuItemLayers = new Array();
            for (var i=0; i<container.menus[x].items.length; i++) {
                var l = find("menuItem" + menuCount);
                l.Menu = container.menus[x];
                l.Menu.menuItemLayers[l.Menu.menuItemLayers.length] = l;
                if (l.addEventListener || window.mmIsOpera) {
                    l.style.width = aMenu.menuItemWidth + 'px';
                    l.style.height = aMenu.menuItemHeight + 'px';
                    l.style.pixelWidth = aMenu.menuItemWidth;
                    l.style.pixelHeight = aMenu.menuItemHeight;
                    l.style.top = top + 'px';
                    l.style.left = left + 'px';
                    if (l.addEventListener) {
                        l.addEventListener("mouseover", onMenuItemOver, false);
                        l.addEventListener("click", onMenuItemAction, false);
                        l.addEventListener("mouseout", mouseoutMenu, false);
	            }
		    if (aMenu.menuItemHAlign != 'left') {
		        l.hiliteShim = find("menuItemHilite" + menuCount + "Shim");
		        l.hiliteShim.style.visibility = "inherit";
		        l.textShim = find("menuItemText" + menuCount + "Shim");
		        l.hiliteShim.style.pixelWidth = aMenu.menuItemWidth - 2*aMenu.menuItemPadding - aMenu.menuItemIndent;
		        l.hiliteShim.style.width = l.hiliteShim.style.pixelWidth;
		        l.textShim.style.pixelWidth = aMenu.menuItemWidth - 2*aMenu.menuItemPadding - aMenu.menuItemIndent;
		        l.textShim.style.width = l.textShim.style.pixelWidth;	
		    }
	        } else {
	            l.style.pixelWidth = aMenu.menuItemWidth;
	            l.style.pixelHeight = aMenu.menuItemHeight;
	            l.style.pixelTop = top;
	            l.style.pixelLeft = left;
	            if (aMenu.menuItemHAlign != 'left') {
                        var shim = find("menuItemShim" + menuCount);
                        shim[0].style.pixelWidth = aMenu.menuItemWidth - 2*aMenu.menuItemPadding - aMenu.menuItemIndent;
                        shim[1].style.pixelWidth = aMenu.menuItemWidth - 2*aMenu.menuItemPadding - aMenu.menuItemIndent;
                        shim[0].style.width = shim[0].style.pixelWidth + 'px';
                        shim[1].style.width = shim[1].style.pixelWidth + 'px';
		    }
	        }
	        if (aMenu.vertical) top = top + aMenu.menuItemHeight+aMenu.menuItemBorder+aMenu.menuItemSpacing;
                else left = left + aMenu.menuItemWidth+aMenu.menuItemBorder+aMenu.menuItemSpacing;
                l.style.fontSize = aMenu.fontSize + 'px';
                l.style.backgroundColor = aMenu.menuItemBgColor;
                l.style.visibility = "inherit";
                l.saveColor = aMenu.menuItemBgColor;
                l.menuHiliteBgColor = aMenu.menuHiliteBgColor;
                l.mmaction = container.menus[x].actions[i];
                l.hilite = find("menuItemHilite" + menuCount);
                l.focusItem = find("focusItem" + x);
                l.focusItem.style.pixelTop = -30;
                l.focusItem.style.top = '-30px';
                var childItem = find("childMenu" + menuCount);
                if (childItem) {
                    l.childMenu = container.menus[x].items[i].menuLayer;
                    childItem.style.pixelLeft = aMenu.menuItemWidth -11;
                    childItem.style.left = childItem.style.pixelLeft + 'px';
                    childItem.style.pixelTop = (aMenu.menuItemHeight /2) -4;
                    childItem.style.top = childItem.style.pixelTop + 'px';
                    l.Menu.childMenus[l.Menu.childMenus.length] = l.childMenu;
	        }
	        l.style.cursor = "hand";
	        menuCount++;
            }
            if (aMenu.vertical) {
               	aMenu.menuHeight = top-1-aMenu.menuItemSpacing;
               	aMenu.menuWidth = aMenu.menuItemWidth;
            } else {
            	aMenu.menuHeight = aMenu.menuItemHeight;
            	aMenu.menuWidth = left-1-aMenu.menuItemSpacing;
	    }

            var lite = find("menuLite" + x);
            var s = lite.style;
            s.pixelHeight = aMenu.menuHeight +(aMenu.menuBorder * 2);
            s.height = s.pixelHeight + 'px';
            s.pixelWidth = aMenu.menuWidth + (aMenu.menuBorder * 2);
            s.width = s.pixelWidth + 'px';
            if (aMenu.menuBgOpaque) s.backgroundColor = aMenu.menuLiteBgColor;

            var body = find("menuFg" + x);
            s = body.style;
            s.pixelHeight = aMenu.menuHeight + aMenu.menuBorder;
            s.height = s.pixelHeight + 'px';
            s.pixelWidth = aMenu.menuWidth + aMenu.menuBorder;
            s.width = s.pixelWidth + 'px';
            if (aMenu.menuBgOpaque) s.backgroundColor = aMenu.bgColor;
                
            s = menuLayer.style;
            s.pixelWidth  = aMenu.menuWidth + (aMenu.menuBorder * 4);
            s.width = s.pixelWidth + 'px';
            s.pixelHeight  = aMenu.menuHeight+(aMenu.menuBorder*4);
            s.height = s.pixelHeight + 'px';
        }
    }
    if (document.captureEvents) document.captureEvents(Event.MOUSEUP);
    if (document.addEventListener) document.addEventListener("mouseup", onMenuItemOver, false);
    if (document.layers && window.innerWidth) {
        window.onresize = NS4resize;
        window.NS4sIW = window.innerWidth;
        window.NS4sIH = window.innerHeight;
        setTimeout("NS4resize()",500);
    }
    document.onmouseup = mouseupMenu;
    window.mmWroteMenu = true;
    status = "";
}

function NS4resize() {
    if (NS4sIW != window.innerWidth || NS4sIH != window.innerHeight) window.location.reload();
}

function onMenuItemOver(e, l) {
    clearTimeout();
    l = l || this;
    var a = window.ActiveMenuItem;
    if (document.layers) {
        if (a) {
            a.document.bgColor = a.saveColor;
            if (a.hilite) a.hilite.visibility = "hidden";
            if (a.Menu.bgImageOver) a.background.src = a.Menu.bgImageUp;
            a.focusItem.top = -100;
            a.clicked = false;
	}
	if (l.hilite) {
	    l.document.bgColor = l.menuHiliteBgColor;
	    l.zIndex = 1;
	    l.hilite.visibility = "inherit";
	    l.hilite.zIndex = 2;
	    l.document.layers[1].zIndex = 1;
	    l.focusItem.zIndex = this.zIndex +2;
	}
        if (l.Menu.bgImageOver) l.background.src = l.Menu.bgImageOver;
        l.focusItem.top = this.top;
        l.focusItem.left = this.left;
        l.focusItem.clip.width = l.clip.width;
        l.focusItem.clip.height = l.clip.height;
        l.Menu.hideChildMenu(l);
    } else if (l.style && l.Menu) {
        if (a) {
            a.style.backgroundColor = a.saveColor;
            if (a.hilite) a.hilite.style.visibility = "hidden";
            if (a.hiliteShim) a.hiliteShim.style.visibility = "inherit";
            if (a.Menu.bgImageUp) a.style.background = "url(" + a.Menu.bgImageUp +")";;
	} 
	l.style.backgroundColor = l.menuHiliteBgColor;
	l.zIndex = 1;
	if (l.Menu.bgImageOver) l.style.background = "url(" + l.Menu.bgImageOver +")";
        if (l.hilite) {
            l.hilite.style.visibility = "inherit";
            if (l.hiliteShim) l.hiliteShim.style.visibility = "visible";
	}
        l.focusItem.style.pixelTop = l.style.pixelTop;
        l.focusItem.style.top = l.focusItem.style.pixelTop + 'px';
        l.focusItem.style.pixelLeft = l.style.pixelLeft;
        l.focusItem.style.left = l.focusItem.style.pixelLeft + 'px';
        l.focusItem.style.zIndex = l.zIndex +1;
        l.Menu.hideChildMenu(l);
    } else return;
    window.ActiveMenuItem = l;
}

function onMenuItemAction(e, l) {
    l = window.ActiveMenuItem;
    if (!l) return;
    hideActiveMenus();
    if (l.mmaction) eval("" + l.mmaction);
    window.ActiveMenuItem = 0;
}

function clearTimeout() {
    hideMenuTimer = null;
    mmDHFlag = false;
}

function startTimeout() {
    if (window.ActiveMenu) {
       mmStart = new Date();
       mmDHFlag = true;
       hideMenuTimer = setTimeout("mmDoHide()", window.ActiveMenu.Menu.hideTimeout);
    }
}

function mmDoHide() {
    if (!mmDHFlag || !window.ActiveMenu) return;
    var elapsed = new Date() - mmStart;
    var timeout = window.ActiveMenu.Menu.hideTimeout;
    if (elapsed < timeout) {
        hideMenuTimer = setTimeout("mmDoHide()", timeout+100-elapsed);
        return;
    }
    mmDHFlag = false;
    hideActiveMenus();
    window.ActiveMenuItem = 0;
}

function showMenu(aMenu, x, y, child, imgname) {
    if (!window.mmWroteMenu) return;
    clearTimeout();
    if (aMenu) {
        var obj = find(imgname) || document.images[imgname] || document.links[imgname] || document.anchors[imgname];
        x = moveXbySlicePos(x, obj);
        y = moveYbySlicePos(y, obj);
    }
    if (document.layers) {
        if (aMenu) {
            var l = aMenu.menuLayer || aMenu;
            l.top = l.left = 1;
            hideActiveMenus();
            if (this.visibility) l = this;
            window.ActiveMenu = l;
        } else {
            var l = child;
	}
        if (!l) return;
        for (var i=0; i<l.layers.length; i++) { 			   
            if (!l.layers[i].isHilite) l.layers[i].visibility = "inherit";
            if (l.layers[i].document.layers.length > 0) showMenu(null, "relative", "relative", l.layers[i]);
	}
        if (l.parentLayer) {
            if (x != "relative") l.parentLayer.left = x || window.pageX || 0;
            if (l.parentLayer.left + l.clip.width > window.innerWidth) l.parentLayer.left -= (l.parentLayer.left + l.clip.width - window.innerWidth);
            if (y != "relative") l.parentLayer.top = y || window.pageY || 0;
            if (l.parentLayer.isContainer) {
                l.Menu.xOffset = window.pageXOffset;
                l.Menu.yOffset = window.pageYOffset;
                l.parentLayer.clip.width = window.ActiveMenu.clip.width +2;
                l.parentLayer.clip.height = window.ActiveMenu.clip.height +2;
                if (l.parentLayer.menuContainerBgColor && l.Menu.menuBgOpaque ) l.parentLayer.document.bgColor = l.parentLayer.menuContainerBgColor;
	    }
        }
        l.visibility = "inherit";
        if (l.Menu) l.Menu.container.visibility = "inherit";
    } else if (find("menuItem0")) {
        var l = aMenu.menuLayer || aMenu;	
        hideActiveMenus();
        if (typeof(l) == "string") l = find(l);
        window.ActiveMenu = l;
        var s = l.style;
        s.visibility = "inherit";
        if (x != "relative") {
        s.pixelLeft = x || (window.pageX + document.body.scrollLeft) || 0;
        s.left = s.pixelLeft + 'px';
        	}
        if (y != "relative") {
            s.pixelTop = y || (window.pageY + document.body.scrollTop) || 0;
            s.top = s.pixelTop + 'px';
        }
        l.Menu.xOffset = document.body.scrollLeft;
        l.Menu.yOffset = document.body.scrollTop;
    }
    if (aMenu) window.activeMenus[window.activeMenus.length] = l;
    clearTimeout();
}

function onMenuItemDown(e, l) {
    var a = window.ActiveMenuItem;
    if (document.layers && a) {
        a.eX = e.pageX;
        a.eY = e.pageY;
        a.clicked = true;
    }
}

function mouseupMenu(e) {
    hideMenu(true, e);
    hideActiveMenus();
    return true;
}

function getExplorerVersion() {
    var ieVers = parseFloat(navigator.appVersion);
    if (navigator.appName != 'Microsoft Internet Explorer' ) return ieVers;
    var tempVers = navigator.appVersion;
    var i = tempVers.indexOf( 'MSIE ' );
    if (i >= 0) {
        tempVers = tempVers.substring( i+5 );
        ieVers = parseFloat( tempVers ); 
    }
    return ieVers;
}

function mouseoutMenu() {
    if ((navigator.appName == "Microsoft Internet Explorer") && (getExplorerVersion() < 4.5)) return true;
    hideMenu(false, false);
    return true;
}

function hideMenu(mouseup, e) {
    var a = window.ActiveMenuItem;
    if (a && document.layers) {
        a.document.bgColor = a.saveColor;
        a.focusItem.top = -30;
        if (a.hilite) a.hilite.visibility = "hidden";
        if (mouseup && a.mmaction && a.clicked && window.ActiveMenu) {
	    if (a.eX <= e.pageX+15 && a.eX >= e.pageX-15 && a.eY <= e.pageY+10 && a.eY >= e.pageY-10) {
                setTimeout('window.ActiveMenu.Menu.onMenuItemAction();', 500);
	    }
	}
        a.clicked = false;
        if (a.Menu.bgImageOver) a.background.src = a.Menu.bgImageUp;
    } else if (window.ActiveMenu && find("menuItem0")) {
        if (a) {
            a.style.backgroundColor = a.saveColor;
            if (a.hilite) a.hilite.style.visibility = "hidden";
            if (a.hiliteShim) a.hiliteShim.style.visibility = "inherit";
            if (a.Menu.bgImageUp) a.style.background = "url(" + a.Menu.bgImageUp +")";
	}
    }
    if (!mouseup && window.ActiveMenu) {
        if (window.ActiveMenu.Menu) {
            if (window.ActiveMenu.Menu.hideOnMouseOut) startTimeout();
	    return true;
        }
    }
    return true;
}

function hideChildMenu(hcmLayer) {
    clearTimeout();
    var l = hcmLayer;
    for (var i=0; i < l.Menu.childMenus.length; i++) {
        var theLayer = l.Menu.childMenus[i];
        if (document.layers) theLayer.visibility = "hidden";
	else {
            theLayer = find(theLayer);
            theLayer.style.visibility = "hidden";
            if (theLayer.Menu.menuItemHAlign != 'left' ) {
                for (var j = 0; j < theLayer.Menu.menuItemLayers.length; j++) {
                    var itemLayer = theLayer.Menu.menuItemLayers[j];
                    if(itemLayer.textShim) itemLayer.textShim.style.visibility = "inherit";
		}
	    }
	}
        theLayer.Menu.hideChildMenu(theLayer);
    }
    if (l.childMenu) {
        var childMenu = l.childMenu;
        if (document.layers) {
            l.Menu.showMenu(null,null,null,childMenu.layers[0]);
            childMenu.zIndex = l.parentLayer.zIndex +1;
            childMenu.top = l.Menu.menuLayer.top + l.Menu.submenuYOffset;
            if (l.Menu.vertical) {
                if (l.Menu.submenuRelativeToItem) childMenu.top += l.top + l.parentLayer.top;
                childMenu.left = l.parentLayer.left + l.parentLayer.clip.width - (2*l.Menu.menuBorder) + l.Menu.menuLayer.left + l.Menu.submenuXOffset;
	    } else {
                childMenu.top += l.top + l.parentLayer.top;	
                if (l.Menu.submenuRelativeToItem) childMenu.left = l.Menu.menuLayer.left + l.left + l.clip.width + (2*l.Menu.menuBorder) + l.Menu.submenuXOffset;
                else childMenu.left = l.parentLayer.left + l.parentLayer.clip.width - (2*l.Menu.menuBorder) + l.Menu.menuLayer.left + l.Menu.submenuXOffset;
	    }
            if (childMenu.left < l.Menu.container.clip.left) l.Menu.container.clip.left = childMenu.left;
            var w = childMenu.clip.width+childMenu.left-l.Menu.container.clip.left;
            if (w > l.Menu.container.clip.width)  l.Menu.container.clip.width = w;
            var h = childMenu.clip.height+childMenu.top-l.Menu.container.clip.top;
            if (h > l.Menu.container.clip.height) l.Menu.container.clip.height = h;
            l.document.layers[1].zIndex = 0;
            childMenu.visibility = "inherit";
        } else if (find("menuItem0")) {
            childMenu = find(l.childMenu);
            var menuLayer = find(l.Menu.menuLayer);
            var s = childMenu.style;
            s.zIndex = menuLayer.style.zIndex+1;
            if (document.all || window.mmIsOpera) {
                s.pixelTop = menuLayer.style.pixelTop + l.Menu.submenuYOffset;
                if (l.Menu.vertical) {
                    if (l.Menu.submenuRelativeToItem) s.pixelTop += l.style.pixelTop;
                    s.pixelLeft = l.style.pixelWidth + menuLayer.style.pixelLeft + l.Menu.submenuXOffset;
                    s.left = s.pixelLeft + 'px';
		} else {
                    s.pixelTop += l.style.pixelTop;
                    if (l.Menu.submenuRelativeToItem) s.pixelLeft = menuLayer.style.pixelLeft + l.style.pixelLeft + l.style.pixelWidth + (2*l.Menu.menuBorder) + l.Menu.submenuXOffset;
                    else s.pixelLeft = (menuLayer.style.pixelWidth-4*l.Menu.menuBorder) + menuLayer.style.pixelLeft + l.Menu.submenuXOffset;
                    s.left = s.pixelLeft + 'px';
		}
	    } else {
		var top = parseInt(menuLayer.style.top) + l.Menu.submenuYOffset;
		var left = 0;
		if (l.Menu.vertical) {
		    if (l.Menu.submenuRelativeToItem) top += parseInt(l.style.top);
		    left = (parseInt(menuLayer.style.width)-4*l.Menu.menuBorder) + parseInt(menuLayer.style.left) + l.Menu.submenuXOffset;
		} else {
		    top += parseInt(l.style.top);
		    if (l.Menu.submenuRelativeToItem) left = parseInt(menuLayer.style.left) + parseInt(l.style.left) + parseInt(l.style.width) + (2*l.Menu.menuBorder) + l.Menu.submenuXOffset;
                    else left = (parseInt(menuLayer.style.width)-4*l.Menu.menuBorder) + parseInt(menuLayer.style.left) + l.Menu.submenuXOffset;
		}
		s.top = top + 'px';
		s.left = left + 'px';
	    }
	    childMenu.style.visibility = "inherit";
        } else return;
        window.activeMenus[window.activeMenus.length] = childMenu;
    }
}

function hideActiveMenus() {
    if (!window.activeMenus) return;
    for (var i=0; i < window.activeMenus.length; i++) {
        if (!activeMenus[i]) continue;
        if (activeMenus[i].visibility && activeMenus[i].Menu && !window.mmIsOpera) {
            activeMenus[i].visibility = "hidden";
            activeMenus[i].Menu.container.visibility = "hidden";
            activeMenus[i].Menu.container.clip.left = 0;
        } else if (activeMenus[i].style) {
            var s = activeMenus[i].style;
            s.visibility = "hidden";
            s.left = '-200px';
            s.top = '-200px';
	}
    }
    if (window.ActiveMenuItem) hideMenu(false, false);
    window.activeMenus.length = 0;
}

function moveXbySlicePos(x, img) { 
    if (!document.layers) {
        var onWindows = navigator.platform ? navigator.platform == "Win32" : false;
        var macIE45 = document.all && !onWindows && getExplorerVersion() == 4.5;
        var par = img;
        var lastOffset = 0;
        while (par) {
            if (par.leftMargin && ! onWindows) x += parseInt(par.leftMargin);
            if ((par.offsetLeft != lastOffset) && par.offsetLeft) x += parseInt(par.offsetLeft);
            if (par.offsetLeft != 0) lastOffset = par.offsetLeft;
            par = macIE45 ? par.parentElement : par.offsetParent;
	}
    } else if (img.x) x += img.x;
    return x;
}

function moveYbySlicePos(y, img) {
    if (!document.layers) {
        var onWindows = navigator.platform ? navigator.platform == "Win32" : false;
        var macIE45 = document.all && !onWindows && getExplorerVersion() == 4.5;
        var par = img;
        var lastOffset = 0;
        while (par){
            if (par.topMargin && !onWindows) y += parseInt(par.topMargin);
            if ((par.offsetTop != lastOffset) && par.offsetTop) y += parseInt(par.offsetTop);
            if (par.offsetTop != 0) lastOffset = par.offsetTop;
            par = macIE45 ? par.parentElement : par.offsetParent;
	}		
    } else if (img.y >= 0) y += img.y;
    return y;
}

/****************************************************************************/
function mmLoadMenus() {
    if (window.menu_products) return;
    window.menu_products = new Menu("root",300,25,"times new roman, Arial, Helvetica, sans-serif",18,"#FFFFFF","#F0F046","#6495DE","#003399","left","middle",3,0,500,0,0,true,true,true,11,true,true);
    menu_products.addMenuItem("<a href='../Film_Thickness_Tools.html' class='topmenu'>Product Showcase</a>","null");
    menu_products.addMenuItem("<a href='../Thin_Film_Product/Microspectrophotometer_MSP300.html' class='topmenu'>Microspectrophotometer MSP Series</a>","null");
    menu_products.addMenuItem("<a href='../Thin_Film_Product/Spectroscopic_Reflectometer_SR300.html' class='topmenu'>Spectroscopic Reflectometer SR Series</a>","null");
    menu_products.addMenuItem("<a href='../Thin_Film_Product/Film_Thickness_Mapping_Reflectometer_SRM300.html' class='topmenu'>Film Thickness Mapping System</a>","null");
    menu_products.addMenuItem("<a href='../Thin_Film_Product/Spectroscopic_Ellipsometer_Microspectrophotometer_SE200-MSP.html' class='topmenu'>Spectroscopic Ellipsometer SE Series</a>","null");
    menu_products.addMenuItem("<a href='../Thin_Film_Product/TFProbe_Thin_Film_Software_SW.html' class='topmenu'>TFProbe Software</a>","null");
    //menu_products.addMenuItem("<a href='../Thin_Film_Product/cfm.html' class='topmenu'>Digital Camera Eyepiece</a>","null");
    menu_products.addMenuItem("<a href='../Thin_Film_Product/Accessories.html' class='topmenu'>Accessories</a>","null");
    menu_products.hideOnMouseOut=true;
    menu_products.bgColor='#FFFFFF';
    menu_products.menuBorder=1;
    menu_products.menuLiteBgColor='#FFFFFF';
    menu_products.menuBorderBgColor='#999999';

    //window.menu_services = new Menu("root",220,25,"times new roman, Arial, Helvetica, sans-serif",18,"#FFFFFF","#F0F046","#6495DE","#003399","left","middle",3,0,500,0,0,true,true,true,11,true,true);
    //menu_services.addMenuItem("<a href='../as.html#1' class='topmenu'>Analytical Service</a>","null");
    //menu_services.hideOnMouseOut=true;
    //menu_services.bgColor='#FFFFFF';
    //menu_services.menuBorder=1;
    //menu_services.menuLiteBgColor='#FFFFFF';
    //menu_services.menuBorderBgColor='#999999';
    
    //window.menu_support = new Menu("root",260,25,"times new roman, Arial, Helvetica, sans-serif",18,"#FFFFFF","#F0F046","#6495DE","#003399","left","middle",3,0,500,0,0,true,true,true,11,true,true);
    //menu_support.addMenuItem("<a href='../support.html' class='topmenu'>Frequently Asked Questions</a>","null");
    //menu_support.addMenuItem("<a href='../support.html' class='topmenu'>Download Software</a>","null");
    //menu_support.addMenuItem("<a href='../support.html' class='topmenu'>Brochure and Documentations</a>","null");
    //menu_support.hideOnMouseOut=true;
    //menu_support.bgColor='#FFFFFF';
    //menu_support.menuBorder=1;
    //menu_support.menuLiteBgColor='#FFFFFF';
    //menu_support.menuBorderBgColor='#999999';
    
    window.menu_databases = new Menu("root",250,25,"times new roman, Arial, Helvetica, sans-serif",18,"#FFFFFF","#F0F046","#6495DE","#003399","left","middle",3,0,500,0,0,true,true,true,11,true,true);
    menu_databases.addMenuItem("<a href='../nkDatabase2.jsp' class='topmenu'>Database of Optical Constants</a>","null");
    menu_databases.addMenuItem("<a href='../ellipsometryDatabase2.jsp' class='topmenu'>Ellipsometry Database</a>","null");
    menu_databases.hideOnMouseOut=true;
    menu_databases.bgColor='#FFFFFF';
    menu_databases.menuBorder=1;
    menu_databases.menuLiteBgColor='#FFFFFF';
    menu_databases.menuBorderBgColor='#999999';


    window.menu_publications = new Menu("root",180,25,"times new roman, Arial, Helvetica, sans-serif",18,"#FFFFFF","#F0F046","#6495DE","#003399","left","middle",3,0,500,0,0,true,true,true,9,true,true);
    menu_publications.addMenuItem("<a href='../Ellipsometry_publicationList.html' class='topmenu'>Publication List</a>","null");
    //menu_publications.addMenuItem("<a href='../Ellipsometer_publicationAbstracts.html' class='topmenu'>Publication Abstracts</a>","null");
    menu_publications.addMenuItem("<a href='../Ellipsometer_presentations.html' class='topmenu'>Presentations</a>","null");
    menu_publications.hideOnMouseOut=true;
    menu_publications.bgColor='#FFFFFF';
    menu_publications.menuBorder=1;
    menu_publications.menuLiteBgColor='#FFFFFF';
    menu_publications.menuBorderBgColor='#999999';
    
    menu_publications.writeMenus();
}