Comment ajouter une nouvelle icône d'en-tête

Bonjour,

J’essaie d’ajouter une nouvelle icône dans l’en-tête (pour un commutateur de thème clair/sombre) en m’inspirant d’un autre commentaire ici, mais cela ne fonctionne pas tout à fait comme prévu. L’icône disparaît lorsque je fais défiler une page de sujet. Quelqu’un peut-il m’aider à la garder visible en permanence ?

Merci beaucoup :grin:

(J’ai essayé d’ajouter la classe keep, mais elle disparaît toujours)

<script type="text/discourse-plugin" version="0.8">
  var h = require('virtual-dom').h;
  var ajax = require('discourse/lib/ajax').ajax;
  var themeSelector = require('discourse/lib/theme-selector');
  var light = 94;
  var dark = 98;
  
  const { iconNode } = require("discourse-common/lib/icon-library");
  let icon = iconNode('adjust');

  api.createWidget("header-theme-selector", {
      tagName: "span.header-theme-selector",
      buildKey: attrs => `header-theme-selector`,
      click(event){
          let $target = $(event.target);
          let id = light;
          let user = api.getCurrentUser();
          if(user){
              console.log(themeSelector.currentThemeId());
            if (themeSelector.currentThemeId() == light) {
              id = dark;
            }
            user.findDetails().then(user => {
                  seq = user.get("user_option.theme_key_seq");
                  this.setTheme(id, seq);
              });
          }else{
              this.setTheme(id);
          };
          return true;
      },
      setTheme(themeId, seq = 0){
          themeSelector.setLocalTheme([themeId], seq);
          window.location.reload();
          this.scheduleRerender();
      },
      html(attrs, state){
            return [h('div', {attributes: {"class": "switcher keep"}}, icon)];
      }
  });
  
  api.decorateWidget('header-buttons:after', (helper)=>{
    const showExtraInfo = helper.attrs.topic;
    if(!showExtraInfo) {
        return [helper.widget.attach('header-theme-selector')];
      }
  });
</script>

Il disparaît parce que le code l’indique avec !showExtraInfo (showExtraInfo correspond à l’état de défilement de l’en-tête) :

  if(!showExtraInfo) {
        return [helper.widget.attach('header-theme-selector')];
      }

Si vous remplacez tout le bloc api.decorateWidget par :

api.decorateWidget('header-buttons:after', (helper)=>{
  return [helper.widget.attach('header-theme-selector')];  
});

Alors il devrait continuer à apparaître même lors du défilement.

Bon sang, je me sens bête maintenant, j’ai passé beaucoup trop de temps à fixer ça. C’est ce que j’obtiens en essayant de modifier un peu votre code ! Merci beaucoup, bonne journée :grin: