Renderizar Componente em Widget

Por favor, como eu faria para inserir um Componente em um widget específico. O que me interessa é colocar o componente TopicNotificationsButton no widget “post-body”.

Agradeceria imensamente a ajuda.

2 curtidas

Temos um shim que pode fazer isso… em um tema, você gostaria de adicionar um arquivo como este dentro do diretório 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 curtidas