mirror of
https://github.com/bitwarden/browser.git
synced 2024-06-25 10:25:36 +02:00
* Restrict UI actions based on user permission * Swap to hiding bulk option without permission * Fix read/write assignment in project service * Filter projects based on permission in dialog * Fix encryption error for updating secret result * Fix spinner (#5182) * Swap to bit-no-items * [SM-699] Projects bulk delete - add bulk confirmation dialog (#5200) * Add bulk confirmation dialog * Code review updates * Code review - load projects * code review - swap to observable * Code review - remove oninit
87 lines
2.5 KiB
TypeScript
87 lines
2.5 KiB
TypeScript
import { SelectionModel } from "@angular/cdk/collections";
|
|
import { Component, EventEmitter, Input, Output } from "@angular/core";
|
|
import { map } from "rxjs";
|
|
|
|
import { I18nService } from "@bitwarden/common/abstractions/i18n.service";
|
|
import { PlatformUtilsService } from "@bitwarden/common/abstractions/platformUtils.service";
|
|
import { TableDataSource } from "@bitwarden/components";
|
|
|
|
import { ProjectListView } from "../models/view/project-list.view";
|
|
|
|
@Component({
|
|
selector: "sm-projects-list",
|
|
templateUrl: "./projects-list.component.html",
|
|
})
|
|
export class ProjectsListComponent {
|
|
@Input()
|
|
get projects(): ProjectListView[] {
|
|
return this._projects;
|
|
}
|
|
set projects(projects: ProjectListView[]) {
|
|
this.selection.clear();
|
|
this._projects = projects;
|
|
this.dataSource.data = projects;
|
|
}
|
|
private _projects: ProjectListView[];
|
|
|
|
@Input()
|
|
set search(search: string) {
|
|
this.dataSource.filter = search;
|
|
}
|
|
|
|
@Output() editProjectEvent = new EventEmitter<string>();
|
|
@Output() deleteProjectEvent = new EventEmitter<ProjectListView[]>();
|
|
@Output() newProjectEvent = new EventEmitter();
|
|
|
|
selection = new SelectionModel<string>(true, []);
|
|
protected dataSource = new TableDataSource<ProjectListView>();
|
|
protected hasWriteAccessOnSelected$ = this.selection.changed.pipe(
|
|
map((_) => this.selectedHasWriteAccess())
|
|
);
|
|
|
|
constructor(
|
|
private i18nService: I18nService,
|
|
private platformUtilsService: PlatformUtilsService
|
|
) {}
|
|
|
|
isAllSelected() {
|
|
const numSelected = this.selection.selected.length;
|
|
const numRows = this.projects.length;
|
|
return numSelected === numRows;
|
|
}
|
|
|
|
toggleAll() {
|
|
this.isAllSelected()
|
|
? this.selection.clear()
|
|
: this.selection.select(...this.projects.map((s) => s.id));
|
|
}
|
|
|
|
deleteProject(projectId: string) {
|
|
this.deleteProjectEvent.emit(this.projects.filter((p) => p.id == projectId));
|
|
}
|
|
|
|
bulkDeleteProjects() {
|
|
if (this.selection.selected.length >= 1) {
|
|
this.deleteProjectEvent.emit(
|
|
this.projects.filter((project) => this.selection.isSelected(project.id))
|
|
);
|
|
} else {
|
|
this.platformUtilsService.showToast(
|
|
"error",
|
|
this.i18nService.t("errorOccurred"),
|
|
this.i18nService.t("nothingSelected")
|
|
);
|
|
}
|
|
}
|
|
|
|
private selectedHasWriteAccess() {
|
|
const selectedProjects = this.projects.filter((project) =>
|
|
this.selection.isSelected(project.id)
|
|
);
|
|
if (selectedProjects.some((project) => project.write)) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
}
|