discourse-user-notes/assets/javascripts/discourse/initializers/enable-user-notes.js.es6

110 lines
3.0 KiB
JavaScript

import { withPluginApi } from "discourse/lib/plugin-api";
import { iconNode } from "discourse-common/lib/icon-library";
import { showUserNotes } from "discourse/plugins/discourse-user-notes/discourse-user-notes/lib/user-notes";
export default {
name: "enable-user-notes",
initialize(container) {
const siteSettings = container.lookup("site-settings:main");
const currentUser = container.lookup("current-user:main");
if (
!siteSettings.user_notes_enabled ||
!currentUser ||
!currentUser.staff
) {
return;
}
const store = container.lookup("store:main");
withPluginApi("0.8.15", api => {
function widgetshowUserNotes() {
showUserNotes(
store,
this.attrs.user_id,
count => {
this.sendWidgetAction("refreshUserNotes", count);
},
{
postId: this.attrs.id
}
);
}
api.attachWidgetAction("post", "refreshUserNotes", function(count) {
const cfs = this.model.get("user_custom_fields") || {};
cfs.user_notes_count = count;
this.model.set("user_custom_fields", cfs);
});
api.modifyClass("controller:user", {
userNotesCount: null,
_modelChanged: function() {
this.set(
"userNotesCount",
this.get("model.custom_fields.user_notes_count") || 0
);
}
.observes("model")
.on("init"),
actions: {
showUserNotes() {
const user = this.get("model");
showUserNotes(store, user.get("id"), count =>
this.set("userNotesCount", count)
);
}
}
});
const mobileView = api.container.lookup("site:main").mobileView;
const loc = mobileView ? "before" : "after";
api.decorateWidget(`poster-name:${loc}`, dec => {
if (dec.widget.settings.hideNotes) {
return;
}
const cfs = dec.attrs.userCustomFields || {};
if (cfs.user_notes_count > 0) {
return dec.attach("user-notes-icon");
}
});
api.decorateWidget(`post-avatar:after`, dec => {
if (!dec.widget.settings.showNotes) {
return;
}
const cfs = dec.attrs.userCustomFields || {};
if (cfs.user_notes_count > 0) {
return dec.attach("user-notes-icon");
}
});
api.decorateWidget("post-admin-menu:after", dec => {
return dec.attach("post-admin-menu-button", {
icon: "pencil",
label: "user_notes.attach",
action: "showUserNotes"
});
});
api.attachWidgetAction("post", "showUserNotes", widgetshowUserNotes);
api.createWidget("user-notes-icon", {
tagName: "span.user-notes-icon",
click: widgetshowUserNotes,
html() {
if (siteSettings.enable_emoji) {
return this.attach("emoji", { name: "pencil" });
} else {
return iconNode("sticky-note");
}
}
});
});
}
};