39948-vm/backend/src/db/models/project_element_defaults.ts
2026-07-01 15:45:38 +02:00

108 lines
2.5 KiB
TypeScript

import type {
SequelizeModel,
SequelizeModelFactory,
} from '../../types/index.ts';
const defineProjectElementDefaultsModel: SequelizeModelFactory = (
sequelize,
DataTypes,
) => {
const projectElementDefaults: SequelizeModel = sequelize.define(
'project_element_defaults',
{
id: {
type: DataTypes.UUID,
defaultValue: DataTypes.UUIDV4,
primaryKey: true,
},
element_type: {
type: DataTypes.TEXT,
allowNull: false,
validate: {
notEmpty: { msg: 'Element type is required' },
len: {
args: [1, 100],
msg: 'Element type must be between 1 and 100 characters',
},
},
},
name: {
type: DataTypes.TEXT,
validate: {
len: { args: [0, 255], msg: 'Name must be at most 255 characters' },
},
},
sort_order: {
type: DataTypes.INTEGER,
allowNull: false,
defaultValue: 0,
},
settings_json: {
type: DataTypes.TEXT,
allowNull: true,
},
source_element_id: {
type: DataTypes.UUID,
allowNull: true,
},
snapshot_version: {
type: DataTypes.INTEGER,
allowNull: false,
defaultValue: 1,
},
importHash: {
type: DataTypes.STRING(255),
allowNull: true,
unique: true,
},
},
{
timestamps: true,
paranoid: true,
freezeTableName: true,
indexes: [
{ fields: ['projectId'] },
{ fields: ['projectId', 'element_type'], unique: true },
{ fields: ['element_type'] },
{ fields: ['source_element_id'] },
{ fields: ['deletedAt'] },
],
},
);
projectElementDefaults.associate = (db) => {
db.project_element_defaults.belongsTo(db.projects, {
as: 'project',
foreignKey: {
name: 'projectId',
allowNull: false,
},
constraints: true,
onDelete: 'CASCADE',
onUpdate: 'CASCADE',
});
db.project_element_defaults.belongsTo(db.element_type_defaults, {
as: 'source_element',
foreignKey: {
name: 'source_element_id',
},
constraints: true,
onDelete: 'SET NULL',
onUpdate: 'CASCADE',
});
db.project_element_defaults.belongsTo(db.users, {
as: 'createdBy',
});
db.project_element_defaults.belongsTo(db.users, {
as: 'updatedBy',
});
};
return projectElementDefaults;
};
export default defineProjectElementDefaultsModel;