diff --git a/resources/qml/TopBar.qml b/resources/qml/TopBar.qml index 20eff7f319bb255bd9b178d1d03c0bc55c1c1268..c9d26019c7a4de60b32c0b2db8d8d9efb4fa5c5e 100644 --- a/resources/qml/TopBar.qml +++ b/resources/qml/TopBar.qml @@ -271,7 +271,12 @@ Pane { height: implicitHeight Reply { - property var e: room ? room.getDump(modelData, "") : {} + id: reply + property var e: room ? room.getDump(modelData, "pins") : {} + Connections { + function onPinnedMessagesChanged() { reply.e = room.getDump(modelData, "pins") } + target: room + } Layout.fillWidth: true Layout.preferredHeight: height diff --git a/src/timeline/EventStore.cpp b/src/timeline/EventStore.cpp index 264cde77939e3daedf2917bb5eb830f27fa97a0e..b0ea07ecf046326495fb557c8758df44616c4912 100644 --- a/src/timeline/EventStore.cpp +++ b/src/timeline/EventStore.cpp @@ -48,9 +48,13 @@ EventStore::EventStore(std::string room_id, QObject *) cache::client()->storeEvent(room_id_, id, {timeline}); if (!relatedTo.empty()) { - auto idx = idToIndex(relatedTo); - if (idx) - emit dataChanged(*idx, *idx); + if (relatedTo == "pins") { + emit pinsChanged(); + } else { + auto idx = idToIndex(relatedTo); + if (idx) + emit dataChanged(*idx, *idx); + } } }, Qt::QueuedConnection); diff --git a/src/timeline/EventStore.h b/src/timeline/EventStore.h index 6317cbbe4e9104322ca3d9607292d2b755a3ebc4..5cfab72765dc27407cb058b053fe330230d2734e 100644 --- a/src/timeline/EventStore.h +++ b/src/timeline/EventStore.h @@ -101,6 +101,7 @@ signals: void beginResetModel(); void endResetModel(); void dataChanged(int from, int to); + void pinsChanged(); void newEncryptedImage(mtx::crypto::EncryptedFile encryptionInfo); void eventFetched(std::string id, std::string relatedTo, diff --git a/src/timeline/TimelineModel.cpp b/src/timeline/TimelineModel.cpp index 578d63b7dc38299a0e6f44bf5610167f70bfd2e3..53559644ff07e137b88a684f858d915b161fc8dc 100644 --- a/src/timeline/TimelineModel.cpp +++ b/src/timeline/TimelineModel.cpp @@ -398,6 +398,7 @@ TimelineModel::TimelineModel(TimelineViewManager *manager, QString room_id, QObj "data changed {} to {}", events.size() - to - 1, events.size() - from - 1); emit dataChanged(index(events.size() - to - 1, 0), index(events.size() - from - 1, 0)); }); + connect(&events, &EventStore::pinsChanged, this, &TimelineModel::pinnedMessagesChanged); connect(&events, &EventStore::beginInsertRows, this, [this](int from, int to) { int first = events.size() - to;