1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-24 21:41:33 +01:00

[PM-2014] feat: implement mocked failing wizard flow

This commit is contained in:
Andreas Coroiu 2023-05-04 13:47:48 +02:00
parent 6831df6ad0
commit 6f9dc73e18
No known key found for this signature in database
GPG Key ID: E70B5FFC81DFEC1A
4 changed files with 107 additions and 14 deletions

View File

@ -1,11 +1,40 @@
<bit-dialog dialogSize="large">
<form [formGroup]="formGroup" [bitSubmit]="submit">
<bit-dialog dialogSize="large">
<span bitDialogTitle
>{{ "loginWithPasskey" | i18n }}
<span class="tw-text-sm tw-normal-case tw-text-muted">{{ "newPasskey" | i18n }}</span>
</span>
<span bitDialogContent>Enter you master password here</span>
<ng-container bitDialogFooter>
<button type="button" bitButton buttonType="primary">Continue</button>
<button type="button" bitButton buttonType="secondary">Cancel</button>
<span bitDialogContent>
<ng-container *ngIf="currentStep === 'userVerification'">
<p bitTypography="body1">
{{ "passkeyEnterMasterPassword" | i18n }}
</p>
<bit-form-field disableMargin formGroupName="userVerification">
<bit-label>{{ "masterPassword" | i18n }}</bit-label>
<input type="password" bitInput formControlName="masterPassword" />
<button type="button" bitIconButton bitSuffix bitPasswordInputToggle></button>
<bit-hint>{{ "confirmIdentity" | i18n }}</bit-hint>
</bit-form-field>
</ng-container>
</bit-dialog>
</span>
<ng-container bitDialogFooter>
<button type="submit" bitButton bitFormButton buttonType="primary">
<ng-container *ngIf="currentStep === 'userVerification'">
{{ "continue" | i18n }}
</ng-container>
<ng-container *ngIf="currentStep === 'credentialCreation'">
{{ "continue" | i18n }}
</ng-container>
<ng-container *ngIf="currentStep === 'credentialCreationFailed'">
{{ "tryAgain" | i18n }}
</ng-container>
<ng-container *ngIf="currentStep === 'credentialNaming'">
{{ "turnOn" | i18n }}
</ng-container>
</button>
<button type="button" bitButton bitFormButton buttonType="secondary">
{{ "cancel" | i18n }}
</button>
</ng-container>
</bit-dialog>
</form>

View File

@ -1,5 +1,6 @@
import { DialogConfig } from "@angular/cdk/dialog";
import { DialogConfig, DialogRef } from "@angular/cdk/dialog";
import { Component } from "@angular/core";
import { FormBuilder, Validators } from "@angular/forms";
import { DialogService } from "@bitwarden/components";
@ -8,10 +9,66 @@ export enum CreateCredentialDialogResult {
Canceled,
}
type Step =
| "userVerification"
| "credentialCreation"
| "credentialCreationFailed"
| "credentialNaming";
@Component({
templateUrl: "create-credential-dialog.component.html",
})
export class CreateCredentialDialogComponent {}
export class CreateCredentialDialogComponent {
protected currentStep: Step = "userVerification";
protected formGroup = this.formBuilder.group({
userVerification: this.formBuilder.group({
masterPassword: ["", [Validators.required]],
}),
credentialNaming: this.formBuilder.group({
name: ["", Validators.maxLength(50)],
}),
});
constructor(private formBuilder: FormBuilder, private dialogRef: DialogRef) {}
protected submit = async () => {
this.dialogRef.disableClose = true;
try {
if (this.currentStep === "userVerification") {
this.formGroup.controls.userVerification.markAllAsTouched();
if (this.formGroup.controls.userVerification.invalid) {
return;
}
await this.verifyUser();
this.currentStep = "credentialCreation";
}
if (this.currentStep === "credentialCreationFailed") {
this.currentStep = "credentialCreation";
}
if (this.currentStep === "credentialCreation") {
try {
await this.createCredential();
} catch {
this.currentStep = "credentialCreationFailed";
}
}
} finally {
this.dialogRef.disableClose = false;
}
};
private async verifyUser() {
// Mocked
await new Promise((resolve) => setTimeout(resolve, 1000));
}
private async createCredential() {
await new Promise((_, reject) => setTimeout(() => reject(new Error("Not implemented")), 1000));
}
}
/**
* Strongly typed helper to open a CreateCredentialDialog

View File

@ -1,4 +1,5 @@
import { NgModule } from "@angular/core";
import { FormsModule, ReactiveFormsModule } from "@angular/forms";
import { SharedModule } from "../../shared/shared.module";
@ -6,7 +7,7 @@ import { CreateCredentialDialogComponent } from "./create-credential-dialog/crea
import { Fido2LoginSettingsComponent } from "./fido2-login-settings.component";
@NgModule({
imports: [SharedModule],
imports: [SharedModule, FormsModule, ReactiveFormsModule],
declarations: [Fido2LoginSettingsComponent, CreateCredentialDialogComponent],
exports: [Fido2LoginSettingsComponent],
})

View File

@ -640,6 +640,12 @@
"learnMoreAboutPasswordless": {
"message": "Learn more about passwordless"
},
"passkeyEnterMasterPassword": {
"message": "Enter your master password to modify log in with passkey settings."
},
"tryAgain": {
"message": "Try again"
},
"createAccount": {
"message": "Create account"
},