2014-03-11 11:23:32 -05:00
|
|
|
import AuthenticatedRoute from 'ghost/routes/authenticated';
|
2014-06-19 14:44:44 -05:00
|
|
|
import base from 'ghost/mixins/editor-route-base';
|
2014-05-09 00:00:10 -05:00
|
|
|
|
2014-06-19 14:44:44 -05:00
|
|
|
var EditorEditRoute = AuthenticatedRoute.extend(base, {
|
2014-03-03 15:18:10 -05:00
|
|
|
classNames: ['editor'],
|
2014-06-08 01:02:21 -05:00
|
|
|
|
2014-03-02 09:30:35 -05:00
|
|
|
model: function (params) {
|
2014-06-08 19:18:39 -05:00
|
|
|
var self = this,
|
|
|
|
post,
|
|
|
|
postId;
|
2014-06-05 20:18:03 -05:00
|
|
|
|
2014-06-08 19:18:39 -05:00
|
|
|
postId = Number(params.post_id);
|
|
|
|
|
|
|
|
if (!Number.isInteger(postId) || !Number.isFinite(postId) || postId <= 0) {
|
2014-06-23 18:52:10 -05:00
|
|
|
this.transitionTo('error404', 'editor/' + params.post_id);
|
2014-06-08 19:18:39 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
post = this.store.getById('post', postId);
|
2014-06-05 12:23:28 -05:00
|
|
|
|
|
|
|
if (post) {
|
|
|
|
return post;
|
|
|
|
}
|
|
|
|
|
2014-06-17 14:17:08 -05:00
|
|
|
return this.store.find('post', {
|
|
|
|
id: params.post_id,
|
|
|
|
status: 'all',
|
2014-06-26 21:35:25 -05:00
|
|
|
staticPages: 'all',
|
|
|
|
include: 'tags'
|
2014-06-05 12:23:28 -05:00
|
|
|
}).then(function (records) {
|
2014-06-08 19:18:39 -05:00
|
|
|
var post = records.get('firstObject');
|
|
|
|
|
|
|
|
if (post) {
|
|
|
|
return post;
|
|
|
|
}
|
|
|
|
|
|
|
|
return self.transitionTo('posts.index');
|
2014-06-05 12:23:28 -05:00
|
|
|
});
|
2014-06-09 23:44:29 -05:00
|
|
|
},
|
2014-06-05 20:18:03 -05:00
|
|
|
|
2014-06-09 23:44:29 -05:00
|
|
|
serialize: function (model) {
|
|
|
|
return {post_id: model.get('id')};
|
2014-06-05 20:18:03 -05:00
|
|
|
},
|
|
|
|
|
|
|
|
setupController: function (controller, model) {
|
|
|
|
this._super(controller, model);
|
|
|
|
controller.set('scratch', model.get('markdown'));
|
2014-06-26 21:35:25 -05:00
|
|
|
// used to check if anything has changed in the editor
|
|
|
|
controller.set('previousTagNames', model.get('tags').mapBy('name'));
|
2014-06-05 20:18:03 -05:00
|
|
|
},
|
|
|
|
|
|
|
|
actions: {
|
|
|
|
willTransition: function (transition) {
|
|
|
|
var controller = this.get('controller'),
|
|
|
|
isDirty = controller.get('isDirty'),
|
|
|
|
|
|
|
|
model = controller.get('model'),
|
|
|
|
isSaving = model.get('isSaving'),
|
2014-06-19 13:31:56 -05:00
|
|
|
isDeleted = model.get('isDeleted'),
|
|
|
|
modelIsDirty = model.get('isDirty');
|
2014-06-05 20:18:03 -05:00
|
|
|
|
|
|
|
// when `isDeleted && isSaving`, model is in-flight, being saved
|
2014-06-19 13:31:56 -05:00
|
|
|
// to the server. when `isDeleted && !isSaving && !modelIsDirty`,
|
|
|
|
// the record has already been deleted and the deletion persisted.
|
|
|
|
//
|
|
|
|
// in either case we can probably just transition now.
|
|
|
|
// in the former case the server will return the record, thereby updating it.
|
|
|
|
// @TODO: this will break if the model fails server-side validation.
|
|
|
|
if (!(isDeleted && isSaving) && !(isDeleted && !isSaving && !modelIsDirty) && isDirty) {
|
2014-06-05 20:18:03 -05:00
|
|
|
transition.abort();
|
|
|
|
this.send('openModal', 'leave-editor', [controller, transition]);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// since the transition is now certain to complete..
|
|
|
|
window.onbeforeunload = null;
|
|
|
|
}
|
2014-03-02 09:30:35 -05:00
|
|
|
}
|
2014-03-03 15:18:10 -05:00
|
|
|
});
|
|
|
|
|
2014-06-09 23:44:29 -05:00
|
|
|
export default EditorEditRoute;
|