bitwarden-desktop/src/app/accounts/two-factor.component.html

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

140 lines
4.7 KiB
HTML
Raw Normal View History

<form
id="two-factor-page"
#form
(ngSubmit)="submit()"
[appApiAction]="formPromise"
attr.aria-hidden="{{ showingModal }}"
>
2018-02-01 04:54:13 +01:00
<div class="content">
<h1>{{ title }}</h1>
2018-02-02 04:59:04 +01:00
<p *ngIf="selectedProviderType === providerType.Authenticator">
{{ "enterVerificationCodeApp" | i18n }}
</p>
<p *ngIf="selectedProviderType === providerType.Email">
{{ "enterVerificationCodeEmail" | i18n: twoFactorEmail }}
</p>
2018-02-02 04:59:04 +01:00
<div
class="box last"
2019-02-21 22:53:32 +01:00
*ngIf="
selectedProviderType === providerType.Email ||
selectedProviderType === providerType.Authenticator
2021-12-20 15:47:17 +01:00
"
2019-02-21 22:53:32 +01:00
>
2018-02-01 04:54:13 +01:00
<div class="box-content">
<div class="box-content-row" appBoxRow>
<label for="code">{{ "verificationCode" | i18n }}</label>
<input
id="code"
type="text"
name="Code"
[(ngModel)]="token"
required
appAutofocus
appInputVerbatim
2018-02-02 04:59:04 +01:00
/>
</div>
<div class="box-content-row box-content-row-checkbox" appBoxRow>
2021-03-04 20:19:59 +01:00
<label for="remember">{{ "rememberMe" | i18n }}</label>
2018-02-02 04:59:04 +01:00
<input id="remember" type="checkbox" name="Remember" [(ngModel)]="remember" />
2018-02-01 04:54:13 +01:00
</div>
</div>
2019-02-21 22:53:32 +01:00
</div>
<ng-container *ngIf="selectedProviderType === providerType.Yubikey">
<p>{{ "insertYubiKey" | i18n }}</p>
<img src="../../images/yubikey.jpg" alt="" />
2018-02-02 04:59:04 +01:00
<div class="box last">
2019-02-21 22:53:32 +01:00
<div class="box-content">
<div class="box-content-row" appBoxRow>
<label for="code" class="sr-only">{{ "verificationCode" | i18n }}</label>
2021-12-20 15:47:17 +01:00
<input
id="code"
type="password"
name="Code"
[(ngModel)]="token"
2019-02-21 22:53:32 +01:00
required
appAutofocus
appInputVerbatim
2021-12-20 15:47:17 +01:00
/>
</div>
2019-02-21 22:53:32 +01:00
<div class="box-content-row box-content-row-checkbox" appBoxRow>
<label for="remember">{{ "rememberMe" | i18n }}</label>
<input id="remember" type="checkbox" name="Remember" [(ngModel)]="remember" />
2021-12-20 15:47:17 +01:00
</div>
</div>
</div>
2018-02-02 04:59:04 +01:00
</ng-container>
2019-02-21 22:53:32 +01:00
<ng-container *ngIf="selectedProviderType === providerType.WebAuthn">
2021-03-08 19:12:56 +01:00
<div id="web-authn-frame">
2019-02-21 22:53:32 +01:00
<iframe id="webauthn_iframe" [allow]="webAuthnAllow"></iframe>
2021-12-20 15:47:17 +01:00
</div>
2021-03-04 20:19:59 +01:00
<div class="box first">
2018-02-02 04:59:04 +01:00
<div class="box-content">
<div class="box-content-row box-content-row-checkbox" appBoxRow>
<label for="remember">{{ "rememberMe" | i18n }}</label>
2021-03-04 20:19:59 +01:00
<input id="remember" type="checkbox" name="Remember" [(ngModel)]="remember" />
2021-12-20 15:47:17 +01:00
</div>
</div>
</div>
2018-02-02 04:59:04 +01:00
</ng-container>
2018-04-03 21:11:37 +02:00
<ng-container
2021-12-20 15:47:17 +01:00
*ngIf="
2019-02-21 22:53:32 +01:00
selectedProviderType === providerType.Duo ||
2018-04-03 21:11:37 +02:00
selectedProviderType === providerType.OrganizationDuo
2019-04-02 05:08:54 +02:00
"
2021-12-20 15:47:17 +01:00
>
2019-04-02 05:08:54 +02:00
<div id="duo-frame"><iframe id="duo_iframe"></iframe></div>
<div class="box last">
<div class="box-content">
<div class="box-content-row box-content-row-checkbox" appBoxRow>
2018-02-01 04:54:13 +01:00
<label for="remember">{{ "rememberMe" | i18n }}</label>
<input id="remember" type="checkbox" name="Remember" [(ngModel)]="remember" />
2021-12-20 15:47:17 +01:00
</div>
2018-02-01 04:54:13 +01:00
</div>
2018-02-02 04:59:04 +01:00
</div>
2019-04-03 06:04:42 +02:00
</ng-container>
2019-02-21 22:53:32 +01:00
<div class="box last" *ngIf="selectedProviderType == null">
<div class="box-content">
2018-02-02 04:59:04 +01:00
<div class="box-content-row">
<p>{{ "noTwoStepProviders" | i18n }}</p>
<p>{{ "noTwoStepProviders2" | i18n }}</p>
2018-02-02 04:59:04 +01:00
</div>
2021-12-20 15:47:17 +01:00
</div>
</div>
2018-02-01 04:54:13 +01:00
<div class="buttons">
2021-12-20 15:47:17 +01:00
<button
type="submit"
2018-02-01 04:54:13 +01:00
class="btn primary block"
2019-04-02 05:08:54 +02:00
[disabled]="form.loading"
2021-12-20 15:47:17 +01:00
appBlurClick
*ngIf="
2018-02-16 17:20:28 +01:00
selectedProviderType != null &&
2018-04-03 21:11:37 +02:00
selectedProviderType !== providerType.Duo &&
selectedProviderType !== providerType.OrganizationDuo
2021-12-20 15:47:17 +01:00
"
>
2019-04-02 05:08:54 +02:00
<span [hidden]="form.loading"
><i class="bwi bwi-sign-in" aria-hidden="true"></i> {{ "continue" | i18n }}</span
2021-12-20 15:47:17 +01:00
>
<i class="bwi bwi-spinner bwi-spin" [hidden]="!form.loading" aria-hidden="true"></i>
2018-02-01 04:54:13 +01:00
</button>
<a routerLink="/login" class="btn block">{{ "cancel" | i18n }}</a>
2021-12-20 15:47:17 +01:00
</div>
2018-02-02 04:59:04 +01:00
<div class="sub-options">
2019-04-03 06:04:42 +02:00
<a href="#" appStopClick (click)="anotherMethod()" role="button">{{
"useAnotherTwoStepMethod" | i18n
2021-12-20 15:47:17 +01:00
}}</a>
<a
href="#"
2019-04-03 06:04:42 +02:00
appStopClick
(click)="sendEmail(true)"
[appApiAction]="emailPromise"
role="button"
2018-04-03 21:11:37 +02:00
*ngIf="selectedProviderType === providerType.Email"
2021-12-20 15:47:17 +01:00
>
2018-02-02 04:59:04 +01:00
{{ "sendVerificationCodeEmailAgain" | i18n }}
2021-12-20 15:47:17 +01:00
</a>
2018-02-01 04:54:13 +01:00
</div>
2021-12-20 15:47:17 +01:00
</div>
2018-02-01 04:54:13 +01:00
</form>
<ng-template #twoFactorOptions></ng-template>