brouter-web/js/control/Profile.js
Norbert Renner 0c1879856c Add CodeMirror as profile editor
Early integration with no code formatting yet, to support fitting
sidebar to editor content (profile text).
2018-03-09 19:24:19 +01:00

80 lines
2.3 KiB
JavaScript

BR.Profile = L.Evented.extend({
cache: {},
initialize: function () {
var textArea = L.DomUtil.get('profile_upload');
this.editor = CodeMirror.fromTextArea(textArea, {});
L.DomUtil.get('upload').onclick = L.bind(this._upload, this);
L.DomUtil.get('clear').onclick = L.bind(this.clear, this);
this.message = new BR.Message('profile_message', {
alert: true
});
},
clear: function(evt) {
var button = evt.target || evt.srcElement;
evt.preventDefault();
this._setValue("");
this.fire('clear');
button.blur();
},
update: function(options) {
var profileName = options.profile,
profileUrl,
empty = !this.editor.getValue(),
clean = this.editor.isClean();
this.profileName = profileName;
if (profileName && BR.conf.profilesUrl && (empty || clean)) {
if (!(profileName in this.cache)) {
profileUrl = BR.conf.profilesUrl + profileName + '.brf';
BR.Util.get(profileUrl, L.bind(function(err, profileText) {
if (err) {
console.warn('Error getting profile from "' + profileUrl + '": ' + err);
return;
}
this.cache[profileName] = profileText;
// don't set when option has changed while loading
if (!this.profileName || this.profileName === profileName) {
this._setValue(profileText);
}
}, this));
} else {
this._setValue(this.cache[profileName]);
}
}
},
show: function() {
this.editor.refresh();
},
_upload: function(evt) {
var button = evt.target || evt.srcElement,
profile = this.editor.getValue();
this.message.hide();
$(button).button('uploading');
evt.preventDefault();
this.fire('update', {
profileText: profile,
callback: function () {
$(button).button('reset');
$(button).blur();
}
});
},
_setValue: function(profileText) {
this.editor.setValue(profileText);
this.editor.markClean();
}
});