Olá, estou usando a versão 3.2.0.beta4-dev para desenvolvimento local e a versão 0.8.7 da API de plugins para desenvolvimento de plugins. No entanto, devido a mudanças recentes no Discourse, as funções addPostMenuButton e component:topic-list foram modificadas.
Como posso usar api.registerValueTransformer para essas funções da API? Além disso, qual versão da API de plugin devo usar para corresponder à 3.2.0.beta4-dev para garantir compatibilidade com api.registerValueTransformer?
Aqui está meu código para addPostMenuButton:
api.addPostMenuButton("togglePostButton", (model) => {
const siteSettings = api.container.lookup("site-settings:main");
const posts = siteSettings.posts;
const array_of_posts = posts.split("|");
const postId = model.id;
const postIdstr = postId.toString();
const isPost = array_of_posts.includes(postIdstr);
return {
action: "togglePost",
position: "first",
className: isPost
? "button.topic_hidden custom-class-hidden"
: "button.topic_visible custom-class-visible",
icon: isPost ? "far-eye-slash" : "far-eye",
title: isPost ? "Hide Post" : "Show Post",
};
});
E aqui está meu código para component:topic-list:
api.modifyClass("component:topic-list", {
pluginId: "post-toggle",
didInsertElement: function () {
this._super();
const topics = this.topics;
for (let key in topics) {
if (topics.hasOwnProperty(key)) {
let newTopicLatest = [];
const topic_id = topics[key].id;
const topic_posters = topics[key].posters;
topic_posters.forEach((poster) => {
if (poster && poster.extras !== null && poster.extras.includes("latest")) {
newTopicLatest = poster["description"].split(",");
}
});
let userListLatest = newTopicLatest;
if (userListLatest.length > 1 && userListLatest[0] === "Original Poster") {
userListLatest = userListLatest.slice(1);
userListLatest[0] = userListLatest[0].trim();
}
let i = 0;
const element = $('tr[data-topic-id="' + topic_id + '"]').find(
"a[data-user-card]"
);
if (element.length > 0) {
element.each(function () {
const poster_inside = topic_posters[i];
if (poster_inside !== undefined && Object.keys(poster_inside).length !== 0) {
const userElement = $(this);
if (!userListLatest.includes(poster_inside.user.id.toString())) {
userElement.hide();
}
}
i++;
});
}
}
}
}
});