2015-05-06 04:06:13 +02:00
|
|
|
/* -*- Mode: javascript; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* JavaScript for SOGo.MailerUI module */
|
|
|
|
|
|
|
|
(function() {
|
|
|
|
'use strict';
|
|
|
|
|
2016-05-02 15:39:55 +02:00
|
|
|
angular.module('SOGo.MailerUI', ['ngCookies', 'ui.router', 'ck', 'angularFileUpload', 'SOGo.Common', 'SOGo.ContactsUI', 'SOGo.SchedulerUI', 'ngAnimate', 'SOGo.PreferencesUI'])
|
2015-05-06 04:06:13 +02:00
|
|
|
.config(configure)
|
|
|
|
.run(runBlock);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2018-06-28 21:44:12 +02:00
|
|
|
configure.$inject = ['$stateProvider', '$urlServiceProvider'];
|
|
|
|
function configure($stateProvider, $urlServiceProvider) {
|
2015-05-06 04:06:13 +02:00
|
|
|
$stateProvider
|
|
|
|
.state('mail', {
|
|
|
|
url: '/Mail',
|
|
|
|
views: {
|
|
|
|
mailboxes: {
|
|
|
|
templateUrl: 'UIxMailMainFrame', // UI/Templates/MailerUI/UIxMailMainFrame.wox
|
2015-07-13 21:22:58 +02:00
|
|
|
controller: 'MailboxesController',
|
|
|
|
controllerAs: 'app'
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
resolve: {
|
2015-05-06 18:12:27 +02:00
|
|
|
stateAccounts: stateAccounts
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('mail.account', {
|
|
|
|
url: '/:accountId',
|
|
|
|
abstract: true,
|
|
|
|
views: {
|
|
|
|
mailbox: {
|
2015-07-13 21:22:58 +02:00
|
|
|
template: '<ui-view/>'
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
resolve: {
|
2015-05-06 18:12:27 +02:00
|
|
|
stateAccount: stateAccount
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
})
|
2015-09-10 22:38:30 +02:00
|
|
|
.state('mail.account.virtualMailbox', {
|
|
|
|
url: '/virtual',
|
|
|
|
views: {
|
|
|
|
'mailbox@mail': {
|
|
|
|
templateUrl: 'UIxMailFolderTemplate', // UI/Templates/MailerUI/UIxMailFolderTemplate.wox
|
|
|
|
controller: 'MailboxController',
|
|
|
|
controllerAs: 'mailbox'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
resolve: {
|
2015-09-14 19:48:06 +02:00
|
|
|
stateMailbox: stateVirtualMailbox
|
2015-09-10 22:38:30 +02:00
|
|
|
}
|
|
|
|
})
|
|
|
|
.state('mail.account.virtualMailbox.message', {
|
|
|
|
url: '/:mailboxId/:messageId',
|
|
|
|
views: {
|
|
|
|
message: {
|
|
|
|
templateUrl: 'UIxMailViewTemplate', // UI/Templates/MailerUI/UIxMailViewTemplate.wox
|
|
|
|
controller: 'MessageController',
|
|
|
|
controllerAs: 'viewer'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
resolve: {
|
2015-09-14 19:48:06 +02:00
|
|
|
stateMailbox: stateVirtualMailboxOfMessage,
|
2015-09-29 14:58:23 +02:00
|
|
|
stateMessages: stateMessages,
|
2015-09-10 22:38:30 +02:00
|
|
|
stateMessage: stateMessage
|
2016-05-30 18:29:58 +02:00
|
|
|
},
|
|
|
|
onEnter: onEnterMessage,
|
|
|
|
onExit: onExitMessage
|
2015-09-10 22:38:30 +02:00
|
|
|
})
|
2016-01-15 21:09:13 +01:00
|
|
|
.state('mail.account.inbox', {
|
|
|
|
url: '/inbox',
|
2016-03-03 21:03:42 +01:00
|
|
|
onEnter: onEnterInbox
|
2016-01-15 21:09:13 +01:00
|
|
|
})
|
2015-05-06 04:06:13 +02:00
|
|
|
.state('mail.account.mailbox', {
|
|
|
|
url: '/:mailboxId',
|
|
|
|
views: {
|
|
|
|
'mailbox@mail': {
|
|
|
|
templateUrl: 'UIxMailFolderTemplate', // UI/Templates/MailerUI/UIxMailFolderTemplate.wox
|
2015-07-13 21:22:58 +02:00
|
|
|
controller: 'MailboxController',
|
|
|
|
controllerAs: 'mailbox'
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
resolve: {
|
2015-05-06 18:12:27 +02:00
|
|
|
stateMailbox: stateMailbox,
|
|
|
|
stateMessages: stateMessages
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
})
|
2015-08-02 19:25:38 +02:00
|
|
|
// .state('mail.account.mailbox.newMessage', {
|
|
|
|
// url: '/new',
|
|
|
|
// views: {
|
|
|
|
// 'mailbox@mail': {
|
|
|
|
// templateUrl: 'UIxMailEditor', // UI/Templates/MailerUI/UIxMailEditor.wox
|
|
|
|
// controller: 'MessageEditorController',
|
|
|
|
// controllerAs: 'editor'
|
|
|
|
// }
|
|
|
|
// },
|
|
|
|
// resolve: {
|
|
|
|
// stateMessage: stateNewMessage
|
|
|
|
// }
|
|
|
|
// })
|
2015-05-06 04:06:13 +02:00
|
|
|
.state('mail.account.mailbox.message', {
|
|
|
|
url: '/:messageId',
|
|
|
|
views: {
|
|
|
|
message: {
|
|
|
|
templateUrl: 'UIxMailViewTemplate', // UI/Templates/MailerUI/UIxMailViewTemplate.wox
|
2015-07-13 21:22:58 +02:00
|
|
|
controller: 'MessageController',
|
|
|
|
controllerAs: 'viewer'
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
},
|
2016-01-13 22:24:37 +01:00
|
|
|
onEnter: onEnterMessage,
|
2016-01-13 18:34:15 +01:00
|
|
|
onExit: onExitMessage,
|
2015-05-06 04:06:13 +02:00
|
|
|
resolve: {
|
2015-05-06 18:12:27 +02:00
|
|
|
stateMessage: stateMessage
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
});
|
2015-08-02 19:25:38 +02:00
|
|
|
// .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'
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// });
|
2015-05-06 04:06:13 +02:00
|
|
|
|
|
|
|
// if none of the above states are matched, use this as the fallback
|
2018-06-28 21:44:12 +02:00
|
|
|
$urlServiceProvider.rules.otherwise('/Mail/0/inbox');
|
2017-08-29 17:45:24 +02:00
|
|
|
|
|
|
|
// Try to register SOGo has an handler for mailto: links
|
|
|
|
if (navigator && navigator.registerProtocolHandler) {
|
|
|
|
var mailtoURL = window.location.origin + window.ApplicationBaseURL + 'UIxMailPopupView#!/Mail/0/INBOX/new?%s';
|
2019-01-08 16:57:38 +01:00
|
|
|
try {
|
|
|
|
navigator.registerProtocolHandler('mailto', mailtoURL, 'SOGo');
|
|
|
|
}
|
|
|
|
catch (e) {}
|
2017-08-29 17:45:24 +02:00
|
|
|
}
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
|
2015-05-06 18:12:27 +02:00
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2017-04-21 17:56:28 +02:00
|
|
|
stateAccounts.$inject = ['$window', '$q', 'Account'];
|
|
|
|
function stateAccounts($window, $q, Account) {
|
|
|
|
var accounts = Account.$findAll($window.mailAccounts),
|
2015-07-13 21:22:58 +02:00
|
|
|
promises = [];
|
2015-05-06 18:12:27 +02:00
|
|
|
// Fetch list of mailboxes for each account
|
|
|
|
angular.forEach(accounts, function(account, i) {
|
|
|
|
var mailboxes = account.$getMailboxes();
|
2017-04-21 17:56:28 +02:00
|
|
|
if (i === 0)
|
|
|
|
// Make sure we have the list of mailboxes of the first account
|
|
|
|
promises.push(mailboxes.then(function(objects) {
|
|
|
|
return account;
|
|
|
|
}));
|
|
|
|
else
|
|
|
|
// Don't wait for external accounts
|
|
|
|
promises.push(account);
|
2015-05-06 18:12:27 +02:00
|
|
|
});
|
|
|
|
return $q.all(promises);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
|
|
|
stateAccount.$inject = ['$stateParams', 'stateAccounts'];
|
|
|
|
function stateAccount($stateParams, stateAccounts) {
|
|
|
|
return _.find(stateAccounts, function(account) {
|
|
|
|
return account.id == $stateParams.accountId;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2017-08-29 17:45:24 +02:00
|
|
|
stateMailbox.$inject = ['$q', '$stateParams', 'stateAccount', 'decodeUriFilter', 'Mailbox'];
|
|
|
|
function stateMailbox($q, $stateParams, stateAccount, decodeUriFilter, Mailbox) {
|
2016-01-15 21:09:13 +01:00
|
|
|
var mailbox,
|
2019-06-27 17:56:44 +02:00
|
|
|
mailboxId = decodeUriFilter(decodeUriFilter($stateParams.mailboxId)),
|
2015-07-13 21:22:58 +02:00
|
|
|
_find;
|
2015-09-14 19:48:06 +02:00
|
|
|
|
2015-05-06 18:12:27 +02:00
|
|
|
// Recursive find function
|
2015-07-13 21:22:58 +02:00
|
|
|
_find = function(mailboxes) {
|
2015-05-06 18:12:27 +02:00
|
|
|
var mailbox = _.find(mailboxes, function(o) {
|
|
|
|
return o.path == mailboxId;
|
|
|
|
});
|
|
|
|
if (!mailbox) {
|
|
|
|
angular.forEach(mailboxes, function(o) {
|
|
|
|
if (!mailbox && o.children && o.children.length > 0) {
|
|
|
|
mailbox = _find(o.children);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
return mailbox;
|
|
|
|
};
|
2015-09-10 22:38:30 +02:00
|
|
|
|
2016-05-18 20:47:33 +02:00
|
|
|
if (Mailbox.selectedFolder && !Mailbox.$virtualMode)
|
2016-01-08 22:31:06 +01:00
|
|
|
Mailbox.selectedFolder.$isLoading = true;
|
|
|
|
|
2019-03-22 15:36:39 +01:00
|
|
|
return stateAccount.$getMailboxes().then(function (mailboxes) {
|
|
|
|
mailbox = _find(mailboxes);
|
|
|
|
if (mailbox) {
|
|
|
|
mailbox.$topIndex = 0;
|
|
|
|
mailbox.selectFolder();
|
|
|
|
return mailbox;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
// Mailbox not found
|
|
|
|
$state.go('mail.account', { accountId: stateMailbox.$account.id });
|
|
|
|
}
|
|
|
|
});
|
2016-01-15 21:09:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2017-05-18 21:31:38 +02:00
|
|
|
onEnterInbox.$inject = ['$transition$', 'encodeUriFilter', 'Mailbox'];
|
|
|
|
function onEnterInbox($transition, encodeUriFilter, Mailbox) {
|
|
|
|
var stateAccountPromise = $transition.injector().getAsync('stateAccount');
|
|
|
|
return stateAccountPromise.then(function(stateAccount) {
|
|
|
|
if (stateAccount.$mailboxes.length > 0) {
|
|
|
|
return $transition.router.stateService.target('mail.account.mailbox', {
|
|
|
|
accountId: stateAccount.id,
|
|
|
|
mailboxId: encodeUriFilter(stateAccount.$mailboxes[0].path)
|
|
|
|
});
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
Mailbox.selectedFolder = false;
|
|
|
|
return $transition.router.stateService.target('mail');
|
|
|
|
}
|
|
|
|
});
|
2015-05-06 18:12:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2017-05-18 21:31:38 +02:00
|
|
|
stateMessages.$inject = ['$q', '$state', 'Mailbox', 'stateMailbox'];
|
|
|
|
function stateMessages($q, $state, Mailbox, stateMailbox) {
|
|
|
|
var promise;
|
|
|
|
|
2015-09-10 22:38:30 +02:00
|
|
|
if (Mailbox.$virtualMode)
|
|
|
|
return [];
|
|
|
|
|
2017-05-18 21:31:38 +02:00
|
|
|
if (stateMailbox)
|
|
|
|
promise = stateMailbox.$filter().catch(function() {
|
|
|
|
// Mailbox not found
|
|
|
|
return $q.reject('Mailbox not found');
|
|
|
|
});
|
|
|
|
else
|
|
|
|
promise = $q.reject("Mailbox doesn't exist");
|
|
|
|
|
|
|
|
return promise;
|
2015-05-06 18:12:27 +02:00
|
|
|
}
|
|
|
|
|
2015-07-13 21:22:58 +02:00
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2015-08-02 19:25:38 +02:00
|
|
|
// stateNewMessage.$inject = ['stateAccount'];
|
|
|
|
// function stateNewMessage(stateAccount) {
|
|
|
|
// return stateAccount.$newMessage();
|
|
|
|
// }
|
2015-07-13 21:22:58 +02:00
|
|
|
|
2015-09-14 19:48:06 +02:00
|
|
|
/**
|
|
|
|
* Return a VirtualMailbox instance
|
|
|
|
* @ngInject
|
|
|
|
*/
|
|
|
|
stateVirtualMailbox.$inject = ['$q', 'Mailbox'];
|
|
|
|
function stateVirtualMailbox($q, Mailbox) {
|
|
|
|
if (Mailbox.$virtualMode)
|
|
|
|
return Mailbox.selectedFolder;
|
|
|
|
else
|
|
|
|
return $q.reject("No virtual mailbox defined");
|
|
|
|
}
|
2015-09-10 22:38:30 +02:00
|
|
|
|
2015-09-14 19:48:06 +02:00
|
|
|
/**
|
|
|
|
* Return a Mailbox instance from a VirtualMailbox instance
|
|
|
|
* @ngInject
|
|
|
|
*/
|
|
|
|
stateVirtualMailboxOfMessage.$inject = ['$q', 'Mailbox', 'decodeUriFilter', '$stateParams'];
|
|
|
|
function stateVirtualMailboxOfMessage($q, Mailbox, decodeUriFilter, $stateParams) {
|
|
|
|
var mailboxId = decodeUriFilter($stateParams.mailboxId);
|
|
|
|
|
2015-09-24 22:48:20 +02:00
|
|
|
if (Mailbox.$virtualMode) {
|
|
|
|
Mailbox.selectedFolder.resetSelectedMessage();
|
2015-09-14 19:48:06 +02:00
|
|
|
return _.find(Mailbox.selectedFolder.$mailboxes, function(mailboxObject) {
|
|
|
|
return mailboxObject.path == mailboxId;
|
|
|
|
});
|
2015-09-24 22:48:20 +02:00
|
|
|
}
|
2015-09-14 19:48:06 +02:00
|
|
|
else
|
|
|
|
return $q.reject("No virtual mailbox defined for message");
|
2015-09-10 22:38:30 +02:00
|
|
|
}
|
|
|
|
|
2015-05-06 18:12:27 +02:00
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2015-09-24 22:48:20 +02:00
|
|
|
stateMessage.$inject = ['Mailbox', 'encodeUriFilter', '$stateParams', '$state', 'stateMailbox', 'stateMessages'];
|
|
|
|
function stateMessage(Mailbox, encodeUriFilter, $stateParams, $state, stateMailbox, stateMessages) {
|
2015-09-10 22:38:30 +02:00
|
|
|
var message;
|
|
|
|
|
|
|
|
message = _.find(stateMailbox.$messages, function(messageObject) {
|
2016-01-08 22:31:06 +01:00
|
|
|
return messageObject.uid == parseInt($stateParams.messageId);
|
2015-05-06 18:12:27 +02:00
|
|
|
});
|
|
|
|
|
2015-07-15 19:44:17 +02:00
|
|
|
if (message) {
|
2016-05-30 18:29:58 +02:00
|
|
|
return message.$reload({useCache: true});
|
2015-07-15 19:44:17 +02:00
|
|
|
}
|
|
|
|
else {
|
2015-05-06 18:12:27 +02:00
|
|
|
// Message not found
|
2015-07-13 21:22:58 +02:00
|
|
|
$state.go('mail.account.mailbox', { accountId: stateMailbox.$account.id, mailboxId: encodeUriFilter(stateMailbox.path) });
|
2015-07-15 19:44:17 +02:00
|
|
|
}
|
2015-05-06 18:12:27 +02:00
|
|
|
}
|
|
|
|
|
2016-01-13 22:24:37 +01:00
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
|
|
|
onEnterMessage.$inject = ['$stateParams', 'stateMailbox'];
|
|
|
|
function onEnterMessage($stateParams, stateMailbox) {
|
|
|
|
stateMailbox.selectedMessage = parseInt($stateParams.messageId);
|
|
|
|
}
|
|
|
|
|
2016-01-13 18:34:15 +01:00
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
|
|
|
onExitMessage.$inject = ['stateMailbox'];
|
|
|
|
function onExitMessage(stateMailbox) {
|
2016-05-18 20:47:33 +02:00
|
|
|
delete stateMailbox.selectedMessage;
|
2016-01-13 18:34:15 +01:00
|
|
|
}
|
|
|
|
|
2015-05-06 18:12:27 +02:00
|
|
|
/**
|
|
|
|
* @ngInject
|
|
|
|
*/
|
2017-05-18 21:31:38 +02:00
|
|
|
runBlock.$inject = ['$window', '$transitions', '$log', '$state', 'Mailbox'];
|
|
|
|
function runBlock($window, $transitions, $log, $state, Mailbox) {
|
|
|
|
if (!$window.DebugEnabled)
|
|
|
|
$state.defaultErrorHandler(function() {
|
|
|
|
// Don't report any state error
|
|
|
|
});
|
|
|
|
$transitions.onError({ to: 'mail.**' }, function(transition) {
|
|
|
|
if (transition.to().name != 'mail' &&
|
|
|
|
!transition.ignored() &&
|
|
|
|
transition.error().message.indexOf('superseded') < 0) {
|
2018-06-28 21:44:12 +02:00
|
|
|
$log.error('transition error to ' + transition.to().name + ': ' + transition.error().detail);
|
2017-05-18 21:31:38 +02:00
|
|
|
// Unselect everything
|
|
|
|
Mailbox.selectedFolder = false;
|
|
|
|
$state.go('mail');
|
|
|
|
}
|
2015-07-29 17:47:01 +02:00
|
|
|
});
|
2015-05-06 04:06:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
})();
|