123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- <!-- Top header (nickname + menu) -->
- <div id="navigation-topheader">
- <div class="my-identity">
- <span ng-click="ctrl.showProfile()" ng-cloak translate-attr="{'title': 'messenger.MY_PUBLIC_NICKNAME'}">
- {{ ctrl.getMe().publicNickname || ctrl.getMe().id }}
- </span>
- </div>
- <battery-status></battery-status>
- <md-menu md-position-mode="target-right target" md-offset="0 45">
- <md-button aria-label="Open menu" class="md-icon-button" ng-click="$mdMenu.open($event)">
- <i class="material-icons md-light md-24">more_vert</i>
- </md-button>
- <md-menu-content width="4">
- <md-menu-item>
- <md-button ng-click="ctrl.closeSession()">
- <md-icon aria-hidden="true" class="material-icons md-24">exit_to_app</md-icon>
- <span translate>common.SESSION_CLOSE</span>
- </md-button>
- </md-menu-item>
- <md-menu-item ng-if="ctrl.isPersistent()">
- <md-button ng-click="ctrl.deleteSession()">
- <md-icon aria-hidden="true" class="material-icons md-24">delete</md-icon>
- <span translate>common.SESSION_DELETE</span>
- </md-button>
- </md-menu-item>
- <md-menu-item>
- <md-button ng-click="ctrl.settings()">
- <md-icon aria-hidden="true" class="material-icons md-24">settings</md-icon>
- <span translate>messenger.SETTINGS</span>
- </md-button>
- </md-menu-item>
- <md-menu-item>
- <md-button ng-click="ctrl.about()">
- <md-icon aria-hidden="true" class="material-icons md-24">info</md-icon>
- <span translate>messenger.ABOUT</span>
- </md-button>
- </md-menu-item>
- </md-menu-content>
- </md-menu>
- </div>
- <!-- Header -->
- <div id="navigation-header">
- <div class="main">
- <md-nav-bar md-no-ink md-selected-nav-item="ctrl.activeTab" nav-bar-aria-label="navigation links">
- <md-nav-item md-nav-click="1" name="conversations" aria-label="conversations">
- <i class="material-icons md-dark md-24" translate translate-attr-title="messenger.CONVERSATIONS">speaker_notes</i>
- </md-nav-item>
- <md-nav-item md-nav-click="1" name="contacts" aria-label="contacts">
- <i class="material-icons md-dark md-24" translate translate-attr-title="messenger.CONTACTS">person</i>
- </md-nav-item>
- </md-nav-bar>
- <span flex></span>
- <md-button aria-label="search" class="md-icon-button" ng-click="ctrl.toggleSearch()">
- <i class="material-icons md-dark md-24" translate translate-attr-title="messenger.SEARCH">search</i>
- </md-button>
- </div>
- <div class="search" searchbox searchbox-focus="ctrl.searchVisible">
- <input type="text" ng-model="ctrl.searchText" translate translate-attr-placeholder="messenger.SEARCH" aria-label="Search" translate-attr-aria-label="messenger.SEARCH">
- </div>
- </div>
- <!-- Conversations -->
- <div id="navigation-conversations" class="tab-content" ng-if="ctrl.activeTab == 'conversations'" in-view-container>
- <p class="empty" ng-if="ctrl.conversations().length === 0" translate>messenger.NO_CONVERSATIONS_FOUND</p>
- <ul>
- <li ng-repeat="conversation in ctrl.conversations() | filter:ctrl.searchConversation"
- ng-init="dndModeSimplified = ctrl.dndModeSimplified(conversation)"
- ui-sref="messenger.home.conversation({ type: conversation.type, id: conversation.id, initParams: null })"
- aria-label="conversation with {{ conversation.receiver.displayName }}"
- class="conversation-wrapper"
- ng-if="ctrl.isVisible(conversation)">
- <div class="conversation"
- ng-class="{'unread': conversation.unreadCount > 0,
- 'starred': conversation.isStarred,
- 'active': ctrl.isActive(conversation)}">
- <section class="avatar-box" role="button">
- <eee-avatar eee-receiver="conversation.receiver"
- eee-resolution="'low'"></eee-avatar>
- </section>
- <section class="conversation-box">
- <section class="receiver-box">
- <span class="title" ng-class="{'disabled': conversation.receiver.disabled === true}" ng-bind-html="conversation.receiver.displayName | escapeHtml | emojify" role="button">
- </span>
- <span class="notification-settings" ng-if="dndModeSimplified === 'on'">
- <img height="16" width="16" src="img/ic_dnd_total_silence.svg" translate translate-attr-title="messenger.MUTED_NONE">
- </span>
- <span class="notification-settings" ng-if="dndModeSimplified === 'mention'">
- <img height="16" width="16" src="img/ic_dnd_mention.svg" translate translate-attr-title="messenger.MUTED_MENTION_ONLY">
- </span>
- <span class="notification-settings" ng-if="dndModeSimplified === 'off' && conversation.notifications && conversation.notifications.sound.mode === 'muted'">
- <img height="16" width="16" src="img/ic_notifications_off.svg" translate translate-attr-title="messenger.MUTED_SILENT">
- </span>
- <span class="badge unread-count" ng-show="conversation.unreadCount > 0">
- {{ conversation.unreadCount }}
- </span>
- </section>
- <section class="message-box">
- <eee-latest-message
- ng-if="!conversation.receiver.isTyping() && conversation.latestMessage"
- ng-class="latest-message-text"
- eee-type="conversation.type"
- eee-receiver="conversation.receiver"
- eee-message="conversation.latestMessage"></eee-latest-message>
- </section>
- </section>
- </div>
- </li>
- </ul>
- </div>
- <!-- Contacts -->
- <div id="navigation-contacts" class="tab-content" ng-if="ctrl.activeTab == 'contacts'" in-view-container>
- <p class="empty" ng-if="ctrl.contacts().length === 0" translate>messenger.NO_CONTACTS_FOUND</p>
- <ul ng-class="{'hide-inactive': ctrl.hideInactiveContacts()}">
- <li ng-repeat="contact in ctrl.contacts() | isNotMe | filter:ctrl.searchContact"
- ui-sref="messenger.home.conversation({ type: 'contact', id: contact.id, initParams: null })"
- class="contact"
- ng-class="{'inactive': contact.state == 'INACTIVE'}">
- <section class="avatar-box">
- <eee-avatar eee-receiver="contact"
- eee-resolution="'low'"></eee-avatar>
- </section>
- <section class="left">
- <div class="name" ng-bind-html="contact.displayName | escapeHtml | emojify"></div>
- <div class="identity">{{ contact.id }}</div>
- </section>
- <section class="right">
- <div class="nickname">
- <span ng-show="contact.publicNickname && contact.publicNickname != contact.identity">
- ~{{ contact.publicNickname }}
- </span>
- </div>
- <div class="verification-level">
- <eee-verification-level
- contact="contact"
- ng-if="contact.verificationLevel">
- </eee-verification-level>
- </div>
- </section>
- </li>
- </ul>
- </div>
- <!-- FAB -->
- <div id="navigation-fab">
- <md-fab-speed-dial md-direction="up" class="md-scale md-fab-bottom-right md-hover-full" ng-cloak>
- <md-fab-trigger>
- <md-button aria-label="menu" class="md-fab">
- <md-icon aria-label="Add" class="material-icons md-24">add</md-icon>
- </md-button>
- </md-fab-trigger>
- <md-fab-actions>
- <md-button
- ng-click="ctrl.addContact()"
- translate-attr="{'aria-label': 'messenger.ADD_CONTACT'}"
- aria-label="Add Contact"
- class="md-fab md-raised md-mini fab-button-add-contact">
- <md-tooltip md-direction="left" md-visible="tooltipVisible">
- <label translate>messenger.ADD_CONTACT</label>
- </md-tooltip>
- <md-icon class="material-icons md-24">person_add</md-icon>
- </md-button>
- <md-button
- ng-click="ctrl.createGroup()"
- translate-attr="{'aria-label': 'messenger.CREATE_GROUP'}"
- aria-label="Create Group"
- class="md-fab md-mini fab-button-add-group">
- <md-tooltip md-direction="left" md-visible="tooltipVisible">
- <label translate>messenger.CREATE_GROUP</label>
- </md-tooltip>
- <md-icon class="material-icons md-24">group_add</md-icon>
- </md-button>
- <md-button
- ng-if="ctrl.showCreateDistributionListButton()"
- ng-click="ctrl.createDistributionList()"
- translate-attr="{'aria-label': 'messenger.CREATE_DISTRIBUTION_LIST'}"
- aria-label="Create Distribution list"
- class="md-fab md-mini fab-button-add-distribution-list">
- <md-tooltip md-direction="left" md-visible="tooltipVisible">
- <label translate>messenger.CREATE_DISTRIBUTION_LIST</label>
- </md-tooltip>
- <md-icon class="material-icons md-24">question_answer</md-icon>
- </md-button>
- </md-fab-actions>
- </md-fab-speed-dial>
- </div>
|