diff --git a/apps/web/__e2e__/vault.test.ts b/apps/web/__e2e__/vault.test.ts
new file mode 100644
index 0000000000..c113b406d6
--- /dev/null
+++ b/apps/web/__e2e__/vault.test.ts
@@ -0,0 +1,88 @@
+/*
+This file is part of the Notesnook project (https://notesnook.com/)
+
+Copyright (C) 2023 Streetwriters (Private) Limited
+
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation, either version 3 of the License, or
+(at your option) any later version.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see .
+*/
+
+import { test, expect } from "@playwright/test";
+import { AppModel } from "./models/app.model";
+import { getTestId, NOTE, PASSWORD } from "./utils";
+
+test("locking a note should show vault unlocked status", async ({ page }) => {
+ const app = new AppModel(page);
+ await app.goto();
+ const notes = await app.goToNotes();
+ const note = await notes.createNote(NOTE);
+ const vaultUnlockedStatus = page.locator(getTestId("vault-unlocked"));
+
+ await note?.contextMenu.lock(PASSWORD);
+
+ await expect(vaultUnlockedStatus).toBeVisible();
+});
+
+test("clicking on vault unlocked status should lock the vault", async ({
+ page
+}) => {
+ const app = new AppModel(page);
+ await app.goto();
+ const notes = await app.goToNotes();
+ const note = await notes.createNote(NOTE);
+ const vaultUnlockedStatus = page.locator(getTestId("vault-unlocked"));
+
+ await note?.contextMenu.lock(PASSWORD);
+ await note?.openLockedNote(PASSWORD);
+ await vaultUnlockedStatus.waitFor({ state: "visible" });
+ await vaultUnlockedStatus.click();
+
+ await expect(vaultUnlockedStatus).toBeHidden();
+ expect(await note?.contextMenu.isLocked()).toBe(true);
+});
+
+test("opening a locked note should show vault unlocked status", async ({
+ page
+}) => {
+ const app = new AppModel(page);
+ await app.goto();
+ const notes = await app.goToNotes();
+ const note = await notes.createNote(NOTE);
+ const vaultUnlockedStatus = page.locator(getTestId("vault-unlocked"));
+
+ await note?.contextMenu.lock(PASSWORD);
+ await vaultUnlockedStatus.waitFor({ state: "visible" });
+ await vaultUnlockedStatus.click();
+ await vaultUnlockedStatus.waitFor({ state: "hidden" });
+ await note?.openLockedNote(PASSWORD);
+
+ await expect(vaultUnlockedStatus).toBeVisible();
+});
+
+test("unlocking a note permanently should not show vault unlocked status", async ({
+ page
+}) => {
+ const app = new AppModel(page);
+ await app.goto();
+ const notes = await app.goToNotes();
+ const note = await notes.createNote(NOTE);
+ const vaultUnlockedStatus = page.locator(getTestId("vault-unlocked"));
+
+ await note?.contextMenu.lock(PASSWORD);
+ await vaultUnlockedStatus.waitFor({ state: "visible" });
+ await vaultUnlockedStatus.click();
+ await vaultUnlockedStatus.waitFor({ state: "hidden" });
+ await note?.contextMenu.unlock(PASSWORD);
+
+ await expect(vaultUnlockedStatus).toBeHidden();
+});
diff --git a/apps/web/src/components/status-bar/index.tsx b/apps/web/src/components/status-bar/index.tsx
index 7af2e18831..a487d4a945 100644
--- a/apps/web/src/components/status-bar/index.tsx
+++ b/apps/web/src/components/status-bar/index.tsx
@@ -174,6 +174,7 @@ function StatusBar() {
justifyContent: "center",
display: "flex"
}}
+ data-test-id="vault-unlocked"
>
diff --git a/packages/core/src/api/vault.ts b/packages/core/src/api/vault.ts
index cfb3b76bfe..7cb4c84dfe 100644
--- a/packages/core/src/api/vault.ts
+++ b/packages/core/src/api/vault.ts
@@ -48,6 +48,7 @@ export default class Vault {
}
private startEraser() {
+ EV.publish(EVENTS.vaultUnlocked);
clearTimeout(this.erasureTimeout);
this.erasureTimeout = setTimeout(() => {
this.lock();
@@ -95,7 +96,6 @@ export default class Vault {
throw new Error(VAULT_ERRORS.wrongPassword);
}
this.password = password;
- EV.publish(EVENTS.vaultUnlocked);
return true;
}