Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Hardware
    4. SONOFF NSPanel mit Lovelace UI

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    SONOFF NSPanel mit Lovelace UI

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      TT-Tom @marc_d0810 last edited by

      @marc_d0810

      Deine Ausgaben in der Konsole sehen anders aus als bei mir. Vielleicht kann @Armilar nochmal rüber schauen. Dein MQTT sieht eigentlich richtig aus.

      Armilar 1 Reply Last reply Reply Quote 0
      • D
        danny_v1 @Armilar last edited by

        @armilar
        Ok alles klar, vielen Dank! Werd ich morgen mal testen.

        Hat jemand noch einen Tipp zu dem WLED Problem?

        Armilar T 3 Replies Last reply Reply Quote 0
        • Armilar
          Armilar Most Active Forum Testing @TT-Tom last edited by

          @tt-tom @marc_d0810

          Sieht soweit okay aus. Hast du da irgendetwas eingestellt, dass das Log so ausführlich ist?

          Hast du mal versucht nachzusehen, ob der Berry-Driver okay ist? Ansonsten da nochmal die Dateien rauswerfen und erneuern.

          M 1 Reply Last reply Reply Quote 0
          • Armilar
            Armilar Most Active Forum Testing @danny_v1 last edited by

            @danny_v1

            Hat jemand noch einen Tipp zu dem WLED Problem?

            Müsste erstmal sehen, wo das Problem ist. Hatte gelesen, dass im Panel alles okay ist. Werden irgendwelche Fehler im Log ausgelöst, wenn du etwas auswählst?

            1 Reply Last reply Reply Quote 0
            • Gargano
              Gargano last edited by

              Wenn man außer Zahlen auch Text in der untersten Zeile anzeigen lassen will :

              da919a68-66b2-4afb-9687-7e1522fcc12c-image.png

              Die Entity muss dann als Value den Typ "string" haben.

               mrIcon1ScreensaverEntity: 
                      { 
                          ScreensaverEntity: '0_userdata.0.trashschedule.0.next.type', 
                          ScreensaverEntityIconOn: null,,                   
                          ScreensaverEntityIconOff: null, 
                          ScreensaverEntityValue: '0_userdata.0.trashschedule.0.next.type',     
                          ScreensaverEntityValueDecimalPlace : 0,                         
                          ScreensaverEntityValueUnit: null,                               
                          ScreensaverEntityOnColor: MSRed, 
                          ScreensaverEntityOffColor: Yellow
                      },
              

              Allerdings ist der Text auf 10 Zeichen begrenzt. Ich habe bei mir das HMI angepasst, deshalb geht da mehr rein.
              Aber evtl hat ja @joBr99 bald eine Lösung.

              Und bei mir ist nicht so kalt, das ist die Simulation 😊

              Änderung im Script ( markiert mit //gargano) :

              
              // gargano new function
              function getMRIconcSreensaverValue (thisMRElement:ScreenSaverMRElement)
              {
                  let payloadString='';
                  if (thisMRElement.ScreensaverEntityValue != null) {
                      if (typeof (getState(thisMRElement.ScreensaverEntityValue).val) == 'string') {
                          payloadString = (getState(thisMRElement.ScreensaverEntityValue).val);
                      } else {
                          payloadString = (getState(thisMRElement.ScreensaverEntityValue).val).toFixed(thisMRElement.ScreensaverEntityValueDecimalPlace);
                          payloadString += thisMRElement.ScreensaverEntityValueUnit;                        
                      }                             
                  }
                  return payloadString;
              }
              
              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);
                                  }
                              } 
                              // gargano 
                              payloadString += getMRIconcSreensaverValue (config.mrIcon1ScreensaverEntity);
                              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);
                                  }
                              } 
                              // gargano 
                              payloadString += getMRIconcSreensaverValue (config.mrIcon1ScreensaverEntity);
                              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);
                          }
                          // gargano 
                          payloadString += getMRIconcSreensaverValue (config.mrIcon1ScreensaverEntity);
                          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);
                                  }
                              } 
                               // gargano 
                              payloadString += getMRIconcSreensaverValue (config.mrIcon2ScreensaverEntity);
                              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);
                                  }
                              } 
                               // gargano 
                              payloadString += getMRIconcSreensaverValue (config.mrIcon2ScreensaverEntity);
                              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);
                          }
                          // gargano 
                          payloadString += getMRIconcSreensaverValue (config.mrIcon2ScreensaverEntity);
                          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.log('HandleScreensaverStatusIcons: ' + err.message);
                  }
              }
              
              
              B 1 Reply Last reply Reply Quote 1
              • T
                TT-Tom @danny_v1 last edited by

                @danny_v1

                so habe es bei mir mal eingestellt. Funktioniert mit den Standards aus dem Wiki.
                Kontrolliere bitte deine Datenpunkte unter 0_userdata, ob die sich ändern, wenn du die Effekte oder Farbe veränderst.

                Gleichzeitig kannst du im Log kontrolieren, ob das Script mitarbeitet.

                D 1 Reply Last reply Reply Quote 0
                • M
                  marc_d0810 @Armilar last edited by marc_d0810

                  @armilar said in SONOFF NSPanel mit Lovelace UI:

                  @tt-tom @marc_d0810

                  Sieht soweit okay aus. Hast du da irgendetwas eingestellt, dass das Log so ausführlich ist?

                  Hast du mal versucht nachzusehen, ob der Berry-Driver okay ist? Ansonsten da nochmal die Dateien rauswerfen und erneuern.

                  @armilar said in SONOFF NSPanel mit Lovelace UI:

                  @tt-tom @marc_d0810

                  Sieht soweit okay aus. Hast du da irgendetwas eingestellt, dass das Log so ausführlich ist?

                  Hast du mal versucht nachzusehen, ob der Berry-Driver okay ist? Ansonsten da nochmal die Dateien rauswerfen und erneuern.

                  Ja ich hatte mal an irgendeiner Stelle das Loglevel hochgesetzt.
                  Hatte Gestern auch nochmal versucht das TFT mit der aktuellsten Version zu flashen, aber da komme ich wieder bei dem alten Fehler an. 😞
                  Something gone wrong....

                  Was ich Gestern noch gesehen habe, waren die Datenpunkte vom TFT.
                  Muss die Version so aussehen?

                  Bildschirm­foto 2023-03-15 um 18.57.24.png

                  Wie kann ich den den BerryDriver checken?

                  Armilar 1 Reply Last reply Reply Quote 0
                  • Armilar
                    Armilar Most Active Forum Testing @marc_d0810 last edited by

                    @marc_d0810

                    Den Berry analog der Wiki-Beschreibung. Alle Dateien (autoexec.be, autoexec.bec, ...) rauswerfen (Flammensymbol) und dann nach einem Tasmota-Neustart den Berry-Treiber neu erstellen. Dann erneut Rebooten...

                    Kann auch daran liegen, dass die Version nicht ermittelt werden kann. Ebenso, dass das TFT sich nicht flashen lässt.

                    M 1 Reply Last reply Reply Quote 0
                    • M
                      marc_d0810 @Armilar last edited by

                      @armilar Ich habe alles nochmal rausgeworfen und neu gemacht.
                      Aber es sieht schlecht aus 😞

                      Bildschirm­foto 2023-03-16 um 06.50.46.png

                      Ist das Ding jetzt für die Tonne?

                      T 1 Reply Last reply Reply Quote 0
                      • T
                        TT-Tom @marc_d0810 last edited by

                        @marc_d0810

                        Ich würde tasmota komplett nochmal neu aufspielen. Achte dabei das der Speicher auch mit gelöscht wird.

                        Armilar 1 Reply Last reply Reply Quote 0
                        • Armilar
                          Armilar Most Active Forum Testing @TT-Tom last edited by Armilar

                          @tt-tom @marc_d0810

                          https://forum.iobroker.net/post/960535

                          Versuche die FlashNextionAdv's in dem Post bitte alle

                          M 1 Reply Last reply Reply Quote 0
                          • D
                            danny_v1 @TT-Tom last edited by

                            @tt-tom
                            Nein da ändert sich nichts. Im Log ist aber auch nichts zu finden.

                            D T 2 Replies Last reply Reply Quote 0
                            • D
                              danny_v1 @danny_v1 last edited by

                              Bin gerade dabei mein zweites Panel in Betrieb zu nehmen. Nach dem Starten des Skripts kam folgende Fehlermeldung:
                              script.js.common.NSPanel_Kueche.NSPanelTS_403: schedule(cron=*/null * * * * *): cannot create schedule
                              Dann habe ich das Skript neu gestartet und seither ist nur der Kreisel mit waiting for content zu sehen. Woran könnte das liegen?

                              Armilar T 2 Replies Last reply Reply Quote 0
                              • T
                                TT-Tom @danny_v1 last edited by

                                @danny_v1 hast du das Panel komplett neu geflasht? Sprich als wenn es neu wäre.

                                D 1 Reply Last reply Reply Quote 0
                                • Armilar
                                  Armilar Most Active Forum Testing @danny_v1 last edited by

                                  @danny_v1

                                  Sieht für mich wie ein Problem mit dem ioBroker aus.

                                  JS-Adapter/JS-Controller/nodeJS/etc.

                                  1 Reply Last reply Reply Quote 0
                                  • T
                                    TT-Tom @danny_v1 last edited by TT-Tom

                                    @danny_v1 ist für das neue Panel, der CustomSend angelegt worden? Hast du im Script die MQTT Punkte angepasst?

                                    Die Meldung hatte ich beim ersten Start auch.

                                    schedule(cron=*/null * * * * *): cannot create schedule
                                    

                                    Dach lief es aber.

                                    Gargano 1 Reply Last reply Reply Quote 0
                                    • M
                                      marc_d0810 @Armilar last edited by

                                      @armilar said in SONOFF NSPanel mit Lovelace UI:

                                      https://forum.iobroker.net/post/960535

                                      Erstmal Danke für deine Geduld 😉
                                      Habe alles durch, aber da tut sich leider nichts.

                                      Something has gone wrong flashing display firmware [bytes('CFE6')]
                                      

                                      Kommt sofort ohne irgendwelche anderen Einträge.

                                      Könnte denn das neu Flashen, wie von @TT-Tom vorgeschlagen, helfen?

                                      Armilar 1 Reply Last reply Reply Quote 0
                                      • Armilar
                                        Armilar Most Active Forum Testing @marc_d0810 last edited by

                                        @marc_d0810

                                        Ich würde erstmal abwarten, ob @joBr99 noch einen Tipp hat. Ist eigentlich mehr ein TFT-Problem... Also Berry und Nextion

                                        M 1 Reply Last reply Reply Quote 0
                                        • Gargano
                                          Gargano @TT-Tom last edited by

                                          @tt-tom

                                          schedule(cron=*/null * * * * *): cannot create schedule```
                                          

                                          Das kommt wenn in

                                          0_userdata.0.NSPanels.....ScreensaverInfo.entityChangeTime = null
                                          

                                          steht.

                                          Evtl. wird der Cron vor dem Setzen des Wertes gestartet (ein Henne / Ei Problem)

                                          1 Reply Last reply Reply Quote 0
                                          • Gargano
                                            Gargano last edited by Gargano

                                            @tt-tom sagte in SONOFF NSPanel mit Lovelace UI:

                                            Das ist ja auch meine Vermutung gewesen. Wir hatten dieses Phänomen schon ein paar Mal beobachten können, das im Hintergrund die alte Datei mit gelaufen ist.

                                            Das kommt daher, weil einige Schedules laufen, die aber mit dem Stoppen des Scripts nicht auch gestoppt werden und trotzdem weiterlaufen.
                                            Diese müssen explizit gestoppt werden.

                                            Siehe Doku JS Adapter hier

                                            onStop() ist die Funktion die benötigt wird.
                                            In der müssen dann alle Schedules gestoppt werden.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            515
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            lovelace ui nspanel sonoff
                                            265
                                            7321
                                            5035671
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo