/* -*- Mode: javascript; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ (function() { 'use strict'; /** * @ngInject */ MessageController.$inject = ['$window', '$scope', '$state', '$mdDialog', 'stateAccounts', 'stateAccount', 'stateMailbox', 'stateMessage', 'encodeUriFilter', 'sgSettings', 'sgFocus', 'Dialog', 'Account', 'Mailbox', 'Message']; function MessageController($window, $scope, $state, $mdDialog, stateAccounts, stateAccount, stateMailbox, stateMessage, encodeUriFilter, sgSettings, focus, Dialog, Account, Mailbox, Message) { var vm = this, messageDialog = null, popupWindow = null; vm.accounts = stateAccounts; vm.account = stateAccount; vm.mailbox = stateMailbox; vm.message = stateMessage; vm.service = Message; vm.tags = { searchText: '', selected: '' }; vm.showFlags = stateMessage.flags && stateMessage.flags.length > 0; vm.$showDetailedRecipients = false; vm.showDetailedRecipients = showDetailedRecipients; vm.doDelete = doDelete; vm.close = close; vm.reply = reply; vm.replyAll = replyAll; vm.forward = forward; vm.edit = edit; vm.openPopup = openPopup; vm.closePopup = closePopup; vm.newMessage = newMessage; vm.saveMessage = saveMessage; vm.toggleRawSource = toggleRawSource; vm.showRawSource = false; // 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 showDetailedRecipients($event) { vm.$showDetailedRecipients = true; $event.stopPropagation(); $event.preventDefault(); } function doDelete() { stateMailbox.$deleteMessages([stateMessage]).then(function() { // Remove message from list of messages var index = _.findIndex(stateMailbox.$messages, function(o) { return o.uid == stateMessage.uid; }); if (index != -1) stateMailbox.$messages.splice(index, 1); // Remove message object from scope vm.message = null; $state.go('mail.account.mailbox', { accountId: stateAccount.id, mailboxId: encodeUriFilter(stateMailbox.path) }); }); } function showMailEditor($event, message, recipients) { if (messageDialog === null) { if (!angular.isDefined(recipients)) recipients = []; messageDialog = $mdDialog .show({ parent: angular.element(document.body), targetEvent: $event, clickOutsideToClose: false, escapeToClose: false, templateUrl: 'UIxMailEditor', controller: 'MessageEditorController', controllerAs: 'editor', locals: { stateAccounts: vm.accounts, stateMessage: message, stateRecipients: recipients } }) .finally(function() { messageDialog = null; }); } } function close() { $state.go('mail.account.mailbox', { accountId: stateAccount.id, mailboxId: encodeUriFilter(stateMailbox.path) }).then(function() { vm.message = null; delete stateMailbox.selectedMessage; }); } 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) { vm.message.$editableContent().then(function() { showMailEditor($event, vm.message); }); } function openPopup() { var url = [sgSettings.baseURL(), 'UIxMailPopupView#/Mail', vm.message.accountId, // The double-encoding is necessary encodeUriFilter(encodeUriFilter(vm.message.$mailbox.path)), vm.message.uid] .join('/'), wId = vm.message.$absolutePath(); popupWindow = $window.open(url, wId, ["width=680", "height=520", "resizable=1", "scrollbars=1", "toolbar=0", "location=0", "directories=0", "status=0", "menubar=0", "copyhistory=0"] .join(',')); } function closePopup() { $window.close(); } function newMessage($event, recipient) { var message = vm.account.$newMessage(); showMailEditor($event, message, [recipient]); $event.stopPropagation(); $event.preventDefault(); } function saveMessage() { window.location.href = ApplicationBaseURL + '/' + vm.mailbox.id + '/saveMessages?uid=' + vm.message.uid; } function toggleRawSource($event) { if (!vm.showRawSource && !vm.rawSource) { Message.$$resource.post(vm.message.id, "viewsource").then(function(data) { vm.rawSource = data; vm.showRawSource = true; }); } else { vm.showRawSource = !vm.showRawSource; } } } angular .module('SOGo.MailerUI') .controller('MessageController', MessageController); })();