import { DataTypes, InferAttributes, InferCreationAttributes, Model, Op, Sequelize, } from "sequelize"; import { Quote_Model } from "./quote.model"; export enum DEALER_STATUS { STATUS_ACTIVE = "active", STATUS_BLOCKED = "blocked", } export type DealerCreationAttributes = InferCreationAttributes; export class Dealer_Model extends Model< InferAttributes, InferCreationAttributes > { // To avoid table creation /*static async sync(): Promise { return Promise.resolve(); }*/ // eslint-disable-next-line @typescript-eslint/no-unused-vars static associate(connection: Sequelize) { const { Dealer_Model, User_Model } = connection.models; Dealer_Model.hasMany(User_Model, { as: "users", foreignKey: "dealer_id", onDelete: "RESTRICT", }); Dealer_Model.hasMany(Quote_Model, { as: "quotes", foreignKey: "dealer_id", onDelete: "RESTRICT", }); } declare id: string; declare id_contact?: string; // number ?? declare name: string; declare contact_information: string; declare default_payment_method: string; declare default_notes: string; declare default_legal_terms: string; declare default_quote_validity: string; declare status: DEALER_STATUS; declare language: string; } export default (sequelize: Sequelize) => { Dealer_Model.init( { id: { type: new DataTypes.UUID(), primaryKey: true, }, id_contact: { type: DataTypes.BIGINT().UNSIGNED, allowNull: true, }, name: { type: DataTypes.STRING, allowNull: false, }, contact_information: DataTypes.STRING, default_payment_method: DataTypes.STRING, default_notes: DataTypes.STRING, default_legal_terms: DataTypes.STRING, default_quote_validity: DataTypes.STRING, language: DataTypes.STRING, status: { type: DataTypes.ENUM(...Object.values(DEALER_STATUS)), allowNull: false, }, }, { sequelize, tableName: "dealers", paranoid: true, // softs deletes timestamps: true, //version: true, createdAt: "created_at", updatedAt: "updated_at", deletedAt: "deleted_at", indexes: [ { name: "id_contact_idx", fields: ["id_contact"] }, { name: "status_idx", fields: ["status"] }, ], whereMergeStrategy: "and", // <- cómo tratar el merge de un scope scopes: { quickSearch(value) { return { where: { [Op.or]: { name: { [Op.like]: `%${value}%`, }, }, }, }; }, }, } ); return Dealer_Model; };