You've already forked element-web
mirror of
https://github.com/element-hq/element-web.git
synced 2025-08-09 14:42:51 +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
85 lines
3.7 KiB
TypeScript
85 lines
3.7 KiB
TypeScript
/*
|
|
Copyright 2024,2025 New Vector Ltd.
|
|
Copyright 2024 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 { fireEvent, render, screen } from "jest-matrix-react";
|
|
import { MatrixEvent, type MatrixClient } from "matrix-js-sdk/src/matrix";
|
|
|
|
import { HideActionButton } from "../../../../../src/components/views/messages/HideActionButton";
|
|
import SettingsStore from "../../../../../src/settings/SettingsStore";
|
|
import { SettingLevel } from "../../../../../src/settings/SettingLevel";
|
|
import type { Settings } from "../../../../../src/settings/Settings";
|
|
import { MediaPreviewValue } from "../../../../../src/@types/media_preview";
|
|
import { getMockClientWithEventEmitter, withClientContextRenderOptions } from "../../../../test-utils";
|
|
import type { MockedObject } from "jest-mock";
|
|
|
|
function mockSetting(mediaPreviews: MediaPreviewValue, showMediaEventIds: Settings["showMediaEventIds"]["default"]) {
|
|
jest.spyOn(SettingsStore, "getValue").mockImplementation((settingName) => {
|
|
if (settingName === "mediaPreviewConfig") {
|
|
return { media_previews: mediaPreviews, invite_avatars: MediaPreviewValue.Off };
|
|
} else if (settingName === "showMediaEventIds") {
|
|
return showMediaEventIds;
|
|
}
|
|
throw Error(`Unexpected setting ${settingName}`);
|
|
});
|
|
}
|
|
|
|
const EVENT_ID = "$foo:bar";
|
|
|
|
const event = new MatrixEvent({
|
|
event_id: EVENT_ID,
|
|
room_id: "!room:id",
|
|
sender: "@user:id",
|
|
type: "m.room.message",
|
|
content: {
|
|
body: "test",
|
|
msgtype: "m.image",
|
|
url: "mxc://matrix.org/1234",
|
|
},
|
|
});
|
|
|
|
describe("HideActionButton", () => {
|
|
let cli: MockedObject<MatrixClient>;
|
|
beforeEach(() => {
|
|
cli = getMockClientWithEventEmitter({
|
|
getRoom: jest.fn(),
|
|
});
|
|
});
|
|
afterEach(() => {
|
|
jest.restoreAllMocks();
|
|
});
|
|
it("should show button when event is visible by showMediaEventIds setting", async () => {
|
|
mockSetting(MediaPreviewValue.Off, { [EVENT_ID]: true });
|
|
render(<HideActionButton mxEvent={event} />, withClientContextRenderOptions(cli));
|
|
expect(screen.getByRole("button")).toBeVisible();
|
|
});
|
|
it("should show button when event is visible by mediaPreviewConfig setting", async () => {
|
|
mockSetting(MediaPreviewValue.On, {});
|
|
render(<HideActionButton mxEvent={event} />, withClientContextRenderOptions(cli));
|
|
expect(screen.getByRole("button")).toBeVisible();
|
|
});
|
|
it("should hide button when event is hidden by showMediaEventIds setting", async () => {
|
|
mockSetting(MediaPreviewValue.Off, { [EVENT_ID]: false });
|
|
render(<HideActionButton mxEvent={event} />, withClientContextRenderOptions(cli));
|
|
expect(screen.queryByRole("button")).toBeNull();
|
|
});
|
|
it("should hide button when event is hidden by showImages setting", async () => {
|
|
mockSetting(MediaPreviewValue.Off, {});
|
|
render(<HideActionButton mxEvent={event} />, withClientContextRenderOptions(cli));
|
|
expect(screen.queryByRole("button")).toBeNull();
|
|
});
|
|
it("should store event as hidden when clicked", async () => {
|
|
const spy = jest.spyOn(SettingsStore, "setValue");
|
|
render(<HideActionButton mxEvent={event} />, withClientContextRenderOptions(cli));
|
|
fireEvent.click(screen.getByRole("button"));
|
|
expect(spy).toHaveBeenCalledWith("showMediaEventIds", null, SettingLevel.DEVICE, { "$foo:bar": false });
|
|
// Button should be hidden after the setting is set.
|
|
expect(screen.queryByRole("button")).toBeNull();
|
|
});
|
|
});
|