From bf8312da1c81a4dd03928f9db651484850d73e08 Mon Sep 17 00:00:00 2001 From: Alec Rippberger Date: Fri, 27 Sep 2024 10:48:27 -0500 Subject: [PATCH] Populate email on registration start form. --- .../registration-start.component.ts | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/libs/auth/src/angular/registration/registration-start/registration-start.component.ts b/libs/auth/src/angular/registration/registration-start/registration-start.component.ts index 141bff1152..613e8665e8 100644 --- a/libs/auth/src/angular/registration/registration-start/registration-start.component.ts +++ b/libs/auth/src/angular/registration/registration-start/registration-start.component.ts @@ -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 = { 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(); @@ -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() {