在 Widget 中渲染组件

请问,我该如何在特定的小部件中插入组件?我想将 TopicNotificationsButton 组件放置在“post-body”小部件中。

非常感谢您的帮助。

2 个赞

我们有一个可以做到这一点的 shim……在一个主题中,您需要将文件添加到 javascripts/discourse/api-initializers 目录中……

import { withPluginApi } from "discourse/lib/plugin-api";
import { registerWidgetShim } from "discourse/widgets/render-glimmer";
import { hbs } from "ember-cli-htmlbars";

export default {
  name: "unique-customization-name",

  initialize() {
    withPluginApi("0.1", (api) => {
      api.decorateWidget(`post-body:after`, (decorate) => {
        const attrs = decorate.attrs;
        return decorate.widget.attach("custom-widget-name", { attrs });
      });

      registerWidgetShim(
        "custom-widget-name",
        "div.custom-widget-name",
        hbs`<ComponentName @postAttrs={{@data.attrs}} />`
      );
    });
  },
};
2 个赞