pagination.js 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. async function getNextId(Model, where, items) {
  2. try {
  3. let maxId = await Model.max('id', { where })
  4. let lastItem = items.slice(-1)[0]
  5. if(!lastItem || maxId === lastItem.id) {
  6. return null
  7. } else {
  8. return lastItem.id
  9. }
  10. } catch (e) {
  11. console.log(e)
  12. return null
  13. }
  14. }
  15. async function getNextIdDesc(Model, where, items) {
  16. try {
  17. let minId = await Model.min('id', { where })
  18. let lastItem = items.slice(-1)[0]
  19. if(!lastItem || minId === lastItem.id) {
  20. return null
  21. } else {
  22. return lastItem.id
  23. }
  24. } catch (e) {
  25. console.log(e)
  26. return null
  27. }
  28. }
  29. async function getNextCount (Model, items, limit, where, desc) {
  30. let lastItem
  31. if(Array.isArray(items)) {
  32. lastItem = items.slice(-1)[0]
  33. } else {
  34. lastItem = items
  35. }
  36. if(desc) {
  37. where.id = { $lt: lastItem.id }
  38. } else {
  39. where.id = { $gt: lastItem.id }
  40. }
  41. let remaining = await Model.count({ where })
  42. if(remaining - limit < 0) {
  43. return remaining
  44. } else {
  45. return limit
  46. }
  47. }
  48. function getPaginationProps(query, desc) {
  49. let from = 0
  50. let limit = 10
  51. if(desc) {
  52. from = null
  53. }
  54. if(+query.from > 0) from = +query.from
  55. if(+query.limit > 0) limit = +query.limit
  56. if(+query.postNumber > 0) {
  57. let lowerFrom = +query.postNumber - Math.floor(limit / 2) + 1
  58. if(lowerFrom < 0) {
  59. from = 0
  60. } else {
  61. from = lowerFrom
  62. }
  63. }
  64. return { from, limit }
  65. }
  66. module.exports = {
  67. getNextId,
  68. getNextIdDesc,
  69. getNextCount,
  70. getPaginationProps
  71. }