mirror of
https://github.com/vale981/Vulcan
synced 2025-03-06 18:11:40 -05:00
better syntax for subs parameters
This commit is contained in:
parent
91579b38c5
commit
6ba2799167
2 changed files with 45 additions and 67 deletions
|
@ -212,77 +212,44 @@ Router.after(filters.resetScroll, {except:['posts_top', 'posts_new', 'posts_best
|
|||
//--------------------------------------------------------------------------------------------------//
|
||||
|
||||
getParameters = function (view, limit, category) {
|
||||
// TODO: streamline syntax to get a base object that gets extended for each view
|
||||
var allParameters = {
|
||||
top: {
|
||||
find: {
|
||||
status: 2
|
||||
},
|
||||
options: {
|
||||
sort: {
|
||||
sticky: -1,
|
||||
score: -1,
|
||||
_id: -1
|
||||
},
|
||||
limit: 10
|
||||
}
|
||||
|
||||
var baseParameters = {
|
||||
find: {
|
||||
status: 2
|
||||
},
|
||||
new: {
|
||||
find: {
|
||||
status: 2
|
||||
},
|
||||
options: {
|
||||
sort: {
|
||||
sticky: -1,
|
||||
submitted: -1,
|
||||
_id: -1
|
||||
},
|
||||
limit: 10
|
||||
}
|
||||
},
|
||||
best: {
|
||||
find: {
|
||||
status: 2
|
||||
},
|
||||
options: {
|
||||
sort: {
|
||||
sticky: -1,
|
||||
baseScore: -1,
|
||||
createdAt: -1,
|
||||
_id: -1
|
||||
},
|
||||
limit: 10
|
||||
}
|
||||
},
|
||||
pending: {
|
||||
find: {
|
||||
status: 1
|
||||
},
|
||||
options: {
|
||||
sort: {
|
||||
sticky: -1,
|
||||
createdAt: -1,
|
||||
_id: -1
|
||||
},
|
||||
limit: 10
|
||||
}
|
||||
},
|
||||
category: {
|
||||
find: {
|
||||
status: 2
|
||||
},
|
||||
options: {
|
||||
sort: {
|
||||
sticky: -1,
|
||||
score: -1,
|
||||
_id: -1
|
||||
},
|
||||
limit: 10
|
||||
}
|
||||
options: {
|
||||
limit: 10
|
||||
}
|
||||
}
|
||||
|
||||
var parameters = allParameters[view];
|
||||
// TODO: find a way to guarantee order of parameters, or else switch back to old syntax
|
||||
|
||||
switch (view) {
|
||||
|
||||
case 'top':
|
||||
var parameters = $.extend(true, baseParameters, {options: {sort: {sticky: -1, score: -1}}});
|
||||
break;
|
||||
|
||||
case 'new':
|
||||
var parameters = $.extend(true, baseParameters, {options: {sort: {sticky: -1, submitted: -1}}});
|
||||
break;
|
||||
|
||||
case 'best':
|
||||
var parameters = $.extend(true, baseParameters, {options: {sort: {sticky: -1, baseScore: -1}}});
|
||||
break;
|
||||
|
||||
case 'pending':
|
||||
var parameters = $.extend(true, baseParameters, {find: {status: 1}, options: {sort: {baseScore: -1}}});
|
||||
break;
|
||||
|
||||
case 'category': // same as top for now
|
||||
var parameters = $.extend(true, baseParameters, {options: {sort: {sticky: -1, score: -1}}});
|
||||
break;
|
||||
|
||||
}
|
||||
|
||||
// sort by _id to break ties
|
||||
$.extend(true, parameters, {options: {sort: {_id: -1}}})
|
||||
|
||||
if(typeof limit != 'undefined')
|
||||
_.extend(parameters.options, {limit: parseInt(limit)});
|
||||
|
@ -290,6 +257,8 @@ getParameters = function (view, limit, category) {
|
|||
if(typeof category != 'undefined')
|
||||
_.extend(parameters.find, {'categories.slug': category});
|
||||
|
||||
// console.log(parameters.options.sort)
|
||||
|
||||
return parameters;
|
||||
}
|
||||
|
||||
|
|
|
@ -65,6 +65,15 @@ Meteor.publish('postsList', function(find, options) {
|
|||
if(canViewById(this.userId)){
|
||||
options = options || {};
|
||||
var posts = Posts.find(find, options);
|
||||
|
||||
// console.log('//-------- Subscription Parameters:');
|
||||
// console.log(find);
|
||||
// console.log(options);
|
||||
// console.log('Found '+posts.fetch().length+ ' posts:');
|
||||
// posts.rewind();
|
||||
// console.log(_.pluck(posts.fetch(), 'headline'));
|
||||
// posts.rewind();
|
||||
|
||||
return posts;
|
||||
}
|
||||
});
|
||||
|
|
Loading…
Add table
Reference in a new issue