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

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    SONOFF NSPanel mit Lovelace UI

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      SirMiker @Armilar last edited by SirMiker

      @armilar
      wirklich vielen dank für die ausführliche Erklärung!

      das mit der Pages klappt null bei mir....und ich verstehe auch mit durchlesen gar nicht was ich da machen muss...sorry...denke da habe ich mir diesmal eindeutig Zuviel vor genommen 😞

       pages: [
              
      
                  NSPanel_Service         	//Auto-Alias Service Page
      	    //Unlock_Service            //Auto-Alias Service Page (Service Pages used with cardUnlock)
          ],
          
      

      Dort muss ich nach Pages den Namen einfügen den ich vergeben habe oder?

      Armilar 1 Reply Last reply Reply Quote 0
      • Stephan L
        Stephan L last edited by

        Ich verwende das 'alternative' screensaver Layout.
        Leider scheint das ein paar Problemchen zu haben.

        Links sind 2 Eintraege uebereinander, daneben sind 3 weitere nebeneinander.

        Problem: Der OBERE auf der linken Seite ist bei ioBroker IMMER das Wetter!
        Im Script zu finden beim Komentar (//Create Weather MainIcon)

        Mein Panel mit AppDaemon:
        d4b300a4-32ba-4a70-9a65-6c213ff5569f-image.png

        Hier im Bild von AppDaemon sieht man dass ich dort was anderes hingelegt habe. Habe das aktuelle Wetter als erstes in der 3er Reihe (geht aber auch ganz ohne Wetter, meine Wahl)

        Ich ja bereits alle Werte und Infos in HA, daher verwende ich den ioBroker HA Adapter. Genial...
        Von dort kommt auch mein momentaner Stromverbrauch. Den konnte ich auch mit ioBroker anzeigen lassen. Aber warum auch immer wurde der Wert als 'String' erkannt. Und im Code gibt es dubiose logik die dann den Wert, z.B. "793" als DATUM umformatiert.
        Dafuer konnte ich einen einfachen Fix machen.

        Ein String x, der folgendes erfuellt ist KEIN Datum:

        if (parseFloat(val+"") == val)      // I have number that would fit this
             val = parseFloat(val)
        

        Dann habe ich den State von 2 Lichtern (die letzten beiden in der Reihe unter dem Datum)

        Ich haette gerne wie mit AppDaemon das Icon in WEISS wenn das Licht aus ist und in Gelb wenn es an ist. Hab ich bisher nicht geschafft.
        Und zuletzt habe ich den State unter dem Icon. Auch hier konnte ich das in AppDaemon etwas schoener machen und den 1. Buchstaben mit 'capitalize' auf gross umstellen.
        Beides scheint es hier nicht zu geben?

        Armilar 2 Replies Last reply Reply Quote 0
        • Armilar
          Armilar Most Active Forum Testing @Stephan L last edited by Armilar

          @stephan-l

          Okay - ich denke du meinst dann wohl das

          d4a27af6-7e45-4bc8-b0a3-97b6f43bb4e5-image.png

          Wir sind im ioBroker noch nicht ganz so International unterwegs... Ich werde mir für die Zukunft mal etwas überlegen.

          Damit sollte es aber funktionieren:

          const event = new Date();
          
          
          let weekday = event.toLocaleString('en-US', { weekday: 'long' });
          let day = event.toLocaleString('en-US', { year: 'numeric', month: '2-digit', day: '2-digit'});
          
          console.log(weekday + ' - ' + day)
          
          Stephan L 1 Reply Last reply Reply Quote 0
          • Armilar
            Armilar Most Active Forum Testing @Stephan L last edited by Armilar

            @stephan-l sagte in SONOFF NSPanel mit Lovelace UI:
            1)

            Dann habe ich den State von 2 Lichtern (die letzten beiden in der Reihe unter dem Datum)
            Ich haette gerne wie mit AppDaemon das Icon in WEISS wenn das Licht aus ist und in Gelb wenn es an ist. Hab ich bisher nicht geschafft.

            Und zuletzt habe ich den State unter dem Icon. Auch hier konnte ich das in AppDaemon etwas schoener machen und den 1. Buchstaben mit 'capitalize' auf gross umstellen.

            Beides scheint es hier nicht zu geben?

            Zu 1)
            Stimmt - mache bitte einen Feature Request:

            wir implementieren dann noch:

            ScreensaverEntityOnColor: Yellow, 
            ScreensaverEntityOffColor: White
            

            Zu 2)
            Kannst du über den Alias verändern:

            Habe hier mal einen Datenpunkt, der "on"/"off" (klein) enthält
            84a604a7-f68e-4eb6-b2bf-bfa2669bd445-image.png

            Device-Manager
            7c5f6c0f-99f0-4e49-93fa-ec913a3ce8be-image.png

            efadd0f8-f5fe-40a5-b767-893243912413-image.png

            unter fx:
            7930201d-fda9-4f17-920e-7737e5f1b0a0-image.png

            val.charAt(0).toUpperCase() + val.slice(1);
            

            Ergebnis:
            1b2786f8-2d0b-421a-975a-de060adda865-image.png

            Stephan L 2 Replies Last reply Reply Quote 0
            • Armilar
              Armilar Most Active Forum Testing @Stephan L last edited by

              @stephan-l sagte in SONOFF NSPanel mit Lovelace UI:

              Ich ja bereits alle Werte und Infos in HA, daher verwende ich den ioBroker HA Adapter. Genial...
              Von dort kommt auch mein momentaner Stromverbrauch. Den konnte ich auch mit ioBroker anzeigen lassen. Aber warum auch immer wurde der Wert als 'String' erkannt. Und im Code gibt es dubiose logik die dann den Wert, z.B. "793" als DATUM umformatiert.
              Dafuer konnte ich einen einfachen Fix machen.
              Ein String x, der folgendes erfuellt ist KEIN Datum:

              if (parseFloat(val+"") == val)      // I have number that would fit this                                                                                                             val = parseFloat(val)
              

              ... sehen wir uns an und machen einen Fix

              Stephan L 1 Reply Last reply Reply Quote 1
              • Stephan L
                Stephan L @Armilar last edited by

                @armilar said in SONOFF NSPanel mit Lovelace UI:

                Ich werde mir für die Zukunft mal etwas überlegen.

                const dayjs = require('dayjs');
                console.error(dayjs().format('dddd - DD/MM/YYYY'));
                

                Bingo... der format-string kann dann ein Datenobjekt sein. Damit kann ich wie in anderen Sprachen das ganze komplett formatieren!

                Siehe auch: https://day.js.org/docs/en/display/format

                Ich bin kein Experte, habe aber wo gelesen dass 'moment' nicht mehr aktualisiert wird? Egal... DayJS kann alles was du brauchst mit minimalem Aufwand und 100% flexibel!

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

                  @stephan-l

                  sieht wirklich nach einer guten Lösung aus

                  Stephan L 1 Reply Last reply Reply Quote 0
                  • Stephan L
                    Stephan L @Armilar last edited by

                    @armilar said in SONOFF NSPanel mit Lovelace UI:

                    Zu 2)
                    Kannst du über den Alias verändern:
                    Habe hier mal einen Datenpunkt, der "on"/"off" (klein) enthält

                    Naja, dann muss ich also alles doppelt machen? Wenn ich im Panel ein anderes Licht anzeigen will, dann muss ich einen neuen Alias machen UND dann noch im TS skript das andere Licht anwaehlen. Also dopplete Arbeit? Oder hab ich was falsch verstanden?

                    1 Reply Last reply Reply Quote 0
                    • Stephan L
                      Stephan L @Armilar last edited by

                      @armilar said in SONOFF NSPanel mit Lovelace UI:

                      ... sehen wir uns an und machen einen Fix

                      Yay! Das waere Supi....

                      Ich will auf keinen Fall auf AppDaemon zurueck. NSPanel mit ioBroker ist 10000000x mehr responsive!
                      Aber.... manches geht halt nicht 😉 Aber ich hoffe wir bekommen das hin.

                      Danke fuer die super schnellen Antworten!

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

                        @sirmiker

                        Gib uns mal ein Anwendungsbeispiel für einen leichten Einstieg. Was soll als erstes passieren?

                        Eine neue Seite mit einer Lampe einbinden?

                        Dann benötigen wir erst einmal einen Datenpunkt der Lampe.

                        Step by Step...

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

                          @stephan-l sagte in SONOFF NSPanel mit Lovelace UI:

                          Yay! Das waere Supi....
                          Ich will auf keinen Fall auf AppDaemon zurueck. NSPanel mit ioBroker ist 10000000x mehr responsive!
                          Aber.... manches geht halt nicht Aber ich hoffe wir bekommen das hin.
                          Danke fuer die super schnellen Antworten!

                          Klar bekommen wir das hin 😊

                          Am Besten aber in einen Feature Request auf Github. Dann geht es nicht so schnell verloren wie in diesem Thread...

                          Du bist dann der erste "Test-Amerikaner" für das NSPanel im ioBroker 😉

                          Kannst natürlich auch "Pull Requests" machen, falls die Lösung schon bekannt ist...

                          Stephan L 1 Reply Last reply Reply Quote 0
                          • Stephan L
                            Stephan L @Armilar last edited by

                            @armilar said in SONOFF NSPanel mit Lovelace UI:

                            Stimmt - mache bitte einen Feature Request:
                            wir implementieren dann noch:

                            https://github.com/joBr99/nspanel-lovelace-ui/issues/1045

                            stleusc created this issue in joBr99/nspanel-lovelace-ui

                            closed ioBroker - add support for on/off icon and text on screensaver #1045

                            1 Reply Last reply Reply Quote 1
                            • Stephan L
                              Stephan L @Armilar last edited by

                              @armilar said in SONOFF NSPanel mit Lovelace UI:

                              Du bist dann der erste "Test-Amerikaner" für das NSPanel im ioBroker

                              Ich denke das liegt daran dass doch einiges auf Deutsch dokumentiert ist 😉 Sowohl online als auch im Code.
                              Nach 15+ Jahren USA ist Englisch eigentlich fuer mich inzwischen einfacher hahaha. Zumindest gefuehlt 😉
                              Aber 30 Jahre Deutsch vergisst man dann ja doch nicht so schnell....

                              Ich mache gerne PullRequest wenn es da nicht so viele Huerden gibt.
                              In manchen Projekten ist das mega unkompliziert und in manchen eher das Gegenteil.

                              Wenn es OK ist wuerde ich den Datumsfix machen, so als tester.
                              Passt das? Ich wuerde dafuer gerne ein DatenObjekt nehmen das, wenn es exisitiert die UI Schalter ignoriert. Und es waere gut wenn eine Aenderung am DatenObjekt direkt erkannt wird und dann ein neues Datum rausgeschickt wird.
                              Geht das? Wenn ja, wie?

                              Armilar 1 Reply Last reply Reply Quote 1
                              • Armilar
                                Armilar Most Active Forum Testing @Stephan L last edited by Armilar

                                @stephan-l sagte in SONOFF NSPanel mit Lovelace UI:

                                Wenn es OK ist wuerde ich den Datumsfix machen, so als tester.
                                Passt das?

                                Ja, natürlich

                                Ich wuerde dafuer gerne ein DatenObjekt nehmen das, wenn es exisitiert die UI Schalter ignoriert. Und es waere gut wenn eine Aenderung am DatenObjekt direkt erkannt wird und dann ein neues Datum rausgeschickt wird.
                                Geht das? Wenn ja, wie?

                                Habe ich noch nicht ganz verstanden. Meinst du als Daten-Objekt einen Datenpunkt unter 0_userdata.0. das durch das Script inoitial erstellt wird?

                                Stephan L 1 Reply Last reply Reply Quote 0
                                • Stephan L
                                  Stephan L @Armilar last edited by

                                  @armilar said in SONOFF NSPanel mit Lovelace UI:

                                  sieht wirklich nach einer guten Lösung aus

                                  Habe PR erstellt (https://github.com/joBr99/nspanel-lovelace-ui/pull/1046)

                                  stleusc created this issue in joBr99/nspanel-lovelace-ui

                                  closed ioBroker - support custom date format using optional .Config.Dateformat.customFormat object #1046

                                  T 1 Reply Last reply Reply Quote 0
                                  • Stephan L
                                    Stephan L @Armilar last edited by

                                    @armilar said in SONOFF NSPanel mit Lovelace UI:

                                    Meinst du als Daten-Objekt einen Datenpunkt unter 0_userdata.0. das durch das Script inoitial erstellt wird?

                                    Ja und nein... Datenpunkt unter dem panel basis pfad (.Config.Dateformat.customFormat)
                                    Der soll aber ja optional sein. Der user kann das anlegen und es wird verwendet. Der user loescht es wieder und die UI toggles gehen wieder.

                                    Was ich gemerkt habe, wenn ich in der UI die Locale einstelle passiert nix bis ich das TS Skript neu starte!
                                    Grund: die Locale wird ganz am Anfang gesetzt:

                                    const parseFormat = require('moment-parseformat');
                                    moment.locale(getState(NSPanel_Path + 'Config.locale').val);
                                    

                                    Der neue dayjs macht das jetzt genau gleich.

                                    Selbst Panel neustart hilft daher nicht.

                                    Was fehlt ist code der Locale change erkennt und dann

                                    moment.locale(getState(NSPanel_Path + 'Config.locale').val); ausfuehrt.
                                    Und mit meiner Aenderung dann auch dayjs.locale(getDayjsLocale());

                                    Stephan L 2 Replies Last reply Reply Quote 0
                                    • Stephan L
                                      Stephan L @Stephan L last edited by

                                      @stephan-l
                                      Also sowas wie

                                      on({id: [].concat(NSPanel_Path + 'Config.Locale'), change: "ne"}, async function (obj) {
                                         moment.locale(getState(NSPanel_Path + 'Config.locale').val);
                                         dayjs.locale(getDayjsLocale());
                                      });
                                      

                                      Da ich den syntax hier nicht kenne ist das kein fertiger Code, nur die Erklaerung was ich meine.

                                      1 Reply Last reply Reply Quote 0
                                      • Stephan L
                                        Stephan L @Stephan L last edited by

                                        @stephan-l said in SONOFF NSPanel mit Lovelace UI:

                                        Was fehlt ist code der Locale change erkennt und dann
                                        moment.locale(getState(NSPanel_Path + 'Config.locale').val); ausfuehrt.
                                        Und mit meiner Aenderung dann auch dayjs.locale(getDayjsLocale());

                                        on({id: [].concat(NSPanel_Path + 'Config.locale'), change: "any"}, async function (obj) {
                                            try {
                                                moment.locale(getState(NSPanel_Path + 'Config.locale').val);
                                                dayjs.locale(getDayjsLocale());
                                                SendDate();
                                            } catch (err) {
                                                console.error("CHANGE LOCALE ERROR")
                                            }
                                        });
                                        

                                        Wenn ich in ioBroker .Config.localeNumber aendere dann wird mein neuer DatumString sofort uebersetzt.
                                        Also der dayjs Teil tut. Nur das ServiceMenue ist immer noch die alte Sprache.

                                        Braucht also noch nen Experten hier.

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

                                          @stephan-l sagte in SONOFF NSPanel mit Lovelace UI:

                                          Wenn ich in ioBroker .Config.localeNumber aendere dann wird mein neuer DatumString sofort uebersetzt.
                                          Also der dayjs Teil tut. Nur das ServiceMenue ist immer noch die alte Sprache.
                                          Braucht also noch nen Experten hier.

                                          Ja, der Teil hat schon immer funktioniert.

                                          Bei dem Service-Menü ist es etwas anders. Die Variablen werden nur beim Start des Scriptes durchlaufen. Nun könnte man sich die Mühe machen, es so flexibel und dynamisch zu programmieren, dass es sich zur Laufzeit umstellt... Ich gehe aber davon aus, dass die Locale-Einstellungen nur genau einmal durchgeführt werden und dann so bleiben werden. Für den Fall kann man auch das Script einmal neu starten.

                                          Also mit anderen Worten. Warum sollte ich mir jeden Tag eine neue Sprache aussuchen? 😉

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

                                            @stephan-l
                                            habe dein PR grade getestet, Passt erstmal. Müssen noch ein paar Anpassungen machen, damit der Datenpunkt automatisch erstellt wird und ein Standard Format bekommt für den Start.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            805
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            lovelace ui nspanel sonoff
                                            260
                                            7128
                                            4289207
                                            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