mirror of
https://github.com/vector-im/element-web.git
synced 2026-03-30 10:41:35 +02:00
* Port over linkifyJS to shared-components. * Drop rubbish * update lock * quickfix test * drop group id * Modernize tests * Remove stories that aren't in use. * Complete working version * Add copyright * tidy up * update lock * Update snaps * update snap * undo change * remove unused * More test updates * fix typo * fix margin on preview * move margin block * snapupdate * prettier * Port url preview logic to a view model. * More fiddling with VM logic * Note to self * Refactor away into a shared component. * Even more lovely lovely code that makes it look prettier * translation cleanup * Even more stuff that I need to fix yay * Remove .last-run.json * Update snaps * Ensure we set showUrlPreview * Cleanup tests * lint + add png support * Add a label * Cleanup * Add snaps * Update snaps * update playwright * Refactors * update snap * Add missing snap * Remove editing code (we check this in a better way in componentDidUpdate) * Add README * fix the one unused import * Style shuffling * Update vis tests * Finally fix the tooltip * Remove unused prop * Add some padding * fix lint issue * Design improvements * new screens * Update snaps * Fix CSS specificity * Remove stale screenshot * Rename function to match reality * Port viewmodel tests to snapshots * finish documenting types * Stop being dangerous * Use Linkify+decode for description * Remove ability for VM to do linkifying. * Port over linkifyJS to shared-components. * Drop rubbish * update lock * quickfix test * drop group id * Modernize tests * Remove stories that aren't in use. * Complete working version * Add copyright * tidy up * update lock * Update snaps * update snap * undo change * remove unused * More test updates * fix typo * fix margin on preview * move margin block * snapupdate * prettier * cleanup a test mistake * Fixup sonar issues * Don't expose linkifyjs to applications, just provide helper functions. * Add story for documentation. * remove $ * Use a const * typo * cleanup var name * remove console line * Changes checkpoint * Convert to context * Revert unrelated change. * more cleanup * Add a test to cover ignoring incoming data elements * Make tests happy * Update tests for LinkedText * Underlines! * fix lock * remove unused linkify packages * import move * Remove mod to remove underline * undo * fix snap * another snapshot fix * More cleanup * Tidy up based on review. * fix story * Pass in args * update snap * cleanup * use source image * oops * remove client peg * Remove unused state * tidy up code * Ensure we update the preview when the event content may have changed. * s/global/globalThis/ * Ensure we don't stretch images * Update screenshots * Cleanup
103 lines
3.5 KiB
TypeScript
103 lines
3.5 KiB
TypeScript
/*
|
|
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 { type MockedObject } from "jest-mock";
|
|
import { type EventTimeline, EventType, type MatrixClient, type MatrixEvent, Room } from "matrix-js-sdk/src/matrix";
|
|
import { KnownMembership } from "matrix-js-sdk/src/types";
|
|
|
|
import { MainSplitContentType } from "../../src/components/structures/RoomView";
|
|
import { type RoomContextType, TimelineRenderingType } from "../../src/contexts/RoomContext";
|
|
import { Layout } from "../../src/settings/enums/Layout";
|
|
import { mkEvent } from "./test-utils";
|
|
import { SdkContextClass } from "../../src/contexts/SDKContext";
|
|
|
|
export const makeMembershipEvent = (roomId: string, userId: string, membership = KnownMembership.Join) =>
|
|
mkEvent({
|
|
event: true,
|
|
type: EventType.RoomMember,
|
|
room: roomId,
|
|
user: userId,
|
|
skey: userId,
|
|
content: { membership },
|
|
ts: Date.now(),
|
|
});
|
|
|
|
/**
|
|
* Creates a room
|
|
* sets state events on the room
|
|
* Sets client getRoom to return room
|
|
* returns room
|
|
*/
|
|
export const makeRoomWithStateEvents = (
|
|
stateEvents: MatrixEvent[] = [],
|
|
{ roomId, mockClient }: { roomId: string; mockClient: MockedObject<MatrixClient> },
|
|
): Room => {
|
|
const room1 = new Room(roomId, mockClient, "@user:server.org");
|
|
room1.currentState.setStateEvents(stateEvents);
|
|
mockClient.getRoom.mockReturnValue(room1);
|
|
return room1;
|
|
};
|
|
|
|
export function getRoomContext(room: Room, override: Partial<RoomContextType>): RoomContextType {
|
|
return {
|
|
roomViewStore: SdkContextClass.instance.roomViewStore,
|
|
room,
|
|
roomLoading: true,
|
|
peekLoading: false,
|
|
shouldPeek: true,
|
|
membersLoaded: false,
|
|
numUnreadMessages: 0,
|
|
canPeek: false,
|
|
showApps: false,
|
|
isPeeking: false,
|
|
showRightPanel: true,
|
|
joining: false,
|
|
atEndOfLiveTimeline: true,
|
|
showTopUnreadMessagesBar: false,
|
|
statusBarVisible: false,
|
|
canReact: false,
|
|
canSendMessages: false,
|
|
layout: Layout.Group,
|
|
lowBandwidth: false,
|
|
alwaysShowTimestamps: false,
|
|
userTimezone: undefined,
|
|
showTwelveHourTimestamps: false,
|
|
readMarkerInViewThresholdMs: 3000,
|
|
readMarkerOutOfViewThresholdMs: 30000,
|
|
showHiddenEvents: false,
|
|
showReadReceipts: true,
|
|
showRedactions: true,
|
|
showJoinLeaves: true,
|
|
showAvatarChanges: true,
|
|
showDisplaynameChanges: true,
|
|
showUrlPreview: false,
|
|
matrixClientIsReady: false,
|
|
timelineRenderingType: TimelineRenderingType.Room,
|
|
mainSplitContentType: MainSplitContentType.Timeline,
|
|
liveTimeline: undefined,
|
|
canSelfRedact: false,
|
|
resizing: false,
|
|
narrow: false,
|
|
msc3946ProcessDynamicPredecessor: false,
|
|
canAskToJoin: false,
|
|
promptAskToJoin: false,
|
|
viewRoomOpts: { buttons: [] },
|
|
isRoomEncrypted: false,
|
|
...override,
|
|
};
|
|
}
|
|
|
|
export const setupRoomWithEventsTimeline = (room: Room, events: MatrixEvent[] = []): void => {
|
|
const timelineSet = room.getUnfilteredTimelineSet();
|
|
const getTimelineForEventSpy = jest.spyOn(timelineSet, "getTimelineForEvent");
|
|
const eventTimeline = {
|
|
getEvents: jest.fn().mockReturnValue(events),
|
|
} as unknown as EventTimeline;
|
|
getTimelineForEventSpy.mockReturnValue(eventTimeline);
|
|
};
|