mirror of
https://github.com/bitwarden/browser
synced 2026-02-07 12:13:45 +00:00
Merge branch 'PM-25685' into PM-25686
This commit is contained in:
@@ -25,6 +25,6 @@ export class FolderExport {
|
||||
|
||||
// Use build method instead of ctor so that we can control order of JSON stringify for pretty print
|
||||
build(o: FolderView | FolderDomain) {
|
||||
this.name = safeGetString(o.name) ?? "";
|
||||
this.name = safeGetString(o.name ?? "") ?? "";
|
||||
}
|
||||
}
|
||||
|
||||
@@ -60,9 +60,8 @@ describe("Folder", () => {
|
||||
it("initializes empty properties when no FolderData is provided", () => {
|
||||
const folder = new Folder();
|
||||
|
||||
expect(folder.id).toBe("");
|
||||
expect(folder.name).toBeInstanceOf(EncString);
|
||||
expect((folder.name as EncString).encryptedString).toBe("");
|
||||
expect(folder.id).toBe(undefined);
|
||||
expect(folder.name).toBe(undefined);
|
||||
expect(folder.revisionDate).toBeInstanceOf(Date);
|
||||
});
|
||||
});
|
||||
|
||||
@@ -8,8 +8,8 @@ import { FolderData } from "../data/folder.data";
|
||||
import { FolderView } from "../view/folder.view";
|
||||
|
||||
export class Folder extends Domain {
|
||||
id: string = "";
|
||||
name: EncString = new EncString("");
|
||||
id?: string;
|
||||
name?: EncString;
|
||||
revisionDate: Date;
|
||||
|
||||
constructor(obj?: FolderData) {
|
||||
@@ -41,10 +41,10 @@ export class Folder extends Domain {
|
||||
encryptService: EncryptService,
|
||||
): Promise<FolderView> {
|
||||
const folderView = new FolderView();
|
||||
folderView.id = this.id;
|
||||
folderView.id = this.id ?? "";
|
||||
folderView.revisionDate = this.revisionDate;
|
||||
try {
|
||||
folderView.name = await encryptService.decryptString(this.name, key);
|
||||
folderView.name = await encryptService.decryptString(this.name ?? new EncString(""), key);
|
||||
} catch (e) {
|
||||
// Note: This should be replaced by the owning team with appropriate, domain-specific behavior.
|
||||
// eslint-disable-next-line no-console
|
||||
@@ -58,6 +58,10 @@ export class Folder extends Domain {
|
||||
if (obj == null) {
|
||||
return null;
|
||||
}
|
||||
return new Folder({ name: obj.name, revisionDate: obj.revisionDate, id: obj.id });
|
||||
return new Folder({
|
||||
name: obj.name ?? "",
|
||||
revisionDate: obj.revisionDate,
|
||||
id: obj.id ?? "",
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
@@ -10,20 +10,21 @@ export class FolderView implements View, ITreeNodeObject {
|
||||
name: string = "";
|
||||
revisionDate: Date;
|
||||
|
||||
constructor(f?: Folder | DecryptedObject<Folder, "name">) {
|
||||
constructor(f?: Folder | DecryptedObject<Folder, undefined>) {
|
||||
if (!f) {
|
||||
this.revisionDate = new Date();
|
||||
return;
|
||||
}
|
||||
|
||||
this.id = f.id;
|
||||
this.id = f.id ?? "";
|
||||
this.name = f.name?.decryptedValue ?? "";
|
||||
this.revisionDate = f.revisionDate;
|
||||
}
|
||||
|
||||
static fromJSON(obj: Jsonify<FolderView>) {
|
||||
const folderView = new FolderView();
|
||||
folderView.id = obj.id;
|
||||
folderView.name = obj.name;
|
||||
folderView.id = obj.id ?? "";
|
||||
folderView.name = obj.name ?? "";
|
||||
folderView.revisionDate = new Date(obj.revisionDate);
|
||||
return folderView;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user