Skip to content

pareapp/mongoose-aggregate-paginate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mongoose-aggregate-paginate

mongoose-aggregate-paginate is a Mongoose plugin easy to add pagination for aggregates. This plugin can be used in combination with view pagination middleware such as express-paginate.

Build Status npm version Dependency Status Test Coverage js-standard-style

NPM

Index

Install

npm install mongoose-aggregate-paginate --save

Usage

This 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()).

MyModel.aggregatePaginate(aggregate, options, callback)

Arguments

  • aggregate - An object of the Mongoose aggregate.
  • options - An object with options for the Mongoose query, such as sorting
    • page - Default: 1
    • limit - Default: 10
    • sortBy - 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)
  })

Tests

npm test

Acknowledgements

mongoose-aggregate-paginate was inspired by mongoose-paginate.

License

MIT

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published