mirror of
https://github.com/bitwarden/browser
synced 2026-01-09 20:13:42 +00:00
157 lines
4.7 KiB
HTML
157 lines
4.7 KiB
HTML
<!-- Please remove this disable statement when editing this file! -->
|
|
<!-- eslint-disable tailwindcss/no-custom-classname -->
|
|
<form
|
|
#form
|
|
(ngSubmit)="submit()"
|
|
[appApiAction]="formPromise"
|
|
class="tw-container tw-mx-auto"
|
|
[formGroup]="formGroup"
|
|
>
|
|
<div>
|
|
<div class="tw-mb-3">
|
|
<bit-form-field>
|
|
<bit-label>{{ "emailAddress" | i18n }}</bit-label>
|
|
<input id="register-form_input_email" bitInput type="email" formControlName="email" />
|
|
<bit-hint>{{ "emailAddressDesc" | i18n }}</bit-hint>
|
|
</bit-form-field>
|
|
</div>
|
|
|
|
<div class="tw-mb-3">
|
|
<bit-form-field>
|
|
<bit-label>{{ "name" | i18n }}</bit-label>
|
|
<input id="register-form_input_name" bitInput type="text" formControlName="name" />
|
|
<bit-hint>{{ "yourNameDesc" | i18n }}</bit-hint>
|
|
</bit-form-field>
|
|
</div>
|
|
|
|
<div class="tw-mb-3">
|
|
<app-callout
|
|
type="info"
|
|
[enforcedPolicyOptions]="enforcedPolicyOptions"
|
|
*ngIf="enforcedPolicyOptions"
|
|
>
|
|
</app-callout>
|
|
<bit-form-field>
|
|
<bit-label>{{ "masterPass" | i18n }}</bit-label>
|
|
<input
|
|
id="register-form_input_master-password"
|
|
bitInput
|
|
type="password"
|
|
formControlName="masterPassword"
|
|
/>
|
|
<button
|
|
type="button"
|
|
bitSuffix
|
|
bitIconButton
|
|
bitPasswordInputToggle
|
|
[(toggled)]="showPassword"
|
|
></button>
|
|
<bit-hint>
|
|
<span class="tw-font-semibold">{{ "important" | i18n }}</span>
|
|
{{ "masterPassImportant" | i18n }} {{ characterMinimumMessage }}
|
|
</bit-hint>
|
|
</bit-form-field>
|
|
<app-password-strength
|
|
[password]="formGroup.get('masterPassword')?.value"
|
|
[email]="formGroup.get('email')?.value"
|
|
[name]="formGroup.get('name')?.value"
|
|
[showText]="true"
|
|
(passwordStrengthResult)="getStrengthResult($event)"
|
|
>
|
|
</app-password-strength>
|
|
</div>
|
|
|
|
<div class="tw-mb-3">
|
|
<bit-form-field>
|
|
<bit-label>{{ "reTypeMasterPass" | i18n }}</bit-label>
|
|
<input
|
|
id="register-form_input_confirm-master-password"
|
|
bitInput
|
|
type="password"
|
|
formControlName="confirmMasterPassword"
|
|
/>
|
|
<button
|
|
type="button"
|
|
bitSuffix
|
|
bitIconButton
|
|
bitPasswordInputToggle
|
|
[(toggled)]="showPassword"
|
|
></button>
|
|
</bit-form-field>
|
|
</div>
|
|
|
|
<div class="tw-mb-3">
|
|
<bit-form-field>
|
|
<bit-label>{{ "masterPassHintLabel" | i18n }}</bit-label>
|
|
<input id="register-form_input_hint" bitInput type="text" formControlName="hint" />
|
|
<bit-hint>{{ "masterPassHintDesc" | i18n }}</bit-hint>
|
|
</bit-form-field>
|
|
</div>
|
|
|
|
<div [hidden]="!showCaptcha()">
|
|
<iframe id="hcaptcha_iframe" height="80" sandbox="allow-scripts allow-same-origin"></iframe>
|
|
</div>
|
|
<div class="tw-mb-4 tw-flex tw-items-start">
|
|
<input
|
|
class="mt-1"
|
|
type="checkbox"
|
|
bitCheckbox
|
|
id="checkForBreaches"
|
|
name="CheckBreach"
|
|
formControlName="checkForBreaches"
|
|
/>
|
|
<bit-label for="checkForBreaches"> {{ "checkForBreaches" | i18n }}</bit-label>
|
|
</div>
|
|
<div class="tw-mb-3 tw-flex tw-items-start" *ngIf="showTerms">
|
|
<input
|
|
class="mt-1"
|
|
id="register-form-input-accept-policies"
|
|
bitCheckbox
|
|
type="checkbox"
|
|
formControlName="acceptPolicies"
|
|
/>
|
|
|
|
<bit-label for="register-form-input-accept-policies">
|
|
{{ "acceptPolicies" | i18n }}<br />
|
|
<a href="https://bitwarden.com/terms/" target="_blank" rel="noopener">{{
|
|
"termsOfService" | i18n
|
|
}}</a
|
|
>,
|
|
<a href="https://bitwarden.com/privacy/" target="_blank" rel="noopener">{{
|
|
"privacyPolicy" | i18n
|
|
}}</a>
|
|
</bit-label>
|
|
</div>
|
|
|
|
<div class="tw-space-x-2 tw-pt-2">
|
|
<ng-container *ngIf="!accountCreated">
|
|
<button
|
|
[block]="true"
|
|
type="submit"
|
|
buttonType="primary"
|
|
bitButton
|
|
[loading]="form.loading"
|
|
>
|
|
{{ "createAccount" | i18n }}
|
|
</button>
|
|
</ng-container>
|
|
<ng-container *ngIf="accountCreated">
|
|
<button
|
|
[block]="true"
|
|
type="submit"
|
|
buttonType="primary"
|
|
bitButton
|
|
[loading]="form.loading"
|
|
>
|
|
{{ "logIn" | i18n }}
|
|
</button>
|
|
</ng-container>
|
|
</div>
|
|
<p class="tw-m-0 tw-mt-5 tw-text-sm">
|
|
{{ "alreadyHaveAccount" | i18n }}
|
|
<a routerLink="/login">{{ "logIn" | i18n }}</a>
|
|
</p>
|
|
<bit-error-summary *ngIf="showErrorSummary" [formGroup]="formGroup"></bit-error-summary>
|
|
</div>
|
|
</form>
|