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