mirror of
https://github.com/bitwarden/browser
synced 2026-01-06 10:33:57 +00:00
* [PM-15506] Wire up vNextOrganizationService for libs/common and libs/angular (#12683) * Wire up vNextOrganizationService in PolicyService * Wire vNextOrganizationService in SyncService * wire vNextOrganizationService for EventCollectionService * wire vNextOrganizationService for KeyConnectorService * wire up vNextOrganizationService for CipherAuthorizationService * Wire up vNextOrganizationService in PolicyService * Wire vNextOrganizationService in SyncService * wire vNextOrganizationService for EventCollectionService * wire vNextOrganizationService for KeyConnectorService * wire up vNextOrganizationService for CipherAuthorizationService * wire vNextOrganizationService for share.component * wire vNextOrganizationService for collections.component * wire vNextOrganizationServcie for add-account-credit-dialog * wire vNextOrganizationService for vault-filter.service * fix browser errors for vNextOrganizationService implementation in libs * fix desktop errors for vNextOrganizationService implementation for libs * fix linter errors * fix CLI errors on vNextOrganizationServcie implementations for libs * [PM-15506] Wire up vNextOrganizationService for web client (#12810) PR to a feature branch, no need to review until this goes to main. * implement vNextOrganization service for browser client (#12844) PR to feature branch, no need for review yet. * wire vNextOrganizationService for licence and some web router guards * wire vNextOrganizationService in tests * remove vNext notation for OrganizationService and related * Merge branch 'main' into ac/pm-15506-vNextOrganizationService * fix tsstrict error * fix test, fix ts strict error
103 lines
3.7 KiB
TypeScript
103 lines
3.7 KiB
TypeScript
// FIXME: Update this file to be type safe and remove this and next line
|
|
// @ts-strict-ignore
|
|
import { Component, OnDestroy, OnInit } from "@angular/core";
|
|
import { FormControl, FormGroup } from "@angular/forms";
|
|
import { firstValueFrom, map, Observable, of, Subject, switchMap, takeUntil } from "rxjs";
|
|
|
|
import { ApiService } from "@bitwarden/common/abstractions/api.service";
|
|
import { OrganizationService } from "@bitwarden/common/admin-console/abstractions/organization/organization.service.abstraction";
|
|
import { Organization } from "@bitwarden/common/admin-console/models/domain/organization";
|
|
import { AccountService } from "@bitwarden/common/auth/abstractions/account.service";
|
|
import { UpdateProfileRequest } from "@bitwarden/common/auth/models/request/update-profile.request";
|
|
import { getUserId } from "@bitwarden/common/auth/services/account.service";
|
|
import { FeatureFlag } from "@bitwarden/common/enums/feature-flag.enum";
|
|
import { ProfileResponse } from "@bitwarden/common/models/response/profile.response";
|
|
import { ConfigService } from "@bitwarden/common/platform/abstractions/config/config.service";
|
|
import { I18nService } from "@bitwarden/common/platform/abstractions/i18n.service";
|
|
import { DialogService, ToastService } from "@bitwarden/components";
|
|
|
|
import { ChangeAvatarDialogComponent } from "./change-avatar-dialog.component";
|
|
|
|
@Component({
|
|
selector: "app-profile",
|
|
templateUrl: "profile.component.html",
|
|
})
|
|
export class ProfileComponent implements OnInit, OnDestroy {
|
|
loading = true;
|
|
profile: ProfileResponse;
|
|
fingerprintMaterial: string;
|
|
managingOrganization$: Observable<Organization>;
|
|
private destroy$ = new Subject<void>();
|
|
|
|
protected formGroup = new FormGroup({
|
|
name: new FormControl(null),
|
|
email: new FormControl(null),
|
|
});
|
|
|
|
constructor(
|
|
private apiService: ApiService,
|
|
private i18nService: I18nService,
|
|
private accountService: AccountService,
|
|
private dialogService: DialogService,
|
|
private toastService: ToastService,
|
|
private configService: ConfigService,
|
|
private organizationService: OrganizationService,
|
|
) {}
|
|
|
|
async ngOnInit() {
|
|
this.profile = await this.apiService.getProfile();
|
|
this.loading = false;
|
|
this.fingerprintMaterial = await firstValueFrom(
|
|
this.accountService.activeAccount$.pipe(map((a) => a?.id)),
|
|
);
|
|
|
|
const userId = await firstValueFrom(getUserId(this.accountService.activeAccount$));
|
|
|
|
this.managingOrganization$ = this.configService
|
|
.getFeatureFlag$(FeatureFlag.AccountDeprovisioning)
|
|
.pipe(
|
|
switchMap((isAccountDeprovisioningEnabled) =>
|
|
isAccountDeprovisioningEnabled
|
|
? this.organizationService
|
|
.organizations$(userId)
|
|
.pipe(
|
|
map((organizations) =>
|
|
organizations.find((o) => o.userIsManagedByOrganization === true),
|
|
),
|
|
)
|
|
: of(null),
|
|
),
|
|
);
|
|
this.formGroup.get("name").setValue(this.profile.name);
|
|
this.formGroup.get("email").setValue(this.profile.email);
|
|
|
|
this.formGroup
|
|
.get("name")
|
|
.valueChanges.pipe(takeUntil(this.destroy$))
|
|
.subscribe((name) => {
|
|
this.profile.name = name;
|
|
});
|
|
}
|
|
|
|
openChangeAvatar = async () => {
|
|
ChangeAvatarDialogComponent.open(this.dialogService, {
|
|
data: { profile: this.profile },
|
|
});
|
|
};
|
|
|
|
async ngOnDestroy() {
|
|
this.destroy$.next();
|
|
this.destroy$.complete();
|
|
}
|
|
|
|
submit = async () => {
|
|
const request = new UpdateProfileRequest(this.formGroup.get("name").value);
|
|
await this.apiService.putProfile(request);
|
|
this.toastService.showToast({
|
|
variant: "success",
|
|
title: null,
|
|
message: this.i18nService.t("accountUpdated"),
|
|
});
|
|
};
|
|
}
|