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

126 lines
4.0 KiB
JavaScript
Raw Normal View History

2019-07-05 07:06:29 +00:00
'use strict';
2019-07-25 16:39:18 +00:00
const moment = require('moment');
const Sequelize = require('sequelize');
moment.locale('es');
const getStateText = (reservation) => {
var currentDate = moment().utc(),
init_availableDate = moment.utc(reservation.init_available_date),
end_availableDate = moment.utc(reservation.end_available_date);
if (moment(currentDate).isBetween(init_availableDate, end_availableDate)) {
return (reservation.sold_out == 1) ? 'Inscripciones abiertas a lista de espera de la reserva' : 'Inscripciones abiertas a la reserva';
} else {
return 'Inscripciones a la reserva a partir del ' + moment(init_availableDate).format('D [de] MMMM');
};
};
2019-07-05 07:06:29 +00:00
module.exports = function (sequelize, DataTypes) {
const EventReservation = sequelize.define('EventReservation', {
id: {
type: DataTypes.UUID,
defaultValue: DataTypes.UUIDV4,
primaryKey: true,
},
2019-07-10 08:42:03 +00:00
init_available_date: {
2019-07-05 07:06:29 +00:00
type: DataTypes.DATE,
},
2019-07-10 08:42:03 +00:00
end_available_date: {
2019-07-05 07:06:29 +00:00
type: DataTypes.DATE,
},
2019-07-19 10:17:52 +00:00
//LO DA EL VENUE DEL EVENTO, Y LO COPIAMOS PARA NO ESTAR CONSULTANDOLO
2019-07-05 07:06:29 +00:00
gmt: {
type: DataTypes.INTEGER,
defaultValue: 1,
2019-07-19 10:17:52 +00:00
},
2019-07-05 07:06:29 +00:00
state: {
type: DataTypes.STRING,
allowNull: false,
defaultValue: 'borrador'
},
assistants: {
type: DataTypes.INTEGER,
},
confirmed: {
type: DataTypes.INTEGER,
},
2019-07-25 16:39:18 +00:00
sold_out: { //Se han vendido todas y se ha abierto lista de espera si hay asignada
type: DataTypes.BOOLEAN,
defaultValue: false,
},
2019-07-05 07:06:29 +00:00
allow_multiple: {
type: DataTypes.BOOLEAN,
allowNull: false,
defaultValue: false,
},
multiple_limit: {
type: DataTypes.INTEGER,
2019-07-19 10:17:52 +00:00
defaultValue: 0,
2019-07-05 07:06:29 +00:00
},
description: {
type: DataTypes.STRING,
},
2019-07-19 17:39:19 +00:00
reservation_code: {
2019-07-05 07:06:29 +00:00
type: DataTypes.STRING,
allowNull: false,
},
color: {
type: DataTypes.STRING,
allowNull: false,
},
allow_overflow: {
type: DataTypes.BOOLEAN,
allowNull: false,
defaultValue: false,
},
2019-07-25 16:39:18 +00:00
overflow_reservationId: {
2019-07-05 07:06:29 +00:00
type: DataTypes.UUID,
foreignKey: true,
},
2019-07-17 12:07:35 +00:00
marketing_list: {
2019-07-05 07:06:29 +00:00
type: DataTypes.STRING,
},
2019-07-25 16:39:18 +00:00
stateText: {
type: Sequelize.VIRTUAL(Sequelize.STRING, ['init_available_date', 'end_available_date', 'sold_out']),
get: function () {
return getStateText(this);
},
},
2019-07-05 07:06:29 +00:00
}, {
tableName: 'events_reservations',
freezeTableName: true,
timestamps: true,
});
EventReservation.associate = function (models) {
2019-07-09 08:51:00 +00:00
EventReservation.OverflowEventReservation = EventReservation.belongsTo(models.EventReservation, {
as: 'EventToEvent',
2019-07-25 16:39:18 +00:00
foreignKey: 'overflow_reservationId' });
2019-07-05 07:06:29 +00:00
EventReservation.Entity = EventReservation.belongsTo(models.Entity, { foreignKey: 'entityId' });
EventReservation.Event = EventReservation.belongsTo(models.Event, { foreignKey: 'eventId' });
2019-08-16 21:27:18 +00:00
EventReservation.Inscriptions = EventReservation.hasMany(models.EventInscription, { foreignKey: 'reservationId', as: 'inscriptions' });
2019-07-05 07:06:29 +00:00
EventReservation.UserCreate = EventReservation.belongsTo(models.User, { foreignKey: 'userId' });
};
2019-08-16 17:49:25 +00:00
EventReservation.addScope('includeEvent', () => {
return {
2019-08-16 21:27:18 +00:00
include: [{
model: sequelize.models.Event
}]
2019-08-16 17:49:25 +00:00
}
});
EventReservation.addScope('includeInscriptions', () => {
return {
2019-08-16 21:27:18 +00:00
include: [{
model: sequelize.models.EventInscription,
as: 'inscriptions'
}]
2019-08-16 17:49:25 +00:00
}
});
2019-08-19 17:54:39 +00:00
2019-07-05 07:06:29 +00:00
return EventReservation;
};