
/*
All code was written by Jason Redding. Al
l                                       l
l       J a s o n   R e d d i n g
                  @                     c
c              C C B C                  o
o                                       d
de was written by Jason Redding. All code

All code was written by Jason Redding. Al
w                                       l
        J a s o n   R e d d i n g
s                 @                     c
a              C C B C                  o
w                                       d
 edoc llA .gniddeR nosaJ yb nettirw saw e
*/


var JMENU_IMAGE_ItemNodeExpanded = "images/jmenu_expanded.gif";
var JMENU_IMAGE_ItemNodeCollapsed = "images/jmenu_collapsed.gif";
var JMENU_showSubMenuDelay = 200;
var JMENU_hideMenuDelay = 650;
var JMENU_hideSubMenuDelay = 200;
var JMENU_defaultItemSeparatorSize = 1;
var JMENU_defaultItemHeight = 20;
var JMENU_defaultMenuOrientation = "down";
var JMENU_defaultSubMenuDir = "right";
var JMENU_decideWhenNoStatusText_ShowURL = true;


if (JMENU_showSubMenuDelay < 0) {
	JMENU_showSubMenuDelay = 200;
}
if (JMENU_hideSubMenuDelay < 0) {
	JMENU_hideSubMenuDelay = 200;
}

if (JMENU_showSubMenuDelay < JMENU_hideSubMenuDelay) {
	/*
	 *  If the delay for hiding a menu is longer than the delay to show 
	 *  a menu, then make the HIDE delay the same as the SHOW delay.
	 *  This fixes a potential misconfiguration problem.
	 */
	JMENU_hideSubMenuDelay = JMENU_showSubMenuDelay;
}

var global = document;

// Except this:
// Note: you don't want your Nav4 or IE4 code to "turn off" or
// stop working when new versions of browsers are released, so
// in conditional code forks, use is_ie5up ("IE 5.0 or greater") 
// is_opera5up ("Opera 5.0 or greater") instead of is_ie5 or is_opera5
// to check version in code which you want to work on future
// versions.

    // convert all characters to lowercase to simplify testing
    var agt=navigator.userAgent.toLowerCase();

    // *** BROWSER VERSION ***
    // Note: On IE5, these return 4, so use is_ie5up to detect IE5.
    var is_major = parseInt(navigator.appVersion);
    var is_minor = parseFloat(navigator.appVersion);

    // Note: Opera and WebTV spoof Navigator.  We do strict client detection.
    // If you want to allow spoofing, take out the tests for opera and webtv.
    var is_nav  = ((agt.indexOf('mozilla')!=-1) && (agt.indexOf('spoofer')==-1) && (agt.indexOf('compatible') == -1) && (agt.indexOf('opera')==-1) && (agt.indexOf('webtv')==-1) && (agt.indexOf('hotjava')==-1));
    var is_nav2 = (is_nav && (is_major == 2));
    var is_nav3 = (is_nav && (is_major == 3));
    var is_nav4 = (is_nav && (is_major == 4));
    var is_nav4up = (is_nav && (is_major >= 4));
    var is_navonly = (is_nav && ((agt.indexOf(";nav") != -1) || (agt.indexOf("; nav") != -1)) );
    var is_nav6 = (is_nav && (is_major == 5));
    var is_nav6up = (is_nav && (is_major >= 5));
    var is_gecko = (agt.indexOf('gecko') != -1);


    var is_ie     = ((agt.indexOf("msie") != -1) && (agt.indexOf("opera") == -1));
    var is_ie3    = (is_ie && (is_major < 4));
    var is_ie4    = (is_ie && (is_major == 4) && (agt.indexOf("msie 4")!=-1) );
    var is_ie4up  = (is_ie && (is_major >= 4));
    var is_ie5    = (is_ie && (is_major == 4) && (agt.indexOf("msie 5.0")!=-1) );
    var is_ie5_5  = (is_ie && (is_major == 4) && (agt.indexOf("msie 5.5") !=-1));
    var is_ie5up  = (is_ie && !is_ie3 && !is_ie4);
    var is_ie5_5up =(is_ie && !is_ie3 && !is_ie4 && !is_ie5);
    var is_ie6    = (is_ie && (is_major == 4) && (agt.indexOf("msie 6.")!=-1) );
    var is_ie6up  = (is_ie && !is_ie3 && !is_ie4 && !is_ie5 && !is_ie5_5);

    // KNOWN BUG: On AOL4, returns false if IE3 is embedded browser
    // or if this is the first browser window opened.  Thus the
    // variables is_aol, is_aol3, and is_aol4 aren't 100% reliable.
    var is_aol   = (agt.indexOf("aol") != -1);
    var is_aol3  = (is_aol && is_ie3);
    var is_aol4  = (is_aol && is_ie4);
    var is_aol5  = (agt.indexOf("aol 5") != -1);
    var is_aol6  = (agt.indexOf("aol 6") != -1);

    var is_opera = (agt.indexOf("opera") != -1);
    var is_opera2 = (agt.indexOf("opera 2") != -1 || agt.indexOf("opera/2") != -1);
    var is_opera3 = (agt.indexOf("opera 3") != -1 || agt.indexOf("opera/3") != -1);
    var is_opera4 = (agt.indexOf("opera 4") != -1 || agt.indexOf("opera/4") != -1);
    var is_opera5 = (agt.indexOf("opera 5") != -1 || agt.indexOf("opera/5") != -1);
    var is_opera5up = (is_opera && !is_opera2 && !is_opera3 && !is_opera4);

    var is_webtv = (agt.indexOf("webtv") != -1); 

    var is_TVNavigator = ((agt.indexOf("navio") != -1) || (agt.indexOf("navio_aoltv") != -1)); 
    var is_AOLTV = is_TVNavigator;

    var is_hotjava = (agt.indexOf("hotjava") != -1);
    var is_hotjava3 = (is_hotjava && (is_major == 3));
    var is_hotjava3up = (is_hotjava && (is_major >= 3));

    // *** JAVASCRIPT VERSION CHECK ***
    var is_js;
    if (is_nav2 || is_ie3) is_js = 1.0;
    else if (is_nav3) is_js = 1.1;
    else if (is_opera5up) is_js = 1.3;
    else if (is_opera) is_js = 1.1;
    else if ((is_nav4 && (is_minor <= 4.05)) || is_ie4) is_js = 1.2;
    else if ((is_nav4 && (is_minor > 4.05)) || is_ie5) is_js = 1.3;
    else if (is_hotjava3up) is_js = 1.4;
    else if (is_nav6 || is_gecko) is_js = 1.5;
    // NOTE: In the future, update this code when newer versions of JS
    // are released. For now, we try to provide some upward compatibility
    // so that future versions of Nav and IE will show they are at
    // *least* JS 1.x capable. Always check for JS version compatibility
    // with > or >=.
    else if (is_nav6up) is_js = 1.5;
    // NOTE: ie5up on mac is 1.4
    else if (is_ie5up) is_js = 1.3

    // HACK: no idea for other browsers; always check for JS version with > or >=
    else is_js = 0.0;

    // *** PLATFORM ***
    var is_win   = ( (agt.indexOf("win")!=-1) || (agt.indexOf("16bit")!=-1) );
    // NOTE: On Opera 3.0, the userAgent string includes "Windows 95/NT4" on all
    //        Win32, so you can't distinguish between Win95 and WinNT.
    var is_win95 = ((agt.indexOf("win95")!=-1) || (agt.indexOf("windows 95")!=-1));

    // is this a 16 bit compiled version?
    var is_win16 = ((agt.indexOf("win16")!=-1) || (agt.indexOf("16bit")!=-1) || (agt.indexOf("windows 3.1")!=-1) || (agt.indexOf("windows 16-bit")!=-1) );

    var is_win31 = ((agt.indexOf("windows 3.1")!=-1) || (agt.indexOf("win16")!=-1) || (agt.indexOf("windows 16-bit")!=-1));

    var is_winme = ((agt.indexOf("win 9x 4.90")!=-1));
    var is_win2k = ((agt.indexOf("windows nt 5.0")!=-1));
    var is_winxp = ((agt.indexOf("windows nt 5.1")!=-1));
    var is_win2kup = ((agt.indexOf("windows nt 5.")!=-1));
    

    // NOTE: Reliable detection of Win98 may not be possible. It appears that:
    //       - On Nav 4.x and before you'll get plain "Windows" in userAgent.
    //       - On Mercury client, the 32-bit version will return "Win98", but
    //         the 16-bit version running on Win98 will still return "Win95".
    var is_win98 = ((agt.indexOf("win98")!=-1) || (agt.indexOf("windows 98")!=-1));
    var is_winnt = ((agt.indexOf("winnt")!=-1) || (agt.indexOf("windows nt")!=-1));
    var is_win32 = (is_win95 || is_winnt || is_win98 || ((is_major >= 4) && (navigator.platform == "Win32")) || (agt.indexOf("win32")!=-1) || (agt.indexOf("32bit")!=-1));

    var is_os2   = ((agt.indexOf("os/2")!=-1) || (navigator.appVersion.indexOf("OS/2")!=-1) || (agt.indexOf("ibm-webexplorer")!=-1));

    var is_mac    = (agt.indexOf("mac")!=-1);
    // hack ie5 js version for mac
    if (is_mac && is_ie5up) is_js = 1.4;
    var is_mac68k = (is_mac && ((agt.indexOf("68k")!=-1) || (agt.indexOf("68000")!=-1)));
    var is_macppc = (is_mac && ((agt.indexOf("ppc")!=-1) || (agt.indexOf("powerpc")!=-1)));

    var is_sun   = (agt.indexOf("sunos")!=-1);
    var is_sun4  = (agt.indexOf("sunos 4")!=-1);
    var is_sun5  = (agt.indexOf("sunos 5")!=-1);
    var is_suni86= (is_sun && (agt.indexOf("i86")!=-1));
    var is_irix  = (agt.indexOf("irix") !=-1);    // SGI
    var is_irix5 = (agt.indexOf("irix 5") !=-1);
    var is_irix6 = ((agt.indexOf("irix 6") !=-1) || (agt.indexOf("irix6") !=-1));
    var is_hpux  = (agt.indexOf("hp-ux")!=-1);
    var is_hpux9 = (is_hpux && (agt.indexOf("09.")!=-1));
    var is_hpux10= (is_hpux && (agt.indexOf("10.")!=-1));
    var is_aix   = (agt.indexOf("aix") !=-1);      // IBM
    var is_aix1  = (agt.indexOf("aix 1") !=-1);    
    var is_aix2  = (agt.indexOf("aix 2") !=-1);    
    var is_aix3  = (agt.indexOf("aix 3") !=-1);    
    var is_aix4  = (agt.indexOf("aix 4") !=-1);    
    var is_linux = (agt.indexOf("inux")!=-1);
    var is_sco   = (agt.indexOf("sco")!=-1) || (agt.indexOf("unix_sv")!=-1);
    var is_unixware = (agt.indexOf("unix_system_v")!=-1); 
    var is_mpras    = (agt.indexOf("ncr")!=-1); 
    var is_reliant  = (agt.indexOf("reliantunix")!=-1);
    var is_dec   = ((agt.indexOf("dec")!=-1) || (agt.indexOf("osf1")!=-1) || (agt.indexOf("dec_alpha")!=-1) || (agt.indexOf("alphaserver")!=-1) || (agt.indexOf("ultrix")!=-1) || (agt.indexOf("alphastation")!=-1));
    var is_sinix = (agt.indexOf("sinix")!=-1);
    var is_freebsd = (agt.indexOf("freebsd")!=-1);
    var is_bsd = (agt.indexOf("bsd")!=-1);
    var is_unix  = ((agt.indexOf("x11")!=-1) || is_sun || is_irix || is_hpux || is_sco ||is_unixware || is_mpras || is_reliant || is_dec || is_sinix || is_aix || is_linux || is_bsd || is_freebsd);

    var is_vms   = ((agt.indexOf("vax")!=-1) || (agt.indexOf("openvms")!=-1));

//But I did do all of this:

var lr = "";
if (document.layers) {
	lr = "<div ";
} else if ((document.all) || (document.getElementById)) {
	lr = "<span ";
}

lr += "name=\"floatingMenu\" id=\"floatingMenu\" ";

if (document.layers) {
	//lr += "z-index=\"50\" visibility=\"hide\"";
	lr += "style=\"position:absolute; z-index:50; visibility: hidden; overflow: visible; border: 0px solid #000000; display: inline;\"";
} else if ((document.all) || (document.getElementById)) {
	lr += "style=\"position:absolute; z-index:50; visibility: hidden; overflow: visible; border: 0px solid #000000; display: inline;\"";
}

lr += ">";

if (document.layers) {
	lr += "</div>";
} else if ((document.all) || (document.getElementById)) {
	lr += "</span>";
}

//-----------------------

if (document.layers) {
	lr += "<div ";
} else if ((document.all) || (document.getElementById)) {
	lr += "<span ";
}

lr += "name=\"floatingSubMenus\" id=\"floatingSubMenus\" style=\"display: inline;\">";

if (document.layers) {
	lr += "</div>";
} else if ((document.all) || (document.getElementById)) {
	lr += "</span>";
}

lr += "<div name=\"floatingShadows\" id=\"floatingShadows\" style=\"display: inline;\"></div>";

document.writeln(lr);


//----------------------------------------------------------------------------

var currentMenu = "";
var currentMenuItem = "";
var hideMenuTimeout = 0;
var buildSubMenusList = "";


function newImage(loc) {
	var d = document;
	var result = null;
	var newLoc = loc;
	var pre = location.protocol + "//" + location.host + "/";
	if (loc.indexOf(":") < 0) newLoc = pre + loc;
	if (!d.JM_images)	d.JM_images = new Array();
	var j = d.JM_images.length;
	for(var i = 0; i < j && !result; i++) {
		if (d.JM_images[i]) {
			if (d.JM_images[i].src == loc) {
				result = d.JM_images[i];
			}
		}
	}
	//alert("loc:" + loc + "\nnewLoc:" + newLoc);
	if (!result) {
		d.JM_images[j] = new Image();
		d.JM_images[j].src = newLoc;
		result = d.JM_images[j];
	}
	return result;
}

function swapImages() {
	if (document.images) {
		if ((swapImages.arguments.length % 2) == 0) {
			var t = "";
			for(var i = 0; i < swapImages.arguments.length; i += 2) {
				if (document.images[swapImages.arguments[i]]) {
					t = typeof(swapImages.arguments[(i + 1)]);
					if (t == "object") {
						document.images[swapImages.arguments[i]].src = swapImages.arguments[(i + 1)].src;
					} else if (t == "string") {
						//document.images[swapImages.arguments[i]].src = swapImages.arguments[(i + 1)];
						document.images[swapImages.arguments[i]].src = newImage(swapImages.arguments[(i + 1)]).src;
					}
				}
			}
		}
	}
}

function getLastNode(name) {
	var lastNode = name;
	if (name.lastIndexOf("__") > 0) {
		lastNode = name.substr(name.lastIndexOf("__") + 2);
	}
	return lastNode;
}

function getFirstNode(name) {
	var firstNode = name;
	if (name.indexOf("__") > 0) {
		firstNode = name.substr(0, name.indexOf("__"));
	}
	return firstNode;
}

function getParentNode(name) {
	var parentNode = name;
	if (name.lastIndexOf("__") > 0) {
		parentNode = name.substr(0, name.lastIndexOf("__"));
	} else if (name.indexOf("_") > 0) {
		parentNode = name.substr(0, name.indexOf("_"));
	}
	return parentNode;
}

function getMenu(name) {
	var m = eval("menu_" + getLastNode(name));
	return m;
}



function getMenuLayerStyle(name) {
	return getObjStyle("floatingMenu_" + name);
}

function getObj(name) {
	var ml = null;
	if (document.layers) {
		//ml = document.layers[(name)];
		ml = getObjNN4(document, name);
	} else if (document.getElementById) {
		ml = document.getElementById(name);
	} else if (document.all) {
		ml = document.all[(name)];
	}
	return ml;
}

function getObjStyle(name) {
	var ml = null;
	ml = getObj(name);
	if (ml) {
		if (document.layers) {
			//ml = document.layers[(name)];
		} else if (document.getElementById) {
			//ml = document.getElementById(name).style;
			ml = ml.style;
		} else if (document.all) {
			//ml = document.all[(name)].style;
			ml = ml.style;
		}
	}
	return ml;
}

function getObjNN4(obj,name) {
	var x = obj.layers;
	var foundLayer;
	if (obj[name]) {
		foundLayer = obj[name];
		return foundLayer;
	}
	for (var i=0;i<x.length;i++) {
		var tmp = null;
		if (x[i].id == name) {
			foundLayer = x[i];
		} else if (x[i].layers.length) {
			tmp = getObjNN4(x[i],name);
		}
		if (tmp) {
			foundLayer = tmp;
			break;
		}
	}
	return foundLayer;
}

function getMenuLayer(name) {
	return getObj("floatingMenu_" + name);
}

function setLayerContent(name, content) {
	var layr = getObj(name);
	if (layr) {
		if (document.layers) {
			layr.document.open();
			layr.document.write(content);
			layr.document.close();
		} else if (document.getElementById) {
			layr.innerHTML = content;
		} else if (document.all) {
			layr.innerHTML = content;
		}
	}
}

function setMenuLayerContent(name, content) {
	setLayerContent("floatingMenu_" + name, content);
}


function setLayerVisible(name, visible) {
	var layerStyle = getObjStyle(name);
	
	if (layerStyle) {
	//alert("name: " + layerStyle + "\nvisible: " + visible);
		if (document.layers) {
			layerStyle.visibility = ((visible) ? "show" : "hide");
		} else if ((document.all) || (document.getElementById)) {
			layerStyle.visibility = ((visible) ? "visible" : "hidden");
		}
	}
}

function setMenuLayerVisible(name, visible) {
	setLayerVisible("floatingMenu_" + name, visible);
}


function getLayerVisible(name) {
	var layerStyle = getObjStyle(name);
	var result = false;
	if (!layerStyle) return result;
	if (layerStyle.visibility) {
		result = ((layerStyle.visibility).toLowerCase().substr(0, 3) != "hid") ? true : false;
	} else if (layerStyle.visible) {
		result = ((layerStyle.visible).toLowerCase() != "false") ? true : false;
	}
	return result;
}

function getMenuLayerVisible(name) {
	return getLayerVisible("floatingMenu_" + name);
}

function setLayerOpacity(name, opacity) {
	if (is_nav || !is_win2kup) return;
	
	var m_layerStyle = getObjStyle(name);
	if (m_layerStyle) {
		if (opacity < 100) {
			m_layerStyle.filter = "alpha(opacity=" + parseInt(opacity) + ")";
		} else {
			m_layerStyle.filter = ";";
		}
	}
}

function setLayerWidth(name, value) {
	var mObjStyle = getObjStyle(name);
	if (mObjStyle) mObjStyle.width = value;
}

function getLayerWidth(name) {
	var mObjStyle = getObjStyle(name);
	if (mObjStyle) return mObjStyle.width;
	return -1;
}

function setMenuLayerWidth(name, value) {
	setLayerWidth("floatingMenu_" + name, value);
}

function getMenuLayerWidth(name) {
	return getLayerWidth("floatingMenu_" + name);
}

function setLayerBgColor(name, color) {
	var layr = getObjStyle(name);
	var c = "";
	if (color) {
		c = color;
	}
	if (layr) {
		if (document.layers) {
			layr.bgColor = c;
		} else if (document.getElementById) {
			layr.backgroundColor = c;
		} else if (document.all) {
			layr.backgroundColor = c;
		}
	}
}

function setMenuLayerBgColor(name, color) {
	setLayerBgColor("floatingMenu_" + name, color);
}

function setLayerBorder(name) {
	if (name) {
		var lsize = 1;
		var lcolor = "#000000";
		var lstyle = "solid";
		var layerStyle = getObjStyle(name);
		if (!layerStyle) return;
		if (setLayerBorder.arguments.length == 2) {
			if ((setLayerBorder.arguments[1] + "") != "undefined") {
				if (setLayerBorder.arguments[1].substr(0, 1) == "#") {
					lcolor = setLayerBorder.arguments[1];
				} else if (!isNaN(setLayerBorder.arguments[1])) {
					lsize = setLayerBorder.arguments[1];
				} else {
					lstyle = setLayerBorder.arguments[1];
				}
			}
		}
		if (setLayerBorder.arguments.length > 2) {
			if ((setLayerBorder.arguments[1] + "") != "undefined") {
				lsize = parseInt(setLayerBorder.arguments[1]);
			}
			if ((setLayerBorder.arguments[2] + "") != "undefined") {
				lcolor = setLayerBorder.arguments[2];
			}
		}
		if (setLayerBorder.arguments.length > 3) {
			if ((setLayerBorder.arguments[3] + "") != "undefined") {
				lstyle = setLayerBorder.arguments[3];
			}
		}
		//alert(layerStyle.border + "\n\n" + lcolor + " " + lsize + "px " + lstyle);
		layerStyle.border = (lcolor + " " + lsize + "px " + lstyle);
		//layerStyle.border = lcolor + " " + "1px " + lstyle;
		//layerStyle.margin = "0px " + lsize + "px";
	}
}


function setMenuLayerBorder(name, size, color, style) {
	setLayerBorder("floatingMenu_" + name, size, color, style);
}

function getLayerBorder(name) {
	var layerStyle = getObjStyle(name);
	var lb = layerStyle.split(" ");
	if (lb.length > 0) {
		this.color = lb[0];
	} else {
		this.color = "#000000";
	}
	if (lb.length > 1) {
		this.size = lb[1];
	} else {
		this.size = 0;
	}
	if (lb.length > 2) {
		this.style = lb[2];
	} else {
		this.style = "solid";
	}
}

function getMenuLayerBorder(name) {
	return getLayerBorder("floatingMenu_" + name);
}


function moveLayer(name, x, y) {
	var layr = getObjStyle(name);
	if (layr) {
		if (document.layers) {
			layr.left = x;
			layr.top = y;
		} else if (document.getElementById) {
			layr.left = x + "px";
			layr.top = y + "px";
		} else if (document.all) {
			layr.left = x;
			layr.top = y;
		}
	}
}

function moveMenuLayer(name, x, y) {
	moveLayer("floatingMenu_" + name, x, y);
}


function getMenuPath(name) {
	var result = name;
	while (result.match("__")) {
		result = name.replace("__", "/");
	}
	return result;
}





function keepMenu() {
	clearHideMenuTimeout();
}

function keepAllMenusUnder(name) {
	var mName = name;
	var m_menu;
	keepMenu();
	m_menu = getMenu(name);
	if (m_menu) {
		//log("keepAllMenusUnder: " + name);
		//From front to back...
		var i = mName.indexOf("__");
		if (i > 0) {
			while (i > 0) {
				//alert("mName: " + mName.substr(0, i));
				clearHideSubMenuTimeout(mName.substr(0, i));
				if (i == name.length) break;
				i = mName.indexOf("__", (i + 2));
				if (i < 0) {
					i = mName.length;
				}
			}
		} else {
			clearHideSubMenuTimeout(mName);
		}
	}
}

function log(str) {
	var logObj = getObj("logger");
	if (logObj) {
		var c = getLayerContent("logger");
		c += "<br>\n" + str;
		setLayerContent("logger", c);
		if (window.frames && window.frames.length) {
			for(var i = 0; i < window.frames.length; i++) {
				
			}
		}
	}
}

function clearHideMenuTimeout() {
	if (window.hideMenuTimeout) {
		clearTimeout(window.hideMenuTimeout);
		window.hideMenuTimeout = 0;
	}
}


function clearShowSubMenuTimeout(name) {
	var v = null;
	v = eval("window.showSubMenu_" + name + "_Timeout");
	if (v) {
		clearTimeout(v);
		v = 0;
	}
}


function clearHideSubMenuTimeout(name) {
	var v = null;
	v = eval("window.hideSubMenu_" + name + "_Timeout");
	if (v) {
		clearTimeout(v);
		v = 0;
	}
}


function Coordinate(x, y) {
	this.x = x;
	this.y = y;
}

function Bound(left, top, width, height) {
	this.left = left;
	this.x = left;
	this.top = top;
	this.y = top;
	this.width = width;
	this.right = (left + width);
	this.height = height;
	this.bottom = (top + height);
}

function GetScrollOffset() {
	var x,y;
	if (self.pageYOffset) // all except Explorer
	{
		x = self.pageXOffset;
		y = self.pageYOffset;
	}
	else if (document.documentElement && document.documentElement.scrollTop)
	// Explorer 6 Strict
	{
		x = document.documentElement.scrollLeft;
		y = document.documentElement.scrollTop;
	}
	else if (document.body) // all other Explorers
	{
		x = document.body.scrollLeft;
		y = document.body.scrollTop;
	}
	return new Coordinate(x, y);
}

function GetElementBound(eElement) {
	if (!eElement && this) {
		eElement = this;
  }
	if (!eElement) return new Bound(0, 0, 0, 0);

	var bIE = document.all ? true : false;
	var nTopPos = eElement.offsetTop;
	var nLeftPos = eElement.offsetLeft;
	var eParElement = eElement.offsetParent;
	if (eParElement) {
		if (eParElement.tagName) {
			if (eParElement.tagName == "MAP") {
				if (document.images) {
					for(var img_i = 0; img_i < document.images.length; img_i++) {
						if (document.images[img_i].useMap) {
							if (document.images[img_i].useMap == ("#" + eParElement.name)) {
								var bnd = GetElementBound(document.images[img_i]);
								nLeftPos += bnd.x;
								nTopPos += bnd.y;
								break;
							}
						}
					}
				}
			}
		}
	}
	while (eParElement != null) {
		if (bIE) {
			if (eParElement.tagName == "TD") {
				nTopPos += eParElement.clientTop;
				nLeftPos += eParElement.clientLeft;
			}
		}
		nTopPos += eParElement.offsetTop;
		nLeftPos += eParElement.offsetLeft;
		eParElement = eParElement.offsetParent;
	}
	//alert("left: " + nLeftPos + "\ntop: " + nTopPos + "\nwidth: " + eElement.offsetWidth + "\nheight: " + eElement.offsetHeight);
	return new Bound(nLeftPos, nTopPos, eElement.offsetWidth, eElement.offsetHeight);
}


function setMenuFontColor(name, i, color) {
	if (setMenuFontColor.arguments.length == 2) {
		var m = getMenu(name);
		for(var item = 0; item < m.menuItems.length; item++) {
			setMenuFontColor(name, item, i);
		}
	} else if (setMenuFontColor.arguments.length > 2) {
		//var mof = getObj("itemFont_" + name + "_" + i);
		//var moa = getObj("arrowFont_" + name + "_" + i);
		var txtCell = getObjStyle("mnuItem_" + name + "_" + i + "_center");
		var arrCell = getObjStyle("mnuItem_" + name + "_" + i + "_right");
		if (txtCell) txtCell.color = color;
		if (arrCell) arrCell.color = color;
	}
}


//------User interacts with these next two functions...

function hoverMenuItem(o, name, i) {
	//log("hover: " + o.tagName);
	var m = getMenu(name);
	if (currentMenuItem) {
		if (m.menuItems[i] == currentMenuItem) return;
	}
	currentMenuItem = m.menuItems[i];
	
	var md = 200;
	if (JMENU_showSubMenuDelay >= 0) {
		md = JMENU_showSubMenuDelay;
	}
	keepMenu();
	
	keepAllMenusUnder(name);
	
	
	/*if (m.menuItems[i].subMenu) {
		clearHideSubMenuTimeout(name + "__" + m.menuItems[i].subMenu);
		clearShowSubMenuTimeout(name + "__" + m.menuItems[i].subMenu);
	}*/
	
	var m_textHoverColor = (m.menuItems[i].textHoverColor) ? m.menuItems[i].textHoverColor : (m.menuOptions.textHoverColor) ? m.menuOptions.textHoverColor : "";
	var m_autoExpand = ((m.menuItems[i].autoExpand + "") != "undefined") ? m.menuItems[i].autoExpand : ((m.menuOptions.autoExpand + "") != "undefined") ? m.menuOptions.autoExpand : true;
	var m_hoverColor = (m.menuItems[i].hoverColor) ? m.menuItems[i].hoverColor : m.menuOptions.hoverColor ? m.menuOptions.hoverColor : "";
	var m_hoverOutlineSize = ((m.menuItems[i].hoverOutlineSize + "") != "undefined" ? m.menuItems[i].hoverOutlineSize : (m.menuOptions.hoverOutlineSize + "") != "undefined" ? m.menuOptions.hoverOutlineSize : 0);
	var m_hoverOutlineColor = (m.menuItems[i].hoverOutlineColor ? m.menuItems[i].hoverOutlineColor : m.menuOptions.hoverOutlineColor ? m.menuOptions.hoverOutlineColor : "#000000");
	
	if (m_hoverColor) {
		o.bgColor = m_hoverColor;
	}
	if (m_textHoverColor.length > 0) {
		setMenuFontColor(name, i, m_textHoverColor);
	}
	
	if (m_hoverOutlineSize > 0) {
		var objLeft = getObj("mnuItem_" + name + "_" + i + "_left");
		var objCenter = getObj("mnuItem_" + name + "_" + i + "_center");
		var objRight = getObj("mnuItem_" + name + "_" + i + "_right");
		//var objRight = getObj("mnuItem_" + name + "_" + i + "_center");
		
		var objUp = getObj("mnuItem_" + name + "_" + (i - 1));
		var objUpLeft = getObj("mnuItem_" + name + "_" + (i - 1) + "_left");
		var objUpCenter = getObj("mnuItem_" + name + "_" + (i - 1) + "_center");
		var objUpRight = getObj("mnuItem_" + name + "_" + (i - 1) + "_right");
		//var objUpRight = getObj("mnuItem_" + name + "_" + (i - 1) + "_center");
		
		if (objLeft) {
			//objLeft.style.borderLeft = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			if (i == 0) {
				if (objUp) objUp.style.borderTop = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			} else {
				if (objUpLeft) objUpLeft.style.borderBottom = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			}
			objLeft.style.borderBottom = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
		}
		if (objCenter) {
			//objCenter.style.border = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			if (i == 0) {
				if (objUp) objUp.style.borderTop = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			} else {
				if (objUpCenter) objUpCenter.style.borderBottom = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			}
			objCenter.style.borderBottom = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
		}
		if (objRight) {
			//objRight.style.borderRight = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			if (i == 0) {
				if (objUp) objUp.style.borderTop = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			} else {
				if (objUpRight) objUpRight.style.borderBottom = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
			}
			objRight.style.borderBottom = m_hoverOutlineSize + "px solid " + m_hoverOutlineColor;
		}
	}
	
	if (m.menuItems[i].subMenu) {
		clearHideSubMenuTimeout(name + "__" + m.menuItems[i].subMenu);
		clearShowSubMenuTimeout(name + "__" + m.menuItems[i].subMenu);
		//var coord = GetElementBound(o);
		if (!getMenuLayerVisible(name + "__" + m.menuItems[i].subMenu)) {
			var sm = getMenuLayer(name + "__" + m.menuItems[i].subMenu);
			sm.parentIndex = i;
			if (m_autoExpand == true) {
				showSubMenuSoon(o, name, m.menuItems[i].subMenu, i);
			}
		}
	} else {
		//setTimeout("hideAllMenusAbove('" + name + "', false);", md);
	}
	if (m_autoExpand == false) {
		hideSubMenuSoon(name);
		//alert("Hid " + name);	
	}
}

function exitMenuItem(o, name, i) {
	var m = getMenu(name);
	
	var m_textColor = (m.menuItems[i].textColor) ? m.menuItems[i].textColor : (m.menuOptions.textColor) ? m.menuOptions.textColor : "";
	var m_bgColor = (m.menuItems[i].bgColor) ? m.menuItems[i].bgColor : "";
	var m_border = (m.menuOptions.border ? m.menuOptions.border : 0);
	var m_borderColor = (m.menuOptions.borderColor ? m.menuOptions.borderColor : "#000000");
	var m_divSize = ((m.menuOptions.divSize + "") != "undefined" ? m.menuOptions.divSize : (JMENU_defaultItemSeparatorSize + "") != "undefined" ? JMENU_defaultItemSeparatorSize : 1);
	var m_divColor = (m.menuOptions.divColor ? m.menuOptions.divColor : "#000000");
	
	o.bgColor = m_bgColor;
	setMenuFontColor(name, i, m_textColor);
	
	var objLeft = getObj("mnuItem_" + name + "_" + i + "_left");
	var objCenter = getObj("mnuItem_" + name + "_" + i + "_center");
	var objRight = getObj("mnuItem_" + name + "_" + i + "_right");
	//var objRight = getObj("mnuItem_" + name + "_" + i + "_center");
	
	var objUp = getObj("mnuItem_" + name + "_" + (i - 1));
	var objUpLeft = getObj("mnuItem_" + name + "_" + (i - 1) + "_left");
	var objUpCenter = getObj("mnuItem_" + name + "_" + (i - 1) + "_center");
	var objUpRight = getObj("mnuItem_" + name + "_" + (i - 1) + "_right");
	//var objUpRight = getObj("mnuItem_" + name + "_" + (i - 1) + "_center");
	
	var divBottom = "none";
	if (m_divSize > 0) {
		divBottom = m_divSize + "px solid " + m_divColor;
	}
	
	if (objLeft) {
		//objLeft.style.borderLeft = "none";
		if (i == 0) {
			if (objUp) objUp.style.borderTop = (m_border > 0 ? m_border + "px solid " + m_borderColor : "none");
		} else {
			if (objUpLeft) objUpLeft.style.borderBottom = divBottom;
		}
		objLeft.style.borderBottom = ((i < m.menuItems.length - 1) ? divBottom : "none");
	}
	if (objCenter) {
		//objCenter.style.border = "none";
		if (i == 0) {
			if (objUp) objUp.style.borderTop = (m_border > 0 ? m_border + "px solid " + m_borderColor : "none");
		} else {
			if (objUpCenter) objUpCenter.style.borderBottom = divBottom;
		}
		objCenter.style.borderBottom = ((i < m.menuItems.length - 1) ? divBottom : "none");
	}
	if (objRight) {
		//objRight.style.borderRight = "none";
		if (i == 0) {
			if (objUp) objUp.style.borderTop = (m_border > 0 ? m_border + "px solid " + m_borderColor : "none");
		} else {
			if (objUpRight) objUpRight.style.borderBottom = divBottom;
		}
		objRight.style.borderBottom = ((i < m.menuItems.length - 1) ? divBottom : "none");
	}
	
	if (m.menuItems[i].subMenu) {
		if (getMenuRule(name + "__" + m.menuItems[i].subMenu, "hide") != "never") {
			clearShowSubMenuTimeout(name + "__" + m.menuItems[i].subMenu);
			clearHideSubMenuTimeout(name + "__" + m.menuItems[i].subMenu);
			hideSubMenuSoon(name + "__" + m.menuItems[i].subMenu);
		}
	} else {
		var m_layer = getMenuLayer(name);
		if (m_layer) {
			if (m_layer.isSubMenu) {
				if (getMenuRule(name, "hide") != "never") {
					clearShowSubMenuTimeout(name);
					clearHideSubMenuTimeout(name);
					hideSubMenuSoon(name);
				}
			}
		}
	}
	
	if (getMenuRule(getFirstNode(name), "hide") != "never") {
		hideMenu();
	}
	
	currentMenuItem = "";
}

function showSubMenuSoon(objRow, parent, name, i) {
	if (!getMenuLayerVisible(parent + "__" + name)) {
		var smd = 200;
		if (JMENU_showSubMenuDelay >= 0) {
			smd = JMENU_showSubMenuDelay;
		}
		var coord = GetElementBound(objRow);
		var sm = getMenuLayer(parent + "__" + name);
		sm.parentIndex = i;
		var m = getMenu(parent);
		var m_autoExpand = (m.menuItems[i].autoExpand + "") != "undefined" ? m.menuItems[i].autoExpand : (m.menuOptions.autoExpand + "") != "undefined" ? m.menuOptions.autoExpand : true;
		
		if (is_opera) {
			var scrollOffset = GetScrollOffset();
			coord.x -= scrollOffset.x;
			coord.left = coord.x;
		}
		if (m_autoExpand == true) {
			eval("window.showSubMenu_" + parent + "__" + name + "_Timeout = setTimeout('showSubMenu(" + (coord.x) + ", " + (coord.y) + ", " + (coord.width) + ", " + (coord.height) + ", \"" + parent + "\", \"" + name + "\", " + i + ");', " + smd + ");");
		} else {
			//alert("showNOW!");
			showSubMenu((coord.x), (coord.y), (coord.width), (coord.height), parent, name, i);
		}
	}
}

function getMenuRule(name, rule) {
	var m = getMenu(name);
	var result = "";
	if (m) {
		if (m.menuOptions.rules) {
			var m_rules = m.menuOptions.rules.split("|");
			for(var c = 0; c < m_rules.length; c++) {
				if ((m_rules[c].split(":")).length <= 1) continue;
				var ruleName = (m_rules[c].split(":")[0]).toLowerCase();
				var ruleValue = (m_rules[c].split(":")[1]).toLowerCase();
				
				if (ruleName == rule) {
					result = ruleValue;
					break;
				}
			}
		}
	}
	return result;
}

function getMenuItemRule(name, i, rule) {
	var m = getMenu(name);
	var result = "";
	if (m) {
		if (i >= 0 && i < m.menuItems.length) {
			if (m.menuItems[i].rules) {
				var m_rules = m.menuItems[i].rules.split("|");
				for(var c = 0; c < m_rules.length; c++) {
					if ((m_rules[c].split(":")).length <= 1) continue;
					var ruleName = (m_rules[c].split(":")[0]).toLowerCase();
					var ruleValue = (m_rules[c].split(":")[1]).toLowerCase();
					
					if (ruleName == rule) {
						result = ruleValue;
						break;
					}
				}
			}
		}
	}
	return result;
}

function showMenu(name, leftObject, topObject) {
	
	var m_orientation = "down";
	if ((JMENU_defaultMenuOrientation + "") != "undefined") {
		m_orientation = JMENU_defaultMenuOrientation;
	}
	if (showMenu.arguments.length > 3) {
		m_orientation = showMenu.arguments[3];
		if (m_orientation.length == 0) m_orientation = "down";
	}
	
	var lefto = leftObject;
	var topo = topObject;
	if (lefto) {
		if (!lefto.tagName) {
			var l = getObj(lefto);
			if (l) {
				lefto = l;
			} else {
				lefto = "";
			}
		}
	}
	
	if (topo) {
		if (!topo.tagName) {
			var t = getObj(topo);
			if (t) {
				topo = t;
			} else {
				topo = "";
			}
		}
	}
	
	if (m_orientation != "fixed") {
		if (topo == "" || lefto == "") {
			return;
		}
	}
	
	var m = getMenu(name);
	var fnc = "setLayerVisible(\"" + name + "\", false);currentMenu = null;showMenu(";
	for(var i = 0; i < showMenu.arguments.length; i++) {
		var opentext = "";
		var closetext = "";
		if (typeof(showMenu.arguments[i]) == "string") {
			opentext = "\"";
			closetext = "\"";
		}
		fnc += opentext + (showMenu.arguments[i]) + closetext;
		if (i < showMenu.arguments.length - 1) fnc += ", ";
	}
	fnc += ")";
	m.functionCall = fnc;
	
	var m_layer = getObj("floatingMenu");
	var m_layerStyle = getObjStyle("floatingMenu");
	var left = 0;
	var top = 0;
	var width = 0;
	var height = 0;
	var hoord = GetElementBound(lefto);
	var voord = GetElementBound(topo);
	if (lefto) {
		left = hoord.x;
		width = hoord.width;
	}
	if (topo) {
		top = voord.y;
		height = voord.height;
	}
	
	var m_height = 0;
	var dirXOffset = 0;
	var dirYOffset = 0;
	var docWidth = document.body.clientWidth + document.body.scrollLeft;
	var docHeight = document.body.clientHeight + document.body.scrollTop;
	
	clearHideMenuTimeout();
	
	if ((currentMenu) && currentMenu == m) {
		return; //Netscape "flicker" FIX
	} else if ((currentMenu)) {
		if (currentMenu.menuOptions.onHide) {
			//var m = this.m;
			//var menu = getMenuLayer(
			eval(currentMenu.menuOptions.onHide);
		}
	}
	
	setLayerVisible("floatingMenu", false);
	
	currentMenu = m;
	
	m_layer.parentX = lefto;
	m_layer.parentY = topo;
	
	setLayerContent("floatingShadows", "");
	
	buildSubMenusList = "";
	//setLayerContent("floatingSubMenus", "");
	setLayerContent("floatingSubMenus", buildSubMenus(name, 0));
	
	//setLayerBorder("floatingMenu", m.menuOptions.border, m.menuOptions.borderColor);
	setLayerBgColor("floatingMenu", m.menuOptions.bgColor);
	
	setLayerContent("floatingMenu", buildMenu(name));
	

	/*
	if (m_orientation == "fixed") {
		if (showMenu.arguments.length > 5) {
			dirXOffset = parseInt(eval(showMenu.arguments[4]));
			dirYOffset = parseInt(eval(showMenu.arguments[5]));
		}
		left = dirXOffset;
		top = dirYOffset;
	}
	*/
	
	
	if (m_orientation == "up") {
		m_height = 20;
		if (JMENU_defaultItemHeight >= 0) {
			m_height = JMENU_defaultItemHeight;
		}
		if ((m.menuOptions.itemHeight + "") != "undefined") {
			m_height = m.menuOptions.itemHeight;
		}
		top -= (m_height * m.menuItems.length);
		var ds = 1;
		if (JMENU_defaultItemSeparatorSize >= 0) {
			ds = JMENU_defaultItemSeparatorSize;
		}
		if (m.menuOptions.divSize) {
			ds = parseInt(m.menuOptions.divSize);
		}
		top -= (ds * (m.menuItems.length - 1));
		if (m.menuOptions.border) {
			top -= (parseInt(m.menuOptions.border) * 2);
		}
		//top -= 2;
	} else if (m_orientation == "right") {
		left += (hoord.width);
		//left += 2;
	} else if (m_orientation == "left") {
		left -= (getObj("floatingMenu").offsetWidth);
		if (m.menuOptions.border) {
			left -= (parseInt(m.menuOptions.border) * 1);
		}
		//left -= 2;
	} else if (m_orientation == "on") {
		//m_orientation = "down";
	} else if (m_orientation != "fixed") { //"down"
		top += (voord.height);
		//top += 2;
	}
	
	//Allow for webmaster to adjust menu position...
	if (showMenu.arguments.length > 5) {
		var menuWidth = getObj("floatingMenu").offsetWidth;
		var menuHeight = getObj("floatingMenu").offsetHeight;
		dirXOffset = parseInt(eval(showMenu.arguments[4]));
		dirYOffset = parseInt(eval(showMenu.arguments[5]));
	}
	left += dirXOffset;
	top += dirYOffset;
	
	var scLeft = document.body.scrollLeft;
	var scTop = document.body.scrollTop;
	var sbLeft = 0;
	var sbTop = 0;
	
	// if the menu won't fit...
	if (docWidth < (left + getObj("floatingMenu").offsetWidth)) {
		// but the menu WOULD fit if the page were scrolled a bit...
		if (document.body.clientWidth <= (left + getObj("floatingMenu").offsetWidth)) {
			sbLeft = ((left + getObj("floatingMenu").offsetWidth) - docWidth);
		} else {
			left = docWidth - (getObj("floatingMenu").offsetWidth) - 2;
		}
	}
	if (scLeft > left) {
		if (left >= 0) {
			sbLeft = (left - scLeft);
		} else {
			left = scLeft + 2;
		}
	}
	
	if (docHeight < (top + getObj("floatingMenu").offsetHeight)) {
		if (document.body.clientHeight <= (top + getObj("floatingMenu").offsetHeight)) {
			sbTop = ((top + getObj("floatingMenu").offsetHeight) - docHeight);
		} else {
			top = docHeight - (getObj("floatingMenu").offsetHeight) - 2;
		}
	}
	if (scTop > top) {
		if (top >= 0) {
			sbTop = (top - scTop);
		} else {
			top = scTop + 2;
		}
	}
	
	if (sbLeft != 0 || sbTop != 0) {
		window.self.scrollBy(sbLeft, sbTop);
	}
	
	moveLayer("floatingMenu", left, top);
	if (m.menuOptions.onShow) {
		eval(m.menuOptions.onShow);
	}
	setLayerVisible("floatingMenu", true);

	if (m.menuOptions.shadow) {
		var shs = parseInt(m.menuOptions.shadow);
		var shc = m.menuOptions.shadowColor;
		if (shc) {
			createMenuDropShadow(m, "floatingMenu", shs, shc);
		} else {
			createMenuDropShadow(m, "floatingMenu", shs);
		}
	}
	
	if (m.menuOptions.opacity && !is_nav) {
		setLayerOpacity("floatingMenu", parseInt(m.menuOptions.opacity));
	} else if (!is_nav) {
		setLayerOpacity("floatingMenu", 100);
	}
}


function hideMenu() {
	if (hideMenu.arguments.length > 0) {
		if (hideMenu.arguments[0] == "now") {
			clearHideMenuTimeout();
			
			var m = currentMenu;
			if (m) {
				if (m.menuOptions.onHide) {
					eval(m.menuOptions.onHide);
				}
			}
			
			setLayerContent("floatingShadows", "");
			setLayerContent("floatingSubMenus", "");
			setLayerVisible("floatingMenu", false);
			currentMenu = "";
			
		}
	} else {
		var md = 650;
		if (JMENU_hideMenuDelay >= 0) {
			md = JMENU_hideMenuDelay;
		}
		hideMenuTimeout = setTimeout('hideMenu("now");', md);
	}
}


function showSubMenu(x, y, parentWidth, parentHeight, parent, name, index) {
	var docWidth = document.body.clientWidth + document.body.scrollLeft;
	var docHeight = document.body.clientHeight + document.body.scrollTop;
	var barWidth = (document.body.offsetWidth - document.body.clientWidth) > 0 ? (document.body.offsetWidth - document.body.clientWidth) : 21;
	
	clearHideMenuTimeout();
	//alert(parent + "\n" + name);
	//keepAllMenusUnder(parent + "__" + name);
	hideAllMenusAbove(parent + "__" + name);  //Try uncommenting this if menus don't go away all the time...
	clearShowSubMenuTimeout(parent + "__" + name);
	clearHideSubMenuTimeout(parent + "__" + name);
	
	var m_layer = getMenuLayer(parent + "__" + name);
	var m_layerStyle = getMenuLayerStyle(parent + "__" + name);
	var m_parentLayerStyle = getMenuLayerStyle(parent);
	if (m_parentLayerStyle) {
		if (m_parentLayerStyle.zIndex) {
			m_layerStyle.zIndex = (parseInt(m_parentLayerStyle.zIndex) + 1);
		} else {
			m_layerStyle.zIndex = 50;
		}
	}
	
	var m = getMenu(name);
	m_layer.isSubMenu = true;
	
	
	var isVisible = getMenuLayerVisible(parent + "__" + name);
	
	//setMenuLayerBorder(parent + "__" + name, m.menuOptions.border, m.menuOptions.borderColor);
	
	setMenuLayerContent(parent + "__" + name, buildMenu(parent + "__" + name));
	
	var layerWidth = m_layer.offsetWidth;
	var layerHeight = m_layer.offsetHeight;
	
	var smor = "right";
	if ((JMENU_defaultSubMenuDir + "") != "undefined") {
		smor = JMENU_defaultSubMenuDir;
	}
	if (getMenu(getLastNode(parent)).menuItems[index].subMenuDir) {
		smor = getMenu(getLastNode(parent)).menuItems[index].subMenuDir;
	}
	
	var m_x = x;
	var m_y = y;
	
	m_y += (parentHeight * 0.0);
	if (getMenu(parent).menuOptions.border) {
		//m_x += parseInt(getMenu(parent).menuOptions.border);
		//m_y += parseInt(getMenu(parent).menuOptions.border);
	}
	
	if (m.menuOptions.border) {
		m_y -= parseInt(m.menuOptions.border);
	}
	
	//alert("docWidth = " + docWidth + "\n\nright_edge = " + (m_x + (parentWidth + 2) + layerWidth));
	if (docWidth < (m_x + (parentWidth + 2) + layerWidth)) {
		smor = "left";
	}
	if (document.body.scrollLeft > (m_x - layerWidth - 2)) {
		smor = "right";
	}
	
	if (smor == "left") {
		m_x -= (layerWidth);
		//m_x -= 2;
	} else {
		m_x += (parentWidth);
		//m_x += 2;
	}
	
	var sbTop = 0;
	if (m_y + layerHeight > docHeight) {
		sbTop = (m_y + layerHeight) - docHeight;
	}
	
	if (sbTop != 0) {
		//window.self.scrollBy(0, sbTop);
		
		var menuHTML = wrapInLayer(
			"innerMenuLayer_" + parent + "__" + name, 
			buildMenu(parent + "__" + name), 
			"overflow: " + ((document.layers) ? "scroll" : "auto") + ";" + 
			" height:" + ((docHeight - m_y) - (parseInt(m.menuOptions.border) * 2) - 4) + "px;" + 
			" width:" + (layerWidth + barWidth) + ";" + 
			" border: 0px solid #000000;", 
			"onMouseOver=\"keepAllMenusUnder('" + parent + "__" + name + "');\" "
			+ "onMouseOut=\"hideSubMenuSoon('" + parent + "__" + name + "');\""
		);
		setMenuLayerContent(parent + "__" + name, menuHTML);
		
	}
	
	setMenuLayerVisible(parent + "__" + name, false);
		
	moveMenuLayer(parent + "__" + name, m_x, m_y);
	if (m.menuOptions.onShow) {
		eval(m.menuOptions.onShow);
	}
	setMenuLayerVisible(parent + "__" + name, true);
	
	//keepAllMenusUnder(parent + "__" + name);
	
	if (m.menuOptions.shadow) {
		var shs = parseInt(m.menuOptions.shadow);
		var shc = m.menuOptions.shadowColor;
		if (shc) {
			createMenuDropShadow(m, parent + "__" + name, shs, shc);
		} else {
			createMenuDropShadow(m, parent + "__" + name, shs);
		}
	}
	
	if (m.menuOptions.opacity && !is_nav) {
		setLayerOpacity("floatingMenu_" + parent + "__" + name, parseInt(m.menuOptions.opacity));
	} else if (!is_nav) {
		setLayerOpacity("floatingMenu_" + parent + "__" + name, 100);
	}
	//alert("subMenu shown!");
	
	swapImages("itemNode_" + parent + "_" + index, JMENU_IMAGE_ItemNodeExpanded);
}


function hideSubMenuSoon(name) {
	var md = 200;
	if (JMENU_hideSubMenuDelay >= 0) {
		md = JMENU_hideSubMenuDelay;
	}
	
	var func = "hideSubMenu(\"" + name + "\"";
	if (hideSubMenuSoon.arguments.length > 1) {
		var isBool = (hideSubMenuSoon.arguments[1] == false || hideSubMenuSoon.arguments[1] == true);
		func += ", " + (isBool ? "" : "\"") + hideSubMenuSoon.arguments[1] + (isBool ? "" : "\"");
	}
	func += ");";
	eval("window.hideSubMenu_" + name + "_Timeout = setTimeout('" + func + "', " + md + ");");
}

function hideSubMenu(name) {
	clearShowSubMenuTimeout(name);
	clearHideSubMenuTimeout(name);
	
	var m = getMenu(name);
	if (m) {
		if (m.menuOptions.onHide) {
			eval(m.menuOptions.onHide);
		}
	}
	
	if (hideSubMenu.arguments.length > 1) {
		hideAllMenusAbove(name, false);
	} else {
		hideAllMenusAbove(name);
	}
	clearShowSubMenuTimeout(name);
	clearHideSubMenuTimeout(name);
	
	if (getMenuLayer(name)) {
		swapImages("itemNode_" + getParentNode(name) + "_" + getMenuLayer(name).parentIndex, JMENU_IMAGE_ItemNodeCollapsed);
	}
	//alert("finished hideSubMenu(  " + name + "  )!\n\ncaller: " + (hideSubMenu.caller).toString().split("\n")[0]);
}

function hideAllMenusAbove(name) {
	if (hideAllMenusAbove.arguments.length > 0) {
		if (name.length > 0) {
			var m = getMenuLayer(name);
			if (m) {
				var theNode = getParentNode(name);
				if (hideAllMenusAbove.arguments.length > 1) {
					if (!hideAllMenusAbove.arguments[1]) { //Check for NOT (isInclusive)
						theNode = name;
					}
				}
				
				//alert(theNode);
				var existingSubMenus = buildSubMenusList.split("\n");
				for(var i = 0; i < existingSubMenus.length; i++) {
					if (existingSubMenus[i].length > theNode.length) {
						if (existingSubMenus[i].substr(0, theNode.length) == theNode) {
							clearHideSubMenuTimeout(existingSubMenus[i]);
							//clearShowSubMenuTimeout(existingSubMenus[i]);
							killMenuDropShadow(existingSubMenus[i]);
							setMenuLayerVisible(existingSubMenus[i], false);
						}
					}
				}
			}
		}
	}
}

function wrapInLayer(name, content) {
	var result = "";
	if (document.layers) {
		result += "<div";
	} else {
		result += "<span";
	}
	result += " id=\"" + name + "\" name=\"" + name + "\"";
	result += " style=\"cursor: default; visibility: inherit; border: 0px;";
	if (wrapInLayer.arguments.length > 2) {
		if (wrapInLayer.arguments[2].length > 0) {
			result += " " + wrapInLayer.arguments[2];
		}
	}
	result += "\"";
	if (wrapInLayer.arguments.length > 3) {
		if (wrapInLayer.arguments[3].length > 0) {
			result += " " + wrapInLayer.arguments[3];
		}
	}
	result += ">";
	result += content;
	if (document.layers) {
		result += "</div>";
	} else {
		result += "</span>";
	}
	return result;
}

function objContains(obj, subObj) {
	if (typeof(obj) != "object" || typeof(subObj) != "object") return false;
	if (obj == subObj) {
		return true;
	}
	var result = false;
	var childs = obj.children;
	if (childs && childs.length > 0) {
		for(var i = 0; i < childs.length; i++) {
			var tmpResult = objContains(childs[i], subObj);
			if (tmpResult == true) {
				result = tmpResult;
				break;
			}
		}
	}
	return result;
}

function buildMenu(o) {
	var m = getMenu(getLastNode(o));
	if (!m.id) m.id = o;
	
	var mBgColor = "";
	
	var result = "";
	
	result += "<table id=\"mnuItem_" + o + "_-1\" name=\"mnuItem_" + o + "_-1\" border=\"0\" cellspacing=\"0\"";
	//result += " onMouseOver=\"keepAllMenusUnder('" + o + "');\"";
	//result += " onMouseOut=\"hideSubMenuSoon('" + o + "');\"";
	if (m.menuOptions.width) {
		if (!isNaN(m.menuOptions.width)) {
			result += " width=\"" + m.menuOptions.width + "\"";
		} else {
			var parent = 0;
			var ml = getObj("floatingMenu");
			if (ml) {
				var px = ml.parentX;
				if (px) {
					parent = px.offsetWidth;
				}
			}
			result += " width=\"" + parseInt(eval(m.menuOptions.width)) + "\"";
		}
	}
	
	if (m.menuOptions.bgColor) {
		mBgColor = m.menuOptions.bgColor;
		result += " bgColor=\"" + mBgColor + "\"";
	}
	
	if (m.menuOptions.bgImage) {
		result += " background=\"" + m.menuOptions.bgImage + "\"";
	}
	
	if (m.menuOptions.border) {
		var m_borderColor = m.menuOptions.borderColor ? m.menuOptions.borderColor : "#000000";
		result += " style=\"border: " + parseInt(m.menuOptions.border) + "px solid " + m_borderColor + ";\"";
	}
	
	result += ">";
	for(var i = 0; i < m.menuItems.length; i++) {
		if (!m.menuItems[i].parentMenu) m.menuItems[i].parentMenu = m;
		//----------------------------------------------------
		var m_bgColor = m.menuItems[i].bgColor ? m.menuItems[i].bgColor : "";
		var txtColor = m.menuItems[i].textColor ? m.menuItems[i].textColor : m.menuOptions.textColor ? m.menuOptions.textColor : "";
		var textActiveColor = m.menuItems[i].textActiveColor ? m.menuItems[i].textActiveColor : m.menuOptions.textActiveColor ? m.menuOptions.textActiveColor : "";
		var m_font = m.menuItems[i].font ? m.menuItems[i].font : m.menuOptions.font ? m.menuOptions.font : "";
		var m_activeColor = m.menuItems[i].activeColor ? m.menuItems[i].activeColor : m.menuOptions.activeColor ? m.menuOptions.activeColor : "";
		var m_textHoverColor = m.menuItems[i].textHoverColor ? m.menuItems[i].textHoverColor : m.menuOptions.textHoverColor ? m.menuOptions.textHoverColor : "";
		var m_hoverColor = m.menuItems[i].hoverColor ? m.menuItems[i].hoverColor : m.menuOptions.hoverColor ? m.menuOptions.hoverColor : "";
		var m_height = m.menuItems[i].itemHeight ? m.menuItems[i].itemHeight : m.menuOptions.itemHeight ? m.menuOptions.itemHeight : JMENU_defaultItemHeight >= 0 ? JMENU_defaultItemHeight : 20;
		var m_cursor = ((m.menuItems[i].url) ? "pointer" : "default");
		var m_align = m.menuItems[i].align ? m.menuItems[i].align : m.menuOptions.align ? m.menuOptions.align : "left";
		var m_valign = m.menuItems[i].valign ? m.menuItems[i].valign : m.menuOptions.valign ? m.menuOptions.valign : "middle";
		var m_url = m.menuItems[i].url ? m.menuItems[i].url : "";
		var m_target = m.menuItems[i].target ? m.menuItems[i].target : m.menuOptions.target ? m.menuOptions.target : "";
		var m_statusText = m.menuItems[i].statusText ? m.menuItems[i].statusText : (m_url.length > 0) ? (((JMENU_decideWhenNoStatusText_ShowURL + "") == "undefined") || JMENU_decideWhenNoStatusText_ShowURL == true ? m_url : "") : "";
		var m_bgImage = m.menuItems[i].bgImage ? m.menuItems[i].bgImage : "";
		var m_fontSize = m.menuItems[i].fontSize ? m.menuItems[i].fontSize : m.menuOptions.fontSize ? m.menuOptions.fontSize : "";
		var m_autoExpand = (m.menuItems[i].autoExpand + "") != "undefined" ? m.menuItems[i].autoExpand : (m.menuOptions.autoExpand + "") != "undefined" ? m.menuOptions.autoExpand : true;
		var m_showPlusMinus = (m.menuItems[i].showPlusMinus + "") != "undefined" ? m.menuItems[i].showPlusMinus : (m.menuOptions.showPlusMinus + "") != "undefined" ? m.menuOptions.showPlusMinus : false;
		var m_fontBold = ((m.menuItems[i].fontBold + "") != "undefined" && (m.menuItems[i].fontBold == "yes" || m.menuItems[i].fontBold == "true" || m.menuItems[i].fontBold == true)) ? true : ((m.menuOptions.fontBold + "") != "undefined" && (m.menuOptions.fontBold == "yes" || m.menuOptions.fontBold == "true" || m.menuOptions.fontBold == true)) ? true : false;
		var m_divSize = ((m.menuOptions.divSize + "") != "undefined" ? m.menuOptions.divSize : (JMENU_defaultItemSeparatorSize + "") != "undefined" ? JMENU_defaultItemSeparatorSize : 1);
		var m_divColor = ((m.menuOptions.divColor + "") != "undefined" ? m.menuOptions.divColor : "#000000");
		var h_colspan = m.menuItems[i].subMenu ? 3 : 3;
		var wruleItem = getMenuItemRule(getLastNode(o), i, "wrap");
		var wrule = getMenuRule(getLastNode(o), "wrap");
		
		if (m_align != "" && m_align.toLowerCase() != "left" && m_align.toLowerCase() != "center" && m_align.toLowerCase() != "right") {
			//alert("Invalid \"align\" property!");
			m_align = "";
		}
		if (m_valign != "" && m_valign.toLowerCase() != "top" && m_valign.toLowerCase() != "middle" && m_valign.toLowerCase() != "bottom" && m_valign.toLowerCase() != "baseline") {
			//alert("Invalid \"valign\" property!");
			m_valign = "";
		}
		
		result += "<tr id=\"mnuItem_" + o + "_" + i + "\" name=\"mnuItem_" + o + "_" + i + "\"";
		result += " style=\"cursor: " + m_cursor + "\"";
		result += " bgColor=\"" + m_bgColor + "\"";
		if (m_bgImage.length > 0) {
			result += " background=\"" + m_bgImage + "\"";
		}
		result += " onMouseOver=\"";
		
		if (is_ie) {
			result += "if (objContains(this, event.fromElement)) return;";
		}
		
		if (m_hoverColor.length > 0) {
			result += "bgColor = '" + m_hoverColor + "'; ";
		}
		result += "window.status = '" + m_statusText.replace("\"", "\\\"").replace("'", "\\'") + "'; ";
		result += "hoverMenuItem";
		result += "(this, '" + o + "', " + i + ");";
		
		result += " return true;\"";
		result += " onMouseOut=\"";
		
		if (is_ie) {
			result += "if (objContains(this, event.toElement)) return;";
		}
		
		result += "window.status = ''; ";
		result += "exitMenuItem";
		result += "(this, '" + o + "', " + i + ");";
		
		if (m_url.length > 0) {
			result += "\" onClick=\"";
			if (m_target == "") {
				result += "window.self.location.href = '" + m_url + "';";
			} else if (m_target == "_blank" || m_target == "_new") {
				result += "window.open('" + m_url + "', '', 'toolbar=yes,location=yes,status=yes,menubar=yes,scrollbars=yes,resizable=yes');";
			} else {
				if (isNaN(m_target)) {
					result += "window.top.frames['" + m_target + "'].location.href = '" + m_url + "';";
				} else {
					result += "window.top.frames[" + parseInt(m_target) + "].location.href = '" + m_url + "';";
				}
			}
		}
		result += "\"";
		
		if (m_activeColor.length > 0 || textActiveColor.length > 0) {
			result += " onMouseDown=\"";
			if (m_activeColor.length > 0) {
				result += "bgColor = '" + m_activeColor + "';";
			}
			if (textActiveColor.length > 0) {
				result += "setMenuFontColor('" + o + "', " + i + ", '" + textActiveColor + "');";
			}
			result += "\"";

			result += " onMouseUp=\"";
			if (m_activeColor.length > 0) {
				result += "bgColor = '" + ((m_hoverColor.length > 0) ? m_hoverColor : (mBgColor.length > 0) ? mBgColor : "") + "';";
			}
			if (textActiveColor.length > 0) {
				result += "setMenuFontColor('" + o + "', " + i + ", '" + m_textHoverColor + "');";
			}
			result += "\"";
		}
		result += ">";
		
		result += "<td id=\"mnuItem_" + o + "_" + i + "_left\" name=\"mnuItem_" + o + "_" + i + "_left\" nowrap";
		result += " height=\"" + (m_height) + "\"";
		if (m_divSize > 0) {
			if (i < m.menuItems.length - 1) result += " style=\"border-bottom: " + m_divSize + "px solid " + m_divColor + "\"";
		}
		result += ">";
		result += "&nbsp;";
		result += "</td>";
		
		result += "<td id=\"mnuItem_" + o + "_" + i + "_center\" name=\"mnuItem_" + o + "_" + i + "_center\"";
		if (m_divSize > 0 || m_fontBold || (m_fontSize || m_fontSize.length > 0) || txtColor.length > 0 || m_font.length > 0) {
			result += " style=\"";
		}
		if (m_divSize > 0) {
			if (i < m.menuItems.length - 1) result += "border-bottom: " + m_divSize + "px solid " + m_divColor + ";";
		}
		if (m_font.length > 0) {
			result += " font-family: " + m_font + ";";
		}
		if (m_fontSize || m_fontSize.length > 0) {
			result += " font-size: " + m_fontSize + "px;";
		}
		if (m_fontBold) {
			result += " font-weight: bold;";
		}
		if (txtColor.length > 0) {
			result += " color: " + txtColor + ";";
		}
		if (m_divSize > 0 || m_fontBold || (m_fontSize || m_fontSize.length > 0) || txtColor.length > 0 || m_font.length > 0) {
			result += "\"";
		}
		if (wruleItem != "yes" && wruleItem != "true" && wruleItem != true) {
			if (wrule != "yes" && wrule != "true" && wrule != true) {
				result += " nowrap";
			}
		}
		
		result += " height=\"" + (m_height) + "\"";
		if (m_align.length > 0) result += " align=\"" + m_align + "\"";
		if (m_valign.length > 0) result += " valign=\"" + m_valign + "\"";
		result += ">";
		
		
		// START OF TEXT CELL
		result += (m.menuItems[i].text ? m.menuItems[i].text : m.menuOptions.text ? m.menuOptions.text : "");		
		result += "</td>";
		// END OF TEXT CELL
		
		
		
		//ARROW goes in this cell!
		result += "<td id=\"mnuItem_" + o + "_" + i + "_right\" name=\"mnuItem_" + o + "_" + i + "_right\"";
		result += " nowrap height=\"" + (m_height) + "\"";
		if (m.menuItems[i].subMenu) {
			result += " width=\"13\"";
		} else {
			result += "";
		}
		result += " align=\"right\" valign=\"middle\"";
		if (m_divSize > 0 || m_fontBold || (m_fontSize || m_fontSize.length > 0) || txtColor.length > 0 || m_font.length > 0) {
			result += " style=\"";
		}
		if (m_divSize > 0) {
			if (i < m.menuItems.length - 1) result += "border-bottom: " + m_divSize + "px solid " + m_divColor + ";";
		}
		if (m_font.length > 0) {
			result += " font-family: " + m_font + ";";
		}
		if (m_fontSize || m_fontSize.length > 0) {
			result += " font-size: " + m_fontSize + "px;";
		}
		if (m_fontBold) {
			result += " font-weight: bold;";
		}
		if (txtColor.length > 0) {
			result += " color: " + txtColor + ";";
		}
		if (m_divSize > 0 || m_fontBold || (m_fontSize || m_fontSize.length > 0) || txtColor.length > 0 || m_font.length > 0) {
			result += "\"";
		}
		result += ">";
		
		/*
		result += "<font id=\"arrowFont_" + o + "_" + i + "\" name=\"arrowFont_" + o + "_" + i + "\"";
		
		if (txtColor.length > 0) {
			result += " color=\"" + txtColor + "\"";
		}
		if ((m_fontSize) || m_fontSize.length > 0) {
			result += " style=\"font-size: " + m_fontSize + "px;\"";
		}
		result += ">";
		*/
		
		if (m.menuItems[i].subMenu) {
			if (m_autoExpand == true && m_showPlusMinus == false) {
				result += "<b>&raquo;</b>";
			} else {
				result += "<img id=\"itemNode_" + o + "_" + i + "\" name=\"itemNode_" + o + "_" + i + "\"";
				result += " src=\"" + JMENU_IMAGE_ItemNodeCollapsed + "\"";
				result += " style=\"cursor: pointer\"";
				result += " border=\"0\"";
				result += " onMouseOver=\"keepAllMenusUnder('" + o + "');";
				result += " var mnuItem = getObj('mnuItem_" + o + "_" + i + "'); if (mnuItem) {showSubMenuSoon(mnuItem, '" + o + "', '" + m.menuItems[i].subMenu + "', " + i + ");}\"";
				result += "\"";
				result += ">";
			}
		} else {
			result += "&nbsp;";
		}
		
		/*
		result += "</font>";
		*/
		result += "</td>";
		
		
		
		result += "</tr>";
		
		//This is the divider
		/*
		var dsize = 1;
		var dcolor = "#000000";
		if (JMENU_defaultItemSeparatorSize >= 0) {
			dsize = JMENU_defaultItemSeparatorSize;
		}
		if ((m.menuOptions.divSize + "") != "undefined") {
			dsize = parseInt(m.menuOptions.divSize);
		}
		if (dsize > 0) {
			if ((m.menuOptions.divColor + "") != "undefined") {
				dcolor = m.menuOptions.divColor;
			}
			if (i < (m.menuItems.length - 1)) {
				result += "<tr";
				result += " style=\"cursor: default\" bgColor=\"" + dcolor + "\"";
				result += " onMouseOver=\"keepAllMenusUnder('" + o + "');\"";
				result += " onMouseOut=\"hideSubMenuSoon('" + o + "');\"";
				result += ">";
				result += "<td nowrap colspan=\"" + h_colspan + "\" height=\"" + dsize + "\"></td>";
				result += "</tr>";
			}
		}
		*/
	}
	result += "</table>";
	
	return result;
}


function buildSubMenus(name, level) {
	var parentLayer = "";
	var lastNode = "";
	if (name.lastIndexOf("__") > 0) {
		lastNode = name.substr(name.lastIndexOf("__") + 2);
	} else {
		lastNode = name;
	}
	if (buildSubMenus.arguments.length > 2) {
		parentLayer = buildSubMenus.arguments[2];
	}
	//alert("name: " + name + "\nparent: " + parentLayer + "\nlevel: " + level);
	var m = getMenu(lastNode);
	var subMenus = "";

	for(var i = 0; i < m.menuItems.length; i++) {
		if (m.menuItems[i].subMenu) {
			if (level < 50) {
				buildSubMenusList += "" + name + "__" + m.menuItems[i].subMenu + "\n";
				//alert(buildSubMenusList + "\n\n" + buildSubMenusList.indexOf("|" + m.menuItems[i].subMenu + "|"));
			} else {
				//alert(buildSubMenusList.split("\n").length);
				return subMenus;
			}
			var mm = getMenu(m.menuItems[i].subMenu);
			if (document.layers) {
				subMenus += '<div';
			} else if ((document.getElementById) || (document.all)) {
				subMenus += '<span';
			}
			subMenus += ' name="floatingMenu_' + name + '__' + m.menuItems[i].subMenu + '" id="floatingMenu_' + name + '__' + m.menuItems[i].subMenu + '"';
			
			//if (document.layers) {
				//subMenus += ' top="-2000" left="-2000" z-index="50" visibility="hide"';
				//if (mm.menuOptions.bgColor) {
					//subMenus += ' bgColor="' + mm.menuOptions.bgColor + '"';
				//}
			//} else if ((document.getElementById) || (document.all)) {
				subMenus += ' style="position:absolute; z-index:50; visibility: hidden; overflow: visible; top: -2000; left: -2000; border: 0px solid #000000;';
				if (mm.menuOptions.bgColor) {
						subMenus += ' background-color: ' + mm.menuOptions.bgColor + '; layer-background-color: ' + mm.menuOptions.bgColor + ';';
				}
				subMenus += '"';
			//}
			
			subMenus += '>';
			if (document.layers) {
				subMenus += '</div>\n';
			} else if ((document.getElementById) || (document.all)) {
				subMenus += '</span>\n';
			}

			subMenus += buildSubMenus(name + "__" + m.menuItems[i].subMenu, ++level, name);
		}
	}
	//alert(buildSubMenusList);
	return subMenus;
}

function createMenuDropShadow(m, name, size, c) {
	if (is_nav || !is_win2kup || is_opera) return;
	if (!m) return;
	var menu = null;
	var shadowList = getObj("floatingShadows");
	if (name.indexOf("_") > 0) {
		menu = getMenuLayer(name);
	} else {
		menu = getObj(name);
	}
	if (!menu) return;
	var color = "#666666";
	if (c) {
		if (c == "inherit" || c == "parent") {
			if (m.menuOptions.bgColor) {
				color = m.menuOptions.bgColor;
			}
		} else {
			color = c;
		}
	}
	for (var i = size; i > 0; i--) {
		var rectContainer = document.createElement("div");
		rectContainer.name = "floatingShadow" + ((name.indexOf("_") > 0) ? "_" + name : "") + "_" + i;
		rectContainer.id = rectContainer.name;

		var m_pos = GetElementBound(menu);
		var distance = 2;
		var offset = size + ((m.menuOptions.shadowDistance + "") != "undefined" ? m.menuOptions.shadowDistance : 2);
		var opacity = 1 - i / (i + 1);
		
		var rdiv = document.createElement("div");
		var rstyle = rdiv.style;
		rstyle.position = "absolute";
		
		var sht = (m_pos.height - (size * 2) + (i * 2));
		
		rstyle.left = (m_pos.left + size - i + offset) + "px";
		rstyle.top = (m_pos.top + size - i + offset) + "px";
		rstyle.width = (m_pos.width - (size * 2) + (i * 2)) + "px";
		if (sht < 20) {
			rstyle.height = 30 + "px";
			rstyle.clip = "rect(auto, auto, " + sht + "px, auto)";
		} else {
			rstyle.height = sht + "px";
		}
		rstyle.zIndex = menu.style.zIndex - i;
		rstyle.backgroundColor = color;
		rstyle.filter = "alpha(opacity=" + (100 * opacity) + ")";
		rectContainer.appendChild(rdiv);
		shadowList.appendChild(rectContainer);
	}
}

function createMenuDropShadow2(m, name, size, c) {
	if (is_nav || !is_win2kup) return;
	if (!m) return;
	var menu = null;
	var shadowList = getObj("floatingShadows");
	if (name.indexOf("_") > 0) {
		menu = getMenuLayer(name);
	} else {
		menu = getObj(name);
	}
	if (!menu) return;
	var color = "#666666";
	if (c) {
		if (c == "inherit" || c == "parent") {
			if (m.menuOptions.bgColor) {
				color = m.menuOptions.bgColor;
			}
		} else {
			color = c;
		}
	}
	for (var i = size; i > 0; i--) {
		var rectContainer = document.createElement("div");
		rectContainer.name = "floatingShadow" + ((name.indexOf("_") > 0) ? "_" + name : "") + "_" + i;
		rectContainer.id = rectContainer.name;
		for (var j = 0; j < (true ? size - (i - 1) : 1); j++) {
			var m_pos = GetElementBound(menu);
			var distance = 6;
			var offset = ((m.menuOptions.shadowDistance + "") != "undefined" ? m.menuOptions.shadowDistance : 2);
			var opacity = 1 - i / (i + 1);
			
			var rdiv = document.createElement("div");
			var rstyle = rdiv.style;
			rstyle.position = "absolute";
			rstyle.left = (m_pos.right + (i - 1) + offset) + "px";
			rstyle.top = (m_pos.top + (size - i) + distance) + "px";
			rstyle.width = (1) + "px";
			rstyle.height = (m_pos.bottom - parseInt(rstyle.top) + (i - (1 - offset))) + "px";
			rstyle.zIndex = menu.style.zIndex - i;
			rstyle.backgroundColor = color;
			rstyle.filter = "alpha(opacity=" + (100 * opacity) + ")";
			rectContainer.appendChild(rdiv);
			//----------------------------------------------------------------
			var bdiv = document.createElement("div");
			var bstyle = bdiv.style;
			bstyle.position = "absolute";
			bstyle.left = (m_pos.left + (size - i) + distance) + "px";
			bstyle.top = (m_pos.bottom + (i + offset) - 30) + "px";
			bstyle.width = (m_pos.right - parseInt(bstyle.left) + (i + offset)) + "px";
			bstyle.height = 30 + "px";
			bstyle.clip = "rect(" + (parseInt(bstyle.height) - 1) + "px, auto, auto, auto)";
			bstyle.zIndex = menu.style.zIndex - i;
			bstyle.backgroundColor = color;
			bstyle.filter = "alpha(opacity=" + (100 * opacity) + ")";
			rectContainer.appendChild(bdiv);
			//----------------------------------------------------------------
			var tdiv = document.createElement("div");
			var tstyle = tdiv.style;
			tstyle.position = "absolute";
			tstyle.left = (m_pos.right) + "px";
			tstyle.top = (m_pos.top + (size - (i - 1)) + distance - 30) + "px";
			tstyle.width = (i - (1 - offset)) + "px";
			tstyle.height = 30 + "px";
			tstyle.clip = "rect(" + (parseInt(tstyle.height) - 1) + "px, auto, auto, auto)";
			tstyle.zIndex = menu.style.zIndex - i;
			tstyle.backgroundColor = color;
			tstyle.filter = "alpha(opacity=" + (100 * opacity) + ")";
			rectContainer.appendChild(tdiv);
			//----------------------------------------------------------------
			var ldiv = document.createElement("div");
			var lstyle = ldiv.style;
			lstyle.position = "absolute";
			lstyle.left = (m_pos.left + (size - i) + distance) + "px";
			lstyle.top = (m_pos.bottom - 30 + 0) + "px";
			lstyle.width = (1) + "px";
			lstyle.height = 30 + (i - (1 - offset)) + "px";
			lstyle.clip = "rect(" + (parseInt(lstyle.height) - (i - (1 - offset))) + "px, auto, auto, auto)";
			lstyle.zIndex = menu.style.zIndex - i;
			lstyle.backgroundColor = color;
			lstyle.filter = "alpha(opacity=" + (100 * opacity) + ")";
			rectContainer.appendChild(ldiv);
			//----------------------------------------------------------------
			for (var k = 1; k <= offset && i <= 1; k++) {
				var rtop = (m_pos.top + (size - 0) + distance);
				var rdiv = document.createElement("div");
				var rstyle = rdiv.style;
				rstyle.position = "absolute";
				rstyle.left = (m_pos.right + (offset - 1) + (i - k)) + "px";
				rstyle.top = rtop - 30 + "px";
				rstyle.width = (1) + "px";
				rstyle.height = 30 + (m_pos.bottom - parseInt(rtop) + (i - (1 - offset)) - k) + "px";
				rstyle.clip = "rect(" + (parseInt(rstyle.height) - (m_pos.bottom - parseInt(rtop) + (i - (1 - offset)) - k)) + "px, auto, auto, auto)";
				rstyle.zIndex = menu.style.zIndex - i;
				rstyle.backgroundColor = color;
				rstyle.filter = "alpha(opacity=" + (100 * opacity) + ")";
				rectContainer.appendChild(rdiv);
				//----------------------------------------------------------------
				var bdiv = document.createElement("div");
				var bstyle = bdiv.style;
				bstyle.position = "absolute";
				bstyle.left = (m_pos.left + (size - 0) + distance) + "px";
				bstyle.top = (m_pos.bottom + (i + offset) - k - 30) + "px";
				bstyle.width = (m_pos.right - parseInt(bstyle.left) + (i + offset) - k) + "px";
				bstyle.height = 30 + "px";
				bstyle.clip = "rect(" + (parseInt(bstyle.height) - 1) + "px, auto, auto, auto)";
				bstyle.zIndex = menu.style.zIndex - i;
				bstyle.backgroundColor = color;
				bstyle.filter = "alpha(opacity=" + (100 * opacity) + ")";
				rectContainer.appendChild(bdiv);
			}
		}
		shadowList.appendChild(rectContainer);
	}
}

function killMenuDropShadow(name) {
	var mname = "";
	if (name.indexOf("_") > 0) {
		mname = name;
	}
	var m = getMenu(mname);
	if (m) {
		if (m.menuOptions.shadow) {
			for(var i = parseInt(m.menuOptions.shadow); i > 0; i--) {
				var fs = getObj("floatingShadow" + (mname.length > 0 ? "_" + mname : "") + "_" + i);
				if (fs) {
					if (fs.removeNode) fs.removeNode(true);
				}
			}
		}
	}
}

window.ufm_Interval = 0;
window.sica_Timeout = 0;
function updateFloatingMenu() {
	if (currentMenu) {
		if (getLayerVisible("floatingMenu")) {
			var call = "";
			if (currentMenu.functionCall) call = currentMenu.functionCall;
			if (call.length > 0) {
				eval(call);
			}
		}
	}
}

function JM_resizeOverride() {
	if (window.sica_Timeout == 0) {
		//log("timeout == 0");
		window.ufm_Interval = setInterval("updateFloatingMenu();", 100);
	}
	if (window.sica_Timeout) {
		clearTimeout(window.sica_Timeout);
		window.sica_Timeout = 0;
	}
	window.sica_Timeout = setTimeout("if (window.ufm_Interval) {clearInterval(window.ufm_Interval);window.ufm_Interval = 0;window.sica_Timeout = 0;}", 500);
}

window.onresize = JM_resizeOverride;
