// gomuks - A Matrix client written in Go. // Copyright (C) 2024 Tulir Asokan // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU Affero General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU Affero General Public License for more details. // // You should have received a copy of the GNU Affero General Public License // along with this program. If not, see . import { use } from "react" import { getAvatarThumbnailURL } from "@/api/media.ts" import { RoomStateStore, useMultipleRoomMembers, useReadReceipts } from "@/api/statestore" import { EventID } from "@/api/types" import { humanJoin } from "@/util/join.ts" import { getDisplayname } from "@/util/validation.ts" import ClientContext from "../ClientContext.ts" import "./ReadReceipts.css" const ReadReceipts = ({ room, eventID }: { room: RoomStateStore, eventID: EventID }) => { const client = use(ClientContext)! const receipts = useReadReceipts(room, eventID) const memberEvts = useMultipleRoomMembers(client, room, receipts.map(receipt => receipt.user_id)) if (receipts.length === 0) { return null } // Hacky hack for mobile clients. Would be nicer to get the number based on the CSS variable defining the size const maxAvatarCount = window.innerWidth > 720 ? 4 : 2 const avatarMembers = receipts.length > maxAvatarCount ? memberEvts.slice(-maxAvatarCount+1) : memberEvts const avatars = avatarMembers.map(([userID, member]) => { return }) const names = memberEvts.map(([userID, member]) => getDisplayname(userID, member)) return
{avatars.length < receipts.length &&
+{receipts.length - avatars.length}
}
{avatars}
} export default ReadReceipts