// Don't change these parameters
var delay        = 200; /////
var menuElement  = new Array ();
var usedWidth    = 0;
var numOfMenus   = 0;
/// ----------------------------

// check browser version
isNC    = (document.layers) ? 1 : 0;
isOPERA = (navigator.userAgent.indexOf('Opera') >= 0)? true : false;
isIE    = (document.all && !isOPERA)? true : false;
isDOM   = (document.getElementById && !isIE && !isOPERA)? true : false;

var topID  = -1;

// constructor of menu elements
function menuConstructor (id, content)
{
	this.ID            = id;
	this.parentID      = content [0]*1;
	this.parentItemID  = content [1]*1;
	this.width         = content [2]*1;
	this.timerID       = -1;
	this.isOn          = false;
	this.item          = new Array ();
	this.currItemID    = -1;
	
	this.x = content [3]*1;
	
	if (this.x < 0 && this.parentID == -1)
	{
		this.x = initX + usedWidth;
		usedWidth = usedWidth + this.width;
	}
	else if (this.x < 0 && this.parentID > -1)
	{
		this.x =  menuElement [this.parentID].x
			      + menuElement [this.parentID].width
			      - xOverlap;
	}
	
	this.y = content [4]*1;
	if (this.y < 0 && this.parentID == -1)
		this.y = initY;
	else if (this.y < 0 && this.parentID > -1)
		this.y =  menuElement [this.parentID].y
	 		      + itemHeight*this.parentItemID
			      + yOverlap;
	
	items = content [5];

	layerBody = '<table class="subMenuLayer" width=' + this.width + '>';
	
	imgLocator = '';
	
	count = 0;
	for (j = 0; j <= items.length - 3; j = j + 3)
	{
		if (items [j + 2] != '') 
			imgLocator = '<img src=' + items [j + 2] + ' border=0 height=' + (itemHeight) + ' align=right vspace=0 hspace=0>';
			controlBlock = ' onMouseOver = "enterItem (' + this.ID + ', ' + ((j + 3)/3 - 1) + ');" onMouseOut = "exitItem (' + this.ID + ', ' + ((j + 3)/3 - 1) + ');" ';
			layerBody += '<td id=Td' + this.ID + count + ' height=' + itemHeight + ' width=' + this.width + '>' + imgLocator + '<a class=subMenu href='+ items [j + 1] +' ' + controlBlock + '>&nbsp;' + items [j] + '</a></td>';
		if (j < items.length - 3)
			layerBody = layerBody +  '<tr>\n';
		else
			layerBody = layerBody + '\n';
		count++;
		imgLocator = '';
	}

	if (!isNC)
		layerHeader = '<div class="menu_menu" id=Menu' + this.ID +
				' onMouseOver="enterMenu (' + this.ID + ');" onMouseOut = "exitMenu (' + this.ID + ');"' +
		    	       ' style="width: ' + this.width + '; left: ' + this.x + '; top: ' + this.y + ';">';
	else
		layerHeader = '<layer id=Menu' + this.ID +
					   ' onMouseOver="enterMenu (' + this.ID + ');" onMouseOut = "exitMenu (' + this.ID + ');"' +
					   ' visibility=hide left=' + this.x + ' top =' + this.y + '>';

	layerHeader += '<table width=' + this.width + ' cellpadding=0 cellspacing=0 border=0>' + '<td>';
	layerFooter = '</table></td></table>';

	if (!isNC)
		layerFooter = layerFooter + '</div>';
	else
		layerFooter = layerFooter + '</layer>';

	document.writeln (layerHeader + layerBody + layerFooter);


	return this;
}
function enterTopItem (ID)
{
	updateTopPos (ID);
	
	if (topID != ID && topID != -1)
		hideTree (topID);
	releaseTree (ID);
	topID = ID;
	show (ID);
}
function exitTopItem (ID)
{
	menuElement [ID].timerID = setTimeout ('hide (' + ID + ')', delay);
}
function updateTopPos (id)
{
	if (isIE) { //pifia
		realX = getRealLeft (document.all['TD' + id]);
	} else {
		realX = getRealLeft (document.getElementById('TD' + id));
	}
	
	
	for (var i = 0; i < numOfMenus; i++)
	{
		if (menuElement [i].parentID == -1)
		{
			if (isIE) { //pifia
				document.all['Menu' + i].style.left=realX+2;
			} else {
				document.getElementById('Menu' + i).style.left=realX;
			}
		}
	}
}
function enterItem (menuID, itemID)
{
	if (isIE) { //pifia
		realX = getRealLeft(document.all['Menu' + menuID]);
	} else {
		realX = getRealLeft(document.getElementById('Menu' + menuID));
	}
	
	var currItemID = menuElement[menuID].currItemID;

	if (currItemID != i & currItemID > -1)	
		hide (currItemID);
	

	for (var i = 0; i < numOfMenus; i++)
	{
		if (menuElement [i].parentID == menuID &&
		    menuElement [i].parentItemID == itemID)
		{
			
			if (isIE) { //pifia
				//document.all['Menu' + i].style.left = realX + menuElement[itemID].width - xOverlap;
				document.all['Menu' + i].style.left = realX  + xOverlap;
			} else {
				//document.getElementById('Menu' + i).style.left = realX + menuElement[itemID].width - xOverlap;
				document.getElementById('Menu' + i).style.left = realX  + xOverlap;
			}
			
			clearTimeout (menuElement [i].timerID);
			menuElement [i].timerID = -1;
			show (i);
			return 0;
		}
	}

	return -1;
}

function exitItem (menuID, itemID)
{
	for (var i = 0; i < numOfMenus; i++)
	{
		if (menuElement [i].parentID == menuID &&
		    menuElement [i].parentItemID == itemID)
		{
			menuElement [i].timerID = setTimeout ('hide (' + i + ')', delay);
			return 0;
		}
	}
}
function enterMenu (ID)
{
	var parentID = menuElement [ID].parentID;
	if (parentID == -1)
	{
		clearTimeout (menuElement [ID].timerID);
		menuElement [ID].timerID = -1;
	}
	else
		releaseTree (ID);
}
function exitMenu (ID)
{
	timeoutTree (ID);
}
function hideTree (ID)
{
	hide (ID);
	for (var j = 0; j < numOfMenus; j++)
	{
		if (menuElement [j].parentID == ID &&
			menuElement [j].isOn)
		{
			hideTree (j);
			return 0;
		}
	}
}
function releaseTree (ID)
{
	clearTimeout (menuElement [ID].timerID);
	menuElement [ID].timerID = -1;

	var parentID = menuElement [ID].parentID;
	if (parentID > -1)
		releaseTree (parentID);
}
function timeoutTree (ID)
{
	menuElement [ID].timerID = setTimeout ('hide (' + ID + ')', delay);
	var parentID = menuElement [ID].parentID;
	if (parentID > -1)
		timeoutTree (parentID);
}

function show (ID)
{
	
	if (isDOM) {
		document.getElementById('Menu' + ID).style.visibility = "visible";
		if (menuContent[ID][0]==-1){
			document.getElementById('TD' + ID).style.background = "#004080";
			document.getElementById('TD' + ID).style.borderLeft = "1px solid #FFFFFF";
			document.getElementById('TD' + ID).style.borderRight = "1px solid #FFFFFF";
		}
    	 } else if (isIE)  {
		document.all['Menu' + ID].style.visibility = "visible";
		if (menuContent[ID][0]==-1){
			document.all['TD' + ID].style.background = "#004080";
			document.all['TD' + ID].style.borderLeft = "1px solid #FFFFFF";
			document.all['TD' + ID].style.borderRight = "1px solid #FFFFFF";
		}
      	} else if (isNC) {
		document.layers[ID].visibility = "show";		
	}
	menuElement [ID].isOn = true;

	if (menuElement [ID].parentID > -1)
		menuElement [menuElement [ID].parentID].currItemID = ID;
}

function hide (ID)
{
	if (isDOM) {
		document.getElementById('Menu' + ID).style.visibility = "hidden";
		if (menuContent[ID][0]==-1){
			document.getElementById('TD' + ID).style.background = "#000050";
			document.getElementById('TD' + ID).style.borderLeft = "1px solid #000050";
			document.getElementById('TD' + ID).style.borderRight = "1px solid #000050";
		}
    	} else if (isIE) {
		document.all['Menu' + ID].style.visibility = "hidden";
		if (menuContent[ID][0]==-1){
			document.all['TD' + ID].style.background = "#000050";
			document.all['TD' + ID].style.borderLeft = "1px solid #000050";
			document.all['TD' + ID].style.borderRight = "1px solid #000050";
		}
      	} else if (isNC) {
		document.layers[ID].visibility = "hide";
	}
	menuElement [ID].isOn = false;

	if (menuElement [ID].parentID > -1)
		menuElement [menuElement [ID].parentID].currItemID = -1;
}

function createMenuTree ()
{
	for (var i = 0; i < menuContent.length; i++)
	{
		menuElement [i] = new menuConstructor (i, menuContent [i]);
		numOfMenus++;
	}
}

function getRealLeft (id) {
    x = id.offsetLeft;
    parentElement = id.offsetParent;
    while (parentElement != null) {
        x += parentElement.offsetLeft;
        parentElement = parentElement.offsetParent;
    }
    return x;
}

function ver_menu(cual) {
	if (cual=="menu_sti_en_linea") {cualno="menu_quienes_somos";} else {cualno="menu_sti_en_linea";}
	if (isDOM) {
		document.getElementById(cual).style.visibility = "visible";
		document.getElementById(cual).style.display = "block";
		document.getElementById(cualno).style.visibility = "hidden";
		document.getElementById(cualno).style.display = "none";
		document.getElementById(cualno+"x").style.background = "#000050";
		document.getElementById(cual+"x").style.background = "#004080";
    	 } else {
		document.all[cual].style.visibility = "visible";
		document.all[cual].style.display = "block";	
		document.all[cualno].style.visibility = "hidden";
		document.all[cualno].style.display = "none";
		document.all[cualno+"x"].style.background = "#000050";
		document.all[cual+"x"].style.background = "#004080";
	}
}

createMenuTree ();
