_ = require 'underscore-plus' {Actions, DatabaseStore, Thread} = require 'inbox-exports' module.exports = activate: -> @unlisteners = [] @unlisteners.push Actions.didPassivelyReceiveNewModels.listen(@_onNewMailReceived, @) @activationTime = Date.now() deactivate: -> fn() for fn in @unlisteners serialize: -> _onNewMailReceived: (incoming) -> new Promise (resolve, reject) => incomingMessages = incoming['message'] ? [] incomingThreads = incoming['thread'] ? [] # Filter for new messages newUnread = _.filter incomingMessages, (msg) => msg.unread is true and msg.date?.valueOf() >= @activationTime return resolve() if newUnread.length is 0 # For each message, find it's corresponding thread. First, look to see # if it's already in the `incoming` payload (sent via delta sync # at the same time as the message.) If it's not, try loading it from # the local cache. # # Note we may receive multiple unread msgs for the same thread. # Using a map and ?= to avoid repeating work. threads = {} for msg in newUnread threads[msg.threadId] ?= _.findWhere(incomingThreads, {id: msg.threadId}) threads[msg.threadId] ?= DatabaseStore.find(Thread, msg.threadId) Promise.props(threads).then (threads) -> # Filter new unread messages to just the ones in the inbox newUnreadInInbox = _.filter newUnread, (msg) -> threads[msg.threadId]?.hasTagId('inbox') if newUnreadInInbox.length is 1 msg = newUnreadInInbox.pop() notif = new Notification(msg.from[0].displayName(), { body: msg.subject tag: 'unread-update' }) notif.onclick = -> atom.displayWindow() Actions.selectTagId("inbox") Actions.selectThreadId(msg.threadId) if newUnreadInInbox.length > 1 new Notification("#{newUnreadInInbox.length} Unread Messages", { tag: 'unread-update' }) if newUnreadInInbox.length > 0 atom.playSound('new_mail.ogg') resolve()