		//Detect Browser
    	var IE4 = (document.all && !document.getElementById) ? true : false;
        var NS4 = (document.layers) ? true : false;
        var IE5 = (document.all && document.getElementById) ? true : false;
        var N6 = (document.getElementById && !document.all) ? true : false;
        var isMac = navigator.platform.indexOf("Mac") != -1;
        var isIE = document.all ? true : false;

var globheight;
var globlevel;
var globdelay;
var globtype;
var globhorizontalinset;
var globverticalinset;
var globhighlightpath;
var menucount=0;
var N6count=0;
var populatemenuitems="false";
var topMenuWidths = [];

//menu_tpl.js from original starts here*****************************************************
var MENU_POS = new Array();
	MENU_POS['height'] = [];
	MENU_POS['width'] = [];
	MENU_POS['block_top'] = [0, 0,];
	MENU_POS['hide_delay'] = [];

var MENU_STYLES = new Array();
	MENU_STYLES['onmouseout'] = [
		[]
	];
	MENU_STYLES['onmouseover'] = [
		[]
	];
	
	MENU_STYLES['onmousedown'] = [
		[]
	];
	
	MENU_STYLES['menuitemfontclass'] = [
		[]
	];
	
	
//menu_tpl.js from original ends here*******************************************************


function initmenu(levels, height, delay, type, horizontalinset, verticalinset, highlightpath)
{
	if (populatemenuitems=="true")
	{
		for (i=0;i<=levels-1;i++)
		{
			MENU_ITEMS[i] = ITEMS[(i+1)];
		}
	}

//setting the height
globheight=height;
globlevel=levels;
globdelay=delay;
globhorizontalinset = horizontalinset;
globverticalinset = verticalinset;
globhighlightpath = highlightpath;

if (populatemenuitems=="false")
{
	if (type=="horizontal")
	{
		//Defaults for horizontal
		MENU_POS['block_left'] = [0, 0];
		MENU_POS['top'] = [0];
		MENU_POS['left'] = [0];
		globtype="horizontal";
	}
	else
	{	
		//Defaults for vertical
		MENU_POS['block_left'] = [0, 0];
		MENU_POS['top']        = [0, 0];
		MENU_POS['left']       = [0, 0];
		globtype="vertical";
	}
}
}




//menu.js from original starts here********************************************************
var menus = [];

// --- menu class ---
function menu (item_struct, pos, styles) {
	// browser check
	this.item_struct = item_struct;
	this.pos = pos;
	this.styles = styles;
	this.id = menus.length;
	this.items = [];
	this.children = [];
	this.add_item = menu_add_item;
	this.hide = menu_hide;
	this.onclick = menu_onclick;
	this.onmouseout = menu_onmouseout;
	this.onmouseover = menu_onmouseover;
	this.onmousedown = menu_onmousedown;
	var i;
	for (i = 0; i < this.item_struct.length; i++)
		new menu_item(i, this, this);
	for (i = 0; i < this.children.length; i++)
		this.children[i].visibility(true);
	menus[this.id] = this;
}
function menu_add_item (item) {
	var id = this.items.length;
	this.items[id] = item;
	return (id);
}
function menu_hide () {
	for (var i = 0; i < this.items.length; i++) {
		this.items[i].visibility(false);
		this.items[i].switch_style('onmouseout');
	}
}
function menu_onclick (id) {
	var item = this.items[id];
	return (item.fields[1] ? true : false);
}
function menu_onmouseout (id) {
	this.hide_timer = setTimeout('menus['+ this.id +'].hide();',
		this.pos['hide_delay'][this.active_item.depth]);
	if (this.active_item.id == id)
		this.active_item = null;
}
function menu_onmouseover (id) {
	this.active_item = this.items[id];
	clearTimeout(this.hide_timer);
	var curr_item, visib, selected;
	for (var i = 0; i < this.items.length; i++) {
		curr_item = this.items[i];
		visib = (curr_item.arrpath.slice(0, curr_item.depth).join('_') ==
			this.active_item.arrpath.slice(0, curr_item.depth).join('_'));
		if (visib) {
			//Check if all elements leading to the selected element should have "selected" style.
			if(globhighlightpath) {
				selected = (curr_item.arrpath.slice(0, curr_item.depth + 1).join('_') ==
						this.active_item.arrpath.slice(0, curr_item.depth + 1).join('_'));
			} else {
				selected = curr_item == this.active_item;
			}
			curr_item.switch_style( selected ? 'onmouseover' : 'onmouseout' );
		}
		curr_item.visibility(visib);
	}
}
function menu_onmousedown (id) {
	this.items[id].switch_style('onmousedown');
}
// --- menu item Class ---
function menu_item (path, parent, container) {
	this.path = new String (path);
	this.parent = parent;
	this.container = container;
	this.arrpath = this.path.split('_');
	this.depth = this.arrpath.length - 1;
	// get pointer to item's data in the structure
	var struct_path = '', i;
	for (i = 0; i <= this.depth; i++)
		struct_path += '[' + (Number(this.arrpath[i]) + (i ? 2 : 0)) + ']';
	eval('this.fields = this.container.item_struct' + struct_path);
	if (!this.fields) return;
	
	// assign methods	
	this.get_x = mitem_get_x;
	this.get_y = mitem_get_y;
	// these methods may be different for different browsers (i.e. non DOM compatible)
	this.init = mitem_init;
	this.visibility = mitem_visibility;
	this.switch_style = mitem_switch_style;
	
	// register in the collections
	this.id = this.container.add_item(this);
	parent.children[parent.children.length] = this;
	
	// init recursively
	this.init();
	this.children = [];
	var child_count = this.fields.length - 2;
	for (i = 0; i < child_count; i++)
		new menu_item (this.path + '_' + i, this, this.container);
	this.switch_style('onmouseout');
}
function mitem_init() {
	var width;
	if(this.depth == 0) {
		width = topMenuWidths[this.arrpath[this.depth]];
	} else {
		width = this.container.pos["width"][this.depth];
	}
	
	if(this.fields[1] == null || this.fields[1] == "null") {
		document.write ("<span id=\"mi_" + this.container.id + "_"
			+ this.id +"\" class=\"" + this.container.styles['onmouseout'][this.depth] + "\""
			+ " style=\"position: absolute; top: "
			+ this.get_y() + "px; left: "	+ this.get_x() + "px; width: "
			+ width + "px; height: "
			+ this.container.pos["height"][this.depth] + "px; visibility: hidden;"
			+ "z-index: " + this.depth + 10 + ";\" "
			+ "onmouseout=\"menus[" + this.container.id + "].onmouseout("
			+ this.id + ");\" onmouseover=\"menus[" + this.container.id + "].onmouseover("
			+ this.id + ");\" onmousedown=\"menus[" + this.container.id + "].onmousedown("
			+ this.id + ");\"><div id=\"md_" + this.container.id + "_"
			+ this.id +"\" class=\"" + this.container.styles['menuitemfontclass'][this.depth] + "\">"
			+ this.fields[0] + "</div></span>\n");
	} else {
		document.write ("<a id=\"mi_" + this.container.id + "_"
			+ this.id +"\" class=\"" + this.container.styles['onmouseout'][this.depth] + "\""
			+ " href=\"" + this.fields[1] + "\" style=\"position: absolute; top: "
			+ this.get_y() + "px; left: "	+ this.get_x() + "px; width: "
			+ width + "px; height: "
			+ this.container.pos["height"][this.depth] + "px; visibility: hidden;"
			+ "z-index: " + this.depth + 10 + ";\" "
			+ "onclick=\"return menus[" + this.container.id + "].onclick("
			+ this.id + ");\" onmouseout=\"menus[" + this.container.id + "].onmouseout("
			+ this.id + ");\" onmouseover=\"menus[" + this.container.id + "].onmouseover("
			+ this.id + ");\" onmousedown=\"menus[" + this.container.id + "].onmousedown("
			+ this.id + ");\"><div id=\"md_" + this.container.id + "_"
			+ this.id +"\" class=\"" + this.container.styles['menuitemfontclass'][this.depth] + "\">"
			+ this.fields[0] + "</div></a>\n");
		
	}
	
	
		
		if (globtype=="horizontal")
		{
			MENU_POS['block_top'][1]=document.getElementById("md_" + this.container.id + "_" + this.id).offsetHeight;
		   for (d=1;d<=MENU_POS['top'].length-1;d++)
		    {
		    MENU_POS['top'][d]= document.getElementById("md_" + this.container.id + "_" + this.id).offsetHeight;
			}
		}
		if (globtype=="vertical")
		{
		   for (h=0;h<=MENU_POS['top'].length-1;h++)
		   {
		    MENU_POS['top'][h]= document.getElementById("md_" + this.container.id + "_" + this.id).offsetHeight;
			}
		}
	this.element = document.getElementById('mi_' + this.container.id + '_' + this.id);
	this.elementDiv = document.getElementById('md_' + this.container.id + '_' + this.id);
}
function mitem_visibility(make_visible) {
	if (make_visible != null) {
		if (this.visible == make_visible) return;
		this.visible = make_visible;
		if (make_visible)
			this.element.style.visibility = 'visible';
		else if (this.depth)
			this.element.style.visibility = 'hidden';
	}
	return (this.visible);
}
function mitem_get_x() {

	//Vertical
	if(globtype=="vertical") {
		var maxDepth = this.depth;
		var value = 0;
		if(this.depth > 0) {
			value += topMenuWidths[this.arrpath[0]];
			maxDepth -= 1;
		}
		for (var i = 0; i <= maxDepth; i++) {
			value += this.container.pos['block_left'][i]
			+ this.arrpath[i] * this.container.pos['left'][i];
			if(isIE) {
				value -= 1;
			}
		}
		
		if(this.depth > 0) {
			value -= globhorizontalinset * (this.depth);
		}
	
	//Horizontal
	} else {
		var value = 0;
		//Add topmenuitems.
		var arrpathMax = this.arrpath[0];
		var maxDepth = this.depth;
		if(this.depth > 0) {
			maxDepth -= 1;
		}
		for(n = 0; n < arrpathMax; n++) {
			value += topMenuWidths[n];
		}
		//Add the rest.
		for (var i = 0; i <= maxDepth; i++) {
			value += this.container.pos['block_left'][i]
			+ this.arrpath[i] * this.container.pos['left'][i];
		}
		
		if(this.depth > 1) {
			value -= globhorizontalinset * (this.depth - 1);
		}
		
		if(isMac && IE5) {
			value += 7;
		}
	}
	
	//X-coordinates for elements starts at "1" in IE and "2" in mozilla and must therefore be subtracted.
	if(isIE) {
		value -= 1;
	} else {
		value -= 2;
	}
	
	
	return (value);
}

function mitem_get_y() {
	var value = 0;
	for (var i = 0; i <= this.depth; i++) {
		if(i == 0) {
			//Add value to position the menu.
			value += this.container.pos['block_top'][i];
		}
		if(globtype == "horizontal") {
			if(this.depth > 0 && i == 0) {
				value += globheight * 2;
			} else {
				if(this.depth == 1) {
					value += (this.arrpath[i] - 1) * globheight;
				} else {
					if(this.depth > 1) {
						var arrpathValue = this.arrpath[i] - 1;
						if(arrpathValue < 0) {
							arrpathValue = 0;
						}
						value += (this.arrpath[i]) * globheight;
					} else {
						value += this.arrpath[i] * this.container.pos['top'][i];
					}
				}
			}
		} else {
			value += this.arrpath[i] * (globheight + 1);
		}
		
		if(isMac && IE5) {
			if(this.container.pos['top'][i] != 0) {
				value -= this.arrpath[i] * 3;
			}
		}
	}
	
	if(globtype == "horizontal" && isMac && IE5) {
		if(this.depth > 0) {
			value -= 3;
		}
		
		value += 14;
	}
	
	if(globtype=="horizontal") {
		if(this.depth > 1) {
			value += globverticalinset * (this.depth - 1);
			value -= globheight;
		}
	} else {
		 if(this.depth > 0) {
			value += globverticalinset * (this.depth);
		}
	}
	
	return (value);
}

function mitem_switch_style(state) {
	if (this.state == state) return;
	this.state = state;
	var classNames = this.container.styles[state];
	this.element.className = classNames[this.depth];
	this.elementDiv.className = this.container.styles['menuitemfontclass'][this.depth];
}
// menu.js from original ends here************************************************



//menu_items.js from original starts here******************************************
var arraywith10values=new Array();
var arraywith10valuescount=0;
var splitvalarray;
var doflag;
var newarraystr=new Array();
mainarray=new Array();
mainarraywithcommas=new Array();
fullmainarray=new Array();
var MENU_ITEMS=new Array();
var ITEMS=new Array();
var splitarray=new Array();
var count=0;

//This is the new function added. This function replaces all the occurances of a particular character/substring in a string with the given character/string***********************
function replace(string,text,by)
{
    var strLength = string.length, txtLength = text.length;
    if ((strLength == 0) || (txtLength == 0)) return string;

    var i = string.indexOf(text);
    if ((!i) && (text != string.substring(0,txtLength))) return string;
    if (i == -1) return string;

    var newstr = string.substring(0,i) + by;

    if (i+txtLength < strLength)
        newstr += replace(string.substring(i+txtLength,strLength),text,by);

    return newstr;
}
//******************************************************************************************

function addmenuitem(val,desc,url,onmouseovrclass, onmouseoutclass, onmousedownclass, menuitemfontclass, width)
{
/*
val=Node level
desc=description which shows up
url=url linked to description
onmouseovertxtcol=Onmouseover Text color
*/
doflag="yes";
splitvalarray=val.split(",");

	if (doflag=="yes")
	{
var val1=replace(val,",","¤");
var val2=replace(val,",","");
			//calculate no of commas in val,this will give us the level************
					 var noofcommascount=0;
					 for (h=0;h<=val.length-1;h++)
					 {
						if (val.charAt(h)==",")
						{
							noofcommascount=noofcommascount+1;
						}
					 }
			//*********************************************************
MENU_STYLES['onmouseover'][noofcommascount] = onmouseovrclass;
MENU_STYLES['onmouseout'][noofcommascount] = onmouseoutclass;						  
MENU_STYLES['onmousedown'][noofcommascount] = onmousedownclass;			
MENU_STYLES['menuitemfontclass'][noofcommascount] = menuitemfontclass;				  
MENU_POS['hide_delay'][noofcommascount] = globdelay;
MENU_POS['height'][noofcommascount]=globheight;
MENU_POS['width'][noofcommascount]=width;
//defining classes for setting font-family,size etc*******

//**********************************************************



//if (noofcommascount>1)
//{
	MENU_POS['block_left'][noofcommascount] = width+1;
	MENU_POS['block_top'][noofcommascount] = 0;
//}
if (noofcommascount>0) {
	MENU_POS['left'][noofcommascount] = 0;
	MENU_POS['top'][noofcommascount] = 0;//need not be 23,you can assign any number.
} else {
	var position = splitvalarray[0];
	topMenuWidths[position - 1] = width;
}

				  
if (val.lastIndexOf(",")=="-1")
{
	var substrextract=val;
}
else
{
	var substrextract=val.substring(0,val.lastIndexOf(","));
}
var replacedstr=replace(substrextract,",","¤");
var val1=replace(val,",","¤");
ITEMS[val1]=new Array(desc,url);
mainarray[count]=replacedstr; 
fullmainarray[count]=val1;
mainarraywithcommas[fullmainarray[count]]=val;
count=count+1;
	}
}

/*
function doCompare(a,b)
{
	return a>b
}
*/
 
function createmenu()
{

	//mainarray.sort(doCompare);
	//fullmainarray.sort(doCompare);
	
	var count1=2;
	for (i=mainarray.length-1;i>=0;i--)
	{
		mainarray[i]=mainarray[i]+"";
		var len=mainarray[i].length;
		for (j=0;j<=fullmainarray.length-1;j++)
		{
			//calculate no of zeros in fullmainarray[j]************
			var noofzeroscount=0;
			for (u=0;u<=fullmainarray[j].length-1;u++)
			{
				if (fullmainarray[j].charAt(u)=="¤")
				{
					noofzeroscount=noofzeroscount+1;
				}
			}
			//*********************************************************
			//calculate no of zeros in mainarray[i]************
			var noofzeroscounti=0;
			for (v=0;v<=mainarray[i].length-1;v++)
			{
				if (mainarray[i].charAt(v)=="¤")
				{
					noofzeroscounti=noofzeroscounti+1;
				}
			}
			//*********************************************************
				
				
			splitarray=mainarraywithcommas[fullmainarray[j]].split(",");
			if (mainarray[i]!=fullmainarray[j])
			{
				fullmainarray[j]=fullmainarray[j]+"";
				if ((fullmainarray[j].substring(0,len)==mainarray[i]) && (mainarray[i].length==(fullmainarray[j].length-noofzeroscount)-(splitarray[splitarray.length-1].length-noofzeroscounti)))
				{
					ITEMS[mainarray[i]][count1]=ITEMS[fullmainarray[j]];
					count1=count1+1;
				}
			}
		}
				count1=2;
	}
	populatemenuitems="true";
	//initmenu(globlevel,globheight,globwidth);
	initmenu(globlevel,globheight, globdelay, globtype, globhorizontalinset, globverticalinset, globhighlightpath);
} 


//menu_items.js from original ends here*****************************************************

function getTotalOffsetLeft(elementID) {
	var x = 0;
	var element = document.getElementById(elementID);
	while(element != null) {
		x += element.offsetLeft;
		element = element.offsetParent;
	}

	return x;
}

function getTotalOffsetTop(elementID) {
	var y = 0;
	var element = document.getElementById(elementID);
	while(element != null) {
		y += element.offsetTop;
		element = element.offsetParent;
	}

	return y;
}

function debug(s) {
	document.getElementById('debug').value = document.getElementById('debug').value + '\n' + s;
}

var debugString;
function debugDelayed(s) {
	debugString = debugString + '\n' + s;
}
