_ = require 'underscore-plus' {Actions, DatabaseStore, Thread, Tag} = 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() body = msg.subject if not body or body.length is 0 body = msg.snippet notif = new Notification(msg.from[0].displayName(), { body: body tag: 'unread-update' }) notif.onclick = -> atom.displayWindow() Actions.focusTag(new Tag(name: "inbox", id: "inbox")) Actions.focusInCollection(collection: 'thread', item: threads[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()