trvw={
	// CSS classes
	trvwClass:'trvw',
	hideClass:'trvw_hide',
	showClass:'trvw_show',
	parentClass:'parent',
	currentClass:'current',
    // boolean to keep the section with the STRONG open or not.
    keepCurrentOpen:true,
	// boolean to make the parent link collapse the section or not 
	linkParent:false,
	init:function(){
		if(!document.getElementById || !document.createTextNode){return;}
		var uls=document.getElementsByTagName('ul');
		for(var i=0;i<uls.length;i++){
		var inneruls,parentLI;
			if(!trvw.cssjs('check',uls[i],trvw.trvwClass)){continue;}
			var inneruls=uls[i].getElementsByTagName('ul');
			for(var j=0;j<inneruls.length;j++){
				parentLI=inneruls[j].parentNode;
				if(parentLI.getElementsByTagName('strong')[0]){
					trvw.cssjs('add',parentLI,trvw.currentClass);
					if(trvw.keepCurrentOpen === true){continue;}
				}
				trvw.cssjs('add',parentLI,trvw.parentClass);
				trvw.cssjs('add',inneruls[j],trvw.hideClass);
				trvw.addEvent(parentLI.getElementsByTagName('a')[0],'click',trvw.showhide,false);
				parentLI.getElementsByTagName('a')[0].onclick=function(){return false;} // Safari hack
				if(trvw.linkParent){
					trvw.addEvent(parentLI.getElementsByTagName('a')[1],'click',trvw.showhide,false);
					parentLI.getElementsByTagName('a')[1].onclick=function(){return false;} // Safari hack
				}
			}
		}
	},
	showhide:function(e){
		var elm=trvw.getTarget(e);
		var ul=elm.parentNode.getElementsByTagName('ul')[0];
		if(trvw.cssjs('check',ul,trvw.hideClass)){
			trvw.cssjs('remove',elm.parentNode.getElementsByTagName('ul')[0],trvw.hideClass);
			trvw.cssjs('add',elm.parentNode.getElementsByTagName('ul')[0],trvw.showClass);
		} else {
			trvw.cssjs('remove',elm.parentNode.getElementsByTagName('ul')[0],trvw.showClass);
			trvw.cssjs('add',elm.parentNode.getElementsByTagName('ul')[0],trvw.hideClass);
		}
		trvw.cancelClick(e);
	},
	getTarget:function(e){
		var target = window.event ? window.event.srcElement : e ? e.target : null;
		if (!target){return false;}
		if (target.nodeName.toLowerCase() != 'a'){target = target.parentNode;}
		return target;
	},
	cancelClick:function(e){
		if (window.event){
			window.event.cancelBubble = true;
			window.event.returnValue = false;
			return;
		}
		if (e){
			e.stopPropagation();
			e.preventDefault();
		}
	},
	addEvent: function(elm, evType, fn, useCapture){
		if (elm.addEventListener) 
		{
			elm.addEventListener(evType, fn, useCapture);
			return true;
		} else if (elm.attachEvent) {
			var r = elm.attachEvent('on' + evType, fn);
			return r;
		} else {
			elm['on' + evType] = fn;
		}
	},
	cssjs:function(a,o,c1,c2){
		switch (a){
			case 'swap':
				o.className=!trvw.cssjs('check',o,c1)?o.className.replace(c2,c1):o.className.replace(c1,c2);
			break;
			case 'add':
				if(!trvw.cssjs('check',o,c1)){o.className+=o.className?' '+c1:c1;}
			break;
			case 'remove':
				var rep=o.className.match(' '+c1)?' '+c1:c1;
				o.className=o.className.replace(rep,'');
			break;
			case 'check':
				return new RegExp("(^|\s)" + c1 + "(\s|$)").test(o.className)
			break;
		}
	}
}
trvw.addEvent(window, 'load', trvw.init, false);

