Mailspring/packages/nylas-core/models/account/thread.js

41 lines
1.4 KiB
JavaScript
Raw Normal View History

const {JSONARRAYType} = require('../../database-types');
2016-06-19 18:02:32 +08:00
module.exports = (sequelize, Sequelize) => {
const Thread = sequelize.define('Thread', {
2016-06-23 02:49:53 +08:00
threadId: Sequelize.STRING,
subject: Sequelize.STRING,
snippet: Sequelize.STRING,
2016-06-25 07:14:04 +08:00
unreadCount: Sequelize.INTEGER,
2016-06-28 01:15:05 +08:00
starredCount: Sequelize.INTEGER,
firstMessageDate: Sequelize.DATE,
lastMessageDate: Sequelize.DATE,
lastMessageReceivedDate: Sequelize.DATE,
lastMessageSentDate: Sequelize.DATE,
participants: JSONARRAYType('participants'),
2016-06-19 18:02:32 +08:00
}, {
classMethods: {
associate: ({Category, Message, ThreadCategory}) => {
Thread.belongsToMany(Category, {through: ThreadCategory})
2016-06-23 02:49:53 +08:00
Thread.hasMany(Message, {as: 'messages'})
2016-06-19 18:02:32 +08:00
},
},
instanceMethods: {
toJSON: function toJSON() {
return {
id: this.id,
participants: this.participants,
subject: this.subject,
snippet: this.snippet,
unread: this.unreadCount > 0,
starred: this.starredCount > 0,
last_message_timestamp: this.lastMessageDate ? this.lastMessageDate.getTime() / 1000.0 : null,
last_message_sent_timestamp: this.lastMessageSentDate ? this.lastMessageSentDate.getTime() / 1000.0 : null,
last_message_received_timestamp: this.lastMessageReceivedDate ? this.lastMessageReceivedDate.getTime() / 1000.0 : null,
};
},
},
2016-06-19 18:02:32 +08:00
});
return Thread;
};