2006-06-15 21:34:10 +02:00
|
|
|
<?xml version="1.0" standalone="yes"?>
|
2007-08-15 23:13:20 +02:00
|
|
|
<!DOCTYPE var:component>
|
2014-11-25 22:09:55 +01:00
|
|
|
<var:component
|
2015-02-26 17:27:36 +01:00
|
|
|
xmlns="http://www.w3.org/1999/xhtml"
|
|
|
|
xmlns:var="http://www.skyrix.com/od/binding"
|
|
|
|
xmlns:const="http://www.skyrix.com/od/constant"
|
2015-08-03 17:53:54 +02:00
|
|
|
xmlns:rsrc="OGo:url"
|
2015-03-18 19:59:06 +01:00
|
|
|
xmlns:label="OGo:label"
|
2015-02-26 17:27:36 +01:00
|
|
|
className="UIxPageFrame"
|
|
|
|
title="title"
|
2016-08-04 23:34:29 +02:00
|
|
|
const:jsFiles="vendor/ckeditor/ckeditor.js, vendor/ckeditor/ck.js, Common.js, Preferences.services.js, Contacts.services.js, Scheduler.services.js, Mailer.js, Mailer.services.js, vendor/angular-file-upload.min.js, vendor/FileSaver.min.js">
|
2015-02-26 17:27:36 +01:00
|
|
|
<script type="text/javascript">
|
2015-09-03 22:10:05 +02:00
|
|
|
var mailAccounts = <var:string value="mailAccounts" const:escapeHTML="NO" />;
|
|
|
|
var userNames = <var:string value="userNames" const:escapeHTML="NO" />;
|
|
|
|
var unseenCountFolders = <var:string value="unseenCountFolders" const:escapeHTML="NO" />;
|
2007-08-15 23:13:20 +02:00
|
|
|
</script>
|
2014-11-25 22:09:55 +01:00
|
|
|
|
2016-03-08 19:20:34 +01:00
|
|
|
<main class="view"
|
|
|
|
layout="row" layout-fill="layout-fill"
|
|
|
|
ui-view="mailboxes"
|
|
|
|
ng-controller="navController"><!-- mailboxes list --></main>
|
2006-12-22 17:58:30 +01:00
|
|
|
|
2016-08-04 23:34:29 +02:00
|
|
|
<sg-draggable-helper>
|
|
|
|
<md-icon>email</md-icon>
|
|
|
|
<sg-draggable-helper-counter class="md-default-theme md-warn md-hue-1 md-bg"><!-- count --></sg-draggable-helper-counter>
|
|
|
|
</sg-draggable-helper>
|
|
|
|
|
2015-02-26 17:27:36 +01:00
|
|
|
<script type="text/ng-template" id="UIxMailMainFrame">
|
2010-05-27 16:41:59 +02:00
|
|
|
|
2015-06-26 19:13:25 +02:00
|
|
|
<!-- Sidenav -->
|
2016-03-08 19:20:34 +01:00
|
|
|
<md-sidenav class="md-sidenav-left md-whiteframe-z1" layout="column" layout-fill="layout-fill"
|
2015-11-27 22:40:23 +01:00
|
|
|
md-component-id="left" md-is-locked-open="isGtMedium"
|
2016-03-08 19:20:34 +01:00
|
|
|
ng-class="{ 'sg-close': leftIsClose }">
|
2015-04-03 17:34:05 +02:00
|
|
|
<var:component className="UIxSidenavToolbarTemplate" />
|
2016-04-21 19:40:47 +02:00
|
|
|
<md-content class="md-flex" layout="column" md-scroll-y="md-scroll-y"
|
|
|
|
md-colors="::{ backgroundColor: 'default-background-300' }">
|
2017-05-18 21:31:38 +02:00
|
|
|
<section class="sg-account-section"
|
|
|
|
layout="column"
|
2016-05-26 21:48:15 +02:00
|
|
|
ng-repeat="account in ::app.accounts track by account.id"
|
|
|
|
ng-class="{ 'md-flex': account.$expanded }">
|
|
|
|
<md-list>
|
2017-05-18 21:31:38 +02:00
|
|
|
<md-list-item ng-click="app.toggleAccountState(account)">
|
|
|
|
<div class="sg-no-wrap"
|
|
|
|
aria-label="{{ ::'Toggle visibility' | loc }}"
|
|
|
|
ng-bind="::account.name"><!-- account name --></div>
|
2016-09-14 21:57:49 +02:00
|
|
|
<md-menu class="md-secondary">
|
|
|
|
<md-icon label:aria-label="Options"
|
2016-11-01 20:54:56 +01:00
|
|
|
ng-click="$mdMenu.open($event)"
|
2016-09-14 21:57:49 +02:00
|
|
|
md-menu-origin="md-menu-origin">more_vert</md-icon>
|
|
|
|
<md-menu-content width="3">
|
2017-05-18 21:31:38 +02:00
|
|
|
<md-menu-item ng-show="::account.id == 0">
|
2016-09-14 21:57:49 +02:00
|
|
|
<md-button
|
|
|
|
label:aria-label="Delegation..."
|
|
|
|
ng-click="app.delegate(account)">
|
|
|
|
<var:string label:value="Delegation..."/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
2017-05-18 21:31:38 +02:00
|
|
|
<md-menu-item ng-show="::app.showSubscribedOnly == 1">
|
2016-09-14 21:57:49 +02:00
|
|
|
<md-button
|
|
|
|
label:aria-label="Subscribe..."
|
|
|
|
ng-click="app.subscribe(account)">
|
|
|
|
<var:string label:value="Subscribe..."/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item>
|
|
|
|
<md-button
|
|
|
|
label:aria-label="New Folder..."
|
|
|
|
ng-click="app.newFolder(account)">
|
|
|
|
<var:string label:value="New Folder..."/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
</md-menu-content>
|
|
|
|
</md-menu>
|
|
|
|
</md-list-item>
|
2016-05-26 21:48:15 +02:00
|
|
|
</md-list>
|
2017-05-18 21:31:38 +02:00
|
|
|
<div class="sg-quota ng-hide" ng-show="::account.$quota">
|
2015-12-22 03:14:39 +01:00
|
|
|
<md-progress-linear md-mode="determinate"
|
|
|
|
ng-class="{ 'md-warn': account.$quota.percent > 70 }"
|
|
|
|
value="{{account.$quota.percent}}"><!-- quota --></md-progress-linear>
|
2016-01-04 17:50:25 +01:00
|
|
|
<div class="sg-md-caption md-default-theme md-fg md-primary"
|
2016-05-26 21:48:15 +02:00
|
|
|
ng-show="account.$expanded"
|
2016-01-07 22:33:41 +01:00
|
|
|
ng-class="{ 'md-warn': account.$quota.percent > 70 }">{{account.$quota.description}}</div>
|
2015-12-22 03:14:39 +01:00
|
|
|
</div>
|
2016-05-26 21:48:15 +02:00
|
|
|
<md-virtual-repeat-container ng-class="{ 'md-flex': account.$expanded }">
|
2015-12-18 22:33:01 +01:00
|
|
|
<md-list>
|
2017-05-18 21:31:38 +02:00
|
|
|
<md-list-item
|
|
|
|
class="sg-mailbox-list-item md-clickable md-default-theme md-background md-hue-1"
|
|
|
|
ng-class="{'md-bg sg-selected': folder.id == app.service.selectedFolder.id}"
|
|
|
|
md-virtual-repeat="folder in account" md-item-size="48" md-on-demand="md-on-demand"
|
|
|
|
sg-mailbox="folder"
|
|
|
|
sg-droppable="app.isDroppableFolder(dragFolder, folder)"
|
|
|
|
sg-drop="app.dragSelectedMessages(dragFolder, folder, dragMode)">
|
|
|
|
<!-- sgMailboxListItem directive -->
|
2015-12-18 22:33:01 +01:00
|
|
|
</md-list-item>
|
|
|
|
</md-list>
|
|
|
|
</md-virtual-repeat-container>
|
2016-01-08 22:34:13 +01:00
|
|
|
<md-divider><!-- divider --></md-divider>
|
2015-04-29 17:23:21 +02:00
|
|
|
</section>
|
2015-01-09 21:58:11 +01:00
|
|
|
</md-content>
|
|
|
|
</md-sidenav>
|
|
|
|
|
2016-03-08 19:20:34 +01:00
|
|
|
<section layout="column" layout-fill="layout-fill" ui-view="mailbox">
|
2016-02-02 21:05:25 +01:00
|
|
|
<md-toolbar layout="row" layout-align="space-between center" class="toolbar-main">
|
2016-03-30 03:59:21 +02:00
|
|
|
<var:component className="UIxTopnavToolbar"/>
|
2016-02-02 21:05:25 +01:00
|
|
|
</md-toolbar>
|
2016-04-21 19:40:47 +02:00
|
|
|
<md-content class="md-flex"
|
|
|
|
md-colors="::{backgroundColor: 'default-background-200'}"
|
2017-05-18 21:31:38 +02:00
|
|
|
layout="column" layout-align="center center">
|
2016-04-21 19:40:47 +02:00
|
|
|
<div class="sg-md-title"
|
|
|
|
md-colors="::{color: 'default-background-500'}">
|
2016-02-02 21:05:25 +01:00
|
|
|
<var:string label:value="No mailbox selected"/>
|
|
|
|
</div>
|
|
|
|
</md-content>
|
|
|
|
</section>
|
2015-07-13 21:22:58 +02:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<script type="text/ng-template" id="UIxMailFolderTemplate">
|
2015-09-15 03:35:34 +02:00
|
|
|
<md-toolbar layout="row" layout-align="space-between center" class="toolbar-main"
|
2017-05-18 21:31:38 +02:00
|
|
|
ng-hide="mailbox.service.$virtualPath">
|
2016-03-30 03:59:21 +02:00
|
|
|
<var:component className="UIxTopnavToolbar"/>
|
2015-09-10 22:38:30 +02:00
|
|
|
</md-toolbar>
|
2015-09-15 03:35:34 +02:00
|
|
|
|
|
|
|
<!-- Advanced search toolbar -->
|
2016-04-21 19:40:47 +02:00
|
|
|
<md-toolbar layout="column" class="md-tall toolbar-main md-hue-3"
|
2017-05-18 21:31:38 +02:00
|
|
|
ng-show="mailbox.service.$virtualPath">
|
2015-09-15 03:35:34 +02:00
|
|
|
<div class="md-toolbar-tools">
|
2015-12-04 21:00:58 +01:00
|
|
|
<div layout="column" class="md-flex">
|
2015-09-15 03:35:34 +02:00
|
|
|
<div class="pseudo-input-container--compact">
|
|
|
|
<label class="pseudo-input-label"><var:string label:value="Add a Criteria"/></label>
|
|
|
|
</div>
|
|
|
|
<div layout="row">
|
2015-09-17 21:06:48 +02:00
|
|
|
<span class="md-button sg-outline-button" ng-click="app.addSearchParam('subject')">
|
2015-09-15 03:35:34 +02:00
|
|
|
<var:string label:value="Subject"/>
|
2015-09-17 21:06:48 +02:00
|
|
|
</span>
|
|
|
|
<span class="md-button sg-outline-button" ng-click="app.addSearchParam('from')">
|
2015-09-15 03:35:34 +02:00
|
|
|
<var:string label:value="From"/>
|
2015-09-17 21:06:48 +02:00
|
|
|
</span>
|
|
|
|
<span class="md-button sg-outline-button" ng-click="app.addSearchParam('to')">
|
2015-09-15 03:35:34 +02:00
|
|
|
<var:string label:value="To"/>
|
2015-09-17 21:06:48 +02:00
|
|
|
</span>
|
|
|
|
<span class="md-button sg-outline-button" ng-click="app.addSearchParam('cc')">
|
2015-09-15 03:35:34 +02:00
|
|
|
<var:string label:value="Cc"/>
|
2015-09-17 21:06:48 +02:00
|
|
|
</span>
|
|
|
|
<span class="md-button sg-outline-button" ng-click="app.addSearchParam('body')">
|
2015-09-15 03:35:34 +02:00
|
|
|
<var:string label:value="Body"/>
|
2015-09-17 21:06:48 +02:00
|
|
|
</span>
|
2015-09-15 03:35:34 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2015-12-04 21:00:58 +01:00
|
|
|
<md-button type="button" class="sg-icon-button" ng-click="app.hideAdvancedSearch()">
|
|
|
|
<md-icon>close</md-icon>
|
|
|
|
</md-button>
|
|
|
|
</div>
|
|
|
|
<div class="md-toolbar-tools">
|
|
|
|
<md-chips class="md-flex"
|
2016-10-21 16:55:59 +02:00
|
|
|
ng-show="app.search.params.length != 0 || app.currentSearchParam"
|
2015-12-04 21:00:58 +01:00
|
|
|
ng-model="app.search.params"
|
2016-05-18 20:47:33 +02:00
|
|
|
md-transform-chip="app.newSearchParam($chip)"
|
2017-03-22 20:35:05 +01:00
|
|
|
md-add-on-blur="true">
|
2015-12-04 21:00:58 +01:00
|
|
|
<input sg-focus-on="advancedSearch" type="text"
|
|
|
|
ng-disabled="app.currentSearchParam.length == 0"
|
|
|
|
sg-placeholder="app.search.options[app.currentSearchParam]"/>
|
|
|
|
<md-chip-template>
|
2016-01-07 21:19:53 +01:00
|
|
|
<span class="md-caption" ng-show="$chip.negative == 0">(<var:string label:value="match"/></span>
|
|
|
|
<span class="md-caption" ng-show="$chip.negative == 1">(<var:string label:value="does not match"/></span>
|
2017-05-18 21:31:38 +02:00
|
|
|
<span class="md-caption" ng-bind="$chip.searchBy"><!-- search by --></span>
|
|
|
|
<span ng-bind="$chip.searchInput"><!-- search input --></span>
|
2015-12-04 21:00:58 +01:00
|
|
|
</md-chip-template>
|
|
|
|
</md-chips>
|
2015-09-15 03:35:34 +02:00
|
|
|
</div>
|
2015-07-13 21:22:58 +02:00
|
|
|
</md-toolbar>
|
2015-09-03 22:10:05 +02:00
|
|
|
|
2015-07-13 21:22:58 +02:00
|
|
|
<div layout="row" class="md-flex">
|
|
|
|
<var:component className="UIxMailFolderTemplate" />
|
|
|
|
</div>
|
2014-11-25 22:09:55 +01:00
|
|
|
</script>
|
2010-05-27 16:41:59 +02:00
|
|
|
|
2017-05-18 21:31:38 +02:00
|
|
|
<!-- template of contextual menu for a mailbox -->
|
|
|
|
<script type="text/ng-template" id="UIxMailFolderMenu">
|
|
|
|
<div md-whiteframe="3">
|
|
|
|
<md-menu-content width="3">
|
|
|
|
<md-menu-item>
|
|
|
|
<md-button type="button" md-menu-align-target="md-menu-align-target"
|
|
|
|
ng-click="$menuCtrl.markFolderRead()">
|
|
|
|
<var:string label:value="Mark Folder Read"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item ng-hide="::$menuCtrl.folder.$isNoInferiors">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.newFolder()">
|
|
|
|
<var:string label:value="New Subfolder..."/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item ng-show="::$menuCtrl.folder.$isEditable">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.editFolder()">
|
|
|
|
<var:string label:value="Rename"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item>
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.compactFolder()">
|
|
|
|
<var:string label:value="Compact"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item ng-show="::$menuCtrl.folder.$isEditable">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.confirmDelete()">
|
|
|
|
<var:string label:value="Delete"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item ng-show="::($menuCtrl.folder.type == 'trash')">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.emptyTrashFolder()">
|
|
|
|
<var:string label:value="Empty Trash"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item>
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.folder.exportFolder()">
|
|
|
|
<var:string label:value="Export"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item>
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.showAdvancedSearch()">
|
|
|
|
<var:string label:value="Search"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-divider ng-show="::$menuCtrl.folder.$canFolderAs()"><!-- divider --></md-menu-divider>
|
|
|
|
<md-menu-item ng-show="::$menuCtrl.folder.$canFolderAs()">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.setFolderAs('Drafts')">
|
|
|
|
<var:string label:value="Set as Drafts"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item ng-show="::$menuCtrl.folder.$canFolderAs()">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.setFolderAs('Sent')">
|
|
|
|
<var:string label:value="Set as Sent"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item ng-show="::$menuCtrl.folder.$canFolderAs()">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.setFolderAs('Trash')">
|
|
|
|
<var:string label:value="Set as Trash"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-item ng-show="::$menuCtrl.folder.$canFolderAs()">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.setFolderAs('Junk')">
|
|
|
|
<var:string label:value="Set as Junk"/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
<md-menu-divider ng-show="::($menuCtrl.folder.type != 'additional')"><!-- divider --></md-menu-divider>
|
|
|
|
<md-menu-item ng-show="::($menuCtrl.folder.type != 'additional')">
|
|
|
|
<md-button type="button" ng-click="$menuCtrl.share()">
|
|
|
|
<var:string label:value="Sharing..."/>
|
|
|
|
</md-button>
|
|
|
|
</md-menu-item>
|
|
|
|
</md-menu-content>
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<!-- template of modal for mailbox sharing options -->
|
2015-06-26 19:13:25 +02:00
|
|
|
<script type="text/ng-template" id="UIxUserRightsEditor">
|
|
|
|
<var:component className="UIxMailUserRightsEditor" />
|
|
|
|
</script>
|
|
|
|
|
2017-05-18 21:31:38 +02:00
|
|
|
<!-- template of mail viewer -->
|
2015-02-26 17:27:36 +01:00
|
|
|
<script type="text/ng-template" id="UIxMailViewTemplate">
|
|
|
|
<var:component className="UIxMailViewTemplate" />
|
2014-11-25 22:09:55 +01:00
|
|
|
</script>
|
2014-12-11 17:24:22 +01:00
|
|
|
|
2007-08-15 23:13:20 +02:00
|
|
|
</var:component>
|