FEATURE: Sync unread state live to topic lists (#7933)

This commit is contained in:
David Taylor 2019-07-29 10:28:42 +01:00 committed by GitHub
parent 933d279811
commit d4acd35466
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 38 additions and 7 deletions

View File

@ -22,6 +22,11 @@ const DiscoveryTopicsListComponent = Ember.Component.extend(
} }
}, },
@observes("topicTrackingState.states")
_updateTopics() {
this.topicTrackingState.updateTopics(this.model.topics);
},
@observes("incomingCount") @observes("incomingCount")
_updateTitle() { _updateTitle() {
Discourse.updateContextCount(this.incomingCount); Discourse.updateContextCount(this.incomingCount);

View File

@ -69,15 +69,12 @@ const TopicTrackingState = Discourse.Model.extend({
if (["new_topic", "unread", "read"].includes(data.message_type)) { if (["new_topic", "unread", "read"].includes(data.message_type)) {
tracker.notify(data); tracker.notify(data);
const old = tracker.states["t" + data.topic_id]; const old = tracker.states["t" + data.topic_id];
// don't add tracking state for read stuff that was not tracked in first place
if (old || data.message_type !== "read") {
if (!_.isEqual(old, data.payload)) { if (!_.isEqual(old, data.payload)) {
tracker.states["t" + data.topic_id] = data.payload; tracker.states["t" + data.topic_id] = data.payload;
tracker.notifyPropertyChange("states");
tracker.incrementMessageCount(); tracker.incrementMessageCount();
} }
} }
}
}; };
this.messageBus.subscribe("/new", process); this.messageBus.subscribe("/new", process);

View File

@ -76,3 +76,32 @@ QUnit.test("Clearing state after leaving a category", async assert => {
"it doesn't expand all pinned in the latest category" "it doesn't expand all pinned in the latest category"
); );
}); });
QUnit.test("Live update unread state", async assert => {
await visit("/");
assert.ok(
exists(".topic-list-item:not(.visited) a[data-topic-id='11995']"),
"shows the topic unread"
);
// Mimic a messagebus message
window.MessageBus.callbacks.filterBy("channel", "/latest").map(c =>
c.func({
message_type: "read",
topic_id: 11995,
payload: {
highest_post_number: 1,
last_read_post_number: 2,
notification_level: 1,
topic_id: 11995
}
})
);
await visit("/"); // We're already there, but use this to wait for re-render
assert.ok(
exists(".topic-list-item.visited a[data-topic-id='11995']"),
"shows the topic read"
);
});