Renderizar Componente en Widget

Por favor, ¿cómo podría insertar un Componente en un widget en particular? Me interesa colocar el componente TopicNotificationsButton en el widget “post-body”.

Agradecería enormemente la ayuda.

2 Me gusta

Tenemos un shim que puede hacer esto… en un tema, querrás agregar un archivo como este dentro del directorio 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 Me gusta