// 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