Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

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

Community Forum

  1. ioBroker Community Home
  2. Deutsch
  3. Hardware
  4. SONOFF NSPanel mit Lovelace UI

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.2k

SONOFF NSPanel mit Lovelace UI

Geplant Angeheftet Gesperrt Verschoben Hardware
lovelace uinspanelsonoff
7.8k Beiträge 272 Kommentatoren 6.7m Aufrufe 254 Watching
  • Ä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.
  • T Offline
    T Offline
    tklein
    schrieb am zuletzt editiert von
    #2662

    Hallo,

    wie kann ich am besten einen Temperaturslider ähnlich der Lautstärke auf einen View neben zusatzlichen Werten bekommen? Der Tempbereich geht von 10-40 Grad. Ein Thermostatview ist dafür zu "viel".

    Gruß
    Thomas

    T 1 Antwort Letzte Antwort
    0
    • T tklein

      Hallo,

      wie kann ich am besten einen Temperaturslider ähnlich der Lautstärke auf einen View neben zusatzlichen Werten bekommen? Der Tempbereich geht von 10-40 Grad. Ein Thermostatview ist dafür zu "viel".

      Gruß
      Thomas

      T Offline
      T Offline
      TT-Tom
      schrieb am zuletzt editiert von
      #2663

      @tklein

      Ein Alias vom Typ Slider würde ich spontan sagen. Benötigt Actual und Set. Schau mal ins Wiki

      Gruß Tom
      https://github.com/tt-tom17
      Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

      NSPanel Script Wiki
      https://github.com/joBr99/nspanel-lovelace-ui/wiki

      NSPanel Adapter Wiki
      https://github.com/ticaki/ioBroker.nspanel-lovelace-ui/wiki

      T 1 Antwort Letzte Antwort
      0
      • T TT-Tom

        @tklein

        Ein Alias vom Typ Slider würde ich spontan sagen. Benötigt Actual und Set. Schau mal ins Wiki

        T Offline
        T Offline
        tklein
        schrieb am zuletzt editiert von
        #2664

        @tt-tom thx. oh man, dazu gab es sogar schon beispiele.....

        1 Antwort Letzte Antwort
        1
        • ArmilarA Armilar

          @bean

          Ich würde auch gerne einen String in der untersten Zeile anzeigen lassen, die 10 Zeichen reichen mir auch leicht, aber ich verstehe die Änderungen (markiert mit //gargano) nicht ganz, bzw. hat sich das Originalscript inzwischen verändert, sodass ich die Änderungen nicht ganz nachvollziehen kann.
          Ob mann diese Möglichkeit vielleicht im Originalscript einbauen könnte?

          Das Script hat sich an dieser Stelle nicht wirklich verändert. Es ist aber ein "Quick and Dirty" hack mit zwei Fehlern und 2 unschärfen:

          • Zunächst ist in der Definition oben ein Komma in der 2. Zeile zuviel.
          • Dann wird nach != null abgefragt. Hier werden Nachkommazahlen berechnet. Das wird dann ohne numerischen Wert auf auf einen toFixed-Fehler laufen, daher wurde die Zeile unkommentiert entfernt. Korrekter wäre, damit andere User auch weiter Freude an ihren Funktionen haben, eine weitere Abfrage einzufügen, ob der Stringwert eine Nummer repräsentiert oder nicht.
          • In boolschen oder numerischen Datenpunkten braucht keine Value-Auswertung ausgeführt werden

          Da das Prinzip aber funktioniert, könnte ich eine Änderung einbauen. Könntest du hierzu einen Issue aufmachen?

          B Offline
          B Offline
          bean
          schrieb am zuletzt editiert von
          #2665

          @armilar sagte in SONOFF NSPanel mit Lovelace UI:

          @bean

          Ich würde auch gerne einen String in der untersten Zeile anzeigen lassen, die 10 Zeichen reichen mir auch leicht, aber ich verstehe die Änderungen (markiert mit //gargano) nicht ganz, bzw. hat sich das Originalscript inzwischen verändert, sodass ich die Änderungen nicht ganz nachvollziehen kann.
          Ob mann diese Möglichkeit vielleicht im Originalscript einbauen könnte?

          Das Script hat sich an dieser Stelle nicht wirklich verändert. Es ist aber ein "Quick and Dirty" hack mit zwei Fehlern und 2 unschärfen:

          • Zunächst ist in der Definition oben ein Komma in der 2. Zeile zuviel.
          • Dann wird nach != null abgefragt. Hier werden Nachkommazahlen berechnet. Das wird dann ohne numerischen Wert auf auf einen toFixed-Fehler laufen, daher wurde die Zeile unkommentiert entfernt. Korrekter wäre, damit andere User auch weiter Freude an ihren Funktionen haben, eine weitere Abfrage einzufügen, ob der Stringwert eine Nummer repräsentiert oder nicht.
          • In boolschen oder numerischen Datenpunkten braucht keine Value-Auswertung ausgeführt werden

          Da das Prinzip aber funktioniert, könnte ich eine Änderung einbauen. Könntest du hierzu einen Issue aufmachen?

          Hab jetzt die neue 4.0.5 Version installiert:
          Wenn die ScreensaverEntityValue für in meinem Fall mrIcon2ScreensaverEntity auf einen String verweist (der mit dem Quick&Dirty-Hack funktioniert hatte), kommt ein Fehler:

          error at function HandleScreensaverStatusIcons: getState(...).val.toFixed is not a function
          
          ArmilarA 1 Antwort Letzte Antwort
          0
          • B bean

            @armilar sagte in SONOFF NSPanel mit Lovelace UI:

            @bean

            Ich würde auch gerne einen String in der untersten Zeile anzeigen lassen, die 10 Zeichen reichen mir auch leicht, aber ich verstehe die Änderungen (markiert mit //gargano) nicht ganz, bzw. hat sich das Originalscript inzwischen verändert, sodass ich die Änderungen nicht ganz nachvollziehen kann.
            Ob mann diese Möglichkeit vielleicht im Originalscript einbauen könnte?

            Das Script hat sich an dieser Stelle nicht wirklich verändert. Es ist aber ein "Quick and Dirty" hack mit zwei Fehlern und 2 unschärfen:

            • Zunächst ist in der Definition oben ein Komma in der 2. Zeile zuviel.
            • Dann wird nach != null abgefragt. Hier werden Nachkommazahlen berechnet. Das wird dann ohne numerischen Wert auf auf einen toFixed-Fehler laufen, daher wurde die Zeile unkommentiert entfernt. Korrekter wäre, damit andere User auch weiter Freude an ihren Funktionen haben, eine weitere Abfrage einzufügen, ob der Stringwert eine Nummer repräsentiert oder nicht.
            • In boolschen oder numerischen Datenpunkten braucht keine Value-Auswertung ausgeführt werden

            Da das Prinzip aber funktioniert, könnte ich eine Änderung einbauen. Könntest du hierzu einen Issue aufmachen?

            Hab jetzt die neue 4.0.5 Version installiert:
            Wenn die ScreensaverEntityValue für in meinem Fall mrIcon2ScreensaverEntity auf einen String verweist (der mit dem Quick&Dirty-Hack funktioniert hatte), kommt ein Fehler:

            error at function HandleScreensaverStatusIcons: getState(...).val.toFixed is not a function
            
            ArmilarA Offline
            ArmilarA Offline
            Armilar
            Most Active Forum Testing
            schrieb am zuletzt editiert von Armilar
            #2666

            @bean

            Hast du den unteren Teil des Scriptes 4.0.5 ausgetauscht? Ich habe die Funktion umgeschrieben.

            Wenn du die 16 Zeichen haben möchtest, dann ist das aktuell nur in der DEV so:

            FlashNextion http://nspanel.pky.eu/lui.tft
            

            function HandleScreensaverStatusIcons() austauschen müsste reichen.

            Ansonsten kurz die Definition senden...

            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.

            B 1 Antwort Letzte Antwort
            0
            • T TT-Tom

              @basti-gepp
              Mensch basti Faktor 0. das kleine 1x1 :wink: :grimacing:

              Basti GeppB Offline
              Basti GeppB Offline
              Basti Gepp
              schrieb am zuletzt editiert von
              #2667

              @tt-tom
              ja...klar...jetzt geht es :)
              Ich sehe schon ich muss noch viel lernen :)

              Aber macht schon auch Spaß das ganze und raubt mir meine Abende :D
              Aber hey, es wird schon, zumindest habe ich selber raus gefunden wie ich in einem Alias die Werte runden kann ;-)

              Danke für eure unermüdliche Hilfe, ich habe wirklich tiefsten Respekt davor wie gut Ihr euch auskennt!!

              basti

              1 Antwort Letzte Antwort
              0
              • ArmilarA Armilar

                @bean

                Hast du den unteren Teil des Scriptes 4.0.5 ausgetauscht? Ich habe die Funktion umgeschrieben.

                Wenn du die 16 Zeichen haben möchtest, dann ist das aktuell nur in der DEV so:

                FlashNextion http://nspanel.pky.eu/lui.tft
                

                function HandleScreensaverStatusIcons() austauschen müsste reichen.

                Ansonsten kurz die Definition senden...

                B Offline
                B Offline
                bean
                schrieb am zuletzt editiert von
                #2668

                @armilar Habe den kompletten unteren Teil ausgetauscht...

                die Definition:

                    mrIcon2ScreensaverEntity: 
                        { 
                            ScreensaverEntity: '0_userdata.0.Global.NextSunEvent', 
                            ScreensaverEntityIconOn: 'weather-sunset-up',
                            ScreensaverEntityIconOff: 'weather-sunset-down', 
                            ScreensaverEntityValue: '0_userdata.0.Global.NextSunEventTime',
                            ScreensaverEntityValueDecimalPlace : 0,
                            ScreensaverEntityValueUnit: '',
                            ScreensaverEntityOnColor: Yellow, 
                            ScreensaverEntityOffColor: Yellow 
                        },
                
                
                ArmilarA 1 Antwort Letzte Antwort
                0
                • B bean

                  @armilar Habe den kompletten unteren Teil ausgetauscht...

                  die Definition:

                      mrIcon2ScreensaverEntity: 
                          { 
                              ScreensaverEntity: '0_userdata.0.Global.NextSunEvent', 
                              ScreensaverEntityIconOn: 'weather-sunset-up',
                              ScreensaverEntityIconOff: 'weather-sunset-down', 
                              ScreensaverEntityValue: '0_userdata.0.Global.NextSunEventTime',
                              ScreensaverEntityValueDecimalPlace : 0,
                              ScreensaverEntityValueUnit: '',
                              ScreensaverEntityOnColor: Yellow, 
                              ScreensaverEntityOffColor: Yellow 
                          },
                  
                  
                  ArmilarA Offline
                  ArmilarA Offline
                  Armilar
                  Most Active Forum Testing
                  schrieb am zuletzt editiert von
                  #2669

                  @bean sagte in SONOFF NSPanel mit Lovelace UI:

                  NextSunEvent

                  Ist das boolean --> true/false?

                  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.

                  B 1 Antwort Letzte Antwort
                  0
                  • ArmilarA Armilar

                    @bean sagte in SONOFF NSPanel mit Lovelace UI:

                    NextSunEvent

                    Ist das boolean --> true/false?

                    B Offline
                    B Offline
                    bean
                    schrieb am zuletzt editiert von bean
                    #2670

                    @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                    @bean sagte in SONOFF NSPanel mit Lovelace UI:

                    NextSunEvent

                    Ist das boolean --> true/false?

                    Ja genau, das sorgt für das richtige Icon.
                    NextSunEventTime ist dann ein String, in etwas "18:12"

                    ArmilarA 1 Antwort Letzte Antwort
                    0
                    • B bean

                      @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                      @bean sagte in SONOFF NSPanel mit Lovelace UI:

                      NextSunEvent

                      Ist das boolean --> true/false?

                      Ja genau, das sorgt für das richtige Icon.
                      NextSunEventTime ist dann ein String, in etwas "18:12"

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

                      @bean

                      Tausch die mal aus:

                      function HandleScreensaverStatusIcons() : void {
                          try {
                              let payloadString = '';
                              let hwBtn1Col: any = config.mrIcon1ScreensaverEntity.ScreensaverEntityOffColor;
                              if (config.mrIcon1ScreensaverEntity.ScreensaverEntity != null) {
                                  if (typeof (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) == 'string') {
                                      let hwBtn1: string = getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val;
                                      if (hwBtn1 == 'ON') {
                                          hwBtn1Col = config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor;
                                      }
                                      if (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) {
                                          payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                      } else {
                                          if (config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                              payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff);
                                          } else {
                                              payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                          }
                                      } 
                                      if (config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null) {
                                          if (isNaN(getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                              payloadString += (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon1ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                              payloadString += config.mrIcon1ScreensaverEntity.ScreensaverEntityValueUnit;
                                          } else {
                                              payloadString += getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val
                                          }                        
                                      }
                                      payloadString += '~' + rgb_dec565(hwBtn1Col) + '~';
                                  } else if (typeof (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) == 'boolean') {
                                      let hwBtn1: boolean = getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val;
                                      if (hwBtn1) {
                                          hwBtn1Col = config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor;
                                      }
                                      if (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) {
                                          payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                      } else {
                                          if (config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                              payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff);
                                          } else {
                                              payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                          }
                                      } 
                                      if (config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null) {
                                          if (isNaN(getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                              payloadString += (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon1ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                              payloadString += config.mrIcon1ScreensaverEntity.ScreensaverEntityValueUnit;
                                          } else {
                                              payloadString += getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val
                                          }                      
                                      }
                                      payloadString += '~' + rgb_dec565(hwBtn1Col) + '~';
                                  }
                              } else if (config.mrIcon1ScreensaverEntity.ScreensaverEntity == null && config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null){
                                  
                                  if(config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor != null){
                                      hwBtn1Col = config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor;
                                  }
                                  if(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn != null){
                                      payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                  }
                                  
                                  if (config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null) {
                                      if (isNaN(getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                          payloadString += (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon1ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                          payloadString += config.mrIcon1ScreensaverEntity.ScreensaverEntityValueUnit;
                                      } else {
                                          payloadString += getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val
                                      }                        
                                  }
                                  payloadString += '~' + rgb_dec565(hwBtn1Col) + '~';
                              }
                              else {
                                  hwBtn1Col = Black;
                                  payloadString += '~~';
                              }
                      
                              let hwBtn2Col: any = config.mrIcon2ScreensaverEntity.ScreensaverEntityOffColor;
                              if (config.mrIcon2ScreensaverEntity.ScreensaverEntity != null) {
                                  if (typeof (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) == 'string') {
                                      let hwBtn2: string = getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val;
                                      if (hwBtn2 == 'ON') {
                                          hwBtn2Col = config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor;
                                      }
                                      if (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) {
                                          payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                      } else {
                                          if (config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                              payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff);
                                          } else {
                                              payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                          }
                                      } 
                                      if (config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null) {
                                          console.log()
                                          if (isNaN(getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                              payloadString += (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon2ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                              payloadString += config.mrIcon2ScreensaverEntity.ScreensaverEntityValueUnit;
                                          } else {
                                              payloadString += getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val
                                          }                        
                                      }
                                      payloadString += '~' + rgb_dec565(hwBtn2Col) + '~';
                                  } else if (typeof (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) == 'boolean') {
                                      let hwBtn2: boolean = getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val;
                                      if (hwBtn2) {
                                          hwBtn2Col = config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor;
                                      }
                                      if (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) {
                                          payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                      } else {
                                          if (config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                              payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff);
                                          } else {
                                              payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                          }
                                      } 
                                      if (config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null) {
                                          if (isNaN(getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                              payloadString += (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon2ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                              payloadString += config.mrIcon2ScreensaverEntity.ScreensaverEntityValueUnit;
                                          } else {
                                              payloadString += getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val
                                          }                        
                                      }
                                      payloadString += '~' + rgb_dec565(hwBtn2Col) + '~';
                                  }
                              } else if (config.mrIcon2ScreensaverEntity.ScreensaverEntity == null && config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null){
                                  
                                  if(config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor != null){
                                      hwBtn2Col = config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor;
                                  }
                      
                                  if(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn != null){
                                      payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                  }
                                  
                                  if (config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null) {
                                      if (isNaN(getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                          payloadString += (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon2ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                          payloadString += config.mrIcon2ScreensaverEntity.ScreensaverEntityValueUnit;
                                      } else {
                                          payloadString += getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val
                                      }                                            
                                  }
                                  payloadString += '~' + rgb_dec565(hwBtn2Col) + '~';
                              } else {
                                  hwBtn2Col = Black;
                                  payloadString += '~~';
                              }
                      
                              let alternateScreensaverMFRIcon1Size = getState(NSPanel_Path + 'Config.MRIcons.alternateMRIconSize.1').val
                              let alternateScreensaverMFRIcon2Size = getState(NSPanel_Path + 'Config.MRIcons.alternateMRIconSize.2').val
                              //Alternate MRIcon Size
                              if (alternateScreensaverMFRIcon1Size) {
                                  payloadString += '1~';
                              } else {
                                  payloadString += '~';
                              }
                              if (alternateScreensaverMFRIcon2Size) {
                                  payloadString += '1~';
                              } else {
                                  payloadString += '~';
                              }
                      
                              SendToPanel(<Payload>{ payload: 'statusUpdate~' + payloadString });
                      
                          } catch (err) {
                              console.warn('error at function HandleScreensaverStatusIcons: ' + err.message);
                          }
                      }
                      

                      Ist jetzt auch auf Bool erweitert

                      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.

                      B 1 Antwort Letzte Antwort
                      2
                      • ArmilarA Armilar

                        @bean

                        Tausch die mal aus:

                        function HandleScreensaverStatusIcons() : void {
                            try {
                                let payloadString = '';
                                let hwBtn1Col: any = config.mrIcon1ScreensaverEntity.ScreensaverEntityOffColor;
                                if (config.mrIcon1ScreensaverEntity.ScreensaverEntity != null) {
                                    if (typeof (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) == 'string') {
                                        let hwBtn1: string = getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val;
                                        if (hwBtn1 == 'ON') {
                                            hwBtn1Col = config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor;
                                        }
                                        if (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) {
                                            payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                        } else {
                                            if (config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                                payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff);
                                            } else {
                                                payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                            }
                                        } 
                                        if (config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null) {
                                            if (isNaN(getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                                payloadString += (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon1ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                                payloadString += config.mrIcon1ScreensaverEntity.ScreensaverEntityValueUnit;
                                            } else {
                                                payloadString += getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val
                                            }                        
                                        }
                                        payloadString += '~' + rgb_dec565(hwBtn1Col) + '~';
                                    } else if (typeof (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) == 'boolean') {
                                        let hwBtn1: boolean = getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val;
                                        if (hwBtn1) {
                                            hwBtn1Col = config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor;
                                        }
                                        if (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntity).val) {
                                            payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                        } else {
                                            if (config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                                payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOff);
                                            } else {
                                                payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                            }
                                        } 
                                        if (config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null) {
                                            if (isNaN(getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                                payloadString += (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon1ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                                payloadString += config.mrIcon1ScreensaverEntity.ScreensaverEntityValueUnit;
                                            } else {
                                                payloadString += getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val
                                            }                      
                                        }
                                        payloadString += '~' + rgb_dec565(hwBtn1Col) + '~';
                                    }
                                } else if (config.mrIcon1ScreensaverEntity.ScreensaverEntity == null && config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null){
                                    
                                    if(config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor != null){
                                        hwBtn1Col = config.mrIcon1ScreensaverEntity.ScreensaverEntityOnColor;
                                    }
                                    if(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn != null){
                                        payloadString += Icons.GetIcon(config.mrIcon1ScreensaverEntity.ScreensaverEntityIconOn);
                                    }
                                    
                                    if (config.mrIcon1ScreensaverEntity.ScreensaverEntityValue != null) {
                                        if (isNaN(getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                            payloadString += (getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon1ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                            payloadString += config.mrIcon1ScreensaverEntity.ScreensaverEntityValueUnit;
                                        } else {
                                            payloadString += getState(config.mrIcon1ScreensaverEntity.ScreensaverEntityValue).val
                                        }                        
                                    }
                                    payloadString += '~' + rgb_dec565(hwBtn1Col) + '~';
                                }
                                else {
                                    hwBtn1Col = Black;
                                    payloadString += '~~';
                                }
                        
                                let hwBtn2Col: any = config.mrIcon2ScreensaverEntity.ScreensaverEntityOffColor;
                                if (config.mrIcon2ScreensaverEntity.ScreensaverEntity != null) {
                                    if (typeof (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) == 'string') {
                                        let hwBtn2: string = getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val;
                                        if (hwBtn2 == 'ON') {
                                            hwBtn2Col = config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor;
                                        }
                                        if (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) {
                                            payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                        } else {
                                            if (config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                                payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff);
                                            } else {
                                                payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                            }
                                        } 
                                        if (config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null) {
                                            console.log()
                                            if (isNaN(getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                                payloadString += (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon2ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                                payloadString += config.mrIcon2ScreensaverEntity.ScreensaverEntityValueUnit;
                                            } else {
                                                payloadString += getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val
                                            }                        
                                        }
                                        payloadString += '~' + rgb_dec565(hwBtn2Col) + '~';
                                    } else if (typeof (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) == 'boolean') {
                                        let hwBtn2: boolean = getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val;
                                        if (hwBtn2) {
                                            hwBtn2Col = config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor;
                                        }
                                        if (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntity).val) {
                                            payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                        } else {
                                            if (config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff != null) {
                                                payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOff);
                                            } else {
                                                payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                            }
                                        } 
                                        if (config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null) {
                                            if (isNaN(getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                                payloadString += (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon2ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                                payloadString += config.mrIcon2ScreensaverEntity.ScreensaverEntityValueUnit;
                                            } else {
                                                payloadString += getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val
                                            }                        
                                        }
                                        payloadString += '~' + rgb_dec565(hwBtn2Col) + '~';
                                    }
                                } else if (config.mrIcon2ScreensaverEntity.ScreensaverEntity == null && config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null){
                                    
                                    if(config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor != null){
                                        hwBtn2Col = config.mrIcon2ScreensaverEntity.ScreensaverEntityOnColor;
                                    }
                        
                                    if(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn != null){
                                        payloadString += Icons.GetIcon(config.mrIcon2ScreensaverEntity.ScreensaverEntityIconOn);
                                    }
                                    
                                    if (config.mrIcon2ScreensaverEntity.ScreensaverEntityValue != null) {
                                        if (isNaN(getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val) == false) {
                                            payloadString += (getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val).toFixed(config.mrIcon2ScreensaverEntity.ScreensaverEntityValueDecimalPlace);
                                            payloadString += config.mrIcon2ScreensaverEntity.ScreensaverEntityValueUnit;
                                        } else {
                                            payloadString += getState(config.mrIcon2ScreensaverEntity.ScreensaverEntityValue).val
                                        }                                            
                                    }
                                    payloadString += '~' + rgb_dec565(hwBtn2Col) + '~';
                                } else {
                                    hwBtn2Col = Black;
                                    payloadString += '~~';
                                }
                        
                                let alternateScreensaverMFRIcon1Size = getState(NSPanel_Path + 'Config.MRIcons.alternateMRIconSize.1').val
                                let alternateScreensaverMFRIcon2Size = getState(NSPanel_Path + 'Config.MRIcons.alternateMRIconSize.2').val
                                //Alternate MRIcon Size
                                if (alternateScreensaverMFRIcon1Size) {
                                    payloadString += '1~';
                                } else {
                                    payloadString += '~';
                                }
                                if (alternateScreensaverMFRIcon2Size) {
                                    payloadString += '1~';
                                } else {
                                    payloadString += '~';
                                }
                        
                                SendToPanel(<Payload>{ payload: 'statusUpdate~' + payloadString });
                        
                            } catch (err) {
                                console.warn('error at function HandleScreensaverStatusIcons: ' + err.message);
                            }
                        }
                        

                        Ist jetzt auch auf Bool erweitert

                        B Offline
                        B Offline
                        bean
                        schrieb am zuletzt editiert von
                        #2672

                        @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                        Tausch die mal aus:

                        :+1: Scheint zu funktionieren (Sehe das Panel gerade nicht, aber keine Fehler im Log) - Danke!

                        ArmilarA 1 Antwort Letzte Antwort
                        1
                        • B bean

                          @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                          Tausch die mal aus:

                          :+1: Scheint zu funktionieren (Sehe das Panel gerade nicht, aber keine Fehler im Log) - Danke!

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

                          @bean

                          Danke fürs testen. Übernehme ich mit ins Script :+1:

                          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
                          1
                          • B Offline
                            B Offline
                            Bhenyamin
                            schrieb am zuletzt editiert von
                            #2674

                            Hello Hello...

                            Frage zur Page Power:
                            Ich habe mich da recht erfolgreich durch das Skript für das JSON gearbeitet und es entsprechend angepasst.
                            Musste einige Werte nochmal als Datenpunkte anlegen und vorher errechnen, da mein Adapter für die LG Anlage manche Werte einfach nicht darstellt (z.B. die aktuelle Gesamtleistung der Panels)

                            Mein einziges Problem:
                            Das erste Symbol oben links auf der Seite wird immer durch die Werte der Id: 0 konfiguriert und die Id: 6 fällt quasi weg.
                            Wie ich las, ist die Id:0 ja der mittlere Balken. Hat sich da an der Config irgendwas geandert? Arbeite mit der V 4.0.4.5

                            ArmilarA 1 Antwort Letzte Antwort
                            0
                            • B Bhenyamin

                              Hello Hello...

                              Frage zur Page Power:
                              Ich habe mich da recht erfolgreich durch das Skript für das JSON gearbeitet und es entsprechend angepasst.
                              Musste einige Werte nochmal als Datenpunkte anlegen und vorher errechnen, da mein Adapter für die LG Anlage manche Werte einfach nicht darstellt (z.B. die aktuelle Gesamtleistung der Panels)

                              Mein einziges Problem:
                              Das erste Symbol oben links auf der Seite wird immer durch die Werte der Id: 0 konfiguriert und die Id: 6 fällt quasi weg.
                              Wie ich las, ist die Id:0 ja der mittlere Balken. Hat sich da an der Config irgendwas geandert? Arbeite mit der V 4.0.4.5

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

                              @bhenyamin

                              Da ist in letzter Zeit nichts mehr an der cardPower passiert - sollte Funktionieren.

                              Sende mal das JSON aus dem Datenpunkt. Dann wird es einfacher zu finden...

                              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.

                              B 1 Antwort Letzte Antwort
                              0
                              • M Offline
                                M Offline
                                marc_d0810
                                schrieb am zuletzt editiert von
                                #2676

                                @armilar said in SONOFF NSPanel mit Lovelace UI:

                                default =

                                @armilar said in SONOFF NSPanel mit Lovelace UI:

                                @ronny130286

                                Mal eine Frage, wäre es eigentlich möglich das Display Nachts komplett auszuschalten? Also sowas wie Dimmode 0

                                Ja klar, einfach nachts auf Dimmode "0" stellen. Geht eigentlich schon immer :blush:

                                EDIT:

                                per Automatik mit:
                                9cb9ab91-44a4-43cf-8947-f385c2248ed9-image.png

                                oder manuell mit:

                                e49492cc-98db-44fd-8ebf-dc083af48dc9-image.png

                                null = default = Automatik

                                Hey @Armilar,

                                wie bekomme ich denn den Modus wieder auf (null) = automatik?
                                Ich hatte zum testen einen Wert eingestellt, da die automatik bei mir irgendwie nicht funktioniert.
                                Zur eingestellten Zeit, wird nicht runtergedimmt sondern bleibt auf dem Tageswert.

                                Ich habe gerade auch im LOG gesehen, dass es ab und zu folgende Fehler gibt.
                                Kann ich aber irgendwie nicht so recht was draus erkennen :-(

                                Bildschirm­foto 2023-03-28 um 19.31.04.png

                                ArmilarA 1 Antwort Letzte Antwort
                                0
                                • M marc_d0810

                                  @armilar said in SONOFF NSPanel mit Lovelace UI:

                                  default =

                                  @armilar said in SONOFF NSPanel mit Lovelace UI:

                                  @ronny130286

                                  Mal eine Frage, wäre es eigentlich möglich das Display Nachts komplett auszuschalten? Also sowas wie Dimmode 0

                                  Ja klar, einfach nachts auf Dimmode "0" stellen. Geht eigentlich schon immer :blush:

                                  EDIT:

                                  per Automatik mit:
                                  9cb9ab91-44a4-43cf-8947-f385c2248ed9-image.png

                                  oder manuell mit:

                                  e49492cc-98db-44fd-8ebf-dc083af48dc9-image.png

                                  null = default = Automatik

                                  Hey @Armilar,

                                  wie bekomme ich denn den Modus wieder auf (null) = automatik?
                                  Ich hatte zum testen einen Wert eingestellt, da die automatik bei mir irgendwie nicht funktioniert.
                                  Zur eingestellten Zeit, wird nicht runtergedimmt sondern bleibt auf dem Tageswert.

                                  Ich habe gerade auch im LOG gesehen, dass es ab und zu folgende Fehler gibt.
                                  Kann ich aber irgendwie nicht so recht was draus erkennen :-(

                                  Bildschirm­foto 2023-03-28 um 19.31.04.png

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

                                  @marc_d0810

                                  In 0_userdata.0.NSPanel.1.ScreensaverInfo.activeDimmodeBrightness einfach null reinschreiben

                                  Die Fehlermeldungen sind interessant. Gibt es die Datenpunkte nicht oder sind die leer?

                                  8970e419-a81c-459a-a3ec-177bf4bfc5b9-image.png

                                  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.

                                  M 1 Antwort Letzte Antwort
                                  0
                                  • ArmilarA Armilar

                                    @bhenyamin

                                    Da ist in letzter Zeit nichts mehr an der cardPower passiert - sollte Funktionieren.

                                    Sende mal das JSON aus dem Datenpunkt. Dann wird es einfacher zu finden...

                                    B Offline
                                    B Offline
                                    Bhenyamin
                                    schrieb am zuletzt editiert von Bhenyamin
                                    #2678

                                    @armilar

                                    Sorry... Hätte ich auch gleich drauf kommen können.
                                    Also Id: 0 steuert bei mir letzlich das Element oben links (und den mittleren Balken mit dem Home-Symbol) und die Id:1 beginnt dann beim 2. Element auf der linken Seite. Dafür fällt Id 6 weg.

                                    Vielleicht noch gleich die Frage dazu was die direction "both" bewirkt?

                                    
                                    [
                                      {
                                        "id": 0,
                                        "value": "",
                                        "unit": "",
                                        "icon": "home",
                                        "iconColor": 0
                                      },
                                      {
                                        "id": 1,
                                        "value": 0,
                                        "unit": "kW",
                                        "direction": "both,in,in,out,both,out",
                                        "icon": "solar-power-variant",
                                        "iconColor": 10,
                                        "speed": 0
                                      },
                                      {
                                        "id": 2,
                                        "value": 0,
                                        "unit": "kW",
                                        "direction": "both",
                                        "icon": "transmission-tower",
                                        "iconColor": 0,
                                        "speed": 0
                                      },
                                      {
                                        "id": 3,
                                        "value": 0.5,
                                        "unit": "kW",
                                        "direction": "out",
                                        "icon": "battery-charging-60",
                                        "iconColor": 1,
                                        "speed": 0
                                      },
                                      {
                                        "id": 4,
                                        "value": 0.4,
                                        "unit": "kW",
                                        "direction": "out",
                                        "icon": "home-lightning-bolt",
                                        "iconColor": 10,
                                        "speed": 3
                                      },
                                      {
                                        "id": 5,
                                        "value": 7,
                                        "unit": "Ct",
                                        "direction": "out",
                                        "icon": "cash-100",
                                        "iconColor": 10,
                                        "speed": 3
                                      },
                                      {
                                        "id": 6,
                                        "value": 85.8,
                                        "unit": "%",
                                        "direction": "out",
                                        "icon": "battery-50",
                                        "iconColor": 9,
                                        "speed": 2
                                      }
                                    ]
                                    
                                    ArmilarA 1 Antwort Letzte Antwort
                                    0
                                    • B Bhenyamin

                                      @armilar

                                      Sorry... Hätte ich auch gleich drauf kommen können.
                                      Also Id: 0 steuert bei mir letzlich das Element oben links (und den mittleren Balken mit dem Home-Symbol) und die Id:1 beginnt dann beim 2. Element auf der linken Seite. Dafür fällt Id 6 weg.

                                      Vielleicht noch gleich die Frage dazu was die direction "both" bewirkt?

                                      
                                      [
                                        {
                                          "id": 0,
                                          "value": "",
                                          "unit": "",
                                          "icon": "home",
                                          "iconColor": 0
                                        },
                                        {
                                          "id": 1,
                                          "value": 0,
                                          "unit": "kW",
                                          "direction": "both,in,in,out,both,out",
                                          "icon": "solar-power-variant",
                                          "iconColor": 10,
                                          "speed": 0
                                        },
                                        {
                                          "id": 2,
                                          "value": 0,
                                          "unit": "kW",
                                          "direction": "both",
                                          "icon": "transmission-tower",
                                          "iconColor": 0,
                                          "speed": 0
                                        },
                                        {
                                          "id": 3,
                                          "value": 0.5,
                                          "unit": "kW",
                                          "direction": "out",
                                          "icon": "battery-charging-60",
                                          "iconColor": 1,
                                          "speed": 0
                                        },
                                        {
                                          "id": 4,
                                          "value": 0.4,
                                          "unit": "kW",
                                          "direction": "out",
                                          "icon": "home-lightning-bolt",
                                          "iconColor": 10,
                                          "speed": 3
                                        },
                                        {
                                          "id": 5,
                                          "value": 7,
                                          "unit": "Ct",
                                          "direction": "out",
                                          "icon": "cash-100",
                                          "iconColor": 10,
                                          "speed": 3
                                        },
                                        {
                                          "id": 6,
                                          "value": 85.8,
                                          "unit": "%",
                                          "direction": "out",
                                          "icon": "battery-50",
                                          "iconColor": 9,
                                          "speed": 2
                                        }
                                      ]
                                      
                                      ArmilarA Offline
                                      ArmilarA Offline
                                      Armilar
                                      Most Active Forum Testing
                                      schrieb am zuletzt editiert von
                                      #2679

                                      @bhenyamin

                                      Ist in der Tat ein Bug drin --> Positionen sind verschoben --> Fix auf github folgt die Tage

                                      Oder direkt die Funktion austauschen:

                                      function GeneratePowerPage(page: PagePower): Payload[] {
                                          try {
                                              let obj:object;
                                              let demoMode = false;        
                                              if (page.items[0].id == undefined){
                                                  console.log("Kein PageItem definiert - cardPower Demo-Modus aktiv");
                                                  demoMode = true;
                                              }
                                      
                                              activePage = page;
                                              if (Debug) {
                                                  console.log('GeneratePowerPage PageItem.id = ' + page.items[0].id);
                                              }
                                              
                                      
                                              let heading = 'cardPower Example';
                                              if (demoMode != true) {
                                                  let id = page.items[0].id
                                                  unsubscribePowerSubscriptions();
                                                  subscribePowerSubscriptions(id);
                                      
                                                  let o = getObject(id);
                                                  heading = page.heading !== undefined ? page.heading : o.common.name.de;
                                      
                                                   obj = JSON.parse((getState(page.items[0].id + '.ACTUAL').val));
                                              }
                                              
                                              let out_msgs: Array<Payload> = [];
                                              out_msgs.push({ payload: 'pageType~cardPower' });
                                      
                                              //Demo Data if no pageItem present
                                              let array_icon_color = [White, MSGreen, MSYellow, MSGreen, MSYellow, MSGreen, MSRed];
                                              let array_icon = ['home', 'battery-charging-60', 'solar-power-variant', 'wind-turbine', 'shape', 'transmission-tower', 'car'];
                                              let array_powerspeed = ['', '-1', '2', '4', '1', '1', '5'];
                                              let array_powerstate = ['', '0,5 kW', '0,9 kW', '2,8 kW', '0,2 kW', '0,1 kW', '4,6 kW'];
                                      
                                              let arrayColorScale = [colorScale0, colorScale1, colorScale2, colorScale3, colorScale4, colorScale5, colorScale6, colorScale7, colorScale8, colorScale9, colorScale10];
                                      
                                              let homeIconColor = 0;
                                              if (!demoMode) {
                                                  for (let obji = 0; obji < 7; obji++) {
                                                      array_icon_color[obji + 1] = arrayColorScale[obj[obji].iconColor !== '' ? obj[obji].iconColor : 0];
                                                      array_icon[obji + 1] = obj[obji].icon;
                                                      array_powerspeed[obji + 1] = obj[obji].speed;
                                                      array_powerstate[obji + 1] = obj[obji].value + ' ' + obj[obji].unit ;
                                                  }
                                                  array_icon[0] = obj[0].icon;
                                                  array_powerstate[0] = obj[0].value + ' ' + obj[0].unit;
                                                  homeIconColor = obj[0].iconColor;
                                              }
                                      
                                              let power_string : any = '';
                                      
                                              for (let i = 1; i < 7; i++ ) {
                                                  power_string = power_string + '~';                                        // type (ignored)
                                                  power_string = power_string + '~';                                        // intNameEntity (ignored)
                                                  power_string = power_string + Icons.GetIcon(array_icon[i+1]) + '~';       // icon~
                                                  power_string = power_string + rgb_dec565(array_icon_color[i+1]) + '~';    // icon_color~
                                                  power_string = power_string + '~';                                        // display (ignored in TS)
                                                  power_string = power_string + array_powerstate[i+1] + '~';                // optionalValue~
                                                  power_string = power_string + array_powerspeed[i+1] + '~';                // speed~
                                      
                                                  if (Debug) console.log(power_string);
                                              }
                                      
                                              power_string = power_string.substring(0, power_string.length - 1);
                                                  
                                              out_msgs.push({
                                                  payload: 'entityUpd~' +                                 //entityUpd~*
                                                      heading                         + '~' +             //internalNameEntity*~*
                                                      GetNavigationString(pageId)     + '~' +             //navigation*~*
                                                  // Home Icon / Value below Home Icon
                                                      '' + '~' +                                          // type (ignored)
                                                      '' + '~' +                                          // intNameEntity (ignored)
                                                      Icons.GetIcon(array_icon[0])    + '~' +             // icon
                                                      rgb_dec565(array_icon_color[homeIconColor]) + '~' + // icon_color
                                                      '' + '~' +                                          // display (ignored in TS)
                                                      array_powerstate[0]             + '~' +             // optionalValue
                                                      '' + '~' +                                          // speed
                                                  // Value above Home Icon
                                                      '' + '~' +                                          // type (ignored)
                                                      '' + '~' +                                          // intNameEntity (ignored)
                                                      '' + '~' +                                          // icon
                                                      '' + '~' +                                          // icon_color
                                                      '' + '~' +                                          // display (ignored in TS)
                                                      '' + '~' +                                          // optionalValue
                                                      '' + '~' +                                          // speed~
                                                  // 1st to 6th Item
                                                      power_string
                                              });
                                              if (Debug) console.log('GeneratePowerPage payload: ' + out_msgs);
                                              return out_msgs;
                                      
                                          } catch (err) {
                                              console.warn('error at function GeneratePowerPage: ' + err.message);
                                          }
                                      }
                                      

                                      Vielleicht noch gleich die Frage dazu was die direction "both" bewirkt?

                                      "Nichts" - weder in noch out noch both wird im Script wirklich ausgewertet. Direction wird nur über das Vorzeichen in speed gesteuert. Habe da nur "in" drin stehen ;-)

                                      Im Übrigen habe ich folgende Warns in der Log: (Wenn ich doch nur peilen würde was die Position 731 ist... 😞 )

                                      Dein JSON ist valide - kann da keinen Fehler erkennen. Sieh noch mal nach dem Fix nach. Dein JSON läuft mit dem Fix bei mir...

                                      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.

                                      B 1 Antwort Letzte Antwort
                                      1
                                      • ArmilarA Armilar

                                        @bhenyamin

                                        Ist in der Tat ein Bug drin --> Positionen sind verschoben --> Fix auf github folgt die Tage

                                        Oder direkt die Funktion austauschen:

                                        function GeneratePowerPage(page: PagePower): Payload[] {
                                            try {
                                                let obj:object;
                                                let demoMode = false;        
                                                if (page.items[0].id == undefined){
                                                    console.log("Kein PageItem definiert - cardPower Demo-Modus aktiv");
                                                    demoMode = true;
                                                }
                                        
                                                activePage = page;
                                                if (Debug) {
                                                    console.log('GeneratePowerPage PageItem.id = ' + page.items[0].id);
                                                }
                                                
                                        
                                                let heading = 'cardPower Example';
                                                if (demoMode != true) {
                                                    let id = page.items[0].id
                                                    unsubscribePowerSubscriptions();
                                                    subscribePowerSubscriptions(id);
                                        
                                                    let o = getObject(id);
                                                    heading = page.heading !== undefined ? page.heading : o.common.name.de;
                                        
                                                     obj = JSON.parse((getState(page.items[0].id + '.ACTUAL').val));
                                                }
                                                
                                                let out_msgs: Array<Payload> = [];
                                                out_msgs.push({ payload: 'pageType~cardPower' });
                                        
                                                //Demo Data if no pageItem present
                                                let array_icon_color = [White, MSGreen, MSYellow, MSGreen, MSYellow, MSGreen, MSRed];
                                                let array_icon = ['home', 'battery-charging-60', 'solar-power-variant', 'wind-turbine', 'shape', 'transmission-tower', 'car'];
                                                let array_powerspeed = ['', '-1', '2', '4', '1', '1', '5'];
                                                let array_powerstate = ['', '0,5 kW', '0,9 kW', '2,8 kW', '0,2 kW', '0,1 kW', '4,6 kW'];
                                        
                                                let arrayColorScale = [colorScale0, colorScale1, colorScale2, colorScale3, colorScale4, colorScale5, colorScale6, colorScale7, colorScale8, colorScale9, colorScale10];
                                        
                                                let homeIconColor = 0;
                                                if (!demoMode) {
                                                    for (let obji = 0; obji < 7; obji++) {
                                                        array_icon_color[obji + 1] = arrayColorScale[obj[obji].iconColor !== '' ? obj[obji].iconColor : 0];
                                                        array_icon[obji + 1] = obj[obji].icon;
                                                        array_powerspeed[obji + 1] = obj[obji].speed;
                                                        array_powerstate[obji + 1] = obj[obji].value + ' ' + obj[obji].unit ;
                                                    }
                                                    array_icon[0] = obj[0].icon;
                                                    array_powerstate[0] = obj[0].value + ' ' + obj[0].unit;
                                                    homeIconColor = obj[0].iconColor;
                                                }
                                        
                                                let power_string : any = '';
                                        
                                                for (let i = 1; i < 7; i++ ) {
                                                    power_string = power_string + '~';                                        // type (ignored)
                                                    power_string = power_string + '~';                                        // intNameEntity (ignored)
                                                    power_string = power_string + Icons.GetIcon(array_icon[i+1]) + '~';       // icon~
                                                    power_string = power_string + rgb_dec565(array_icon_color[i+1]) + '~';    // icon_color~
                                                    power_string = power_string + '~';                                        // display (ignored in TS)
                                                    power_string = power_string + array_powerstate[i+1] + '~';                // optionalValue~
                                                    power_string = power_string + array_powerspeed[i+1] + '~';                // speed~
                                        
                                                    if (Debug) console.log(power_string);
                                                }
                                        
                                                power_string = power_string.substring(0, power_string.length - 1);
                                                    
                                                out_msgs.push({
                                                    payload: 'entityUpd~' +                                 //entityUpd~*
                                                        heading                         + '~' +             //internalNameEntity*~*
                                                        GetNavigationString(pageId)     + '~' +             //navigation*~*
                                                    // Home Icon / Value below Home Icon
                                                        '' + '~' +                                          // type (ignored)
                                                        '' + '~' +                                          // intNameEntity (ignored)
                                                        Icons.GetIcon(array_icon[0])    + '~' +             // icon
                                                        rgb_dec565(array_icon_color[homeIconColor]) + '~' + // icon_color
                                                        '' + '~' +                                          // display (ignored in TS)
                                                        array_powerstate[0]             + '~' +             // optionalValue
                                                        '' + '~' +                                          // speed
                                                    // Value above Home Icon
                                                        '' + '~' +                                          // type (ignored)
                                                        '' + '~' +                                          // intNameEntity (ignored)
                                                        '' + '~' +                                          // icon
                                                        '' + '~' +                                          // icon_color
                                                        '' + '~' +                                          // display (ignored in TS)
                                                        '' + '~' +                                          // optionalValue
                                                        '' + '~' +                                          // speed~
                                                    // 1st to 6th Item
                                                        power_string
                                                });
                                                if (Debug) console.log('GeneratePowerPage payload: ' + out_msgs);
                                                return out_msgs;
                                        
                                            } catch (err) {
                                                console.warn('error at function GeneratePowerPage: ' + err.message);
                                            }
                                        }
                                        

                                        Vielleicht noch gleich die Frage dazu was die direction "both" bewirkt?

                                        "Nichts" - weder in noch out noch both wird im Script wirklich ausgewertet. Direction wird nur über das Vorzeichen in speed gesteuert. Habe da nur "in" drin stehen ;-)

                                        Im Übrigen habe ich folgende Warns in der Log: (Wenn ich doch nur peilen würde was die Position 731 ist... 😞 )

                                        Dein JSON ist valide - kann da keinen Fehler erkennen. Sieh noch mal nach dem Fix nach. Dein JSON läuft mit dem Fix bei mir...

                                        B Offline
                                        B Offline
                                        Bhenyamin
                                        schrieb am zuletzt editiert von
                                        #2680

                                        @armilar

                                        Ah Supergeil!
                                        Sorry, die Logs habe ich wieder aus meinem Post genommen, da sie von heute Nachmittag waren, als ich da rum probiert habe. Fiel mir erst später auf. Sorry.
                                        Danke für den super schnellen Support! Freue mich sehr! Setzte ich gleich um!

                                        1 Antwort Letzte Antwort
                                        0
                                        • B Offline
                                          B Offline
                                          Bhenyamin
                                          schrieb am zuletzt editiert von
                                          #2681

                                          Super läuft!
                                          Kann ich denn eigentlich beeinflussen, dass die Power-Page aktualisiert wird, ohne dass ich sie neu lade (durch Blättern im Menü oder Screensaver) ?

                                          ArmilarA 1 Antwort Letzte Antwort
                                          1
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          435

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          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