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>
41 lines
1.2 KiB
JavaScript
41 lines
1.2 KiB
JavaScript
// CodeMirror, copyright (c) by Marijn Haverbeke and others
|
|
// Distributed under an MIT license: https://codemirror.net/LICENSE
|
|
|
|
(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";
|
|
|
|
// Depends on js-yaml.js from https://github.com/nodeca/js-yaml
|
|
|
|
// declare global: jsyaml
|
|
|
|
CodeMirror.registerHelper("lint", "yaml", function(text) {
|
|
var found = [];
|
|
if (!window.jsyaml) {
|
|
if (window.console) {
|
|
window.console.error("Error: window.jsyaml not defined, CodeMirror YAML linting cannot run.");
|
|
}
|
|
return found;
|
|
}
|
|
try { jsyaml.loadAll(text); }
|
|
catch(e) {
|
|
var loc = e.mark,
|
|
// js-yaml YAMLException doesn't always provide an accurate lineno
|
|
// e.g., when there are multiple yaml docs
|
|
// ---
|
|
// ---
|
|
// foo:bar
|
|
from = loc ? CodeMirror.Pos(loc.line, loc.column) : CodeMirror.Pos(0, 0),
|
|
to = from;
|
|
found.push({ from: from, to: to, message: e.message });
|
|
}
|
|
return found;
|
|
});
|
|
|
|
});
|