aboutsummaryrefslogtreecommitdiff
path: root/lib/room.cpp
diff options
context:
space:
mode:
authorKitsune Ral <Kitsune-Ral@users.sf.net>2018-09-12 23:10:20 +0900
committerGitHub <noreply@github.com>2018-09-12 23:10:20 +0900
commitb5b0d8438bdf3cb8b37f311e8047ef6883f858c2 (patch)
tree633a6e8fe8a244b44b510b608ec3103431a0e042 /lib/room.cpp
parent2a1596c16baad77fc80391c66694101f91028deb (diff)
parent1e78ca6b9c09cb16677ab3db1656085adbd4901b (diff)
downloadlibquotient-b5b0d8438bdf3cb8b37f311e8047ef6883f858c2.tar.gz
libquotient-b5b0d8438bdf3cb8b37f311e8047ef6883f858c2.zip
Merge pull request #239 from encombhat/master
Add readUser for RoomEvent
Diffstat (limited to 'lib/room.cpp')
-rw-r--r--lib/room.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/room.cpp b/lib/room.cpp
index 18b06b7d..869a81c8 100644
--- a/lib/room.cpp
+++ b/lib/room.cpp
@@ -103,6 +103,7 @@ class Room::Private
int notificationCount = 0;
members_map_t membersMap;
QList<User*> usersTyping;
+ QMultiHash<QString, User*> eventIdReadUsers;
QList<User*> membersLeft;
int unreadMessages = 0;
bool displayed = false;
@@ -375,8 +376,11 @@ void Room::Private::setLastReadEvent(User* u, QString eventId)
auto& storedId = lastReadEventIds[u];
if (storedId == eventId)
return;
+ eventIdReadUsers.remove(storedId, u);
+ eventIdReadUsers.insert(eventId, u);
swap(storedId, eventId);
emit q->lastReadEventChanged(u);
+ emit q->readMarkerForUserMoved(u, eventId, storedId);
if (isLocalUser(u))
{
if (storedId != serverReadMarker)
@@ -635,6 +639,10 @@ QString Room::readMarkerEventId() const
return d->lastReadEventIds.value(localUser());
}
+QList<User*> Room::usersAtEventId(const QString& eventId) {
+ return d->eventIdReadUsers.values(eventId);
+}
+
int Room::notificationCount() const
{
return d->notificationCount;