sogo/UI/Templates/ContactsUI/UIxContactFoldersView.wox

604 lines
29 KiB
Plaintext
Raw Normal View History

<?xml version='1.0' standalone='yes'?>
<!DOCTYPE var:component>
<var:component
2014-06-19 21:52:57 +02: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:uix="OGo:uix"
xmlns:label="OGo:label"
xmlns:rsrc="OGo:url"
const:userDefaultsKeys="SOGoContactsCategories"
2014-10-01 20:27:58 +02:00
const:jsFiles="Common/acl-model.js, Common/resource.js, Contacts/card-model.js, Contacts/addressbook-model.js"
2014-06-19 21:52:57 +02:00
className="UIxPageFrame"
title="name"
var:popup="isPopup">
<script type="text/javascript">
var contactFolders = <var:string value="contactFolders" const:escapeHTML="NO"/>;
</script>
<div id="uploadDialog" style="display: none" class="dialog left">
<div>
<h3><var:string label:value="Import Cards"/></h3>
<p class="prompt"><var:string label:value="Select a vCard or LDIF file."/></p>
<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>
</form>
<hr/>
</div>
</div>
<div id="uploadResults" data-dropdown-content="dropdown-content" class="f-dropdown">
<div>
<h3><var:string label:value="Import Cards"/></h3>
<p id="uploadResultsContent"><!-- empty --></p>
<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>
<hr/>
</div>
</div>
2014-06-19 21:52:57 +02:00
<ul class="f-dropdown" data-dropdown-content="dropdown-content" id="contactMenu">
<li><var:string label:value="Properties" /></li>
<li><var:string label:value="Categories" /></li>
<li><!-- separator --></li>
<li><var:string label:value="Write" /></li>
<li><var:string label:value="Instant Message" /></li>
<li><!-- separator --></li>
<li><var:string label:value="Delete" /></li>
<li><!-- separator --></li>
<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>
</ul>
<div>
2014-10-01 20:27:58 +02:00
<div data-ui-view="addressbooks"><!-- addressbooks list --></div>
2014-09-30 21:17:44 +02:00
<!-- modal for addressbook sharing options -->
2014-10-01 20:27:58 +02:00
<script type="text/ng-template" id="addressbookSharing.html">
<div id="modalACL">
<h2>Sharing</h2>
<div>
<!-- left side -->
2014-09-30 21:17:44 +02:00
<div id="usersList">
<div>
<ul>
<li data-ng-repeat="user in users" data-ng-click="selectUser($index)" data-ng-class="{_selected: $index==selected}">
<span>
<i data-ng-class="(user.userClass == 'public-user') ? 'icon-user4' : 'icon-vcard'"><!-- spacer --></i>
{{user.displayName}}</span>
<span class="subscriptionArea" data-ng-hide="user.userClass == 'public-user'">
<input type="checkbox" ng-model="user.isSubscribed" ng-checked="user.isSubscribed"
ng-disabled="user.isSubscribed" ng-change="dirtyObjects()" />
<span><var:string label:value="Subscribe User"/></span></span>
</li>
</ul>
</div>
<div>
<form ng-submit="addUser(userToAdd)" class="addContactsToolbar">
<input type="search" ng-model="userToAdd" label:placeholder="add aclUser" typeahead-wait-ms="1000"
typeahead="user for user in getContacts($viewValue) | filter:$viewValue" class="form-control" />
</form>
<button data-ng-click="addUser(userToAdd)">Add User</button>
<button ng-disabled="removeButton()" data-ng-click="removeUser()">Remove User</button>
</div>
</div>
<!-- right side -->
<div id="AccessRightList">
<input id="uid" type="hidden" name="uid" var:value="uid"/>
<div class="title">
<label><var:string label:value="Access rights to"/><br />
<span id="folderName" class="value">{{addressbook.name}}</span></label>
<label><var:string label:value="For user"/><br />
<span class="value">{{userSelected.displayName}}</span></label>
</div>
<div class="calendarUserRights">
<ul>
<li data-ng-show="displayUserRights()">
<input type="checkbox" ng-checked="userSelected.aclOptions.canCreateObjects"
ng-model="userSelected.aclOptions.canCreateObjects" ng-change="dirtyObjects()" />
<var:string label:value="This person can add cards to this addressbook."/></li>
<li data-ng-show="displayUserRights()" ng-model="displayUserRights">
<input type="checkbox" ng-checked="userSelected.aclOptions.canEditObjects"
ng-model="userSelected.aclOptions.canEditObjects" ng-change="dirtyObjects()" />
<var:string label:value="This person can edit the cards of this addressbook."/></li>
<li data-ng-show="displayUserRights()" ng-model="displayUserRights">
<input type="checkbox" ng-checked="userSelected.aclOptions.canEraseObjects"
ng-model="userSelected.aclOptions.canEraseObjects" ng-change="dirtyObjects()" />
<var:string label:value="This person can erase cards from this addressbook."/></li>
<li data-ng-hide="!userSelected.displayName">
<input type="checkbox" ng-checked="userSelected.aclOptions.canViewObjects"
ng-model="userSelected.aclOptions.canViewObjects" ng-change="dirtyObjects()" />
<var:string label:value="This person can read the cards of this addressbook."/></li>
</ul>
</div>
</div>
</div>
<div id="aclButtons">
<button data-ng-click="closeModal()">Close</button>
<button data-ng-click="saveModal()">Save</button>
</div>
</div>
<span class="close-reveal-modal" data-ng-click="closeModal()"><i class="icon-close"><!-- close --></i></span>
</script>
2014-08-06 22:06:58 +02:00
<script type="text/ng-template" id="addressbooks.html">
<!-- dropdown menu for addressbook options button -->
2014-06-19 21:52:57 +02:00
<div id="addressbookProperties" class="f-dropdown icons-dropdown" data-dropdown-content="dropdown-content">
<ul class="button-group">
<li>
<span class="button"><i class="icon-hyperlink"><!-- links --></i></span>
</li>
2014-10-01 20:27:58 +02:00
<li data-ng-hide="addressbook.isRemote">
<span class="button"><i class="icon-pencil" data-ng-click="edit()"><!-- rename --></i></span>
</li>
2014-10-01 20:27:58 +02:00
<li data-ng-hide="addressbook.isRemote">
<span class="button" data-ng-click="share()"><i class="icon-share"><!-- share --></i></span>
</li>
2014-10-01 20:27:58 +02:00
<li data-ng-hide="addressbook.isRemote">
<span class="button" data-ng-click="importCards()"><i class="icon-file"><!-- import --></i></span>
</li>
2014-10-01 20:27:58 +02:00
<li data-ng-hide="addressbook.isRemote">
<span class="button" data-ng-click="confirmDelete(addressbook)"><i class="icon-trash"><!-- delete --></i></span>
</li>
2014-06-19 21:52:57 +02:00
</ul>
</div>
<!-- dropdown menu for new card split button -->
<ul id="newListDrop" class="f-dropdown">
<li><a class="tiny" data-ui-sref="addressbook.new({addressbookId: addressbook.id, contactType: 'list'})"><var:string label:value="New List"/></a></li>
</ul>
2014-08-06 22:06:58 +02:00
<div id="addressbooksList" class="folders-list">
<div class="newItemsToolbar">
<a class="button tiny radius split" data-ui-sref="addressbook.new({addressbookId: addressbook.id, contactType: 'card'})"><var:string label:value="New Card"/><span data-dropdown-toggle="#newListDrop"></span></a><br/>
2014-08-06 22:06:58 +02:00
</div>
<ul>
2014-08-06 22:06:58 +02:00
<li data-ng-repeat="folder in addressbooks"
data-ng-class="{_selected: addressbook.id==folder.id}"
data-ng-dblclick="edit($index)">
<i class="icon" data-ng-class="{'icon-earth': folder.isRemote, 'icon-address-book': folder.isEditable}"><!-- icon --></i>
<form data-ng-submit="save($index)">
<a data-ui-sref="addressbook({addressbookId: folder.id})"
2014-06-19 21:52:57 +02:00
data-ng-click="select($index)"
data-ng-show="editMode!=folder.id"
2014-08-06 22:06:58 +02:00
data-ng-cloak="ng-cloak">{{folder.name}}</a>
<input class="folder-name" type="text"
data-ng-model="folder.name"
data-ng-show="editMode==folder.id"
data-ng-cloak="ng-cloak"
data-ng-blur="save($index)"
data-sg-focus-on="addressBookName_{{$index}}"
data-sg-escape="revertEditing($index)"/>
2014-08-06 22:06:58 +02:00
</form>
<span class="icon" data-ng-cloak="ng-cloak"><a class="icon" href="#" data-dropdown-toggle="#addressbookProperties" data-options="align:right" data-ng-show="addressbook.id==folder.id"><i class="icon-cog"><!-- options --></i></a></span>
2014-08-06 22:06:58 +02:00
</li>
</ul>
<div class="buttonsToolbar">
<button data-ng-click="newAddressbook()" class="button small" label:title="New Addressbook..."><i class="icon-plus"><!-- new --></i></button>
2014-08-06 22:06:58 +02:00
<a href="#" class="button small" label:title="Subscribe to an Addressbook..."><i class="icon-earth"><!-- subscribe --></i></a>
</div>
<!--<var:if condition="hasContactSelectionButtons">
2014-08-06 22:06:58 +02:00
<div class="contactSelection">
<var:component value="selectorComponent" />
2014-06-19 21:52:57 +02:00
</div>
</var:if>-->
2014-06-19 21:52:57 +02:00
</div>
<div class="dragHandle" id="dragHandle"><!-- space --></div>
<div id="rightPanel">
2014-08-06 22:06:58 +02:00
<div id="contactsList">
<div class="buttonsToolbar searchToolbar">
<div class="input-content">
<div class="input-search">
<i class="icon-ion-search"><!-- search --></i>
<input type="text" placeholder="Search" data-ng-model="search.filter" data-ng-keyup="doSearch($event)" />
</div>
</div>
<!--<div class="input-options">
<a href="#" class="button"><i class="icon-cog"><!- options -></i></a>
</div>-->
</div>
<div data-ng-switch="search.status">
<div data-ng-switch-when="min-char" class="alert-bg">
<i class="icon-warning"><!-- warn --></i><var:string label:value="Please enter at least three characters"/>
</div>
<div data-ng-switch-when="no-result" class="alert-bg">
<i class="icon-ion-search"><!-- no result --></i><var:string label:value="No matching card"/>
</div>
<div data-ng-switch-when="remote-addressbook" data-ng-show="addressbook.cards.length == 0" class="alert-bg">
2014-08-06 22:06:58 +02:00
<i class="icon-ion-search"><!-- search --></i><var:string label:value="Initiate a search"/>
</div>
</div>
<ul>
<li data-ng-repeat="currentCard in addressbook.cards"
data-ng-class="{_selected: card.id == currentCard.id}">
<!-- <input type="checkbox" class="card-picture left"/> -->
<a data-ui-sref="addressbook.card.view({addressbookId: addressbook.id, cardId: currentCard.id})">
<span class="card-picture" data-ng-switch="currentCard.tag">
<i data-ng-switch-when="vcard" class="icon-ion-ios7-person"><!-- card --></i>
<i data-ng-switch-when="vlist" class="icon-ion-ios7-people"><!-- list --></i>
2014-08-06 22:06:58 +02:00
</span>
<div class="name" data-ng-bind-html="currentCard.$fullname()"><!-- cn --></div>
<div><span data-ng-show="currentCard.emails"><i class="icon-ion-ios7-email-outline"><!-- email --></i> {{currentCard.$preferredEmail()}}</span><var:entity const:name="nbsp" /></div>
2014-08-06 22:06:58 +02:00
</a>
</li>
</ul>
</div>
<div id="contactView" data-ui-view="card"><!-- card state view --></div>
</div>
</script><!-- addressbooks.html -->
2014-08-06 22:06:58 +02:00
<script type="text/ng-template" id="card.html">
<div class="viewer">
2014-08-06 22:06:58 +02:00
<div class="header">
<h1 data-ng-bind-html="card.$fullname()"><!-- fullname --></h1>
<h6>{{card.$description()}}
<span class="label radius" data-ng-repeat="category in card.categories">{{category.value}}</span>
2014-08-06 22:06:58 +02:00
</h6>
</div>
<div class="buttonsToolbar">
<span data-ng-show="addressbook.isEditable">
<a class="button tiny radius" data-ui-sref="addressbook.card.editor({addressbookId: addressbook.id, cardId: card.id})"><i class="icon-pencil"><!-- edit --></i></a>
<span class="button tiny radius alert" data-ng-click="confirmDelete(card)"><i class="icon-trash"><!-- delete --></i></span>
2014-08-06 22:06:58 +02:00
</span>
</div>
<div class="attr" data-ng-show="card.birthday">
2014-08-06 22:06:58 +02:00
<div class="key">
<label class="right"><var:string label:value="Birthday"/></label>
</div>
<div class="value">
<span>{{card.$birthday() | date}}</span>
2014-08-06 22:06:58 +02:00
</div>
</div>
<div class="section" data-ng-show="card.refs.length > 0">
<!-- list members -->
<div class="attr" data-ng-repeat="ref in card.refs">
2014-08-06 22:06:58 +02:00
<div class="value single">
<a href="mailto:{{ref.email}}">{{ref.fn || ref.email}}</a>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
<div class="section" data-ng-show="card.emails.length > 0">
<div class="attr" data-ng-repeat="email in card.emails">
2014-08-06 22:06:58 +02:00
<div class="key">
<label class="right"><var:entity const:name="nbsp" />{{email.type}}</label>
</div>
<div class="value">
<a href="mailto:{{email.value}}">{{email.value}}</a>
</div>
</div>
</div>
<div class="section" data-ng-show="card.phones.length > 0">
<div class="attr" data-ng-repeat="phone in card.phones">
2014-08-06 22:06:58 +02:00
<div class="key">
<label class="right">{{phone.type}}</label>
</div>
<div class="value">
<a href="tel:{{phone.value}}">{{phone.value}}</a>
</div>
</div>
</div>
<div class="section" data-ng-show="card.urls">
<div class="attr" data-ng-repeat="url in card.urls">
2014-08-06 22:06:58 +02:00
<div class="key">
<label class="right"><var:entity const:name="nbsp" />{{url.type}}</label>
</div>
<div class="value">
<a href="#" data-ng-href="{{url.value}}">{{url.value}}</a>
</div>
</div>
2014-06-19 21:52:57 +02:00
</div>
<div class="section" data-ng-show="card.addresses">
<div class="attr" data-ng-repeat="address in card.addresses">
2014-08-06 22:06:58 +02:00
<div class="key">
<label class="right">{{address.type}}</label>
</div>
<div class="value">
<div data-sg-address="address"><!-- address --></div>
</div>
</div>
</div>
<div class="attr" data-ng-show="card.note">
2014-08-06 22:06:58 +02:00
<div class="key">
<label class="right"><var:string label:value="Note"/></label>
</div>
<div class="value">
<div data-ng-bind-html="card.note"><!-- note --></div>
2014-08-06 22:06:58 +02:00
</div>
</div>
</div>
</script><!-- card.html -->
<script type="text/ng-template" id="cardEditor.html">
2014-08-06 22:06:58 +02:00
<div class="editor">
<form name="cardForm" data-ng-show="card.$isCard()" data-ng-submit="save(cardForm)">
2014-08-06 22:06:58 +02:00
<div class="buttonsToolbar">
2014-09-10 22:25:46 +02:00
<span class="button tiny radius secondary" data-ng-click="cancel()"><i class="icon-arrow-left"><!-- cancel --></i> <var:string label:value="Cancel"/></span>
<span class="button tiny radius secondary" data-ng-click="reset()"><i class="icon-undo"><!-- reset --></i> <var:string label:value="Reset"/></span>
<button class="button tiny radius" type="submit"><i class="icon-checkmark"><!-- save --></i> <var:string label:value="Save"/></button>
2014-08-06 22:06:58 +02:00
</div>
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Display"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.fn"/>
2014-08-06 22:06:58 +02:00
</div>
</div>
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Firstname"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.givenname"/>
2014-08-06 22:06:58 +02:00
</div>
</div>
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Lastname"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.sn"/>
2014-08-06 22:06:58 +02:00
</div>
</div>
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Nickname"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.nickname"/>
2014-08-06 22:06:58 +02:00
</div>
</div>
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Organization"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.org"/>
2014-08-06 22:06:58 +02:00
</div>
</div>
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Title"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.title"/>
2014-08-06 22:06:58 +02:00
</div>
</div>
<!-- org units -->
<div class="section">
<div class="attr" data-ng-repeat="unit in card.orgUnits">
2014-08-06 22:06:58 +02:00
<div class="action">
<span class="button alert icon" data-ng-click="card.$delete('orgUnits', $index)"><i class="icon-minus"><!-- remove --></i></span>
2014-08-06 22:06:58 +02:00
</div>
2014-06-19 21:52:57 +02:00
<div class="key">
2014-08-06 22:06:58 +02:00
<label class="right inline"><var:string label:value="Organization Unit"/></label>
2014-06-19 21:52:57 +02:00
</div>
<div class="value">
2014-08-06 22:06:58 +02:00
<input type="text" label:placeholder="unit" data-ng-model="unit.value" data-sg-focus-on="orgUnit_{{$index}}"/>
2014-06-19 21:52:57 +02:00
</div>
</div>
2014-08-06 22:06:58 +02:00
<div class="attr">
<div class="value single">
2014-09-10 22:25:46 +02:00
<span class="button secondary outline tiny" data-ng-click="addOrgUnit()"><i class="icon-plus"><!-- new --></i> <var:string label:value="Add Organizational Unit"/></span>
2014-06-19 21:52:57 +02:00
</div>
</div>
2014-08-06 22:06:58 +02:00
</div>
<!-- birthday -->
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Birthday"/></label>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="value">
<input type="text" data-ng-model="card.birthday"/>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
<!-- categories -->
<div class="section">
<div class="attr" data-ng-repeat="category in card.categories">
2014-08-06 22:06:58 +02:00
<div class="action">
<span class="button alert icon" data-ng-click="card.$delete('categories', $index)"><i class="icon-minus"><!-- remove --></i></span>
2014-06-19 21:52:57 +02:00
</div>
<div class="key">
2014-08-06 22:06:58 +02:00
<label class="right inline"><var:string label:value="Category"/></label>
2014-06-19 21:52:57 +02:00
</div>
<div class="value">
<input type="text" label:placeholder="category" data-ng-model="category.value" data-sg-focus-on="category_{{$index}}" data-typeahead="cat for cat in card.allCategories | filter:$viewValue"/>
2014-06-19 21:52:57 +02:00
</div>
</div>
2014-08-06 22:06:58 +02:00
<div class="attr">
<div class="value single">
2014-09-10 22:25:46 +02:00
<span class="button secondary outline tiny" data-ng-click="addCategory()"><i class="icon-plus"><!-- new --></i> <var:string label:value="New Category"/></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
<!-- emails -->
<div class="section">
<div class="attr" data-ng-repeat="email in card.emails">
2014-08-06 22:06:58 +02:00
<div class="action">
<span class="button alert icon" data-ng-click="card.$delete('emails', $index)"><i class="icon-minus"><!-- remove --></i></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="key">
<select class="text-right" data-ng-model="email.type" data-ng-options="type for type in allEmailTypes">
<!-- email types -->
</select>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="value">
<input type="email" label:placeholder="email address" data-ng-model="email.value" data-sg-focus-on="email_{{$index}}"/>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
<div class="attr">
<div class="value single">
2014-09-10 22:25:46 +02:00
<span class="button secondary outline tiny" data-ng-click="addEmail()"><i class="icon-plus"><!-- new --></i> <var:string label:value="New Email Address"/></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
<!-- phones -->
<div class="section">
<div class="attr" data-ng-repeat="phone in card.phones">
2014-08-06 22:06:58 +02:00
<div class="action">
<span class="button alert icon" data-ng-click="card.$delete('phones', $index)"><i class="icon-minus"><!-- remove --></i></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="key">
<select class="text-right" data-ng-model="phone.type" data-ng-options="type for type in allTelTypes">
<!-- phone types -->
</select>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="value">
<input type="text" label:placeholder="phone number" data-ng-model="phone.value" data-sg-focus-on="phone_{{$index}}"/>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
<div class="attr">
<div class="value single">
2014-09-10 22:25:46 +02:00
<span class="button secondary outline tiny" data-ng-click="addPhone()"><i class="icon-plus"><!-- new --></i> <var:string label:value="New Phone Number"/></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
<!-- urls -->
<div class="section">
<div class="attr" data-ng-repeat="url in card.urls">
2014-08-06 22:06:58 +02:00
<div class="action">
<span class="button alert icon" data-ng-click="card.$delete('urls', $index)"><i class="icon-minus"><!-- remove --></i></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="key">
<select class="text-right" data-ng-model="url.type" data-ng-options="type for type in allUrlTypes">
<!-- url types -->
</select>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="value">
<input type="url" label:placeholder="URL" data-ng-model="url.value" data-sg-focus-on="url_{{$index}}"/>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
<div class="attr">
<div class="value single">
2014-09-10 22:25:46 +02:00
<span class="button secondary outline tiny" data-ng-click="addUrl()"><i class="icon-plus"><!-- new --></i> <var:string label:value="New URL"/></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
<!-- addresses -->
<div class="section">
<div class="attr" data-ng-repeat="address in card.addresses">
2014-08-06 22:06:58 +02:00
<div class="action">
<span class="button alert icon" data-ng-click="card.$delete('addresses', $index)"><i class="icon-minus"><!-- remove --></i></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="key">
<select class="text-right" data-ng-model="address.type" data-ng-options="type for type in allAddressTypes">
<!-- address types -->
</select>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
<div class="value compact">
<input type="text" label:placeholder="street" data-ng-model="address.street" data-sg-focus-on="address_{{$index}}"/>
<input type="text" data-ng-model="address.street2"/>
<input type="text" label:placeholder="Postoffice" data-ng-model="address.postoffice"/>
<input type="text" label:placeholder="City" data-ng-model="address.locality"/>
<input type="text" label:placeholder="Region" data-ng-model="address.region"/>
<input type="text" label:placeholder="Country" data-ng-model="address.country"/>
<input type="text" label:placeholder="Postal Code" data-ng-model="address.postalcode"/>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
<div class="attr">
<div class="value single">
2014-09-10 22:25:46 +02:00
<span class="button secondary outline tiny" data-ng-click="addAddress()"><i class="icon-plus"><!-- new --></i> <var:string label:value="New Address"/></span>
2014-06-19 21:52:57 +02:00
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
<!-- note -->
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Note"/></label>
</div>
<div class="value">
<textarea data-ng-model="card.note"><!-- note --></textarea>
2014-08-06 22:06:58 +02:00
</div>
</div>
</form>
<form name="listForm" data-ng-show="card.$isList()" data-ng-submit="save(listForm)">
<div class="buttonsToolbar">
2014-09-10 22:25:46 +02:00
<span class="button tiny radius secondary" data-ng-click="cancel()"><i class="icon-arrow-left"><!-- cancel --></i> <var:string label:value="Cancel"/></span>
<span class="button tiny radius secondary" data-ng-click="reset()"><i class="icon-undo"><!-- reset --></i> <var:string label:value="Reset"/></span>
<button class="button tiny radius" type="submit"><i class="icon-checkmark"><!-- save --></i> <var:string label:value="Save"/></button>
</div>
<div class="section">
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Display"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.fn"/>
</div>
2014-08-06 22:06:58 +02:00
</div>
<div class="attr">
<div class="action"><var:entity const:name="nbsp"/></div>
<div class="key">
<label class="right inline"><var:string label:value="Nickname"/></label>
</div>
<div class="value">
<input type="text" data-ng-model="card.nickname"/>
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
<!-- list members -->
<div class="section">
<div class="attr" data-ng-repeat="ref in card.refs">
<div class="action">
<span class="button alert icon" data-ng-click="card.$delete('refs', $index)"><i class="icon-minus"><!-- remove --></i></span>
</div>
<div class="key">
<label class="right inline"><var:string label:value="Member"/></label>
</div>
<div class="value">
<input type="text" label:placeholder="email address"
data-ng-model="ref.email"
data-sg-focus-on="ref_{{$index}}"
data-typeahead="card.$preferredEmail($viewValue) as card.$shortFormat($viewValue) for card in addressbook.$filter($viewValue, {dry: true, excludeLists: true})"
data-typeahead-on-select="card.$updateMember($index, $model, $item)"/>
</div>
2014-08-06 22:06:58 +02:00
</div>
<div class="attr">
<div class="value single">
2014-09-10 22:25:46 +02:00
<span class="button outline secondary tiny" data-ng-click="addMember()"><i class="icon-plus"><!-- new --></i> <var:string label:value="Add Member"/></span>
</div>
2014-08-06 22:06:58 +02:00
</div>
</div>
</form>
</div>
</script><!-- cardEditor.html -->
2014-08-06 22:06:58 +02:00
<!--<div class="dragHandle" id="rightDragHandle"></div>-->
2014-08-06 22:06:58 +02:00
<var:string value="errorAlertJavaScript" const:escapeHTML="NO" />
2014-06-19 21:52:57 +02:00
</div>
</var:component>