2015-05-06 04:06:13 +02:00
|
|
|
/* -*- Mode: javascript; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
|
|
|
|
(function() {
|
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2015-08-02 19:25:38 +02:00
|
|
|
MessageController.$inject = ['$scope', '$state', '$mdDialog', 'stateAccounts', 'stateAccount', 'stateMailbox', 'stateMessage', 'encodeUriFilter', 'sgFocus', 'Dialog', 'Account', 'Mailbox', 'Message'];
|
|
|
|
function MessageController($scope, $state, $mdDialog, stateAccounts, stateAccount, stateMailbox, stateMessage, encodeUriFilter, focus, Dialog, Account, Mailbox, Message) {
|
2015-07-13 21:22:58 +02:00
|
|
|
var vm = this;
|
|
|
|
|
2015-08-02 19:25:38 +02:00
|
|
|
vm.accounts = stateAccounts;
|
2015-07-13 21:22:58 +02:00
|
|
|
vm.account = stateAccount;
|
|
|
|
vm.mailbox = stateMailbox;
|
|
|
|
vm.message = stateMessage;
|
|
|
|
vm.service = Message;
|
|
|
|
vm.tags = { searchText: '', selected: '' };
|
|
|
|
vm.doDelete = doDelete;
|
2015-08-02 19:25:38 +02:00
|
|
|
vm.reply = reply;
|
|
|
|
vm.replyAll = replyAll;
|
|
|
|
vm.forward = forward;
|
|
|
|
vm.edit = edit;
|
2015-08-09 16:36:54 +02:00
|
|
|
vm.newMessage = newMessage;
|
2015-08-04 22:51:33 +02:00
|
|
|
vm.viewRawSource = viewRawSource;
|
2015-07-13 21:22:58 +02:00
|
|
|
|
|
|
|
// Watch the message model "flags" attribute to remove on-the-fly a tag from the IMAP message
|
|
|
|
// when removed from the message viewer.
|
|
|
|
// TODO: this approach should be reviewed once md-chips supports ng-change.
|
|
|
|
$scope.$watchCollection('viewer.message.flags', function(oldTags, newTags) {
|
|
|
|
_.each(_.difference(newTags, oldTags), function(tag) {
|
|
|
|
vm.message.removeTag(tag);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function doDelete() {
|
2015-05-06 04:06:13 +02:00
|
|
|
stateMailbox.$deleteMessages([stateMessage.uid]).then(function() {
|
2015-05-08 21:47:09 +02:00
|
|
|
// Remove message from list of messages
|
2015-07-13 21:22:58 +02:00
|
|
|
var index = _.findIndex(stateMailbox.$messages, function(o) {
|
2015-05-06 04:06:13 +02:00
|
|
|
return o.uid == stateMessage.uid;
|
|
|
|
});
|
2015-07-13 21:22:58 +02:00
|
|
|
if (index != -1)
|
|
|
|
stateMailbox.$messages.splice(index, 1);
|
2015-05-08 21:47:09 +02:00
|
|
|
// Remove message object from scope
|
2015-07-13 21:22:58 +02:00
|
|
|
vm.message = null;
|
2015-05-06 04:06:13 +02:00
|
|
|
$state.go('mail.account.mailbox', { accountId: stateAccount.id, mailboxId: encodeUriFilter(stateMailbox.path) });
|
|
|
|
});
|
2015-07-13 21:22:58 +02:00
|
|
|
}
|
2015-08-02 19:25:38 +02:00
|
|
|
|
2015-08-09 16:36:54 +02:00
|
|
|
function showMailEditor($event, message, recipients) {
|
|
|
|
|
|
|
|
if (!angular.isDefined(recipients))
|
|
|
|
recipients = [];
|
|
|
|
|
2015-08-02 19:25:38 +02:00
|
|
|
$mdDialog.show({
|
|
|
|
parent: angular.element(document.body),
|
|
|
|
targetEvent: $event,
|
2015-08-05 16:14:32 +02:00
|
|
|
clickOutsideToClose: false,
|
|
|
|
escapeToClose: false,
|
2015-08-02 19:25:38 +02:00
|
|
|
templateUrl: 'UIxMailEditor',
|
|
|
|
controller: 'MessageEditorController',
|
|
|
|
controllerAs: 'editor',
|
|
|
|
locals: {
|
|
|
|
stateAccounts: vm.accounts,
|
2015-08-09 16:36:54 +02:00
|
|
|
stateMessage: message,
|
|
|
|
stateRecipients: recipients
|
2015-08-02 19:25:38 +02:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function reply($event) {
|
|
|
|
var message = vm.message.$reply();
|
|
|
|
showMailEditor($event, message);
|
|
|
|
}
|
|
|
|
|
|
|
|
function replyAll($event) {
|
|
|
|
var message = vm.message.$replyAll();
|
|
|
|
showMailEditor($event, message);
|
|
|
|
}
|
|
|
|
|
|
|
|
function forward($event) {
|
|
|
|
var message = vm.message.$forward();
|
|
|
|
showMailEditor($event, message);
|
|
|
|
}
|
|
|
|
|
|
|
|
function edit($event) {
|
2015-08-04 16:56:55 +02:00
|
|
|
vm.message.$editableContent().then(function() {
|
|
|
|
showMailEditor($event, vm.message);
|
|
|
|
});
|
2015-08-02 19:25:38 +02:00
|
|
|
}
|
2015-08-04 22:51:33 +02:00
|
|
|
|
2015-08-09 16:36:54 +02:00
|
|
|
function newMessage($event, recipient) {
|
|
|
|
var message = vm.account.$newMessage();
|
|
|
|
showMailEditor($event, message, [recipient]);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-08-04 22:51:33 +02:00
|
|
|
function viewRawSource($event) {
|
|
|
|
Message.$$resource.post(vm.message.id, "viewsource").then(function(data) {
|
|
|
|
$mdDialog.show({
|
|
|
|
parent: angular.element(document.body),
|
|
|
|
targetEvent: $event,
|
|
|
|
clickOutsideToClose: true,
|
|
|
|
escapeToClose: true,
|
|
|
|
template: [
|
|
|
|
'<md-dialog flex="80" flex-sm="100" aria-label="' + l('View Message Source') + '">',
|
|
|
|
' <md-dialog-content>',
|
|
|
|
' <pre>',
|
|
|
|
data,
|
|
|
|
' </pre>',
|
|
|
|
' </md-dialog-content>',
|
|
|
|
' <div class="md-actions">',
|
|
|
|
' <md-button ng-click="close()">' + l('Close') + '</md-button>',
|
|
|
|
' </div>',
|
|
|
|
'</md-dialog>'
|
|
|
|
].join(''),
|
|
|
|
controller: MessageRawSourceDialogController
|
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
|
|
|
MessageRawSourceDialogController.$inject = ['scope', '$mdDialog'];
|
|
|
|
function MessageRawSourceDialogController(scope, $mdDialog) {
|
|
|
|
scope.close = function() {
|
|
|
|
$mdDialog.hide();
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
angular
|
|
|
|
.module('SOGo.MailerUI')
|
|
|
|
.controller('MessageController', MessageController);
|
|
|
|
})();
|