mirror of
https://github.com/moparisthebest/mail
synced 2024-11-29 20:32:15 -05:00
Merge branch 'delete_mail' into new_ui
This commit is contained in:
commit
bcd395d4de
@ -18,7 +18,7 @@ define(function(require) {
|
|||||||
// scope functions
|
// scope functions
|
||||||
//
|
//
|
||||||
|
|
||||||
$scope.select = function(email) {
|
$scope.$parent.select = $scope.select = function(email) {
|
||||||
if (!email) {
|
if (!email) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -66,7 +66,7 @@ define(function(require) {
|
|||||||
|
|
||||||
// development... display dummy mail objects
|
// development... display dummy mail objects
|
||||||
updateStatus('Last update: ', new Date());
|
updateStatus('Last update: ', new Date());
|
||||||
$scope.emails = createDummyMails();
|
$scope.$parent.emails = $scope.emails = createDummyMails();
|
||||||
$scope.select($scope.emails[0]);
|
$scope.select($scope.emails[0]);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -151,7 +151,7 @@ define(function(require) {
|
|||||||
return -e.uid;
|
return -e.uid;
|
||||||
});
|
});
|
||||||
|
|
||||||
$scope.emails = emails;
|
$scope.$parent.emails = $scope.emails = emails;
|
||||||
$scope.select($scope.emails[0]);
|
$scope.select($scope.emails[0]);
|
||||||
$scope.$apply();
|
$scope.$apply();
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@ define(function(require) {
|
|||||||
|
|
||||||
var angular = require('angular'),
|
var angular = require('angular'),
|
||||||
appController = require('js/app-controller'),
|
appController = require('js/app-controller'),
|
||||||
|
_ = require('underscore'),
|
||||||
emailDao;
|
emailDao;
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -31,6 +32,49 @@ define(function(require) {
|
|||||||
$scope.closeNav();
|
$scope.closeNav();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$scope.remove = function(email) {
|
||||||
|
var trashFolder = _.findWhere($scope.folders, {
|
||||||
|
type: 'Trash'
|
||||||
|
});
|
||||||
|
|
||||||
|
if ($scope.currentFolder === trashFolder) {
|
||||||
|
emailDao.imapDeleteMessage({
|
||||||
|
folder: $scope.currentFolder.path,
|
||||||
|
uid: email.uid
|
||||||
|
}, moved);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
emailDao.imapMoveMessage({
|
||||||
|
folder: $scope.currentFolder.path,
|
||||||
|
uid: email.uid,
|
||||||
|
destination: trashFolder.path
|
||||||
|
}, moved);
|
||||||
|
|
||||||
|
function moved(err) {
|
||||||
|
var index;
|
||||||
|
|
||||||
|
if (err) {
|
||||||
|
console.error(err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
index = $scope.emails.indexOf(email);
|
||||||
|
// show the next mail
|
||||||
|
if ($scope.emails.length > 1) {
|
||||||
|
// if we're about to delete the last entry of the array, show the previous (i.e. the one below in the list),
|
||||||
|
// otherwise show the next one (i.e. the one above in the list)
|
||||||
|
$scope.select(_.last($scope.emails) === email ? $scope.emails[index - 1] : $scope.emails[index + 1]);
|
||||||
|
} else {
|
||||||
|
// if we have only one email in the array, show nothing
|
||||||
|
$scope.select();
|
||||||
|
$scope.selected = undefined;
|
||||||
|
}
|
||||||
|
$scope.emails.splice(index, 1);
|
||||||
|
$scope.$apply();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
$scope.write = function(replyTo) {
|
$scope.write = function(replyTo) {
|
||||||
var replyToPath = (replyTo) ? encodeURIComponent($scope.currentFolder.path) + '/' + replyTo.uid : '',
|
var replyToPath = (replyTo) ? encodeURIComponent($scope.currentFolder.path) + '/' + replyTo.uid : '',
|
||||||
url = 'chrome.html#/write/' + replyToPath;
|
url = 'chrome.html#/write/' + replyToPath;
|
||||||
|
@ -290,14 +290,6 @@ define(function(require) {
|
|||||||
var self = this,
|
var self = this,
|
||||||
dbType = 'email_' + options.folder;
|
dbType = 'email_' + options.folder;
|
||||||
|
|
||||||
// validate options
|
|
||||||
if (!options.folder || typeof options.offset === 'undefined' || typeof options.num === 'undefined') {
|
|
||||||
callback({
|
|
||||||
errMsg: 'Invalid options!'
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
fetchList(function(err, emails) {
|
fetchList(function(err, emails) {
|
||||||
if (err) {
|
if (err) {
|
||||||
callback(err);
|
callback(err);
|
||||||
@ -386,14 +378,6 @@ define(function(require) {
|
|||||||
EmailDAO.prototype.imapListMessages = function(options, callback) {
|
EmailDAO.prototype.imapListMessages = function(options, callback) {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
// validate options
|
|
||||||
if (!options.folder || typeof options.offset === 'undefined' || typeof options.num === 'undefined') {
|
|
||||||
callback({
|
|
||||||
errMsg: 'Invalid options!'
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
self._imapClient.listMessages({
|
self._imapClient.listMessages({
|
||||||
path: options.folder,
|
path: options.folder,
|
||||||
offset: options.offset,
|
offset: options.offset,
|
||||||
@ -408,44 +392,54 @@ define(function(require) {
|
|||||||
EmailDAO.prototype.imapGetMessage = function(options, callback) {
|
EmailDAO.prototype.imapGetMessage = function(options, callback) {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
// validate options
|
|
||||||
if (!options.folder || !options.uid) {
|
|
||||||
callback({
|
|
||||||
errMsg: 'Invalid options!'
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
function messageReady(err, gottenMessage) {
|
|
||||||
if (err || !gottenMessage) {
|
|
||||||
callback({
|
|
||||||
errMsg: 'Error fetching message body!',
|
|
||||||
err: err
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// return message
|
|
||||||
callback(null, gottenMessage);
|
|
||||||
}
|
|
||||||
|
|
||||||
self._imapClient.getMessagePreview({
|
self._imapClient.getMessagePreview({
|
||||||
path: options.folder,
|
path: options.folder,
|
||||||
uid: options.uid
|
uid: options.uid
|
||||||
}, messageReady);
|
}, callback);
|
||||||
|
};
|
||||||
|
|
||||||
|
EmailDAO.prototype.imapMoveMessage = function(options, callback) {
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
self._imapClient.moveMessage({
|
||||||
|
path: options.folder,
|
||||||
|
uid: options.uid,
|
||||||
|
destination: options.destination
|
||||||
|
}, moved);
|
||||||
|
|
||||||
|
function moved(err) {
|
||||||
|
if (err) {
|
||||||
|
callback(err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// delete from local db
|
||||||
|
self._devicestorage.removeList('email_' + options.folder + '_' + options.uid, callback);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
EmailDAO.prototype.imapDeleteMessage = function(options, callback) {
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
self._imapClient.deleteMessage({
|
||||||
|
path: options.folder,
|
||||||
|
uid: options.uid
|
||||||
|
}, moved);
|
||||||
|
|
||||||
|
function moved(err) {
|
||||||
|
if (err) {
|
||||||
|
callback(err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// delete from local db
|
||||||
|
self._devicestorage.removeList('email_' + options.folder + '_' + options.uid, callback);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
EmailDAO.prototype.imapMarkMessageRead = function(options, callback) {
|
EmailDAO.prototype.imapMarkMessageRead = function(options, callback) {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
// validate options
|
|
||||||
if (!options.folder || !options.uid) {
|
|
||||||
callback({
|
|
||||||
errMsg: 'Invalid options!'
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
self._imapClient.updateFlags({
|
self._imapClient.updateFlags({
|
||||||
path: options.folder,
|
path: options.folder,
|
||||||
uid: options.uid,
|
uid: options.uid,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<div class="controls">
|
<div class="controls">
|
||||||
<button class="btn-icon"></button>
|
<button ng-click="remove(selected)" class="btn-icon"></button>
|
||||||
<button ng-click="write(selected)" class="btn-icon"></button>
|
<button ng-click="write(selected)" class="btn-icon"></button>
|
||||||
<button ng-click="write()" class="btn-icon"></button>
|
<button ng-click="write()" class="btn-icon"></button>
|
||||||
</div><!--/.controls-->
|
</div><!--/.controls-->
|
||||||
|
@ -302,14 +302,6 @@ define(function(require) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('IMAP: list messages from folder', function() {
|
describe('IMAP: list messages from folder', function() {
|
||||||
it('should fail due to bad options', function(done) {
|
|
||||||
emailDao.imapListMessages({}, function(err) {
|
|
||||||
expect(imapClientStub.listMessages.called).to.be.false;
|
|
||||||
expect(err).to.exist;
|
|
||||||
done();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should work', function(done) {
|
it('should work', function(done) {
|
||||||
imapClientStub.listMessages.yields();
|
imapClientStub.listMessages.yields();
|
||||||
emailDao.imapListMessages({
|
emailDao.imapListMessages({
|
||||||
@ -325,16 +317,6 @@ define(function(require) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
describe('IMAP: get message preview', function() {
|
describe('IMAP: get message preview', function() {
|
||||||
it('should fail due to bad options', function(done) {
|
|
||||||
emailDao.imapGetMessage({
|
|
||||||
folder: 'INBOX'
|
|
||||||
}, function(err) {
|
|
||||||
expect(imapClientStub.getMessagePreview.called).to.be.false;
|
|
||||||
expect(err).to.exist;
|
|
||||||
done();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should parse message body without attachement', function(done) {
|
it('should parse message body without attachement', function(done) {
|
||||||
var uid = 415;
|
var uid = 415;
|
||||||
|
|
||||||
@ -385,6 +367,86 @@ define(function(require) {
|
|||||||
// });
|
// });
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('IMAP: move messages', function() {
|
||||||
|
it('should move messages and remove from local storage', function(done) {
|
||||||
|
imapClientStub.moveMessage.yields();
|
||||||
|
devicestorageStub.removeList.yields();
|
||||||
|
|
||||||
|
emailDao.imapMoveMessage({
|
||||||
|
folder: 'ORIGIN',
|
||||||
|
uid: 1234,
|
||||||
|
destination: 'DESTINATION'
|
||||||
|
}, function(err) {
|
||||||
|
expect(err).to.not.exist;
|
||||||
|
expect(imapClientStub.moveMessage.calledWith({
|
||||||
|
path: 'ORIGIN',
|
||||||
|
uid: 1234,
|
||||||
|
destination: 'DESTINATION'
|
||||||
|
})).to.be.true;
|
||||||
|
expect(imapClientStub.moveMessage.calledOnce).to.be.true;
|
||||||
|
expect(devicestorageStub.removeList.calledOnce).to.be.true;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not remove from local storage after imap error', function(done) {
|
||||||
|
imapClientStub.moveMessage.yields(new Error('tis a silly place...'));
|
||||||
|
|
||||||
|
emailDao.imapMoveMessage({
|
||||||
|
folder: 'ORIGIN',
|
||||||
|
uid: 1234,
|
||||||
|
destination: 'DESTINATION'
|
||||||
|
}, function(err) {
|
||||||
|
expect(err).to.exist;
|
||||||
|
expect(imapClientStub.moveMessage.calledWith({
|
||||||
|
path: 'ORIGIN',
|
||||||
|
uid: 1234,
|
||||||
|
destination: 'DESTINATION'
|
||||||
|
})).to.be.true;
|
||||||
|
expect(imapClientStub.moveMessage.calledOnce).to.be.true;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('IMAP: delete messages', function() {
|
||||||
|
it('should delete messages and remove from local storage', function(done) {
|
||||||
|
imapClientStub.deleteMessage.yields();
|
||||||
|
devicestorageStub.removeList.yields();
|
||||||
|
|
||||||
|
emailDao.imapDeleteMessage({
|
||||||
|
folder: 'FOLDAAAA',
|
||||||
|
uid: 1234
|
||||||
|
}, function(err) {
|
||||||
|
expect(err).to.not.exist;
|
||||||
|
expect(imapClientStub.deleteMessage.calledWith({
|
||||||
|
path: 'FOLDAAAA',
|
||||||
|
uid: 1234
|
||||||
|
})).to.be.true;
|
||||||
|
expect(imapClientStub.deleteMessage.calledOnce).to.be.true;
|
||||||
|
expect(devicestorageStub.removeList.calledOnce).to.be.true;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should not remove from local storage after imap error', function(done) {
|
||||||
|
imapClientStub.deleteMessage.yields(new Error('tis a silly place...'));
|
||||||
|
|
||||||
|
emailDao.imapDeleteMessage({
|
||||||
|
folder: 'FOLDAAAA',
|
||||||
|
uid: 1234
|
||||||
|
}, function(err) {
|
||||||
|
expect(err).to.exist;
|
||||||
|
expect(imapClientStub.deleteMessage.calledWith({
|
||||||
|
path: 'FOLDAAAA',
|
||||||
|
uid: 1234
|
||||||
|
})).to.be.true;
|
||||||
|
expect(imapClientStub.deleteMessage.calledOnce).to.be.true;
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
describe('IMAP: sync messages to local storage', function() {
|
describe('IMAP: sync messages to local storage', function() {
|
||||||
it('should not list unencrypted messages', function(done) {
|
it('should not list unencrypted messages', function(done) {
|
||||||
imapClientStub.listMessages.yields(null, [{
|
imapClientStub.listMessages.yields(null, [{
|
||||||
|
Loading…
Reference in New Issue
Block a user