Ghost/ghost/admin/app/components/modal-delete-post.js
Kevin Ansfield 352c4af1d7 Refactored usage of .get('property') with es5 getters
no issue
- ran [es5-getter-ember-codemod](https://github.com/rondale-sc/es5-getter-ember-codemod)
- [es5 getters RFC](https://github.com/emberjs/rfcs/blob/master/text/0281-es5-getters.md)
- updates the majority of `object.get('property')` with `object.property` with exceptions:
  - `.get('nested.property')` - it's not possible to determine if this is relying on "safe" path chaining for when `nested` doesn't exist
  - `.get('config.x')` and `.get('settings.x')` - both our `config` and `settings` services are proxy objects which do not support es5 getters
- this PR is not exhaustive, there are still a number of places where `.get('service.foo')` and similar could be replaced but it gets us a long way there in a quick and automated fashion
2019-03-06 13:54:14 +00:00

53 lines
1.2 KiB
JavaScript

import ModalComponent from 'ghost-admin/components/modal-base';
import {alias} from '@ember/object/computed';
import {inject as service} from '@ember/service';
import {task} from 'ember-concurrency';
export default ModalComponent.extend({
notifications: service(),
post: alias('model.post'),
onSuccess: alias('model.onSuccess'),
actions: {
confirm() {
this.deletePost.perform();
}
},
_deletePost() {
let post = this.post;
// definitely want to clear the data store and post of any unsaved,
// client-generated tags
post.updateTags();
return post.destroyRecord();
},
_success() {
// clear any previous error messages
this.notifications.closeAlerts('post.delete');
// trigger the success action
if (this.onSuccess) {
this.onSuccess();
}
},
_failure(error) {
this.notifications.showAPIError(error, {key: 'post.delete.failed'});
},
deletePost: task(function* () {
try {
yield this._deletePost();
this._success();
} catch (e) {
this._failure(e);
} finally {
this.send('closeModal');
}
}).drop()
});