diff options
| author | Nicolai Tellefsen <niccofyren@gmail.com> | 2016-03-24 02:51:06 +0100 | 
|---|---|---|
| committer | Nicolai Tellefsen <niccofyren@gmail.com> | 2016-03-24 02:51:06 +0100 | 
| commit | 91e4dcd96203f12c67936ed5d3fa7a890ea2cf55 (patch) | |
| tree | 42b64cf3a9aa2bedd5266330488fe26de3ff3232 /web | |
| parent | 85a031af6775a9a24fa51c63b6ed4b38ee52945b (diff) | |
NMS: Add POC inventory listing to front-end
Diffstat (limited to 'web')
| -rw-r--r-- | web/nms.gathering.org/index.html | 6 | ||||
| -rw-r--r-- | web/nms.gathering.org/js/nms-info-box.js | 111 | 
2 files changed, 113 insertions, 4 deletions
| diff --git a/web/nms.gathering.org/index.html b/web/nms.gathering.org/index.html index a10d1dc..366c960 100644 --- a/web/nms.gathering.org/index.html +++ b/web/nms.gathering.org/index.html @@ -77,11 +77,15 @@  		<li><a href="#" onclick="toggleNightMode()">Toggle Night Mode</a></li>  		<li><a href="#" onclick="toggleConnect()">Toggle linknets</a></li>  		<li class="divider"> </li> -		<li class="dropdown-header">Move switches</li> +		<li class="dropdown-header">Switches</li>  	  	<li><a href="#" onclick="nmsMap.moveSet(true);">Enable switch moving</a></li>  	  	<li><a href="#" onclick="nmsMap.moveSet(false);">Disable switch moving</a></li>  	  	<li><a href="#" onclick="nmsInfoBox.showWindow('addSwitch')">Add switch</a></li>  		<li class="divider"> </li> +		<li class="dropdown-header">Inventory lists</li> +	  	<li><a href="#" onclick="nmsInfoBox.showWindow('inventoryListing','distro_name');">Distro names</a></li> +	  	<li><a href="#" onclick="nmsInfoBox.showWindow('inventoryListing','sysDescr')">System description</a></li> +		<li class="divider"> </li>  		<li class="dropdown-header">Help</li>  	  	<li><a href="#" onclick="toggleLayer('aboutKeybindings');" >Keyboard Shortcuts</a></li>  	      </ul> diff --git a/web/nms.gathering.org/js/nms-info-box.js b/web/nms.gathering.org/js/nms-info-box.js index 6599f5b..85b5d81 100644 --- a/web/nms.gathering.org/js/nms-info-box.js +++ b/web/nms.gathering.org/js/nms-info-box.js @@ -37,10 +37,10 @@ nmsInfoBox.showWindow = function (windowName,argument) {  /*   * Refresh the active window   */ -nmsInfoBox.refresh = function() { +nmsInfoBox.refresh = function(argument) {  	if(!nmsInfoBox._window)  		return; -  nmsInfoBox._show(); +  nmsInfoBox._show(argument);  };  nmsInfoBox.update = function(argument) {  	if(!nmsInfoBox._window) @@ -57,7 +57,8 @@ nmsInfoBox._show = function(argument) {    nmsData.addHandler("smanagement","switchshower",nmsInfoBox.update,'smanagement');    nmsData.addHandler("snmp","switchshower",nmsInfoBox.update,'snmp'); -  this._window.load(argument); +	if(argument != "soft") +		this._window.load(argument);    this._container = document.getElementById("info-panel-container");    var panel = document.createElement("div"); @@ -368,6 +369,110 @@ nmsInfoBox._windowTypes.switchInfo = {  };  /* + * Window type: Show inventory listing + * + * Basic window that displays a list of all devices with simple summary information + * + * TODO: Set up more complex views with more columns, sorting, etc. + * + */ +nmsInfoBox._windowTypes.inventoryListing = { +  content:  '', +  childContent: false, +	activeView: '', +  getTitle: function() { +    return '<h4>Inventory listing</h4><button type="button" class="distro-name btn btn-xs btn-default" onclick="nmsInfoBox.showWindow(\'inventoryListing\',\'distro_name\');">Distro name</button> <button type="button" class="distro-name btn btn-xs btn-default" onclick="nmsInfoBox.showWindow(\'inventoryListing\',\'sysDescr\');">System Description</button>'; +  }, +  getContent: function() { +    return this.content; +  }, +  getChildContent: function() { +    return this.childContent; +  }, +  load: function(list) { +		var hasSnmp = false; +		var targetArray = []; +		var listTitle = ''; +		var needRefresh = false; +		var needSnmp = false; + +		if(!nmsData.switches || !nmsData.switches.switches) +			return; +		if(!(!nmsData.snmp || !nmsData.snmp.snmp)) { +			hasSnmp = true; +		} +		if(list == 'soft') { +			list = this.activeView; +			needRefresh = true; +		} + +		switch (list) { +			case 'distro_name': +				targetArray = nmsData.switches.switches; +				listTitle = 'Distro names'; +				break; +			case 'sysDescr': +				if(hasSnmp) +					targetArray = nmsData.snmp.snmp; +				listTitle = 'System description'; +				needSnmp = true; +				break; +			default: +				targetArray = nmsData.switches.switches; +				listTitle = 'Distro names'; +				list = 'distro_name'; +		} +		this.activeView = list; + +		if(needSnmp && !hasSnmp) { +			this.content = "No SNMP data loaded. Reloading shortly."; +			nmsData.addHandler("snmp","inventoryListing",nmsInfoBox._windowTypes.inventoryListing.update,'soft'); +			return; +		} + +		var resultArray = []; +		for(var sw in targetArray) { +			var value = ''; +			try { +				switch (list) { +					case 'distro_name': +						value = targetArray[sw]["distro_name"]; +						break; +					case 'sysDescr': +						value = targetArray[sw]["misc"]["sysDescr"][0]; +						break; +				} +			} catch (e) { +				//console.log(e); +			} +			resultArray.push([sw, value]); +		} + +		resultArray.sort(); + +		var infotable = nmsInfoBox._makeTable(resultArray,listTitle); +		infotable.id = "inventory-table"; + +		this.content = infotable; +		if(needRefresh) +			nmsInfoBox.refresh("soft"); +  }, +	update: function(type) { +		if(type == "soft") { +			nmsData.unregisterHandler("snmp","inventoryListing"); +			nmsInfoBox._windowTypes.inventoryListing.load('soft'); +		} +	}, +  unload: function() { +		nmsData.unregisterHandler("snmp","inventoryListing"); +		this.content = ''; +		this.activeView = ''; +  }, +  save: function() { +	} +}; + +/*   * Click a switch and display it   * it.   */ | 
