app2-api/modules/events/event.model.js

156 lines
4.4 KiB
JavaScript
Raw Normal View History

'use strict';
2019-07-16 16:27:54 +00:00
const moment = require('moment');
const Sequelize = require('sequelize');
module.exports = function (sequelize, DataTypes) {
const Event = sequelize.define('Event', {
id: {
type: DataTypes.UUID,
defaultValue: DataTypes.UUIDV4,
primaryKey: true,
},
name: {
type: DataTypes.STRING,
allowNull: false,
},
description: {
type: DataTypes.STRING,
},
2019-06-26 10:24:58 +00:00
campaign_text: {
type: DataTypes.TEXT,
allowNull: true
},
date: {
type: DataTypes.DATE,
allowNull: false,
},
2019-07-10 08:42:03 +00:00
init_available_date: {
type: DataTypes.DATE,
},
2019-07-10 08:42:03 +00:00
end_available_date: {
type: DataTypes.DATE,
},
gmt: {
type: DataTypes.INTEGER,
defaultValue: 1,
},
assistants: {
type: DataTypes.INTEGER,
},
confirmed: {
type: DataTypes.INTEGER,
},
allow_multiple: {
type: DataTypes.BOOLEAN,
allowNull: false,
defaultValue: false,
},
multiple_limit: {
type: DataTypes.INTEGER,
},
allow_overflow: {
type: DataTypes.BOOLEAN,
allowNull: false,
defaultValue: false,
},
overflow_eventId: {
type: DataTypes.UUID,
foreignKey: true,
2019-07-16 16:27:54 +00:00
require: false,
},
state: {
type: DataTypes.STRING,
allowNull: false,
defaultValue: 'borrador'
},
typeId: {
type: DataTypes.UUID,
foreignKey: true,
},
venueId: {
type: DataTypes.UUID,
foreignKey: true,
},
url_streaming: {
type: DataTypes.STRING,
},
url_poll: {
type: DataTypes.STRING,
},
url_registration: {
type: DataTypes.STRING,
},
2019-07-05 07:06:29 +00:00
marketingList: {
type: DataTypes.STRING,
},
2019-07-11 18:05:06 +00:00
userId: {
type: DataTypes.UUID,
foreignKey: true,
},
}, {
tableName: 'events',
freezeTableName: true,
timestamps: true,
2019-07-16 16:27:54 +00:00
defaultScope: {
//Se pude poner algo en función del usuario?????
},
scopes: {
next: {
where: {
date: {
[Sequelize.Op.gte]: moment().add(1, 'days').startOf('day').utc()
}
},
},
current: {
where: {
date: {
[Sequelize.Op.gte]: moment().startOf('day').utc(),
[Sequelize.Op.lt]: moment().add(1, 'days').startOf('day').utc(),
}
}
},
2019-07-16 18:18:28 +00:00
past: {
where: {
date: {
[Sequelize.Op.lt]: moment().startOf('day').utc()
}
}
},
2019-07-16 16:27:54 +00:00
}
});
2019-07-16 16:27:54 +00:00
2019-07-16 16:27:54 +00:00
Event.associate = function (models) {
2019-07-16 16:27:54 +00:00
// Event.OverflowEvent = Event.belongsTo(models.Event, {
// as: 'overflowEvent',
// foreignKey: 'overflow_eventId',
// required: false });
2019-07-14 16:44:59 +00:00
Event.Type = Event.belongsTo(models.EventType, { foreignKey: 'typeId', as: "type" });
Event.UserCreate = Event.belongsTo(models.User, { foreignKey: 'userId', as: "user" });
Event.Venue = Event.belongsTo(models.Venue, { foreignKey: 'venueId', as: "venue" });
2019-07-14 16:44:59 +00:00
Event.Schedule = Event.hasMany(models.EventSchedule, { foreignKey: 'eventId', as: "schedule" });
2019-07-09 17:39:52 +00:00
2019-07-12 11:19:15 +00:00
Event.Comments = Event.hasMany(models.Comment, {
foreignKey: 'entityId',
2019-07-14 16:44:59 +00:00
as: "comments"
2019-07-12 11:19:15 +00:00
});
2019-07-09 17:39:52 +00:00
2019-07-12 11:19:15 +00:00
Event.Multimedias = Event.hasMany(models.Multimedia, {
foreignKey: 'entityId',
2019-07-14 16:44:59 +00:00
as: { singular: 'multimedia', plural: 'multimedias' }});
2019-06-26 10:24:58 +00:00
2019-07-14 16:44:59 +00:00
Event.Reservations = Event.hasMany(models.EventReservation, { foreignKey: 'eventId', as: "reservations" });
Event.Inscriptions = Event.hasMany(models.EventInscription, { foreignKey: 'eventId', as: "inscriptions" });
Event.Questions = Event.hasMany(models.EventQuestion, { foreignKey: 'eventId', as: "questions" });
};
return Event;
};