import React from "react"; import { fireEvent, GlobalTestState, render } from "./test-utils"; import Excalidraw from "../packages/excalidraw/index"; import { queryByText, queryByTestId } from "@testing-library/react"; import { GRID_SIZE } from "../constants"; import { t } from "../i18n"; const { h } = window; describe("", () => { describe("Test zenModeEnabled prop", () => { it('should show exit zen mode button when zen mode is set and zen mode option in context menu when zenModeEnabled is "undefined"', async () => { const { container } = await render(); expect( container.getElementsByClassName("disable-zen-mode--visible").length, ).toBe(0); expect(h.state.zenModeEnabled).toBe(false); fireEvent.contextMenu(GlobalTestState.canvas, { button: 2, clientX: 1, clientY: 1, }); const contextMenu = document.querySelector(".context-menu"); fireEvent.click(queryByText(contextMenu as HTMLElement, "Zen mode")!); expect(h.state.zenModeEnabled).toBe(true); expect( container.getElementsByClassName("disable-zen-mode--visible").length, ).toBe(1); }); it("should not show exit zen mode button and zen mode option in context menu when zenModeEnabled is set", async () => { const { container } = await render(); expect( container.getElementsByClassName("disable-zen-mode--visible").length, ).toBe(0); expect(h.state.zenModeEnabled).toBe(true); fireEvent.contextMenu(GlobalTestState.canvas, { button: 2, clientX: 1, clientY: 1, }); const contextMenu = document.querySelector(".context-menu"); expect(queryByText(contextMenu as HTMLElement, "Zen mode")).toBe(null); expect(h.state.zenModeEnabled).toBe(true); expect( container.getElementsByClassName("disable-zen-mode--visible").length, ).toBe(0); }); }); describe("Test gridModeEnabled prop", () => { it('should show grid mode in context menu when gridModeEnabled is "undefined"', async () => { const { container } = await render(); expect(h.state.gridSize).toBe(null); expect( container.getElementsByClassName("disable-zen-mode--visible").length, ).toBe(0); fireEvent.contextMenu(GlobalTestState.canvas, { button: 2, clientX: 1, clientY: 1, }); const contextMenu = document.querySelector(".context-menu"); fireEvent.click(queryByText(contextMenu as HTMLElement, "Show grid")!); expect(h.state.gridSize).toBe(GRID_SIZE); }); it('should not show grid mode in context menu when gridModeEnabled is not "undefined"', async () => { const { container } = await render( , ); expect(h.state.gridSize).toBe(null); expect( container.getElementsByClassName("disable-zen-mode--visible").length, ).toBe(0); fireEvent.contextMenu(GlobalTestState.canvas, { button: 2, clientX: 1, clientY: 1, }); const contextMenu = document.querySelector(".context-menu"); expect(queryByText(contextMenu as HTMLElement, "Show grid")).toBe(null); expect(h.state.gridSize).toBe(null); }); }); describe("Test theme prop", () => { it('should show the dark mode toggle when the theme prop is "undefined"', async () => { const { container } = await render(); expect(h.state.theme).toBe("light"); const darkModeToggle = queryByTestId(container, "toggle-dark-mode"); expect(darkModeToggle).toBeTruthy(); }); it('should not show the dark mode toggle when the theme prop is not "undefined"', async () => { const { container } = await render(); expect(h.state.theme).toBe("dark"); expect(queryByTestId(container, "toggle-dark-mode")).toBe(null); }); }); describe("Test name prop", () => { it('should allow editing name when the name prop is "undefined"', async () => { const { container } = await render(); fireEvent.click(queryByTestId(container, "export-button")!); const textInput: HTMLInputElement | null = document.querySelector( ".ExportDialog__name .TextInput", ); expect(textInput?.value).toContain(`${t("labels.untitled")}`); expect(textInput?.nodeName).toBe("INPUT"); }); it('should set the name and not allow editing when the name prop is present"', async () => { const name = "test"; const { container } = await render(); await fireEvent.click(queryByTestId(container, "export-button")!); const textInput = document.querySelector( ".ExportDialog__name .TextInput--readonly", ); expect(textInput?.textContent).toEqual(name); expect(textInput?.nodeName).toBe("SPAN"); }); }); });