mirror of
https://github.com/vector-im/element-web.git
synced 2024-12-01 07:01:01 +08:00
be281fd735
* Use RelationType enum instead of hardcoded value * Fix threads replies fallback to target last reply * Only unsubscribe from threads events if needed * fix strict null check * fix strict null checks * strict null checks * fix typing * Unsubscribe listeners if new thread is `null` Co-authored-by: Faye Duxovni <fayed@element.io> * Update strict null checks * Type HTMLElement as nullable * Add thread fallback integration test * lint fix * Update snapshots * Add test after changing thread * Remove test comment * update snapshot * fix room context test utility * Add ThreadListContextMenu test * lint fix * fix thread rendering Co-authored-by: Faye Duxovni <fayed@element.io> Co-authored-by: Michael Telatynski <7t3chguy@gmail.com>
98 lines
2.9 KiB
TypeScript
98 lines
2.9 KiB
TypeScript
/*
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
import { MockedObject } from "jest-mock";
|
|
import {
|
|
MatrixClient,
|
|
MatrixEvent,
|
|
EventType,
|
|
Room,
|
|
} from "matrix-js-sdk/src/matrix";
|
|
|
|
import { IRoomState } from "../../src/components/structures/RoomView";
|
|
import { TimelineRenderingType } from "../../src/contexts/RoomContext";
|
|
import { Layout } from "../../src/settings/enums/Layout";
|
|
import { mkEvent } from "./test-utils";
|
|
|
|
export const makeMembershipEvent = (
|
|
roomId: string, userId: string, membership = '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<IRoomState>): IRoomState {
|
|
return {
|
|
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,
|
|
showTwelveHourTimestamps: false,
|
|
readMarkerInViewThresholdMs: 3000,
|
|
readMarkerOutOfViewThresholdMs: 30000,
|
|
showHiddenEvents: false,
|
|
showReadReceipts: true,
|
|
showRedactions: true,
|
|
showJoinLeaves: true,
|
|
showAvatarChanges: true,
|
|
showDisplaynameChanges: true,
|
|
matrixClientIsReady: false,
|
|
timelineRenderingType: TimelineRenderingType.Room,
|
|
liveTimeline: undefined,
|
|
canSelfRedact: false,
|
|
resizing: false,
|
|
narrow: false,
|
|
activeCall: null,
|
|
|
|
...override,
|
|
};
|
|
}
|