From 0948d6b19e34320f95226cc43fbce976b71ceb31 Mon Sep 17 00:00:00 2001 From: David Taylor Date: Tue, 7 Nov 2023 17:39:27 +0000 Subject: [PATCH] DEV: Refactor initializer to use RenderGlimmer and registerWidgetShim --- .../initializers/initialize-ad-plugin.js | 42 +++++++------------ 1 file changed, 16 insertions(+), 26 deletions(-) diff --git a/assets/javascripts/discourse/initializers/initialize-ad-plugin.js b/assets/javascripts/discourse/initializers/initialize-ad-plugin.js index f0ac5991..e9d18c9c 100644 --- a/assets/javascripts/discourse/initializers/initialize-ad-plugin.js +++ b/assets/javascripts/discourse/initializers/initialize-ad-plugin.js @@ -1,40 +1,30 @@ +import { hbs } from "ember-cli-htmlbars"; import { withPluginApi } from "discourse/lib/plugin-api"; import Site from "discourse/models/site"; +import { registerWidgetShim } from "discourse/widgets/render-glimmer"; export default { name: "initialize-ad-plugin", initialize(container) { + registerWidgetShim( + "after-post-ad", + "div.widget-connector", + hbs`` + ); + withPluginApi("0.1", (api) => { - api.decorateWidget("post:after", (dec) => { - if (dec.canConnectComponent) { - if (!dec.attrs.cloaked) { - return dec.connect({ - component: "post-bottom-ad", - context: "model", - }); - } - } else { - // Old way for backwards compatibility - return dec.connect({ - templateName: "connectors/post-bottom/discourse-adplugin", - context: "model", - }); - } + api.decorateWidget("post:after", (helper) => { + return helper.attach("after-post-ad", helper.attrs); }); }); - const messageBus = container.lookup("message-bus:main"); - if (!messageBus) { - return; - } - + const messageBus = container.lookup("service:message-bus"); const currentUser = container.lookup("service:current-user"); - let channel; - if (currentUser) { - channel = "/site/house-creatives/logged-in"; - } else { - channel = "/site/house-creatives/anonymous"; - } + + const channel = currentUser + ? "/site/house-creatives/logged-in" + : "/site/house-creatives/anonymous"; + messageBus.subscribe(channel, function (houseAdsSettings) { Site.currentProp("house_creatives", houseAdsSettings); });