var timeOn = null;

var numMenus = 250;

var currentMenuNo = 0;
var menuActive = new Array(numMenus);
var tier = new Array(numMenus);
var borderMod = new Array(numMenus);
var offClass = new Array(numMenus);
var onClass = new Array(numMenus);
var offColours = new Array(numMenus);
var onColours = new Array(numMenus);
var labelBulletName = new Array(numMenus);
var menuType = new Array(numMenus);
var bgImages = new Array(numMenus);
var menus = new Array(numMenus);


function bulletPoint(offURL, onURL) {	
	this.offImage = new Image();
	this.offImage.src = offURL;
	this.onImage = new Image();
	this.onImage.src = onURL;
	this.URL = String(offURL);
}

function openMe(newin) {
        flyout=window.open(newin,"flyout","")
}

function borderCell(B) {
	return '<td width="1" bgcolor="' + B + '"><img src="images/shim.gif" width="1" height="1" border="0"></td>';
}

function borderRow(B, C) {
	return '<tr><td height="1" colspan="' + C + '" bgcolor="' + B + '"><img src="images/shim.gif" width="1" height="1" border="0"></td></tr>';
}

function menuOver() {
	clearTimeout(timeOn);
}

function menuOut() {
	timeOn = setTimeout("hideAllMenus()", 1000);
}


function showMenu(m_No, eventObj) {
	hideAllMenusTier(tier[m_No]-1);
	var borderModSize = borderMod[m_No];
	if (ns4) {
		changeBGColour('menuLabel' + m_No, onColours[m_No]);
		if(bgImages[m_No] != null)
			changeBGImage('menuLabel' + m_No, bgImages[m_No] + '.onImage');
	} else {
		changeBGColour('labelCell' + m_No, onColours[m_No]);
		if(bgImages[m_No] != null)
			changeBGImage('labelCell' + m_No, bgImages[m_No] + '.onImage');
		changeClass('menuLink' + m_No, onClass[m_No]);
	}
	if (labelBulletName[m_No] != null){
		changeImage('menuBullet' + m_No, labelBulletName[m_No] + '.onImage');
	}
	menuActive[m_No] = true;
	if (menuType[m_No] != 'blank') {
		if (ns4) labelObj = 'menuLabel'+m_No;
		else labelObj = 'labelCell'+m_No;
		
		x = getElementLeft(labelObj)-borderModSize;
		y = getElementTop(labelObj) + getElementHeight(labelObj);

		if (menus[m_No].align == 'center')  x = x + ((getElementWidth(labelObj)-getElementWidth('menu'+m_No))/2);
		if (menus[m_No].align == 'right') x = x + ((getElementWidth(labelObj)-getElementWidth('menu'+m_No))) + (borderModSize*2);

		moveXY('menu' + m_No, x, y);

		if(changeObjectVisibility('menu' + m_No, 'visible')) return true;
    	else return false;
	}
}

function showMenuSide(m_No, eventObj, myTier) {
	hideAllMenusTier(tier[m_No]-1);
	var borderModSize = borderMod[m_No];
	if (ns4) {
		changeBGColour('menuLabel' + m_No, onColours[m_No]);
		if(bgImages[m_No] != null)
			changeBGImage('menuLabel' + m_No, bgImages[m_No] + '.onImage');
		
	} else {
		changeBGColour('labelCell' + m_No, onColours[m_No]);
		if(bgImages[m_No] != null)
		      changeBGImage('labelCell' + m_No, bgImages[m_No] + '.onImage');
		changeClass('menuLink' + m_No, onClass[m_No]);
		
	}
	if (labelBulletName[m_No] != null) changeImage('menuBullet' + m_No, labelBulletName[m_No] + '.onImage');
	menuActive[m_No] = true;
	if (menuType[m_No] != 'blank') {
		if (ns4) {
			labelObj = 'menuLabel'+m_No;
		} else {
			labelObj = 'labelCell'+m_No;
			if (mac_ie) labelObj = 'labelRow'+m_No;
		}
		x = getElementLeft(labelObj);
		y = getElementTop(labelObj) - borderModSize;

		if (menus[m_No].align=='right') x = x + getElementWidth(labelObj);
		else x = x - getElementWidth('menu'+m_No);

		moveXY('menu' + m_No, x, y);
	
		if(changeObjectVisibility('menu' + m_No, 'visible')) return true;
	    else return false;
	}
}

function hideAllMenus() {
	for (var i = 1; i < (currentMenuNo+1); i++) {
		if(menuActive[i] == true) hideMenu(i);
	}
}

function hideAllMenusTier(myTier) {
	for (var i = 1; i < (currentMenuNo+1); i++) {
		if( tier[i] > myTier && menuActive[i] == true) hideMenu(i);
	}
}

function hideMenu(m_No) {
	if (ns4) {
		changeBGColour('menuLabel' + m_No, offColours[m_No]);
		if(bgImages[m_No] != null)
			changeBGImage('menuLabel' + m_No, bgImages[m_No] + '.offImage');
		
	} else {
		changeBGColour('labelCell' + m_No, offColours[m_No]);
		if(bgImages[m_No] != null)
			changeBGImage('labelCell' + m_No, bgImages[m_No] + '.offImage');
		changeClass('menuLink' + m_No, offClass[m_No]);
	}
	
	if (labelBulletName[m_No] != null){
		changeImage('menuBullet' + m_No, labelBulletName[m_No] + '.offImage');
	}
	
	menuActive[m_No] = false;
	
	if(changeObjectVisibility('menu' + m_No, 'hidden'))  return true;
    else return false;

}



function menuBar(barName, barWidth, orientation, i_Bor, o_Bor ) {
	this.numLabels = 0;
	this.i_Bor = i_Bor;	
	this.o_Bor = o_Bor;	
	this.height = 15;
	this.orientation = orientation;
	this.labelText = new Array();
	this.rowText = new Array();
	this.targetTypes = new Array();
	this.targetFrames = new Array();
	this.bulletAlign = 'right';
	this.targetType = 'self'; // self, iframe, frame, new
	this.targetFrame = '_self'; // _self, _blank or (i)frame name
	
	
	this.ConstructLabel = function(bullet, bgImage, menuNo, offColour, onColour, off_Class, on_Class)
	{
		tier[menuNo] = 0;
		if (this.o_Bor != null)
		    borderMod[menuNo] = 1;	
		else
		    borderMod[menuNo] = 0;	
		onColours[menuNo] = onColour;
		offColours[menuNo] = offColour;
		onClass[menuNo] = on_Class;
		offClass[menuNo] = off_Class;
		labelBulletName[menuNo] = bullet;
		if(bgImage != null)
		    bgImages[menuNo] = bgImage;		
	}
}


function menu(menuWidth, orientation, i_Bor, o_Bor) {
	currentMenuNo += 1;
	this.numItems = 0;
	this.i_Bor = i_Bor;	
	this.o_Bor = o_Bor;	
	this.height = 15;
	this.itemText = new Array();
	this.rowText = new Array();
	this.targetTypes = new Array();
	this.targetFrames = new Array();
	this.align = 'right';
	this.offClass = 'MenuLabelLink';
	this.onClass = 'MenuLabelLinkOn';
	this.orientation = orientation;
	this.bulletAlign = 'right';


	this.addItem = function(bullet, background, itemText, menuNo, itemWidth, offColour, onColour, offCls, onCls, itemURL, align, target_Type, target_Frame)
	{
		this.numItems += 1;
		
		this.targetType = 'self'; // self, iframe, frame, new
		
		if(this.targetTypes[this.numItems]!= null)
			this.targetType = this.targetTypes[this.numItems];		
		
		this.targetFrame = '_self'; // _self, _blank or (i)frame name
		if(this.targetFrames[this.numItems]!= null)
			this.targetFrame = this.targetFrames[this.numItems];	
		
		if (menuNo != null) {
			tier[menuNo] = tier[currentMenuNo] + 1;
			onColours[menuNo] = onColour;
			offColours[menuNo] = offColour;
			onClass[menuNo] = onCls;
			offClass[menuNo] = offCls;
			labelBulletName[menuNo] = bullet;
			bgImages[menuNo] = background;
			if (this.o_Bor != null)
			    borderMod[menuNo] = 1;	
			else
			    borderMod[menuNo] = 0;	
		}

		var tempId = currentMenuNo + '_' + this.numItems;

		temp = new String('');
		this.rowText[this.numItems] = new String('');

		if (menuNo != null)
		{
			if (this.orientation == 'vertical')
			    this.rowText[this.numItems] += '<tr id="labelRow'+ menuNo + '">';
			temp += '<td id="labelCell'+ menuNo + '" width="'+ itemWidth + '" bgcolor="' + offColour +
			    '" valign="middle" height="' + this.height + '" ';
		}
		else
		{
			if (this.orientation =='vertical')
			    this.rowText[this.numItems] += '<tr>';
			temp += '<td id="itemCell' + tempId + '" width="'+ itemWidth + '" bgcolor="' + offColour +
			    '" valign="middle" height="' + this.height + '" class="' + align + 'Menu"';
		}
		
		if (background != null)
		{
		  temp += ' background="' + eval(background + ".URL") + '"';
		}

		if (!ns4)
		{
			if (this.targetType == 'self')
			    temp += ' onclick="document.location.href=\'' + itemURL + '\';" ';

			if (this.targetType == 'new')
			    temp += ' onclick="openMe(\'' + itemURL + '\'); return false;" ';

			if (this.targetType == 'frame')
			    temp += ' onclick="parent.' + this.targetFrame + '.document.location.href=\'' + itemURL + '\';" ';

			if (this.targetType == 'iframe')
			    temp += ' onclick="' + this.targetFrame + '.location.href=\'' + itemURL + '\';" ';

			if (menuNo != null)
			{
				if (this.orientation =='vertical')
				    temp += ' onmouseover="menuOver(); return !showMenuSide(' + menuNo + ', event, tier[' + menuNo + ']); " onmouseout=" menuOut(); "';
				else
				    temp += ' onmouseover="menuOver(); return !showMenu(' + menuNo + ', event); " onmouseout=" menuOut(); "';
			}
			else
			{
				temp += ' onmouseover="changeClass(\'menuLink' + tempId + '\',\'' + onCls +
				    '\'); hideAllMenusTier(tier[' + currentMenuNo + ']); menuOver();  changeBGColour(\'itemCell' + tempId + '\', \'' + onColour + '\'); ';
				if(background != null)				
					temp += 'changeBGImage(\'itemCell' + tempId + '\', \'' + background + '.onImage\'); ';				

				temp += 'changeImage(\'menuItemBullet' + tempId + '\', \'' + bullet + '.onImage\'); " onmouseout="menuOut(); changeClass(\'menuLink' + tempId + '\',\'' + offCls + '\'); changeBGColour(\'itemCell' + tempId + '\', \'' + offColour + '\'); ';

				if(background != null)				
					temp += 'changeBGImage(\'itemCell' + tempId + '\', \'' + background + '.offImage\'); ';				

				temp += 'changeImage(\'menuItemBullet' + tempId + '\', \'' + bullet + '.offImage\'); "';
			}
		} 

		temp += '>';

		if (ns4)
		{
			temp += '<ilayer><layer ';
			if(menuNo != null)
			{
				if (this.orientation == 'vertical')
				    temp += 'onmouseover="menuOver(); return !showMenuSide(' + menuNo + ', event, tier[' + menuNo + ']);" onmouseout="menuOut();"';
				else
				    temp += 'onmouseover="menuOver(); return !showMenu(' + menuNo + ', event);" onmouseout="menuOut();"';
			}
			else
			{
				temp += 'onmouseover="hideAllMenusTier(tier[' + currentMenuNo + ']); menuOver(); changeBGColour(\'menuItem' + tempId + '\', \'' + onColour + '\'); changeImage(\'menuItemBullet' + tempId + '\', \'' + bullet + '.onImage\'); " onmouseout="menuOut(); changeBGColour(\'menuItem' + tempId + '\', \'' + offColour + '\'); changeImage(\'menuItemBullet' + tempId + '\', \'' + bullet + '.offImage\'); "';
			}
		}
		else
		{
			temp +='<div ';
		}

		temp += ' class="myMenuItem' + align + '" width="' + itemWidth + '"';
	
		if (menuNo != null)
		    temp += ' id="menuLabel' + menuNo +'"';
		else
		    temp += ' id="menuItem' + tempId +'"';
		
		temp += '><a href="' + itemURL +'" target="' + this.targetFrame + '" class="' + offCls + '"';
		if
		    (menuNo != null) temp += 'id="menuLink' + menuNo +'"';
		else
		    temp += 'id="menuLink' + tempId +'"';
		temp +='>';
		
		if (bullet != null)
		{
			if (menuNo != null)
			{
			    temp += '<img src="' + eval(bullet + ".URL") + '" border="0" align="' + this.bulletAlign +
			        '" id="menuBullet' + menuNo + '" name="menuBullet' + menuNo + '">';
			}
			else
			{
			    temp += '<img src="' + eval(bullet + ".URL") + '" border="0" align="' + this.bulletAlign +
			        '" id="menuItemBullet' + tempId + '" name="menuItemBullet' + tempId + '">';
			}
		}

		temp += itemText + '</a>';

		if (ns4)
		    temp += '</layer></ilayer>';
		else
		    temp += '</div>';

		temp += '</td>';	

		this.itemText[this.numItems] = new String(temp);
	}
	
	this.writeMenu = function()
	{
		var menuStr = new String();
		o_Bor = this.o_Bor;
		i_Bor = this.i_Bor;
		if (this.numItems == 0)
			menuType[currentMenuNo] = 'blank';
		else
			menuType[currentMenuNo] = 'default';
		menuStr += '<div id="menu' + currentMenuNo + '" name="menu' + currentMenuNo + '" class="myMenu" width="' + menuWidth + '"';
		if (!ns4)
			menuStr += ' style="width:' + menuWidth + ';"';
		menuStr+= '><table border="0" cellpadding="0" cellspacing="0" width="' + menuWidth + '">';
		menuStr += '<tr><td height="1" bgcolor="#9E9E9E"></td></tr>';
		if (this.orientation == 'vertical')
		{
			if (o_Bor != null) menuStr += borderRow(this.o_Bor, 3);
			for (var count = 0; count < this.numItems; count++)
			{
				menuStr += this.rowText[count+1];
				if (o_Bor != null) menuStr += borderCell(o_Bor);
				menuStr += this.itemText[count+1];
				if (o_Bor != null) menuStr += borderCell(o_Bor);
				menuStr += '</tr>';
				if (i_Bor != null && count < (this.numItems-1))
				{
					if (o_Bor != null)
						menuStr += '<tr>' + borderCell(o_Bor) + borderCell(i_Bor) + borderCell(o_Bor) + '</tr>';
					else
						menuStr += borderRow(i_Bor, 1);
				}
			}

			if (o_Bor != null)
				menuStr += borderRow(o_Bor, 3);
		}
		else
		{
			if (o_Bor != null)
			{
				if (i_Bor != null)
				    menuStr += borderRow(o_Bor, ((this.numItems * 2)+1));
				else
				    menuStr += borderRow(o_Bor, (this.numItems + 2));
			}
			menuStr += '<tr>';
			if (o_Bor != null) menuStr += borderCell(o_Bor); 
			for (var count = 0; count < this.numItems; count++) {		
				menuStr += this.rowText[count+1];			
				menuStr += this.itemText[count+1];
				if (i_Bor != null && count < (this.numItems-1)) {
					menuStr += borderCell(i_Bor);
				}
			}
			if (o_Bor != null) {
				menuStr += borderCell(o_Bor);
				if (i_Bor != null) menuStr += borderRow(o_Bor, ((this.numItems*2)+1));
				else menuStr += borderRow(o_Bor, (this.numItems+2)); 
			}
			menuStr +=  '</tr>';
		}
		menuStr += '<tr><td height="1" bgcolor="#9E9E9E"></td></tr>';
		menuStr += '</table></div>';

		document.write(menuStr);
	}
}

