mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-11-29 07:09:48 +03:00
9adbcd1fd0
no issue Automated tools, code generators, and editor integrations are increasingly standardising on the import style used in `ember-modules-codemod`. Our import style differed a little with regards to service/controller injection imports which meant we were starting to see inconsistent naming.
106 lines
3.0 KiB
JavaScript
106 lines
3.0 KiB
JavaScript
import Ember from 'ember';
|
|
import EmberError from '@ember/error';
|
|
import RSVP from 'rsvp';
|
|
import Service, {inject as service} from '@ember/service';
|
|
import {computed} from '@ember/object';
|
|
import {set} from '@ember/object';
|
|
|
|
export function feature(name, user = false) {
|
|
let watchedProps = user ? [`accessibility.${name}`] : [`config.${name}`, `labs.${name}`];
|
|
|
|
return computed.apply(Ember, watchedProps.concat({
|
|
get() {
|
|
if (user) {
|
|
return this.get(`accessibility.${name}`);
|
|
}
|
|
|
|
if (this.get(`config.${name}`)) {
|
|
return this.get(`config.${name}`);
|
|
}
|
|
|
|
return this.get(`labs.${name}`) || false;
|
|
},
|
|
set(key, value) {
|
|
this.update(key, value, user);
|
|
return value;
|
|
}
|
|
}));
|
|
}
|
|
|
|
export default Service.extend({
|
|
store: service(),
|
|
config: service(),
|
|
session: service(),
|
|
settings: service(),
|
|
notifications: service(),
|
|
|
|
publicAPI: feature('publicAPI'),
|
|
subscribers: feature('subscribers'),
|
|
nightShift: feature('nightShift', true),
|
|
|
|
_user: null,
|
|
|
|
labs: computed('settings.labs', function () {
|
|
let labs = this.get('settings.labs');
|
|
|
|
try {
|
|
return JSON.parse(labs) || {};
|
|
} catch (e) {
|
|
return {};
|
|
}
|
|
}),
|
|
|
|
accessibility: computed('_user.accessibility', function () {
|
|
let accessibility = this.get('_user.accessibility');
|
|
|
|
try {
|
|
return JSON.parse(accessibility) || {};
|
|
} catch (e) {
|
|
return {};
|
|
}
|
|
}),
|
|
|
|
fetch() {
|
|
return RSVP.hash({
|
|
settings: this.get('settings').fetch(),
|
|
user: this.get('session.user')
|
|
}).then(({user}) => {
|
|
this.set('_user', user);
|
|
|
|
return true;
|
|
});
|
|
},
|
|
|
|
update(key, value, user = false) {
|
|
let serviceProperty = user ? 'accessibility' : 'labs';
|
|
let model = this.get(user ? '_user' : 'settings');
|
|
let featureObject = this.get(serviceProperty);
|
|
|
|
// set the new key value for either the labs property or the accessibility property
|
|
set(featureObject, key, value);
|
|
|
|
// update the 'labs' or 'accessibility' key of the model
|
|
model.set(serviceProperty, JSON.stringify(featureObject));
|
|
|
|
return model.save().then(() => {
|
|
// return the labs key value that we get from the server
|
|
this.notifyPropertyChange(serviceProperty);
|
|
return this.get(`${serviceProperty}.${key}`);
|
|
|
|
}).catch((error) => {
|
|
model.rollbackAttributes();
|
|
this.notifyPropertyChange(serviceProperty);
|
|
|
|
// we'll always have an errors object unless we hit a
|
|
// validation error
|
|
if (!error) {
|
|
throw new EmberError(`Validation of the feature service ${user ? 'user' : 'settings'} model failed when updating ${serviceProperty}.`);
|
|
}
|
|
|
|
this.get('notifications').showAPIError(error);
|
|
|
|
return this.get(`${serviceProperty}.${key}`);
|
|
});
|
|
}
|
|
});
|