/* CONFIGURATION AREA */
/*
	browsers:
		IE - Microsoft Internet Explorer
		FF - FireFox
		Safari - Safari browser
		Opera - Opera browser
		all - includes IE, FF, Opera and Safari
		
	parentId:
		any existing Id attribute 
	tagName:
		any valid tag name
	tagPosition:
		all - all inner elements 
		children - first level children only
	className:
		any valid class name
*/

var browsers = 'all';
var config = {
	hovers: new Array(
		{
			parentId:'menu',
			tagName:'li',
			tagPosition:'children',
			className:'hover'
		}
	)
};

/* CODE AREA */

/* hovers */

var initHovers = function()
{
	for (var index in config.hovers){
		var conf = config.hovers[index];
		var topLevelElement = document.getElementById(conf.parentId);
		if (topLevelElement){
			var subElements = topLevelElement.getElementsByTagName(conf.tagName);
			for (var i = 0; i < subElements.length; i++){
				if (conf.tagPosition == 'all' || (conf.tagPosition == 'children' && subElements[i].parentNode.id == conf.parentId))
				{
					subElements[i].configIndex = index;
					subElements[i].onmouseover = function(){
						this.className += ' ' + config.hovers[this.configIndex].className;
						
						var menu = document.getElementById('menu');
						if (menu){
							var elements = menu.getElementsByTagName('li');
							for (var j=0; j<elements.length;j++){
								if (elements[j].className.indexOf('active')!=-1 && elements[j] != this){
									var subnav = elements[j].getElementsByTagName('ul');
									if (subnav[0]){
										subnav[0].style.visibility="hidden";
									}
								}
							}
						}
					};
					subElements[i].onmouseout = function(){
						this.className = this.className.replace(config.hovers[this.configIndex].className,'');
						var menu = document.getElementById('menu');
						if (menu){
							var elements = menu.getElementsByTagName('li');
							for (var j=0; j<elements.length;j++){
								if (elements[j].className.indexOf('active')!=-1 && elements[j] != this){
									var subnav = elements[j].getElementsByTagName('ul');
									if (subnav[0]){
										subnav[0].style.visibility="visible";
										subnav[0].style.width="966px";
									}
								}
							}
						}
					};
				}
			}
		}
	}
}

/* common */

var currentState = {};

var opera = window.opera;
var safari = navigator.appVersion.indexOf("Safari") != -1;
var ie = document.all && !window.opera;
var ff = navigator.userAgent.indexOf("Firefox") != -1;

var addEvent1 = function(browsers,event,initMethod)
{
	if (opera && (browsers.match(/Opera/) || browsers.match(/all/))) {
		window.addEventListener(event, initMethod, false);
	} else if (safari && (browsers.match(/Safari/) || browsers.match(/all/))) {
		window.addEventListener(event, initMethod, false);
	} else if (ie && (browsers.match(/IE/) || browsers.match(/all/))) {
		window.attachEvent("on" + event, initMethod);
	} else if (ff && (browsers.match(/FF/) || browsers.match(/all/))) {
		window.addEventListener(event, initMethod, false);
	} else if (!ie && !ff && !safari && !opera) {
		if (window.addEventListener){
			window.addEventListener(event, initMethod, false);
		}
		else if (window.attachEvent){
			window.attachEvent("on" + event, initMethod);
		}
	} 
}

var InitMenuOpera = function()
{
	menu = document.getElementById('menu');
	if (menu){
		var menuItems = menu.getElementsByTagName('li');
		for (var i=0;i<menuItems.length;i++){
			if (menuItems[i].parentNode.id == 'menu'){
				menuItems[i].style.width = eval(menuItems[i].clientWidth - 2) + 'px';
			}
		}
	}
}
window.addEvent('domready',initHovers);
window.addEvent('domready',InitMenuOpera);
