2014-05-04 08:34:13 +02:00
|
|
|
<!--This program is free software: you can redistribute it and/or modify
|
2015-01-06 23:51:59 +01:00
|
|
|
it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
2014-05-04 08:34:13 +02:00
|
|
|
|
2015-01-06 23:51:59 +01:00
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU Lesser General Public License for more details.
|
2014-05-04 08:34:13 +02:00
|
|
|
|
2015-01-06 23:51:59 +01:00
|
|
|
You should have received a copy of the GNU Lesser General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2014-05-04 08:34:13 +02:00
|
|
|
-->
|
|
|
|
|
2014-06-30 00:15:27 +02:00
|
|
|
<!DOCTYPE html>
|
2014-01-12 15:07:30 +01:00
|
|
|
<html>
|
|
|
|
<head>
|
2015-03-16 00:04:39 +01:00
|
|
|
<meta charset='utf-8'>
|
2015-08-26 01:47:15 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='two-column'>
|
|
|
|
<div class='title-bar' id='header'>
|
|
|
|
<div class='menu'>
|
|
|
|
<button class='hamburger'></button>
|
|
|
|
<ul class='menu-list'>
|
|
|
|
<li><a class='new-group'>Create Group</a></li>
|
|
|
|
<li><a class='settings'>Settings</a></li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
2015-08-26 19:11:12 +02:00
|
|
|
<span class='title-text'>Signal</span>
|
2015-08-26 19:31:16 +02:00
|
|
|
<span class='socket-status'></span>
|
2015-08-26 01:47:15 +02:00
|
|
|
</div>
|
|
|
|
<div class='gutter'>
|
|
|
|
<div class='conversations scrollable'></div>
|
|
|
|
<span class='fab'></span>
|
|
|
|
</div>
|
|
|
|
<div class='conversation-stack'></div>
|
|
|
|
</script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='conversation'>
|
2015-08-26 01:47:15 +02:00
|
|
|
<div class='conversation-header'>
|
|
|
|
<div class='conversation-menu menu'>
|
2015-03-16 00:04:39 +01:00
|
|
|
<button class='hamburger'></button>
|
|
|
|
<ul class='menu-list'>
|
|
|
|
{{#group}}
|
2015-08-04 21:15:37 +02:00
|
|
|
<li><a class='view-members'>Members</a></li>
|
2015-03-16 00:04:39 +01:00
|
|
|
<li><a class='new-group-update'>Update group</a></li>
|
|
|
|
<li><a class='leave-group'>Leave group</a></li>
|
|
|
|
{{/group}}
|
|
|
|
{{^group}}
|
|
|
|
<li><a class='end-session'>Reset Session</a></li>
|
|
|
|
<li><a class='verify-identity'>Verify Identity</a></li>
|
|
|
|
{{/group}}
|
|
|
|
<li><a class='destroy'>Delete messages</a></li>
|
|
|
|
</ul>
|
|
|
|
</div>
|
2015-06-02 23:56:58 +02:00
|
|
|
<span class='conversation-title'>{{ title }}</span>
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class='discussion-container'></div>
|
|
|
|
|
|
|
|
<div class="bottom-bar" id='footer'>
|
|
|
|
<form class='send'>
|
|
|
|
<div class='attachments'>
|
|
|
|
<div class='paperclip thumbnail'></div>
|
|
|
|
<input type='file' class='file-input'>
|
|
|
|
</div>
|
|
|
|
<input class="send-btn" type='submit' value='' />
|
2015-06-16 22:43:40 +02:00
|
|
|
<textarea class='send-message' placeholder="Send a message" rows="1"></textarea>
|
2015-03-16 00:04:39 +01:00
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-05-27 01:54:21 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='confirmation-dialog'>
|
|
|
|
<div class='message'>{{ message }}</div>
|
|
|
|
<div class='buttons'>
|
|
|
|
<button class='cancel'>Cancel</button>
|
|
|
|
<button class='ok'>OK</button>
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='attachment-preview'>
|
|
|
|
<img src="{{ source }}" class="preview" />
|
|
|
|
<div class="close">x</div>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='message'>
|
|
|
|
<div class='sender'>{{ sender }}</div>
|
2015-03-23 22:01:18 +01:00
|
|
|
{{> avatar }}
|
2015-03-16 00:04:39 +01:00
|
|
|
<div class="bubble">
|
|
|
|
<div class='attachments'></div>
|
2015-07-05 08:08:25 +02:00
|
|
|
<p class="content">{{ message }}</p>
|
2015-03-16 00:04:39 +01:00
|
|
|
<div class='meta'>
|
|
|
|
<span class='timestamp'>{{ timestamp }}</span>
|
|
|
|
<span class='checkmark hide'>✓</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='new-group-update-form'>
|
2015-08-27 00:13:14 +02:00
|
|
|
<div class='conversation-header'>
|
2015-03-16 00:04:39 +01:00
|
|
|
<button class='back'></button>
|
|
|
|
<button class='send check'></button>
|
2015-08-27 00:13:14 +02:00
|
|
|
<span class='conversation-title'>Update group</span>
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
|
|
|
<div class='container'>
|
|
|
|
<div class='scrollable'>
|
|
|
|
<div class='clearfix'>
|
|
|
|
<div class='group-avatar'>
|
|
|
|
<div class='thumbnail'>
|
2015-03-23 22:01:18 +01:00
|
|
|
{{> avatar }}
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
|
|
|
<input type='file' name='avatar' class='file-input'>
|
|
|
|
</div>
|
|
|
|
<div>
|
|
|
|
<input type='text' name='name' class='name' placeholder='Group Name' value="{{ name }}">
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-03-23 22:01:18 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='avatar'>
|
2015-06-25 22:32:05 +02:00
|
|
|
<span class='avatar {{#avatar.color }} color{{avatar.color}} {{/avatar.color}}' style='background-image: url("{{ avatar.url }}");'>
|
2015-06-19 02:05:00 +02:00
|
|
|
{{ avatar.content }}
|
|
|
|
</span>
|
2015-03-23 22:01:18 +01:00
|
|
|
</script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='contact_pill'>
|
|
|
|
<span>{{ name }}</span><span class='remove'>x</span>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='contact'>
|
2015-03-23 22:01:18 +01:00
|
|
|
{{> avatar }}
|
2015-03-16 00:04:39 +01:00
|
|
|
<div class='contact-details'>
|
|
|
|
<h3 class='contact-name'>
|
|
|
|
{{ contact_name }}
|
|
|
|
</h3>
|
|
|
|
<p class='number'>{{ number }}</p>
|
|
|
|
<p class='last-message'>
|
|
|
|
{{ last_message }}
|
|
|
|
</p>
|
|
|
|
<span class='last-timestamp'>
|
|
|
|
{{ last_message_timestamp }}
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
<script type="text/x-tmpl-mustache" id="phone-number">
|
|
|
|
<div class="phone-input-form">
|
|
|
|
<div class="number-container">
|
|
|
|
<input type="tel" class="number" placeholder="Phone Number" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='file-size-modal'>
|
|
|
|
Sorry, the selected file exceeds message size
|
|
|
|
restrictions. ({{ limit }}kB)
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='message-detail'>
|
2015-08-27 00:13:14 +02:00
|
|
|
<div class='conversation-header'>
|
2015-03-16 00:04:39 +01:00
|
|
|
<button class='back'></button>
|
2015-08-27 00:13:14 +02:00
|
|
|
<span class='conversation-title'>Message Detail</span>
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
2015-02-18 03:03:05 +01:00
|
|
|
<div class='container'>
|
|
|
|
<div class='message-container'></div>
|
|
|
|
<div class='info'>
|
|
|
|
<table>
|
|
|
|
<tr><td class='label'>Sent</td><td> {{ sent_at }}</td></tr>
|
|
|
|
<tr><td class='label'>Received</td><td> {{ received_at }}</td></tr>
|
|
|
|
<tr>
|
|
|
|
<td class='tofrom label'>{{ tofrom }}</td>
|
|
|
|
<td> <div class='contacts'></div> </td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
|
|
|
</div>
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
|
|
|
</script>
|
2015-08-04 21:15:37 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='group-member-list'>
|
2015-08-27 00:13:14 +02:00
|
|
|
<div class='conversation-header'>
|
2015-08-04 21:15:37 +02:00
|
|
|
<button class='back'></button>
|
2015-08-27 00:13:14 +02:00
|
|
|
<span class='conversation-title'>Members</span>
|
2015-08-04 21:15:37 +02:00
|
|
|
</div>
|
|
|
|
<div class='container'>
|
|
|
|
<div class='scrollable'></div>
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='key-verification'>
|
2015-08-27 00:13:14 +02:00
|
|
|
<div class='conversation-header'>
|
2015-03-16 00:04:39 +01:00
|
|
|
<button class='back'></button>
|
2015-08-27 00:13:14 +02:00
|
|
|
<span class='conversation-title'>Verify Identity</span>
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
|
|
|
<div class='container'>
|
|
|
|
<p> Their identity (they read): </p>
|
|
|
|
<div class='key'>
|
|
|
|
{{ #their_key }} <span>{{ . }}</span> {{ /their_key }}
|
|
|
|
</div>
|
|
|
|
<p> Your identity (you read): </p>
|
|
|
|
<div class='key'>
|
|
|
|
{{ #your_key }} <span>{{ . }}</span> {{ /your_key }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
<!-- index -->
|
|
|
|
<script type="text/x-tmpl-mustache" id="inbox">
|
|
|
|
<div class='title-bar' id='header'>
|
|
|
|
<div class='socket-status'></div>
|
|
|
|
</div>
|
|
|
|
<div class='gutter'>
|
|
|
|
<div class='conversations scrollable'></div>
|
|
|
|
<span class='fab'></span>
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='new-conversation'>
|
2015-08-27 00:13:14 +02:00
|
|
|
<div class='conversation-header'>
|
2015-03-16 00:04:39 +01:00
|
|
|
<button class='back'></button>
|
|
|
|
<button class='create check hide'></button>
|
2015-08-27 00:13:14 +02:00
|
|
|
<span class='conversation-title'>New Message</span>
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
2015-08-27 00:13:14 +02:00
|
|
|
<div class='container'>
|
2015-03-16 00:04:39 +01:00
|
|
|
<div class='scrollable'>
|
|
|
|
<div class='new-group-update-form clearfix'>
|
|
|
|
<div class='group-avatar'>
|
|
|
|
<div class='thumbnail'>
|
|
|
|
<span class='default group-default'></span>
|
|
|
|
</div>
|
|
|
|
<input type='file' name='avatar' class='file-input'>
|
|
|
|
</div>
|
|
|
|
<input type='text' name='name' class='name' placeholder='Group Name' value="{{ name }}">
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='recipients-input'>
|
|
|
|
<div class='recipients-container'>
|
|
|
|
<span class='recipients'></span>
|
2015-06-09 21:04:03 +02:00
|
|
|
<input type='text' class='search' placeholder="{{ placeholder }}" />
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
|
|
|
<div class='results'>
|
|
|
|
<div class='new-contact contact hide'></div>
|
|
|
|
<div class='contacts'></div>
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-02-18 03:03:05 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='incoming-key-conflict'>
|
|
|
|
<p>
|
|
|
|
Received message with unknown identity key.
|
|
|
|
Click to process and display.
|
|
|
|
</p>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='outgoing-key-conflict'>
|
|
|
|
<p>
|
2015-07-06 22:40:23 +02:00
|
|
|
This contact's identity key has changed.
|
2015-02-18 03:03:05 +01:00
|
|
|
Click to process and display.
|
|
|
|
</p>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='generic-error'>
|
|
|
|
<p>{{ message }}</p>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='contact-detail'>
|
|
|
|
<div>
|
2015-03-23 22:01:18 +01:00
|
|
|
{{> avatar }}
|
2015-02-18 03:03:05 +01:00
|
|
|
<span class='name'>{{ name }}</span>
|
|
|
|
{{ #conflict }}
|
|
|
|
<button class='conflict'><span>Verify</span></button>
|
|
|
|
{{ /conflict }}
|
|
|
|
</div>
|
|
|
|
</script>
|
|
|
|
<script type='text/x-tmpl-mustache' id='key-conflict-dialogue'>
|
|
|
|
<div class='content'>
|
|
|
|
<p> {{ message }} </p>
|
|
|
|
<p>
|
|
|
|
You may wish to <span class='verify'>verify</span> this contact.
|
|
|
|
</p>
|
|
|
|
<p>
|
|
|
|
<button class='cancel'>Cancel</button>
|
|
|
|
<button class='resolve'>Accept new key</button>
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-05-21 22:05:52 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='window-controls'>
|
|
|
|
<button class='minimize'>−</button>
|
|
|
|
<button class='close'>×</button>
|
|
|
|
</script>
|
2014-11-01 04:59:30 +01:00
|
|
|
<script type="text/javascript" src="js/components.js"></script>
|
2015-04-08 21:20:34 +02:00
|
|
|
<script type="text/javascript" src="js/database.js"></script>
|
2015-05-13 00:14:20 +02:00
|
|
|
<script type="text/javascript" src="js/storage.js"></script>
|
2015-04-01 22:08:09 +02:00
|
|
|
<script type="text/javascript" src="js/axolotl_store.js"></script>
|
2015-01-14 01:09:32 +01:00
|
|
|
<script type="text/javascript" src="js/libtextsecure.js"></script>
|
|
|
|
|
2015-03-17 23:06:21 +01:00
|
|
|
<script type="text/javascript" src="js/notifications.js"></script>
|
2015-01-14 01:09:32 +01:00
|
|
|
<script type="text/javascript" src="js/libphonenumber-util.js"></script>
|
2015-01-06 23:51:59 +01:00
|
|
|
<script type="text/javascript" src="js/models/messages.js"></script>
|
|
|
|
<script type="text/javascript" src="js/models/conversations.js"></script>
|
2014-06-03 18:39:29 +02:00
|
|
|
|
2015-01-06 23:51:59 +01:00
|
|
|
<script type="text/javascript" src="js/chromium.js"></script>
|
2015-08-27 21:38:51 +02:00
|
|
|
<script type="text/javascript" src="js/bimap.js"></script>
|
|
|
|
<script type="text/javascript" src="js/panel_controller.js"></script>
|
2015-03-16 00:04:39 +01:00
|
|
|
|
|
|
|
<script type="text/javascript" src="js/views/whisper_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/toast_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/attachment_preview_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/file_input_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/list_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/conversation_list_item_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/conversation_list_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/recipients_input_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/new_group_update_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/attachment_view.js"></script>
|
2015-02-18 03:03:05 +01:00
|
|
|
<script type="text/javascript" src="js/views/key_conflict_dialogue_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/error_view.js"></script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type="text/javascript" src="js/views/message_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/key_verification_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/message_detail_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/message_list_view.js"></script>
|
2015-08-04 21:15:37 +02:00
|
|
|
<script type="text/javascript" src="js/views/group_member_list_view.js"></script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type="text/javascript" src="js/views/conversation_view.js"></script>
|
|
|
|
<script type="text/javascript" src="js/views/new_conversation_view.js"></script>
|
2015-05-21 22:05:52 +02:00
|
|
|
<script type="text/javascript" src="js/views/window_controls_view.js"></script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type="text/javascript" src="js/views/inbox_view.js"></script>
|
2015-05-27 01:54:21 +02:00
|
|
|
<script type="text/javascript" src="js/views/confirmation_dialog_view.js"></script>
|
2015-01-19 02:43:25 +01:00
|
|
|
|
2015-02-11 11:47:50 +01:00
|
|
|
<script type="text/javascript" src="js/background.js"></script>
|
2014-01-12 15:07:30 +01:00
|
|
|
</head>
|
2015-01-14 22:21:54 +01:00
|
|
|
<body>
|
2014-01-12 15:07:30 +01:00
|
|
|
</body>
|
|
|
|
</html>
|