2025-01-11 00:13:46 +02:00
|
|
|
import { test, expect } from "@playwright/test";
|
|
|
|
import App from "../support/app";
|
|
|
|
|
2025-01-11 00:45:02 +02:00
|
|
|
const NOTE_TITLE = "Trilium Integration Test DB";
|
|
|
|
|
2025-01-12 18:05:24 +02:00
|
|
|
test("Can drag tabs around", async ({ page, context }) => {
|
|
|
|
const app = new App(page, context);
|
2025-01-11 00:13:46 +02:00
|
|
|
await app.goto();
|
|
|
|
|
|
|
|
// [1]: Trilium Integration Test DB note
|
|
|
|
await app.closeAllTabs();
|
2025-01-11 00:45:02 +02:00
|
|
|
await app.clickNoteOnNoteTreeByTitle(NOTE_TITLE);
|
|
|
|
await expect(app.getActiveTab()).toContainText(NOTE_TITLE);
|
2025-01-11 00:13:46 +02:00
|
|
|
|
|
|
|
// [1] [2] [3]
|
|
|
|
await app.addNewTab();
|
|
|
|
await app.addNewTab();
|
|
|
|
|
|
|
|
let tab = app.getTab(0);
|
|
|
|
|
|
|
|
// Drag the first tab at the end
|
2025-03-02 20:47:57 +01:00
|
|
|
await tab.dragTo(app.getTab(2), { targetPosition: { x: 50, y: 0 } });
|
2025-01-11 00:13:46 +02:00
|
|
|
|
|
|
|
tab = app.getTab(2);
|
2025-01-11 00:45:02 +02:00
|
|
|
await expect(tab).toContainText(NOTE_TITLE);
|
2025-01-11 00:13:46 +02:00
|
|
|
|
|
|
|
// Drag the tab to the left
|
2025-03-02 20:47:57 +01:00
|
|
|
await tab.dragTo(app.getTab(0), { targetPosition: { x: 50, y: 0 } });
|
2025-01-11 00:45:02 +02:00
|
|
|
await expect(app.getTab(0)).toContainText(NOTE_TITLE);
|
|
|
|
});
|
|
|
|
|
2025-01-12 18:05:24 +02:00
|
|
|
test("Can drag tab to new window", async ({ page, context }) => {
|
|
|
|
const app = new App(page, context);
|
2025-01-11 00:45:02 +02:00
|
|
|
await app.goto();
|
|
|
|
|
|
|
|
await app.closeAllTabs();
|
|
|
|
await app.clickNoteOnNoteTreeByTitle(NOTE_TITLE);
|
|
|
|
const tab = app.getTab(0);
|
|
|
|
await expect(tab).toContainText(NOTE_TITLE);
|
|
|
|
|
|
|
|
const popupPromise = page.waitForEvent("popup");
|
|
|
|
|
|
|
|
const tabPos = await tab.boundingBox();
|
|
|
|
if (tabPos) {
|
|
|
|
const x = tabPos.x + tabPos.width / 2;
|
|
|
|
const y = tabPos.y + tabPos.height / 2;
|
|
|
|
await page.mouse.move(x, y);
|
|
|
|
await page.mouse.down();
|
|
|
|
await page.mouse.move(x, y + tabPos.height + 100, { steps: 5 });
|
|
|
|
await page.mouse.up();
|
|
|
|
} else {
|
2025-01-12 17:17:07 +02:00
|
|
|
test.fail(true, "Unable to determine tab position");
|
2025-01-11 00:45:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Wait for the popup to show
|
|
|
|
const popup = await popupPromise;
|
2025-01-12 18:05:24 +02:00
|
|
|
const popupApp = new App(popup, context);
|
2025-01-11 00:45:02 +02:00
|
|
|
await expect(popupApp.getActiveTab()).toHaveText(NOTE_TITLE);
|
2025-01-11 00:13:46 +02:00
|
|
|
});
|