import { test, expect } from "@playwright/test";
import { ViewerPage } from "../pages/ViewerPage";

test.beforeEach(async ({ page }) => {
  await ViewerPage.init(page);
});

const singleBoardFileId = "dd5cc0bb-91ff-81b9-8004-77df9cd3edb1";
const singleBoardPageId = "dd5cc0bb-91ff-81b9-8004-77df9cd3edb2";

const setupFileWithSingleBoard = async (viewer) => {
  await viewer.mockRPC(/get\-view\-only\-bundle\?/, "viewer/get-view-only-bundle-single-board.json");
  await viewer.mockRPC("get-comment-threads?file-id=*", "workspace/get-comment-threads-empty.json");
  await viewer.mockRPC(
    "get-file-fragment?file-id=*&fragment-id=*",
    "viewer/get-file-fragment-single-board.json",
  );
};

test("Clips link area of the logo", async ({ page }) => {
  const viewerPage = new ViewerPage(page);
  await viewerPage.setupLoggedInUser();
  await viewerPage.setupEmptyFile();

  await viewerPage.goToViewer();

  const viewerUrl = page.url();

  const logoLink = viewerPage.page.getByTestId("penpot-logo-link");
  await expect(logoLink).toBeVisible();

  const { x, y } = await logoLink.boundingBox();
  await viewerPage.page.mouse.click(x, y + 100);
  await expect(page.url()).toBe(viewerUrl);
});

test("Updates URL with zoom type", async ({ page }) => {
  const viewer = new ViewerPage(page);
  await viewer.setupLoggedInUser();
  await setupFileWithSingleBoard(viewer);

  await viewer.goToViewer({ fileId: singleBoardFileId, pageId: singleBoardPageId });

  await viewer.page.getByTitle("Zoom").click();
  await viewer.page.getByText(/Fit/).click();

  await expect(viewer.page).toHaveURL(/&zoom=fit/);
});