mirror of
https://github.com/status-im/consul.git
synced 2025-01-22 11:40:06 +00:00
d1ac40e967
* ui: Add XML syntax highlighting to key/value editor * ui: Make explicit options that are specific to XML for clarity
47 lines
926 B
JavaScript
47 lines
926 B
JavaScript
import Service, { inject as service } from '@ember/service';
|
|
import lint from 'consul-ui/utils/editor/lint';
|
|
const MODES = [
|
|
{
|
|
name: 'JSON',
|
|
mime: 'application/json',
|
|
mode: 'javascript',
|
|
ext: ['json', 'map'],
|
|
alias: ['json5'],
|
|
},
|
|
{
|
|
name: 'HCL',
|
|
mime: 'text/x-ruby',
|
|
mode: 'ruby',
|
|
ext: ['rb'],
|
|
alias: ['jruby', 'macruby', 'rake', 'rb', 'rbx'],
|
|
},
|
|
{ name: 'YAML', mime: 'text/x-yaml', mode: 'yaml', ext: ['yaml', 'yml'], alias: ['yml'] },
|
|
{
|
|
name: 'XML',
|
|
mime: 'application/xml',
|
|
mode: 'xml',
|
|
htmlMode: false,
|
|
matchClosing: true,
|
|
alignCDATA: false,
|
|
ext: ['xml'],
|
|
alias: ['xml'],
|
|
},
|
|
];
|
|
|
|
export default class LinterService extends Service {
|
|
@service('dom')
|
|
dom;
|
|
|
|
modes() {
|
|
return MODES;
|
|
}
|
|
|
|
lint() {
|
|
return lint(...arguments);
|
|
}
|
|
|
|
getEditor(element) {
|
|
return this.dom.element('textarea + div', element).CodeMirror;
|
|
}
|
|
}
|