mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			169 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			169 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
/**
 | 
						|
 * Copyright (c)2005-2009 Matt Kruse (javascripttoolbox.com)
 | 
						|
 * 
 | 
						|
 * Dual licensed under the MIT and GPL licenses. 
 | 
						|
 * This basically means you can use this code however you want for
 | 
						|
 * free, but don't claim to have written it yourself!
 | 
						|
 * Donations always accepted: http://www.JavascriptToolbox.com/donate/
 | 
						|
 * 
 | 
						|
 * Please do not link to the .js files on javascripttoolbox.com from
 | 
						|
 * your site. Copy the files locally to your server instead.
 | 
						|
 * 
 | 
						|
 */
 | 
						|
/*
 | 
						|
This code is inspired by and extended from Stuart Langridge's aqlist code:
 | 
						|
		http://www.kryogenix.org/code/browser/aqlists/
 | 
						|
		Stuart Langridge, November 2002
 | 
						|
		sil@kryogenix.org
 | 
						|
		Inspired by Aaron's labels.js (http://youngpup.net/demos/labels/) 
 | 
						|
		and Dave Lindquist's menuDropDown.js (http://www.gazingus.org/dhtml/?id=109)
 | 
						|
*/
 | 
						|
 | 
						|
// Automatically attach a listener to the window onload, to convert the trees
 | 
						|
addEvent(window,"load",convertTrees);
 | 
						|
 | 
						|
// Utility function to add an event listener
 | 
						|
function addEvent(o,e,f){
 | 
						|
	if (o.addEventListener){ o.addEventListener(e,f,false); return true; }
 | 
						|
	else if (o.attachEvent){ return o.attachEvent("on"+e,f); }
 | 
						|
	else { return false; }
 | 
						|
}
 | 
						|
 | 
						|
// utility function to set a global variable if it is not already set
 | 
						|
function setDefault(name,val) {
 | 
						|
	if (typeof(window[name])=="undefined" || window[name]==null) {
 | 
						|
		window[name]=val;
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Full expands a tree with a given ID
 | 
						|
function expandTree(treeId) {
 | 
						|
	var ul = document.getElementById(treeId);
 | 
						|
	if (ul == null) { return false; }
 | 
						|
	expandCollapseList(ul,nodeOpenClass);
 | 
						|
}
 | 
						|
 | 
						|
// Fully collapses a tree with a given ID
 | 
						|
function collapseTree(treeId) {
 | 
						|
	var ul = document.getElementById(treeId);
 | 
						|
	if (ul == null) { return false; }
 | 
						|
	expandCollapseList(ul,nodeClosedClass);
 | 
						|
}
 | 
						|
 | 
						|
// Expands enough nodes to expose an LI with a given ID
 | 
						|
function expandToItem(treeId,itemId) {
 | 
						|
	var ul = document.getElementById(treeId);
 | 
						|
	if (ul == null) { return false; }
 | 
						|
	var ret = expandCollapseList(ul,nodeOpenClass,itemId);
 | 
						|
	if (ret) {
 | 
						|
		var o = document.getElementById(itemId);
 | 
						|
		if (o.scrollIntoView) {
 | 
						|
			o.scrollIntoView(false);
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Performs 3 functions:
 | 
						|
// a) Expand all nodes
 | 
						|
// b) Collapse all nodes
 | 
						|
// c) Expand all nodes to reach a certain ID
 | 
						|
function expandCollapseList(ul,cName,itemId) {
 | 
						|
	if (!ul.childNodes || ul.childNodes.length==0) { return false; }
 | 
						|
	// Iterate LIs
 | 
						|
	for (var itemi=0;itemi<ul.childNodes.length;itemi++) {
 | 
						|
		var item = ul.childNodes[itemi];
 | 
						|
		if (itemId!=null && item.id==itemId) { return true; }
 | 
						|
		if (item.nodeName == "LI") {
 | 
						|
			// Iterate things in this LI
 | 
						|
			var subLists = false;
 | 
						|
			for (var sitemi=0;sitemi<item.childNodes.length;sitemi++) {
 | 
						|
				var sitem = item.childNodes[sitemi];
 | 
						|
				if (sitem.nodeName=="UL") {
 | 
						|
					subLists = true;
 | 
						|
					var ret = expandCollapseList(sitem,cName,itemId);
 | 
						|
					if (itemId!=null && ret) {
 | 
						|
						item.className=cName;
 | 
						|
						return true;
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
			if (subLists && itemId==null) {
 | 
						|
				item.className = cName;
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
// Search the document for UL elements with the correct CLASS name, then process them
 | 
						|
function convertTrees() {
 | 
						|
	setDefault("treeClass","mktree");
 | 
						|
	setDefault("nodeClosedClass","liClosed");
 | 
						|
	setDefault("nodeOpenClass","liOpen");
 | 
						|
	setDefault("nodeBulletClass","liBullet");
 | 
						|
	setDefault("nodeLinkClass","bullet");
 | 
						|
	setDefault("preProcessTrees",true);
 | 
						|
	if (preProcessTrees) {
 | 
						|
		if (!document.createElement) { return; } // Without createElement, we can't do anything
 | 
						|
		var uls = document.getElementsByTagName("ul");
 | 
						|
		if (uls==null) { return; }
 | 
						|
		var uls_length = uls.length;
 | 
						|
		for (var uli=0;uli<uls_length;uli++) {
 | 
						|
			var ul=uls[uli];
 | 
						|
			if (ul.nodeName=="UL" && ul.className==treeClass) {
 | 
						|
				processList(ul);
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 | 
						|
 | 
						|
function treeNodeOnclick() {
 | 
						|
	this.parentNode.className = (this.parentNode.className==nodeOpenClass) ? nodeClosedClass : nodeOpenClass;
 | 
						|
	return false;
 | 
						|
}
 | 
						|
function retFalse() {
 | 
						|
	return false;
 | 
						|
}
 | 
						|
// Process a UL tag and all its children, to convert to a tree
 | 
						|
function processList(ul) {
 | 
						|
	if (!ul.childNodes || ul.childNodes.length==0) { return; }
 | 
						|
	// Iterate LIs
 | 
						|
	var childNodesLength = ul.childNodes.length;
 | 
						|
	for (var itemi=0;itemi<childNodesLength;itemi++) {
 | 
						|
		var item = ul.childNodes[itemi];
 | 
						|
		if (item.nodeName == "LI") {
 | 
						|
			// Iterate things in this LI
 | 
						|
			var subLists = false;
 | 
						|
			var itemChildNodesLength = item.childNodes.length;
 | 
						|
			for (var sitemi=0;sitemi<itemChildNodesLength;sitemi++) {
 | 
						|
				var sitem = item.childNodes[sitemi];
 | 
						|
				if (sitem.nodeName=="UL") {
 | 
						|
					subLists = true;
 | 
						|
					processList(sitem);
 | 
						|
				}
 | 
						|
			}
 | 
						|
			var s= document.createElement("SPAN");
 | 
						|
			var t= '\u00A0'; //  
 | 
						|
			s.className = nodeLinkClass;
 | 
						|
			if (subLists) {
 | 
						|
				// This LI has UL's in it, so it's a +/- node
 | 
						|
				if (item.className==null || item.className=="") {
 | 
						|
					item.className = nodeClosedClass;
 | 
						|
				}
 | 
						|
				// If it's just text, make the text work as the link also
 | 
						|
				if (item.firstChild.nodeName=="#text") {
 | 
						|
					t = t+item.firstChild.nodeValue;
 | 
						|
					item.removeChild(item.firstChild);
 | 
						|
				}
 | 
						|
				s.onclick = treeNodeOnclick;
 | 
						|
			}
 | 
						|
			else {
 | 
						|
				// No sublists, so it's just a bullet node
 | 
						|
				item.className = nodeBulletClass;
 | 
						|
				s.onclick = retFalse;
 | 
						|
			}
 | 
						|
			s.appendChild(document.createTextNode(t));
 | 
						|
			item.insertBefore(s,item.firstChild);
 | 
						|
		}
 | 
						|
	}
 | 
						|
}
 |