Owen Leonard
08900d5653
system preferences This patch adds CodeMirror plugins for linting JS, CSS, HTML, and YAML. When invalid data is entered in a linted CodeMirror editor an icon is displayed in the editor's "gutter." Hovering over the icon displays the error message. This patch renames the minified CodeMirror JS file to match convention but the version is unchanged. To test, apply the patch and go to Administration -> System preferences. Test preferences of each type and confirm that each type of CodeMirror editor shows an error indicator if you entry invalid data. Valid data should trigger no error indicator. - HTML: e.g. OpacMainUserBlock, opacheader. Enter invalid HTML, for example "<h1>Hello <h2>World</h2>." Example valid HTML: "<h1>Hello world</h1>" - JavaScript: e.g. OpacUserJS, IntranetUserJS. Example bad JS, "alert("Success!');" Example valid JS: "alert("Success!");" - CSS: e.g. IntranetUserCSS, SCOUserCSS. Example bad CSS, "p { color blue }" Example valid CSS, "p { color: blue; }" - YAML: e.g. OpacHiddenItems. Example bad YAML: "one: two, three: four" Example valid YAML: "one: two three: four" Also test that other CodeMirror instances still work correctly without linting: The advanced MARC editor, SQL reports editing. Signed-off-by: David Nind <david@davidnind.com> Signed-off-by: Katrin Fischer <katrin.fischer.83@web.de> Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>
40 lines
1.3 KiB
JavaScript
40 lines
1.3 KiB
JavaScript
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
|
// Distributed under an MIT license: https://codemirror.net/LICENSE
|
|
|
|
// Depends on csslint.js from https://github.com/stubbornella/csslint
|
|
|
|
// declare global: CSSLint
|
|
|
|
(function(mod) {
|
|
if (typeof exports == "object" && typeof module == "object") // CommonJS
|
|
mod(require("../../lib/codemirror"));
|
|
else if (typeof define == "function" && define.amd) // AMD
|
|
define(["../../lib/codemirror"], mod);
|
|
else // Plain browser env
|
|
mod(CodeMirror);
|
|
})(function(CodeMirror) {
|
|
"use strict";
|
|
|
|
CodeMirror.registerHelper("lint", "css", function(text, options) {
|
|
var found = [];
|
|
if (!window.CSSLint) {
|
|
if (window.console) {
|
|
window.console.error("Error: window.CSSLint not defined, CodeMirror CSS linting cannot run.");
|
|
}
|
|
return found;
|
|
}
|
|
var results = CSSLint.verify(text, options), messages = results.messages, message = null;
|
|
for ( var i = 0; i < messages.length; i++) {
|
|
message = messages[i];
|
|
var startLine = message.line -1, endLine = message.line -1, startCol = message.col -1, endCol = message.col;
|
|
found.push({
|
|
from: CodeMirror.Pos(startLine, startCol),
|
|
to: CodeMirror.Pos(endLine, endCol),
|
|
message: message.message,
|
|
severity : message.type
|
|
});
|
|
}
|
|
return found;
|
|
});
|
|
|
|
});
|