mongoose-aggregate-paginateis a Mongoose plugin easy to add pagination for aggregates. This plugin can be used in combination with view pagination middleware such as express-paginate.
npm install mongoose-aggregate-paginate --saveThis plugin must first be added to a schema:
var mongooseAggregatePaginate = require('mongoose-aggregate-paginate');
mySchema.plugin(mongooseAggregatePaginate);MyModel will have a new function called paginate (e.g. MyModel.aggregatePaginate()).
Arguments
aggregate- An object of the Mongoose aggregate.options- An object with options for the Mongoose query, such as sortingpage- Default:1limit- Default:10sortBy- Default:undefined
callback(err, results, pageCount, itemCount)- A callback is called once pagination results are retrieved, or an error has occurred. If not specified promise will be returned
Returns
Promise- Promise object
Examples
var MyModel = mongoose.model('MyModel',{
name : String,
age: Number,
city, String
})
// find users above 18 by city
var aggregate = MyModel.aggregate();
aggregate.match({age : {'lt' : 18 } })
.group({ _id: '$city' , count : { '$sum' : 1 } })
var options = { page : 1, limit : 15}
// callback
MyModel.aggregatePaginate(aggregate, options, function(err, results, pageCount, count) {
if(err)
{
console.err(err)
}
else
{
console.log(results)
}
})
// Promise
MyModel.aggregatePaginate(aggregate, options)
.then(function(value) {
console.log(value.data, value.pageCount, value.totalCount)
})
.catch(function(err){
console.err(err)
})npm testmongoose-aggregate-paginate was inspired by mongoose-paginate.
