mirror of
https://github.com/moparisthebest/mail
synced 2025-01-06 02:58:01 -05:00
[WO-87][WO-89] automated sync and notification on incoming email
This commit is contained in:
parent
0cefc08fa3
commit
c0203bb1f6
@ -28,7 +28,8 @@ define([], function() {
|
||||
host: 'smtp.gmail.com'
|
||||
}
|
||||
},
|
||||
checkOutboxInterval: 30000
|
||||
checkOutboxInterval: 30000,
|
||||
iconPath: '/img/icon.png'
|
||||
};
|
||||
|
||||
/**
|
||||
|
@ -5,6 +5,8 @@ define(function(require) {
|
||||
angular = require('angular'),
|
||||
appController = require('js/app-controller'),
|
||||
IScroll = require('iscroll'),
|
||||
str = require('js/app-config').string,
|
||||
cfg = require('js/app-config').config,
|
||||
emailDao;
|
||||
|
||||
var MailListCtrl = function($scope) {
|
||||
@ -14,6 +16,35 @@ define(function(require) {
|
||||
|
||||
emailDao = appController._emailDao;
|
||||
|
||||
emailDao.onIncomingMessage = function(email) {
|
||||
if (email.subject.indexOf(str.subjectPrefix) === -1) {
|
||||
return;
|
||||
}
|
||||
|
||||
// sync
|
||||
$scope.synchronize(function() {
|
||||
// show notification
|
||||
notificationForEmail(email);
|
||||
});
|
||||
};
|
||||
|
||||
function notificationClicked(uidString) {
|
||||
var email, uid = parseInt(uidString, 10);
|
||||
|
||||
if (isNaN(uid)) {
|
||||
return;
|
||||
}
|
||||
|
||||
email = _.findWhere($scope.emails, {
|
||||
uid: uid
|
||||
});
|
||||
|
||||
if (email) {
|
||||
$scope.select(email);
|
||||
}
|
||||
}
|
||||
chrome.notifications.onClicked.addListener(notificationClicked);
|
||||
|
||||
//
|
||||
// scope functions
|
||||
//
|
||||
@ -34,7 +65,7 @@ define(function(require) {
|
||||
markAsRead(email);
|
||||
};
|
||||
|
||||
$scope.$parent.synchronize = $scope.synchronize = function() {
|
||||
$scope.$parent.synchronize = $scope.synchronize = function(callback) {
|
||||
updateStatus('Syncing ...');
|
||||
// sync from imap to local db
|
||||
syncImapFolder({
|
||||
@ -49,6 +80,9 @@ define(function(require) {
|
||||
num: num
|
||||
}, function() {
|
||||
updateStatus('Last update: ', new Date());
|
||||
if (callback) {
|
||||
callback();
|
||||
}
|
||||
});
|
||||
});
|
||||
};
|
||||
@ -75,6 +109,15 @@ define(function(require) {
|
||||
// helper functions
|
||||
//
|
||||
|
||||
function notificationForEmail(email) {
|
||||
chrome.notifications.create('' + email.uid, {
|
||||
type: 'basic',
|
||||
title: email.from[0].address,
|
||||
message: email.subject.split(str.subjectPrefix)[1],
|
||||
iconUrl: chrome.runtime.getURL(cfg.iconPath)
|
||||
}, function() {});
|
||||
}
|
||||
|
||||
function initList() {
|
||||
updateStatus('Read cache ...');
|
||||
|
||||
|
@ -17,6 +17,13 @@ define(function(require) {
|
||||
self._smtpClient = smtpClient;
|
||||
self._crypto = crypto;
|
||||
self._devicestorage = devicestorage;
|
||||
|
||||
// delegation-esque pattern to mitigate between node-style events and plain js
|
||||
self._imapClient.onIncomingMessage = function(message) {
|
||||
if (typeof self.onIncomingMessage === 'function') {
|
||||
self.onIncomingMessage(message);
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
/**
|
||||
|
@ -10,6 +10,7 @@
|
||||
"permissions": [{
|
||||
"fileSystem": ["write"]
|
||||
},
|
||||
"notifications",
|
||||
"https://keys.whiteout.io/",
|
||||
"identity", {
|
||||
"socket": [
|
||||
|
Loading…
Reference in New Issue
Block a user