editor: preload lint gutters css; update on disabling
This commit is contained in:
parent
e65e3c9c0b
commit
c15082fed4
|
@ -8,8 +8,8 @@
|
||||||
<script src="js/localization.js"></script>
|
<script src="js/localization.js"></script>
|
||||||
<script src="content/apply.js"></script>
|
<script src="content/apply.js"></script>
|
||||||
<link rel="stylesheet" href="edit/edit.css">
|
<link rel="stylesheet" href="edit/edit.css">
|
||||||
<script src="edit/edit.js"></script>
|
|
||||||
<script src="edit/lint.js"></script>
|
<script src="edit/lint.js"></script>
|
||||||
|
<script src="edit/edit.js"></script>
|
||||||
|
|
||||||
<script src="vendor/codemirror/lib/codemirror.js"></script>
|
<script src="vendor/codemirror/lib/codemirror.js"></script>
|
||||||
<link rel="stylesheet" href="vendor/codemirror/lib/codemirror.css">
|
<link rel="stylesheet" href="vendor/codemirror/lib/codemirror.css">
|
||||||
|
@ -34,6 +34,7 @@
|
||||||
|
|
||||||
<script src="vendor/codemirror/addon/edit/matchbrackets.js"></script>
|
<script src="vendor/codemirror/addon/edit/matchbrackets.js"></script>
|
||||||
|
|
||||||
|
<link rel="stylesheet" href="vendor/codemirror/addon/lint/lint.css" />
|
||||||
<link rel="stylesheet" href="vendor/codemirror/addon/hint/show-hint.css" />
|
<link rel="stylesheet" href="vendor/codemirror/addon/hint/show-hint.css" />
|
||||||
<script src="vendor/codemirror/addon/hint/show-hint.js"></script>
|
<script src="vendor/codemirror/addon/hint/show-hint.js"></script>
|
||||||
<script src="vendor/codemirror/addon/hint/css-hint.js"></script>
|
<script src="vendor/codemirror/addon/hint/css-hint.js"></script>
|
||||||
|
|
12
edit/edit.js
12
edit/edit.js
|
@ -162,8 +162,6 @@ function initCodeMirror() {
|
||||||
const CM = CodeMirror;
|
const CM = CodeMirror;
|
||||||
const isWindowsOS = navigator.appVersion.indexOf('Windows') > 0;
|
const isWindowsOS = navigator.appVersion.indexOf('Windows') > 0;
|
||||||
// lint.js is not loaded initially
|
// lint.js is not loaded initially
|
||||||
const hasLinter = window.linterConfig ? linterConfig.getForCodeMirror() : false;
|
|
||||||
|
|
||||||
// CodeMirror miserably fails on keyMap='' so let's ensure it's not
|
// CodeMirror miserably fails on keyMap='' so let's ensure it's not
|
||||||
if (!prefs.get('editor.keyMap')) {
|
if (!prefs.get('editor.keyMap')) {
|
||||||
prefs.reset('editor.keyMap');
|
prefs.reset('editor.keyMap');
|
||||||
|
@ -175,11 +173,15 @@ function initCodeMirror() {
|
||||||
lineNumbers: true,
|
lineNumbers: true,
|
||||||
lineWrapping: true,
|
lineWrapping: true,
|
||||||
foldGutter: true,
|
foldGutter: true,
|
||||||
gutters: ['CodeMirror-linenumbers', 'CodeMirror-foldgutter', 'CodeMirror-lint-markers'],
|
gutters: [
|
||||||
|
'CodeMirror-linenumbers',
|
||||||
|
'CodeMirror-foldgutter',
|
||||||
|
...(prefs.get('editor.linter') ? ['CodeMirror-lint-markers'] : []),
|
||||||
|
],
|
||||||
matchBrackets: true,
|
matchBrackets: true,
|
||||||
highlightSelectionMatches: {showToken: /[#.\-\w]/, annotateScrollbar: true},
|
highlightSelectionMatches: {showToken: /[#.\-\w]/, annotateScrollbar: true},
|
||||||
hintOptions: {},
|
hintOptions: {},
|
||||||
lint: hasLinter,
|
lint: linterConfig.getForCodeMirror(),
|
||||||
lintReportDelay: prefs.get('editor.lintReportDelay'),
|
lintReportDelay: prefs.get('editor.lintReportDelay'),
|
||||||
styleActiveLine: true,
|
styleActiveLine: true,
|
||||||
theme: 'default',
|
theme: 'default',
|
||||||
|
@ -370,7 +372,7 @@ function acmeEventListener(event) {
|
||||||
option = 'highlightSelectionMatches';
|
option = 'highlightSelectionMatches';
|
||||||
break;
|
break;
|
||||||
case 'linter':
|
case 'linter':
|
||||||
updateLinter(value);
|
debounce(updateLinter);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
CodeMirror.setOption(option, value);
|
CodeMirror.setOption(option, value);
|
||||||
|
|
61
edit/lint.js
61
edit/lint.js
|
@ -3,6 +3,8 @@
|
||||||
/* global onDOMscripted injectCSS require CSSLint stylelint */
|
/* global onDOMscripted injectCSS require CSSLint stylelint */
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
loadLinterAssets();
|
||||||
|
|
||||||
// eslint-disable-next-line no-var
|
// eslint-disable-next-line no-var
|
||||||
var linterConfig = {
|
var linterConfig = {
|
||||||
csslint: {},
|
csslint: {},
|
||||||
|
@ -133,19 +135,49 @@ function initLint() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function updateLinter(linter = prefs.get('editor.linter')) {
|
function updateLinter(linter = prefs.get('editor.linter')) {
|
||||||
|
const GUTTERS_CLASS = 'CodeMirror-lint-markers';
|
||||||
|
|
||||||
function updateEditors() {
|
function updateEditors() {
|
||||||
const options = linterConfig.getForCodeMirror(linter);
|
CodeMirror.defaults.lint = linterConfig.getForCodeMirror(linter);
|
||||||
CodeMirror.defaults.lint = options;
|
const guttersOption = prepareGuttersOption();
|
||||||
editors.forEach(cm => {
|
editors.forEach(cm => {
|
||||||
// set lint to "null" to disable
|
cm.setOption('lint', CodeMirror.defaults.lint);
|
||||||
cm.setOption('lint', options);
|
if (guttersOption) {
|
||||||
// enabling/disabling linting changes the gutter width
|
cm.setOption('guttersOption', guttersOption);
|
||||||
|
updateGutters(cm, guttersOption);
|
||||||
|
}
|
||||||
cm.refresh();
|
cm.refresh();
|
||||||
updateLintReport(cm, 200);
|
updateLintReport(cm, 200);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function prepareGuttersOption() {
|
||||||
|
const gutters = CodeMirror.defaults.gutters;
|
||||||
|
const needRefresh = Boolean(linter) !== gutters.includes(GUTTERS_CLASS);
|
||||||
|
if (needRefresh) {
|
||||||
|
if (linter) {
|
||||||
|
gutters.push(GUTTERS_CLASS);
|
||||||
|
} else {
|
||||||
|
gutters.splice(gutters.indexOf(GUTTERS_CLASS), 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return needRefresh && gutters;
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateGutters(cm, guttersOption) {
|
||||||
|
cm.options.gutters = guttersOption;
|
||||||
|
const el = $('.' + GUTTERS_CLASS, cm.display.gutters);
|
||||||
|
if (linter && !el) {
|
||||||
|
cm.display.gutters.appendChild($element({
|
||||||
|
className: 'CodeMirror-gutter ' + GUTTERS_CLASS
|
||||||
|
}));
|
||||||
|
} else if (!linter && el) {
|
||||||
|
el.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// load scripts
|
// load scripts
|
||||||
loadSelectedLinter(linter).then(() => {
|
loadLinterAssets(linter).then(() => {
|
||||||
updateEditors();
|
updateEditors();
|
||||||
});
|
});
|
||||||
$('#linter-settings').style.display = !linter ? 'none' : 'inline-block';
|
$('#linter-settings').style.display = !linter ? 'none' : 'inline-block';
|
||||||
|
@ -159,8 +191,10 @@ function updateLintReport(cm, delay) {
|
||||||
}
|
}
|
||||||
if (delay > 0) {
|
if (delay > 0) {
|
||||||
setTimeout(cm => {
|
setTimeout(cm => {
|
||||||
cm.performLint();
|
if (cm.performLint) {
|
||||||
update(cm);
|
cm.performLint();
|
||||||
|
update(cm);
|
||||||
|
}
|
||||||
}, delay, cm);
|
}, delay, cm);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -374,7 +408,7 @@ function setupLinterSettingsEvents(popup) {
|
||||||
}
|
}
|
||||||
linterConfig.save(json);
|
linterConfig.save(json);
|
||||||
linterConfig.showSavedMessage();
|
linterConfig.showSavedMessage();
|
||||||
debounce(updateLinter, 0, linter);
|
debounce(updateLinter);
|
||||||
} else {
|
} else {
|
||||||
showLinterErrorMessage(linter, t('linterJSONError'));
|
showLinterErrorMessage(linter, t('linterJSONError'));
|
||||||
}
|
}
|
||||||
|
@ -450,7 +484,11 @@ function setupLinterPopup(config) {
|
||||||
setupLinterSettingsEvents(popup);
|
setupLinterSettingsEvents(popup);
|
||||||
}
|
}
|
||||||
|
|
||||||
function loadSelectedLinter(name) {
|
function loadLinterAssets(name = prefs.get('editor.linter')) {
|
||||||
|
if (loadLinterAssets.loadingName === name) {
|
||||||
|
return onDOMscripted();
|
||||||
|
}
|
||||||
|
loadLinterAssets.loadingName = name;
|
||||||
const scripts = [];
|
const scripts = [];
|
||||||
if (name === 'csslint' && !window.CSSLint) {
|
if (name === 'csslint' && !window.CSSLint) {
|
||||||
scripts.push(
|
scripts.push(
|
||||||
|
@ -473,5 +511,6 @@ function loadSelectedLinter(name) {
|
||||||
'msgbox/msgbox.js'
|
'msgbox/msgbox.js'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
return onDOMscripted(scripts);
|
return onDOMscripted(scripts)
|
||||||
|
.then(() => (loadLinterAssets.loadingName = null));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user