/* 



	List Expander 

	written by Alen Grakalic, provided by Css Globe (cssglobe.com)

	

*/

 

this.listexpander = function(){

	

	// edit 

	

	var expandTo = 1; // level up to which you want your lists to be initially expanded. 1 is minimum

	// var expandText = "Expand All"; // text for expand all button

	//var collapseText = "Collapse All"; // text for collapse all button		

	var listClass = "listexpander" // class name that you want to assign to list(s). If you wish to change it make sure to update the css file as well  

	

	// end edit (do not edit below this line)

	

	this.start = function(){

		var ul = document.getElementsByTagName("ul");

		for (var i=0;i<ul.length;i++){

			if(ul[i].className == listClass){

				create(ul[i]);

				buttons(ul[i])

			};

		};

	};



	this.create = function(list) {	

		var items = list.getElementsByTagName("li");

		for(var i=0;i<items.length;i++){

			listItem(items[i]);

		};

	};	



	this.listItem = function(li){

		if(li.getElementsByTagName("ul").length > 0){

			var ul = li.getElementsByTagName("ul")[0];

			ul.style.display = (depth(ul) <= expandTo) ? "block" : "none";

			li.className = (depth(ul) <= expandTo) ? "expanded" : "collapsed";

			li.over = true;	

			ul.onmouseover = function(){li.over = false;} 

			ul.onmouseout = function(){li.over = true;} 

			li.onclick = function(){

				if(this.over){

					ul.style.display = (ul.style.display == "none") ? "block" : "none";

					this.className = (ul.style.display == "none") ? "collapsed" : "expanded";				

				};

			};

		};		

	};	

	

	this.buttons = function(list){

		var parent = list.parentNode;

		var p = document.createElement("p");

		p.className = listClass;

		var a = document.createElement("a");

		a.innerHTML = expandText;

		a.onclick = function(){expand(list)};

		p.appendChild(a);

		var a = document.createElement("a");

		a.innerHTML = collapseText;

		a.onclick = function(){collapse(list)};

		p.appendChild(a);

		parent.insertBefore(p,list);

	};

	

	this.expand = function(list){

		li = list.getElementsByTagName("li");

		for(var i=0;i<li.length;i++){

			if(li[i].getElementsByTagName("ul").length > 0){

				var ul = li[i].getElementsByTagName("ul")[0];

				ul.style.display = "block";

				li[i].className = "expanded";

			};

		};

	};

	

	this.collapse = function(list){

		li = list.getElementsByTagName("li");

		for(var i=0;i<li.length;i++){

			if(li[i].getElementsByTagName("ul").length > 0){

				var ul = li[i].getElementsByTagName("ul")[0];

				ul.style.display = "none";

				li[i].className = "collapsed";

			};

		};

	};

	

	this.depth = function(obj){

		var level = 1;

		while(obj.parentNode.className != listClass){

			if (obj.tagName == "UL") level++;

			obj = obj.parentNode;

		};

		return level;

	};	

	

	start();

	

};



window.onload = listexpander;

