Fix stylelint popup code & use codemirror

This commit is contained in:
Rob Garrison 2017-08-19 20:49:13 -05:00
parent 06130446c6
commit b1a7f8d4a2
3 changed files with 101 additions and 24 deletions

View File

@ -511,18 +511,17 @@
"description": "Label for the button to remove a section" "description": "Label for the button to remove a section"
}, },
"setStylelintLink": { "setStylelintLink": {
"message": "Get a full list of rules from $link$", "message": "Get a full list of rules",
"description": "Stylelint rules link", "description": "Stylelint rules label before link"
"placeholders": {
"link": {
"content": "$1"
}
}
}, },
"setStylelintRules": { "setStylelintRules": {
"message": "Set stylelint rules", "message": "Set stylelint rules",
"description": "Stylelint popup header" "description": "Stylelint popup header"
}, },
"resetStylelintRules": {
"message": "Reset",
"description": "Reset stylelint rules"
},
"setStylelintError": { "setStylelintError": {
"message": "Invalid JSON format", "message": "Invalid JSON format",
"description": "Stylelint invalid JSON message" "description": "Stylelint invalid JSON message"

View File

@ -1,4 +1,5 @@
/* global CodeMirror CSSLint editors makeSectionVisible showHelp stylelintDefaultConfig */ /* global CodeMirror CSSLint editors makeSectionVisible showHelp showCodeMirrorPopup */
/* global stylelintDefaultConfig onDOMscripted */
'use strict'; 'use strict';
function initLint() { function initLint() {
@ -204,11 +205,11 @@ function showLintHelp() {
return showHelp(t('issues'), header + list + '</ul>'); return showHelp(t('issues'), header + list + '</ul>');
} }
function setupStylelintSettingsEvents() { function setupStylelintSettingsEvents(popup) {
let timer; let timer;
$('#help-popup .save').addEventListener('click', event => { popup.querySelector('.save').addEventListener('click', event => {
event.preventDefault(); event.preventDefault();
const json = tryJSONparse($('#help-popup textarea').value); const json = tryJSONparse(popup.codebox.getValue());
if (json && json.rules) { if (json && json.rules) {
setStylelintRules(json.rules); setStylelintRules(json.rules);
// it is possible to have stylelint rules popup open & switch to csslint // it is possible to have stylelint rules popup open & switch to csslint
@ -227,10 +228,10 @@ function setupStylelintSettingsEvents() {
}, 3000); }, 3000);
} }
}); });
$('#help-popup .reset').addEventListener('click', event => { popup.querySelector('reset').addEventListener('click', event => {
event.preventDefault(); event.preventDefault();
setStylelintRules(); setStylelintRules();
$('#help-popup .settings').value = JSON.stringify({rules: stylelintDefaultConfig.rules}, null, 2); popup.codebox.setValue(JSON.stringify({rules: stylelintDefaultConfig.rules}, null, 2));
if (prefs.get('editor.linter') === 'stylelint') { if (prefs.get('editor.linter') === 'stylelint') {
updateLinter('stylelint'); updateLinter('stylelint');
} }
@ -239,16 +240,56 @@ function setupStylelintSettingsEvents() {
function openStylelintSettings() { function openStylelintSettings() {
BG.chromeLocal.getValue('editorStylelintRules').then((rules = stylelintDefaultConfig.rules) => { BG.chromeLocal.getValue('editorStylelintRules').then((rules = stylelintDefaultConfig.rules) => {
const link = '<a target="_blank" href="https://stylelint.io/demo/">Stylelint</a>'; const rulesString = JSON.stringify({rules: rules}, null, 2);
const text = JSON.stringify({rules: rules}, null, 2); setupStylelintPopup(rulesString);
const content = `<textarea class="contents settings">${text}</textarea>
<p>${t('setStylelintLink', link)}</p>
<button class="save" type="button">Save</button>&nbsp;
<button class="reset" type="button">Reset</button>
<span class="error">
${t('setStylelintError')} (<a target="_blank" href="https://jsonlint.com/">JSONLint</a>)
</span>`;
showHelp(t('setStylelintRules'), content);
setupStylelintSettingsEvents();
}); });
} }
function setupStylelintPopup(rules) {
function makeButton(className, text) {
return $element({tag: 'button', className, type: 'button', textContent: t(text)});
}
function makeLink(url, textContent) {
return $element({tag: 'a', target: '_blank', href: url, textContent});
}
function setJSONMode(cm) {
cm.setOption('mode', 'application/json');
}
const popup = showCodeMirrorPopup(t('setStylelintRules'), $element({
className: 'contents',
appendChild: [
$element({
tag: 'p',
appendChild: [
t('setStylelintLink') + ' ',
makeLink('https://stylelint.io/demo/', 'Stylelint')
]
}),
makeButton('save', 'styleSaveLabel'),
makeButton('reset', 'resetStylelintRules'),
$element({
tag: 'span',
className: 'error',
appendChild: [
t('setStylelintError'),
makeLink('https://jsonlint.com/', 'Stylelint')
]
})
]
}));
const contents = popup.querySelector('.contents');
contents.insertBefore(popup.codebox.display.wrapper, contents.firstElementChild);
popup.codebox.focus();
popup.codebox.setValue(rules);
if (!$('script[src*="json-lint.js"]')) {
onDOMscripted(
['vendor/codemirror/addon/lint/json-lint.js'],
() => {
setJSONMode(popup.codebox);
}
);
} else {
setJSONMode(popup.codebox);
}
setupStylelintSettingsEvents(popup);
}

View File

@ -0,0 +1,37 @@
// CodeMirror, copyright (c) by Marijn Haverbeke and others
// Distributed under an MIT license: http://codemirror.net/LICENSE
// Depends on jsonlint.js from https://github.com/zaach/jsonlint
// declare global: jsonlint
(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", "json", function(text) {
var found = [];
if (!window.jsonlint) {
if (window.console) {
window.console.error("Error: window.jsonlint not defined, CodeMirror JSON linting cannot run.");
}
return found;
}
jsonlint.parseError = function(str, hash) {
var loc = hash.loc;
found.push({from: CodeMirror.Pos(loc.first_line - 1, loc.first_column),
to: CodeMirror.Pos(loc.last_line - 1, loc.last_column),
message: str});
};
try { jsonlint.parse(text); }
catch(e) {}
return found;
});
});