2013-04-14 14:51:37 +09:00
|
|
|
// Session variables
|
2012-12-11 10:47:11 +09:00
|
|
|
Session.set('initialLoad', true);
|
2013-04-06 15:17:09 +09:00
|
|
|
Session.set('currentDate', new Date());
|
2013-04-06 16:36:47 +09:00
|
|
|
Session.set('categorySlug', null);
|
2012-12-11 10:47:11 +09:00
|
|
|
|
2013-10-09 22:16:47 +09:00
|
|
|
// Subscriptions
|
|
|
|
|
|
|
|
// note: here we only subscribe to subscriptions that we need to be available all the time.
|
|
|
|
// For subscriptions depending on specific pages, see the router.
|
|
|
|
|
|
|
|
// TODO: add session variable that tracks once all subscriptions here have loaded
|
|
|
|
|
2013-04-14 14:51:37 +09:00
|
|
|
// Settings
|
2012-10-10 07:28:44 +09:00
|
|
|
Meteor.subscribe('settings', function(){
|
2013-10-09 22:16:47 +09:00
|
|
|
// runs once after settings have loaded
|
2012-12-11 10:47:11 +09:00
|
|
|
analyticsInit();
|
2012-11-21 14:31:58 +09:00
|
|
|
Session.set('settingsLoaded',true);
|
2012-10-10 07:28:44 +09:00
|
|
|
});
|
|
|
|
|
2013-04-14 14:51:37 +09:00
|
|
|
// Categories
|
2013-02-18 13:38:15 +09:00
|
|
|
Meteor.subscribe('categories');
|
|
|
|
|
2013-10-09 22:16:47 +09:00
|
|
|
// Current User
|
|
|
|
// we need to subscribe to the currentUser subscription because by default,
|
|
|
|
//Meteor doesn't send all the user properties that we need
|
2012-11-17 13:24:19 +09:00
|
|
|
Meteor.subscribe('currentUser');
|
|
|
|
|
2013-04-14 14:51:37 +09:00
|
|
|
// Notifications - only load if user is logged in
|
2013-02-22 15:41:15 +09:00
|
|
|
if(Meteor.userId() != null){
|
2012-10-10 07:57:34 +09:00
|
|
|
Meteor.subscribe('notifications');
|
2012-10-10 07:28:44 +09:00
|
|
|
}
|
|
|
|
|
2013-04-14 14:51:37 +09:00
|
|
|
// Posts Lists
|
2012-10-24 11:04:42 +09:00
|
|
|
STATUS_PENDING=1;
|
|
|
|
STATUS_APPROVED=2;
|
|
|
|
STATUS_REJECTED=3;
|
2012-11-25 19:10:10 +11:00
|
|
|
|
2013-04-06 15:42:33 +09:00
|
|
|
// put it all together with pagination
|
2013-04-06 15:17:09 +09:00
|
|
|
postListSubscription = function(find, options, per_page) {
|
2013-03-23 16:58:28 +11:00
|
|
|
var handle = Meteor.subscribeWithPagination('paginatedPosts', find, options, per_page);
|
2012-12-13 17:06:13 +11:00
|
|
|
handle.fetch = function() {
|
2013-04-14 13:00:23 +10:00
|
|
|
var ourFind = _.isFunction(find) ? find() : find;
|
|
|
|
return limitDocuments(Posts.find(ourFind, options), handle.loaded());
|
2012-12-13 17:06:13 +11:00
|
|
|
}
|
|
|
|
return handle;
|
2012-10-09 12:02:37 +09:00
|
|
|
}
|
|
|
|
|
2013-04-07 17:40:32 +09:00
|
|
|
// note: the "name" property is for internal debugging purposes only
|
2013-10-12 11:59:34 +09:00
|
|
|
// selectTop = function() {
|
|
|
|
// return selectPosts({name: 'top', status: STATUS_APPROVED, slug: Session.get('categorySlug')});
|
|
|
|
// }
|
|
|
|
// topPostsHandle = postListSubscription(selectTop, sortPosts('score'), 10);
|
2013-04-14 14:51:37 +09:00
|
|
|
|
2013-04-06 17:32:05 +09:00
|
|
|
selectNew = function() {
|
2013-04-06 18:39:01 +11:00
|
|
|
return selectPosts({name: 'new', status: STATUS_APPROVED, slug: Session.get('categorySlug')});
|
2012-12-13 18:12:08 +11:00
|
|
|
}
|
2013-04-14 14:51:37 +09:00
|
|
|
newPostsHandle = postListSubscription(selectNew, sortPosts('submitted'), 10);
|
|
|
|
|
2013-04-06 17:32:05 +09:00
|
|
|
selectBest = function() {
|
2013-04-06 18:39:01 +11:00
|
|
|
return selectPosts({name: 'best', status: STATUS_APPROVED, slug: Session.get('categorySlug')});
|
2013-04-06 15:42:33 +09:00
|
|
|
}
|
2013-04-14 14:51:37 +09:00
|
|
|
bestPostsHandle = postListSubscription(selectBest, sortPosts('baseScore'), 10);
|
|
|
|
|
2013-04-06 17:32:05 +09:00
|
|
|
selectPending = function() {
|
2013-04-06 18:39:01 +11:00
|
|
|
return selectPosts({name: 'pending', status: STATUS_PENDING, slug: Session.get('categorySlug')});
|
2012-12-13 18:12:08 +11:00
|
|
|
}
|
2013-04-06 18:39:01 +11:00
|
|
|
pendingPostsHandle = postListSubscription(selectPending, sortPosts('createdAt'), 10);
|