Rerender on new route or transition

I’m building a banner ad plug-in. I have a section of the DOM that I need to re-render each time the page transitions. I have attempted (unsuccessfully) both a Widget and Ember Component, but neither are updating. I loaded them via a Plugin Outlet. I even tried to simplify the problem and dump the current timestamp of the load to the screen (rather than a banner), but only get a re-render if I refresh the browser.

Can someone please point me in the right direction for a solution? I’ve been through the main Discourse developer tutorials, BTW. Just seems like I’m missing something simple.

In which place you are trying to render? In Discourse most of the header UI sections will not refresh across page transactions unlike you hit browser refresh.

And can you post your code to see how you are doing it.

The plugin outlet right above the topic list.

Maybe you can try the following code (not tested):

// My plugin initializer
export default {

	name: 'myPlugin',

	initialize(container) {

		// Reopen the router to add a didTransition hook
		const router = container.lookup('router:main')
		router.reopen({
			doSomething: function() {
				// Wait for rendering to be over. THIS DOESN'T WORK IN ALL CASES. 
				// In fact, there is no way to be sure rendering is complete, because 
				// a 'complete rendering' is meaningless (think about a looping DOM  
				// animation)
				Ember.run.schedule('afterRender', null, () => {
					// Do your stuff here
					...
				})
			}.on('didTransition')
		})

	}

}

Может ли кто-нибудь дать дальнейшие рекомендации по этому вопросу?

Не могли бы вы пояснить, чего вы пытаетесь достичь?

Необходимо добавить компонент в область футера и обновлять его содержимое при каждой загрузке страницы, когда пользователь посещает тему. Это слайдер, содержащий популярные темы нашего сообщества, и он отображается только на странице тем для анонимных пользователей. Таким образом, при посещении пользователем каждой темы, присутствующей в слайдере, соответствующий слайд должен удаляться из компонента. Подключение с помощью следующего выхода футера не вызывает повторный рендеринг компонента.

Когда в Discourse отображается «подвал» (footer), приложение отправляет «событие».

Это событие называется inserted-custom-html:footer.

Вы можете использовать это событие для обновления содержимого подвала следующим образом:

api.onAppEvent("inserted-custom-html:footer", () => {
  // добавьте здесь ваш JS-код
});

Есть ещё несколько деталей здесь.

Это должно сработать для вашей задачи. Если нет — дайте знать и опубликуйте используемый вами код.

Я хотел бы разместить динамический контент в верхней части главной страницы (только на ней).

Какой сейчас считается лучшей практикой для обеспечения его перерисовки при каждом переходе на главную страницу?

Буду признателен за ссылку на существующий плагин, использующий этот подход.