ui/app/components/modal-edit-setting/component.js

48 lines
1.2 KiB
JavaScript

import Ember from 'ember';
import { normalizeName } from 'ui/services/settings';
import ModalBase from 'ui/mixins/modal-base';
export default Ember.Component.extend(ModalBase, {
settings: Ember.inject.service(),
growl: Ember.inject.service(),
classNames: ['span-8', 'offset-2'],
model: Ember.computed.alias('modalService.modalOpts'),
value: null,
removing: false,
init() {
this._super(...arguments);
this.set('value', this.get('model.obj.value')||'');
},
actions: {
save(btnCb) {
this.get('settings').set(normalizeName(this.get('model.key')), this.get('value'));
this.get('settings').one('settingsPromisesResolved', () => {
btnCb(true);
this.send('done');
});
},
remove() {
this.set('removing',true);
let key = this.get('model.key');
this.get('model.obj').delete({forceRemove: true}).then(() => {
this.get('settings').load([key]).then(() => {
this.send('done');
});
}).catch((err) => {
this.get('growl').fromError(err);
}).finally(() => {
this.set('removing', false);
});
},
done() {
this.send('cancel');
}
},
});