Better error handling on dev tools

This commit is contained in:
Jesús Ángel González 2018-05-09 18:12:18 +02:00
parent 44da24f85b
commit 8ba97e8908
3 changed files with 61 additions and 20 deletions

View File

@ -46,7 +46,7 @@ app.controller('devToolsController', function($scope, $rootScope, errorHandler,
const cursor = apiInputBox.getSearchCursor(tmp[0])
if(cursor.findNext()) start = cursor.from().line
else return false;
else return [];
end = start + tmp.length;
@ -84,7 +84,7 @@ app.controller('devToolsController', function($scope, $rootScope, errorHandler,
return tmpgroups;
} catch(error){
return false;
return [];
}
}
@ -96,6 +96,7 @@ app.controller('devToolsController', function($scope, $rootScope, errorHandler,
if(currentGroup){
const hasWidget = widgets.filter(item => item.start === currentGroup.start)
if(hasWidget.length) apiInputBox.removeLineWidget(hasWidget[0].widget)
setTimeout(() => checkJsonParseError(),450)
}
})
@ -128,20 +129,23 @@ app.controller('devToolsController', function($scope, $rootScope, errorHandler,
jsonLint.parse(item.requestTextJson)
} catch(error) {
affectedGroups.push(item.requestText);
var msg = document.createElement("div");
var icon = msg.appendChild(document.createElement("span"));
icon.innerHTML = "!";
const msg = document.createElement("div");
msg.id = new Date().getTime()/1000;
const icon = msg.appendChild(document.createElement("div"));
icon.className = "lint-error-icon";
msg.onmouseover = () => {
msg.removeChild(msg.lastChild)
msg.appendChild(document.createTextNode(error.message));
icon.id = new Date().getTime()/1000;
icon.onmouseover = () => {
const advice = msg.appendChild(document.createElement("span"));
advice.id = new Date().getTime()/1000;
advice.innerText = error.message || 'Error parsing query'
advice.className = 'lint-block-wz'
}
msg.onmouseleave = () => {
icon.onmouseleave = () => {
msg.removeChild(msg.lastChild)
msg.appendChild(document.createTextNode('Invalid query'));
}
msg.appendChild(document.createTextNode('Invalid query'));
msg.className = "lint-error";
widgets.push({start:item.start,widget:apiInputBox.addLineWidget(item.start, msg, {coverGutter: false, noHScroll: true})});
}
}
@ -194,12 +198,11 @@ app.controller('devToolsController', function($scope, $rootScope, errorHandler,
const desiredGroup = calculateWhichGroup();
if(!desiredGroup) throw Error('not desired');
if(!firstTime){
const affectedGroups = checkJsonParseError();
const filteredAffectedGroups = affectedGroups.filter(item => item === desiredGroup.requestText);
if(filteredAffectedGroups.length) {apiOutputBox.setValue('Error parsing JSON query'); return;}
}
const affectedGroups = checkJsonParseError();
const filteredAffectedGroups = affectedGroups.filter(item => item === desiredGroup.requestText);
if(filteredAffectedGroups.length) {apiOutputBox.setValue('Error parsing JSON query'); return;}
const method = desiredGroup.requestText.startsWith('GET') ?
'GET' :

View File

@ -1,5 +1,5 @@
<div flex ng-controller="devToolsController" layout="column">
<div flex ng-controller="devToolsController" layout="column" class="dev-tools-max-height">
<wz-menu ng-init="menuNavItem = 'wazuh-dev'"></wz-menu>
<md-content flex layout="column" class="md-padding" layout-align="start">

View File

@ -349,4 +349,42 @@ span.CodeMirror-selectedtext { background: none; }
.lint-error {font-family: arial; font-size: 70%; background: #ffa; color: #a00; padding: 2px 5px 3px; }
.lint-error-icon {color: white; background-color: red; font-weight: bold; border-radius: 50%; padding: 0 3px; margin-right: 7px;}
.lint-error-icon {
background-image: url("");
background-repeat: no-repeat;
background-position: 2px center;
height: 15px;
width:18px;
cursor:help;
}
.lint-default-msg {
padding-left:19px;
}
.lint-block-wz {
background-color: #FFF;
background-image: -webkit-linear-gradient(top, transparent, rgba(0, 0, 0, 0.1));
background-image: linear-gradient(to bottom, transparent, rgba(0, 0, 0, 0.1));
border: 1px solid gray;
border-radius: 1px;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
color: black;
display: inline-block;
max-width: 500px;
padding: 4px;
/*position: fixed;*/
z-index: 999999;
-moz-box-sizing: border-box;
-webkit-box-sizing: border-box;
box-sizing: border-box;
cursor: default;
white-space: pre-line;
word-wrap: break-word;
line-height: normal;
font-style: normal;
font-weight: normal;
letter-spacing: normal;
}
.dev-tools-max-height {
height: -webkit-fill-available;
}