import { CommonModule } from "@angular/common"; import { Component, HostBinding, OnChanges, OnInit, SimpleChanges, input, model, } from "@angular/core"; import { RouterModule } from "@angular/router"; import { firstValueFrom } from "rxjs"; import { BitwardenLogo, BitSvg } from "@bitwarden/assets/svg"; import { ClientType } from "@bitwarden/common/enums"; import { EnvironmentService } from "@bitwarden/common/platform/abstractions/environment.service"; import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service"; import { LandingContentMaxWidthType } from "../landing-layout"; import { LandingLayoutModule } from "../landing-layout/landing-layout.module"; import { SharedModule } from "../shared"; import { SvgModule } from "../svg"; import { TypographyModule } from "../typography"; // FIXME(https://bitwarden.atlassian.net/browse/CL-764): Migrate to OnPush // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection @Component({ selector: "auth-anon-layout", templateUrl: "./anon-layout.component.html", imports: [ SvgModule, CommonModule, TypographyModule, SharedModule, RouterModule, LandingLayoutModule, ], }) export class AnonLayoutComponent implements OnInit, OnChanges { @HostBinding("class") get classList() { // AnonLayout should take up full height of parent container for proper footer placement. return ["tw-h-full"]; } readonly title = input(); readonly subtitle = input(); readonly icon = model.required(); readonly showReadonlyHostname = input(false); readonly hideLogo = input(false); readonly hideFooter = input(false); readonly hideCardWrapper = input(false); readonly hideBackgroundIllustration = input(false); /** * Max width of the anon layout title, subtitle, and content areas. * * @default 'md' */ readonly maxWidth = model("md"); protected logo = BitwardenLogo; protected year: string; protected clientType: ClientType; protected hostname?: string; protected version?: string; protected hideYearAndVersion = false; constructor( private environmentService: EnvironmentService, private platformUtilsService: PlatformUtilsService, ) { this.year = new Date().getFullYear().toString(); this.clientType = this.platformUtilsService.getClientType(); this.hideYearAndVersion = this.clientType !== ClientType.Web; } async ngOnInit() { this.maxWidth.set(this.maxWidth() ?? "md"); this.hostname = (await firstValueFrom(this.environmentService.environment$)).getHostname(); this.version = await this.platformUtilsService.getApplicationVersion(); } async ngOnChanges(changes: SimpleChanges) { if (changes.maxWidth) { this.maxWidth.set(changes.maxWidth.currentValue ?? "md"); } } }