mirror of
https://github.com/bitwarden/browser
synced 2026-01-01 16:13:27 +00:00
* Rename service-factory folder * Move cryptographic service factories * Move crypto models * Move crypto services * Move domain base class * Platform code owners * Move desktop log services * Move log files * Establish component library ownership * Move background listeners * Move background background * Move localization to Platform * Move browser alarms to Platform * Move browser state to Platform * Move CLI state to Platform * Move Desktop native concerns to Platform * Move flag and misc to Platform * Lint fixes * Move electron state to platform * Move web state to Platform * Move lib state to Platform * Fix broken tests * Rename interface to idiomatic TS * `npm run prettier` 🤖 * Resolve review feedback * Set platform as owners of web core and shared * Expand moved services * Fix test types --------- Co-authored-by: Hinton <hinton@users.noreply.github.com>
161 lines
5.2 KiB
TypeScript
161 lines
5.2 KiB
TypeScript
import { Component, EventEmitter, Input, OnInit, Output } from "@angular/core";
|
|
|
|
import { SearchPipe } from "@bitwarden/angular/pipes/search.pipe";
|
|
import { ApiService } from "@bitwarden/common/abstractions/api.service";
|
|
import { OrganizationUserService } from "@bitwarden/common/abstractions/organization-user/organization-user.service";
|
|
import { OrganizationUserUserDetailsResponse } from "@bitwarden/common/abstractions/organization-user/responses";
|
|
import {
|
|
OrganizationUserStatusType,
|
|
OrganizationUserType,
|
|
} from "@bitwarden/common/admin-console/enums";
|
|
import { SelectionReadOnlyRequest } from "@bitwarden/common/admin-console/models/request/selection-read-only.request";
|
|
import { I18nService } from "@bitwarden/common/platform/abstractions/i18n.service";
|
|
import { LogService } from "@bitwarden/common/platform/abstractions/log.service";
|
|
import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service";
|
|
import { Utils } from "@bitwarden/common/platform/misc/utils";
|
|
|
|
@Component({
|
|
selector: "app-entity-users",
|
|
templateUrl: "entity-users.component.html",
|
|
providers: [SearchPipe],
|
|
})
|
|
export class EntityUsersComponent implements OnInit {
|
|
@Input() entity: "group" | "collection";
|
|
@Input() entityId: string;
|
|
@Input() entityName: string;
|
|
@Input() organizationId: string;
|
|
@Output() onEditedUsers = new EventEmitter();
|
|
|
|
organizationUserType = OrganizationUserType;
|
|
organizationUserStatusType = OrganizationUserStatusType;
|
|
|
|
showSelected = false;
|
|
loading = true;
|
|
formPromise: Promise<any>;
|
|
selectedCount = 0;
|
|
searchText: string;
|
|
|
|
private allUsers: OrganizationUserUserDetailsResponse[] = [];
|
|
|
|
constructor(
|
|
private search: SearchPipe,
|
|
private apiService: ApiService,
|
|
private i18nService: I18nService,
|
|
private platformUtilsService: PlatformUtilsService,
|
|
private organizationUserService: OrganizationUserService,
|
|
private logService: LogService
|
|
) {}
|
|
|
|
async ngOnInit() {
|
|
await this.loadUsers();
|
|
this.loading = false;
|
|
}
|
|
|
|
get users() {
|
|
if (this.showSelected) {
|
|
return this.allUsers.filter((u) => (u as any).checked);
|
|
} else {
|
|
return this.allUsers;
|
|
}
|
|
}
|
|
|
|
get searchedUsers() {
|
|
return this.search.transform(this.users, this.searchText, "name", "email", "id");
|
|
}
|
|
|
|
get scrollViewportStyle() {
|
|
return `min-height: 120px; height: ${120 + this.searchedUsers.length * 46}px`;
|
|
}
|
|
|
|
async loadUsers() {
|
|
const users = await this.organizationUserService.getAllUsers(this.organizationId);
|
|
this.allUsers = users.data.map((r) => r).sort(Utils.getSortFunction(this.i18nService, "email"));
|
|
if (this.entity === "group") {
|
|
const response = await this.apiService.getGroupUsers(this.organizationId, this.entityId);
|
|
if (response != null && users.data.length > 0) {
|
|
response.forEach((s) => {
|
|
const user = users.data.filter((u) => u.id === s);
|
|
if (user != null && user.length > 0) {
|
|
(user[0] as any).checked = true;
|
|
}
|
|
});
|
|
}
|
|
} else if (this.entity === "collection") {
|
|
const response = await this.apiService.getCollectionUsers(this.organizationId, this.entityId);
|
|
if (response != null && users.data.length > 0) {
|
|
response.forEach((s) => {
|
|
const user = users.data.filter((u) => !u.accessAll && u.id === s.id);
|
|
if (user != null && user.length > 0) {
|
|
(user[0] as any).checked = true;
|
|
(user[0] as any).readOnly = s.readOnly;
|
|
(user[0] as any).hidePasswords = s.hidePasswords;
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
this.allUsers.forEach((u) => {
|
|
if (this.entity === "collection" && u.accessAll) {
|
|
(u as any).checked = true;
|
|
}
|
|
if ((u as any).checked) {
|
|
this.selectedCount++;
|
|
}
|
|
});
|
|
}
|
|
|
|
check(u: OrganizationUserUserDetailsResponse) {
|
|
if (this.entity === "collection" && u.accessAll) {
|
|
return;
|
|
}
|
|
(u as any).checked = !(u as any).checked;
|
|
this.selectedChanged(u);
|
|
}
|
|
|
|
selectedChanged(u: OrganizationUserUserDetailsResponse) {
|
|
if ((u as any).checked) {
|
|
this.selectedCount++;
|
|
} else {
|
|
if (this.entity === "collection") {
|
|
(u as any).readOnly = false;
|
|
(u as any).hidePasswords = false;
|
|
}
|
|
this.selectedCount--;
|
|
}
|
|
}
|
|
|
|
filterSelected(showSelected: boolean) {
|
|
this.showSelected = showSelected;
|
|
}
|
|
|
|
async submit() {
|
|
try {
|
|
if (this.entity === "group") {
|
|
const selections = this.users.filter((u) => (u as any).checked).map((u) => u.id);
|
|
this.formPromise = this.apiService.putGroupUsers(
|
|
this.organizationId,
|
|
this.entityId,
|
|
selections
|
|
);
|
|
} else {
|
|
const selections = this.users
|
|
.filter((u) => (u as any).checked && !u.accessAll)
|
|
.map(
|
|
(u) =>
|
|
new SelectionReadOnlyRequest(u.id, !!(u as any).readOnly, !!(u as any).hidePasswords)
|
|
);
|
|
this.formPromise = this.apiService.putCollectionUsers(
|
|
this.organizationId,
|
|
this.entityId,
|
|
selections
|
|
);
|
|
}
|
|
await this.formPromise;
|
|
this.platformUtilsService.showToast("success", null, this.i18nService.t("updatedUsers"));
|
|
this.onEditedUsers.emit();
|
|
} catch (e) {
|
|
this.logService.error(e);
|
|
}
|
|
}
|
|
}
|