2017-03-17 20:16:21 +03:00
|
|
|
import Ember from 'ember';
|
|
|
|
import RSVP from 'rsvp';
|
2017-10-30 12:38:01 +03:00
|
|
|
import Service, {inject as service} from '@ember/service';
|
2017-03-17 20:16:21 +03:00
|
|
|
import ValidationEngine from 'ghost-admin/mixins/validation-engine';
|
2022-02-03 01:11:11 +03:00
|
|
|
import classic from 'ember-classic-decorator';
|
2017-08-22 10:53:26 +03:00
|
|
|
import {get} from '@ember/object';
|
2017-03-17 20:16:21 +03:00
|
|
|
|
|
|
|
// ember-cli-shims doesn't export _ProxyMixin
|
|
|
|
const {_ProxyMixin} = Ember;
|
|
|
|
|
2022-02-03 01:11:11 +03:00
|
|
|
@classic
|
|
|
|
export default class SettingsService extends Service.extend(_ProxyMixin, ValidationEngine) {
|
2022-02-03 22:04:43 +03:00
|
|
|
@service store;
|
2017-03-17 20:16:21 +03:00
|
|
|
|
|
|
|
// will be set to the single Settings model, it's a reference so any later
|
|
|
|
// changes to the settings object in the store will be reflected
|
2022-02-03 01:11:11 +03:00
|
|
|
content = null;
|
2017-03-17 20:16:21 +03:00
|
|
|
|
2022-02-03 01:11:11 +03:00
|
|
|
validationType = 'setting';
|
|
|
|
_loadingPromise = null;
|
2017-03-17 20:16:21 +03:00
|
|
|
|
2017-04-19 19:57:56 +03:00
|
|
|
// this is an odd case where we only want to react to changes that we get
|
|
|
|
// back from the API rather than local updates
|
2022-02-03 01:11:11 +03:00
|
|
|
settledIcon = '';
|
2017-04-19 19:57:56 +03:00
|
|
|
|
2017-03-17 20:16:21 +03:00
|
|
|
// the settings API endpoint is a little weird as it's singular and we have
|
|
|
|
// to pass in all types - if we ever fetch settings without all types then
|
|
|
|
// save we have problems with the missing settings being removed or reset
|
|
|
|
_loadSettings() {
|
|
|
|
if (!this._loadingPromise) {
|
2019-03-06 16:53:54 +03:00
|
|
|
this._loadingPromise = this.store
|
2022-07-06 12:01:57 +03:00
|
|
|
.queryRecord('setting', {group: 'site,theme,private,members,portal,newsletter,email,amp,labs,slack,unsplash,views,firstpromoter,editor,comments'})
|
2017-03-17 20:16:21 +03:00
|
|
|
.then((settings) => {
|
|
|
|
this._loadingPromise = null;
|
|
|
|
return settings;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return this._loadingPromise;
|
2022-02-03 01:11:11 +03:00
|
|
|
}
|
2017-03-17 20:16:21 +03:00
|
|
|
|
|
|
|
fetch() {
|
2019-03-06 16:53:54 +03:00
|
|
|
if (!this.content) {
|
2017-03-17 20:16:21 +03:00
|
|
|
return this.reload();
|
|
|
|
} else {
|
|
|
|
return RSVP.resolve(this);
|
|
|
|
}
|
2022-02-03 01:11:11 +03:00
|
|
|
}
|
2017-03-17 20:16:21 +03:00
|
|
|
|
|
|
|
reload() {
|
|
|
|
return this._loadSettings().then((settings) => {
|
|
|
|
this.set('content', settings);
|
2017-04-19 19:57:56 +03:00
|
|
|
this.set('settledIcon', get(settings, 'icon'));
|
2017-03-17 20:16:21 +03:00
|
|
|
return this;
|
|
|
|
});
|
2022-02-03 01:11:11 +03:00
|
|
|
}
|
2017-03-17 20:16:21 +03:00
|
|
|
|
2020-06-04 23:30:06 +03:00
|
|
|
async save() {
|
2019-03-06 16:53:54 +03:00
|
|
|
let settings = this.content;
|
2017-03-17 20:16:21 +03:00
|
|
|
|
|
|
|
if (!settings) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-06-04 23:30:06 +03:00
|
|
|
await settings.save();
|
2022-10-04 19:32:49 +03:00
|
|
|
await this.validate();
|
2020-06-04 23:30:06 +03:00
|
|
|
this.set('settledIcon', settings.icon);
|
|
|
|
return settings;
|
2022-02-03 01:11:11 +03:00
|
|
|
}
|
2017-03-17 20:16:21 +03:00
|
|
|
|
|
|
|
rollbackAttributes() {
|
2021-01-20 01:31:59 +03:00
|
|
|
return this.content?.rollbackAttributes();
|
2022-02-03 01:11:11 +03:00
|
|
|
}
|
2020-02-24 12:08:47 +03:00
|
|
|
|
2018-03-09 17:42:27 +03:00
|
|
|
changedAttributes() {
|
2021-01-20 01:31:59 +03:00
|
|
|
return this.content?.changedAttributes();
|
2017-03-17 20:16:21 +03:00
|
|
|
}
|
2022-02-03 01:11:11 +03:00
|
|
|
}
|