Ghost/core/client/routes/posts/index.js
Robert Jackson 188265115a
Handle toggleing the content screen on mobile.
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.
2014-08-01 02:47:29 -04:00

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;