FIX: when category or tag is muted, update user (#9456)

Currently, when category or tag is muted, only after hard refresh, these new muted categories are really muted. Without a hard refresh, you will still receive "new topic" messages.

Therefore, when tag or category is muted, we should update the user object right away.
This commit is contained in:
Krzysztof Kotlarek 2020-04-21 08:33:55 +10:00 committed by GitHub
parent 74e4102093
commit e9f7262813
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 41 additions and 2 deletions

View File

@ -155,7 +155,18 @@ export default Controller.extend(BulkTopicSelection, FilterModeMixin, {
}, },
changeTagNotificationLevel(notificationLevel) { changeTagNotificationLevel(notificationLevel) {
this.tagNotification.update({ notification_level: notificationLevel }); this.tagNotification
.update({ notification_level: notificationLevel })
.then(response => {
this.currentUser.set(
"muted_tag_ids",
this.currentUser.calculateMutedIds(
notificationLevel,
response.responseJson.tag_id,
"muted_tag_ids"
)
);
});
} }
} }
}); });

View File

@ -7,6 +7,7 @@ import PermissionType from "discourse/models/permission-type";
import { NotificationLevels } from "discourse/lib/notification-levels"; import { NotificationLevels } from "discourse/lib/notification-levels";
import deprecated from "discourse-common/lib/deprecated"; import deprecated from "discourse-common/lib/deprecated";
import Site from "discourse/models/site"; import Site from "discourse/models/site";
import User from "discourse/models/user";
const Category = RestModel.extend({ const Category = RestModel.extend({
permissions: null, permissions: null,
@ -241,6 +242,16 @@ const Category = RestModel.extend({
setNotification(notification_level) { setNotification(notification_level) {
this.set("notification_level", notification_level); this.set("notification_level", notification_level);
User.currentProp(
"muted_category_ids",
User.current().calculateMutedIds(
notification_level,
this.id,
"muted_category_ids"
)
);
const url = `/category/${this.id}/notifications`; const url = `/category/${this.id}/notifications`;
return ajax(url, { data: { notification_level }, type: "POST" }); return ajax(url, { data: { notification_level }, type: "POST" });
}, },

View File

@ -25,6 +25,7 @@ import Category from "discourse/models/category";
import { Promise } from "rsvp"; import { Promise } from "rsvp";
import deprecated from "discourse-common/lib/deprecated"; import deprecated from "discourse-common/lib/deprecated";
import Site from "discourse/models/site"; import Site from "discourse/models/site";
import { NotificationLevels } from "discourse/lib/notification-levels";
export const SECOND_FACTOR_METHODS = { export const SECOND_FACTOR_METHODS = {
TOTP: 1, TOTP: 1,
@ -859,6 +860,15 @@ const User = RestModel.extend({
changeTimezone(tz) { changeTimezone(tz) {
this._timezone = tz; this._timezone = tz;
},
calculateMutedIds(notificationLevel, id, type) {
const muted_ids = this.get(type);
if (notificationLevel === NotificationLevels.MUTED) {
return muted_ids.concat(id).uniq();
} else {
return muted_ids.filter(existing_id => existing_id !== id);
}
} }
}); });

View File

@ -274,7 +274,7 @@ class TagsController < ::ApplicationController
raise Discourse::NotFound unless tag raise Discourse::NotFound unless tag
level = params[:tag_notification][:notification_level].to_i level = params[:tag_notification][:notification_level].to_i
TagUser.change(current_user.id, tag.id, level) TagUser.change(current_user.id, tag.id, level)
render json: { notification_level: level } render json: { notification_level: level, tag_id: tag.id }
end end
def check_hashtag def check_hashtag

View File

@ -104,3 +104,10 @@ QUnit.test("resolvedTimezone", assert => {
); );
stub.restore(); stub.restore();
}); });
QUnit.test("muted ids", assert => {
let user = User.create({ username: "chuck", muted_category_ids: [] });
assert.deepEqual(user.calculateMutedIds(0, 1, "muted_category_ids"), [1]);
assert.deepEqual(user.calculateMutedIds(1, 1, "muted_category_ids"), []);
});