app2-api/modules/comments/comment.model.js

69 lines
2.1 KiB
JavaScript
Raw Normal View History

2019-05-23 09:40:50 +00:00
module.exports = function (sequelize, DataTypes) {
const Comment = sequelize.define('Comment', {
id: {
type: DataTypes.UUID,
defaultValue: DataTypes.UUIDV4,
primaryKey: true
},
2019-07-05 07:06:29 +00:00
entityId: {
type: DataTypes.UUID,
allowNull: false,
},
entityName: {
2019-05-23 09:40:50 +00:00
type: DataTypes.STRING,
2019-07-05 07:06:29 +00:00
allowNull: false,
2019-05-23 09:40:50 +00:00
},
2019-07-05 07:06:29 +00:00
type: {
type: DataTypes.STRING,
allowNull: false,
2019-05-23 09:40:50 +00:00
},
content: {
type: DataTypes.STRING,
allowNull: false
},
2019-07-05 07:06:29 +00:00
entity: {
type: DataTypes.VIRTUAL,
get: function () {
const name = this.get('entityName');
const id = this.get('entityId');
let modelName = '';
switch (name) {
case 'post':
modelName = 'Post';
break;
case 'speaker':
modelName = 'Speaker'
break;
case 'event':
modelName = 'Event';
break;
default:
break;
}
return sequelize.models[modelName].findOne(id);
}
}
2019-05-23 09:40:50 +00:00
}, {
2019-07-05 07:06:29 +00:00
indexes: [{
unique: false,
fields: ['entityId']
}],
2019-05-23 09:40:50 +00:00
tableName: 'comments',
freezeTableName: true,
timestamps: true,
});
2019-07-05 07:06:29 +00:00
2019-05-23 09:40:50 +00:00
Comment.associate = function (models) {
Comment.User = Comment.belongsTo(models.User, { foreignKey: 'userId', constraints: false });
//Comment.Conference = Comment.belongsTo(models.Conference, { foreignKey: 'conferenceId', constraints: false });
2019-07-05 07:06:29 +00:00
//Comment.Post = Comment.belongsTo(models.Post, { foreignKey: 'postId', constraints: false });
2019-05-23 09:40:50 +00:00
//Comment.Speaker = Comment.belongsTo(models.Speaker, { foreignKey: 'speakerId', constraints: false });
};
return Comment;
};