666 lines
27 KiB
HTML
666 lines
27 KiB
HTML
<html>
|
|
|
|
<head>
|
|
<meta charset='utf-8'>
|
|
<title>TextSecure test runner</title>
|
|
<link rel="stylesheet" href="../node_modules/mocha/mocha.css" />
|
|
<link rel="stylesheet" href="../stylesheets/manifest.css" />
|
|
</head>
|
|
<body>
|
|
<div id="mocha">
|
|
</div>
|
|
<div id="tests">
|
|
</div>
|
|
<div id="render-android" class='index' style="width: 800; height: 500; margin:10px; border: solid 1px black;">
|
|
</div>
|
|
<div id="render-android-dark" class='index' style="width: 800; height: 500; margin:10px; border: solid 1px black;">
|
|
</div>
|
|
<div id="render-ios" class='index' style="width: 800; height: 500; margin:10px; border: solid 1px black;">
|
|
</div>
|
|
<script type='text/x-tmpl-mustache' id='app-loading-screen'>
|
|
<div class='content'>
|
|
<img src='/images/icon_128.png'>
|
|
<div class='container'>
|
|
<span class='dot'></span>
|
|
<span class='dot'></span>
|
|
<span class='dot'></span>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='conversation-loading-screen'>
|
|
<div class='content'>
|
|
<img src='/images/icon_128.png'>
|
|
<div class='container'>
|
|
<span class='dot'></span>
|
|
<span class='dot'></span>
|
|
<span class='dot'></span>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='two-column'>
|
|
<div class='gutter'>
|
|
<div class='network-status-container'></div>
|
|
<div class='title-bar active' id='header'>
|
|
<h1>Signal</h1>
|
|
<div class='tool-bar clearfix'>
|
|
<input type='search' class='search' placeholder='{{ searchForPeopleOrGroups }}' dir='auto'>
|
|
<span class='search-icon'></span>
|
|
</div>
|
|
</div>
|
|
<div class='content'>
|
|
<div class='conversations scrollable inbox'></div>
|
|
<div class='conversations scrollable search-results hide'>
|
|
<div class='new-contact contact hide'></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class='conversation-stack'>
|
|
<div class='conversation placeholder'>
|
|
<div class='conversation-header'></div>
|
|
<div class='content'>
|
|
<img src='/images/icon_128.png' />
|
|
<h3>{{ welcomeToSignal }}</h3>
|
|
<p>{{ selectAContact }}</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='scroll-down-button-view'>
|
|
<button class='text {{ cssClass }}' alt='{{ moreBelow }}'>
|
|
<div class='icon'></div>
|
|
</button>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='last-seen-indicator-view'>
|
|
<div class='bar'>
|
|
<div class='text'>
|
|
{{ unreadMessages }}
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='expired_alert'>
|
|
<a target='_blank' href='https://signal.org/download/'>
|
|
<button class='upgrade'>{{ upgrade }}</button>
|
|
</a>
|
|
{{ expiredWarning }}
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='banner'>
|
|
<div class='body'>
|
|
<span class='icon warning'></span>
|
|
{{ message }}
|
|
<span class='icon dismiss'></span>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='toast'>
|
|
{{ toastMessage }}
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='hint'>
|
|
<p> {{ content }}</p>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='conversation'>
|
|
<div class='conversation-header {{ avatar.color }}'>
|
|
<div class='header-buttons left'>
|
|
<div class='vertical-align'>
|
|
<button class='back hide'></button>
|
|
</div>
|
|
</div>
|
|
<div class='header-buttons right'>
|
|
<div class='vertical-align'>
|
|
<div class='conversation-menu menu'>
|
|
<button class='hamburger' alt='conversation menu'></button>
|
|
<ul class='menu-list'>
|
|
<li class='disappearing-messages'>{{ disappearing-messages }}</li>
|
|
{{#group}}
|
|
<li class='show-members'>{{ show-members }}</li>
|
|
<!-- <li class='update-group'>Update group</li> -->
|
|
<!-- <li class='leave-group'>Leave group</li> -->
|
|
{{/group}}
|
|
{{^group}}
|
|
{{ ^isMe }}
|
|
<li class='show-identity'>{{ show-identity }}</li>
|
|
{{ /isMe }}
|
|
<li class='end-session'>{{ end-session }}</li>
|
|
{{/group}}
|
|
<li class='destroy'>{{ destroy }}</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<span class='conversation-title'></span>
|
|
{{> avatar }}
|
|
</div>
|
|
<div class='main panel'>
|
|
<div class='discussion-container'>
|
|
<div class='bar-container hide'>
|
|
<div class='bar active progress-bar-striped progress-bar'></div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class='bottom-bar' id='footer'>
|
|
<form class='send clearfix'>
|
|
<div class='attachment-previews'></div>
|
|
<div class='flex'>
|
|
<div class='choose-file'>
|
|
<button class='paperclip thumbnail'></button>
|
|
<input type='file' class='file-input'>
|
|
</div>
|
|
<textarea class='send-message' placeholder='{{ send-message }}' rows='1' dir='auto'></textarea>
|
|
<div class='capture-audio'>
|
|
<!--<button class='microphone'></button>-->
|
|
</div>
|
|
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='recorder'>
|
|
<button class='finish'><span class='icon'></span></button>
|
|
<span class='time'>0:00</span>
|
|
<button class='close'><span class='icon'></span></button>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='confirmation-dialog'>
|
|
<div class="content">
|
|
<div class='message'>{{ message }}</div>
|
|
<div class='buttons'>
|
|
{{ #showCancel }}
|
|
<button class='cancel' tabindex='2'>{{ cancel }}</button>
|
|
{{ /showCancel }}
|
|
<button class='ok' tabindex='1'>{{ ok }}</button>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='attachment-preview'>
|
|
<img src='{{ source }}' class='preview' />
|
|
<a class='x close' alt='remove attachment' href='#'></a>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='hasRetry'>
|
|
{{ messageNotSent }}
|
|
<span href='#' class='retry'>{{ resend }}</span>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='keychange'>
|
|
<span class='content' dir='auto'><span class='shield icon'></span> {{ content }}</span>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='verified-change'>
|
|
<span class='content' dir='auto'><span class='{{ icon }} icon'></span> {{ content }}</span>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='message'>
|
|
{{> avatar }}
|
|
<div class='bubble {{ avatar.color }}'>
|
|
<div class='sender' dir='auto'>
|
|
{{ sender }}
|
|
{{ #profileName }}
|
|
<span class='profileName'>{{ profileName }} </span>
|
|
{{ /profileName }}
|
|
</div>
|
|
<div class='tail-wrapper {{ innerBubbleClasses }}'>
|
|
<div class='inner-bubble'>
|
|
{{ #hasAttachments }}
|
|
<div class='attachments'></div>
|
|
{{ /hasAttachments }}
|
|
{{ #hasBody }}
|
|
<div class='content' dir='auto'>
|
|
{{ #message }}
|
|
<div class='body'></div>
|
|
{{ /message }}
|
|
</div>
|
|
{{ /hasBody }}
|
|
</div>
|
|
</div>
|
|
<div class='meta'>
|
|
<span class='timestamp' data-timestamp={{ timestamp }}></span>
|
|
<span class='status hide'></span>
|
|
<span class='timer'></span>
|
|
</div>
|
|
{{ #hoverIcon }}
|
|
<div class='menu-container menu'>
|
|
<div class='menu-anchor'>
|
|
<span class='dots-horizontal-icon'></span>
|
|
<ul class='menu-list'>
|
|
<li class='reply'>{{ reply }}</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
{{ /hoverIcon }}
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='hourglass'>
|
|
<span class='hourglass'><span class='sand'></span></span>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='expirationTimerUpdate'>
|
|
<span class='content'><span class='icon clock'></span> {{ content }}</span>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='new-group-update'>
|
|
<div class='conversation-header'>
|
|
<button class='back'></button>
|
|
<button class='send check'></button>
|
|
<span class='conversation-title'>Update group</span>
|
|
</div>
|
|
{{> group_info_input }}
|
|
<div class='container'>
|
|
<div class='scrollable'></div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='identicon-svg'>
|
|
<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-family='sans-serif' font-size='24px' x='50' y='50' baseline-shift='-8px'>
|
|
{{ content }}
|
|
</text>
|
|
</svg>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='avatar'>
|
|
<span aria-hidden class='avatar
|
|
{{ ^avatar.url }}
|
|
{{ avatar.color }}
|
|
{{ /avatar.url }}
|
|
'
|
|
{{ #avatar.url }}
|
|
style='background-image: url("{{ avatar.url }}");'
|
|
{{ /avatar.url }}
|
|
>
|
|
{{ avatar.content }}
|
|
</span>
|
|
</script>
|
|
<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_name_and_number'>
|
|
<h3 class='name' dir='auto'> {{ title }} </h3>
|
|
<div class='number'>{{ #isVerified }}<span class='verified-icon'></span> {{ verified }} ·{{ /isVerified }} {{ number }}</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='contact'>
|
|
{{> avatar }}
|
|
<div class='contact-details'> {{> contact_name_and_number }} </div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='new-contact'>
|
|
{{> avatar }}
|
|
<div class='contact-details'>
|
|
{{> contact_name_and_number }}
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='conversation-preview'>
|
|
{{> avatar }}
|
|
<div class='contact-details'>
|
|
<span class='last-timestamp' data-timestamp='{{ last_message_timestamp }}' dir='auto' > </span>
|
|
{{> contact_name_and_number }}
|
|
{{ #unreadCount }}
|
|
<span class='unread-count'>{{ unreadCount }}</span>
|
|
{{ /unreadCount }}
|
|
{{ #last_message }}
|
|
<p class='last-message' dir='auto'></p>
|
|
{{ /last_message }}
|
|
</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'>
|
|
{{ file-size-warning }}
|
|
({{ limit }}{{ units }})
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='attachment-type-modal'>
|
|
Sorry, your attachment has a type, {{type}}, that is not currently supported.
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='message-detail'>
|
|
<div class='container'>
|
|
<div class='message-container'></div>
|
|
<div class='info'>
|
|
<table>
|
|
{{ #errors }}
|
|
<tr>
|
|
<td class='label'>{{ errorLabel }}</td>
|
|
<td> <span class='error-message'>{{message}}</span> </td>
|
|
</tr>
|
|
{{ /errors }}
|
|
<tr>
|
|
<td class='label'>{{ sent }}</td>
|
|
<td> {{ sent_at }}</td>
|
|
</tr>
|
|
{{ #received_at }}
|
|
<tr>
|
|
<td class='label'>{{ received }}</td>
|
|
<td> {{ received_at }}</td>
|
|
</tr>
|
|
{{ /received_at }}
|
|
<tr> <td class='tofrom label'>{{tofrom}}</td> </tr>
|
|
</table>
|
|
<div class='contacts'>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='identity-key-send-error'>
|
|
<div class='container'>
|
|
<div class='explanation'>
|
|
{{ errorExplanation }}
|
|
</div>
|
|
<div class='safety-number'>
|
|
<button class='show-safety-number grey'>{{ showSafetyNumber }}</button>
|
|
</div>
|
|
<div class='actions'>
|
|
<button class='send-anyway grey'>{{ sendAnyway }}</button>
|
|
<button class='cancel grey'>{{ cancel }}</button>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='group-member-list'>
|
|
<div class='container'>
|
|
{{ #summary }} <div class='summary'>{{ summary }}</div>{{ /summary }}
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='key-verification'>
|
|
<div class='container'>
|
|
{{ ^hasTheirKey }}
|
|
<div class='placeholder'>{{ theirKeyUnknown }}</div>
|
|
{{ /hasTheirKey }}
|
|
{{ #hasTheirKey }}
|
|
<label> {{ yourSafetyNumberWith }} </label>
|
|
<!--<div class='qr'></div>-->
|
|
<div class='key'>
|
|
{{ #chunks }} <span>{{ . }}</span> {{ /chunks }}
|
|
</div>
|
|
{{ /hasTheirKey }}
|
|
{{ verifyHelp }}
|
|
<p> {{> link_to_support }} </p>
|
|
<div class='summary'>
|
|
{{ #isVerified }}
|
|
<span class='icon verified'></span>
|
|
{{ /isVerified }}
|
|
{{ ^isVerified }}
|
|
<span class='icon shield'></span>
|
|
{{ /isVerified }}
|
|
{{ verifiedStatus }}
|
|
</div>
|
|
<div class='verify'>
|
|
<button class='verify grey'>
|
|
{{ verifyButton }}
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<!-- index -->
|
|
<script type='text/x-tmpl-mustache' id='group_info_input'>
|
|
<div class='group-info-input'>
|
|
<div class='group-avatar'>
|
|
<div class='choose-file attachment-previews 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>
|
|
<script type='text/x-tmpl-mustache' id='new-conversation'>
|
|
<div class='conversation-header'>
|
|
<button class='back'></button>
|
|
<button class='create check hide'></button>
|
|
<span class='conversation-title'>New Message</span>
|
|
</div>
|
|
{{> group_info_input }}
|
|
<div class='container'>
|
|
<div class='scrollable'>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='recipients-input'>
|
|
<div class='recipients-container'>
|
|
<span class='recipients'></span>
|
|
<input type='text' class='search' placeholder='{{ placeholder }}' dir='auto' />
|
|
</div>
|
|
<div class='results'>
|
|
<div class='new-contact contact hide'></div>
|
|
<div class='contacts'></div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='generic-error'>
|
|
<p>{{ message }}</p>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='error-icon'>
|
|
<span class='error-icon'>
|
|
</span>
|
|
{{ #message }}
|
|
<span class='error-message'>{{message}}</span>
|
|
{{ /message }}
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='contact-detail'>
|
|
<div class='clearfix'>
|
|
{{> avatar }}
|
|
<div class='contact-details'>
|
|
{{ #errors }}
|
|
<div class='error-icon-container'>
|
|
<span class='error-icon'></span>
|
|
</div>
|
|
{{ /errors }}
|
|
<span class='name' dir='auto'>{{ name }}</span>
|
|
{{ #errors }}
|
|
{{ #message }}
|
|
<p class='error-message'>{{message}}</p>
|
|
{{ /message }}
|
|
{{ /errors }}
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='link_to_support'>
|
|
<a href='http://support.signal.org/hc/articles/213134107' target='_blank'>
|
|
{{ learnMore }}
|
|
</a>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='debug-log'>
|
|
<div class='content'>
|
|
<div>
|
|
<a class='x close' alt='close debug log' href='#'></a>
|
|
<h1> {{ title }} </h1>
|
|
<p> {{ debugLogExplanation }}</p>
|
|
</div>
|
|
<textarea spellcheck='false' rows='5'></textarea>
|
|
<div class='buttons'>
|
|
<button class='grey submit'>{{ submit }}</button>
|
|
</div>
|
|
<div class='result'>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='debug-log-link'>
|
|
<div class='input-group clearfix'>
|
|
<input type='text' class='link' readonly value='{{ url }}' />
|
|
<a class='open' alt='open in a new browser tab' target='_blank' href='{{ url }}'></a>
|
|
</div>
|
|
<p>
|
|
<a class='report-link' target='_blank'
|
|
href='https://github.com/signalapp/Signal-Desktop/issues/new/'>
|
|
{{ reportIssue }}
|
|
</a>
|
|
</p>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='settings'>
|
|
<div class='content'>
|
|
<a class='x close' alt='close settings' href='#'></a>
|
|
<h2>{{ settings }}</h2>
|
|
<hr>
|
|
<div class='theme-settings'>
|
|
<h3>{{ theme }}</h3>
|
|
<div>
|
|
<input type='radio' name='theme' id='theme-setting-android' value='android'>
|
|
<label for='theme-setting-android'>Android</label>
|
|
</div>
|
|
<div>
|
|
<input type='radio' name='theme' id='theme-setting-android-dark' value='android-dark'>
|
|
<label for='theme-setting-android-dark'>{{ themeAndroidDark }}</label>
|
|
</div>
|
|
<div>
|
|
<input type='radio' name='theme' id='theme-setting-ios' value='ios'/>
|
|
<label for='theme-setting-ios'>iOS</label>
|
|
</div>
|
|
</div>
|
|
<hr>
|
|
<div class='notification-settings'>
|
|
<h3>{{ notifications }}</h3>
|
|
<p>{{ notificationSettingsDialog }}</p>
|
|
<div>
|
|
<input type='radio' name='notifications' id='notification-setting-message' value='message'>
|
|
<label for='notification-setting-message'>{{ nameAndMessage }} </label>
|
|
</div>
|
|
<div>
|
|
<input type='radio' name='notifications' id='notification-setting-name' value='name'/>
|
|
<label for='notification-setting-name'>{{ nameOnly }} </label>
|
|
</div>
|
|
<div>
|
|
<input type='radio' name='notifications' id='notification-setting-count' value='count'/>
|
|
<label for='notification-setting-count'>{{ noNameOrMessage }} </label>
|
|
</div>
|
|
<div>
|
|
<input type='radio' name='notifications' id='notification-setting-off' value='off'/>
|
|
<label for='notification-setting-off'>{{ disableNotifications }} </label>
|
|
</div>
|
|
</div>
|
|
<br />
|
|
<div class='audio-notification-setting'>
|
|
<input type='checkbox' name='audio-notification' id='audio-notification'/>
|
|
<label for='audio-notification'>{{ audioNotificationDescription }}</label>
|
|
</div>
|
|
</div>
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='syncSettings'>
|
|
<hr>
|
|
<h3>{{ sync }}</h3>
|
|
<div>
|
|
<button class='grey sync'>{{ syncNow }}</button>
|
|
<p>
|
|
{{ syncExplanation }}
|
|
<div class='synced_at'>
|
|
{{ lastSynced }} {{ syncDate }} {{ syncTime }}
|
|
</div>
|
|
<div class='sync_failed'>{{ syncFailed }}</div>
|
|
</p>
|
|
</div>
|
|
</script>
|
|
|
|
|
|
<script type='text/x-tmpl-mustache' id='networkStatus'>
|
|
<div class='network-status-message'>
|
|
<h3>{{ message }}</h3>
|
|
<span>{{ instructions }}</span>
|
|
</div>
|
|
{{ #reconnectDurationAsSeconds }}
|
|
<div class="network-status-message">
|
|
{{ attemptingReconnectionMessage }}
|
|
</div>
|
|
{{/reconnectDurationAsSeconds }}
|
|
{{ #action }}
|
|
<div class="action">
|
|
<button class='small blue {{ buttonClass }}'>{{ action }}</button>
|
|
</div>
|
|
{{/action }}
|
|
</script>
|
|
<script type='text/x-tmpl-mustache' id='file-view'>
|
|
<div class='icon'></div>
|
|
<div class='text'>
|
|
<div class='fileName' alt='{{ fileName }}' title='{{ altText }}'>{{ fileName }}</div>
|
|
<div class='fileSize'>{{ fileSize }}</div>
|
|
</div>
|
|
</script>
|
|
|
|
<script type="text/javascript" src="../libtextsecure/test/fake_web_api.js"></script>
|
|
|
|
<script type="text/javascript" src="../js/components.js"></script>
|
|
<script type="text/javascript" src="../js/reliable_trigger.js" data-cover></script>
|
|
<script type="text/javascript" src="test.js"></script>
|
|
|
|
<script type='text/javascript' src='../js/registration.js' data-cover></script>
|
|
<script type="text/javascript" src="../js/expire.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/chromium.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/database.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/storage.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/signal_protocol_store.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/libtextsecure.js" data-cover></script>
|
|
|
|
<script type="text/javascript" src="../js/libphonenumber-util.js"></script>
|
|
<script type="text/javascript" src="../js/models/messages.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/models/conversations.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/models/blockedNumbers.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/conversation_controller.js" data-cover></script>
|
|
<script type="text/javascript" src="../js/keychange_listener.js" data-cover></script>
|
|
<script type='text/javascript' src='../js/expiring_messages.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/notifications.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/focus_listener.js'></script>
|
|
|
|
<script type="text/javascript" src="../js/chromium.js" data-cover></script>
|
|
|
|
<script type='text/javascript' src='../js/views/react_wrapper_view.js'></script>
|
|
<script type='text/javascript' src='../js/views/whisper_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/debug_log_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/toast_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/attachment_preview_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/file_input_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/list_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/conversation_list_item_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/conversation_list_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/contact_list_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/new_group_update_view.js' data-cover></script>
|
|
<script type="text/javascript" src="../js/views/group_update_view.js"></script>
|
|
<script type='text/javascript' src='../js/views/attachment_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/error_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/timestamp_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/message_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/key_verification_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/message_detail_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/message_list_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/group_member_list_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/recorder_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/conversation_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/conversation_search_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/hint_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/inbox_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/network_status_view.js'></script>
|
|
<script type='text/javascript' src='../js/views/confirmation_dialog_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/identicon_svg_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/settings_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/last_seen_indicator_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/scroll_down_button_view.js' data-cover></script>
|
|
<script type='text/javascript' src='../js/views/banner_view.js' data-cover></script>
|
|
<script type="text/javascript" src='../js/views/identity_key_send_error_view.js' data-cover></script>
|
|
|
|
<script type="text/javascript" src="views/whisper_view_test.js"></script>
|
|
<script type="text/javascript" src="views/group_update_view_test.js"></script>
|
|
<script type="text/javascript" src="views/message_view_test.js"></script>
|
|
<script type="text/javascript" src="views/attachment_view_test.js"></script>
|
|
<script type="text/javascript" src="views/timestamp_view_test.js"></script>
|
|
<script type="text/javascript" src="views/list_view_test.js"></script>
|
|
<script type="text/javascript" src="views/inbox_view_test.js"></script>
|
|
<script type="text/javascript" src="views/conversation_search_view_test.js"></script>
|
|
<script type="text/javascript" src="views/network_status_view_test.js"></script>
|
|
<script type="text/javascript" src="views/last_seen_indicator_view_test.js"></script>
|
|
<script type='text/javascript' src='views/scroll_down_button_view_test.js'></script>
|
|
|
|
|
|
<script type="text/javascript" src="models/conversations_test.js"></script>
|
|
<script type="text/javascript" src="models/messages_test.js"></script>
|
|
|
|
<script type="text/javascript" src="libphonenumber_util_test.js"></script>
|
|
<script type="text/javascript" src="conversation_controller_test.js"></script>
|
|
<script type="text/javascript" src="storage_test.js"></script>
|
|
<script type="text/javascript" src="keychange_listener_test.js"></script>
|
|
<script type="text/javascript" src="reliable_trigger_test.js"></script>
|
|
<script type="text/javascript" src="backup_test.js"></script>
|
|
<script type="text/javascript" src="crypto_test.js"></script>
|
|
<script type="text/javascript" src="database_test.js"></script>
|
|
<script type="text/javascript" src="i18n_test.js"></script>
|
|
<script type="text/javascript" src="spellcheck_test.js"></script>
|
|
|
|
<script type="text/javascript" src="fixtures.js"></script>
|
|
<script type="text/javascript" src="fixtures_test.js"></script>
|
|
|
|
<!-- Comment out to turn off code coverage. Useful for getting real callstacks. -->
|
|
<!-- NOTE: blanket doesn't support modern syntax and will choke until we find a replacement. :0( -->
|
|
<!-- <script type="text/javascript" src="blanket_mocha.js"></script> -->
|
|
|
|
<!-- Uncomment to start tests without code coverage enabled -->
|
|
<script type="text/javascript">
|
|
mocha.run();
|
|
</script>
|
|
</body>
|
|
</html>
|