1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-04 18:37:45 +01:00

hide ownership view when viewing a cipher in the admin console (#11852)

This commit is contained in:
Nick Krantz 2024-11-05 10:09:16 -06:00 committed by GitHub
parent e206fc1819
commit adcd5bd307
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 98 additions and 6 deletions

View File

@ -7,6 +7,7 @@
*ngIf="showCipherView" *ngIf="showCipherView"
[cipher]="cipher" [cipher]="cipher"
[collections]="collections" [collections]="collections"
[isAdminConsole]="formConfig.isAdminConsole"
></app-cipher-view> ></app-cipher-view>
<vault-cipher-form <vault-cipher-form
*ngIf="loadForm" *ngIf="loadForm"

View File

@ -18,6 +18,7 @@
[organization]="organization$ | async" [organization]="organization$ | async"
[collections]="collections" [collections]="collections"
[folder]="folder$ | async" [folder]="folder$ | async"
[hideOwner]="isAdminConsole"
> >
</app-item-details-v2> </app-item-details-v2>

View File

@ -51,6 +51,10 @@ export class CipherViewComponent implements OnChanges, OnDestroy {
* `CipherService` and the `collectionIds` property of the cipher. * `CipherService` and the `collectionIds` property of the cipher.
*/ */
@Input() collections: CollectionView[]; @Input() collections: CollectionView[];
/** Should be set to true when the component is used within the Admin Console */
@Input() isAdminConsole?: boolean = false;
organization$: Observable<Organization>; organization$: Observable<Organization>;
folder$: Observable<FolderView>; folder$: Observable<FolderView>;
private destroyed$: Subject<void> = new Subject(); private destroyed$: Subject<void> = new Subject();

View File

@ -4,10 +4,8 @@
</bit-section-header> </bit-section-header>
<bit-card> <bit-card>
<bit-form-field <bit-form-field
[disableMargin]="!cipher.collectionIds?.length && !cipher.organizationId && !cipher.folderId" [disableMargin]="!cipher.collectionIds?.length && !showOwnership && !cipher.folderId"
[disableReadOnlyBorder]=" [disableReadOnlyBorder]="!cipher.collectionIds?.length && !showOwnership && !cipher.folderId"
!cipher.collectionIds?.length && !cipher.organizationId && !cipher.folderId
"
> >
<bit-label> <bit-label>
{{ "itemName" | i18n }} {{ "itemName" | i18n }}
@ -24,11 +22,11 @@
<ul <ul
[attr.aria-label]="'itemLocation' | i18n" [attr.aria-label]="'itemLocation' | i18n"
*ngIf="cipher.collectionIds?.length || cipher.organizationId || cipher.folderId" *ngIf="cipher.collectionIds?.length || showOwnership || cipher.folderId"
class="tw-mb-0 tw-pl-0" class="tw-mb-0 tw-pl-0"
> >
<li <li
*ngIf="cipher.organizationId && organization" *ngIf="showOwnership && organization"
class="tw-flex tw-items-center tw-list-none" class="tw-flex tw-items-center tw-list-none"
[ngClass]="{ 'tw-mb-3': cipher.collectionIds }" [ngClass]="{ 'tw-mb-3': cipher.collectionIds }"
bitTypography="body2" bitTypography="body2"

View File

@ -0,0 +1,83 @@
import { ComponentFixture, TestBed } from "@angular/core/testing";
import { By } from "@angular/platform-browser";
import { CollectionView } from "@bitwarden/admin-console/common";
import { Organization } from "@bitwarden/common/admin-console/models/domain/organization";
import { I18nService } from "@bitwarden/common/platform/abstractions/i18n.service";
import { CipherView } from "@bitwarden/common/vault/models/view/cipher.view";
import { FolderView } from "@bitwarden/common/vault/models/view/folder.view";
import { ItemDetailsV2Component } from "./item-details-v2.component";
describe("ItemDetailsV2Component", () => {
let component: ItemDetailsV2Component;
let fixture: ComponentFixture<ItemDetailsV2Component>;
const cipher = {
id: "cipher1",
collectionIds: ["col1", "col2"],
organizationId: "org1",
folderId: "folder1",
name: "cipher name",
} as CipherView;
const organization = {
id: "org1",
name: "Organization 1",
} as Organization;
const collection = {
id: "col1",
name: "Collection 1",
} as CollectionView;
const collection2 = {
id: "col2",
name: "Collection 2",
} as CollectionView;
const folder = {
id: "folder1",
name: "Folder 1",
} as FolderView;
beforeEach(async () => {
await TestBed.configureTestingModule({
imports: [ItemDetailsV2Component],
providers: [{ provide: I18nService, useValue: { t: (key: string) => key } }],
}).compileComponents();
});
beforeEach(() => {
fixture = TestBed.createComponent(ItemDetailsV2Component);
component = fixture.componentInstance;
component.cipher = cipher;
component.organization = organization;
component.collections = [collection, collection2];
component.folder = folder;
fixture.detectChanges();
});
it("displays all available fields", () => {
const itemName = fixture.debugElement.query(By.css('[data-testid="item-name"]'));
const owner = fixture.debugElement.query(By.css('[data-testid="owner"]'));
const collections = fixture.debugElement.queryAll(By.css('[data-testid="collections"] li'));
const folderElement = fixture.debugElement.query(By.css('[data-testid="folder"]'));
expect(itemName.nativeElement.value).toBe(cipher.name);
expect(owner.nativeElement.textContent.trim()).toBe(organization.name);
expect(collections.map((c) => c.nativeElement.textContent.trim())).toEqual([
collection.name,
collection2.name,
]);
expect(folderElement.nativeElement.textContent.trim()).toBe(folder.name);
});
it("does not render owner when `hideOwner` is true", () => {
component.hideOwner = true;
fixture.detectChanges();
const owner = fixture.debugElement.query(By.css('[data-testid="owner"]'));
expect(owner).toBeNull();
});
});

View File

@ -36,4 +36,9 @@ export class ItemDetailsV2Component {
@Input() organization?: Organization; @Input() organization?: Organization;
@Input() collections?: CollectionView[]; @Input() collections?: CollectionView[];
@Input() folder?: FolderView; @Input() folder?: FolderView;
@Input() hideOwner?: boolean = false;
get showOwnership() {
return this.cipher.organizationId && this.organization && !this.hideOwner;
}
} }