Rev 1 | Blame | Last modification | View Log | Download
/** * fw_menu 24OCT2000 Version 4.0 * John Ahlquist, October 2000 * Copyright (c) 2000 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) { this.version = "990702 [Menu; menu.js]"; this.type = "Menu"; this.menuWidth = mw; this.menuItemHeight = mh; this.fontSize = fs||12; this.fontWeight = "plain"; this.fontFamily = fnt||"arial,helvetica,verdana,sans-serif"; this.fontColor = fclr||"#000000"; this.fontColorHilite = fhclr||"#ffffff"; this.bgColor = "#555555"; this.menuBorder = 1; this.menuItemBorder = 1; this.menuItemBgColor = bg||"#cccccc"; this.menuLiteBgColor = "#ffffff"; this.menuBorderBgColor = "#777777"; this.menuHiliteBgColor = bgh||"#000084"
; this.menuContainerBgColor = "#cccccc"; this.childMenuIcon = "arrows.gif"; this.items = new Array(); this.actions = new Array(); this.childMenus = new Array(); this.hideOnMouseOut = true; this.addMenuItem = addMenuItem; this.addMenuSeparator = addMenuSeparator; this.writeMenus = writeMenus; this.FW_showMenu = FW_showMenu; this.onMenuItemOver = onMenuItemOver; this.onMenuItemAction = onMenuItemAction; this.hideMenu = hideMenu; this.hideChildMenu = hideChildMenu; if (!window.menus) window.menus = new Array(); this.label = label || "menuLabel" + window.menus.length; 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 addMenuSeparator() { this.items[this.items.length] = "separator"; this.actions[this.actions.length] = ""; this.menuItemBorder = 0; } // For NS6. function
FIND(item) { if (document.all) return(document.all[item]); if (document.getElementById) return(document.getElementById(item)); return(false); } function writeMenus(container) { if (window.triedToWriteMenus) return; if (!container && document.layers) { window.delayWriteMenus = this.writeMenus; var timer = setTimeout('delayWriteMenus()', 250); container = new Layer(100); clearTimeout(timer); } else if (document.all || document.hasChildNodes) { document.writeln('<SPAN ID="menuContainer"></SPAN>'); container = FIND("menuContainer"); } window.fwHideMenuTimer = 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.leng
th; i++, countMenus++) { var menu = container.menus[i]; if (menu.bgImageUp) { menu.menuBorder = 0; menu.menuItemBorder = 0; } if (lrs) { var menuLayer = new Layer(100, container); var lite = new Layer(100, menuLayer); lite.top = menu.menuBorder; lite.left = menu.menuBorder; var body = new Layer(100, lite); body.top = menu.menuBorder; body.left = menu.menuBorder; } else { content += ''+ '<DIV ID="menuLayer'+ countMenus +'" STYLE="position:absolute;z-index:1;left:10;top:'+ (i * 100) +';visibility:hidden;">\n'+ ' <DIV ID="menuLite'+ countMenus +'" STYLE="position:absolute;z-index:1;left:'+ menu.menuBorder +';top:'+ menu.menuBorder +';visibility:hide;" onMouseOut="mouseoutMenu();">\n'+ ' <DIV ID="menuFg'+ countMenus +'" STYLE="position:absolute;left:'+ menu.menuBorder +';top:'+ menu.menuBorder +';visibility:hide;">\n'+ ''; } var x=i; for (var i=0; i<menu.items.length; i++) { var item = menu.items[i]; var childMenu = false; var defaultHeight = m
enu.fontSize+6; var defaultIndent = menu.fontSize; if (item.label) { item = item.label; childMenu = true; } menu.menuItemHeight = menu.menuItemHeight || defaultHeight; menu.menuItemIndent = menu.menuItemIndent || defaultIndent; var itemProps = 'font-family:' + menu.fontFamily +';font-weight:' + menu.fontWeight + ';fontSize:' + menu.fontSize + ';'; if (menu.fontStyle) itemProps += 'font-style:' + menu.fontStyle + ';'; if (document.all) itemProps += 'font-size:' + menu.fontSize + ';" onMouseOver="onMenuItemOver(null,this);" onClick="onMenuItemAction(null,this);'; else if (!document.layers) { itemProps += 'font-size:' + menu.fontSize + 'px;'; // zilla wants 12px. } var l; if (lrs) { l = new Layer(800,body); } var dTag = '<DIV ID="menuItem'+ countItems +'" STYLE="position:absolute;left:0;top:'+ (i * menu.menuItemHeight) +';'+ itemProps +'">'; var dClose = '</DIV>' if (menu.bgImageUp) { menu.menuBorder = 0; menu.menuItemBorder = 0; d
Tag = '<DIV ID="menuItem'+ countItems +'" STYLE="background:url('+menu.bgImageUp+');position:absolute;left:0;top:'+ (i * menu.menuItemHeight) +';'+ itemProps +'">'; if (document.layers) { dTag = '<LAYER BACKGROUND="'+menu.bgImageUp+'" ID="menuItem'+ countItems +'" TOP="'+ (i * menu.menuItemHeight) +'" style="' + itemProps +'">'; dClose = '</LAYER>'; } } var textProps = 'position:absolute;left:' + menu.menuItemIndent + ';top:1;'; if (lrs) { textProps +=itemProps; dTag = ""; dClose = ""; } var dText = '<DIV ID="menuItemText'+ countItems +'" STYLE="' + textProps + 'color:'+ menu.fontColor +';">'+ item +' </DIV>\n<DIV ID="menuItemHilite'+ countItems +'" STYLE="' + textProps + 'top:1;color:'+ menu.fontColorHilite +';visibility:hidden;">'+ item +' </DIV>'; if (item == "separator") { content += ( dTag + '<DIV ID="menuSeparator'+ countItems +'" STYLE="position:absolute;left:1;top:2;"></DIV>\n<DIV ID="menuSeparatorLite'+ countItems +'" STYLE="position:absol
ute;left:1;top:2;"></DIV>\n' + dClose); } else if (childMenu) { content += ( dTag + dText + '<DIV ID="childMenu'+ countItems +'" STYLE="position:absolute;left:0;top:3;"><IMG SRC="'+ menu.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) { // focus layer var focusItem = new Layer(100, body); focusItem.visiblity="hidden"; focusItem.document.open("text/html"); focusItem.document.writeln(" "); focusItem.document.close(); } else { content += ' <DIV ID="focusItem'+ countMenus +'" STYLE="position:absolute;left:0;top:0;visibility:hide;" onClick="onMenuItemAction(null,this);"> </DIV>\n'; content += ' </DIV>\n </DIV>\n</DIV>\n'; } i=x; } if (docu
ment.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 menu = container.document.layers[i]; container.menus[i].menuLayer = menu; container.menus[i].menuLayer.Menu = container.menus[i]; container.menus[i].menuLayer.Menu.container = container; var body = menu.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.action = container.menus[i].actions[n]; l.focusItem = body.document.layers[body.document.layers.length-1]; l.clip.width = proto.menuWidth || body.clip.width + proto.menuItemIndent; l.clip.height = proto.menuItemHeight || l.clip.height; if (n>0) l.top = body.document.layers[n-1].top + body.document.layers[n-1].clip.height + proto.menuItemBorder; l.hilite = l.document.layers[1]; if (proto.bgImageUp) l.background.src = proto.bgImageUp; l.document.layers[1].isHilite = true; if (l.document.layers[0].id.indexOf("menuSeparator") != -1) { l.hilite = null; l.clip.height -= l.clip.height / 2; l.document.layers[0].document.bgColor = proto.bgColor; l.document.layers[0].clip.width = l.clip.width -2; l.document.layers[0].clip.height = 1; l.document.layers[1].document.bgColor = proto.menuLiteBgColor; l.document.layers[1].clip.width = l.clip.width -2; l.document.layers[1].clip.height = 1; l.document.layers[1].top = l.document.layers[0].top
+ 1; } else 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; } } body.document.bgColor = proto.bgColor; body.clip.width = l.clip.width +proto.menuBorder; body.clip.height = l.top + l.clip.height +proto.menuBorder; 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; menu.document.bgColor = proto.menuBorderBgColor; var lite = menu.document.layers[0]; lite.document.bgColor = proto.menuLiteBgColor; lite.clip.width = body.clip.width +1; lite.clip.height = body.clip.height +1; menu.clip.width = body.clip.width + (proto.menuBorder * 3
) ; menu.clip.height = body.clip.height + (proto.menuBorder * 3); } } else { if ((!document.all) && (container.hasChildNodes)) { 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.top = s.pixelTop = -300; s.left = s.pixelLeft = -300; var menu = container.menus[x]; menu.menuItemWidth = menu.menuWidth || menu.menuIEWidth || 140; menuLayer.style.backgroundColor = menu.menuBorderBgColor; var top = 0; for (var i=0; i<container.menus[x].items.length; i++) { var l = FIND("menuItem" + menuCount); l.Menu = container.menus[x];
if (l.addEventListener) { // ns6 l.style.width = menu.menuItemWidth; l.style.height = menu.menuItemHeight; l.style.top = top; l.addEventListener("mouseover", onMenuItemOver, false); l.addEventListener("click", onMenuItemAction, false); l.addEventListener("mouseout", mouseoutMenu, false); } else { //ie l.style.pixelWidth = menu.menuItemWidth; l.style.pixelHeight = menu.menuItemHeight; l.style.pixelTop = top; } top = top + menu.menuItemHeight+menu.menuItemBorder; l.style.fontSize = menu.fontSize; l.style.backgroundColor = menu.menuItemBgColor; l.style.visibility = "inherit"; l.saveColor = menu.menuItemBgColor; l.menuHiliteBgColor = menu.menuHiliteBgColor; l.action = container.menus[x].actions[i]; l.hilite = FIND("menuItemHilite" + menuCount); l.focusItem = FIND("focusItem" + x); l.focusItem.style.pixelTop = l.focusItem.style.top = -30; var childItem = FIND("childMenu" + menuCount); if (childItem) { l.chi
ldMenu = container.menus[x].items[i].menuLayer; childItem.style.pixelLeft = childItem.style.left = menu.menuItemWidth -11; childItem.style.pixelTop = childItem.style.top =(menu.menuItemHeight /2) -4; //childItem.style.pixelWidth = 30 || 7; //childItem.style.clip = "rect(0 7 7 3)"; l.Menu.childMenus[l.Menu.childMenus.length] = l.childMenu; } var sep = FIND("menuSeparator" + menuCount); if (sep) { sep.style.clip = "rect(0 " + (menu.menuItemWidth - 3) + " 1 0)"; sep.style.width = sep.style.pixelWidth = menu.menuItemWidth; sep.style.backgroundColor = menu.bgColor; sep = FIND("menuSeparatorLite" + menuCount); sep.style.clip = "rect(1 " + (menu.menuItemWidth - 3) + " 2 0)"; sep.style.width = sep.style.pixelWidth = menu.menuItemWidth; sep.style.backgroundColor = menu.menuLiteBgColor; l.style.height = l.style.pixelHeight = menu.menuItemHeight/2; l.isSeparator = true top -= (menu.menuItemHeight - l.style.pixelHeight) } else {
l.style.cursor = "hand" } menuCount++; } menu.menuHeight = top-1; var lite = FIND("menuLite" + x); var s = lite.style; s.height = s.pixelHeight = menu.menuHeight +(menu.menuBorder * 2); s.width = s.pixelWidth = menu.menuItemWidth + (menu.menuBorder * 2); s.backgroundColor = menu.menuLiteBgColor; var body = FIND("menuFg" + x); s = body.style; s.height = s.pixelHeight = menu.menuHeight + menu.menuBorder; s.width = s.pixelWidth = menu.menuItemWidth + menu.menuBorder; s.backgroundColor = menu.bgColor; s = menuLayer.style; s.width = s.pixelWidth = menu.menuItemWidth + (menu.menuBorder * 4); s.height = s.pixelHeight = menu.menuHeight+(menu.menuBorder*4); } } 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; wind
ow.NS4sIH = window.innerHeight; } document.onmouseup = mouseupMenu; window.fwWroteMenu = true; status = ""; } function NS4resize() { if (NS4sIW < window.innerWidth || NS4sIW > window.innerWidth || NS4sIH > window.innerHeight || NS4sIH < window.innerHeight ) { window.location.reload(); } } function onMenuItemOver(e, l) { FW_clearTimeout(); l = l || this; 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.Menu.hideChildMenu(l); } else if (l.st
yle && l.Menu) { if (a) { a.style.backgroundColor = a.saveColor; if (a.hilite) a.hilite.style.visibility = "hidden"; if (a.Menu.bgImageUp) { a.style.background = "url(" + a.Menu.bgImageUp +")";; } } if (l.isSeparator) return; l.style.backgroundColor = l.menuHiliteBgColor; l.zIndex = 1; // magic IE 4.5 mac happy doohicky. jba if (l.Menu.bgImageOver) { l.style.background = "url(" + l.Menu.bgImageOver +")"; } if (l.hilite) { l.style.backgroundColor = l.menuHiliteBgColor; l.hilite.style.visibility = "inherit"; } l.focusItem.style.top = l.focusItem.style.pixelTop = l.style.pixelTop; l.focusItem.style.zIndex = l.zIndex +1; l.Menu.hideChildMenu(l); } else { return; // not a menu - magic IE 4.5 mac happy doohicky. jba } window.ActiveMenuItem = l; } function onMenuItemAction(e, l) { l = window.ActiveMenuItem; if (!l) return; hideActiveMenus(); if (l.action) { eval("" + l.action); } window.ActiveMenuItem = 0; } function FW_clearTimeout() { if (fwHideM
enuTimer) clearTimeout(fwHideMenuTimer); fwHideMenuTimer = null; fwDHFlag = false; } function FW_startTimeout() { fwStart = new Date(); fwDHFlag = true; fwHideMenuTimer = setTimeout("fwDoHide()", 1000); } function fwDoHide() { if (!fwDHFlag) return; var elapsed = new Date() - fwStart; if (elapsed < 1000) { fwHideMenuTimer = setTimeout("fwDoHide()", 1100-elapsed); return; } fwDHFlag = false; hideActiveMenus(); window.ActiveMenuItem = 0; } function FW_showMenu(menu, x, y, child) { if (!window.fwWroteMenu) return; FW_clearTimeout(); if (document.layers) { if (menu) { var l = menu.menuLayer || menu; l.left = 1; l.top = 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) FW_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.parentLayer.document.bgColor = l.parentLayer.menuContainerBgColor; } } l.visibility = "inherit"; if (l.Menu) l.Menu.container.visibility = "inherit"; } else if (FIND("menuItem0")) { var l = menu.menuLayer || menu; hideActiveMenus(); if (typeof(l) == "string") { l = FIND(l); } window.ActiveMenu = l; var s = l.style; s.visibility = "inherit"; if (x != "relative") s.left = s.pixe
lLeft = x || (window.pageX + document.body.scrollLeft) || 0; if (y != "relative") s.top = s.pixelTop = y || (window.pageY + document.body.scrollTop) || 0; l.Menu.xOffset = document.body.scrollLeft; l.Menu.yOffset = document.body.scrollTop; } if (menu) { window.activeMenus[window.activeMenus.length] = l; } } function onMenuItemDown(e, l) { var a = window.ActiveMenuItem; if (document.layers) { if (a) { a.eX = e.pageX; a.eY = e.pageY; a.clicked = true; } } } function mouseupMenu(e) { hideMenu(true, e); hideActiveMenus(); return true; } function mouseoutMenu() { 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.action && 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();', 2); } } 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.Menu.bgImageUp) { a.style.background = "url(" + a.Menu.bgImageUp +")";; } } } if (!mouseup && window.ActiveMenu) { if (window.ActiveMenu.Menu) { if (window.ActiveMenu.Menu.hideOnMouseOut) { FW_startTimeout(); } return(true); } } return(true); } function PxToNum(pxStr) { // pxStr == 27px, we want 27. if (pxStr.length > 2) { n = Number(pxStr.substr(0, pxStr.length-2)); return(n); } return(0); } function hideChildMenu(hcmLayer) { FW_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"; } theLayer.Menu.hideChildMenu(theLayer); } if (l.childMenu) { var childMenu = l.childMenu; if (document.layers) { l.Menu.FW_showMenu(null,null,null,childMenu.layers[0]); childMenu.zIndex = l.parentLayer.zIndex +1; childMenu.top = l.top + l.parentLayer.top + l.Menu.menuLayer.top + l.Menu.menuItemHeight/3; if (childMenu.left + childMenu.clip.width > window.innerWidth) { childMenu.left = l.parentLayer.left - childMenu.clip.width + l.Menu.menuLayer.left + 15; l.Menu.container.clip.left -= childMenu.clip.width; } else { childMenu.left = l.parentLayer.left + l.parentLayer.clip.width + l.Menu.menuLayer.left -5; } 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) { // ie case. s.pixelTop = l.style.pixelTop + menuLayer.style.pixelTop + l.Menu.menuItemHeight/3; s.left = s.pixelLeft = (menuLayer.style.pixelWidth) + menuLayer.style.pixelLeft -5; } else { // zilla case var top = PxToNum(l.style.top) + PxToNum(menuLayer.style.top) + l.Menu.menuItemHeight/3; var left = (PxToNum(menuLayer.style.width)) + PxToNum(menuLayer.style.left) -5; s.top = top; s.left = left; } 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].Me
nu) { 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 = -200; s.top = -200; } } if (window.ActiveMenuItem) { hideMenu(false, false); } window.activeMenus.length = 0; }