342 lines
17 KiB
XML
342 lines
17 KiB
XML
<?xml version='1.0' standalone='yes'?>
|
|
<container
|
|
xmlns="http://www.w3.org/1999/xhtml"
|
|
xmlns:var="http://www.skyrix.com/od/binding"
|
|
xmlns:label="OGo:label">
|
|
<div class="view-list" layout="column">
|
|
|
|
<!-- in virtual mailbox mode -->
|
|
<md-toolbar class="md-whiteframe-z1 md-hue-3"
|
|
ng-hide="!app.showingAdvancedSearch || mailbox.mode.multiple">
|
|
<div class="md-toolbar-tools">
|
|
<md-input-container class="md-flex">
|
|
<label><var:string label:value="Search messages in"/></label>
|
|
<md-select ng-model="app.search.mailbox">
|
|
<md-option ng-value="">
|
|
<span>{{app.accounts[0].name}}</span>
|
|
</md-option>
|
|
<md-option ng-repeat="folder in
|
|
app.accounts[0].$flattenMailboxes()
|
|
track by folder.path"
|
|
ng-value="folder.path">
|
|
<span ng-class="'sg-child-level-' + folder.level">{{folder.name}}</span>
|
|
</md-option>
|
|
</md-select>
|
|
</md-input-container>
|
|
<md-menu>
|
|
<md-button class="sg-icon-button" label:aria-label="More search options" ng-click="$mdOpenMenu()">
|
|
<md-icon>settings</md-icon>
|
|
</md-button>
|
|
<md-menu-content>
|
|
<md-menu-item>
|
|
<sg-checkmark ng-model="app.search.subfolders"
|
|
sg-true-value="1"
|
|
sg-false-value="0">
|
|
<var:string label:value="Search subfolders"/>
|
|
</sg-checkmark>
|
|
</md-menu-item>
|
|
<md-menu-divider> <!-- divider --></md-menu-divider>
|
|
<md-menu-item>
|
|
<md-button ng-click="app.search.match='AND'">
|
|
<md-icon ng-class="{ 'icon-check': app.search.match == 'AND'}">
|
|
<!-- all --></md-icon><var:string label:value="Match all of the following"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-button ng-click="app.search.match='OR'">
|
|
<md-icon ng-class="{ 'icon-check': app.search.match == 'OR'}">
|
|
<!-- any --></md-icon><var:string label:value="Match any of the following"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
</md-menu-content>
|
|
</md-menu>
|
|
<md-button class="sg-icon-button"
|
|
label:aria-label="Search"
|
|
ng-click="app.toggleAdvancedSearch()"
|
|
ng-disabled="app.search.params.length == 0">
|
|
<md-icon ng-class="{'icon-stop': app.service.selectedFolder.$isLoading,
|
|
'icon-search': !app.service.selectedFolder.$isLoading}"><!-- icon --></md-icon>
|
|
</md-button>
|
|
</div>
|
|
</md-toolbar>
|
|
<!-- single-selection toolbars -->
|
|
<md-toolbar class="md-accent md-hue-1"
|
|
ng-hide="app.showingAdvancedSearch || mailbox.mode.multiple">
|
|
<!-- sort mode (default) -->
|
|
<div class="md-toolbar-tools" ng-hide="mailbox.mode.search">
|
|
<md-button class="sg-icon-button" label:aria-label="Search"
|
|
ng-click="mailbox.searchMode()">
|
|
<md-icon>search</md-icon>
|
|
</md-button>
|
|
<a href="javascript:void(0)" class="sg-folder-name"
|
|
ng-click="mailbox.searchMode()">{{mailbox.selectedFolder.name}}</a>
|
|
<md-menu>
|
|
<md-button class="sg-icon-button" label:aria-label="Sort"
|
|
ng-click="$mdOpenMenu()">
|
|
<md-icon>sort</md-icon>
|
|
</md-button>
|
|
<md-menu-content>
|
|
<md-menu-item>
|
|
<md-button ng-click="mailbox.sort('subject')">
|
|
<md-icon ng-class="{ 'icon-check': mailbox.sortedBy('subject') }">
|
|
<!-- subject --></md-icon> <var:string label:value="Subject"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-button ng-click="mailbox.sort('from')">
|
|
<md-icon ng-class="{ 'icon-check': mailbox.sortedBy('from') }">
|
|
<!-- from --></md-icon> <var:string label:value="From"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-button ng-click="mailbox.sort('date')">
|
|
<md-icon ng-class="{ 'icon-check': mailbox.sortedBy('date') }">
|
|
<!-- date --></md-icon> <var:string label:value="Date"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-button ng-click="mailbox.sort('size')">
|
|
<md-icon ng-class="{ 'icon-check': mailbox.sortedBy('size') }">
|
|
<!-- size --></md-icon> <var:string label:value="Size"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-divider> <!-- divider --></md-menu-divider>
|
|
<md-menu-item>
|
|
<sg-checkmark
|
|
label:aria-label="Descending Order"
|
|
ng-model="mailbox.service.$query.asc"
|
|
ng-change="mailbox.selectedFolder.$filter()"
|
|
sg-true-value="0"
|
|
sg-false-value="1"><var:string label:value="Descending Order"/></sg-checkmark>
|
|
</md-menu-item>
|
|
</md-menu-content>
|
|
</md-menu>
|
|
<md-button class="sg-icon-button" label:aria-label="Get Mail" ng-click="mailbox.selectedFolder.$filter()" >
|
|
<md-icon>refresh</md-icon>
|
|
</md-button>
|
|
</div>
|
|
<!-- search mode -->
|
|
<form class="md-toolbar-tools sg-toolbar-secondary"
|
|
name="searchForm"
|
|
layout="row"
|
|
ng-show="mailbox.mode.search"
|
|
sg-search="mailbox.selectedFolder.$filter(null, [{ searchBy: searchField, searchInput: searchText }])"
|
|
sg-allow-dot="false">
|
|
<md-button class="sg-icon-button"
|
|
sg-search-cancel="mailbox.cancelSearch()"
|
|
label:aria-label="Back">
|
|
<md-icon>arrow_back</md-icon>
|
|
</md-button>
|
|
<md-input-container class="md-flex" md-no-float="md-no-float">
|
|
<input name="folderSearch" type="search" var:minlength="minimumSearchLength" label:placeholder="Search" sg-focus-on="search" />
|
|
<div ng-messages="searchForm.folderSearch.$error" ng-show="searchForm.folderSearch.$dirty">
|
|
<div ng-message="minlength"><var:string value="minimumSearchLengthLabel"/></div>
|
|
</div>
|
|
</md-input-container>
|
|
<md-input-container flex="25">
|
|
<md-select label:aria-label="Search scope">
|
|
<md-option value="subject" selected="selected"><var:string label:value="Subject"/></md-option>
|
|
<md-option value="from"><var:string label:value="Sender"/></md-option>
|
|
<md-option value="subject_or_from"><var:string label:value="Subject or Sender"/></md-option>
|
|
<md-option value="to_or_cc"><var:string label:value="To or Cc"/></md-option>
|
|
<md-option value="body"><var:string label:value="Entire Message"/></md-option>
|
|
</md-select>
|
|
</md-input-container>
|
|
</form>
|
|
</md-toolbar>
|
|
|
|
<!-- multiple-selection mode -->
|
|
<md-toolbar class="md-hue-1 sg-toolbar-secondary"
|
|
ng-show="mailbox.mode.multiple">
|
|
<div class="md-toolbar-tools">
|
|
<md-button class="sg-icon-button" ng-click="mailbox.unselectMessages()">
|
|
<md-icon>arrow_back</md-icon>
|
|
</md-button>
|
|
<label>{{mailbox.service.selectedFolder.$selectedCount()}} <var:string label:value="selected"/></label>
|
|
<div class="md-flex"><!-- spacer --></div>
|
|
<md-button class="sg-icon-button" ng-click="mailbox.selectAll()">
|
|
<md-tooltip md-direction="bottom"><var:string label:value="Select All"/></md-tooltip>
|
|
<md-icon>select_all</md-icon>
|
|
</md-button>
|
|
<md-button class="sg-icon-button" ng-click="mailbox.confirmDeleteSelectedMessages()">
|
|
<md-icon>delete</md-icon>
|
|
</md-button>
|
|
<md-button class="sg-icon-button" ng-click="mailbox.markOrUnMarkMessagesAsJunk()">
|
|
<md-icon ng-hide="mailbox.service.selectedFolder.type == 'junk'">thumb_down</md-icon>
|
|
<md-icon ng-hide="mailbox.service.selectedFolder.type != 'junk'">thumb_up</md-icon>
|
|
</md-button>
|
|
<md-menu>
|
|
<md-button class="sg-icon-button" label:aria-label="More messages options" ng-click="$mdOpenMenu()">
|
|
<md-icon>more_vert</md-icon>
|
|
</md-button>
|
|
<md-menu-content width="2">
|
|
<md-menu-item>
|
|
<md-button ng-click="mailbox.markSelectedMessagesAsFlagged()">
|
|
<var:string label:value="Flag"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-button ng-click="mailbox.markSelectedMessagesAsUnread()">
|
|
<var:string label:value="Mark as Unread"/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-button ng-click="mailbox.selectedFolder.saveSelectedMessages()">
|
|
<var:string label:value="Save As..."/>
|
|
</md-button>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-menu>
|
|
<md-button label:aria-label="Copy To" ng-click="$mdOpenMenu($event)">
|
|
<var:string label:value="Copy To"/>
|
|
</md-button>
|
|
<md-menu-content width="4">
|
|
<div ng-repeat="account in mailbox.accounts track by account.id">
|
|
<md-menu-item>
|
|
<md-menu>
|
|
<md-button class="md-primary" ng-click="$mdOpenMenu($event)">{{account.name}}</md-button>
|
|
<md-menu-content class="md-dense" width="4">
|
|
<div ng-repeat="folder in
|
|
account.$flattenMailboxes({ all: true })
|
|
track by folder.path">
|
|
<md-menu-item>
|
|
<md-button class="sg-no-wrap"
|
|
ng-disabled="mailbox.service.selectedFolder.id == folder.id"
|
|
ng-click="mailbox.copySelectedMessages(folder.id)">
|
|
<span ng-class="'sg-child-level-' + folder.level">{{folder.name}}</span>
|
|
</md-button>
|
|
</md-menu-item>
|
|
</div>
|
|
</md-menu-content>
|
|
</md-menu>
|
|
</md-menu-item>
|
|
</div>
|
|
</md-menu-content>
|
|
</md-menu>
|
|
</md-menu-item>
|
|
<md-menu-item>
|
|
<md-menu>
|
|
<md-button label:aria-label="Move To" ng-click="$mdOpenMenu($event)">
|
|
<var:string label:value="Move To"/>
|
|
</md-button>
|
|
<md-menu-content width="4">
|
|
<div ng-repeat="account in mailbox.accounts track by account.id">
|
|
<md-menu-item>
|
|
<md-menu>
|
|
<md-button class="md-primary" ng-click="$mdOpenMenu($event)">{{account.name}}</md-button>
|
|
<md-menu-content class="md-dense" width="4">
|
|
<div ng-repeat="folder in
|
|
account.$flattenMailboxes({ all: true })
|
|
track by folder.path">
|
|
<md-menu-item>
|
|
<md-button class="sg-no-wrap"
|
|
ng-disabled="mailbox.service.selectedFolder.id == folder.id"
|
|
ng-click="mailbox.moveSelectedMessages(folder.id)">
|
|
<span ng-class="'sg-child-level-' + folder.level">{{folder.name}}</span>
|
|
</md-button>
|
|
</md-menu-item>
|
|
</div>
|
|
</md-menu-content>
|
|
</md-menu>
|
|
</md-menu-item>
|
|
</div>
|
|
</md-menu-content>
|
|
</md-menu>
|
|
</md-menu-item>
|
|
</md-menu-content>
|
|
</md-menu>
|
|
</div>
|
|
</md-toolbar>
|
|
|
|
<md-divider><!-- divider --></md-divider>
|
|
|
|
<md-content id="messagesList" layout="column" class="md-flex">
|
|
<md-subheader>
|
|
<!-- message count -->
|
|
<span ng-switch="mailbox.service.selectedFolder.getLength()">
|
|
<span ng-switch-when="0"><var:string label:value="No message"/></span>
|
|
<span ng-switch-default="true">{{mailbox.service.selectedFolder.getLength()}} <var:string label:value="messages"/></span>
|
|
</span>
|
|
</md-subheader>
|
|
<md-virtual-repeat-container class="md-flex" md-top-index="mailbox.selectedFolder.$topIndex">
|
|
<md-list class="sg-section-list"
|
|
ng-class="{ 'sg-list-selectable': mailbox.mode.multiple }">
|
|
<md-list-item
|
|
ng-class="{'md-default-theme md-accent md-bg md-hue-2': mailbox.selectedFolder.isSelectedMessage(currentMessage.uid, currentMessage.$mailbox.path),
|
|
unread: !currentMessage.isread}"
|
|
md-virtual-repeat="currentMessage in mailbox.service.selectedFolder"
|
|
md-on-demand="md-on-demand" md-item-size="56"
|
|
ng-click="mailbox.selectMessage(currentMessage)"
|
|
aria-label="{{currentMessage.subject}}">
|
|
<div class="md-secondary sg-avatar-selectable"
|
|
label:aria-label="Select Message"
|
|
ng-class="{ 'sg-avatar-selected': currentMessage.selected }"
|
|
ng-click="mailbox.toggleMessageSelection($event, currentMessage)">
|
|
<sg-avatar-image
|
|
sg-email="mailbox.service.selectedFolder.type == 'sent' ? currentMessage.to[0].email : currentMessage.from[0].email"
|
|
size="40"><!-- avatar --></sg-avatar-image>
|
|
</div>
|
|
<div class="sg-category"
|
|
ng-repeat="tag in currentMessage.flags | limitTo:5"
|
|
ng-style="{ 'background-color': currentMessage.constructor.$tags[tag][1], left: ($index * 3) + 'px' }"><!-- calendar color --></div>
|
|
<div class="sg-tile-content">
|
|
<div class="sg-md-subhead">
|
|
<div>
|
|
<span class="sg-label-outline ng-hide"
|
|
ng-show="mailbox.service.$virtualMode">{{currentMessage.$mailbox.name}}</span>
|
|
<md-icon class="ng-hide"
|
|
ng-show="currentMessage.priority.level == 1 ||
|
|
currentMessage.priority.level == 2"
|
|
ng-class="{'md-warn': currentMessage.priority.level == 1}">error</md-icon>
|
|
{{mailbox.service.selectedFolder.type == 'sent' ? currentMessage.$shortAddress('to' ) : currentMessage.$shortAddress('from' )}}
|
|
</div>
|
|
<div class="sg-tile-date" ng-bind="currentMessage.relativedate"><!-- date --></div>
|
|
</div>
|
|
<div class="sg-md-body">
|
|
<div>{{currentMessage.subject}}</div>
|
|
<div class="sg-tile-size" ng-bind="currentMessage.size"><!-- size --></div>
|
|
</div>
|
|
</div>
|
|
<div class="sg-tile-icons">
|
|
<md-icon class="ng-hide" ng-show="currentMessage.isflagged">star</md-icon>
|
|
<md-icon class="ng-hide" ng-show="currentMessage.isanswered">reply</md-icon>
|
|
<md-icon class="ng-hide" ng-show="currentMessage.isforwarded">forward</md-icon>
|
|
<md-icon class="ng-hide" ng-show="currentMessage.hasattachment">attach_file</md-icon>
|
|
</div>
|
|
<div class="sg-progress-linear-bottom">
|
|
<md-progress-linear class="md-accent"
|
|
md-mode="indeterminate"
|
|
ng-show="currentMessage.$isLoading()"><!-- message loading progress --></md-progress-linear>
|
|
</div>
|
|
</md-list-item>
|
|
</md-list>
|
|
</md-virtual-repeat-container>
|
|
<div class="sg-progress-circular-floating"
|
|
ng-show="mailbox.service.selectedFolder.$isLoading">
|
|
<md-progress-circular class="md-accent"
|
|
md-mode="indeterminate"
|
|
md-diameter="32"><!-- mailbox loading progress --></md-progress-circular>
|
|
</div>
|
|
<md-button class="md-fab md-fab-bottom-right md-accent"
|
|
label:aria-label="Write a new message"
|
|
ng-click="mailbox.newMessage($event)">
|
|
<md-icon>edit</md-icon>
|
|
</md-button>
|
|
</md-content>
|
|
</div>
|
|
|
|
<div id="detailView" class="view-detail"
|
|
layout="column" layout-align="start center"
|
|
ng-class="{ 'sg-close': !mailbox.service.selectedFolder.hasSelectedMessage() }"
|
|
md-colors="::{backgroundColor: 'default-background-200'}"
|
|
ui-view="message">
|
|
<md-content class="hide show-gt-md md-flex"
|
|
md-colors="::{backgroundColor: 'default-background-200'}"
|
|
layout="column" layout-align="center center" layout-fill="layout-fill">
|
|
<div class="sg-md-title"
|
|
md-colors="::{color: 'default-background-500'}"><var:string label:value="No message selected"/></div>
|
|
</md-content>
|
|
</div>
|
|
|
|
</container>
|