Yes, and presumably you can apply to every available Theme so this can’t be switched off? (to address @sarahann concern about this approach).
I could use display: none but it might now be as secure as we need it to be. And I figured it would be helpful to have a discussion on how to remove / change Discourse UI templates.
It’s tricky to do properly, unfortunately. For a big customer of ours who needs functionality removed, my approach has been to hide the elements with CSS and remove the controller side actions by using add_to_class to overwrite the methods with an error in plugin.rb.
I have a same problem. I’m working on plugin with topic, and I have to change the html structures but it’s impossible with only CSS. So I was tried to overwrite template but changes never applied.
So do you have find any solution for that?
You can override any template in the application if you like (although outlets are always preferred!). How were you doing it? did you confirm the name is exactly the same as the template you are replacing?
I tried to override the “list/topic-list-item.raw.hbs” template, but even though I removed all of the content in template, the topic items still appearing as original, any changing in override template never worked.
Please help me what I was wrong.
See: https://github.com/SamSaffron/discourse-simple-theme for an example of how it is done.
Hello,
When I run the command git grep “plugin-outlet” – “*.hbs” in my Linux Terminal, nothing shows up. Any ideas why? Thanks for your help!
Caveat: This is a sysadmin answer, not a plugin developer answer, and I can’t guess what you might have done before you did your git command.
Did you add it to git? What about
grep -r plugin-outlet .
Building on Jay’s shoulders here, you can of course focus on the specific file type:
grep -r "plugin-outlet" --include \*.hbs
Is there anything you need to consider differently if the plugin outlet looks like this?
{{plugin-outlet name="users-top" connectorTagName="div" args=(hash model=model)}}
do the connectorTagName and args attributes mean that plugin developers have particular constraints or extra accesses when using these outlets?
Yes you are meant to work with the API that the outlets establish.
In the users-top you are passed a model which you can use, and the connector will be rendered with a div in this case.
Je n’ai pas trouvé {{plugin-outlet}}. J’ai trouvé certains composants portant le même nom. Sont-ils identiques ?

Je pense que le code de Discourse a changé et que le guide pourrait être obsolète.
Je cherche cet exemple :
J’ai trouvé ceci à la place :
Et en utilisant ce formidable composant de thème (deprecated) Plugin outlet locations theme component, je peux voir cet outlet où il devrait être :
Pour répondre à votre question, je suppose que c’est la même chose, mais avec une nouvelle syntaxe.
J’ai également trouvé cette balise. Quelqu’un pourrait-il confirmer qu’elles sont toutes identiques ?
{{~raw-plugin-outlet name="topic-list-after-title"}}
La référence la plus à jour sur les prises de plugin se trouve ici :
J’essaierai de mettre à jour le message d’origine dans les prochains jours.
OP mis à jour avec la nouvelle syntaxe, et un lien vers la documentation complète
Je pense que la commande devrait être mise à jour pour :
git grep "<PluginOutlet" -- "*.gjs"
Ce lien indique « déprécié ».
Edit : J’ai trouvé le lien pour faire une PR sous le message principal, donc j’ai fait une PR.
Remplacé par :
https://meta.discourse.org/t/introducing-discourse-developer-toolbar/346215?u=merefield

