From 8ba97e8908906ca77ca2e7f3fa0f310047ea927d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jes=C3=BAs=20=C3=81ngel=20Gonz=C3=A1lez?= Date: Wed, 9 May 2018 18:12:18 +0200 Subject: [PATCH] Better error handling on dev tools --- public/controllers/dev-tools.js | 39 ++++++++++++---------- public/templates/dev-tools/dev-tools.html | 2 +- public/utils/codemirror/codemirror.css | 40 ++++++++++++++++++++++- 3 files changed, 61 insertions(+), 20 deletions(-) diff --git a/public/controllers/dev-tools.js b/public/controllers/dev-tools.js index 9b84e5eb8..2a5676f6d 100644 --- a/public/controllers/dev-tools.js +++ b/public/controllers/dev-tools.js @@ -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' : diff --git a/public/templates/dev-tools/dev-tools.html b/public/templates/dev-tools/dev-tools.html index 679177017..f482cfeaa 100644 --- a/public/templates/dev-tools/dev-tools.html +++ b/public/templates/dev-tools/dev-tools.html @@ -1,5 +1,5 @@ -
+
diff --git a/public/utils/codemirror/codemirror.css b/public/utils/codemirror/codemirror.css index f6436a9e7..52e07a2cd 100644 --- a/public/utils/codemirror/codemirror.css +++ b/public/utils/codemirror/codemirror.css @@ -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; +} \ No newline at end of file