You've already forked element-web
mirror of
https://github.com/element-hq/element-web.git
synced 2025-08-08 03:42:14 +03:00
* Modify useMediaVisible to take a room. * Add initial support for a account data level key. * Update controls. * Update settings * Lint and fixes * make some tests go happy * lint * i18n * update preferences * prettier * Update settings tab. * update screenshot * Update docs * Rewrite controller * Rewrite tons of tests * Rewrite RoomAvatar to be a functional component This is so we can use hooks to determine the setting state. * lint * lint * Tidy up comments * Apply media visible hook to inline images. * Move conditionals. * copyright all the things * Review changes * Update html utils to properly discard media. * Types fix * Fixing tests that break settings getValue expectations * Fix logic around media preview calculation * Fix room header tests * Fixup tests for timelinePanel * Clear settings in matrixchat * Update tests to use SettingsStore where possible. * fix bug * revert changes to client.ts * copyright years * Add header * Add a test for MediaPreviewAccountSettingsTab * Mark initMatrixClient as optional * Improve on types * Ensure we do not set the account data twice. * lint * Review changes * Ensure we include the client on rendered messages. * Fix test * update labels * clean designs * update settings tab * update snapshot * copyright * prevent mutation
105 lines
4.3 KiB
TypeScript
105 lines
4.3 KiB
TypeScript
/*
|
|
Copyright 2024, 2025 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 { render } from "jest-matrix-react";
|
|
import { EventType, type MatrixClient, MatrixEvent, Room, RoomMember } from "matrix-js-sdk/src/matrix";
|
|
import { mocked } from "jest-mock";
|
|
|
|
import RoomAvatar from "../../../../../src/components/views/avatars/RoomAvatar";
|
|
import { filterConsole, stubClient } from "../../../../test-utils";
|
|
import DMRoomMap from "../../../../../src/utils/DMRoomMap";
|
|
import { LocalRoom } from "../../../../../src/models/LocalRoom";
|
|
import * as AvatarModule from "../../../../../src/Avatar";
|
|
import { DirectoryMember } from "../../../../../src/utils/direct-messages";
|
|
import { MediaPreviewValue } from "../../../../../src/@types/media_preview";
|
|
import SettingsStore from "../../../../../src/settings/SettingsStore";
|
|
import { SettingLevel } from "../../../../../src/settings/SettingLevel";
|
|
|
|
describe("RoomAvatar", () => {
|
|
let client: MatrixClient;
|
|
|
|
filterConsole(
|
|
// unrelated for this test
|
|
"Room !room:example.com does not have an m.room.create event",
|
|
);
|
|
|
|
beforeAll(() => {
|
|
client = stubClient();
|
|
const dmRoomMap = new DMRoomMap(client);
|
|
jest.spyOn(dmRoomMap, "getUserIdForRoomId");
|
|
jest.spyOn(DMRoomMap, "shared").mockReturnValue(dmRoomMap);
|
|
jest.spyOn(AvatarModule, "defaultAvatarUrlForString");
|
|
});
|
|
|
|
afterAll(() => {
|
|
SettingsStore.setValue(
|
|
"mediaPreviewConfig",
|
|
null,
|
|
SettingLevel.ACCOUNT,
|
|
SettingsStore.getDefaultValue("mediaPreviewConfig"),
|
|
);
|
|
jest.restoreAllMocks();
|
|
});
|
|
|
|
afterEach(() => {
|
|
mocked(DMRoomMap.shared().getUserIdForRoomId).mockReset();
|
|
mocked(AvatarModule.defaultAvatarUrlForString).mockClear();
|
|
});
|
|
|
|
it("should render as expected for a Room", () => {
|
|
const room = new Room("!room:example.com", client, client.getSafeUserId());
|
|
room.name = "test room";
|
|
expect(render(<RoomAvatar room={room} />).container).toMatchSnapshot();
|
|
});
|
|
|
|
it("should render as expected for a DM room", () => {
|
|
const userId = "@dm_user@example.com";
|
|
const room = new Room("!room:example.com", client, client.getSafeUserId());
|
|
room.getMember = jest.fn().mockImplementation(() => new RoomMember(room.roomId, userId));
|
|
room.name = "DM room";
|
|
mocked(DMRoomMap.shared().getUserIdForRoomId).mockReturnValue(userId);
|
|
expect(render(<RoomAvatar room={room} />).container).toMatchSnapshot();
|
|
});
|
|
|
|
it("should render as expected for a LocalRoom", () => {
|
|
const userId = "@local_room_user@example.com";
|
|
const localRoom = new LocalRoom("!room:example.com", client, client.getSafeUserId());
|
|
localRoom.name = "local test room";
|
|
localRoom.targets.push(new DirectoryMember({ user_id: userId }));
|
|
expect(render(<RoomAvatar room={localRoom} />).container).toMatchSnapshot();
|
|
});
|
|
it("should render an avatar for a room the user is invited to", () => {
|
|
const room = new Room("!room:example.com", client, client.getSafeUserId());
|
|
jest.spyOn(room, "getMxcAvatarUrl").mockImplementation(() => "mxc://example.com/foobar");
|
|
room.name = "test room";
|
|
room.updateMyMembership("invite");
|
|
room.currentState.setStateEvents([
|
|
new MatrixEvent({
|
|
sender: "@sender:server",
|
|
room_id: room.roomId,
|
|
type: EventType.RoomAvatar,
|
|
state_key: "",
|
|
content: {
|
|
url: "mxc://example.com/foobar",
|
|
},
|
|
}),
|
|
]);
|
|
expect(render(<RoomAvatar room={room} />).container).toMatchSnapshot();
|
|
});
|
|
it("should not render an invite avatar if the user has disabled it", () => {
|
|
SettingsStore.setValue("mediaPreviewConfig", null, SettingLevel.ACCOUNT, {
|
|
invite_avatars: MediaPreviewValue.Off,
|
|
});
|
|
const room = new Room("!room:example.com", client, client.getSafeUserId());
|
|
room.name = "test room";
|
|
room.updateMyMembership("invite");
|
|
expect(render(<RoomAvatar room={room} />).container).toMatchSnapshot();
|
|
});
|
|
});
|