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'>
|
2015-09-16 08:28:00 +02:00
|
|
|
<div class='global-menu menu'>
|
2015-08-26 01:47:15 +02:00
|
|
|
<button class='hamburger'></button>
|
|
|
|
<ul class='menu-list'>
|
2015-09-16 08:28:00 +02:00
|
|
|
<li><a class='show-debug-log'>Submit debug log</a></li>
|
2015-08-26 01:47:15 +02:00
|
|
|
</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'>
|
2015-09-18 22:07:19 +02:00
|
|
|
<div class='tool-bar clearfix'>
|
|
|
|
<button class='show-new-conversation'></button>
|
|
|
|
</div>
|
2015-08-26 01:47:15 +02:00
|
|
|
<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-08-31 22:58:17 +02:00
|
|
|
<button class='drop-down'></button>
|
2015-03-16 00:04:39 +01:00
|
|
|
<ul class='menu-list'>
|
|
|
|
{{#group}}
|
2015-08-04 21:15:37 +02:00
|
|
|
<li><a class='view-members'>Members</a></li>
|
2015-09-04 22:11:21 +02:00
|
|
|
<li><a class='update-group'>Update group</a></li>
|
2015-03-16 00:04:39 +01:00
|
|
|
<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>
|
2015-09-04 22:11:21 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='new-group-update'>
|
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>
|
2015-09-04 22:11:21 +02:00
|
|
|
{{> group_info_input }}
|
2015-03-16 00:04:39 +01:00
|
|
|
<div class='container'>
|
2015-09-04 22:11:21 +02:00
|
|
|
<div class='scrollable'></div>
|
2015-03-16 00:04:39 +01:00
|
|
|
</div>
|
|
|
|
</script>
|
2015-09-10 09:46:50 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='identicon-svg'>
|
2015-09-14 20:39:42 +02:00
|
|
|
<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100">
|
|
|
|
<circle cx="50" cy="50" r="40" fill="{{ color }}" />
|
|
|
|
<text text-anchor="middle" fill="white" font-size="24px" x="50" y="50" baseline-shift="-8px">
|
2015-09-10 09:46:50 +02:00
|
|
|
{{ content }}
|
|
|
|
</text>
|
|
|
|
</svg>
|
|
|
|
</script>
|
2015-03-23 22:01:18 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='avatar'>
|
2015-09-10 09:46:50 +02:00
|
|
|
<span class='avatar'
|
|
|
|
style='background-image: url("{{ avatar.url }}"); background-color: {{ avatar.color }}'>
|
2015-06-19 02:05:00 +02:00
|
|
|
{{ avatar.content }}
|
2015-09-03 22:33:17 +02:00
|
|
|
</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>
|
2015-09-03 22:33:17 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='contact_name_and_number'>
|
|
|
|
<h3 class='name'> {{ title }} </h3>
|
|
|
|
<div class='number'>{{ number }}</div>
|
|
|
|
</script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<script type='text/x-tmpl-mustache' id='contact'>
|
2015-09-03 22:33:17 +02:00
|
|
|
{{> avatar }}
|
|
|
|
<div class='contact-details'> {{> contact_name_and_number }} </div>
|
|
|
|
</script>
|
2015-09-05 03:44:33 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='conversation-preview'>
|
2015-03-23 22:01:18 +01:00
|
|
|
{{> avatar }}
|
2015-03-16 00:04:39 +01:00
|
|
|
<div class='contact-details'>
|
2015-09-03 22:33:17 +02:00
|
|
|
{{> contact_name_and_number }}
|
|
|
|
<p class='last-message'> {{ last_message }} </p>
|
|
|
|
<span class='last-timestamp'> {{ last_message_timestamp }} </span>
|
2015-03-16 00:04:39 +01:00
|
|
|
</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>
|
2015-09-04 22:11:21 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='group_info_input'>
|
|
|
|
<div class='group-info-input'>
|
|
|
|
<div class='group-avatar'>
|
|
|
|
<div class='thumbnail'> {{> avatar }} </div>
|
|
|
|
<input type='file' name='avatar' class='file-input'>
|
|
|
|
</div>
|
|
|
|
<input type='text' name='name' class='name' placeholder='Group Name' value="{{ name }}">
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<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-09-04 22:11:21 +02:00
|
|
|
{{> group_info_input }}
|
2015-08-27 00:13:14 +02:00
|
|
|
<div class='container'>
|
2015-03-16 00:04:39 +01:00
|
|
|
<div class='scrollable'>
|
|
|
|
</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>
|
2015-09-16 08:28:00 +02:00
|
|
|
<script type='text/x-tmpl-mustache' id='debug-log'>
|
|
|
|
<h1> Submit Debug Log </h1>
|
|
|
|
<form>
|
|
|
|
<textarea rows="5"></textarea>
|
|
|
|
<input class="submit" type='submit' value='Create Public Gist' />
|
|
|
|
<button class='close'>Cancel</button>
|
|
|
|
</form>
|
|
|
|
<div class='result'>
|
|
|
|
<a target='_blank'></a>
|
|
|
|
<div><button class='close'>Got it!</button></div>
|
|
|
|
</div>
|
|
|
|
</script>
|
2015-09-16 03:48:49 +02:00
|
|
|
<script type="text/javascript" src="js/debugLog.js"></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>
|
2015-09-17 08:13:17 +02:00
|
|
|
<script type="text/javascript" src="js/conversation_controller.js"></script>
|
2015-08-27 21:38:51 +02:00
|
|
|
<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>
|
2015-09-16 08:28:00 +02:00
|
|
|
<script type="text/javascript" src="js/views/debug_log_view.js"></script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<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>
|
2015-09-03 22:33:17 +02:00
|
|
|
<script type="text/javascript" src="js/views/contact_list_view.js"></script>
|
2015-03-16 00:04:39 +01:00
|
|
|
<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-09-10 09:46:50 +02:00
|
|
|
<script type="text/javascript" src="js/views/identicon_svg_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>
|