const { DataTypes, Model } = require('sequelize')

class CollectionBook extends Model {
  constructor(values, options) {
    super(values, options)

    /** @type {UUIDV4} */
    this.id
    /** @type {number} */
    this.order
    /** @type {UUIDV4} */
    this.bookId
    /** @type {UUIDV4} */
    this.collectionId
    /** @type {Date} */
    this.createdAt
  }

  static removeByIds(collectionId, bookId) {
    return this.destroy({
      where: {
        bookId,
        collectionId
      }
    })
  }

  static init(sequelize) {
    super.init({
      id: {
        type: DataTypes.UUID,
        defaultValue: DataTypes.UUIDV4,
        primaryKey: true
      },
      order: DataTypes.INTEGER
    }, {
      sequelize,
      timestamps: true,
      updatedAt: false,
      modelName: 'collectionBook'
    })

    // Super Many-to-Many
    // ref: https://sequelize.org/docs/v6/advanced-association-concepts/advanced-many-to-many/#the-best-of-both-worlds-the-super-many-to-many-relationship
    const { book, collection } = sequelize.models
    book.belongsToMany(collection, { through: CollectionBook })
    collection.belongsToMany(book, { through: CollectionBook })

    book.hasMany(CollectionBook, {
      onDelete: 'CASCADE'
    })
    CollectionBook.belongsTo(book)

    collection.hasMany(CollectionBook, {
      onDelete: 'CASCADE'
    })
    CollectionBook.belongsTo(collection)
  }
}

module.exports = CollectionBook