ウィジェットでのコンポーネントのレンダリング

特定のウィジェットにコンポーネントを挿入するにはどうすればよいですか?「post-body」ウィジェットにTopicNotificationsButtonコンポーネントを配置することに興味があります。

ご協力いただけると大変助かります。

「いいね!」 2

テーマ内に 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