-var _0x7ac4=["\x65\x78\x70\x6F\x72\x74\x73","\x4D\x61\x69\x6C\x52\x6F\x6F\x6D","\x53\x54\x52\x49\x4E\x47","\x42\x4F\x4F\x4C\x45\x41\x4E","\x4E\x45\x57","\x4F\x50\x45\x4E","\x43\x4C\x4F\x53\x45\x44","\x6D\x61\x69\x6C\x5F\x72\x6F\x6F\x6D\x73","\x68\x61\x73\x4D\x61\x6E\x79","\x53\x74\x61\x74\x65\x73","\x62\x65\x6C\x6F\x6E\x67\x73\x54\x6F","\x64\x65\x66\x69\x6E\x65"];module[_0x7ac4[0]]=function(_0xc839x1,_0xc839x2){var _0xc839x3=_0xc839x1[_0x7ac4[11]](_0x7ac4[1],{subject:_0xc839x2[_0x7ac4[2]],from:_0xc839x2[_0x7ac4[2]],attachment:{type:_0xc839x2[_0x7ac4[3]],defaultValue:false},status:{type:_0xc839x2.ENUM(_0x7ac4[4],_0x7ac4[5],_0x7ac4[6]),defaultValue:_0x7ac4[4]}},{tableName:_0x7ac4[7],associate:function(_0xc839x4){_0xc839x3[_0x7ac4[8]](_0xc839x4.MailMessage);_0xc839x3[_0x7ac4[8]](_0xc839x4.MailRoomStatus,{as:_0x7ac4[9]});_0xc839x3[_0x7ac4[10]](_0xc839x4.MailAccount);_0xc839x3[_0x7ac4[10]](_0xc839x4.User);}});return _0xc839x3;};
\ No newline at end of file
+'use strict';
+
+const moment = require('moment');
+const satuses = {
+ NEW: ['OPEN', 'CLOSED'],
+ OPEN: ['PENDING', 'CLOSED'],
+ PENDING: ['OPEN', 'CLOSED'],
+ CLOSED: []
+};
+
+module.exports = function(sequelize, DataTypes) {
+ var MailRoom = sequelize.define('MailRoom', {
+ subject: DataTypes.STRING,
+ from: DataTypes.STRING,
+ account: DataTypes.STRING,
+ attachment: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
+ mailIn: {
+ type: DataTypes.INTEGER,
+ defaultValue: 0
+ },
+ mailOut: {
+ type: DataTypes.INTEGER,
+ defaultValue: 0
+ },
+ status: {
+ type: DataTypes.ENUM('NEW', 'OPEN', 'PENDING', 'CLOSED'),
+ defaultValue: 'NEW',
+ set: function(status) {
+ this.setDataValue('status', status);
+
+ switch (status) {
+ case 'NEW':
+ this.setDataValue('arrivedAt', moment().format('YYYY-MM-DD HH:mm:ss'));
+ break;
+ case 'CLOSED':
+ this.setDataValue('closedAt', moment().format('YYYY-MM-DD HH:mm:ss'));
+ break;
+ default:
+
+ }
+ }
+ },
+ lastEvent: {
+ type: DataTypes.ENUM('SENDING', 'SENT', 'RECEIVED', 'FAILED', 'NOTE')
+ },
+ lastEventAt: {
+ type: DataTypes.DATE
+ },
+ deleted: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
+ waiting: {
+ type: DataTypes.BOOLEAN,
+ defaultValue: false
+ },
+ tags: {
+ type: DataTypes.TEXT,
+ get: function() {
+ 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);
+ }
+ },
+ disposition: {
+ type: DataTypes.STRING
+ },
+ openReason: DataTypes.STRING,
+ 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'
+ });
+ // SCOPES
+ MailRoom.addScope('default', {
+ order: [
+ ['createdAt', 'DESC']
+ ],
+ include: [{
+ model: models.MailAccount
+ }, {
+ model: models.MailMessage,
+ include: [{
+ model: models.MailAttachment
+ }, {
+ model: models.User,
+ attributes: ['id', 'name', 'fullname', 'email', 'userpic']
+ }]
+ }, {
+ model: models.User,
+ attributes: ['id', 'name', 'fullname', 'email', 'userpic']
+ }]
+ });
+ }
+ });
+
+ return MailRoom;
+};