Enable read receipts action and sync read receipts from cache

This commit is contained in:
Nicolas Werner 2019-09-18 23:37:30 +02:00
parent 240b3a566b
commit d34067a257
5 changed files with 39 additions and 4 deletions

View File

@ -180,6 +180,7 @@ Rectangle {
MenuItem { MenuItem {
text: "Read receipts" text: "Read receipts"
onTriggered: chat.model.readReceiptsAction(model.id)
} }
MenuItem { MenuItem {
text: "Mark as read" text: "Mark as read"

View File

@ -7,6 +7,7 @@
#include "ChatPage.h" #include "ChatPage.h"
#include "Logging.h" #include "Logging.h"
#include "MainWindow.h"
#include "Olm.h" #include "Olm.h"
#include "Utils.h" #include "Utils.h"
#include "dialogs/RawMessage.h" #include "dialogs/RawMessage.h"
@ -376,6 +377,8 @@ TimelineModel::data(const QModelIndex &index, int role) const
return qml_mtx_events::Failed; return qml_mtx_events::Failed;
else if (pending.contains(id)) else if (pending.contains(id))
return qml_mtx_events::Sent; return qml_mtx_events::Sent;
else if (read.contains(id))
return qml_mtx_events::Read;
else else
return qml_mtx_events::Received; return qml_mtx_events::Received;
default: default:
@ -664,7 +667,13 @@ TimelineModel::replyAction(QString id)
if (related.quoted_body.isEmpty()) if (related.quoted_body.isEmpty())
return; return;
emit ChatPage::instance()->messageReply(related); ChatPage::instance()->messageReply(related);
}
void
TimelineModel::readReceiptsAction(QString id) const
{
MainWindow::instance()->openReadReceiptsDialog(id);
} }
int int
@ -685,3 +694,17 @@ TimelineModel::indexToId(int index) const
return ""; return "";
return eventOrder[index]; return eventOrder[index];
} }
void
TimelineModel::markEventsAsRead(const std::vector<QString> &event_ids)
{
for (const auto &id : event_ids) {
read.insert(id);
int idx = idToIndex(id);
if (idx < 0) {
nhlog::ui()->warn("Read index out of range");
return;
}
emit dataChanged(index(idx, 0), index(idx, 0));
}
}

View File

@ -131,6 +131,7 @@ public:
Q_INVOKABLE QString escapeEmoji(QString str) const; Q_INVOKABLE QString escapeEmoji(QString str) const;
Q_INVOKABLE void viewRawMessage(QString id) const; Q_INVOKABLE void viewRawMessage(QString id) const;
Q_INVOKABLE void replyAction(QString id); Q_INVOKABLE void replyAction(QString id);
Q_INVOKABLE void readReceiptsAction(QString id) const;
Q_INVOKABLE int idToIndex(QString id) const; Q_INVOKABLE int idToIndex(QString id) const;
Q_INVOKABLE QString indexToId(int index) const; Q_INVOKABLE QString indexToId(int index) const;
@ -146,10 +147,10 @@ public slots:
emit currentIndexChanged(index); emit currentIndexChanged(index);
} }
int currentIndex() const { return idToIndex(currentId); } int currentIndex() const { return idToIndex(currentId); }
void markEventsAsRead(const std::vector<QString> &event_ids);
private slots: private slots:
// Add old events at the top of the timeline. // Add old events at the top of the timeline.
void addBackwardsEvents(const mtx::responses::Messages &msgs); void addBackwardsEvents(const mtx::responses::Messages &msgs);
signals: signals:
@ -165,7 +166,7 @@ private:
const std::vector<mtx::events::collections::TimelineEvents> &timeline); const std::vector<mtx::events::collections::TimelineEvents> &timeline);
QHash<QString, mtx::events::collections::TimelineEvents> events; QHash<QString, mtx::events::collections::TimelineEvents> events;
QSet<QString> pending, failed; QSet<QString> pending, failed, read;
std::vector<QString> eventOrder; std::vector<QString> eventOrder;
QString room_id_; QString room_id_;

View File

@ -52,6 +52,16 @@ TimelineViewManager::setHistoryView(const QString &room_id)
} }
} }
void
TimelineViewManager::updateReadReceipts(const QString &room_id,
const std::vector<QString> &event_ids)
{
auto room = models.find(room_id);
if (room != models.end()) {
room.value()->markEventsAsRead(event_ids);
}
}
void void
TimelineViewManager::initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs) TimelineViewManager::initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs)
{ {

View File

@ -40,7 +40,7 @@ signals:
void activeTimelineChanged(TimelineModel *timeline); void activeTimelineChanged(TimelineModel *timeline);
public slots: public slots:
void updateReadReceipts(const QString &room_id, const std::vector<QString> &event_ids) {} void updateReadReceipts(const QString &room_id, const std::vector<QString> &event_ids);
void removeTimelineEvent(const QString &room_id, const QString &event_id) {} void removeTimelineEvent(const QString &room_id, const QString &event_id) {}
void initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs); void initWithMessages(const std::map<QString, mtx::responses::Timeline> &msgs);