discourse/app/assets/javascripts/select-kit/addon/components/topic-notifications-button.js

29 lines
788 B
JavaScript

import { action, computed } from "@ember/object";
import Component from "@ember/component";
import layout from "select-kit/templates/components/topic-notifications-button";
export default Component.extend({
layout,
classNames: ["topic-notifications-button"],
classNameBindings: ["isLoading"],
appendReason: true,
showFullTitle: true,
notificationLevel: null,
topic: null,
showCaret: true,
isLoading: false,
icon: computed("isLoading", function () {
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));
}
},
});