123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111 |
- let slug = require('slug')
- module.exports = (sequelize, DataTypes) => {
- let Thread = sequelize.define('Thread', {
- name: {
- type: DataTypes.TEXT,
- set (val) {
- this.setDataValue('name', val)
- this.setDataValue('slug', slug(val).toLowerCase())
- }
- },
- slug: DataTypes.TEXT,
- postsCount: {
- type: DataTypes.INTEGER,
- defaultValue: 0
- },
- locked: {
- type: DataTypes.BOOLEAN,
- defaultValue: false
- }
- }, {
- instanceMethods: {
- async getMeta (limit) {
- let meta = {}
-
- let posts = this.Posts
- let firstPost = posts[0]
- let lastPost = posts.slice(-1)[0]
- //next url
- if(!lastPost || lastPost.postNumber+1 === this.postsCount) {
- meta.nextURL = null
- } else {
- meta.nextURL =
- `/api/v1/thread/${this.id}?limit=${limit}&from=${lastPost.postNumber + 1}`
- }
- //previous url
- if(!firstPost || firstPost.postNumber === 0) {
- meta.previousURL = null
- } else if(firstPost.postNumber - limit < 0) {
- meta.previousURL =
- `/api/v1/thread/${this.id}?limit=${firstPost.postNumber}&from=0`
- } else {
- meta.previousURL =
- `/api/v1/thread/${this.id}?limit=${limit}&from=${firstPost.postNumber - limit}`
- }
- //remaining posts
- if(lastPost === undefined) {
- meta.nextPostsCount = 0
- meta.previousPostsCount = 0
- meta.postsRemaining = 0
- } else {
- let postsRemaining =
- this.postsCount - lastPost.postNumber - 1
- meta.postsRemaining = postsRemaining
- if(postsRemaining < limit) {
- meta.nextPostsCount = postsRemaining
- } else {
- meta.nextPostsCount = limit
- }
- if(firstPost.postNumber === 0) {
- meta.previousPostsCount = 0
- } else if(firstPost.postNumber - limit < 0) {
- meta.previousPostsCount = firstPost.postNumber
- } else {
- meta.previousPostsCount = limit
- }
- }
- return meta
- }
- },
- classMethods: {
- associate (models) {
- Thread.belongsTo(models.User)
- Thread.belongsTo(models.Category)
- Thread.hasMany(models.Post)
- },
- includeOptions (from, limit) {
- let models = sequelize.models
- return [
- { model: models.User, attributes: ['username', 'createdAt', 'color', 'updatedAt', 'id'] },
- models.Category,
- {
- model: models.Post,
- where: { postNumber: { $gte: from } },
- order: [['id', 'ASC']],
- limit,
- include: [
- { model: models.Thread, attributes: ['slug'] },
- { model: models.User, as: 'Likes', attributes: ['username', 'createdAt', 'id', 'color'] },
- { model: models.User, attributes: ['username', 'createdAt', 'id', 'color'] },
- {
- model: models.Post, as: 'Replies', include:
- [{ model: models.User, attributes: ['username', 'id', 'color'] }]
- }
- ]
- }
- ]
- }
- }
- })
- return Thread
- }
|