Skip to content

Commit

Permalink
Fixed the totalDocs counting issue with populate and collation.
Browse files Browse the repository at this point in the history
  • Loading branch information
aravindnc committed Oct 17, 2019
1 parent 05a8a98 commit 21dba19
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 7 deletions.
6 changes: 3 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
{
"name": "mongoose-paginate-v2",
"version": "1.3.1",
"version": "1.3.2",
"description": "A cursor based custom pagination library for Mongoose with customizable labels.",
"main": "dist/index.js",
"scripts": {
"pretest": "npm run build",
"test": "./node_modules/.bin/mocha tests/*.js -R spec --ui bdd --timeout 5000",
"test": "./node_modules/.bin/mocha tests/*.js -R spec --ui bdd --timeout 9999999",
"build": "babel src -d dist",
"prepublish": "npm run test"
},
Expand Down Expand Up @@ -65,4 +65,4 @@
"engines": {
"node": ">=4.0.0"
}
}
}
20 changes: 16 additions & 4 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,19 @@ function paginate(query, options, callback) {
}

// const countPromise = this.countDocuments(query).exec();
const countPromise = this.find(query).exec();
// const countPromise = this.find(query).exec();

const countQuery = this.find(query);
if (populate) {
countQuery.populate(populate);
}

// Hack for mongo < v3.4
if (Object.keys(collation).length > 0) {
countQuery.collation(collation);
}

const countPromise = countQuery.exec();

if (limit) {
const mQuery = this.find(query, projection, findOptions);
Expand All @@ -115,12 +127,12 @@ function paginate(query, options, callback) {
mQuery.collation(collation);
}

mQuery.skip(skip);
mQuery.limit(limit);

if (populate) {
mQuery.populate(populate);
}

mQuery.skip(skip);
mQuery.limit(limit);

docsPromise = mQuery.exec();

Expand Down

0 comments on commit 21dba19

Please sign in to comment.