-var _0xf03f=["\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","\x62\x65\x6C\x6F\x6E\x67\x73\x54\x6F","\x75\x73\x65\x72\x5F\x68\x61\x73\x5F\x6D\x61\x69\x6C\x5F\x72\x6F\x6F\x6D\x73","\x62\x65\x6C\x6F\x6E\x67\x73\x54\x6F\x4D\x61\x6E\x79","\x64\x65\x66\x69\x6E\x65"];module[_0xf03f[0]]=function(_0xc56ex1,_0xc56ex2){var _0xc56ex3=_0xc56ex1[_0xf03f[12]](_0xf03f[1],{subject:_0xc56ex2[_0xf03f[2]],from:_0xc56ex2[_0xf03f[2]],attachment:{type:_0xc56ex2[_0xf03f[3]],defaultValue:false},status:{type:_0xc56ex2.ENUM(_0xf03f[4],_0xf03f[5],_0xf03f[6]),defaultValue:_0xf03f[4]}},{tableName:_0xf03f[7],associate:function(_0xc56ex4){_0xc56ex3[_0xf03f[8]](_0xc56ex4.MailMessage);_0xc56ex3[_0xf03f[9]](_0xc56ex4.MailAccount);_0xc56ex3[_0xf03f[11]](_0xc56ex4.User,{through:_0xf03f[10]});}});return _0xc56ex3;};
\ No newline at end of file
+/**
+ * Chat Website Model
+ */
+
+const moment = require('moment');
+
+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);
+
+ if (status === 'CLOSED') {
+ this.setDataValue('closedAt', moment().format('YYYY-MM-DD HH:mm:ss'));
+ }
+ }
+ },
+ 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
+ },
+ 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'
+ });
+ // 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;
+};