У меня есть опыт создания кастомных решений на других платформах/фреймворках, и я хочу понять, является ли этот подход правильным для создания компонента темы в Discourse.
Кажется, что это работает, но это не обязательно означает, что это правильный способ.
Если кратко, этот код должен скрывать реакцию в зависимости от категории, в которой находится тема. Правильно ли я это делаю?
<script type="text/discourse-plugin" version="0.1">
$(document).ready(function() {
try {
const isTopicPage = /^\/t\//.test(window.location.pathname);
if (!isTopicPage) return;
const allowedCategories = ['ask-a-question'];
const topic = Discourse.__container__.lookup("controller:topic");
const categorySlug = topic && topic.get("model.category.slug");
const isAllowedCategory = categorySlug && allowedCategories.includes(categorySlug);
const toggleReactionEmoji = () => {
const emoji = document.querySelector("[data-reaction='frog']");
if (emoji) {
emoji.style.display = isAllowedCategory ? '' : 'none';
console.log(`Эмодзи с data-reaction='frog' ${isAllowedCategory ? 'показывается' : 'скрывается'}.`);
}
};
toggleReactionEmoji();
const observer = new MutationObserver(mutations => {
mutations.forEach(mutation => {
mutation.addedNodes.forEach(node => {
if (node.nodeType === 1) {
const emoji = node.querySelector("[data-reaction='frog']");
if (emoji) {
emoji.style.display = isAllowedCategory ? '' : 'none';
console.log(`Эмодзи с data-reaction='frog' найден в мутации и ${isAllowedCategory ? 'показывается' : 'скрывается'}.`);
}
}
});
});
});
observer.observe(document.body, { childList: true, subtree: true });
api.cleanupStream(() => observer.disconnect());
} catch (error) {
console.error("В скрипте переключения эмодзи произошла ошибка:", error);
}
});
</script>