/*
Copyright 2024 New Vector Ltd.
Copyright 2022 The Matrix.org Foundation C.I.C.

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 React from "react";
import { Room } from "matrix-js-sdk/src/matrix";
import { act, render, screen } from "jest-matrix-react";

import { useTopic } from "../../src/hooks/room/useTopic";
import { mkEvent, stubClient } from "../test-utils";
import { MatrixClientPeg } from "../../src/MatrixClientPeg";

describe("useTopic", () => {
    it("should display the room topic", () => {
        stubClient();
        const room = new Room("!TESTROOM", MatrixClientPeg.safeGet(), "@alice:example.org");
        const topic = mkEvent({
            type: "m.room.topic",
            room: "!TESTROOM",
            user: "@alice:example.org",
            content: {
                topic: "Test topic",
            },
            ts: 123,
            event: true,
        });

        room.addLiveEvents([topic], { addToState: true });

        function RoomTopic() {
            const topic = useTopic(room);
            return <p>{topic!.text}</p>;
        }

        render(<RoomTopic />);

        expect(screen.queryByText("Test topic")).toBeInTheDocument();

        const updatedTopic = mkEvent({
            type: "m.room.topic",
            room: "!TESTROOM",
            user: "@alice:example.org",
            content: {
                topic: "New topic",
            },
            ts: 666,
            event: true,
        });

        act(() => {
            room.addLiveEvents([updatedTopic], { addToState: true });
        });

        expect(screen.queryByText("New topic")).toBeInTheDocument();
    });
});