FIX: watched topic overcome muted category (#18480)
Previously, when categories were not muted by default, we were sending message about unmuted topics (topics which user explicitly set notification level to watching) The same mechanism can be used to fix a bug. When the user was explicitly watching topic, but category was muted, then the user was not informed about new reply.
This commit is contained in:
parent
89ac01704e
commit
d5f6262c4f
|
@ -866,7 +866,8 @@ const TopicTrackingState = EmberObject.extend({
|
||||||
|
|
||||||
if (
|
if (
|
||||||
mutedCategoryIds &&
|
mutedCategoryIds &&
|
||||||
mutedCategoryIds.includes(data.payload.category_id)
|
mutedCategoryIds.includes(data.payload.category_id) &&
|
||||||
|
!this.isUnmutedTopic(data.topic_id)
|
||||||
) {
|
) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -760,6 +760,33 @@ discourseModule("Unit | Model | topic-tracking-state", function (hooks) {
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test("watched topics in muted categories are added to the state", async function (assert) {
|
||||||
|
trackingState.currentUser.setProperties({
|
||||||
|
muted_category_ids: [123],
|
||||||
|
});
|
||||||
|
|
||||||
|
trackingState.trackMutedOrUnmutedTopic({
|
||||||
|
topic_id: 222,
|
||||||
|
message_type: "unmuted",
|
||||||
|
});
|
||||||
|
|
||||||
|
await publishToMessageBus("/new", newTopicPayload);
|
||||||
|
|
||||||
|
assert.deepEqual(
|
||||||
|
trackingState.findState(222),
|
||||||
|
{
|
||||||
|
category_id: 123,
|
||||||
|
topic_tag_ids: [44],
|
||||||
|
tags: ["pending"],
|
||||||
|
last_read_post_number: null,
|
||||||
|
highest_post_number: 1,
|
||||||
|
created_at: "2012-11-31 12:00:00 UTC",
|
||||||
|
archetype: "regular",
|
||||||
|
},
|
||||||
|
"topic state updated"
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
test("topics in muted tags do not get added to the state", async function (assert) {
|
test("topics in muted tags do not get added to the state", async function (assert) {
|
||||||
trackingState.currentUser.set("muted_tags", ["pending"]);
|
trackingState.currentUser.set("muted_tags", ["pending"]);
|
||||||
|
|
||||||
|
|
|
@ -69,7 +69,7 @@ module Jobs
|
||||||
end
|
end
|
||||||
|
|
||||||
if SiteSetting.mute_all_categories_by_default
|
if SiteSetting.mute_all_categories_by_default
|
||||||
users = users.watching_topic_when_mute_categories_by_default(post.topic)
|
users = users.watching_topic(post.topic)
|
||||||
end
|
end
|
||||||
|
|
||||||
DiscourseEvent.trigger(:notify_mailing_list_subscribers, users, post)
|
DiscourseEvent.trigger(:notify_mailing_list_subscribers, users, post)
|
||||||
|
|
|
@ -118,8 +118,7 @@ class TopicTrackingState
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.publish_unmuted(topic)
|
def self.publish_unmuted(topic)
|
||||||
return if !SiteSetting.mute_all_categories_by_default
|
user_ids = User.watching_topic(topic)
|
||||||
user_ids = User.watching_topic_when_mute_categories_by_default(topic)
|
|
||||||
.where("users.last_seen_at > ?", 7.days.ago)
|
.where("users.last_seen_at > ?", 7.days.ago)
|
||||||
.order("users.last_seen_at DESC")
|
.order("users.last_seen_at DESC")
|
||||||
.limit(100)
|
.limit(100)
|
||||||
|
|
|
@ -265,7 +265,7 @@ class User < ActiveRecord::Base
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
scope :watching_topic_when_mute_categories_by_default, ->(topic) do
|
scope :watching_topic, ->(topic) do
|
||||||
joins(DB.sql_fragment("LEFT JOIN category_users ON category_users.user_id = users.id AND category_users.category_id = :category_id", category_id: topic.category_id))
|
joins(DB.sql_fragment("LEFT JOIN category_users ON category_users.user_id = users.id AND category_users.category_id = :category_id", category_id: topic.category_id))
|
||||||
.joins(DB.sql_fragment("LEFT JOIN topic_users ON topic_users.user_id = users.id AND topic_users.topic_id = :topic_id", topic_id: topic.id))
|
.joins(DB.sql_fragment("LEFT JOIN topic_users ON topic_users.user_id = users.id AND topic_users.topic_id = :topic_id", topic_id: topic.id))
|
||||||
.joins("LEFT JOIN tag_users ON tag_users.user_id = users.id AND tag_users.tag_id IN (#{topic.tag_ids.join(",").presence || 'NULL'})")
|
.joins("LEFT JOIN tag_users ON tag_users.user_id = users.id AND tag_users.tag_id IN (#{topic.tag_ids.join(",").presence || 'NULL'})")
|
||||||
|
|
Loading…
Reference in New Issue