Skip to content

Commit

Permalink
Use relations to load existing reactions when joining the call
Browse files Browse the repository at this point in the history
Signed-off-by: Milton Moura <miltonmoura@gmail.com>
  • Loading branch information
mgcm committed Sep 10, 2024
1 parent eef6015 commit 5742355
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 0 deletions.
35 changes: 35 additions & 0 deletions src/room/InCallView.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -316,6 +316,41 @@ export const InCallView: FC<InCallViewProps> = ({
const userId = `${username}:${localpart}`;
const isHandRaised = raisedHands.includes(userId);

useEffect(() => {
const getLastReactionEvent = async (
eventId: string,
): Promise<MatrixEvent | undefined> => {
const rels = await client.relations(
rtcSession.room.roomId,
eventId,
RelationType.Annotation,
EventType.Reaction,
{
limit: 1,
},
);

return rels.events.length > 0 ? rels.events[0] : undefined;
};

const fetchReactions = async (): Promise<void> => {
const newRaisedHands = [...raisedHands];
for (const m of memberships) {
const reaction = await getLastReactionEvent(m.eventId!);
if (reaction && reaction.getType() === EventType.Reaction) {
const content = reaction.getContent() as ReactionEventContent;
if (content?.["m.relates_to"].key === "🖐️") {
newRaisedHands.push(m.sender!);
}
}
}
setRaisedHands(newRaisedHands);
};

fetchReactions();
// eslint-disable-next-line react-hooks/exhaustive-deps
}, []);

useEffect(() => {
const handleReactionEvent = (event: MatrixEvent): void => {
if (event.getType() === EventType.Reaction) {
Expand Down
2 changes: 2 additions & 0 deletions src/widget.ts
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,8 @@ export const widget = ((): WidgetHelpers | null => {
const sendRecvEvent = [
"org.matrix.rageshake_request",
EventType.CallEncryptionKeysPrefix,
EventType.Reaction,
EventType.RoomRedaction,
];

const sendState = [
Expand Down

0 comments on commit 5742355

Please sign in to comment.