background.html 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550
  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='showSettings'>{{ 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'></span>
  19. </div>
  20. </div>
  21. <h1>Cable</h1>
  22. <div class='tool-bar clearfix'>
  23. <input type='search' class='search' placeholder='{{ searchForPeopleOrGroups }}' dir='auto'>
  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. <div class='conversation-header'></div>
  37. <div class='content'>
  38. <img src='/images/icon_128.png' />
  39. <h3>{{ welcomeToSignal }}</h3>
  40. <p>{{ selectAContact }}</p>
  41. </div>
  42. </div>
  43. </div>
  44. </script>
  45. <script type='text/x-tmpl-mustache' id='expired_alert'>
  46. <a target='_blank' href='https://chrome.google.com/webstore/detail/bikioccmkafdpakkkcpdbppfkghcmihk'>
  47. <button class='upgrade'>{{ upgrade }}</button>
  48. </a>
  49. {{ expiredWarning }}
  50. </script>
  51. <script type='text/x-tmpl-mustache' id='toast'>
  52. {{ toastMessage }}
  53. </script>
  54. <script type='text/x-tmpl-mustache' id='hint'>
  55. <p> {{ content }}</p>
  56. </script>
  57. <script type='text/x-tmpl-mustache' id='conversation'>
  58. <div class='conversation-header {{ avatar.color }}'>
  59. <div class='header-buttons left'>
  60. <div class='vertical-align'>
  61. <button class='back hide'></button>
  62. </div>
  63. </div>
  64. <div class='header-buttons right'>
  65. <div class='vertical-align'>
  66. <div class='conversation-menu menu'>
  67. <button class='hamburger' alt='conversation menu'></button>
  68. <ul class='menu-list'>
  69. {{#group}}
  70. <li class='view-members'>{{ view-members }}</li>
  71. <!-- <li class='update-group'>Update group</li> -->
  72. <!-- <li class='leave-group'>Leave group</li> -->
  73. {{/group}}
  74. {{^group}}
  75. <li class='end-session'>{{ end-session }}</li>
  76. <li class='verify-identity'>{{ verify-identity }}</li>
  77. {{/group}}
  78. <li class='disappearing-messages'>{{ disappearing-messages }}</li>
  79. <li class='destroy'>{{ destroy }}</li>
  80. </ul>
  81. </div>
  82. <div class='timer-menu menu'>
  83. <button class='clock' alt='timer menu'></button>
  84. <ul class='menu-list'>
  85. {{ #timer_options }}
  86. <li data-seconds={{ attributes.seconds }}>{{ getName }}</li>
  87. {{ /timer_options }}
  88. </ul>
  89. </div>
  90. </div>
  91. </div>
  92. <span class='conversation-title'>
  93. {{ #name }}
  94. <span class='conversation-name' dir='auto'>{{ name }}</span>
  95. {{ /name }}
  96. {{ #number }}
  97. <span class='conversation-number'>{{ number }}</span>
  98. {{ /number }}
  99. </span>
  100. {{> avatar }}
  101. </div>
  102. <div class='main panel'>
  103. <div class='discussion-container'>
  104. <div class='bar-container hide'>
  105. <div class='bar active progress-bar-striped progress-bar'></div>
  106. </div>
  107. </div>
  108. <div class='bottom-bar' id='footer'>
  109. <form class='send clearfix'>
  110. <div class='attachment-previews'></div>
  111. <div class='flex'>
  112. <div class='choose-file'>
  113. <button class='paperclip thumbnail'></button>
  114. <input type='file' class='file-input'>
  115. </div>
  116. <textarea class='send-message' placeholder='{{ send-message }}' rows='1' dir='auto'></textarea>
  117. <div class='capture-audio'>
  118. <!--<button class='microphone'></button>-->
  119. </div>
  120. </div>
  121. </form>
  122. </div>
  123. </div>
  124. </script>
  125. <script type='text/x-tmpl-mustache' id='recorder'>
  126. <button class='finish'><span class='icon'></span></button>
  127. <span class='time'>0:00</span>
  128. <button class='close'><span class='icon'></span></button>
  129. </script>
  130. <script type='text/x-tmpl-mustache' id='lightbox'>
  131. <div class='content'>
  132. <div class='controls'>
  133. <a class='x close' alt='Close image.' href='#'></a>
  134. <a class='save' alt='Save as...' href='#'></a>
  135. </div>
  136. <img class='image' src='{{ url }}' />
  137. </div>
  138. </script>
  139. <script type='text/x-tmpl-mustache' id='confirmation-dialog'>
  140. <div class="content">
  141. <div class='message'>{{ message }}</div>
  142. <div class='buttons'>
  143. <button class='cancel'>{{ cancel }}</button>
  144. <button class='ok'>{{ ok }}</button>
  145. </div>
  146. </div>
  147. </script>
  148. <script type='text/x-tmpl-mustache' id='attachment-preview'>
  149. <img src='{{ source }}' class='preview' />
  150. <a class='x close' alt='remove attachment' href='#'></a>
  151. </script>
  152. <script type='text/x-tmpl-mustache' id='hasRetry'>
  153. {{ messageNotSent }}
  154. <span href='#' class='retry'>{{ resend }}</span>
  155. </script>
  156. <script type='text/x-tmpl-mustache' id='keychange'>
  157. <span class='content' dir='auto'>{{ content }}</span>
  158. </script>
  159. <script type='text/x-tmpl-mustache' id='message'>
  160. {{> avatar }}
  161. <div class='bubble {{ avatar.color }}'>
  162. <div class='sender' dir='auto'>{{ sender }}</div>
  163. <div class='attachments'></div>
  164. <p class='content' dir='auto'>
  165. {{ #message }}<span class='body'>{{ message }}</span>{{ /message }}
  166. </p>
  167. <div class='meta'>
  168. <span class='timestamp' data-timestamp={{ timestamp }}></span>
  169. <span class='status hide'></span>
  170. <span class='timer'></span>
  171. </div>
  172. </div>
  173. </script>
  174. <script type='text/x-tmpl-mustache' id='hourglass'>
  175. <span class='hourglass'><span class='sand'></span></span>
  176. </script>
  177. <script type='text/x-tmpl-mustache' id='expirationTimerUpdate'>
  178. <span class='content'>{{ content }}</span>
  179. </script>
  180. <script type='text/x-tmpl-mustache' id='new-group-update'>
  181. <div class='conversation-header'>
  182. <button class='back'></button>
  183. <button class='send check'></button>
  184. <span class='conversation-title'>Update group</span>
  185. </div>
  186. {{> group_info_input }}
  187. <div class='container'>
  188. <div class='scrollable'></div>
  189. </div>
  190. </script>
  191. <script type='text/x-tmpl-mustache' id='identicon-svg'>
  192. <svg xmlns='http://www.w3.org/2000/svg' width='100' height='100'>
  193. <circle cx='50' cy='50' r='40' fill='{{ color }}' />
  194. <text text-anchor='middle' fill='white' font-size='24px' x='50' y='50' baseline-shift='-8px'>
  195. {{ content }}
  196. </text>
  197. </svg>
  198. </script>
  199. <script type='text/x-tmpl-mustache' id='avatar'>
  200. <span aria-hidden class='avatar
  201. {{ ^avatar.url }}
  202. {{ avatar.color }}
  203. {{ /avatar.url }}
  204. '
  205. {{ #avatar.url }}
  206. style='background-image: url("{{ avatar.url }}");'
  207. {{ /avatar.url }}
  208. >
  209. {{ avatar.content }}
  210. </span>
  211. </script>
  212. <script type='text/x-tmpl-mustache' id='contact_pill'>
  213. <span>{{ name }}</span><span class='remove'>x</span>
  214. </script>
  215. <script type='text/x-tmpl-mustache' id='contact_name_and_number'>
  216. <h3 class='name' dir='auto'> {{ title }} </h3>
  217. <div class='number'>{{ number }}</div>
  218. </script>
  219. <script type='text/x-tmpl-mustache' id='contact'>
  220. {{> avatar }}
  221. <div class='contact-details'> {{> contact_name_and_number }} </div>
  222. </script>
  223. <script type='text/x-tmpl-mustache' id='new-contact'>
  224. {{> avatar }}
  225. <div class='contact-details'>
  226. {{> contact_name_and_number }}
  227. </div>
  228. </script>
  229. <script type='text/x-tmpl-mustache' id='conversation-preview'>
  230. {{> avatar }}
  231. <div class='contact-details'>
  232. <span class='last-timestamp' data-timestamp='{{ last_message_timestamp }}' dir='auto' > </span>
  233. {{> contact_name_and_number }}
  234. {{ #unreadCount }}
  235. <span class='unread-count'>{{ unreadCount }}</span>
  236. {{ /unreadCount }}
  237. {{ #last_message }}
  238. <p class='last-message' dir='auto'> {{ last_message }} </p>
  239. {{ /last_message }}
  240. </div>
  241. </script>
  242. <script type='text/x-tmpl-mustache' id='phone-number'>
  243. <div class='phone-input-form'>
  244. <div class='number-container'>
  245. <input type='tel' class='number' placeholder="Phone Number" />
  246. </div>
  247. </div>
  248. </script>
  249. <script type='text/x-tmpl-mustache' id='file-size-modal'>
  250. {{ file-size-warning }}
  251. ({{ limit }}{{ units }})
  252. </script>
  253. <script type='text/x-tmpl-mustache' id='attachment-type-modal'>
  254. Sorry, your attachment has a type, {{type}}, that is not currently supported.
  255. </script>
  256. <script type='text/x-tmpl-mustache' id='message-detail'>
  257. <div class='container'>
  258. {{ #hasConflict }}
  259. <div class='hasConflict clearfix'>
  260. <div class='conflicts'>
  261. </div>
  262. </div>
  263. {{ /hasConflict }}
  264. <div class='message-container'></div>
  265. <div class='info'>
  266. <table>
  267. {{ #errors }}
  268. <tr>
  269. <td class='label'>{{ errorLabel }}</td>
  270. <td> <span class='error-message'>{{message}}</span> </td>
  271. </tr>
  272. {{ /errors }}
  273. <tr>
  274. <td class='label'>{{ sent }}</td>
  275. <td> {{ sent_at }}</td>
  276. </tr>
  277. {{ #received_at }}
  278. <tr>
  279. <td class='label'>{{ received }}</td>
  280. <td> {{ received_at }}</td>
  281. </tr>
  282. {{ /received_at }}
  283. <tr> <td class='tofrom label'>{{tofrom}}</td> </tr>
  284. </table>
  285. <div class='contacts'>
  286. </div>
  287. </div>
  288. </div>
  289. </script>
  290. <script type='text/x-tmpl-mustache' id='group-member-list'>
  291. <div class='container'></div>
  292. </script>
  293. <script type='text/x-tmpl-mustache' id='key_verification_panel'>
  294. <div class='container'>
  295. {{> key_verification }}
  296. <p> {{> link_to_support }} </p>
  297. </div>
  298. </script>
  299. <script type='text/x-tmpl-mustache' id='key_verification'>
  300. {{ ^has_their_key }}
  301. <div class='placeholder'>{{ their_key_unknown }}</div>
  302. {{ /has_their_key }}
  303. {{ #has_their_key }}
  304. <label> {{ yourSafetyNumberWith }} </label>
  305. <!--<div class='qr'></div>-->
  306. <div class='key'>
  307. {{ #chunks }} <span>{{ . }}</span> {{ /chunks }}
  308. </div>
  309. {{ /has_their_key }}
  310. </script>
  311. <!-- index -->
  312. <script type='text/x-tmpl-mustache' id='group_info_input'>
  313. <div class='group-info-input'>
  314. <div class='group-avatar'>
  315. <div class='choose-file attachment-previews thumbnail'>
  316. {{> avatar }}
  317. </div>
  318. <input type='file' name='avatar' class='file-input'>
  319. </div>
  320. <input type='text' name='name' class='name' placeholder='Group Name' value='{{ name }}'>
  321. </div>
  322. </script>
  323. <script type='text/x-tmpl-mustache' id='new-conversation'>
  324. <div class='conversation-header'>
  325. <button class='back'></button>
  326. <button class='create check hide'></button>
  327. <span class='conversation-title'>New Message</span>
  328. </div>
  329. {{> group_info_input }}
  330. <div class='container'>
  331. <div class='scrollable'>
  332. </div>
  333. </div>
  334. </script>
  335. <script type='text/x-tmpl-mustache' id='recipients-input'>
  336. <div class='recipients-container'>
  337. <span class='recipients'></span>
  338. <input type='text' class='search' placeholder='{{ placeholder }}' dir='auto' />
  339. </div>
  340. <div class='results'>
  341. <div class='new-contact contact hide'></div>
  342. <div class='contacts'></div>
  343. </div>
  344. </script>
  345. <script type='text/x-tmpl-mustache' id='generic-error'>
  346. <p>{{ message }}</p>
  347. </script>
  348. <script type='text/x-tmpl-mustache' id='error-icon'>
  349. <span class='error-icon'>
  350. </span>
  351. {{ #message }}
  352. <span class='error-message'>{{message}}</span>
  353. {{ /message }}
  354. </script>
  355. <script type='text/x-tmpl-mustache' id='contact-detail'>
  356. <div class='clearfix'>
  357. {{> avatar }}
  358. <div class='contact-details'>
  359. {{ #errors }}
  360. <div class='error-icon-container'>
  361. <span class='error-icon'></span>
  362. </div>
  363. {{ /errors }}
  364. <span class='name' dir='auto'>{{ name }}</span>
  365. {{ #errors }}
  366. {{ #message }}
  367. <p class='error-message'>{{message}}</p>
  368. {{ /message }}
  369. {{ /errors }}
  370. </div>
  371. </div>
  372. </script>
  373. <script type='text/x-tmpl-mustache' id='link_to_support'>
  374. <a href='http://support.whispersystems.org/hc/articles/213134107' target='_blank'>
  375. {{ learnMore }}
  376. </a>
  377. </script>
  378. <script type='text/x-tmpl-mustache' id='key-conflict-dialogue'>
  379. <h3 class='header'>{{ newIdentity }}</h3>
  380. <div class='content clearfix'>
  381. <div class='clearfix'>
  382. {{> avatar }}
  383. <span class='name'>{{ name }}</span>
  384. <button class='resolve'>{{ resolve }}</button>
  385. <a href='#' class='hideKeys hide'> {{ hideKeys }} </a>
  386. <a href='#' class='showKeys'> {{ showKeys }} </a>
  387. </div>
  388. <div class='keys hide'>
  389. <p>
  390. {{ message }}
  391. {{> link_to_support }}
  392. </p>
  393. </div>
  394. </div>
  395. </script>
  396. <script type='text/x-tmpl-mustache' id='debug-log'>
  397. <div class='content'>
  398. <div>
  399. <a class='x close' alt='close debug log' href='#'></a>
  400. <h1> {{ title }} </h1>
  401. <p> {{ debugLogExplanation }}</p>
  402. </div>
  403. <textarea rows='5'></textarea>
  404. <div class='buttons'>
  405. <button class='grey submit'>{{ submit }}</button>
  406. </div>
  407. <div class='result'>
  408. </div>
  409. </div>
  410. </script>
  411. <script type='text/x-tmpl-mustache' id='debug-log-link'>
  412. <div class='input-group clearfix'>
  413. <input type='text' class='link' readonly value='{{ url }}' />
  414. <a class='open' alt='open in a new browser tab' target='_blank' href='{{ url }}'></a>
  415. </div>
  416. <p>
  417. <a class='report-link' target='_blank'
  418. href='https://github.com/WhisperSystems/Signal-Desktop/issues/new/'>
  419. {{ reportIssue }}
  420. </a>
  421. </p>
  422. </script>
  423. <script type='text/x-tmpl-mustache' id='settings'>
  424. <div class='content'>
  425. <a class='x close' alt='close settings' href='#'></a>
  426. <h2>{{ settings }}</h2>
  427. <hr>
  428. <div class='theme-settings'>
  429. <h3>{{ theme }}</h3>
  430. <div>
  431. <input type='radio' name='theme' id='theme-setting-android' value='android'>
  432. <label for='theme-setting-android'>Android</label>
  433. </div>
  434. <div>
  435. <input type='radio' name='theme' id='theme-setting-android-dark' value='android-dark'>
  436. <label for='theme-setting-android-dark'>{{ themeAndroidDark }}</label>
  437. </div>
  438. <div>
  439. <input type='radio' name='theme' id='theme-setting-ios' value='ios'/>
  440. <label for='theme-setting-ios'>iOS</label>
  441. </div>
  442. </div>
  443. <hr>
  444. <div class='notification-settings'>
  445. <h3>{{ notifications }}</h3>
  446. <p>{{ notificationSettingsDialog }}</p>
  447. <div>
  448. <input type='radio' name='notifications' id='notification-setting-message' value='message'>
  449. <label for='notification-setting-message'>{{ nameAndMessage }} </label>
  450. </div>
  451. <div>
  452. <input type='radio' name='notifications' id='notification-setting-name' value='name'/>
  453. <label for='notification-setting-name'>{{ nameOnly }} </label>
  454. </div>
  455. <div>
  456. <input type='radio' name='notifications' id='notification-setting-count' value='count'/>
  457. <label for='notification-setting-count'>{{ noNameOrMessage }} </label>
  458. </div>
  459. <div>
  460. <input type='radio' name='notifications' id='notification-setting-off' value='off'/>
  461. <label for='notification-setting-off'>{{ disableNotifications }} </label>
  462. </div>
  463. </div>
  464. <br />
  465. <div class='audio-notification-setting'>
  466. <input type='checkbox' name='audio-notification' id='audio-notification'/>
  467. <label for='audio-notification'>{{ audioNotificationDescription }}</label>
  468. </div>
  469. <hr>
  470. <div class='safety-numbers-settings'>
  471. <h3>{{ safetyNumbersSettingHeader }}</h3>
  472. <input type='checkbox' name='safety-numbers-approval' id='safety-numbers-approval'/>
  473. <label for='safety-numbers-approval'>{{ safetyNumbersSettingDescription }}</label>
  474. </div>
  475. </div>
  476. </script>
  477. <script type='text/x-tmpl-mustache' id='syncSettings'>
  478. <hr>
  479. <h3>{{ sync }}</h3>
  480. <div>
  481. <button class='grey sync'>{{ syncNow }}</button>
  482. <p>
  483. {{ syncExplanation }}
  484. <div class='synced_at'>
  485. {{ lastSynced }} {{ syncDate }} {{ syncTime }}
  486. </div>
  487. <div class='sync_failed'>{{ syncFailed }}</div>
  488. </p>
  489. </div>
  490. </script>
  491. <script type='text/javascript' src='js/components.js'></script>
  492. <script type='text/javascript' src='js/database.js'></script>
  493. <script type='text/javascript' src='js/debugLog.js'></script>
  494. <script type='text/javascript' src='js/storage.js'></script>
  495. <script type='text/javascript' src='js/signal_protocol_store.js'></script>
  496. <script type='text/javascript' src='js/libtextsecure.js'></script>
  497. <script type='text/javascript' src='js/notifications.js'></script>
  498. <script type='text/javascript' src='js/delivery_receipts.js'></script>
  499. <script type='text/javascript' src='js/read_receipts.js'></script>
  500. <script type='text/javascript' src='js/libphonenumber-util.js'></script>
  501. <script type='text/javascript' src='js/models/messages.js'></script>
  502. <script type='text/javascript' src='js/models/conversations.js'></script>
  503. <script type='text/javascript' src='js/models/blockedNumbers.js'></script>
  504. <script type='text/javascript' src='js/expiring_messages.js'></script>
  505. <script type='text/javascript' src='js/chromium.js'></script>
  506. <script type='text/javascript' src='js/registration.js'></script>
  507. <script type='text/javascript' src='js/expire.js'></script>
  508. <script type='text/javascript' src='js/conversation_controller.js'></script>
  509. <script type='text/javascript' src='js/panel_controller.js'></script>
  510. <script type='text/javascript' src='js/emoji_util.js'></script>
  511. <script type='text/javascript' src='js/views/whisper_view.js'></script>
  512. <script type='text/javascript' src='js/views/debug_log_view.js'></script>
  513. <script type='text/javascript' src='js/views/toast_view.js'></script>
  514. <script type='text/javascript' src='js/views/attachment_preview_view.js'></script>
  515. <script type='text/javascript' src='js/views/file_input_view.js'></script>
  516. <script type='text/javascript' src='js/views/list_view.js'></script>
  517. <script type='text/javascript' src='js/views/conversation_list_item_view.js'></script>
  518. <script type='text/javascript' src='js/views/conversation_list_view.js'></script>
  519. <script type='text/javascript' src='js/views/contact_list_view.js'></script>
  520. <script type='text/javascript' src='js/views/new_group_update_view.js'></script>
  521. <script type='text/javascript' src='js/views/attachment_view.js'></script>
  522. <script type='text/javascript' src='js/views/key_conflict_dialogue_view.js'></script>
  523. <script type='text/javascript' src='js/views/error_view.js'></script>
  524. <script type='text/javascript' src='js/views/timestamp_view.js'></script>
  525. <script type='text/javascript' src='js/views/message_view.js'></script>
  526. <script type='text/javascript' src='js/views/key_verification_view.js'></script>
  527. <script type='text/javascript' src='js/views/message_detail_view.js'></script>
  528. <script type='text/javascript' src='js/views/message_list_view.js'></script>
  529. <script type='text/javascript' src='js/views/group_member_list_view.js'></script>
  530. <script type='text/javascript' src='js/views/recorder_view.js'></script>
  531. <script type='text/javascript' src='js/views/conversation_view.js'></script>
  532. <script type='text/javascript' src='js/views/conversation_search_view.js'></script>
  533. <script type='text/javascript' src='js/views/hint_view.js'></script>
  534. <script type='text/javascript' src='js/views/inbox_view.js'></script>
  535. <script type='text/javascript' src='js/views/confirmation_dialog_view.js'></script>
  536. <script type='text/javascript' src='js/views/identicon_svg_view.js'></script>
  537. <script type='text/javascript' src='js/views/settings_view.js'></script>
  538. <script type='text/javascript' src='js/wall_clock_listener.js'></script>
  539. <script type='text/javascript' src='js/rotate_signed_prekey_listener.js'></script>
  540. <script type='text/javascript' src='js/background.js'></script>
  541. </head>
  542. <body>
  543. </body>
  544. </html>