From 20e1233f89c3b8effe71f5429ddf52c9a3f0d31a Mon Sep 17 00:00:00 2001 From: Robin Ward Date: Wed, 19 Aug 2020 11:15:56 -0400 Subject: [PATCH] REFACTOR: Remove container from raw template helper --- .../javascripts/discourse/app/helpers/raw.js | 26 +++++-------------- .../app/initializers/auto-load-modules.js | 18 ++++++++++--- 2 files changed, 20 insertions(+), 24 deletions(-) diff --git a/app/assets/javascripts/discourse/app/helpers/raw.js b/app/assets/javascripts/discourse/app/helpers/raw.js index fe0d43c88bc..89177b4a1e8 100644 --- a/app/assets/javascripts/discourse/app/helpers/raw.js +++ b/app/assets/javascripts/discourse/app/helpers/raw.js @@ -1,36 +1,23 @@ -import { registerUnbound } from "discourse-common/lib/helpers"; +import { registerUnbound, helperContext } from "discourse-common/lib/helpers"; import { findRawTemplate } from "discourse-common/lib/raw-templates"; import { htmlSafe } from "@ember/template"; -import { setOwner } from "@ember/application"; -let _injections; - -function renderRaw(ctx, container, template, templateName, params) { +function renderRaw(ctx, template, templateName, params) { params = jQuery.extend({}, params); params.parent = params.parent || ctx; - if (!_injections) { - _injections = { - siteSettings: container.lookup("site-settings:main"), - currentUser: container.lookup("current-user:main"), - site: container.lookup("site:main"), - session: container.lookup("session:main"), - topicTrackingState: container.lookup("topic-tracking-state:main") - }; - setOwner(_injections, container); - } - + let context = helperContext(); if (!params.view) { const module = `discourse/raw-views/${templateName}`; if (requirejs.entries[module]) { const viewClass = requirejs(module, null, null, true); if (viewClass && viewClass.default) { - params.view = viewClass.default.create(params, _injections); + params.view = viewClass.default.create(params, context); } } if (!params.view) { - params = jQuery.extend({}, params, _injections); + params = jQuery.extend({}, params, context); } } @@ -40,12 +27,11 @@ function renderRaw(ctx, container, template, templateName, params) { registerUnbound("raw", function(templateName, params) { templateName = templateName.replace(".", "/"); - const container = Discourse.__container__; const template = findRawTemplate(templateName); if (!template) { // eslint-disable-next-line no-console console.warn("Could not find raw template: " + templateName); return; } - return renderRaw(this, container, template, templateName, params); + return renderRaw(this, template, templateName, params); }); diff --git a/app/assets/javascripts/discourse/app/initializers/auto-load-modules.js b/app/assets/javascripts/discourse/app/initializers/auto-load-modules.js index 2c7c4f00638..6482f52e43b 100644 --- a/app/assets/javascripts/discourse/app/initializers/auto-load-modules.js +++ b/app/assets/javascripts/discourse/app/initializers/auto-load-modules.js @@ -5,6 +5,7 @@ import { import RawHandlebars from "discourse-common/lib/raw-handlebars"; import { registerRawHelpers } from "discourse-common/lib/raw-handlebars-helpers"; import Handlebars from "handlebars"; +import { setOwner } from "@ember/application"; export function autoLoadModules(container, registry) { Object.keys(requirejs.entries).forEach(entry => { @@ -15,10 +16,19 @@ export function autoLoadModules(container, registry) { requirejs(entry, null, null, true); } }); - let siteSettings = container.lookup("site-settings:main"); - let themeSettings = container.lookup("service:theme-settings"); - let keyValueStore = container.lookup("key-value-store:main"); - createHelperContext({ siteSettings, themeSettings, keyValueStore }); + + let context = { + siteSettings: container.lookup("site-settings:main"), + themeSettings: container.lookup("service:theme-settings"), + keyValueStore: container.lookup("key-value-store:main"), + currentUser: container.lookup("current-user:main"), + site: container.lookup("site:main"), + session: container.lookup("session:main"), + topicTrackingState: container.lookup("topic-tracking-state:main") + }; + setOwner(context, container); + + createHelperContext(context); registerHelpers(registry); registerRawHelpers(RawHandlebars, Handlebars); }