Ajouter CurrentThemeId dans les classes CSS du Body

Bonjour,
Quelqu’un peut-il m’aider à ajouter l’ID du thème actif en tant que classe CSS sur les balises <html> ou <body> ?
J’ai besoin d’écrire des styles et d’attribuer des attributs différents selon certains thèmes.

Par exemple, lors de l’utilisation de « dark-theme » :

<html class="desktop-view not-mobile-device text-size-normal dark-theme">

Nous n’utilisons pas le nom comme identifiant, mais uniquement un numéro. Vous pouvez trouver l’ID d’un thème en examinant l’URL lorsque vous personnalisez un thème dans le panneau d’administration… par exemple https://forum.example.come/admin/customize/themes/140

Si vous pouvez vous contenter de l’ID plutôt que du nom, voici une méthode rapide pour le faire (à ajouter dans le fichier head de votre thème/composant) :

<script type="text/discourse-plugin" version="0.8">
  var themeSelector = require('discourse/lib/theme-selector');
  document.querySelector("body").classList.add("theme-id-" + themeSelector.currentThemeId())
</script>

Vous pouvez également retrouver le nom du thème à partir de son ID, mais cela demandera un peu plus de travail.

2 « J'aime »

Merci, Kris, @awesomerobot
Existe-t-il une documentation sur les plugins Discourse et les méthodes des bibliothèques associées ?

J’ai trouvé ceci, mais il semble qu’il ne couvre pas toutes les bibliothèques et méthodes :

This topic was automatically closed 30 days after the last reply. New replies are no longer allowed.