mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 18:22:45 +08:00
d1cc60c435
Changes made using the ember-native-class-codemod, plus some manual tweaks
119 lines
3.5 KiB
JavaScript
119 lines
3.5 KiB
JavaScript
import Component from "@ember/component";
|
|
import { action, computed } from "@ember/object";
|
|
import { isEmpty } from "@ember/utils";
|
|
import { classNameBindings, classNames } from "@ember-decorators/component";
|
|
import { NotificationLevels } from "discourse/lib/notification-levels";
|
|
import getURL from "discourse-common/lib/get-url";
|
|
import discourseComputed from "discourse-common/utils/decorators";
|
|
import I18n from "discourse-i18n";
|
|
|
|
@classNames("topic-notifications-button")
|
|
@classNameBindings("isLoading")
|
|
export default class TopicNotificationsButton extends Component {
|
|
appendReason = true;
|
|
showFullTitle = true;
|
|
notificationLevel = null;
|
|
topic = null;
|
|
showCaret = true;
|
|
isLoading = false;
|
|
|
|
@computed("isLoading")
|
|
get icon() {
|
|
return this.isLoading ? "spinner" : null;
|
|
}
|
|
|
|
@action
|
|
changeTopicNotificationLevel(levelId) {
|
|
if (levelId !== this.notificationLevel) {
|
|
this.set("isLoading", true);
|
|
this.topic.details
|
|
.updateNotifications(levelId)
|
|
.finally(() => this.set("isLoading", false));
|
|
}
|
|
}
|
|
|
|
@discourseComputed(
|
|
"topic",
|
|
"topic.details.{notification_level,notifications_reason_id}"
|
|
)
|
|
notificationReasonText(topic, topicDetails) {
|
|
let level = topicDetails.notification_level;
|
|
let reason = topicDetails.notifications_reason_id;
|
|
|
|
if (typeof level !== "number") {
|
|
level = 1;
|
|
}
|
|
|
|
let localeString = `topic.notifications.reasons.${level}`;
|
|
if (typeof reason === "number") {
|
|
let localeStringWithReason = localeString + "_" + reason;
|
|
|
|
if (
|
|
this._notificationReasonStale(level, reason, topic, this.currentUser)
|
|
) {
|
|
localeStringWithReason += "_stale";
|
|
}
|
|
|
|
// some sane protection for missing translations of edge cases
|
|
if (I18n.lookup(localeStringWithReason, { locale: "en" })) {
|
|
localeString = localeStringWithReason;
|
|
}
|
|
}
|
|
|
|
if (
|
|
this.currentUser &&
|
|
this.currentUser.user_option.mailing_list_mode &&
|
|
level > NotificationLevels.MUTED
|
|
) {
|
|
return I18n.t("topic.notifications.reasons.mailing_list_mode");
|
|
} else {
|
|
return I18n.t(localeString, {
|
|
username: this.currentUser && this.currentUser.username_lower,
|
|
basePath: getURL(""),
|
|
});
|
|
}
|
|
}
|
|
|
|
// The user may have changed their category or tag tracking settings
|
|
// since this topic was tracked/watched based on those settings in the
|
|
// past. In that case we need to alter the reason message we show them
|
|
// otherwise it is very confusing for the end user to be told they are
|
|
// tracking a topic because of a category, when they are no longer tracking
|
|
// that category.
|
|
_notificationReasonStale(level, reason, topic, currentUser) {
|
|
if (!currentUser) {
|
|
return;
|
|
}
|
|
|
|
let categoryId = topic.category_id;
|
|
let tags = topic.tags;
|
|
let watchedCategoryIds = currentUser.watched_category_ids || [];
|
|
let trackedCategoryIds = currentUser.tracked_category_ids || [];
|
|
let watchedTags = currentUser.watched_tags || [];
|
|
|
|
// 2_8 tracking category
|
|
if (categoryId) {
|
|
if (level === 2 && reason === 8) {
|
|
if (!trackedCategoryIds.includes(categoryId)) {
|
|
return true;
|
|
}
|
|
|
|
// 3_6 watching category
|
|
} else if (level === 3 && reason === 6) {
|
|
if (!watchedCategoryIds.includes(categoryId)) {
|
|
return true;
|
|
}
|
|
}
|
|
} else if (!isEmpty(tags)) {
|
|
// 3_10 watching tag
|
|
if (level === 3 && reason === 10) {
|
|
if (!tags.some((tag) => watchedTags.includes(tag))) {
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
}
|