mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-13 22:41:32 -05:00
f6dd851ffb
fixes #3013 - bubble promise rejection on post model validation/save error so that it doesn't bubble as resolved - prefer `.catch()` for promise handlers as per recommendations - check if `.save()` is being called from model.destroyRecord() and forgo validation if so - normalize output for both `.validate()` and `.save()`
59 lines
1.7 KiB
JavaScript
59 lines
1.7 KiB
JavaScript
var LeaveEditorController = Ember.Controller.extend({
|
|
args: Ember.computed.alias('model'),
|
|
|
|
actions: {
|
|
confirmAccept: function () {
|
|
var args = this.get('args'),
|
|
editorController,
|
|
model,
|
|
transition;
|
|
|
|
if (Ember.isArray(args)) {
|
|
editorController = args[0];
|
|
transition = args[1];
|
|
model = editorController.get('model');
|
|
}
|
|
|
|
if (!transition || !editorController) {
|
|
this.notifications.showError('Sorry, there was an error in the application. Please let the Ghost team know what happened.');
|
|
return true;
|
|
}
|
|
|
|
// definitely want to clear the data store and post of any unsaved, client-generated tags
|
|
model.updateTags();
|
|
|
|
if (model.get('isNew')) {
|
|
// the user doesn't want to save the new, unsaved post, so delete it.
|
|
model.deleteRecord();
|
|
} else {
|
|
// roll back changes on model props
|
|
model.rollback();
|
|
}
|
|
|
|
// setting isDirty to false here allows willTransition on the editor route to succeed
|
|
editorController.set('isDirty', false);
|
|
|
|
// since the transition is now certain to complete, we can unset window.onbeforeunload here
|
|
window.onbeforeunload = null;
|
|
|
|
transition.retry();
|
|
},
|
|
|
|
confirmReject: function () {
|
|
|
|
}
|
|
},
|
|
|
|
confirm: {
|
|
accept: {
|
|
text: 'Leave',
|
|
buttonClass: 'button-delete'
|
|
},
|
|
reject: {
|
|
text: 'Cancel',
|
|
buttonClass: 'button'
|
|
}
|
|
}
|
|
});
|
|
|
|
export default LeaveEditorController;
|