mirror of
https://github.com/bitwarden/browser.git
synced 2024-10-09 05:57:40 +02:00
64 lines
2.0 KiB
TypeScript
64 lines
2.0 KiB
TypeScript
import { CommonModule } from "@angular/common";
|
|
import { Component, EventEmitter, Input, Output } from "@angular/core";
|
|
import { ActivatedRoute } from "@angular/router";
|
|
import { combineLatest, map, Observable } from "rxjs";
|
|
|
|
import { JslibModule } from "@bitwarden/angular/jslib.module";
|
|
import { OrganizationService } from "@bitwarden/common/admin-console/abstractions/organization/organization.service.abstraction";
|
|
import type { Organization } from "@bitwarden/common/admin-console/models/domain/organization";
|
|
import { NavigationModule } from "@bitwarden/components";
|
|
|
|
@Component({
|
|
selector: "org-switcher",
|
|
templateUrl: "org-switcher.component.html",
|
|
standalone: true,
|
|
imports: [CommonModule, JslibModule, NavigationModule],
|
|
})
|
|
export class OrgSwitcherComponent {
|
|
protected organizations$: Observable<Organization[]> =
|
|
this.organizationService.organizations$.pipe(
|
|
map((orgs) =>
|
|
orgs.filter((org) => this.filter(org)).sort((a, b) => a.name.localeCompare(b.name)),
|
|
),
|
|
);
|
|
|
|
protected activeOrganization$: Observable<Organization> = combineLatest([
|
|
this.route.paramMap,
|
|
this.organizations$,
|
|
]).pipe(map(([params, orgs]) => orgs.find((org) => org.id === params.get("organizationId"))));
|
|
|
|
/**
|
|
* Filter function for displayed organizations in the `org-switcher`
|
|
* @example
|
|
* const smFilter = (org: Organization) => org.canAccessSecretsManager
|
|
* // <org-switcher [filter]="smFilter">
|
|
*/
|
|
@Input()
|
|
filter: (org: Organization) => boolean = () => true;
|
|
|
|
/**
|
|
* Is `true` if the expanded content is visible
|
|
*/
|
|
@Input()
|
|
open = false;
|
|
@Output()
|
|
openChange = new EventEmitter<boolean>();
|
|
|
|
/**
|
|
* Visibility of the New Organization button
|
|
*/
|
|
@Input()
|
|
hideNewButton = false;
|
|
|
|
constructor(
|
|
private route: ActivatedRoute,
|
|
private organizationService: OrganizationService,
|
|
) {}
|
|
|
|
protected toggle(event?: MouseEvent) {
|
|
event?.stopPropagation();
|
|
this.open = !this.open;
|
|
this.openChange.emit(this.open);
|
|
}
|
|
}
|