2019-03-27 05:41:50 -04:00
|
|
|
import DropdownSelectBox from "select-kit/components/dropdown-select-box";
|
|
|
|
import { popupAjaxError } from "discourse/lib/ajax-error";
|
2019-03-29 06:14:53 -04:00
|
|
|
import showModal from "discourse/lib/show-modal";
|
2019-11-07 16:38:28 -05:00
|
|
|
import discourseComputed from "discourse-common/utils/decorators";
|
2019-03-27 05:41:50 -04:00
|
|
|
|
|
|
|
export default DropdownSelectBox.extend({
|
|
|
|
classNames: ["user-notifications", "user-notifications-dropdown"],
|
|
|
|
nameProperty: "label",
|
2019-07-31 10:31:02 -04:00
|
|
|
|
2019-03-27 05:41:50 -04:00
|
|
|
computeContent() {
|
|
|
|
const content = [];
|
|
|
|
|
|
|
|
content.push({
|
|
|
|
icon: "user",
|
2019-03-29 06:14:53 -04:00
|
|
|
id: "changeToNormal",
|
|
|
|
description: I18n.t("user.user_notifications.normal_option_title"),
|
|
|
|
label: I18n.t("user.user_notifications.normal_option")
|
2019-03-27 05:41:50 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
content.push({
|
|
|
|
icon: "times-circle",
|
2019-03-29 06:14:53 -04:00
|
|
|
id: "changeToMuted",
|
|
|
|
description: I18n.t("user.user_notifications.mute_option_title"),
|
|
|
|
label: I18n.t("user.user_notifications.mute_option")
|
2019-03-27 05:41:50 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
if (this.get("user.can_ignore_user")) {
|
|
|
|
content.push({
|
|
|
|
icon: "eye-slash",
|
2019-03-29 06:14:53 -04:00
|
|
|
id: "changeToIgnored",
|
|
|
|
description: I18n.t("user.user_notifications.ignore_option_title"),
|
|
|
|
label: I18n.t("user.user_notifications.ignore_option")
|
2019-03-27 05:41:50 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return content;
|
|
|
|
},
|
|
|
|
|
2019-11-07 16:38:28 -05:00
|
|
|
@discourseComputed("value")
|
2019-07-31 10:31:02 -04:00
|
|
|
headerIcon(value) {
|
|
|
|
return this.computeContent().find(row => row.id === value).icon;
|
|
|
|
},
|
|
|
|
|
2019-03-29 06:14:53 -04:00
|
|
|
changeToNormal() {
|
2019-07-31 10:31:02 -04:00
|
|
|
this.updateNotificationLevel("normal").catch(popupAjaxError);
|
2019-03-29 06:14:53 -04:00
|
|
|
},
|
|
|
|
changeToMuted() {
|
2019-07-31 10:31:02 -04:00
|
|
|
this.updateNotificationLevel("mute").catch(popupAjaxError);
|
2019-03-29 06:14:53 -04:00
|
|
|
},
|
|
|
|
changeToIgnored() {
|
2019-07-31 10:31:02 -04:00
|
|
|
showModal("ignore-duration", {
|
2019-05-27 04:15:39 -04:00
|
|
|
model: this.user
|
2019-03-29 06:14:53 -04:00
|
|
|
});
|
2019-07-31 10:31:02 -04:00
|
|
|
},
|
|
|
|
|
2019-11-07 16:38:28 -05:00
|
|
|
@discourseComputed("user.ignored", "user.muted")
|
2019-07-31 10:31:02 -04:00
|
|
|
value() {
|
|
|
|
if (this.get("user.ignored")) {
|
|
|
|
return "changeToIgnored";
|
|
|
|
} else if (this.get("user.muted")) {
|
|
|
|
return "changeToMuted";
|
|
|
|
} else {
|
|
|
|
return "changeToNormal";
|
|
|
|
}
|
2019-03-29 06:14:53 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
_select(id) {
|
|
|
|
this.select(
|
|
|
|
this.collectionComputedContent.find(c => c.originalContent.id === id)
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
2019-03-27 05:41:50 -04:00
|
|
|
actions: {
|
2019-03-29 06:14:53 -04:00
|
|
|
onSelect(level) {
|
|
|
|
this[level]();
|
2019-03-27 05:41:50 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|