mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-01 13:14:16 +08:00
Add unread query to threads route
This commit is contained in:
parent
18ad15937f
commit
bc5a4ecf3c
3 changed files with 28 additions and 4 deletions
|
@ -10,7 +10,8 @@ module.exports = (server) => {
|
|||
notes: 'Notes go here',
|
||||
tags: ['threads'],
|
||||
validate: {
|
||||
params: {
|
||||
query: {
|
||||
unread: Joi.boolean().allow(''),
|
||||
},
|
||||
},
|
||||
response: {
|
||||
|
@ -22,9 +23,19 @@ module.exports = (server) => {
|
|||
handler: (request, reply) => {
|
||||
request.getAccountDatabase().then((db) => {
|
||||
const {Thread} = db;
|
||||
Thread.findAll({limit: 50}).then((threads) => {
|
||||
reply(Serialization.jsonStringify(threads));
|
||||
})
|
||||
// the unread value will be '' if the url was just '/threads?unread'
|
||||
if (request.query.unread || request.query.unread === '') {
|
||||
Thread.findAll({
|
||||
where: {unreadCount: {gt: 0}},
|
||||
limit: 50,
|
||||
}).then((threads) => {
|
||||
reply(Serialization.jsonStringify(threads));
|
||||
})
|
||||
} else {
|
||||
Thread.findAll({limit: 50}).then((threads) => {
|
||||
reply(Serialization.jsonStringify(threads));
|
||||
})
|
||||
}
|
||||
})
|
||||
},
|
||||
});
|
||||
|
|
|
@ -3,6 +3,7 @@ module.exports = (sequelize, Sequelize) => {
|
|||
threadId: Sequelize.STRING,
|
||||
subject: Sequelize.STRING,
|
||||
cleanedSubject: Sequelize.STRING,
|
||||
unreadCount: Sequelize.INTEGER,
|
||||
}, {
|
||||
classMethods: {
|
||||
associate: ({Message}) => {
|
||||
|
|
|
@ -127,6 +127,7 @@ function matchThread({db, accountId, message}) {
|
|||
return Thread.create({
|
||||
subject: message.subject,
|
||||
cleanedSubject: cleanSubject(message.subject),
|
||||
unreadCount: 0,
|
||||
})
|
||||
})
|
||||
})
|
||||
|
@ -140,6 +141,7 @@ function matchThread({db, accountId, message}) {
|
|||
return Thread.create({
|
||||
subject: message.subject,
|
||||
cleanedSubject: cleanSubject(message.subject),
|
||||
unreadCount: 0,
|
||||
})
|
||||
})
|
||||
}
|
||||
|
@ -154,12 +156,22 @@ function addMessageToThread({db, accountId, message}) {
|
|||
.then((thread) => (thread))
|
||||
}
|
||||
|
||||
function updateThreadProperties({thread, message}) {
|
||||
// Update the thread's unread count
|
||||
if (message.unread) {
|
||||
thread.unreadCount++;
|
||||
thread.save();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
function processMessage({message, accountId}) {
|
||||
return DatabaseConnector.forAccount(accountId)
|
||||
.then((db) => addMessageToThread({db, accountId, message}))
|
||||
.then((thread) => {
|
||||
thread.addMessage(message)
|
||||
message.setThread(thread)
|
||||
updateThreadProperties({thread, message})
|
||||
return message
|
||||
})
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue