mirror of
https://github.com/librenms/librenms.git
synced 2024-10-07 16:52:45 +00:00
Added missing mktree files
This commit is contained in:
@@ -14,6 +14,9 @@ LibreNMS ships with the following software components:
|
|||||||
http://momentjs.com
|
http://momentjs.com
|
||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
|
- MKTree
|
||||||
|
http://www.javascripttoolbox.com/lib/mktree/
|
||||||
|
MIT and GPL License
|
||||||
|
|
||||||
Other components (needs details filled in):
|
Other components (needs details filled in):
|
||||||
- JpGraph (html/includes/jpgraph): QPL 1.0 license
|
- JpGraph (html/includes/jpgraph): QPL 1.0 license
|
||||||
|
23
html/css/mktree.css
Normal file
23
html/css/mktree.css
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
/* Put this inside a @media qualifier so Netscape 4 ignores it */
|
||||||
|
@media screen, print {
|
||||||
|
/* Turn off list bullets */
|
||||||
|
ul.mktree li { list-style: none; }
|
||||||
|
/* Control how "spaced out" the tree is */
|
||||||
|
ul.mktree, ul.mktree ul , ul.mktree li { margin-left:10px; padding:0px; }
|
||||||
|
/* Provide space for our own "bullet" inside the LI */
|
||||||
|
ul.mktree li .bullet { padding-left: 15px; }
|
||||||
|
/* Show "bullets" in the links, depending on the class of the LI that the link's in */
|
||||||
|
ul.mktree li.liOpen .bullet { cursor: pointer; background: url(/images/minus.gif) center left no-repeat; }
|
||||||
|
ul.mktree li.liClosed .bullet { cursor: pointer; background: url(/images/plus.gif) center left no-repeat; }
|
||||||
|
ul.mktree li.liBullet .bullet { cursor: default; background: url(/images/bullet.gif) center left no-repeat; }
|
||||||
|
/* Sublists are visible or not based on class of parent LI */
|
||||||
|
ul.mktree li.liOpen ul { display: block; }
|
||||||
|
ul.mktree li.liClosed ul { display: none; }
|
||||||
|
|
||||||
|
/* Format menu items differently depending on what level of the tree they are in */
|
||||||
|
/* Uncomment this if you want your fonts to decrease in size the deeper they are in the tree */
|
||||||
|
/*
|
||||||
|
ul.mktree li ul li { font-size: 90% }
|
||||||
|
*/
|
||||||
|
|
||||||
|
}
|
BIN
html/images/bullet.gif
Normal file
BIN
html/images/bullet.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 62 B |
BIN
html/images/minus.gif
Normal file
BIN
html/images/minus.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 87 B |
BIN
html/images/plus.gif
Normal file
BIN
html/images/plus.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 89 B |
@@ -165,6 +165,7 @@ if (empty($config['favicon'])) {
|
|||||||
<link href="css/typeahead.js-bootstrap.css" rel="stylesheet" type="text/css" />
|
<link href="css/typeahead.js-bootstrap.css" rel="stylesheet" type="text/css" />
|
||||||
<link href="css/jquery-ui.min.css" rel="stylesheet" type="text/css" />
|
<link href="css/jquery-ui.min.css" rel="stylesheet" type="text/css" />
|
||||||
<link href="css/tagmanager.css" rel="stylesheet" type="text/css" />
|
<link href="css/tagmanager.css" rel="stylesheet" type="text/css" />
|
||||||
|
<link href="css/mktree.css" rel="stylesheet" type="text/css" />
|
||||||
<link href="<?php echo($config['stylesheet']); ?>" rel="stylesheet" type="text/css" />
|
<link href="<?php echo($config['stylesheet']); ?>" rel="stylesheet" type="text/css" />
|
||||||
<script src="js/jquery.min.js"></script>
|
<script src="js/jquery.min.js"></script>
|
||||||
<script src="js/bootstrap.min.js"></script>
|
<script src="js/bootstrap.min.js"></script>
|
||||||
@@ -177,6 +178,7 @@ if (empty($config['favicon'])) {
|
|||||||
<script src="js/typeahead.min.js"></script>
|
<script src="js/typeahead.min.js"></script>
|
||||||
<script src="js/jquery-ui.min.js"></script>
|
<script src="js/jquery-ui.min.js"></script>
|
||||||
<script src="js/tagmanager.js"></script>
|
<script src="js/tagmanager.js"></script>
|
||||||
|
<script src="js/mktree.js"></script>
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
|
|
||||||
<!-- Begin
|
<!-- Begin
|
||||||
|
168
html/js/mktree.js
Normal file
168
html/js/mktree.js
Normal file
@@ -0,0 +1,168 @@
|
|||||||
|
/**
|
||||||
|
* 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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user