* Chat Website Model
*/
+const moment = require('moment');
module.exports = function(sequelize, DataTypes) {
var MailRoom = sequelize.define('MailRoom', {
defaultValue: 0
},
status: {
- type: DataTypes.ENUM('NEW', 'OPEN', 'CLOSED', 'UNMANAGED'),
- defaultValue: 'NEW'
+ type: DataTypes.ENUM('NEW', 'OPEN', 'PENDING', 'CLOSED'),
+ defaultValue: 'NEW',
+ set: function(status) {
+ this.setDataValue('status', status);
+
+ if (status === 'CLOSED') {
+ this.setDataValue('closedAt', moment().format('YYYY-MM-DD HH:mm:ss'));
+ }
+ }
},
lastEvent: {
- type: DataTypes.ENUM('SENT', 'SENDING', 'RECEIVED', 'FAILED', 'NOTE')
+ type: DataTypes.ENUM('SENDING', 'SENT', 'RECEIVED', 'FAILED', 'NOTE')
},
lastEventAt: {
type: DataTypes.DATE
type: DataTypes.BOOLEAN,
defaultValue: false
},
+ waiting: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
tags: {
type: DataTypes.TEXT,
get: function() {
- return this.getDataValue('tags') ? this.getDataValue('tags').split(';').pop() : [];
+ var tags;
+ if (this.getDataValue('tags')) {
+ tags = this.getDataValue('tags').split(';');
+ tags.pop();
+ } else {
+ tags = [];
+ }
+ return tags;
},
set: function(val) {
this.setDataValue('tags', val && val.length ? val.join(';') + ';' : null);
deletedAt: {
type: DataTypes.DATE
},
+ ParentId: {
+ type: DataTypes.INTEGER
+ },
+ arrivedAt: {
+ type: DataTypes.DATE
+ },
+ closedAt: {
+ type: DataTypes.DATE
+ }
}, {
tableName: 'mail_rooms',
paranoid: true,
associate: function(models) {
// BINDING
MailRoom.hasMany(models.MailMessage);
+ MailRoom.hasMany(models.MailRoomStatus, {
+ plural: 'MailRoomStatuses'
+ });
MailRoom.belongsTo(models.MailAccount);
MailRoom.belongsToMany(models.User, {
through: 'user_has_mail_rooms'