(js) Compose new message in a popup window

pull/232/head
Francis Lachapelle 2017-01-19 12:23:55 -05:00
parent 4fca484ed0
commit d7d88e2620
7 changed files with 101 additions and 45 deletions

1
NEWS
View File

@ -5,6 +5,7 @@ Enhancements
- [web] show locale codes beside language names in Preferences module
- [web] fixed visual glitches in Month view with Firefox
- [web] mail editor can now be expanded horizontally and automatically expands vertically
- [web] compose a new message inline or in a popup window
Bug fixes
- [core] remove all alarms before sending IMIP replies (#3925)

View File

@ -53,7 +53,13 @@
/* Mail account main windows */
"Welcome to the SOGo Mailer. Use the folder tree on the left to browse your mail accounts!" = "Welcome to the SOGo Mailer. Use the folder tree on the left to browse your mail accounts!";
"Read messages" = "Read messages";
/* Tooltip for fab button */
"Write a new message" = "Write a new message";
/* Tooltip for fab button */
"Write a message in new window" = "Write a message in new window";
"Share" = "Share";
"Account" = "Account";
"Shared Account" = "Shared Account";

View File

@ -12,7 +12,8 @@
nv-file-drop="nv-file-drop"
nv-file-over="nv-file-over"
over-class="sg-over-dropzone"
uploader="editor.uploader">
uploader="editor.uploader"
ng-controller="navController">
<form name="messageForm">
<md-toolbar>
<div class="md-toolbar-tools">
@ -231,7 +232,7 @@
<md-input-container class="md-block sg-mail-editor-content">
<textarea name="content" var:class="editorClass"
ck-locale="editor.localeCode"
rows="10"
rows="9"
ng-model="editor.message.editable.text"
md-no-resize="md-no-resize"
md-detect-hidden="md-detect-hidden" />

View File

@ -336,6 +336,28 @@
ng-click="mailbox.newMessage($event)">
<md-icon>edit</md-icon>
</md-button>
<md-fab-speed-dial
class="md-scale md-fab-bottom-right"
ng-cloak="ng-cloak"
md-direction="up">
<md-fab-trigger>
<md-button class="md-fab md-accent" label:aria-label="Write a new message">
<md-icon>edit</md-icon>
</md-button>
</md-fab-trigger>
<md-fab-actions>
<md-button class="md-fab md-raised md-mini" var:aria-label="Write a new message"
ng-click="mailbox.newMessage($event)">
<md-tooltip md-direction="left"><var:string label:value="Write a new message"/></md-tooltip>
<md-icon>open_in_browser</md-icon>
</md-button>
<md-button class="md-fab md-raised md-mini" var:aria-label="Write a message in new window"
ng-click="mailbox.newMessage($event, true)">
<md-tooltip md-direction="left"><var:string label:value="Write a message in new window"/></md-tooltip>
<md-icon>open_in_new</md-icon>
</md-button>
</md-fab-actions>
</md-fab-speed-dial>
</md-content>
</div>

View File

@ -6,8 +6,8 @@
/**
* @ngInject
*/
MailboxController.$inject = ['$window', '$scope', '$timeout', '$q', '$state', '$mdDialog', '$mdToast', 'stateAccounts', 'stateAccount', 'stateMailbox', 'sgHotkeys', 'encodeUriFilter', 'sgFocus', 'Dialog', 'Account', 'Mailbox'];
function MailboxController($window, $scope, $timeout, $q, $state, $mdDialog, $mdToast, stateAccounts, stateAccount, stateMailbox, sgHotkeys, encodeUriFilter, focus, Dialog, Account, Mailbox) {
MailboxController.$inject = ['$window', '$scope', '$timeout', '$q', '$state', '$mdDialog', '$mdToast', 'stateAccounts', 'stateAccount', 'stateMailbox', 'sgHotkeys', 'encodeUriFilter', 'sgSettings', 'sgFocus', 'Dialog', 'Account', 'Mailbox'];
function MailboxController($window, $scope, $timeout, $q, $state, $mdDialog, $mdToast, stateAccounts, stateAccount, stateMailbox, sgHotkeys, encodeUriFilter, sgSettings, focus, Dialog, Account, Mailbox) {
var vm = this,
defaultWindowTitle = angular.element($window.document).find('title').attr('sg-default') || "SOGo",
hotkeys = [];
@ -156,32 +156,59 @@
});
}
function newMessage($event) {
function newMessage($event, inPopup) {
var message;
if (vm.messageDialog === null) {
message = vm.account.$newMessage();
vm.messageDialog = $mdDialog
.show({
parent: angular.element(document.body),
targetEvent: $event,
clickOutsideToClose: false,
escapeToClose: false,
templateUrl: 'UIxMailEditor',
controller: 'MessageEditorController',
controllerAs: 'editor',
locals: {
stateAccount: vm.account,
stateMessage: message,
stateRecipients: []
}
})
.finally(function() {
vm.messageDialog = null;
});
if (inPopup)
_newMessageInPopup();
else {
message = vm.account.$newMessage();
vm.messageDialog = $mdDialog
.show({
parent: angular.element(document.body),
targetEvent: $event,
clickOutsideToClose: false,
escapeToClose: false,
templateUrl: 'UIxMailEditor',
controller: 'MessageEditorController',
controllerAs: 'editor',
locals: {
stateAccount: vm.account,
stateMessage: message
}
})
.finally(function() {
vm.messageDialog = null;
});
}
}
}
function _newMessageInPopup() {
var url = [sgSettings.baseURL(),
'UIxMailPopupView#!/Mail',
vm.account.id,
// The double-encoding is necessary
encodeUriFilter(encodeUriFilter(vm.selectedFolder.path)),
'new']
.join('/'),
wId = vm.selectedFolder.$id() + '/' + Math.random(0, 1000);
console.debug(url);
$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(','));
}
/**
* User has pressed up arrow key
*/

View File

@ -215,8 +215,8 @@
/**
* @ngInject
*/
MessageEditorControllerPopup.$inject = ['$window', '$mdDialog', 'stateAccounts', 'stateMessage'];
function MessageEditorControllerPopup($window, $mdDialog, stateAccounts, stateMessage) {
MessageEditorControllerPopup.$inject = ['$window', '$mdDialog', 'stateAccount', 'stateMessage'];
function MessageEditorControllerPopup($window, $mdDialog, stateAccount, stateMessage) {
$mdDialog
.show({
hasBackdrop: false,
@ -227,9 +227,8 @@
controller: 'MessageEditorController',
controllerAs: 'editor',
locals: {
stateAccounts: stateAccounts,
stateMessage: stateMessage,
stateRecipients: []
stateAccount: stateAccount,
stateMessage: stateMessage
}
})
.finally(function() {

View File

@ -284,22 +284,22 @@
_messageDialog(
$mdDialog
.show({
parent: angular.element(document.body),
targetEvent: $event,
clickOutsideToClose: false,
escapeToClose: false,
templateUrl: 'UIxMailEditor',
controller: 'MessageEditorController',
controllerAs: 'editor',
locals: {
stateAccount: vm.account,
stateMessage: message
}
})
.finally(function() {
_messageDialog(null);
closePopup();
})
parent: angular.element(document.body),
targetEvent: $event,
clickOutsideToClose: false,
escapeToClose: false,
templateUrl: 'UIxMailEditor',
controller: 'MessageEditorController',
controllerAs: 'editor',
locals: {
stateAccount: vm.account,
stateMessage: message
}
})
.finally(function() {
_messageDialog(null);
closePopup();
})
);
}
}