diff options
| author | Ole Mathias Heggem <ole@sdok.no> | 2017-03-25 15:04:04 +0100 | 
|---|---|---|
| committer | Ole Mathias Heggem <ole@sdok.no> | 2017-03-25 15:04:04 +0100 | 
| commit | f70f65f7466a480a45a8260b35887cb7ed36b466 (patch) | |
| tree | 8bb42a981600498ab53d8f444e926920b9195b53 /web/js/nms-search.js | |
| parent | 108377f8adf91d34481ff344cb914e0c6101e530 (diff) | |
Added a basic search results page and search on tags
Diffstat (limited to 'web/js/nms-search.js')
| -rw-r--r-- | web/js/nms-search.js | 32 | 
1 files changed, 22 insertions, 10 deletions
| diff --git a/web/js/nms-search.js b/web/js/nms-search.js index 1167b51..7528a82 100644 --- a/web/js/nms-search.js +++ b/web/js/nms-search.js @@ -15,6 +15,8 @@ nmsSearch.helpText =  [  	'IP search: Start typing an IP and any switch with that IP registered either as management IP or part of its subnet will be identified',  	'SNMP search: Type anything found in the "sysDescr" SNMP OID to hilight a switch matching that. Practical examples include version numbers for firmware (e.g.: "JUNOS 12." vs "JUNOS 14.").']; +nmsSearch.matches = []; +  /*   * Test if the search expression "id" matches the switch "sw"   * @@ -81,6 +83,13 @@ nmsSearch.searchTest = function(id, sw) {  			}  		} catch (e) {}  		try { +			for (var x in nmsData.switches.switches[sw]['tags']) { +				if(re.test(nmsData.switches.switches[sw]['tags'][x])){ +					return true; +				} +			} +		} catch (e) {} +		try {  			for (var x in nmsData.snmp.snmp[sw].misc.entPhysicalSerialNum) {  				if (nmsData.snmp.snmp[sw].misc.entPhysicalSerialNum[x] == null) {  					continue; @@ -126,7 +135,7 @@ nmsSearch._disableTimer = function() {  nmsSearch.search = function() {  	var el = document.getElementById("searchbox");  	var id = false; -	var matches = []; +	nmsSearch.matches = [];  	if (el) {  		id = el.value.toLowerCase();  	} @@ -134,7 +143,7 @@ nmsSearch.search = function() {  		nmsMap.enableHighlights();  		for(var sw in nmsData.switches.switches) {  			if (nmsSearch.searchTest(id,sw)) { -				matches.push(sw); +				nmsSearch.matches.push(sw);  				nmsMap.setSwitchHighlight(sw,true);  			} else {  				nmsMap.setSwitchHighlight(sw,false); @@ -145,22 +154,25 @@ nmsSearch.search = function() {  		nmsSearch._disableTimer();  		nmsMap.disableHighlights();  	} -	if(matches.length == 1) { -		document.getElementById("searchbox-submit").classList.add("btn-primary"); -		document.getElementById("searchbox").dataset.match = matches[0]; -	} else { +	if(nmsSearch.matches.length == 0) {  		document.getElementById("searchbox-submit").classList.remove("btn-primary");  		document.getElementById("searchbox").dataset.match = '';  	}  }; +nmsSearch.runSearch = function() { +	if(nmsSearch.matches.length == 1) { +		nmsInfoBox.showWindow("switchInfo",nmsSearch.matches[0]); +	} +	else { +        	nmsInfoBox.showWindow('searchResults',nmsSearch.matches.length); +	} +}; +  nmsSearch._searchKeyListener = function(e) {  	switch (e.keyCode) {  		case 13: -			var sw = document.getElementById("searchbox").dataset.match; -			if(sw != '') { -				nmsInfoBox.showWindow("switchInfo",sw); -			} +			nmsSearch.runSearch();  			break;  		case 27:  			nmsSearch.reset(); | 
