mirror of
https://github.com/vector-im/element-web.git
synced 2026-05-04 11:51:36 +02:00
* feat(sc): add section menu to section header * feat(rls): add edit and remove sections * feat(dialog): add editing mode to CreateSectionDialog * feat(dialog): add remove section dialog * feat(vm): wire up vm and stores * test: update existing snapshots * test(e2e): add playwright tests to edit and remove a section * chore: fix remove section i18n key * fix: able to send empty sections * chore: update create section editing docs * chore: remove useless fallback * chore: add logs when section is unknown * feat: use different wording when removing an empty section * fix: only animate the chevron icon in the section header * fix: change dialog subtitle weight to medium
94 lines
3.7 KiB
TypeScript
94 lines
3.7 KiB
TypeScript
/*
|
|
* Copyright 2026 Element Creations Ltd.
|
|
*
|
|
* SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
|
|
* Please see LICENSE files in the repository root for full details.
|
|
*/
|
|
|
|
import { render, screen } from "jest-matrix-react";
|
|
import userEvent from "@testing-library/user-event";
|
|
import React from "react";
|
|
|
|
import { CreateSectionDialog } from "../../../../../src/components/views/dialogs/CreateSectionDialog";
|
|
|
|
describe("CreateSectionDialog", () => {
|
|
const onFinished: jest.Mock = jest.fn();
|
|
|
|
beforeEach(() => {
|
|
jest.resetAllMocks();
|
|
});
|
|
|
|
function renderComponent(): void {
|
|
render(<CreateSectionDialog onFinished={onFinished} />);
|
|
}
|
|
|
|
it("renders the dialog", () => {
|
|
const { container } = render(<CreateSectionDialog onFinished={onFinished} />);
|
|
expect(container).toMatchSnapshot();
|
|
});
|
|
|
|
it("has the create section button disabled when the input is empty", () => {
|
|
renderComponent();
|
|
const createButton = screen.getByRole("button", { name: "Create section" });
|
|
expect(createButton).toBeDisabled();
|
|
});
|
|
|
|
it("calls onFinished with true and the section name when create section is clicked", async () => {
|
|
renderComponent();
|
|
const input = screen.getByRole("textbox");
|
|
await userEvent.type(input, "My section");
|
|
const createButton = screen.getByRole("button", { name: "Create section" });
|
|
await userEvent.click(createButton);
|
|
expect(onFinished).toHaveBeenCalledWith(true, "My section");
|
|
});
|
|
|
|
it("calls onFinished with false when the dialog is cancelled", async () => {
|
|
renderComponent();
|
|
const cancelButton = screen.getByRole("button", { name: "Cancel" });
|
|
await userEvent.click(cancelButton);
|
|
expect(onFinished).toHaveBeenCalledWith(false, "");
|
|
});
|
|
|
|
it("calls onFinished with true and the section name when the form is submitted", async () => {
|
|
renderComponent();
|
|
const input = screen.getByRole("textbox");
|
|
await userEvent.type(input, "My section");
|
|
await userEvent.keyboard("{Enter}");
|
|
expect(onFinished).toHaveBeenCalledWith(true, "My section");
|
|
});
|
|
|
|
describe("editing mode", () => {
|
|
function renderEditComponent(): void {
|
|
render(<CreateSectionDialog onFinished={onFinished} sectionToEdit="Existing Section" />);
|
|
}
|
|
|
|
it("pre-fills the input with the existing section name", () => {
|
|
renderEditComponent();
|
|
const input = screen.getByRole("textbox");
|
|
expect(input).toHaveValue("Existing Section");
|
|
});
|
|
|
|
it("shows the edit section button instead of create section", () => {
|
|
renderEditComponent();
|
|
expect(screen.getByRole("button", { name: "Edit section" })).toBeInTheDocument();
|
|
expect(screen.queryByRole("button", { name: "Create section" })).not.toBeInTheDocument();
|
|
});
|
|
|
|
it("calls onFinished with the updated name when edit section is clicked", async () => {
|
|
renderEditComponent();
|
|
const input = screen.getByRole("textbox");
|
|
await userEvent.clear(input);
|
|
await userEvent.type(input, "Updated Section");
|
|
await userEvent.click(screen.getByRole("button", { name: "Edit section" }));
|
|
expect(onFinished).toHaveBeenCalledWith(true, "Updated Section");
|
|
});
|
|
|
|
it("has the edit section button disabled when the input is empty", async () => {
|
|
renderEditComponent();
|
|
const input = screen.getByRole("textbox");
|
|
await userEvent.clear(input);
|
|
expect(screen.getByRole("button", { name: "Edit section" })).toBeDisabled();
|
|
});
|
|
});
|
|
});
|