mirror of
https://github.com/inverse-inc/sogo.git
synced 2026-04-16 10:48:50 +00:00
(feat) now use mdDialog for message composition
This commit is contained in:
@@ -53,19 +53,19 @@
|
||||
stateMessages: stateMessages
|
||||
}
|
||||
})
|
||||
.state('mail.account.mailbox.newMessage', {
|
||||
url: '/new',
|
||||
views: {
|
||||
'mailbox@mail': {
|
||||
templateUrl: 'UIxMailEditor', // UI/Templates/MailerUI/UIxMailEditor.wox
|
||||
controller: 'MessageEditorController',
|
||||
controllerAs: 'editor'
|
||||
}
|
||||
},
|
||||
resolve: {
|
||||
stateMessage: stateNewMessage
|
||||
}
|
||||
})
|
||||
// .state('mail.account.mailbox.newMessage', {
|
||||
// url: '/new',
|
||||
// views: {
|
||||
// 'mailbox@mail': {
|
||||
// templateUrl: 'UIxMailEditor', // UI/Templates/MailerUI/UIxMailEditor.wox
|
||||
// controller: 'MessageEditorController',
|
||||
// controllerAs: 'editor'
|
||||
// }
|
||||
// },
|
||||
// resolve: {
|
||||
// stateMessage: stateNewMessage
|
||||
// }
|
||||
// })
|
||||
.state('mail.account.mailbox.message', {
|
||||
url: '/:messageId',
|
||||
views: {
|
||||
@@ -78,30 +78,30 @@
|
||||
resolve: {
|
||||
stateMessage: stateMessage
|
||||
}
|
||||
})
|
||||
.state('mail.account.mailbox.message.edit', {
|
||||
url: '/edit',
|
||||
views: {
|
||||
'mailbox@mail': {
|
||||
templateUrl: 'UIxMailEditor', // UI/Templates/MailerUI/UIxMailEditor.wox
|
||||
controller: 'MessageEditorController',
|
||||
controllerAs: 'editor'
|
||||
}
|
||||
},
|
||||
resolve: {
|
||||
stateContent: stateContent
|
||||
}
|
||||
})
|
||||
.state('mail.account.mailbox.message.action', {
|
||||
url: '/{actionName:(?:reply|replyall|forward)}',
|
||||
views: {
|
||||
'mailbox@mail': {
|
||||
templateUrl: 'UIxMailEditor', // UI/Templates/MailerUI/UIxMailEditor.wox
|
||||
controller: 'MessageEditorController',
|
||||
controllerAs: 'editor'
|
||||
}
|
||||
}
|
||||
});
|
||||
// .state('mail.account.mailbox.message.edit', {
|
||||
// url: '/edit',
|
||||
// views: {
|
||||
// 'mailbox@mail': {
|
||||
// templateUrl: 'UIxMailEditor', // UI/Templates/MailerUI/UIxMailEditor.wox
|
||||
// controller: 'MessageEditorController',
|
||||
// controllerAs: 'editor'
|
||||
// }
|
||||
// },
|
||||
// resolve: {
|
||||
// stateContent: stateContent
|
||||
// }
|
||||
// })
|
||||
// .state('mail.account.mailbox.message.action', {
|
||||
// url: '/{actionName:(?:reply|replyall|forward)}',
|
||||
// views: {
|
||||
// 'mailbox@mail': {
|
||||
// templateUrl: 'UIxMailEditor', // UI/Templates/MailerUI/UIxMailEditor.wox
|
||||
// controller: 'MessageEditorController',
|
||||
// controllerAs: 'editor'
|
||||
// }
|
||||
// }
|
||||
// });
|
||||
|
||||
// if none of the above states are matched, use this as the fallback
|
||||
$urlRouterProvider.otherwise('/Mail');
|
||||
@@ -176,10 +176,10 @@
|
||||
/**
|
||||
* @ngInject
|
||||
*/
|
||||
stateNewMessage.$inject = ['stateAccount'];
|
||||
function stateNewMessage(stateAccount) {
|
||||
return stateAccount.$newMessage();
|
||||
}
|
||||
// stateNewMessage.$inject = ['stateAccount'];
|
||||
// function stateNewMessage(stateAccount) {
|
||||
// return stateAccount.$newMessage();
|
||||
// }
|
||||
|
||||
/**
|
||||
* @ngInject
|
||||
@@ -203,10 +203,10 @@
|
||||
/**
|
||||
* @ngInject
|
||||
*/
|
||||
stateContent.$inject = ['stateMessage'];
|
||||
function stateContent(stateMessage) {
|
||||
return stateMessage.$editableContent();
|
||||
}
|
||||
// stateContent.$inject = ['stateMessage'];
|
||||
// function stateContent(stateMessage) {
|
||||
// return stateMessage.$editableContent();
|
||||
// }
|
||||
|
||||
/**
|
||||
* @ngInject
|
||||
|
||||
@@ -6,8 +6,8 @@
|
||||
/**
|
||||
* @ngInject
|
||||
*/
|
||||
MailboxController.$inject = ['$state', '$timeout', 'stateAccounts', 'stateAccount', 'stateMailbox', 'encodeUriFilter', 'sgFocus', 'Dialog', 'Account', 'Mailbox'];
|
||||
function MailboxController($state, $timeout, stateAccounts, stateAccount, stateMailbox, encodeUriFilter, focus, Dialog, Account, Mailbox) {
|
||||
MailboxController.$inject = ['$state', '$timeout', '$mdDialog', 'stateAccounts', 'stateAccount', 'stateMailbox', 'encodeUriFilter', 'sgFocus', 'Dialog', 'Account', 'Mailbox'];
|
||||
function MailboxController($state, $timeout, $mdDialog, stateAccounts, stateAccount, stateMailbox, encodeUriFilter, focus, Dialog, Account, Mailbox) {
|
||||
var vm = this;
|
||||
|
||||
Mailbox.selectedFolder = stateMailbox;
|
||||
@@ -25,6 +25,7 @@
|
||||
vm.sort = sort;
|
||||
vm.sortedBy = sortedBy;
|
||||
vm.cancelSearch = cancelSearch;
|
||||
vm.newMessage = newMessage;
|
||||
vm.mode = { search: false };
|
||||
|
||||
function selectMessage(message) {
|
||||
@@ -88,6 +89,21 @@
|
||||
vm.selectedFolder.$filter();
|
||||
}
|
||||
|
||||
function newMessage($event) {
|
||||
$mdDialog.show({
|
||||
parent: angular.element(document.body),
|
||||
targetEvent: $event,
|
||||
clickOutsideToClose: true,
|
||||
escapeToClose: true,
|
||||
templateUrl: 'UIxMailEditor',
|
||||
controller: 'MessageEditorController',
|
||||
controllerAs: 'editor',
|
||||
locals: {
|
||||
stateAccounts: vm.accounts,
|
||||
stateMessage: vm.account.$newMessage()
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
angular
|
||||
|
||||
@@ -6,16 +6,21 @@
|
||||
/**
|
||||
* @ngInject
|
||||
*/
|
||||
MessageController.$inject = ['$scope', '$state', 'stateAccount', 'stateMailbox', 'stateMessage', 'encodeUriFilter', 'sgFocus', 'Dialog', 'Account', 'Mailbox', 'Message'];
|
||||
function MessageController($scope, $state, stateAccount, stateMailbox, stateMessage, encodeUriFilter, focus, Dialog, Account, Mailbox, Message) {
|
||||
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) {
|
||||
var vm = this;
|
||||
|
||||
vm.accounts = stateAccounts;
|
||||
vm.account = stateAccount;
|
||||
vm.mailbox = stateMailbox;
|
||||
vm.message = stateMessage;
|
||||
vm.service = Message;
|
||||
vm.tags = { searchText: '', selected: '' };
|
||||
vm.doDelete = doDelete;
|
||||
vm.reply = reply;
|
||||
vm.replyAll = replyAll;
|
||||
vm.forward = forward;
|
||||
vm.edit = edit;
|
||||
|
||||
// Watch the message model "flags" attribute to remove on-the-fly a tag from the IMAP message
|
||||
// when removed from the message viewer.
|
||||
@@ -39,6 +44,42 @@
|
||||
$state.go('mail.account.mailbox', { accountId: stateAccount.id, mailboxId: encodeUriFilter(stateMailbox.path) });
|
||||
});
|
||||
}
|
||||
|
||||
function showMailEditor($event, message) {
|
||||
$mdDialog.show({
|
||||
parent: angular.element(document.body),
|
||||
targetEvent: $event,
|
||||
clickOutsideToClose: true,
|
||||
escapeToClose: true,
|
||||
templateUrl: 'UIxMailEditor',
|
||||
controller: 'MessageEditorController',
|
||||
controllerAs: 'editor',
|
||||
locals: {
|
||||
stateAccounts: vm.accounts,
|
||||
stateMessage: message
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
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) {
|
||||
var message = vm.message.$editableContent();
|
||||
showMailEditor($event, message);
|
||||
}
|
||||
}
|
||||
|
||||
angular
|
||||
|
||||
@@ -6,8 +6,8 @@
|
||||
/**
|
||||
* @ngInject
|
||||
*/
|
||||
MessageEditorController.$inject = ['$stateParams', '$state', '$q', 'FileUploader', 'stateAccounts', 'stateMessage', '$timeout', 'encodeUriFilter', 'sgFocus', 'Dialog', 'Account', 'Mailbox', 'AddressBook', 'Preferences'];
|
||||
function MessageEditorController($stateParams, $state, $q, FileUploader, stateAccounts, stateMessage, $timeout, encodeUriFilter, focus, Dialog, Account, Mailbox, AddressBook, Preferences) {
|
||||
MessageEditorController.$inject = ['$stateParams', '$state', '$q', '$mdDialog', 'FileUploader', 'stateAccounts', 'stateMessage', '$timeout', 'encodeUriFilter', 'sgFocus', 'Dialog', 'Account', 'Mailbox', 'AddressBook', 'Preferences'];
|
||||
function MessageEditorController($stateParams, $state, $q, $mdDialog, FileUploader, stateAccounts, stateMessage, $timeout, encodeUriFilter, focus, Dialog, Account, Mailbox, AddressBook, Preferences) {
|
||||
var vm = this;
|
||||
|
||||
vm.autocomplete = {to: {}, cc: {}, bcc: {}};
|
||||
@@ -71,10 +71,7 @@
|
||||
if (vm.autosave)
|
||||
$timeout.cancel(vm.autosave);
|
||||
|
||||
if ($state.params.mailboxId)
|
||||
$state.go('mail.account.mailbox', { accountId: $state.params.accountId, mailboxId: $state.params.mailboxId });
|
||||
else
|
||||
$state.go('mail');
|
||||
$mdDialog.cancel();
|
||||
}
|
||||
|
||||
function send() {
|
||||
@@ -82,7 +79,7 @@
|
||||
$timeout.cancel(vm.autosave);
|
||||
|
||||
vm.message.$send().then(function(data) {
|
||||
$state.go('mail');
|
||||
$mdDialog.hide();
|
||||
}, function(data) {
|
||||
Dialog.alert(l(data.status), l(data.message));
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user