2006-10-30 23:38:22 +01:00
|
|
|
<?xml version='1.0' standalone='yes'?>
|
2009-06-26 19:48:28 +02:00
|
|
|
<!DOCTYPE var:component>
|
|
|
|
<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"
|
|
|
|
xmlns:label="OGo:label"
|
|
|
|
const:userDefaultsKeys="SOGoContactsCategories"
|
|
|
|
const:jsFiles="Common/user-model.js, Common/acl-model.js, Common/resource.js, Contacts/card-model.js, Contacts/addressbook-model.js"
|
|
|
|
className="UIxPageFrame"
|
|
|
|
title="name"
|
|
|
|
var:popup="isPopup">
|
|
|
|
<script type="text/javascript">
|
|
|
|
var contactFolders =<var:string value="contactFolders" const:escapeHTML="NO" />;
|
2014-06-19 21:52:57 +02:00
|
|
|
</script>
|
2009-06-26 19:48:28 +02:00
|
|
|
|
2015-01-17 05:26:59 +01:00
|
|
|
<!--
|
2009-09-03 16:18:13 +02:00
|
|
|
<div id="uploadDialog" style="display: none" class="dialog left">
|
|
|
|
<div>
|
2009-10-28 18:48:22 +01:00
|
|
|
<h3><var:string label:value="Import Cards"/></h3>
|
2012-09-24 18:18:18 +02:00
|
|
|
<p class="prompt"><var:string label:value="Select a vCard or LDIF file."/></p>
|
2009-12-23 22:14:18 +01:00
|
|
|
<form const:href="" name="uploadForm" id="uploadForm" method="post"
|
2014-06-19 21:52:57 +02:00
|
|
|
enctype="multipart/form-data"
|
|
|
|
onsubmit="return AIM.submit(this, {'onStart' : validateUploadForm,
|
|
|
|
'onComplete' : uploadCompleted})">
|
|
|
|
<p class="prompt"><input type="file" name="contactsFile" id="contactsFile" class="textField" required="required" />
|
|
|
|
<a href="#" class="button actionButton" id="uploadSubmit"
|
|
|
|
onclick="if($('uploadForm').onsubmit()) $('uploadForm').submit()">
|
|
|
|
<span><var:string label:value="Upload" /></span></a>
|
|
|
|
<a href="#" class="button" const:id="uploadCancel">
|
|
|
|
<span><var:string label:value="Cancel" /></span></a></p>
|
2009-09-03 16:18:13 +02:00
|
|
|
</form>
|
2012-09-24 18:18:18 +02:00
|
|
|
<hr/>
|
2009-09-03 16:18:13 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2009-09-03 19:53:38 +02:00
|
|
|
|
2015-02-26 16:58:17 +01:00
|
|
|
<div id="uploadResults" dropdown-content="dropdown-content" class="f-dropdown">
|
2009-09-03 19:53:38 +02:00
|
|
|
<div>
|
2009-10-28 18:48:22 +01:00
|
|
|
<h3><var:string label:value="Import Cards"/></h3>
|
2015-01-17 05:26:59 +01:00
|
|
|
<p id="uploadResultsContent">!- empty -</p>
|
2009-11-04 23:13:20 +01:00
|
|
|
<p><a href="#" class="button" const:id="uploadOK">
|
2014-06-19 21:52:57 +02:00
|
|
|
<span><var:string label:value="Done" /></span></a></p>
|
2012-09-24 18:18:18 +02:00
|
|
|
<hr/>
|
2009-09-03 19:53:38 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2009-06-26 19:48:28 +02:00
|
|
|
|
2015-02-26 16:58:17 +01:00
|
|
|
<ul class="f-dropdown" dropdown-content="dropdown-content" id="contactMenu">
|
2014-06-19 21:52:57 +02:00
|
|
|
<li><var:string label:value="Properties" /></li>
|
|
|
|
<li><var:string label:value="Categories" /></li>
|
2015-01-17 05:26:59 +01:00
|
|
|
<li>!- separator -</li>
|
2014-06-19 21:52:57 +02:00
|
|
|
<li><var:string label:value="Write" /></li>
|
|
|
|
<li><var:string label:value="Instant Message" /></li>
|
2015-01-17 05:26:59 +01:00
|
|
|
<li>!- separator -</li>
|
2014-06-19 21:52:57 +02:00
|
|
|
<li><var:string label:value="Delete" /></li>
|
2015-01-17 05:26:59 +01:00
|
|
|
<li>!- separator -</li>
|
2014-06-19 21:52:57 +02:00
|
|
|
<li><var:string label:value="Move To" /></li>
|
|
|
|
<li><var:string label:value="Copy To" /></li>
|
|
|
|
<li><var:string label:value="Export" /></li>
|
|
|
|
<li><var:string label:value="View Raw Source" /></li>
|
2015-01-17 05:26:59 +01:00
|
|
|
</ul>
|
|
|
|
-->
|
2015-01-28 01:05:35 +01:00
|
|
|
<!--
|
|
|
|
MAIN CONTENT ROW
|
|
|
|
Content of the application view injected injected in the element bellow
|
|
|
|
MUST be the first html element after body
|
|
|
|
SHOULD be a main tag (with role="main")
|
2014-06-19 21:52:57 +02:00
|
|
|
|
2015-01-28 01:05:35 +01:00
|
|
|
Templates script tag wrappers goes next
|
|
|
|
-->
|
2015-01-28 09:24:53 +01:00
|
|
|
<!-- fixme : consistently prefix attributes with or without data prefix-->
|
2015-02-26 16:58:17 +01:00
|
|
|
<main class="view md-layout-fill" ui-view="addressbooks" layout="row"><!-- addressbooks list --></main>
|
2015-01-26 03:30:27 +01:00
|
|
|
|
2015-01-28 01:05:35 +01:00
|
|
|
<!-- TEMPLATE SCRIPT WRAPPER -->
|
2015-02-26 17:27:36 +01:00
|
|
|
<script type="text/ng-template" id="UIxContactFoldersView">
|
2014-10-08 16:35:50 +02:00
|
|
|
|
2015-01-28 01:05:35 +01:00
|
|
|
<!-- dropdown menu for addressbook options button -->
|
2015-02-26 17:27:36 +01:00
|
|
|
<div id="addressbookProperties" class="f-dropdown icons-dropdown">
|
|
|
|
<ul class="button-group">
|
|
|
|
<li label:tooltip="Links to this Address Book"
|
|
|
|
tooltip-popup-delay="500">
|
|
|
|
<span class="button"
|
|
|
|
sg-dropdown-content-toggle="#addressbookLinks">
|
|
|
|
<i class="icon-hyperlink"><!-- links --></i>
|
2015-01-28 01:05:35 +01:00
|
|
|
</span>
|
|
|
|
</li>
|
2015-02-26 17:27:36 +01:00
|
|
|
<li label:tooltip="Rename"
|
|
|
|
tooltip-popup-delay="500">
|
|
|
|
<span class="button" ng-click="edit()">
|
|
|
|
<i class="icon-pencil"><!-- rename --></i>
|
2015-01-28 01:05:35 +01:00
|
|
|
</span>
|
|
|
|
</li>
|
2015-02-26 17:27:36 +01:00
|
|
|
<li ng-show="addressbook.isOwned"
|
|
|
|
label:tooltip="Sharing..."
|
|
|
|
tooltip-popup-delay="500">
|
|
|
|
<span class="button" ng-click="share()">
|
|
|
|
<i class="icon-share"><!-- share --></i>
|
2015-01-28 01:05:35 +01:00
|
|
|
</span>
|
|
|
|
</li>
|
2015-02-26 17:27:36 +01:00
|
|
|
<li label:tooltip="Import Cards"
|
|
|
|
tooltip-popup-delay="500">
|
|
|
|
<span class="button" ng-click="importCards()">
|
|
|
|
<i class="icon-file"><!-- import --></i>
|
2015-01-28 01:05:35 +01:00
|
|
|
</span>
|
|
|
|
</li>
|
2015-02-26 17:27:36 +01:00
|
|
|
<li label:tooltip="Export"
|
|
|
|
tooltip-popup-delay="500">
|
|
|
|
<span class="button" ng-click="exportCards()">
|
|
|
|
<i class="icon-ion-ios7-upload-outline"><!-- export --></i>
|
2015-01-28 01:05:35 +01:00
|
|
|
</span>
|
|
|
|
</li>
|
2015-02-26 17:27:36 +01:00
|
|
|
<li label:tooltip="Delete"
|
|
|
|
tooltip-popup-delay="500">
|
|
|
|
<span class="button" ng-click="confirmDelete(addressbook)">
|
|
|
|
<i class="icon-trash"><!-- delete --></i>
|
2015-01-28 01:05:35 +01:00
|
|
|
</span>
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
2014-10-08 16:35:50 +02:00
|
|
|
|
2015-01-28 01:05:35 +01:00
|
|
|
<!-- dropdown menu for new card split button
|
|
|
|
<ul id="newListDrop" class="f-dropdown">
|
2015-02-26 16:58:17 +01:00
|
|
|
<li><a class="tiny" ui-sref="addressbook.new({addressbookId: addressbook.id, contactType: 'list'})"><var:string label:value="New List"/></a></li>
|
2015-01-28 01:05:35 +01:00
|
|
|
</ul>
|
|
|
|
-->
|
2014-08-20 21:49:44 +02:00
|
|
|
|
2015-01-28 01:05:35 +01:00
|
|
|
<!-- dropdown menu for addressbook links
|
|
|
|
<div id="addressbookLinks" class="sg-dropdown-content joyride-tip-guide">
|
|
|
|
<span class="joyride-nub left">!- dropdown nub -</span>
|
|
|
|
<div class="joyride-content-wrapper">
|
|
|
|
<ul>
|
|
|
|
<li class="title"><var:string label:value="Links to this Address Book"/></li>
|
|
|
|
<li class="subtitle"><var:string label:value="CardDAV URL for Authenticated User Access"/></li>
|
|
|
|
<li class="value">{{addressbook.cardDavURL}}</li>
|
|
|
|
<var:if condition="isPublicAccessEnabled">
|
|
|
|
<li class="subtitle"><var:string label:value="CardDAV URL for Public Access"/></li>
|
|
|
|
<li class="value">{{addressbook.publicCardDavURL}}</li>
|
|
|
|
</var:if>
|
2014-06-19 21:52:57 +02:00
|
|
|
</ul>
|
2010-04-12 19:51:59 +02:00
|
|
|
</div>
|
2015-01-28 01:05:35 +01:00
|
|
|
</div>
|
|
|
|
-->
|
2014-08-20 21:49:44 +02:00
|
|
|
|
2015-01-28 01:05:35 +01:00
|
|
|
<!-- dropdown menu for subscriptions
|
|
|
|
<div id="folderSubscribe" class="sg-dropdown-content"
|
2015-02-26 16:58:17 +01:00
|
|
|
sg-subscribe="contact"
|
|
|
|
sg-subscribe-on-select="subscribeToFolder">!- subscription dropdown -</div>
|
2015-01-28 01:05:35 +01:00
|
|
|
-->
|
|
|
|
<!-- Sidenav -->
|
2015-02-20 04:05:53 +01:00
|
|
|
<md-sidenav class="md-sidenav-left" md-component-id="left" md-is-locked-open="$media('gt-md')" layout="column">
|
|
|
|
<md-toolbar class="md-tall" layout-align="end start">
|
|
|
|
<span class="sg-logo"> </span>
|
|
|
|
<h2 class="md-toolbar-tools md-toolbar-tools-bottom">
|
|
|
|
<span class="sg-md-title md-flex">{{activeUser.identification}}</span>
|
2015-01-28 01:05:35 +01:00
|
|
|
</h2>
|
|
|
|
</md-toolbar>
|
2015-02-20 04:05:53 +01:00
|
|
|
<md-content md-scroll-y="md-scroll-y" class="md-flex" ng-controller="LeftCtrl">
|
2015-01-28 03:45:56 +01:00
|
|
|
<md-button ng-click="close()" class="md-primary md-hide-gt-md">Close</md-button>
|
2015-01-28 01:05:35 +01:00
|
|
|
<md-list>
|
2015-02-26 17:27:36 +01:00
|
|
|
<md-item ng-repeat="folder in addressbooks track by folder.id"
|
|
|
|
ng-class="{_selected: addressbook.id==folder.id}"
|
|
|
|
ng-dblclick="edit($index)">
|
2015-01-28 01:05:35 +01:00
|
|
|
<md-item-content>
|
2015-02-26 17:27:36 +01:00
|
|
|
<i class="icon" ng-class="{'icon-earth': folder.isRemote, 'icon-address-book': folder.isEditable}"><!-- icon --></i>
|
|
|
|
<form ng-submit="save($index)">
|
|
|
|
<a ui-sref="addressbook({addressbookId: folder.id})"
|
|
|
|
ng-click="select($index)"
|
|
|
|
ng-show="editMode!=folder.id"
|
|
|
|
ng-cloak="ng-cloak">{{folder.name}}
|
2015-01-28 01:05:35 +01:00
|
|
|
</a>
|
2015-02-26 17:27:36 +01:00
|
|
|
<input class="folder-name" type="text"
|
|
|
|
ng-model="folder.name"
|
|
|
|
ng-show="editMode==folder.id"
|
|
|
|
ng-cloak="ng-cloak"
|
|
|
|
ng-blur="save($index)"
|
|
|
|
sg-focus-on="addressBookName_{{$index}}"
|
|
|
|
sg-escape="revertEditing($index)" />
|
2015-01-28 01:05:35 +01:00
|
|
|
</form>
|
2015-02-26 17:27:36 +01:00
|
|
|
<span class="icon" ng-cloak="ng-cloak">
|
|
|
|
<a class="icon" href="#"
|
|
|
|
dropdown-toggle="#addressbookProperties"
|
|
|
|
options="align:right"
|
|
|
|
ng-show="currentFolderIsConfigurable(folder)">
|
|
|
|
<i class="icon-cog"><!-- options --></i>
|
2015-01-28 01:05:35 +01:00
|
|
|
</a>
|
|
|
|
</span>
|
|
|
|
</md-item-content>
|
|
|
|
</md-item>
|
|
|
|
</md-list>
|
|
|
|
</md-content>
|
|
|
|
</md-sidenav>
|
2014-08-20 21:49:44 +02:00
|
|
|
|
2015-01-28 09:24:53 +01:00
|
|
|
<section layout="column" class="md-layout-fill">
|
2015-02-20 04:05:53 +01:00
|
|
|
<md-toolbar layout="column" layout-align="space-between start" class="md-tall toolbar-main">
|
2015-02-27 22:11:59 +01:00
|
|
|
<div class="md-toolbar-tools" layout="row" layout-align="space-between start" ng-controller="toggleCtrl">
|
|
|
|
<div class="sg-toolbar-group-1" layout="row">
|
|
|
|
<md-button ng-click="toggleLeft()" class="md-hide-gt-md sg-button-navicon">
|
|
|
|
<span class="md-icon-menu"></span>
|
|
|
|
</md-button>
|
|
|
|
<div class="sg-date-group" layout="column" layout-align="center end">
|
|
|
|
<p class="sg-day">monday</p>
|
|
|
|
<p class="sg-month">january</p>
|
|
|
|
<p class="sg-year">2015</p>
|
|
|
|
</div>
|
2015-02-27 21:26:18 +01:00
|
|
|
|
2015-02-27 22:11:59 +01:00
|
|
|
<p class="sg-md-display-3">15</p>
|
|
|
|
</div>
|
|
|
|
<div class="sg-toolbar-group-2">
|
|
|
|
<span class="md-icon-search"></span>
|
|
|
|
</div>
|
2015-02-27 21:26:18 +01:00
|
|
|
</div>
|
2015-02-27 22:11:59 +01:00
|
|
|
<div class="md-toolbar-tools md-toolbar-tools-bottom" layout="row" layout-align="space-between center">
|
|
|
|
<div class="cols-6" layout="row" layout-align="space-between center" style="padding-right: 16px">
|
|
|
|
<md-input-container class="sg-search-field-container">
|
|
|
|
<label style="color: white"><i class="md-icon-search"><!--icon--></i>Search</label>
|
|
|
|
<input name="folderSearch" type="search"
|
|
|
|
ng-model="search.filter" ng-keyup="doSearch($event)" style="color: white"/>
|
|
|
|
</md-input-container>
|
2015-02-26 06:39:18 +01:00
|
|
|
|
2015-02-20 04:05:53 +01:00
|
|
|
<div class="sg-toolbar-group">
|
2015-02-27 14:17:17 +01:00
|
|
|
<md-select class="sg-toolbar-sort md-contrast-light" label:placeholder="All"
|
|
|
|
ng-model="search.filter">
|
|
|
|
<md-option value="all">ALL</md-option>
|
2015-02-27 04:32:22 +01:00
|
|
|
</md-select>
|
2015-02-20 04:05:53 +01:00
|
|
|
<span class="md-icon-create"><!-- icon --></span>
|
|
|
|
</div>
|
2015-01-28 03:45:56 +01:00
|
|
|
</div>
|
2015-02-27 22:11:59 +01:00
|
|
|
<div class="spacer cols-8"><!-- spacer --></div>
|
2015-02-20 04:05:53 +01:00
|
|
|
</div>
|
2015-02-27 22:11:59 +01:00
|
|
|
</md-toolbar>
|
2015-02-20 04:05:53 +01:00
|
|
|
|
|
|
|
<div layout="row" class="md-flex" layout-align="space-between">
|
|
|
|
|
|
|
|
<md-content style="position: relative;" id="contactsList">
|
|
|
|
<style>
|
|
|
|
.vs-repeat-repeated-element {
|
|
|
|
width: 100%;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
<header class="sg-md-subheader">
|
|
|
|
<h2 class="sg-md-subhead-solo fg-sogoBlue-700">Contacts</h2>
|
|
|
|
</header>
|
|
|
|
<!-- Search field & special results
|
2015-02-26 16:58:17 +01:00
|
|
|
<input type="text" placeholder="Search" ng-model="search.filter" ng-keyup="doSearch($event)" />
|
|
|
|
<div ng-switch="search.status">
|
|
|
|
<div ng-switch-when="min-char" class="alert-bg">
|
2015-02-20 04:05:53 +01:00
|
|
|
<i class="icon-warning"></i><var:string label:value="Please enter at least three characters"/>
|
|
|
|
</div>
|
2015-02-26 16:58:17 +01:00
|
|
|
<div ng-switch-when="no-result" class="alert-bg">
|
2015-02-20 04:05:53 +01:00
|
|
|
<i class="icon-ion-search"></i><var:string label:value="No matching card"/>
|
|
|
|
</div>
|
2015-02-26 16:58:17 +01:00
|
|
|
<div ng-switch-when="remote-addressbook" ng-show="addressbook.cards.length == 0" class="alert-bg">
|
2015-02-20 04:05:53 +01:00
|
|
|
<i class="icon-ion-search"></i><var:string label:value="Initiate a search"/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
-->
|
2015-02-26 16:58:17 +01:00
|
|
|
<md-list vs-repeat="72" vs-scroll-parent="#contactsList">
|
2015-02-27 21:26:18 +01:00
|
|
|
<md-item ng-repeat="currentCard in addressbook.cards track by currentCard.id">
|
|
|
|
<md-item-content
|
|
|
|
ng-class="{_selected: card.id == currentCard.id}"
|
|
|
|
ng-click="select($index)">
|
2015-02-20 04:05:53 +01:00
|
|
|
<div class="md-tile-left">
|
|
|
|
<!--avatar--><!-- currentCard.tag = vcard || vlist -->
|
|
|
|
</div>
|
|
|
|
<div class="sg-tile-content">
|
2015-02-26 16:58:17 +01:00
|
|
|
<a ui-sref="addressbook.card.view({addressbookId: addressbook.id, cardId: currentCard.id})">
|
2015-02-20 04:05:53 +01:00
|
|
|
<div class="sg-md-body-multi contact-name" ng-bind-html="currentCard.$fullname()"><!-- cn --></div>
|
|
|
|
<div class="sg-md-subhead-multi contact-email">{{currentCard.$preferredEmail()}}</div>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
</md-item-content>
|
|
|
|
</md-item>
|
|
|
|
</md-list>
|
|
|
|
</md-content>
|
2015-02-26 16:58:17 +01:00
|
|
|
<md-content class="md-padding md-flex" ui-view="card"><!-- card view --></md-content>
|
2015-01-28 03:45:56 +01:00
|
|
|
</div>
|
2015-02-20 04:05:53 +01:00
|
|
|
|
|
|
|
</section>
|
2014-09-17 22:28:40 +02:00
|
|
|
|
2015-01-28 01:05:35 +01:00
|
|
|
</script>
|
|
|
|
<!-- modal for addressbook sharing options -->
|
2015-02-26 17:27:36 +01:00
|
|
|
<script type="text/ng-template" id="UIxUserRightsEditor">
|
2015-02-20 04:05:53 +01:00
|
|
|
<var:component className="UIxContactsUserRightsEditor" />
|
2015-01-26 04:33:00 +01:00
|
|
|
</script>
|
2015-02-26 17:27:36 +01:00
|
|
|
<script type="text/ng-template" id="UIxContactViewTemplate">
|
2015-02-20 04:05:53 +01:00
|
|
|
<var:component className="UIxContactViewTemplate" />
|
2014-12-17 20:58:20 +01:00
|
|
|
</script>
|
2009-06-26 19:48:28 +02:00
|
|
|
|
2015-02-26 17:27:36 +01:00
|
|
|
<var:string value="errorAlertJavaScript" const:escapeHTML="NO" />
|
2015-01-28 01:05:35 +01:00
|
|
|
|
2009-06-26 19:48:28 +02:00
|
|
|
</var:component>
|