新しいヘッダーアイコンの追加方法

こんにちは、

ヘッダーに新しいアイコン(ライト/ダークテーマ切り替え用)を追加しようとしています。ここにある別のコメントを参考にしましたが、期待通りに動作していません。投稿ページをスクロールするとアイコンが消えてしまいます。ずっと表示されるようにする方法をご教示ください。

よろしくお願いいたします :grin:

keep クラスを追加してみましたが、それでも消えてしまいます)

<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>

!showExtraInfo(showExtraInfo はヘッダーのスクロール状態を指します)というコードがそのように指示しているため、表示されなくなります。

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

もし、この api.decorateWidget ブロック全体を以下のように変更すれば:

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

スクロール時でも表示され続けるようになります。

なんてことだ、今すごくバカっぽく感じているよ。あのコードをじっと見つめすぎてしまった。君のコードをいじろうとした結果ね!ありがとう、良い一日を :grin: