background.html 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset='utf-8'>
  5. <script type='text/x-tmpl-mustache' id='two-column'>
  6. <div class='gutter'>
  7. <div class='title-bar active' id='header'>
  8. <div class='header-buttons right'>
  9. <div class='vertical-align'>
  10. <div class='global-menu menu'>
  11. <button class='hamburger' alt='signal menu'></button>
  12. <ul class='menu-list'>
  13. <li class='settings'>{{ settings }}</li>
  14. <li class='show-debug-log'>{{ submitDebugLog }}</li>
  15. <li class='restart-signal'>{{ restartSignal }}</li>
  16. </ul>
  17. </div>
  18. <span class='socket-status' title='Restart Signal'></span>
  19. </div>
  20. </div>
  21. <h1>Signal</h1>
  22. <div class='tool-bar clearfix'>
  23. <input type='search' class='search' placeholder='{{ searchForPeopleOrGroups }}'>
  24. <span class='search-icon'></span>
  25. </div>
  26. </div>
  27. <div class='content'>
  28. <div class='conversations scrollable inbox'></div>
  29. <div class='conversations scrollable search-results hide'>
  30. <div class='new-contact contact hide'></div>
  31. </div>
  32. </div>
  33. </div>
  34. <div class='conversation-stack'>
  35. <div class='conversation placeholder'>
  36. <h3>{{ welcomeToSignal }}</h3>
  37. <p>{{ selectAContact }}</p>
  38. </div>
  39. </div>
  40. </script>
  41. <script type='text/x-tmpl-mustache' id='expired_alert'>
  42. <a target='_blank' href='https://chrome.google.com/webstore/detail/bikioccmkafdpakkkcpdbppfkghcmihk'>
  43. <button class='upgrade'>{{ upgrade }}</button>
  44. </a>
  45. {{ expiredWarning }}
  46. </script>
  47. <script type='text/x-tmpl-mustache' id='expired_toast'>
  48. {{ expiredWarning }}
  49. </script>
  50. <script type='text/x-tmpl-mustache' id='hint'>
  51. <p> {{ content }}</p>
  52. </script>
  53. <script type='text/x-tmpl-mustache' id='conversation'>
  54. <div class='conversation-header'
  55. style='background-color: {{ avatar.color }}'>
  56. <div class='header-buttons left'>
  57. <div class='vertical-align'>
  58. <button class='back hide'></button>
  59. </div>
  60. </div>
  61. <div class='header-buttons right'>
  62. <div class='vertical-align'>
  63. <div class='conversation-menu menu'>
  64. <button class='hamburger' alt='conversation menu'></button>
  65. <ul class='menu-list'>
  66. {{#group}}
  67. <li class='view-members'>{{ view-members }}</li>
  68. <!-- <li class='update-group'>Update group</li> -->
  69. <!-- <li class='leave-group'>Leave group</li> -->
  70. {{/group}}
  71. {{^group}}
  72. <li class='end-session'>{{ end-session }}</li>
  73. <li class='verify-identity'>{{ verify-identity }}</li>
  74. {{/group}}
  75. <li class='destroy'>{{ destroy }}</li>
  76. </ul>
  77. </div>
  78. </div>
  79. </div>
  80. <span class='conversation-title'>
  81. {{ #name }}
  82. <span class='conversation-name'>{{ name }}</span>
  83. {{ /name }}
  84. {{ #number }}
  85. <span class='conversation-number'>{{ number }}</span>
  86. {{ /number }}
  87. </span>
  88. {{> avatar }}
  89. </div>
  90. <div class='main panel'>
  91. <div class='discussion-container'>
  92. <div class='bar-container hide'>
  93. <div class='bar active progress-bar-striped progress-bar'></div>
  94. </div>
  95. </div>
  96. <div class='bottom-bar' id='footer'>
  97. <form class='send clearfix'>
  98. <div class='attachment-previews'></div>
  99. <div class='choose-file'>
  100. <button class='paperclip thumbnail'></button>
  101. <input type='file' class='file-input'>
  102. </div>
  103. <textarea class='send-message' placeholder='{{ send-message }}' rows='1'></textarea>
  104. </form>
  105. </div>
  106. </div>
  107. </script>
  108. <script type='text/x-tmpl-mustache' id='confirmation-dialog'>
  109. <div class="content">
  110. <div class='message'>{{ message }}</div>
  111. <div class='buttons'>
  112. <button class='cancel'>{{ cancel }}</button>
  113. <button class='ok'>{{ ok }}</button>
  114. </div>
  115. </div>
  116. </script>
  117. <script type='text/x-tmpl-mustache' id='attachment-preview'>
  118. <img src='{{ source }}' class='preview' />
  119. <a class='x close' alt='remove attachment' href='#'></a>
  120. </script>
  121. <script type='text/x-tmpl-mustache' id='hasRetry'>
  122. {{ messageNotSent }}
  123. <span href='#' class='retry'>{{ resend }}</span>
  124. </script>
  125. <script type='text/x-tmpl-mustache' id='message'>
  126. {{> avatar }}
  127. <div class='bubble' style='background-color: {{ avatar.color }};'>
  128. <div class='sender'>{{ sender }}</div>
  129. <div class='attachments'></div>
  130. <p class='content'>{{ message }}</p>
  131. <div class='meta'>
  132. <span class='timestamp' data-timestamp={{ timestamp }}></span>
  133. <span class='status hide'></span>
  134. </div>
  135. </div>
  136. </script>
  137. <script type='text/x-tmpl-mustache' id='new-group-update'>
  138. <div class='conversation-header'>
  139. <button class='back'></button>
  140. <button class='send check'></button>
  141. <span class='conversation-title'>Update group</span>
  142. </div>
  143. {{> group_info_input }}
  144. <div class='container'>
  145. <div class='scrollable'></div>
  146. </div>
  147. </script>
  148. <script type='text/x-tmpl-mustache' id='identicon-svg'>
  149. <svg xmlns='http://www.w3.org/2000/svg' width='100' height='100'>
  150. <circle cx='50' cy='50' r='40' fill='{{ color }}' />
  151. <text text-anchor='middle' fill='white' font-size='24px' x='50' y='50' baseline-shift='-8px'>
  152. {{ content }}
  153. </text>
  154. </svg>
  155. </script>
  156. <script type='text/x-tmpl-mustache' id='avatar'>
  157. <span class='avatar' aria-hidden
  158. {{ #avatar.url }}
  159. style='background-image: url("{{ avatar.url }}");'>
  160. {{ /avatar.url }}
  161. {{ ^avatar.url }}
  162. style='background-color: {{ avatar.color }};'>
  163. {{ /avatar.url }}
  164. {{ avatar.content }}
  165. </span>
  166. </script>
  167. <script type='text/x-tmpl-mustache' id='contact_pill'>
  168. <span>{{ name }}</span><span class='remove'>x</span>
  169. </script>
  170. <script type='text/x-tmpl-mustache' id='contact_name_and_number'>
  171. <h3 class='name'> {{ title }} </h3>
  172. <div class='number'>{{ number }}</div>
  173. </script>
  174. <script type='text/x-tmpl-mustache' id='contact'>
  175. {{> avatar }}
  176. <div class='contact-details'> {{> contact_name_and_number }} </div>
  177. </script>
  178. <script type='text/x-tmpl-mustache' id='new-contact'>
  179. {{> avatar }}
  180. <div class='contact-details'>
  181. {{> contact_name_and_number }}
  182. </div>
  183. </script>
  184. <script type='text/x-tmpl-mustache' id='conversation-preview'>
  185. {{> avatar }}
  186. <div class='contact-details'>
  187. <span class='last-timestamp' data-timestamp={{ last_message_timestamp }}> </span>
  188. {{> contact_name_and_number }}
  189. {{ #unreadCount }}
  190. <span class='unread-count'>{{ unreadCount }}</span>
  191. {{ /unreadCount }}
  192. {{ #last_message }}
  193. <p class='last-message'> {{ last_message }} </p>
  194. {{ /last_message }}
  195. </div>
  196. </script>
  197. <script type='text/x-tmpl-mustache' id='phone-number'>
  198. <div class='phone-input-form'>
  199. <div class='number-container'>
  200. <input type='tel' class='number' placeholder="Phone Number" />
  201. </div>
  202. </div>
  203. </script>
  204. <script type='text/x-tmpl-mustache' id='file-size-modal'>
  205. {{ file-size-warning }}
  206. ({{ limit }}{{ units }})
  207. </script>
  208. <script type='text/x-tmpl-mustache' id='attachment-type-modal'>
  209. Sorry, your attachment has a type, {{type}}, that is not currently supported.
  210. </script>
  211. <script type='text/x-tmpl-mustache' id='message-detail'>
  212. <div class='container'>
  213. {{ #hasConflict }}
  214. <div class='hasConflict clearfix'>
  215. <div class='conflicts'>
  216. </div>
  217. </div>
  218. {{ /hasConflict }}
  219. <div class='message-container'></div>
  220. <div class='info'>
  221. <table>
  222. {{ #errors }}
  223. <tr>
  224. <td class='label'>{{ errorLabel }}</td>
  225. <td> <span class='error-message'>{{message}}</span> </td>
  226. </tr>
  227. {{ /errors }}
  228. <tr>
  229. <td class='label'>{{ sent }}</td>
  230. <td> {{ sent_at }}</td>
  231. </tr>
  232. {{ #received_at }}
  233. <tr>
  234. <td class='label'>{{ received }}</td>
  235. <td> {{ received_at }}</td>
  236. </tr>
  237. {{ /received_at }}
  238. <tr> <td class='tofrom label'>{{tofrom}}</td> </tr>
  239. </table>
  240. <div class='contacts'>
  241. </div>
  242. </div>
  243. </div>
  244. </script>
  245. <script type='text/x-tmpl-mustache' id='group-member-list'>
  246. <div class='container'></div>
  247. </script>
  248. <script type='text/x-tmpl-mustache' id='key_verification_panel'>
  249. <div class='container'>
  250. {{> key_verification }}
  251. <p> {{> link_to_support }} </p>
  252. </div>
  253. </script>
  254. <script type='text/x-tmpl-mustache' id='key_verification'>
  255. <label> {{theirIdentity}} </label>
  256. {{ ^their_key }}
  257. <div class='placeholder'>{{ their_key_unknown }}</div>
  258. {{ /their_key }}
  259. {{ #has_their_key }}
  260. <div class='key'>
  261. {{ #their_key }} <span>{{ . }}</span> {{ /their_key }}
  262. </div>
  263. {{ /has_their_key }}
  264. <label> {{yourIdentity}} </label>
  265. <div class='key'>
  266. {{ #your_key }} <span>{{ . }}</span> {{ /your_key }}
  267. </div>
  268. </script>
  269. <!-- index -->
  270. <script type='text/x-tmpl-mustache' id='group_info_input'>
  271. <div class='group-info-input'>
  272. <div class='group-avatar'>
  273. <div class='choose-file attachment-previews thumbnail'>
  274. {{> avatar }}
  275. </div>
  276. <input type='file' name='avatar' class='file-input'>
  277. </div>
  278. <input type='text' name='name' class='name' placeholder='Group Name' value='{{ name }}'>
  279. </div>
  280. </script>
  281. <script type='text/x-tmpl-mustache' id='new-conversation'>
  282. <div class='conversation-header'>
  283. <button class='back'></button>
  284. <button class='create check hide'></button>
  285. <span class='conversation-title'>New Message</span>
  286. </div>
  287. {{> group_info_input }}
  288. <div class='container'>
  289. <div class='scrollable'>
  290. </div>
  291. </div>
  292. </script>
  293. <script type='text/x-tmpl-mustache' id='recipients-input'>
  294. <div class='recipients-container'>
  295. <span class='recipients'></span>
  296. <input type='text' class='search' placeholder='{{ placeholder }}' />
  297. </div>
  298. <div class='results'>
  299. <div class='new-contact contact hide'></div>
  300. <div class='contacts'></div>
  301. </div>
  302. </script>
  303. <script type='text/x-tmpl-mustache' id='generic-error'>
  304. <p>{{ message }}</p>
  305. </script>
  306. <script type='text/x-tmpl-mustache' id='error-icon'>
  307. <span class='error-icon'>
  308. </span>
  309. {{ #message }}
  310. <span class='error-message'>{{message}}</span>
  311. {{ /message }}
  312. </script>
  313. <script type='text/x-tmpl-mustache' id='contact-detail'>
  314. <div class='clearfix'>
  315. {{> avatar }}
  316. <div class='contact-details'>
  317. {{ #errors }}
  318. <div class='error-icon-container'>
  319. <span class='error-icon'></span>
  320. </div>
  321. {{ /errors }}
  322. <span class='name'>{{ name }}</span>
  323. {{ #errors }}
  324. {{ #message }}
  325. <p class='error-message'>{{message}}</p>
  326. {{ /message }}
  327. {{ /errors }}
  328. </div>
  329. </div>
  330. </script>
  331. <script type='text/x-tmpl-mustache' id='link_to_support'>
  332. <a href='http://support.whispersystems.org/hc/articles/213134107' target='_blank'>
  333. {{ learnMore }}
  334. </a>
  335. </script>
  336. <script type='text/x-tmpl-mustache' id='key-conflict-dialogue'>
  337. <h3 class='header'>{{ newIdentity }}</h3>
  338. <div class='content clearfix'>
  339. <div class='clearfix'>
  340. {{> avatar }}
  341. <span class='name'>{{ name }}</span>
  342. <button class='resolve'>{{ resolve }}</button>
  343. <a href='#' class='hideKeys hide'> {{ hideKeys }} </a>
  344. <a href='#' class='showKeys'> {{ showKeys }} </a>
  345. </div>
  346. <div class='keys hide'>
  347. <p>
  348. {{ message }}
  349. {{> link_to_support }}
  350. </p>
  351. </div>
  352. </div>
  353. </script>
  354. <script type='text/x-tmpl-mustache' id='debug-log'>
  355. <div class='content'>
  356. <div>
  357. <a class='x close' alt='close debug log' href='#'></a>
  358. <h1> {{ title }} </h1>
  359. <p> {{ debugLogExplanation }}</p>
  360. </div>
  361. <textarea rows='5'></textarea>
  362. <div class='buttons'>
  363. <button class='submit'>{{ submit }}</button>
  364. </div>
  365. <div class='result'>
  366. </div>
  367. </div>
  368. </script>
  369. <script type='text/x-tmpl-mustache' id='debug-log-link'>
  370. <div class='input-group clearfix'>
  371. <input type='text' class='link' readonly value='{{ url }}' />
  372. <a class='open' alt='open in a new browser tab' target='_blank' href='{{ url }}'></a>
  373. </div>
  374. <p>
  375. <a class='report-link' target='_blank'
  376. href='https://github.com/WhisperSystems/Signal-Desktop/issues/new/'>
  377. {{ reportIssue }}
  378. </a>
  379. </p>
  380. </script>
  381. <script type='text/x-tmpl-mustache' id='settings'>
  382. <div class='content'>
  383. <a class='x close' alt='close settings' href='#'></a>
  384. <h3>{{ notifications }}</h3>
  385. <p>{{ notificationSettingsDialog }}</p>
  386. <div>
  387. <input type='radio' name='notifications' id='notification-setting-message' value='message'>
  388. <label for='notification-setting-message'>{{ nameAndMessage }} </label>
  389. </div>
  390. <div>
  391. <input type='radio' name='notifications' id='notification-setting-name' value='name'/>
  392. <label for='notification-setting-name'>{{ nameOnly }} </label>
  393. </div>
  394. <div>
  395. <input type='radio' name='notifications' id='notification-setting-count' value='count'/>
  396. <label for='notification-setting-count'>{{ noNameOrMessage }} </label>
  397. </div>
  398. <div>
  399. <input type='radio' name='notifications' id='notification-setting-off' value='off'/>
  400. <label for='notification-setting-off'>{{ disableNotifications }} </label>
  401. </div>
  402. </div>
  403. </script>
  404. <script type='text/javascript' src='js/components.js'></script>
  405. <script type='text/javascript' src='js/database.js'></script>
  406. <script type='text/javascript' src='js/debugLog.js'></script>
  407. <script type='text/javascript' src='js/storage.js'></script>
  408. <script type='text/javascript' src='js/signal_protocol_store.js'></script>
  409. <script type='text/javascript' src='js/libtextsecure.js'></script>
  410. <script type='text/javascript' src='js/notifications.js'></script>
  411. <script type='text/javascript' src='js/delivery_receipts.js'></script>
  412. <script type='text/javascript' src='js/read_receipts.js'></script>
  413. <script type='text/javascript' src='js/libphonenumber-util.js'></script>
  414. <script type='text/javascript' src='js/models/messages.js'></script>
  415. <script type='text/javascript' src='js/models/conversations.js'></script>
  416. <script type='text/javascript' src='js/chromium.js'></script>
  417. <script type='text/javascript' src='js/expire.js'></script>
  418. <script type='text/javascript' src='js/conversation_controller.js'></script>
  419. <script type='text/javascript' src='js/panel_controller.js'></script>
  420. <script type='text/javascript' src='js/emoji_util.js'></script>
  421. <script type='text/javascript' src='js/views/whisper_view.js'></script>
  422. <script type='text/javascript' src='js/views/debug_log_view.js'></script>
  423. <script type='text/javascript' src='js/views/toast_view.js'></script>
  424. <script type='text/javascript' src='js/views/attachment_preview_view.js'></script>
  425. <script type='text/javascript' src='js/views/file_input_view.js'></script>
  426. <script type='text/javascript' src='js/views/list_view.js'></script>
  427. <script type='text/javascript' src='js/views/conversation_list_item_view.js'></script>
  428. <script type='text/javascript' src='js/views/conversation_list_view.js'></script>
  429. <script type='text/javascript' src='js/views/contact_list_view.js'></script>
  430. <script type='text/javascript' src='js/views/new_group_update_view.js'></script>
  431. <script type='text/javascript' src='js/views/attachment_view.js'></script>
  432. <script type='text/javascript' src='js/views/key_conflict_dialogue_view.js'></script>
  433. <script type='text/javascript' src='js/views/error_view.js'></script>
  434. <script type='text/javascript' src='js/views/timestamp_view.js'></script>
  435. <script type='text/javascript' src='js/views/message_view.js'></script>
  436. <script type='text/javascript' src='js/views/key_verification_view.js'></script>
  437. <script type='text/javascript' src='js/views/message_detail_view.js'></script>
  438. <script type='text/javascript' src='js/views/message_list_view.js'></script>
  439. <script type='text/javascript' src='js/views/group_member_list_view.js'></script>
  440. <script type='text/javascript' src='js/views/conversation_view.js'></script>
  441. <script type='text/javascript' src='js/views/new_conversation_view.js'></script>
  442. <script type='text/javascript' src='js/views/conversation_search_view.js'></script>
  443. <script type='text/javascript' src='js/views/window_controls_view.js'></script>
  444. <script type='text/javascript' src='js/views/hint_view.js'></script>
  445. <script type='text/javascript' src='js/views/inbox_view.js'></script>
  446. <script type='text/javascript' src='js/views/confirmation_dialog_view.js'></script>
  447. <script type='text/javascript' src='js/views/identicon_svg_view.js'></script>
  448. <script type='text/javascript' src='js/views/settings_view.js'></script>
  449. <script type='text/javascript' src='js/background.js'></script>
  450. </head>
  451. <body>
  452. </body>
  453. </html>