1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-23 21:31:29 +01:00

Populate email on registration start form.

This commit is contained in:
Alec Rippberger 2024-09-27 10:48:27 -05:00
parent c0629705ea
commit bf8312da1c
No known key found for this signature in database
GPG Key ID: 9DD8DA583B28154A

View File

@ -6,9 +6,12 @@ import { Subject, takeUntil } from "rxjs";
import { JslibModule } from "@bitwarden/angular/jslib.module";
import { AccountApiService } from "@bitwarden/common/auth/abstractions/account-api.service";
import { AccountService } from "@bitwarden/common/auth/abstractions/account.service";
import { AuthService } from "@bitwarden/common/auth/abstractions/auth.service";
import { RegisterSendVerificationEmailRequest } from "@bitwarden/common/auth/models/request/registration/register-send-verification-email.request";
import { RegionConfig, Region } from "@bitwarden/common/platform/abstractions/environment.service";
import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service";
import { StateProvider } from "@bitwarden/common/platform/state";
import {
AsyncActionsModule,
ButtonModule,
@ -18,6 +21,7 @@ import {
LinkModule,
} from "@bitwarden/components";
import { LoginEmailService } from "../../../common";
import { RegistrationCheckEmailIcon } from "../../icons/registration-check-email.icon";
import { RegistrationEnvSelectorComponent } from "../registration-env-selector/registration-env-selector.component";
@ -48,6 +52,17 @@ const DEFAULT_MARKETING_EMAILS_PREF_BY_REGION: Record<Region, boolean> = {
IconModule,
RegistrationEnvSelectorComponent,
],
providers: [
{
provide: LoginEmailService,
useFactory: (
accountService: AccountService,
authService: AuthService,
stateProvider: StateProvider,
) => new LoginEmailService(accountService, authService, stateProvider),
deps: [AccountService, AuthService, StateProvider],
},
],
})
export class RegistrationStartComponent implements OnInit, OnDestroy {
@Output() registrationStartStateChange = new EventEmitter<RegistrationStartState>();
@ -88,6 +103,7 @@ export class RegistrationStartComponent implements OnInit, OnDestroy {
private platformUtilsService: PlatformUtilsService,
private accountApiService: AccountApiService,
private router: Router,
private loginEmailService: LoginEmailService,
) {
this.isSelfHost = platformUtilsService.isSelfHost();
}
@ -97,6 +113,15 @@ export class RegistrationStartComponent implements OnInit, OnDestroy {
this.registrationStartStateChange.emit(this.state);
this.listenForQueryParamChanges();
/**
* If the user has a login email, set the email field to the login email.
*/
this.loginEmailService.loginEmail$.pipe(takeUntil(this.destroy$)).subscribe((email) => {
if (email) {
this.formGroup.patchValue({ email });
}
});
}
private listenForQueryParamChanges() {