mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-04 08:54:36 +03:00
49 lines
1.2 KiB
JavaScript
49 lines
1.2 KiB
JavaScript
|
/* global CodeMirror */
|
||
|
import Ember from 'ember';
|
||
|
|
||
|
var CodeMirrorEditor = Ember.Component.extend({
|
||
|
|
||
|
// DOM stuff
|
||
|
classNameBindings: ['isFocused:focused'],
|
||
|
isFocused: false,
|
||
|
|
||
|
value: '', // make sure a value exists
|
||
|
editor: null, // reference to CodeMirror editor
|
||
|
|
||
|
// options for the editor
|
||
|
lineNumbers: true,
|
||
|
indentUnit: 4,
|
||
|
mode: 'htmlmixed',
|
||
|
theme: 'xq-light',
|
||
|
|
||
|
didInsertElement: function () {
|
||
|
var options = this.getProperties('lineNumbers', 'indentUnit', 'mode', 'theme'),
|
||
|
self = this,
|
||
|
editor;
|
||
|
editor = new CodeMirror(this.get('element'), options);
|
||
|
editor.getDoc().setValue(this.get('value'));
|
||
|
|
||
|
// events
|
||
|
editor.on('focus', function () {
|
||
|
self.set('isFocused', true);
|
||
|
});
|
||
|
editor.on('blur', function () {
|
||
|
self.set('isFocused', false);
|
||
|
});
|
||
|
editor.on('change', function () {
|
||
|
self.set('value', editor.getDoc().getValue());
|
||
|
});
|
||
|
|
||
|
this.set('editor', editor);
|
||
|
},
|
||
|
|
||
|
willDestroyElement: function () {
|
||
|
var editor = this.get('editor').getWrapperElement();
|
||
|
editor.parentNode.removeChild(editor);
|
||
|
this.set('editor', null);
|
||
|
}
|
||
|
|
||
|
});
|
||
|
|
||
|
export default CodeMirrorEditor;
|