var sitenav = {
	siteBox : null,
	dropBox : null,
	descBox : null,
	descText : { 
		"sitenavhub" : "hub page",
		"sitenavbgc" : "get connected",
		"sitenavbbg" : "business guide",
		"sitenavbbsc" : "social club"
	},
	
	loadSiteNavHandlers : function() {
		siteBox = document.getElementById("sitenavbox");
		dropBox = document.getElementById("sitenavdropbox");
		closeBox = document.getElementById("sitenavboxclose");
		descBox = document.getElementById("sitenavboxdesc");
		
		dropBox.onclick = sitenav.showNavBox;
		closeBox.onclick = sitenav.closeBoxClick;

		// make sure we start invisible
		siteBox.style.visibility = "hidden";
		sitenav.displaynav(null);
			
		var descElements = siteBox.getElementsByTagName('li');
		for(var i=0; i < descElements.length; i++) {
			var lie = descElements[i];
			var liid = lie.getAttribute('id');

			/* move the inner h3 tag to a mouseover display */
			var wordyElements = lie.getElementsByTagName('h3');
			if(wordyElements.length) {
				wordyElements[0].style.display = 'none';
				this.descText[liid] = wordyElements[0].innerHTML;
			}			

			if(liid && siteBox.className && siteBox.className.indexOf(liid) != -1) {
				lie.style.display = 'none';
			}
			else {
				lie.onmouseover = new Function("sitenav.displaynav('"+liid+"')");
				lie.onmouseout = function() { sitenav.displaynav(null); };
			}
		}
	},
	
	displaynav : function(tid) {
		if(tid == null) {
			descBox.innerHTML = 'Move the mouse over a link for a description';
		}
		else if(sitenav.descText[tid]) {
			descBox.innerHTML = "<h2>" + sitenav.descText[tid] + "</h2>";
		}
	},

	closeBoxClick : function() {
		siteBox.style.visibility = "hidden";
	},

	showNavBox : function() {
		siteBox.style.visibility = "visible";
	}
}

/*
cbb function by Roger Johansson, http://www.456bereastreet.com/
*/
var cbb = {
	init : function() {
	// Check that the browser supports the DOM methods used
		if (!document.getElementById || !document.createElement || !document.appendChild) return false;
		var oElement, oOuter, oI1, oI2, tempId;
	// Find all elements with a class name of cbb
		var arrElements = document.getElementsByTagName('*');
		var oRegExp = new RegExp("(^|\\s)cbb(\\s|$)");
		for (var i=0; i<arrElements.length; i++) {
	// Save the original outer element for later
			oElement = arrElements[i];
			if (oRegExp.test(oElement.className)) {
	// 	Create a new element and give it the original element's class name(s) while replacing 'cbb' with 'cb'
				oOuter = document.createElement('div');
				oOuter.className = oElement.className.replace(oRegExp, '$1cb$2');
	// Give the new div the original element's id if it has one
				if (oElement.getAttribute("id")) {
					tempId = oElement.id;
					oElement.removeAttribute('id');
					oOuter.setAttribute('id', '');
					oOuter.id = tempId;
				}
	// Deal with visibility!
				oOuter.style.visibility = oElement.style.visibility;
				oElement.style.visibility = 'inherit';
	// Change the original element's class name and replace it with the new div
				oElement.className = 'i3';
				oElement.parentNode.replaceChild(oOuter, oElement);
	// Create two new div elements and insert them into the outermost div
				oI1 = document.createElement('div');
				oI1.className = 'i1';
				oOuter.appendChild(oI1);
				oI2 = document.createElement('div');
				oI2.className = 'i2';
				oI1.appendChild(oI2);
	// Insert the original element
				oI2.appendChild(oElement);
	// Insert the top and bottom divs
				cbb.insertTop(oOuter);
				cbb.insertBottom(oOuter);
			}
		}
	},
	insertTop : function(obj) {
		var oOuter, oInner;
	// Create the two div elements needed for the top of the box
		oOuter=document.createElement("div");
		oOuter.className="bt"; // The outer div needs a class name
	    oInner=document.createElement("div");
	    oOuter.appendChild(oInner);
		obj.insertBefore(oOuter,obj.firstChild);
	},
	insertBottom : function(obj) {
		var oOuter, oInner;
	// Create the two div elements needed for the bottom of the box
		oOuter=document.createElement("div");
		oOuter.className="bb"; // The outer div needs a class name
	    oInner=document.createElement("div");
	    oOuter.appendChild(oInner);
		obj.appendChild(oOuter);
	},
	// addEvent function from http://www.quirksmode.org/blog/archives/2005/10/_and_the_winner_1.html
	addEvent : function(obj, type, fn) {
		if (obj.addEventListener)
			obj.addEventListener(type, fn, false);
		else if (obj.attachEvent) {
			obj["e"+type+fn] = fn;
			obj[type+fn] = function() { obj["e"+type+fn]( window.event ); }
			obj.attachEvent("on"+type, obj[type+fn]);
		}
	}
};

cbb.addEvent(window, 'load', function() { cbb.init(); sitenav.loadSiteNavHandlers(); });
