Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Hardware
  4. SONOFF NSPanel mit Lovelace UI (TypeScript Version)

NEWS

  • wichtiges UPDATE für controller 7.2.2 im stable
    HomoranH
    Homoran
    8
    1
    555

  • Neues YouTube-Video: Visualisierung im Devices-Adapter
    BluefoxB
    Bluefox
    15
    1
    2.8k

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    2.9k

SONOFF NSPanel mit Lovelace UI (TypeScript Version)

Geplant Angeheftet Gesperrt Verschoben Hardware
lovelace uinspanelsonoff
8.1k Beiträge 280 Kommentatoren 7.8m Aufrufe 261 Beobachtet
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • SmartStuffCoyoteS SmartStuffCoyote

    Ja, genau den. Die Card lässt mich den ja sogar wählen, aber ich sehe den dann nirgendwo. Ich würd aber gern wissen, ob ich Bad oder Esszimmer steuere. :)

    ArmilarA Offline
    ArmilarA Offline
    Armilar
    Most Active Forum Testing
    schrieb am zuletzt editiert von
    #8095

    @SmartStuffCoyote sagte:

    Ja, genau den. Die Card lässt mich den ja sogar wählen, aber ich sehe den dann nirgendwo. Ich würd aber gern wissen, ob ich Bad oder Esszimmer steuere. :)

    Okay, den können wir natürlich auch nehmen... Ist bei mir etwas schwieriger... Ich steuere damit exakt einen Player... Daher sehe ich auch keine anderen...

    Ich ändere das ab...

    Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
    https://github.com/joBr99/nspanel-lovelace-ui/wiki

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    1 Antwort Letzte Antwort
    0
    • SmartStuffCoyoteS SmartStuffCoyote

      Ja, genau den. Die Card lässt mich den ja sogar wählen, aber ich sehe den dann nirgendwo. Ich würd aber gern wissen, ob ich Bad oder Esszimmer steuere. :)

      ArmilarA Offline
      ArmilarA Offline
      Armilar
      Most Active Forum Testing
      schrieb am zuletzt editiert von
      #8096

      @SmartStuffCoyote

      Noch mal den unteren Teil aus dem DEV Script ersetzen:

      https://github.com/joBr99/nspanel-lovelace-ui/blob/main/ioBroker/DEV/NSPanelTs.ts

      Danach sollte der Player und der Artist angezeigt werden...

      Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
      https://github.com/joBr99/nspanel-lovelace-ui/wiki

      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

      1 Antwort Letzte Antwort
      0
      • SmartStuffCoyoteS Offline
        SmartStuffCoyoteS Offline
        SmartStuffCoyote
        schrieb am zuletzt editiert von SmartStuffCoyote
        #8097
        javascript.0	01:03:40.994	warn	
        error at function GenerateMediaPage: Cannot read properties of null (reading 'length')
        javascript.0	01:03:41.959	warn	
            at GenerateMediaPage (script.js.common.NSPanel:9087:26)
        javascript.0	01:03:41.959	warn	
            at GeneratePage (script.js.common.NSPanel:6065:29)
        javascript.0	01:03:41.959	warn	
            at Object.<anonymous> (script.js.common.NSPanel:8421:21)
        javascript.0	01:03:41.959	warn	
            at step (script.js.common.NSPanel:33:23)
        javascript.0	01:03:41.959	warn	
            at Object.next (script.js.common.NSPanel:14:53)
        javascript.0	01:03:41.959	warn	
            at script.js.common.NSPanel:8:71
        javascript.0	01:03:41.959	warn	
            at __awaiter (script.js.common.NSPanel:4:12)
        

        Die Seite wird jetzt nicht mehr angezeigt.

        Ich kann aber grad nicht sagen, wo genau das auftaucht - im squeezeboxrpc-Block sind sowohl author.length als auch title.length immer vorhanden.

        Nachtrag: mit showOnlyPlayerHeadline: false tritt es nicht auf. Ich kriegs auf die Schnelle im Code aber nicht eingegrenzt. @armilar

        Nachtrag 2:

        	
        {
          id: 'alias.0.NSPanel.1.Media.PlayerSqueezeboxRPC',
          adapterPlayerInstance: 'squeezeboxrpc.0.',
          speakerList: [ 'Heartbeat_4', 'Squeezebox' ],
          mediaDevice: 'Heartbeat_4',
          playList: [],
          colorMediaIcon: { red: 0, green: 255, blue: 0 },
          colorMediaArtist: { red: 255, green: 255, blue: 0 },
          colorMediaTitle: { red: 255, green: 255, blue: 0 },
          alwaysOnDisplay: true,
          autoCreateALias: true,
          showOnlyPlayerHeadline: true
        }
        

        Ich habe

        name = getState(page.items[0].adapterPlayerInstance + "Players.SqueezePlay.Playername").val;
        

        mal so geändert, dann klappts:

        name = getState(page.items[0].adapterPlayerInstance + "Players." + page.items[0].mediaDevice + ".Playername").val;
        
        1 Antwort Letzte Antwort
        0
        • T Nicht stören
          T Nicht stören
          ticaki
          schrieb am zuletzt editiert von ticaki
          #8098

          Ich bin da nicht drin daher:

          ergibt das bei dir eine gültige id? adapterPlayerInstance + "Players.SqueezePlay.Playername"

          aber nicht wichtig - hier if (name.length == 0) muß ein if (typeOf name !== 'string' || name.length == 0) rein.
          https://github.com/joBr99/nspanel-lovelace-ui/blob/b8649caa2714e0594d14c334550e2ba8e33f8cfb/ioBroker/DEV/NSPanelTs.ts#L7884

          EDIT: du benutzt doch squeezeboxrpc

          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

          Spenden

          1 Antwort Letzte Antwort
          0
          • SmartStuffCoyoteS Offline
            SmartStuffCoyoteS Offline
            SmartStuffCoyote
            schrieb am zuletzt editiert von SmartStuffCoyote
            #8099

            @ticaki siehe oben, das hab ich noch gefunden und nachgetragen. Das ".SqueezePlay." im Datenpunkt-Pfad ist falsch. Das existiert schlicht nicht.

            Hab aber immer noch mein "undefined". heul

            author = lmstracklist[currentIndex].Artist + '|' + lmstracklist[currentIndex].Album;
            if (author == undefined || author == "undefined") {
                  author = getState(id + '.ARTIST').val;
            }
            

            Das kann aber auch nicht klappen, author wird ja zugewiesen und kann nnicht undefined sein.

                                  author = lmstracklist[currentIndex].Artist;
                                    if (author == undefined || author == "undefined") {
                                        author = getState(id + '.ARTIST').val;
                                    } 
                                    author = author + '|' + lmstracklist[currentIndex].Album;
            

            klappt bei mir.

            ArmilarA T 2 Antworten Letzte Antwort
            0
            • SmartStuffCoyoteS SmartStuffCoyote

              @ticaki siehe oben, das hab ich noch gefunden und nachgetragen. Das ".SqueezePlay." im Datenpunkt-Pfad ist falsch. Das existiert schlicht nicht.

              Hab aber immer noch mein "undefined". heul

              author = lmstracklist[currentIndex].Artist + '|' + lmstracklist[currentIndex].Album;
              if (author == undefined || author == "undefined") {
                    author = getState(id + '.ARTIST').val;
              }
              

              Das kann aber auch nicht klappen, author wird ja zugewiesen und kann nnicht undefined sein.

                                    author = lmstracklist[currentIndex].Artist;
                                      if (author == undefined || author == "undefined") {
                                          author = getState(id + '.ARTIST').val;
                                      } 
                                      author = author + '|' + lmstracklist[currentIndex].Album;
              

              klappt bei mir.

              ArmilarA Offline
              ArmilarA Offline
              Armilar
              Most Active Forum Testing
              schrieb am zuletzt editiert von
              #8100

              @SmartStuffCoyote

              Wenn es jetzt funktioniert, dann bitte mal hier die komplette GenerateMediaPage reinwerfen. Dann kann ich mir das zusammensuchen sparen.

              Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
              https://github.com/joBr99/nspanel-lovelace-ui/wiki

              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

              SmartStuffCoyoteS 1 Antwort Letzte Antwort
              0
              • SmartStuffCoyoteS SmartStuffCoyote

                @ticaki siehe oben, das hab ich noch gefunden und nachgetragen. Das ".SqueezePlay." im Datenpunkt-Pfad ist falsch. Das existiert schlicht nicht.

                Hab aber immer noch mein "undefined". heul

                author = lmstracklist[currentIndex].Artist + '|' + lmstracklist[currentIndex].Album;
                if (author == undefined || author == "undefined") {
                      author = getState(id + '.ARTIST').val;
                }
                

                Das kann aber auch nicht klappen, author wird ja zugewiesen und kann nnicht undefined sein.

                                      author = lmstracklist[currentIndex].Artist;
                                        if (author == undefined || author == "undefined") {
                                            author = getState(id + '.ARTIST').val;
                                        } 
                                        author = author + '|' + lmstracklist[currentIndex].Album;
                

                klappt bei mir.

                T Nicht stören
                T Nicht stören
                ticaki
                schrieb am zuletzt editiert von ticaki
                #8101

                @SmartStuffCoyote

                Das hier ist trotzdem nötig - da darf kein undefined auf length geprüft werden...

                if (name.length == 0) -> if (typeof name !== 'string' || name.length == 0)

                wobei das ist kürzer (aber auch unsicherer)
                if ((name ?? '').length == 0)

                Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                Spenden

                1 Antwort Letzte Antwort
                0
                • ArmilarA Armilar

                  @SmartStuffCoyote

                  Wenn es jetzt funktioniert, dann bitte mal hier die komplette GenerateMediaPage reinwerfen. Dann kann ich mir das zusammensuchen sparen.

                  SmartStuffCoyoteS Offline
                  SmartStuffCoyoteS Offline
                  SmartStuffCoyote
                  schrieb am zuletzt editiert von SmartStuffCoyote
                  #8102

                  @Armilar Hier, inklusive des Fix von @ticaki

                  function GenerateMediaPage (page: NSPanel.PageMedia): NSPanel.Payload[] {
                      try {
                          unsubscribeMediaSubscriptions();
                  
                          if (!page.items[0].id) throw new Error('Missing page id for cardMedia!');
                  
                          let id = page.items[0].id;
                          let tid = 0;
                          let out_msgs: NSPanel.Payload[] = [];
                  
                          if (!page.items[0].adapterPlayerInstance!) throw new Error('page.items[0].adapterPlayerInstance is undefined!');
                          let vInstance = page.items[0].adapterPlayerInstance!;
                          let v1Adapter = vInstance.split('.');
                          let v2Adapter: NSPanel.PlayerType = v1Adapter[0] as NSPanel.PlayerType;
                  
                          let vMediaDevice = page.items[0].mediaDevice != undefined ? page.items[0].mediaDevice : '';
                  
                          if (isPlayerWithMediaDevice(v2Adapter)) {
                              if (!vMediaDevice) throw new Error(`Error in cardMedia! mediaDevice is empty! Page: ${JSON.stringify(page)}`);
                          }
                          createAutoMediaAlias(id, vMediaDevice, page.items[0].adapterPlayerInstance!);
                  
                          // Leave the display on if the alwaysOnDisplay parameter is specified (true)
                          if (page.type == 'cardMedia' && pageCounter == 0 && page.items[0].alwaysOnDisplay != undefined) {
                              out_msgs.push({payload: 'pageType~cardMedia'});
                              if (page.items[0].alwaysOnDisplay != undefined) {
                                  if (page.items[0].alwaysOnDisplay) {
                                      pageCounter = 1;
                                      if (alwaysOn == false) {
                                          alwaysOn = true;
                                          SendToPanel({payload: 'timeout~0'});
                                          subscribeMediaSubscriptions(page.items[0].id);
                                          if (v2Adapter == 'sonos') {
                                              subscribeMediaSubscriptionsSonosAdd(page.items[0].id);
                                          } else if (v2Adapter == 'spotify-premium') {
                                              setState(vInstance + 'getDevices', true);
                                              setState(vInstance + 'getPlaybackInfo', true);
                                              setState(vInstance + 'getPlaylists', true);
                                          }
                                      }
                                  }
                              }
                          } else if (page.type == 'cardMedia' && pageCounter == 1) {
                              alwaysOn = true;
                              subscribeMediaSubscriptions(page.items[0].id);
                              if (v2Adapter == 'sonos') {
                                  subscribeMediaSubscriptionsSonosAdd(page.items[0].id);
                              }
                          } else if (page.type == 'cardMedia' && pageCounter == -1) {
                              //Do Nothing
                          } else {
                              out_msgs.push({payload: 'pageType~cardMedia'});
                          }
                  
                          if (existsObject(id)) {
                  
                              let name = "";
                              if (page.items[0].showOnlyPlayerHeadline && page.items[0].showOnlyPlayerHeadline != undefined) {
                                  //name = getState(page.items[0].adapterPlayerInstance + "Players.SqueezePlay.Playername").val;
                                  name = getState(page.items[0].adapterPlayerInstance + "Players." + page.items[0].mediaDevice + ".Playername").val;
                                  //name = page.heading;
                              } else {
                                  name = getState(id + '.ALBUM').val;
                                  console.log("##### else name");
                              }
                              let title = getState(id + '.TITLE').val;
                              if (title && title.indexOf('~') !== -1) {
                                  title = title.split('~')[0].trim();
                              }
                  
                              if (title.length > 24) {
                                  title = title.slice(0, 24) + '...';
                              }
                              if (existsObject(id + '.DURATION') && existsObject(id + '.ELAPSED')) {
                                  if (v2Adapter == 'alexa2') {
                                      if (Debug) log(getState(id + '.DURATION').val, 'info');
                                      let Seconds = parseInt(getState(id + '.DURATION').val) % 60 < 10 ? '0' : '';
                                      let Duration = Math.floor(getState(id + '.DURATION').val / 60) + ':' + Seconds + (getState(id + '.DURATION').val % 60);
                                      let vElapsed = getState(id + '.ELAPSED').val;
                  
                                      if (vElapsed.length == 5) {
                                          if (parseInt(vElapsed.slice(0, 2)) < 9) {
                                              vElapsed = vElapsed.slice(1);
                                          }
                                      }
                                      if (vElapsed == 0) {
                                          vElapsed = '0:00';
                                      }
                                      let vDuration = Duration;
                                      if (vDuration.length == 5) {
                                          if (parseInt(vDuration.slice(0, 2)) < 9) {
                                              vDuration = vDuration.slice(1);
                                          }
                                      }
                                      if (vDuration != '0:00') {
                                          title = title + ' (' + vElapsed + '|' + vDuration + ')';
                                      } else {
                                          title = title + ' (' + vElapsed + ')';
                                      }
                                      if (title == ' (0:00)') {
                                          title = '';
                                      }
                                  } else if (v2Adapter == 'sonos' && getState(page.items[0].adapterPlayerInstance + 'root.' + page.items[0].mediaDevice + '.current_type').val == 0) {
                                      let vElapsed = getState(id + '.ELAPSED').val;
                                      if (vElapsed.length == 5) {
                                          if (parseInt(vElapsed.slice(0, 2)) < 9) {
                                              vElapsed = vElapsed.slice(1);
                                          }
                                      } else if (vElapsed.length == 8) {
                                          vElapsed = vElapsed.slice(4);
                                      }
                                      let vDuration = getState(id + '.DURATION').val;
                                      if (vDuration.length == 5) {
                                          if (parseInt(vDuration.slice(0, 2)) < 9) {
                                              vDuration = vDuration.slice(1);
                                          }
                                      } else if (vDuration.length == 8) {
                                          vDuration = vDuration.slice(4);
                                      }
                                      title = title + ' (' + vElapsed + '|' + vDuration + ')';
                                  } else if (v2Adapter == 'bosesoundtouch') {
                                      if (Debug) log(getState(id + '.ELAPSED').val, 'info');
                                      let elapsedSeconds = parseInt(getState(id + '.ELAPSED').val) % 60 < 10 ? '0' : '';
                                      let vElapsed = Math.floor(getState(id + '.ELAPSED').val / 60) + ':' + elapsedSeconds + (getState(id + '.ELAPSED').val % 60);
                                      if (Debug) log(getState(id + '.DURATION').val, 'info');
                                      let durationSeconds = parseInt(getState(id + '.DURATION').val) % 60 < 10 ? '0' : '';
                                      let vDuration = Math.floor(getState(id + '.DURATION').val / 60) + ':' + durationSeconds + (getState(id + '.DURATION').val % 60);
                                      title = title + ' (' + vElapsed + '|' + vDuration + ')';
                                  } else if (v2Adapter == 'mpd') {
                                      let vElapsed: string = getState(id + '.ELAPSED').val;
                                      let vDuration: string = getState(id + '.DURATION').val;
                                      title = title + ' (' + vElapsed + '|' + vDuration + ')';
                                      if (getState(id + '.STATE').val === 'stop') {
                                          title = '(00:00|00:00)';
                                      }
                                  }
                              }
                  
                              let author = getState(id + '.ARTIST').val;
                  
                              if (v2Adapter == 'squeezeboxrpc' && author.length > 0) {
                                  if (existsObject([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.Playlist'].join(''))) {
                                      if (existsObject([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.Playlist'].join(''))) {
                                          let lmstracklist = JSON.parse(getState([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.Playlist'].join('')).val);
                                          let currentIndex: number = parseInt(getState([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.PlaylistCurrentIndex'].join('')).val);
                                          
                                          author = lmstracklist[currentIndex].Artist;
                                          if (author == undefined || author == "undefined") {
                                              author = getState(id + '.ARTIST').val;
                                          } 
                                          author = author + '|' + lmstracklist[currentIndex].Album;
                                          if (author.length > 37) {
                                              author = author.slice(0, 37) + '...';
                                          }
                                          let elapsedTime: number = parseInt(getState([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.Time'].join('')).val);
                                          let elapsedSeconds = elapsedTime % 60 < 10 ? '0' : '';
                                          let vElapsed = Math.floor(elapsedTime / 60) + ':' + elapsedSeconds + (elapsedTime % 60);
                  
                                          let durationSeconds = parseInt(lmstracklist[currentIndex].Duration) % 60 < 10 ? '0' : '';
                                          let vDuration = Math.floor(parseInt(lmstracklist[currentIndex].Duration) / 60) + ':' + durationSeconds + (parseInt(lmstracklist[currentIndex].Duration) % 60);
                                          title = lmstracklist[currentIndex].title;
                                          if (title.length > 25) {
                                              title = title.slice(0, 25) + '...';
                                          }
                                          title = title + ' (' + vElapsed + '|' + vDuration + ')';
                                      }
                                  }
                              }
                  
                              // Settings >>Aktualisierungsintervall für Statusinformationen<< = 1 !
                              // If the refresh time is set to 1 second in the spotify-premium.X instance,
                              // the elapsed refresh bug '00:00' is not visible
                              if (v2Adapter == 'spotify-premium') {
                                  let vElapsed: string = getState(id + '.ELAPSED').val;
                                  if (vElapsed.substring(0, 1) == '0') {
                                      vElapsed = vElapsed.slice(1);
                                  }
                                  let vDuration: string = getState(id + '.DURATION').val;
                                  if (vDuration.substring(0, 1) == '0') {
                                      vDuration = vDuration.slice(1);
                                  }
                                  title = title + ' (' + vElapsed + '|' + vDuration + ')';
                                  if (title == ' (0:00|0:00)') {
                                      title = '';
                                  }
                              }
                  
                              let shuffle = getState(id + '.SHUFFLE').val;
                  
                              //New Adapter/Player
                              let media_icon = Icons.GetIcon('playlist-music');
                  
                              //Spotify-Premium
                              if (v2Adapter == 'spotify-premium') {
                                  media_icon = Icons.GetIcon('spotify');
                                  if (page.items[0].playerMediaIcon !== undefined) {
                                      if (page.items[0].playerMediaIcon == 'logo-spotify') {
                                          media_icon = page.items[0].playerMediaIcon;
                                      } else {
                                          media_icon = Icons.GetIcon(page.items[0].playerMediaIcon);
                                      }
                                  }
                                  name = getState(id + '.CONTEXT_DESCRIPTION').val;
                                  let nameLength = name.length;
                                  if (name.substring(0, 17) == 'Playlist: This Is') {
                                      name = name.slice(18, 34) + '...';
                                  } else if (name.substring(0, 9) == 'Playlist:') {
                                      name = name.slice(10, 26) + '...';
                                  } else if (name.substring(0, 6) == 'Album:') {
                                      name = name.slice(7, 23) + '...';
                                  } else if (name.substring(0, 6) == 'Track:') {
                                      name = name.slice(7, 23) + '...';
                                  } else if (name.substring(0, 7) == 'Artist:') {
                                      name = name.slice(8, 24) + '...';
                                  }
                                  if (nameLength == 0) {
                                      name = 'Spotify-Premium';
                                  }
                                  author = getState(id + '.ARTIST').val + ' | ' + getState(id + '.ALBUM').val;
                                  if (author.length > 37) {
                                      author = author.slice(0, 37) + '...';
                                  }
                                  if (getState(id + '.ARTIST').val.length == 0) {
                                      author = findLocale('media', 'no_music_to_control');
                                  }
                              }
                  
                              //Sonos
                              if (v2Adapter == 'sonos') {
                                  media_icon = Icons.GetIcon('alpha-s-circle');
                                  if (page.items[0].playerMediaIcon !== undefined) {
                                      if (page.items[0].playerMediaIcon == 'logo-sonos') {
                                          media_icon = page.items[0].playerMediaIcon;
                                      } else {
                                          media_icon = Icons.GetIcon(page.items[0].playerMediaIcon);
                                      }
                                  }
                                  name = getState(id + '.CONTEXT_DESCRIPTION').val;
                                  let nameLenght = name.length;
                                  if (nameLenght == 0) {
                                      name = page.heading;
                                  } else if (nameLenght > 16) {
                                      name = name.slice(0, 16) + '...';
                                  }
                                  if (getState(id + '.ALBUM').val.length > 0) {
                                      author = getState(id + '.ARTIST').val + ' | ' + getState(id + '.ALBUM').val;
                                      if (author.length > 37) {
                                          author = author.slice(0, 37) + '...';
                                      }
                                  } else {
                                      author = getState(id + '.ARTIST').val;
                                  }
                                  if (getState(id + '.ARTIST').val.length == 0) {
                                      author = findLocale('media', 'no_music_to_control');
                                  }
                              }
                  
                              //Bose Soundtouch
                              if (v2Adapter == 'bosesoundtouch') {
                                  media_icon = Icons.GetIcon('alpha-b-circle');
                                  if (page.items[0].playerMediaIcon !== undefined) {
                                      if (page.items[0].playerMediaIcon == 'logo-bose') {
                                          media_icon = page.items[0].playerMediaIcon;
                                      } else {
                                          media_icon = Icons.GetIcon(page.items[0].playerMediaIcon);
                                      }
                                  }
                                  name = page.heading;
                  
                                  if (getState(id + '.ALBUM').val.length > 0) {
                                      author = getState(id + '.ARTIST').val + ' | ' + getState(id + '.ALBUM').val;
                                      if (author.length > 37) {
                                          author = author.slice(0, 37) + '...';
                                      }
                                  } else {
                                      author = getState(id + '.ARTIST').val;
                                  }
                                  if (getState(id + '.ARTIST').val.length == 0) {
                                      author = findLocale('media', 'no_music_to_control');
                                  }
                              }
                  
                              //Logitech Squeezebox RPC
                              if (v2Adapter == 'squeezeboxrpc') {
                                  media_icon = Icons.GetIcon('dlna');
                                  if (page.items[0].playerMediaIcon !== undefined) {
                                      if (page.items[0].playerMediaIcon == 'logo-dnla') {
                                          media_icon = page.items[0].playerMediaIcon;
                                      } else {
                                          media_icon = Icons.GetIcon(page.items[0].playerMediaIcon);
                                      }
                                  }
                                  if (name.length == 0) {
                                      name = page.heading;
                                  } else if (name.length > 16) {
                                      name = name.slice(0, 16) + '...';
                                  }
                              }
                  
                              //Alexa2
                              if (v2Adapter == 'alexa2') {
                                  media_icon = Icons.GetIcon('alpha-a-circle');
                                  if (page.items[0].playerMediaIcon !== undefined) {
                                      if (page.items[0].playerMediaIcon == 'logo-alexa') {
                                          media_icon = page.items[0].playerMediaIcon;
                                      } else {
                                          media_icon = Icons.GetIcon(page.items[0].playerMediaIcon);
                                      }
                                  }
                                  name = getState(id + '.ALBUM').val;
                                  let nameLength = name.length;
                                  if (name.substring(0, 9) == 'Playlist:') {
                                      name = name.slice(10, 26) + '...';
                                  } else if (name.substring(0, 6) == 'Album:') {
                                      name = name.slice(7, 23) + '...';
                                  } else if (name.substring(0, 6) == 'Track') {
                                      name = 'Alexa Player';
                                  }
                                  if (nameLength == 0) {
                                      name = 'Alexa Player';
                                  } else {
                                      name = name.slice(0, 16) + '...';
                                  }
                                  author = getState(id + '.ARTIST').val + ' | ' + getState(id + '.ALBUM').val;
                                  if (author.length > 30) {
                                      author = getState(id + '.ARTIST').val;
                                  }
                                  if (getState(id + '.ARTIST').val.length == 0) {
                                      author = findLocale('media', 'no_music_to_control');
                                  }
                              }
                  
                              //Volumio
                              if (v2Adapter == 'volumio') {
                                  media_icon = Icons.GetIcon('clock-time-twelve-outline');
                                  if (page.items[0].playerMediaIcon !== undefined) {
                                      if (page.items[0].playerMediaIcon == 'logo-volumio') {
                                          media_icon = page.items[0].playerMediaIcon;
                                      } else {
                                          media_icon = Icons.GetIcon(page.items[0].playerMediaIcon);
                                      }
                                  }
                                  if (name != undefined) {
                                      author = author + ' | ' + name;
                                  }
                                  name = page.heading;
                              }
                  
                              //MPD
                              if (v2Adapter == 'mpd') {
                                  media_icon = Icons.GetIcon('alpha-m-circle');
                                  if (page.items[0].playerMediaIcon !== undefined) {
                                      if (page.items[0].playerMediaIcon == 'logo-mpd') {
                                          media_icon = page.items[0].playerMediaIcon;
                                      } else {
                                          media_icon = Icons.GetIcon(page.items[0].playerMediaIcon);
                                      }
                                  }
                                  if (getState(id + '.ALBUM').val.length > 0) {
                                      author = getState(id + '.ARTIST').val + ' | ' + getState(id + '.ALBUM').val;
                                      if (author.length > 37) {
                                          author = author.slice(0, 37) + '...';
                                      }
                                  } else {
                                      author = getState(id + '.ARTIST').val;
                                  }
                                  if (getState(id + '.ARTIST').val.length == 0) {
                                      author = findLocale('media', 'no_music_to_control');
                                  }
                                  name = page.heading;
                              }
                  
                              let volume = scale(getState(id + '.VOLUME').val, activePage!.items[0]!.minValue ?? 0, activePage!.items[0]!.maxValue ?? 100, 100, 0);
                              let iconplaypause = Icons.GetIcon('pause'); //pause
                              let shuffle_icon = Icons.GetIcon('shuffle-variant'); //shuffle
                              let onoffbutton = 1374;
                  
                              if (shuffle == 'off' || shuffle == false || shuffle == 0 || shuffle == 'false') {
                                  shuffle_icon = Icons.GetIcon('shuffle-disabled'); //shuffle
                              }
                  
                              // Todo: Refresh automatisieren und dafür wieder Shuffle nutzen
                              //if (v2Adapter == 'volumio') { shuffle_icon = Icons.GetIcon('shuffle-disabled'); } //Volumio: refresh playlist
                  
                              //For all players
                              if (getState(id + '.STATE').val) {
                                  onoffbutton = 65535;
                                  iconplaypause = Icons.GetIcon('pause'); //pause
                              } else {
                                  iconplaypause = Icons.GetIcon('play'); //play
                              }
                  
                              //Ausnahme für squeezebox, da State = Power
                              if (v2Adapter == 'squeezeboxrpc') {
                                  if (getState(id + '.PAUSE').val === false) {
                                      onoffbutton = 65535;
                                      iconplaypause = Icons.GetIcon('pause'); //pause
                                  } else {
                                      iconplaypause = Icons.GetIcon('play'); //play
                                  }
                              }
                  
                              //Ausnahme für mpd, da State = play, pause,....
                              if (v2Adapter == 'mpd') {
                                  if (getState(id + '.STATE').val === 'play') {
                                      onoffbutton = 65535;
                                      iconplaypause = Icons.GetIcon('pause'); //pause
                                  } else if (getState(id + '.STATE').val === 'pause') {
                                      iconplaypause = Icons.GetIcon('play'); //play
                                  } else if (getState(id + '.STATE').val === 'stop') {
                                      onoffbutton = 1374;
                                      iconplaypause = Icons.GetIcon('play'); //play
                                  }
                  
                              }
                  
                              //Ausnahme Volumio: status = string: play, pause, stop usw.
                              if (v2Adapter == 'volumio') {
                                  if (getState(id + '.status').val == 'play') {
                                      onoffbutton = 65535;
                                      iconplaypause = Icons.GetIcon('pause'); //pause
                                  } else {
                                      iconplaypause = Icons.GetIcon('play'); //play
                                  }
                              }
                  
                              let currentSpeaker: string = findLocale('media', 'no_speaker_found');
                  
                              if (v2Adapter == 'alexa2') {
                                  currentSpeaker = getState([page.items[0].adapterPlayerInstance, 'Echo-Devices.', page.items[0].mediaDevice, '.Info.name'].join('')).val;
                              } else if (v2Adapter == 'spotify-premium') {
                                  currentSpeaker = getState([page.items[0].adapterPlayerInstance, 'player.device.name'].join('')).val;
                              } else if (v2Adapter == 'sonos') {
                                  currentSpeaker = getState([page.items[0].adapterPlayerInstance, 'root.', page.items[0].mediaDevice, '.members'].join('')).val;
                              } else if (v2Adapter == 'squeezeboxrpc') {
                                  currentSpeaker = getState([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.Playername'].join('')).val;
                              } else if (v2Adapter == 'bosesoundtouch') {
                                  currentSpeaker = getState([page.items[0].adapterPlayerInstance, 'deviceInfo.name'].join('')).val;
                              } else if (v2Adapter == 'volumio') {
                                  currentSpeaker = getState([page.items[0].adapterPlayerInstance, 'info.name'].join('')).val;
                              } else if (v2Adapter == 'mpd') {
                                  currentSpeaker = v1Adapter[0] + '.' + v1Adapter[1];
                              }
                              //-------------------------------------------------------------------------------------------------------------
                              // All Alexa devices (the online / player and commands directory is available) are listed and linked below
                              // If the constant alexaSpeakerList contains at least one entry, the constant is used - otherwise all devices from the Alexa adapter
                              let speakerListArray: string[] = [];
                              if (page.items[0].speakerList && page.items[0].speakerList.length > 0) {
                                  for (let i_index in page.items[0].speakerList) {
                                      speakerListArray.push(page.items[0].speakerList[i_index]);
                                  }
                              } else if (v2Adapter == 'squeezeboxrpc') {
                                  // Beim Squeezeboxrpc ist jeder Player ein eigener Knoten im Objektbaum. Somit werden einzelne Aliase benötigt.
                                  const squeezeboxPlayerQuery: iobJS.QueryResult = $('channel[state.id=' + page.items[0].adapterPlayerInstance + '.Players.*.Playername]');
                                  squeezeboxPlayerQuery.each((playerId: string, playerIndex: number) => {
                                      speakerListArray.push(getState(playerId).val);
                                      page.items[0].speakerList = speakerListArray;
                                  });
                              } else if (v2Adapter == 'spotify-premium') {
                                  // All possible Devices if page.items[0].speakerList empty
                                  if (Debug) log(getState(page.items[0].adapterPlayerInstance + 'devices.availableDeviceListString').val);
                                  speakerListArray = getState(page.items[0].adapterPlayerInstance + 'devices.availableDeviceListString').val.split(';');
                                  page.items[0].speakerList = speakerListArray;
                              } else if (v2Adapter == 'mpd') {
                                  // All possible Devices if page.items[0].speakerList empty
                                  page.items[0].speakerList[0] = v1Adapter[0] + '.' + v1Adapter[1];
                              } else {
                                  let i_list = Array.prototype.slice.apply($('[state.id="' + page.items[0].adapterPlayerInstance + 'Echo-Devices.*.Info.name"]'));
                                  for (let i_index in i_list) {
                                      let i = i_list[i_index];
                                      let deviceId = i;
                                      deviceId = deviceId.split('.');
                                      if (
                                          getState([page.items[0].adapterPlayerInstance, 'Echo-Devices.', deviceId[3], '.online'].join('')).val &&
                                          existsObject([page.items[0].adapterPlayerInstance, 'Echo-Devices.', deviceId[3], '.Player'].join('')) &&
                                          existsObject([page.items[0].adapterPlayerInstance, 'Echo-Devices.', deviceId[3], '.Commands'].join(''))
                                      ) {
                                          speakerListArray.push(getState(i).val);
                                      }
                                  }
                              }
                              //--------------------------------------------------------------------------------------------------------------
                  
                              let colMediaIcon = page.items[0].colorMediaIcon != undefined ? page.items[0].colorMediaIcon : White;
                              let colMediaTitle = page.items[0].colorMediaTitle != undefined ? page.items[0].colorMediaTitle : White;
                              let colMediaArtist = page.items[0].colorMediaArtist != undefined ? page.items[0].colorMediaArtist : White;
                  
                              //InSel Speaker
                              let speakerListString: string = '~~~~~~';
                              let speakerListIconCol = rgb_dec565(HMIOff);
                              if (speakerListArray.length > 0) {
                                  speakerListIconCol = rgb_dec565(HMIOn);
                                  speakerListString = 'input_sel' + '~' + tid + '?speakerlist' + '~' + Icons.GetIcon('speaker') + '~' + speakerListIconCol + '~' + findLocale('media', 'speaker') + '~' + 'media0~';
                              }
                  
                              //InSel Playlist
                              let playListString: string = '~~~~~~';
                              let playListIconCol = rgb_dec565(HMIOff);
                              if (page.items[0].playList != undefined) {
                                  /* Volumio: get actual playlist if empty */
                                  if (v2Adapter == 'volumio') {
                                      if (page.items[0].playList.length == 0) {
                                          let urlString: string = `${getState(vInstance + 'info.host').val}/api/listplaylists`;
                  
                                          axios
                                              .get(urlString, {headers: {'User-Agent': 'ioBroker'}})
                                              .then(async function (response) {
                                                  if (response.status === 200) {
                                                      if (Debug) {
                                                          log(JSON.stringify(response.data), 'info');
                                                      }
                                                      page.items[0].playList = JSON.parse(JSON.stringify(response.data));
                                                      if (Debug) log('volumio-playlist: ' + page.items[0].playList, 'info');
                                                  } else {
                                                      log('Axios Status - get_volumio-playlist: ' + response.state, 'warn');
                                                  }
                                              })
                                              .catch(function (error) {
                                                  log(error, 'warn');
                                              });
                                      }
                                      /* Spotify: get all playlists if empty */
                                  } else if (v2Adapter == 'spotify-premium') {
                                      page.items[0].playList = getState(page.items[0].adapterPlayerInstance + 'playlists.playlistListString').val.split(';');
                                  } else if (v2Adapter == 'mpd') {
                                      let tempPL = getState(page.items[0].adapterPlayerInstance + 'listplaylists').val;
                                      tempPL = tempPL.replace('[', '');
                                      tempPL = tempPL.replace(']', '');
                                      tempPL = tempPL.replaceAll('"', '');
                                      page.items[0].playList = tempPL.split(',');
                                  }
                                  playListIconCol = rgb_dec565(HMIOn);
                                  playListString =
                                      'input_sel' +
                                      '~' +
                                      tid +
                                      '?playlist' +
                                      '~' +
                                      Icons.GetIcon('playlist-play') +
                                      '~' +
                                      playListIconCol +
                                      '~' +
                                      //'PlayL ' + page.heading + '~' +
                                      findLocale('media', 'playlist') +
                                      '~' +
                                      'media1~';
                              }
                  
                              //InSel Tracklist
                              globalTracklist = '';
                  
                              let trackListString: string = '~~~~~~';
                              let trackListIconCol = rgb_dec565(HMIOff);
                              if (v2Adapter == 'volumio') {
                                  /* Volumio: get queue */
                                  setTimeout(async function () {
                                      let urlString: string = `${getState(vInstance + 'info.host').val}/api/getQueue`;
                  
                                      axios
                                          .get(urlString, {headers: {'User-Agent': 'ioBroker'}})
                                          .then(async function (response) {
                                              if (response.status === 200) {
                                                  if (Debug) {
                                                      log(JSON.stringify(response.data), 'info');
                                                  }
                                                  const QUEUELIST = JSON.parse(JSON.stringify(response.data));
                                                  page.items[0].globalTracklist = QUEUELIST.queue;
                                                  if (Debug) {
                                                      for (let i_index in QUEUELIST.queue) {
                                                          log('volumio-queue: ' + QUEUELIST.queue[i_index], 'info');
                                                      }
                                                  }
                                              } else {
                                                  log('Axios Status - get_volumio-queue: ' + response.state, 'warn');
                                              }
                                          })
                                          .catch(function (error) {
                                              log(error, 'warn');
                                          });
                                  }, 2000);
                                  globalTracklist = page.items[0].globalTracklist;
                              } else if (v2Adapter == 'squeezeboxrpc' && existsObject([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.Playlist'].join(''))) {
                                  let lmstracklist = JSON.parse(getState([page.items[0].adapterPlayerInstance, 'Players.', page.items[0].mediaDevice, '.Playlist'].join('')).val);
                                  globalTracklist = lmstracklist;
                              } else if (v2Adapter == 'sonos' && existsObject([page.items[0].adapterPlayerInstance, 'root.', page.items[0].mediaDevice, '.playlist_set'].join(''))) {
                                  let lmstracklist = getState([page.items[0].adapterPlayerInstance, 'root.', page.items[0].mediaDevice, '.queue'].join('')).val;
                                  lmstracklist = lmstracklist.replace(/\s*[\[{(].*?[)}\]]\s*/g, '');
                                  let lmstracklistTemp = lmstracklist.split(', ');
                                  let trackList: string = '[';
                                  if (getState(page.items[0].adapterPlayerInstance + 'root.' + page.items[0].mediaDevice + '.current_type').val == 0) {
                                      for (let i = 0; i < lmstracklistTemp.length; i++) {
                                          let trackTemp = lmstracklistTemp[i].split(' - ');
                                          trackList = trackList + '{"id":"' + i + '","name":"' + trackTemp[0] + '","title":"' + trackTemp[1] + '"}';
                                          if (i < lmstracklistTemp.length - 1) {
                                              trackList = trackList + ',';
                                          }
                                      }
                                  }
                                  trackList = trackList + ']';
                                  if (Debug) log(trackList, 'info');
                                  globalTracklist = trackList;
                              } else if (v2Adapter == 'spotify-premium') {
                                  try {
                                      let tempTrackList = JSON.parse(getState(page.items[0].adapterPlayerInstance + 'player.playlist.trackListArray').val);
                                      globalTracklist = tempTrackList;
                                  } catch {
                                      log('Hello Mr. Developer something went wrong in tracklist!', 'debug');
                                  }
                              } else if (v2Adapter == 'mpd') {
                                  try {
                                      let tempTrackList = JSON.parse(getState(page.items[0].adapterPlayerInstance + 'playlist_list').val);
                                      globalTracklist = tempTrackList;
                                  } catch {
                                      log('Hello Mr. Developer something went wrong in tracklist!', 'debug');
                                  }
                              }
                  
                              if (globalTracklist != null && globalTracklist.length != 0) {
                                  trackListIconCol = rgb_dec565(HMIOn);
                                  trackListString =
                                      'input_sel' + '~' + tid + '?tracklist' + '~' + Icons.GetIcon('animation-play-outline') + '~' + trackListIconCol + '~' + findLocale('media', 'tracklist') + '~' + 'media2~';
                              }
                  
                              // InSel/Slider EQ
                              let equalizerListString: string = '~~~~~~';
                              let equalizerListIconCol = rgb_dec565(HMIOff);
                  
                              if (page.items[0].equalizerList != undefined) {
                                  equalizerListIconCol = rgb_dec565(HMIOn);
                                  equalizerListString =
                                      'input_sel' + '~' + tid + '?equalizer' + '~' + Icons.GetIcon('equalizer-outline') + '~' + equalizerListIconCol + '~' + findLocale('media', 'equalizer') + '~' + 'media3~';
                              } else if (page.items[0].equalizerSlider != undefined && v2Adapter == 'alexa2') {
                                  equalizerListIconCol = rgb_dec565(HMIOn);
                                  equalizerListString =
                                      'slider' + '~' + tid + '~' + Icons.GetIcon('equalizer-outline') + '~' + equalizerListIconCol + '~' + findLocale('media', 'equalizer') + '~' + 'media3~';
                              } else if (page.items[0].equalizerList == undefined && v2Adapter == 'sonos') {
                                  let equalizerListIconCol = rgb_dec565(HMIOn);
                                  //equalizerListString is used for favariteList
                                  equalizerListString =
                                      'input_sel' + '~' + tid + '?favorites' + '~' + Icons.GetIcon('playlist-star') + '~' + equalizerListIconCol + '~' + findLocale('media', 'favorites') + '~' + 'media3~';
                              }
                  
                              //Repeat Control Button
                              let repeatIcon = Icons.GetIcon('repeat-variant');
                              let repeatIconCol = rgb_dec565(HMIOff);
                              let repeatButtonString: string = '~~~~~~';
                  
                              if (v2Adapter == 'spotify-premium') {
                                  if (getState(id + '.REPEAT').val == 'context') {
                                      repeatIcon = Icons.GetIcon('repeat-variant');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  } else if (getState(id + '.REPEAT').val == 'track') {
                                      repeatIcon = Icons.GetIcon('repeat-once');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  }
                              } else if (v2Adapter == 'alexa2') {
                                  if (getState(id + '.REPEAT').val == true) {
                                      repeatIcon = Icons.GetIcon('repeat-variant');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  }
                              } else if (v2Adapter == 'sonos') {
                                  if (getState(id + '.REPEAT').val == 1) {
                                      repeatIcon = Icons.GetIcon('repeat-variant');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  } else if (getState(id + '.REPEAT').val == 2) {
                                      repeatIcon = Icons.GetIcon('repeat-once');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  }
                              } else if (v2Adapter == 'bosesoundtouch') {
                                  if (getState(id + '.REPEAT').val == 'REPEAT_ALL') {
                                      repeatIcon = Icons.GetIcon('repeat-variant');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  } else if (getState(id + '.REPEAT').val == 'REPEAT_ONE') {
                                      repeatIcon = Icons.GetIcon('repeat-once');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  }
                              } else if (v2Adapter == 'squeezeboxrpc') {
                                  if (getState(id + '.REPEAT').val == 1) {
                                      repeatIcon = Icons.GetIcon('repeat-once');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  } else if (getState(id + '.REPEAT').val == 2) {
                                      repeatIcon = Icons.GetIcon('repeat');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  }
                              } else if (v2Adapter == 'volumio') {
                                  /* Volumio: only Repeat true/false with API */
                                  if (getState(id + '.REPEAT').val == true) {
                                      repeatIcon = Icons.GetIcon('repeat-variant');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  }
                              } else if (v2Adapter == 'mpd') {
                                  if (getState(id + '.REPEAT').val == true && getState(id + '.SINGLE').val == 0) {
                                      repeatIcon = Icons.GetIcon('repeat');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  } else if (getState(id + '.REPEAT').val == true && getState(id + '.SINGLE').val == 1) {
                                      repeatIcon = Icons.GetIcon('repeat-once');
                                      repeatIconCol = rgb_dec565(HMIOn);
                                  }
                              }
                  
                              if (v2Adapter == 'spotify-premium' || v2Adapter == 'alexa2' || v2Adapter == 'sonos' || v2Adapter == 'bosesoundtouch' || v2Adapter == 'volumio' || v2Adapter == 'squeezeboxrpc' || v2Adapter == 'mpd') {
                                  repeatButtonString = 'button' + '~' + tid + '?repeat' + '~' + repeatIcon + '~' + repeatIconCol + '~' + 'Repeat' + '~' + 'media4';
                              }
                  
                              //popUp Tools
                              let toolsString: string = '~~~~~~';
                              let toolsIconCol = rgb_dec565(colMediaIcon);
                              if (v2Adapter == 'sonos' || v2Adapter == 'mpd') {
                                  if (page.items[0].crossfade == undefined || page.items[0].crossfade == false) {
                                      toolsString = 'input_sel' + '~' + tid + '?seek' + '~' + media_icon + '~' + toolsIconCol + '~' + findLocale('media', 'seek') + '~' + 'media5~';
                                  } else {
                                      toolsString = 'input_sel' + '~' + tid + '?crossfade' + '~' + media_icon + '~' + toolsIconCol + '~' + findLocale('media', 'crossfade') + '~' + 'media5~';
                                  }
                              } else if (v2Adapter == 'squeezeboxrpc') {
                                  if (page.items[0].crossfade == undefined || page.items[0].crossfade == false) {
                                      toolsString = 'input_sel' + '~' + tid + '?seek' + '~' + media_icon + '~' + toolsIconCol + '~' + findLocale('media', 'seek') + '~' + 'media5~';
                                  }
                              } else if (v2Adapter == 'spotify-premium') {
                                  if (page.items[0].crossfade == undefined || page.items[0].crossfade == false) {
                                      toolsString = 'input_sel' + '~' + tid + '?seek' + '~' + media_icon + '~' + toolsIconCol + '~' + findLocale('media', 'seek') + '~' + 'media5~';
                                  }
                              } else {
                                  toolsString = 'button' + '~' + tid + '' + '~' + media_icon + '~' + toolsIconCol + '~' + findLocale('media', 'tools') + '~' + 'media5~';
                              }
                  
                              out_msgs.push({
                                  payload:
                                      'entityUpd~' + //entityUpd
                                      name +
                                      '~' + //heading
                                      getNavigationString(pageId) +
                                      '~' + //navigation
                                      tid +
                                      '~' + //internalNameEntiy
                                      title +
                                      '~' + //title
                                      rgb_dec565(colMediaTitle) +
                                      '~' + //titleColor
                                      author +
                                      '~' + //author
                                      rgb_dec565(colMediaArtist) +
                                      '~' + //authorColor
                                      volume +
                                      '~' + //volume
                                      iconplaypause +
                                      '~' + //playpauseicon
                                      onoffbutton +
                                      '~' + //On/Off Button Color
                                      shuffle_icon +
                                      '~' + //iconShuffle                     --> Code
                                      toolsString +
                                      speakerListString +
                                      playListString +
                                      trackListString +
                                      equalizerListString +
                                      repeatButtonString,
                              });
                          }
                          if (Debug) {
                              log('GenerateMediaPage payload: ' + JSON.stringify(out_msgs), 'info');
                          }
                          return out_msgs;
                      } catch (err: any) {
                          log('error at function GenerateMediaPage: ' + err.message, 'warn');
                          return [];
                      }
                  }
                  

                  Danke euch!

                  1 Antwort Letzte Antwort
                  1
                  • A Offline
                    A Offline
                    australien
                    schrieb am zuletzt editiert von australien
                    #8103

                    da ich seit geraumer Zeit folgende Fehlermelungen bekomme:

                    javascript.0	14:13:02.803	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:02.804	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:11.799	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:11.800	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:20.907	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:20.907	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:29.924	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:29.924	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:38.948	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:38.948	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:47.996	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    
                    javascript.0	14:13:47.996	warn	
                    
                    Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                    

                    hab ich von 5_1_1_1 auf 5_1_1_7 upgedatet, leider noch immer alles beim allten.

                    Tasmota 15.0.1

                    javascript.0	14:15:29.238	info	
                    
                    --- start of NsPanelTs: 0_userdata.0.NSPanel.Kueche. ---
                    
                    javascript.0	14:15:29.250	info	
                    
                    setObjects enabled - create Alias Channels possible
                    
                    javascript.0	14:15:29.254	info	
                    
                    weather alias for pirate-weather.0. already exists
                    
                    javascript.0	14:15:29.271	info	
                    
                    registered 41 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                    
                    javascript.0	14:15:29.276	info	
                    
                    Updates for NSPanel available
                    
                    javascript.0	14:15:29.365	info	
                    
                    Desired TFT Firmware: 61 / v5.1.1
                    
                    javascript.0	14:15:29.365	info	
                    
                    Installed TFT Firmware: 61 / v5.1.1
                    
                    javascript.0	14:15:29.479	info	
                    
                    Debug mode disabled
                    
                    javascript.0	14:15:30.108	info	
                    
                    hidden Cards disabled
                    
                    javascript.0	14:15:32.279	info	
                    
                    Start MQTT-Port-Check -------------------------------------
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- admin.0                   - 8081
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- influxdb.0                - 8086
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- mqtt.0                    - 1886
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- mqtt.1                    - 1883
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- proxmox.0                 - 8006
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- shelly.0                  - 1882
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- simple-api.0              - 8087
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- sonoff.0                  - 1884
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- telegram.0                - 8443
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- unifi-network.0           - 1144
                    
                    javascript.0	14:15:32.279	info	
                    
                    -- web.0                     - 8082
                    
                    javascript.0	14:15:32.279	info	
                    
                    - MQTT-Port-Check OK: Instance of Adapter: mqtt.0 is running on Port:1886
                    
                    javascript.0	14:15:32.279	info	
                    
                    End MQTT-Port-Check ---------------------------------------
                    
                    ArmilarA 1 Antwort Letzte Antwort
                    0
                    • A australien

                      da ich seit geraumer Zeit folgende Fehlermelungen bekomme:

                      javascript.0	14:13:02.803	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:02.804	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:11.799	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:11.800	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:20.907	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:20.907	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:29.924	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:29.924	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:38.948	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:38.948	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:47.996	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      
                      javascript.0	14:13:47.996	warn	
                      
                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.
                      

                      hab ich von 5_1_1_1 auf 5_1_1_7 upgedatet, leider noch immer alles beim allten.

                      Tasmota 15.0.1

                      javascript.0	14:15:29.238	info	
                      
                      --- start of NsPanelTs: 0_userdata.0.NSPanel.Kueche. ---
                      
                      javascript.0	14:15:29.250	info	
                      
                      setObjects enabled - create Alias Channels possible
                      
                      javascript.0	14:15:29.254	info	
                      
                      weather alias for pirate-weather.0. already exists
                      
                      javascript.0	14:15:29.271	info	
                      
                      registered 41 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                      
                      javascript.0	14:15:29.276	info	
                      
                      Updates for NSPanel available
                      
                      javascript.0	14:15:29.365	info	
                      
                      Desired TFT Firmware: 61 / v5.1.1
                      
                      javascript.0	14:15:29.365	info	
                      
                      Installed TFT Firmware: 61 / v5.1.1
                      
                      javascript.0	14:15:29.479	info	
                      
                      Debug mode disabled
                      
                      javascript.0	14:15:30.108	info	
                      
                      hidden Cards disabled
                      
                      javascript.0	14:15:32.279	info	
                      
                      Start MQTT-Port-Check -------------------------------------
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- admin.0                   - 8081
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- influxdb.0                - 8086
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- mqtt.0                    - 1886
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- mqtt.1                    - 1883
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- proxmox.0                 - 8006
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- shelly.0                  - 1882
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- simple-api.0              - 8087
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- sonoff.0                  - 1884
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- telegram.0                - 8443
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- unifi-network.0           - 1144
                      
                      javascript.0	14:15:32.279	info	
                      
                      -- web.0                     - 8082
                      
                      javascript.0	14:15:32.279	info	
                      
                      - MQTT-Port-Check OK: Instance of Adapter: mqtt.0 is running on Port:1886
                      
                      javascript.0	14:15:32.279	info	
                      
                      End MQTT-Port-Check ---------------------------------------
                      
                      ArmilarA Offline
                      ArmilarA Offline
                      Armilar
                      Most Active Forum Testing
                      schrieb zuletzt editiert von Armilar
                      #8104

                      @australien sagte:

                      Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet.

                      Das Skript prüft mit dem Start korrekt und sendet die auch, dass es keine Portüberschneidungen gibt (unterer Log-Auszug)

                      Da der Fehler aber mit Please wait a few seconds longer when launching the NSPanel. Not all parameters are loaded yet. ausgegeben wird, gehe ich mal von einer fehlerhaften Seiten-Konfiguration aus, da diese Meldung im Seitenaufbau der function GeneratePage eigentlich ein abgefangener Error: Cannot read properties of undefined (reading 'type') ist und als nur Warnung ausgegeben wird.

                      Die Fehlermeldung Cannot read properties of undefined (reading 'type') ist ein JavaScript-Fehler. Er bedeutet, dass der Code versucht, auf die Eigenschaft .type eines Objekts zuzugreifen, dieses Objekt zu diesem Zeitpunkt aber überhaupt nicht existiert (es ist undefined).

                      Also kein Zeitproblem, sondern eine fehlerhafte oder fehlende Seitendefinition (oder fehlender Datenpunkt) führt zu deinem Problem.

                      Kannst du die Seite eingrenzen und sehen, wann der Fehler passiert? Dann wäre das der Anhaltspunkt zur Suche in der Seiten-Konfiguration.

                      Den Screensaver würde ich aktuell ausschließen, da der andere Funktionen durchläuft...

                      Installationsanleitung, Tipps, Alias-Definitionen, FAQ für das Sonoff NSPanel mit lovelace UI unter ioBroker
                      https://github.com/joBr99/nspanel-lovelace-ui/wiki

                      Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                      1 Antwort Letzte Antwort
                      0

                      Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

                      Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

                      Mit deinem Input könnte dieser Beitrag noch besser werden 💗

                      Registrieren Anmelden
                      Antworten
                      • In einem neuen Thema antworten
                      Anmelden zum Antworten
                      • Älteste zuerst
                      • Neuste zuerst
                      • Meiste Stimmen


                      Support us

                      ioBroker
                      Community Adapters
                      Donate

                      555

                      Online

                      33.0k

                      Benutzer

                      83.3k

                      Themen

                      1.3m

                      Beiträge
                      Community
                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                      ioBroker Community 2014-2026
                      logo
                      • Anmelden

                      • Du hast noch kein Konto? Registrieren

                      • Anmelden oder registrieren, um zu suchen
                      • Erster Beitrag
                        Letzter Beitrag
                      0
                      • Home
                      • Aktuell
                      • Tags
                      • Ungelesen 0
                      • Kategorien
                      • Unreplied
                      • Beliebt
                      • GitHub
                      • Docu
                      • Hilfe