mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-28 05:14:12 +03:00
9912c2bfed
Closes #3520. Move the custom jQuery animation into an action on the controller so that we can trigger it from within the route if needed.
39 lines
1.5 KiB
JavaScript
39 lines
1.5 KiB
JavaScript
import loadingIndicator from 'ghost/mixins/loading-indicator';
|
|
import {mobileQuery} from 'ghost/utils/mobile';
|
|
|
|
var PostsIndexRoute = Ember.Route.extend(SimpleAuth.AuthenticatedRouteMixin, loadingIndicator, {
|
|
// This route's only function is to determine whether or not a post
|
|
// exists to be used for the content preview. It has a parent resource (Posts)
|
|
// that is responsible for populating the store.
|
|
beforeModel: function () {
|
|
var self = this,
|
|
// the store has been populated so we can work with the local copy
|
|
posts = this.store.all('post'),
|
|
currentPost = this.controllerFor('posts').get('currentPost');
|
|
|
|
return this.store.find('user', 'me').then(function (user) {
|
|
// return the first post find that matches the following criteria:
|
|
// * User is an author, and is the author of this post
|
|
// * User has a role other than author
|
|
return posts.find(function (post) {
|
|
if (user.get('isAuthor')) {
|
|
return post.isAuthoredByUser(user);
|
|
} else {
|
|
return true;
|
|
}
|
|
});
|
|
})
|
|
.then(function (post) {
|
|
if (post) {
|
|
if (currentPost === post && mobileQuery.matches) {
|
|
self.controllerFor('posts').send('hideContentPreview');
|
|
}
|
|
|
|
return self.transitionTo('posts.post', post);
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
export default PostsIndexRoute;
|