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

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

Community Forum

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

NEWS

  • wichtiges UPDATE fĂŒr controller 7.2.2 im stable
    HomoranH
    Homoran
    5
    1
    100

  • Neues YouTube-Video: Visualisierung im Devices-Adapter
    BluefoxB
    Bluefox
    14
    1
    2.5k

  • Neuer ioBroker-Blog online: MonatsrĂŒckblick MĂ€rz/April 2026
    BluefoxB
    Bluefox
    8
    1
    2.8k

SONOFF NSPanel mit Lovelace UI (TypeScript Version)

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

    @danny_v1

    deine Navigation Config in den Seiten musst du richtig anpassen. Schaue dir dazu mal die Beschreibung im Wiki an. Könnte eine Ursache sein.
    hast du mal deine Javascript Instanz mal neu gestartet?

    D Offline
    D Offline
    danny_v1
    schrieb am zuletzt editiert von danny_v1
    #4037

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

    @danny_v1

    deine Navigation Config in den Seiten musst du richtig anpassen. Schaue dir dazu mal die Beschreibung im Wiki an. Könnte eine Ursache sein.

    Ja das habe ich eigentlich nach der Beschreibung gemacht. steh da gerade etwas auf dem Schlauch, bzw sehe den Fehler nicht. FĂ€llt dir in der Config was auf was nicht passt?

    Edit: das einzige was mir aufgefallen ist, ist der Parameter targetPage, aber laut Wiki sollten beide Varianten funktionieren

    T 1 Antwort Letzte Antwort
    0
    • D danny_v1

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

      @danny_v1

      deine Navigation Config in den Seiten musst du richtig anpassen. Schaue dir dazu mal die Beschreibung im Wiki an. Könnte eine Ursache sein.

      Ja das habe ich eigentlich nach der Beschreibung gemacht. steh da gerade etwas auf dem Schlauch, bzw sehe den Fehler nicht. FĂ€llt dir in der Config was auf was nicht passt?

      Edit: das einzige was mir aufgefallen ist, ist der Parameter targetPage, aber laut Wiki sollten beide Varianten funktionieren

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

      @danny_v1

      der Teil ist nicht ganz konform

                      "parent": Obergeschoss,
                      'prev': undefined,
                      'next': 'Wohnzimmer2',
                      'home': 'Obergeschoss',
      

      Wichtig!
      Wenn 'prev' eine Seite zugewiesen wurde, wird 'parent' nicht ausgewertet. Das gleiche gilt auch fĂŒr 'next' und 'home'.

      siehe dir mal im Wiki das Bild an, das erklÀrt es ganz gut.

      Gruß Tom

      Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

      Public Transport
      https://github.com/tt-tom17/ioBroker.public-transport
      https://github.com/tt-tom17/ioBroker.public-transport/wiki

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

      D 1 Antwort Letzte Antwort
      0
      • T TT-Tom

        @danny_v1

        der Teil ist nicht ganz konform

                        "parent": Obergeschoss,
                        'prev': undefined,
                        'next': 'Wohnzimmer2',
                        'home': 'Obergeschoss',
        

        Wichtig!
        Wenn 'prev' eine Seite zugewiesen wurde, wird 'parent' nicht ausgewertet. Das gleiche gilt auch fĂŒr 'next' und 'home'.

        siehe dir mal im Wiki das Bild an, das erklÀrt es ganz gut.

        D Offline
        D Offline
        danny_v1
        schrieb am zuletzt editiert von
        #4039

        @tt-tom Ok, danke fĂŒr die ErklĂ€rung, jetzt sehe ich den Fehler.

        Das einzige was ich noch nicht 100% versteh ist der Unterschied zwischen parent und home. Im Bild sehe ich, wenn ich ĂŒber navigate in eine höher Ebene gesprungen bin das der RĂŒcksprung mit parent erfolgt. Aber ich könnte genauso gut home verwenden? Das einzige worin die beiden sich unterscheiden ist die Position des icons oder?

        T 1 Antwort Letzte Antwort
        0
        • D danny_v1

          @tt-tom Ok, danke fĂŒr die ErklĂ€rung, jetzt sehe ich den Fehler.

          Das einzige was ich noch nicht 100% versteh ist der Unterschied zwischen parent und home. Im Bild sehe ich, wenn ich ĂŒber navigate in eine höher Ebene gesprungen bin das der RĂŒcksprung mit parent erfolgt. Aber ich könnte genauso gut home verwenden? Das einzige worin die beiden sich unterscheiden ist die Position des icons oder?

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

          @danny_v1

          Mit Home springst du in die mainpages also die erste Zeile.

          Gruß Tom

          Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

          Public Transport
          https://github.com/tt-tom17/ioBroker.public-transport
          https://github.com/tt-tom17/ioBroker.public-transport/wiki

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

          D 1 Antwort Letzte Antwort
          0
          • T TT-Tom

            @danny_v1

            Mit Home springst du in die mainpages also die erste Zeile.

            D Offline
            D Offline
            danny_v1
            schrieb am zuletzt editiert von
            #4041

            @tt-tom Dann wÀre aber das Bild im Wiki falsch, da wird ja mit home aus der Subpage "Wohnzimmer 3" in die Subpage "Erdgeschoss" gesprungen.

            T 1 Antwort Letzte Antwort
            0
            • D danny_v1

              @tt-tom Dann wÀre aber das Bild im Wiki falsch, da wird ja mit home aus der Subpage "Wohnzimmer 3" in die Subpage "Erdgeschoss" gesprungen.

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

              @danny_v1

              oh Sorry, ja du hast recht, das war mal der Ursprung. Das Bild stimmt natĂŒrlich. Mit den Parametern werden auch die Standrad Icon bestimmt Pfeil hoch , Links, Rechts und Haus. Wobei du diese auch ĂŒberschreiben kannst. Parameter die auf undefined stehen, kannst du weg lassen. Damit wird es ĂŒbersichtlicher.

              Gruß Tom

              Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

              Public Transport
              https://github.com/tt-tom17/ioBroker.public-transport
              https://github.com/tt-tom17/ioBroker.public-transport/wiki

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

              D 1 Antwort Letzte Antwort
              0
              • T TT-Tom

                @danny_v1

                oh Sorry, ja du hast recht, das war mal der Ursprung. Das Bild stimmt natĂŒrlich. Mit den Parametern werden auch die Standrad Icon bestimmt Pfeil hoch , Links, Rechts und Haus. Wobei du diese auch ĂŒberschreiben kannst. Parameter die auf undefined stehen, kannst du weg lassen. Damit wird es ĂŒbersichtlicher.

                D Offline
                D Offline
                danny_v1
                schrieb am zuletzt editiert von
                #4043

                @tt-tom Ok dann hab ich es nun glaub ich endlich verstanden, manches dauert halt doch etwas lÀnger. Vielen Dank!

                T 1 Antwort Letzte Antwort
                0
                • D danny_v1

                  @tt-tom Ok dann hab ich es nun glaub ich endlich verstanden, manches dauert halt doch etwas lÀnger. Vielen Dank!

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

                  @danny_v1

                  Ja das Script ist schon sehr mÀchtig geworden und hat dadurch sehr viele Einstellungsmöglichkeiten. Ich muss auch öfter nochmal in den Code sehen, um nicht falsches zu schreiben. Aber wie du siehst passiert mir das auch hin und wieder. Weiter viel Spass

                  Gruß Tom

                  Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                  Public Transport
                  https://github.com/tt-tom17/ioBroker.public-transport
                  https://github.com/tt-tom17/ioBroker.public-transport/wiki

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

                  D 2 Antworten Letzte Antwort
                  0
                  • T TT-Tom

                    @danny_v1

                    Ja das Script ist schon sehr mÀchtig geworden und hat dadurch sehr viele Einstellungsmöglichkeiten. Ich muss auch öfter nochmal in den Code sehen, um nicht falsches zu schreiben. Aber wie du siehst passiert mir das auch hin und wieder. Weiter viel Spass

                    D Offline
                    D Offline
                    danny_v1
                    schrieb am zuletzt editiert von
                    #4045

                    @tt-tom ja das stimmt das Skript ist echt riesig, wÀre schön wenn man das aufteilen könnte.
                    So das man die ganze Seitenkonfiguration in einer extra Datei hÀtte. HÀtte auch den Vorteil, dass man bei einem Update nur das eigentliche Skript tauscht und die Seiten-Konfig nicht anfassen muss.

                    1 Antwort Letzte Antwort
                    0
                    • E Offline
                      E Offline
                      eMd
                      schrieb am zuletzt editiert von
                      #4046

                      Ich denke mal das wird bestimmt bald ein Adapter werden um alles ein wenig zu vereinfachen 😉😉😉

                      Master: Intel NUC 16GB/500GB
                      Slave: Raspberry Pi 3 + Homematicmodul
                      Shelly, Google Home, Zigbee Aqara, Sonoff

                      Meine VIS: https://youtu.be/JMYr2KYlpME

                      1 Antwort Letzte Antwort
                      0
                      • ArmilarA Armilar

                        @Bergi84

                        kam keine Antwort mehr...

                        Ich habe die Änderungen in die v4.3.1.6 gesetzt...

                        fe09ab24-9edc-4164-9123-95b87b4f1ab0-image.png

                        Wer die FunktionalitÀt der erweiterten Alias-GerÀtetypen in der Navi verwenden möchte, kann den unteren Teil des NSPanelTs.ts austauschen.

                        Siehe Post von @Bergi84

                        @all
                        Übrigens hab ich gleich auch noch einen Verbesserungswunsch den ich hier zur Diskussion stellen wollte. Und zwar geht es darum dass ich gerne hĂ€tte wenn ich zB auf auf einer GridPage auf die Temperatur vom zB. Wohnzimmer drĂŒcke dass sich dann eine subPage öffnet. Durch hinzufĂŒgen entsprechenden cases in der Funktion CreateEntity in der switch abfrage fĂŒr die dynamischen navi icons hab ich das mal ausprobiert und in meinem Fall funktioniert das.

                        geÀnderte Config damit es auch funktioniert:

                        let NSPanel_Temp = <PageGrid>
                        {
                            'type': 'cardGrid',
                            'heading': 'Temperaturen',
                            'useColor': true,
                            'items': [
                                <PageItem>{ navigate: true, targetPage: 'NSPanel_TestSub', id: 'alias.0.devices.TempSchlafzimmer', unit: '°C', name: 'Schlafzimmer', offColor: MSRed, onColor: MSGreen, useValue: true, colorScale: {'val_min': 20, 'val_max': 25, 'val_best': 23} },
                            ]
                        };
                        

                        Ansonsten hat das Update keine Auswirkungen auf bisherige FunktionalitÀt...

                        B Offline
                        B Offline
                        Bergi84
                        schrieb am zuletzt editiert von Bergi84
                        #4047

                        @Bergi84

                        kam keine Antwort mehr...

                        Ich habe die Änderungen in die v4.3.1.6 gesetzt...

                        fe09ab24-9edc-4164-9123-95b87b4f1ab0-image.png

                        Wer die FunktionalitÀt der erweiterten Alias-GerÀtetypen in der Navi verwenden möchte, kann den unteren Teil des NSPanelTs.ts austauschen.

                        Siehe Post von @Bergi84

                        @all
                        Übrigens hab ich gleich auch noch einen Verbesserungswunsch den ich hier zur Diskussion stellen wollte. Und zwar geht es darum dass ich gerne hĂ€tte wenn ich zB auf auf einer GridPage auf die Temperatur vom zB. Wohnzimmer drĂŒcke dass sich dann eine subPage öffnet. Durch hinzufĂŒgen entsprechenden cases in der Funktion CreateEntity in der switch abfrage fĂŒr die dynamischen navi icons hab ich das mal ausprobiert und in meinem Fall funktioniert das.

                        geÀnderte Config damit es auch funktioniert:

                        let NSPanel_Temp = <PageGrid>
                        {
                            'type': 'cardGrid',
                            'heading': 'Temperaturen',
                            'useColor': true,
                            'items': [
                                <PageItem>{ navigate: true, targetPage: 'NSPanel_TestSub', id: 'alias.0.devices.TempSchlafzimmer', unit: '°C', name: 'Schlafzimmer', offColor: MSRed, onColor: MSGreen, useValue: true, colorScale: {'val_min': 20, 'val_max': 25, 'val_best': 23} },
                            ]
                        };
                        

                        Ansonsten hat das Update keine Auswirkungen auf bisherige FunktionalitÀt...

                        Sorry das ich nicht geantwortet habe. Mir fehlt leider ein wenig die zeit mich um das regelmĂ€ĂŸig zu kĂŒmmern. Verzeihung.

                        Danke fĂŒr die Änderung, Somit kann ich das Script ohne Modifikation einsetzen.

                        1 Antwort Letzte Antwort
                        0
                        • ArmilarA Armilar

                          @bergi84

                          Wenn ich ein Notify Popup verwende, wie bekomme ich mit das der Nutzer auf das schließen X in der rechten oberen Ecke gedrĂŒckt hat oder der timeout abgelaufen ist. FĂŒr die unteren zwei Buttons kann ich ja auf den State "popupNotify.popupNotifyAction" triggern. Das Problem ist ja das mein Trigger scharf bleibt und wenn zufĂ€llig ein anderes Notify Popup reinspringt dann passiert irgend was.

                          weil die HMI bei dem "x" ein bExit sendet und bei den beiden Buttons ein Event mit b1 oder b2, welches ausgewertet werden kann:

                          396b9563-11da-4081-921c-9fd4a1f3952f-image.png

                          Somit wird nicht explizit ein "false" gesendet, wenn das "x" gedrĂŒckt wird. Das popUp wird durch die HMI beendet.

                          Warum kann man nur dann die Schriftart des Textes im Popup Àndern wenn man auf Layout 2 umschaltet? Das funktioniert mit dem Standard Layout prinzipiell auch und die Standard Schriftart des Popups ist arg klein und ich kann keine Icons im Text verwenden.

                          Weil die HMI vor einiger Zeit bereits eine neue zusĂ€tzliche Version des popupNotify bekam. Sollte eigentlich die alte ablösen. Wir wollten die alte Version jedoch weiter benutzen (wird aber nicht mehr weiterentwickelt) und haben die daher Layout 1und 2 genannt. In der Ă€lteren Version berĂŒcksichtigt die Nextion HMI keine Schriftarten...

                          B Offline
                          B Offline
                          Bergi84
                          schrieb am zuletzt editiert von
                          #4048

                          @armilar said in SONOFF NSPanel mit Lovelace UI:

                          @bergi84

                          Wenn ich ein Notify Popup verwende, wie bekomme ich mit das der Nutzer auf das schließen X in der rechten oberen Ecke gedrĂŒckt hat oder der timeout abgelaufen ist. FĂŒr die unteren zwei Buttons kann ich ja auf den State "popupNotify.popupNotifyAction" triggern. Das Problem ist ja das mein Trigger scharf bleibt und wenn zufĂ€llig ein anderes Notify Popup reinspringt dann passiert irgend was.

                          weil die HMI bei dem "x" ein bExit sendet und bei den beiden Buttons ein Event mit b1 oder b2, welches ausgewertet werden kann:

                          396b9563-11da-4081-921c-9fd4a1f3952f-image.png

                          Somit wird nicht explizit ein "false" gesendet, wenn das "x" gedrĂŒckt wird. Das popUp wird durch die HMI beendet.

                          Das meine ich ja. Wenn ich das Popup verwende bekomme ich eben nicht mit das es geschlossen wurde. Und das ist ungĂŒnstig da ja mein Subscribe auf ACTION auch nicht gelöscht wird und sobald ein anderes Popup wie zB Tasmota update hinein springt und ich dort auf Ja drĂŒcke wird auch das andere Script fĂ€lschlicherweise getriggert. Ich glaube es wĂ€re besser das ĂŒber ACTION als String die Werte 'true', 'false', 'exit' und 'timeout' kommuniziert werden. Mir ist natĂŒrlich klar das dass nicht einfach ist weil es inkompatibel ist.

                          Warum kann man nur dann die Schriftart des Textes im Popup Àndern wenn man auf Layout 2 umschaltet? Das funktioniert mit dem Standard Layout prinzipiell auch und die Standard Schriftart des Popups ist arg klein und ich kann keine Icons im Text verwenden.

                          Weil die HMI vor einiger Zeit bereits eine neue zusĂ€tzliche Version des popupNotify bekam. Sollte eigentlich die alte ablösen. Wir wollten die alte Version jedoch weiter benutzen (wird aber nicht mehr weiterentwickelt) und haben die daher Layout 1und 2 genannt. In der Ă€lteren Version berĂŒcksichtigt die Nextion HMI keine Schriftarten...

                          Ich möchte kurz erklĂ€ren fĂŒr was ich das verwende. Ich hab mir im ioBroker ein Warningsystem geschrieben das unter anderem ĂŒberwacht ob alle nötigen Sensoren verfĂŒgbar sind und ob der Batteriestand bei batteriebetriebenen GerĂ€ten ĂŒber einen gewissen Grenzwert ist. Alle Warnung werden in einer Liste gesammelt. Da es in der NSPanel UI keine geeignete Page fĂŒr sowas gibt verwende ich das Layout 1 des Notify Popups. Ich zeige pro Seite 3 Warnungen an und verwende eben auch Symbole damit es auf einen Blick erkennbar ist, was das Problem ist gefolgt von dem ĂŒberwachten State. Wenn es mehr als 3 Warnungen gibt nutze ich die unteren zwei Tasten zum blĂ€ttern. Damit die Symbole angezeigt werden muss entsprechend die richtige Schriftart gewĂ€hlt werden. Die aktuelle Firmware des Nextion Displays entscheidet anhand der Anwesenheit des ICON ob es Layout 1 oder Layout 2 verwendet. Die gewĂ€hlte Schriftart wird auf beide Layouts angewendet. Das hab ich auch schon ausprobiert in dem ich die Variabel v_popupNotifyFontIdText inde folgendem Codeabschnitt vor das If gezogen habe.

                                      notification = 'entityUpdateDetail' + '~'
                                          + getState(popupNotifyInternalName).val + '~'
                                          + getState(popupNotifyHeading).val + '~'
                                          + v_popupNotifyHeadingColor + '~'
                                          + getState(popupNotifyButton1Text).val + '~'
                                          + v_popupNotifyButton1TextColor + '~'
                                          + getState(popupNotifyButton2Text).val + '~'
                                          + v_popupNotifyButton2TextColor + '~'
                                          + getState(popupNotifyText).val + '~'
                                          + v_popupNotifyTextColor + '~'
                                          + getState(popupNotifySleepTimeout).val;
                          
                                      if (getState(popupNotifyLayout).val == 2) {
                                          notification = notification + '~'
                                          + v_popupNotifyFontIdText + '~'
                                          + Icons.GetIcon(v_popupNotifyIcon) + '~'
                                          + v_popupNotifyIconColor;
                                      }
                          
                          D T 2 Antworten Letzte Antwort
                          0
                          • B Bergi84

                            @armilar said in SONOFF NSPanel mit Lovelace UI:

                            @bergi84

                            Wenn ich ein Notify Popup verwende, wie bekomme ich mit das der Nutzer auf das schließen X in der rechten oberen Ecke gedrĂŒckt hat oder der timeout abgelaufen ist. FĂŒr die unteren zwei Buttons kann ich ja auf den State "popupNotify.popupNotifyAction" triggern. Das Problem ist ja das mein Trigger scharf bleibt und wenn zufĂ€llig ein anderes Notify Popup reinspringt dann passiert irgend was.

                            weil die HMI bei dem "x" ein bExit sendet und bei den beiden Buttons ein Event mit b1 oder b2, welches ausgewertet werden kann:

                            396b9563-11da-4081-921c-9fd4a1f3952f-image.png

                            Somit wird nicht explizit ein "false" gesendet, wenn das "x" gedrĂŒckt wird. Das popUp wird durch die HMI beendet.

                            Das meine ich ja. Wenn ich das Popup verwende bekomme ich eben nicht mit das es geschlossen wurde. Und das ist ungĂŒnstig da ja mein Subscribe auf ACTION auch nicht gelöscht wird und sobald ein anderes Popup wie zB Tasmota update hinein springt und ich dort auf Ja drĂŒcke wird auch das andere Script fĂ€lschlicherweise getriggert. Ich glaube es wĂ€re besser das ĂŒber ACTION als String die Werte 'true', 'false', 'exit' und 'timeout' kommuniziert werden. Mir ist natĂŒrlich klar das dass nicht einfach ist weil es inkompatibel ist.

                            Warum kann man nur dann die Schriftart des Textes im Popup Àndern wenn man auf Layout 2 umschaltet? Das funktioniert mit dem Standard Layout prinzipiell auch und die Standard Schriftart des Popups ist arg klein und ich kann keine Icons im Text verwenden.

                            Weil die HMI vor einiger Zeit bereits eine neue zusĂ€tzliche Version des popupNotify bekam. Sollte eigentlich die alte ablösen. Wir wollten die alte Version jedoch weiter benutzen (wird aber nicht mehr weiterentwickelt) und haben die daher Layout 1und 2 genannt. In der Ă€lteren Version berĂŒcksichtigt die Nextion HMI keine Schriftarten...

                            Ich möchte kurz erklĂ€ren fĂŒr was ich das verwende. Ich hab mir im ioBroker ein Warningsystem geschrieben das unter anderem ĂŒberwacht ob alle nötigen Sensoren verfĂŒgbar sind und ob der Batteriestand bei batteriebetriebenen GerĂ€ten ĂŒber einen gewissen Grenzwert ist. Alle Warnung werden in einer Liste gesammelt. Da es in der NSPanel UI keine geeignete Page fĂŒr sowas gibt verwende ich das Layout 1 des Notify Popups. Ich zeige pro Seite 3 Warnungen an und verwende eben auch Symbole damit es auf einen Blick erkennbar ist, was das Problem ist gefolgt von dem ĂŒberwachten State. Wenn es mehr als 3 Warnungen gibt nutze ich die unteren zwei Tasten zum blĂ€ttern. Damit die Symbole angezeigt werden muss entsprechend die richtige Schriftart gewĂ€hlt werden. Die aktuelle Firmware des Nextion Displays entscheidet anhand der Anwesenheit des ICON ob es Layout 1 oder Layout 2 verwendet. Die gewĂ€hlte Schriftart wird auf beide Layouts angewendet. Das hab ich auch schon ausprobiert in dem ich die Variabel v_popupNotifyFontIdText inde folgendem Codeabschnitt vor das If gezogen habe.

                                        notification = 'entityUpdateDetail' + '~'
                                            + getState(popupNotifyInternalName).val + '~'
                                            + getState(popupNotifyHeading).val + '~'
                                            + v_popupNotifyHeadingColor + '~'
                                            + getState(popupNotifyButton1Text).val + '~'
                                            + v_popupNotifyButton1TextColor + '~'
                                            + getState(popupNotifyButton2Text).val + '~'
                                            + v_popupNotifyButton2TextColor + '~'
                                            + getState(popupNotifyText).val + '~'
                                            + v_popupNotifyTextColor + '~'
                                            + getState(popupNotifySleepTimeout).val;
                            
                                        if (getState(popupNotifyLayout).val == 2) {
                                            notification = notification + '~'
                                            + v_popupNotifyFontIdText + '~'
                                            + Icons.GetIcon(v_popupNotifyIcon) + '~'
                                            + v_popupNotifyIconColor;
                                        }
                            
                            D Offline
                            D Offline
                            danny_v1
                            schrieb am zuletzt editiert von
                            #4049

                            @bergi84

                            kannst du das mit dem Warnsystem mal reinstellen wie du das umgesetzt hast.
                            Sowas habe ich auch noch vor.
                            Hab das schon mit geöffneten Fenstern beim verlassen das Hauses (auf einem Panel neben der HaustĂŒr) umgesetzt , aber so 100% zufrieden bin ich mit dem Layout noch nicht.

                            1 Antwort Letzte Antwort
                            0
                            • B Bergi84

                              @armilar said in SONOFF NSPanel mit Lovelace UI:

                              @bergi84

                              Wenn ich ein Notify Popup verwende, wie bekomme ich mit das der Nutzer auf das schließen X in der rechten oberen Ecke gedrĂŒckt hat oder der timeout abgelaufen ist. FĂŒr die unteren zwei Buttons kann ich ja auf den State "popupNotify.popupNotifyAction" triggern. Das Problem ist ja das mein Trigger scharf bleibt und wenn zufĂ€llig ein anderes Notify Popup reinspringt dann passiert irgend was.

                              weil die HMI bei dem "x" ein bExit sendet und bei den beiden Buttons ein Event mit b1 oder b2, welches ausgewertet werden kann:

                              396b9563-11da-4081-921c-9fd4a1f3952f-image.png

                              Somit wird nicht explizit ein "false" gesendet, wenn das "x" gedrĂŒckt wird. Das popUp wird durch die HMI beendet.

                              Das meine ich ja. Wenn ich das Popup verwende bekomme ich eben nicht mit das es geschlossen wurde. Und das ist ungĂŒnstig da ja mein Subscribe auf ACTION auch nicht gelöscht wird und sobald ein anderes Popup wie zB Tasmota update hinein springt und ich dort auf Ja drĂŒcke wird auch das andere Script fĂ€lschlicherweise getriggert. Ich glaube es wĂ€re besser das ĂŒber ACTION als String die Werte 'true', 'false', 'exit' und 'timeout' kommuniziert werden. Mir ist natĂŒrlich klar das dass nicht einfach ist weil es inkompatibel ist.

                              Warum kann man nur dann die Schriftart des Textes im Popup Àndern wenn man auf Layout 2 umschaltet? Das funktioniert mit dem Standard Layout prinzipiell auch und die Standard Schriftart des Popups ist arg klein und ich kann keine Icons im Text verwenden.

                              Weil die HMI vor einiger Zeit bereits eine neue zusĂ€tzliche Version des popupNotify bekam. Sollte eigentlich die alte ablösen. Wir wollten die alte Version jedoch weiter benutzen (wird aber nicht mehr weiterentwickelt) und haben die daher Layout 1und 2 genannt. In der Ă€lteren Version berĂŒcksichtigt die Nextion HMI keine Schriftarten...

                              Ich möchte kurz erklĂ€ren fĂŒr was ich das verwende. Ich hab mir im ioBroker ein Warningsystem geschrieben das unter anderem ĂŒberwacht ob alle nötigen Sensoren verfĂŒgbar sind und ob der Batteriestand bei batteriebetriebenen GerĂ€ten ĂŒber einen gewissen Grenzwert ist. Alle Warnung werden in einer Liste gesammelt. Da es in der NSPanel UI keine geeignete Page fĂŒr sowas gibt verwende ich das Layout 1 des Notify Popups. Ich zeige pro Seite 3 Warnungen an und verwende eben auch Symbole damit es auf einen Blick erkennbar ist, was das Problem ist gefolgt von dem ĂŒberwachten State. Wenn es mehr als 3 Warnungen gibt nutze ich die unteren zwei Tasten zum blĂ€ttern. Damit die Symbole angezeigt werden muss entsprechend die richtige Schriftart gewĂ€hlt werden. Die aktuelle Firmware des Nextion Displays entscheidet anhand der Anwesenheit des ICON ob es Layout 1 oder Layout 2 verwendet. Die gewĂ€hlte Schriftart wird auf beide Layouts angewendet. Das hab ich auch schon ausprobiert in dem ich die Variabel v_popupNotifyFontIdText inde folgendem Codeabschnitt vor das If gezogen habe.

                                          notification = 'entityUpdateDetail' + '~'
                                              + getState(popupNotifyInternalName).val + '~'
                                              + getState(popupNotifyHeading).val + '~'
                                              + v_popupNotifyHeadingColor + '~'
                                              + getState(popupNotifyButton1Text).val + '~'
                                              + v_popupNotifyButton1TextColor + '~'
                                              + getState(popupNotifyButton2Text).val + '~'
                                              + v_popupNotifyButton2TextColor + '~'
                                              + getState(popupNotifyText).val + '~'
                                              + v_popupNotifyTextColor + '~'
                                              + getState(popupNotifySleepTimeout).val;
                              
                                          if (getState(popupNotifyLayout).val == 2) {
                                              notification = notification + '~'
                                              + v_popupNotifyFontIdText + '~'
                                              + Icons.GetIcon(v_popupNotifyIcon) + '~'
                                              + v_popupNotifyIconColor;
                                          }
                              
                              T Offline
                              T Offline
                              TT-Tom
                              schrieb am zuletzt editiert von
                              #4050

                              @bergi84

                              Ein Tipp zum Trigger. Ich prĂŒfe zusĂ€tzlich den internen Namen des PopupNotify. Das komplette Script findest du in meinem Github (Fahrplan).

                               const internalName: string = getState(DP_NSPanel + 'popupNotify.popupNotifyInternalName').val;
                                          if (internalName.includes('Delay')) {
                                              if (internalName == 'DelayFahrplanScript') {
                                                  console.log('jetzt kommmt Text 2' + Info + '%');
                              

                              Damit weist du von welchem popupNotify der Action kommt.

                              Gruß Tom

                              Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                              Public Transport
                              https://github.com/tt-tom17/ioBroker.public-transport
                              https://github.com/tt-tom17/ioBroker.public-transport/wiki

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

                              1 Antwort Letzte Antwort
                              0
                              • L L4rs

                                @tt-tom Ist hier auch so, der Raspberry steht auf Europa/Berlin, die Uhrzeit ist aktuell, ioBroker steht ebenfalls auf Deutsch mit dem Datumsformat DD.MM.YYYY und der JS_Adapter verwendet die Systemeinstellungen.

                                Das Blockly liefert bei mir aber auch den falschen Wert. 02.11.2023 -> 11.02.23.

                                Gruß, Lars

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

                                @l4rs

                                Hi Lars,

                                Ich habe hier mal das Problem ins Forum gepostet. Muss mich mit @Armilar noch abstimmen.

                                Gruß Tom

                                Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                                Public Transport
                                https://github.com/tt-tom17/ioBroker.public-transport
                                https://github.com/tt-tom17/ioBroker.public-transport/wiki

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

                                1 Antwort Letzte Antwort
                                0
                                • B Offline
                                  B Offline
                                  Bergi84
                                  schrieb am zuletzt editiert von
                                  #4052

                                  @danny_v1
                                  puh das ist aber viel verstreuter Code und sicher noch nicht fehlerfrei. Ich versuch mal zumindest den NSPanel teil zu erklÀren und poste.

                                  Also damit die Liste aufgeht habe ich einen passenden Button Channel in den Objekten unter userdata angelegt:

                                  let mainConfig =  <PageGrid>
                                  {
                                      'type': 'cardGrid',
                                      'heading': 'Einstellungen',
                                      'useColor': true,
                                      'items': [
                                          <PageItem>{ id: '0_userdata.0.NSPanel.1.warning.showAlertInfo', icon: 'alert', name: 'Warnings', offColor: Yellow, onColor: Yellow},
                                  }
                                  

                                  Ich triggere einfach auf das umschalten und zeige anschließen das Notify an. Die Daten sind in mehrere Listen von den jeweiligen Überwachungsscripten aufgeteilt. Und jede liste ist als JSON in einem State der ebenfalls unter userdata gespeichert ist abgelegt. Bei jeder Änderung einer dieser Listen sammle ich alle daten ein sortiere Sie und aktualisiere die Anzeige. Das mach folgender code:

                                  // warn system
                                  createState(NSPanel_Path + 'warning.cnt');
                                  createState(NSPanel_Path + 'warning.aktiv');
                                  
                                  let warnPageNo;
                                  let warnPageCnt;
                                  let warnSubscribeHandler;
                                  let warningList :warningItem[];
                                  let warnItemsPerPage = 4;
                                  
                                  let warningListIds = [
                                      {id: '0_userdata.0.sensorSuperVisor.missingSensors', icon: 'connection', prefix: 'Verloren: ', postfix: ' vor '},
                                      {id: '0_userdata.0.batteryMonitor.batterLow', icon: 'battery-alert-variant-outline', prefix: 'Batterie schwach: ', postfix: ' vor '}
                                  ]
                                  function updateWarnings(aObj: iobJS.ChangedStateObject<any,any>)
                                  {
                                      warningList = [];
                                  
                                      warningListIds.forEach(listEle => {
                                          JSON.parse(getState(listEle.id).val).forEach((e :warningItem) => {
                                              e.source = listEle.id; warningList.push(e);
                                          });
                                      });
                                  
                                      console.log(JSON.stringify(warningListIds));
                                      console.log(JSON.stringify(warningList));
                                  
                                      let listLen = warningList.length;
                                  
                                      warningList.sort((a, b) => a.time - b.time);
                                  
                                      warnPageCnt = (listLen == 0) ? 1 : ((listLen + warnItemsPerPage-1) / warnItemsPerPage | 0);
                                  
                                      console.log('warnPageCnt: ' + warnPageCnt + ', listLen: ' + listLen);
                                  
                                      setState(NSPanel_Path + 'warning.cnt', warningList.length);
                                      setState(NSPanel_Path + 'warning.aktiv', (warningList.length) > 0);
                                  }
                                  updateWarnings(null);
                                  warningListIds.forEach(e => on({id: e.id, change: 'any'}, updateWarnings));
                                  
                                  function showAlert(aObj: iobJS.ChangedStateObject<any,any>)
                                  {
                                      warnPageNo = 0;
                                      console.log('show Alert: ' + aObj.state.val);
                                  
                                      warnSubscribeHandler = on({id: '0_userdata.0.NSPanel.1.popupNotify.popupNotifyAction', change: 'any'}, switchPage);
                                      showAlarmPage();
                                  
                                      if(Debug) {
                                          console.log('show Alarmpage');
                                      }
                                  }
                                  
                                  function switchPage(aObj: iobJS.ChangedStateObject<any,any>)
                                  {
                                      if(aObj.state.val) {
                                          if(warningList.length != 0 && warnPageCnt != warnPageNo + 1) {
                                              warnPageNo = warnPageNo + 1;
                                          }
                                      }
                                      else
                                      {
                                          if(warnPageCnt != 0) {
                                              warnPageNo = warnPageNo - 1;
                                          }
                                      }
                                      showAlarmPage();
                                  
                                      if(Debug) {
                                          console.log('switch Alarmpage');
                                      }
                                  }
                                  on({id: '0_userdata.0.NSPanel.1.warning.showAlertInfo.SET', change: 'any'}, showAlert);
                                  
                                  function showAlarmPage()
                                  {
                                      let itemIndex = 0;
                                      let timeNow = Date.now();
                                  
                                      let popupText :string[] = [];
                                  
                                      if(warningList.length > 0)
                                      {
                                          for(let i = warnPageNo * warnItemsPerPage; i < (warnPageNo + 1)* warnItemsPerPage; i++) {
                                              if(i < warningList.length) {
                                                  let deltaTime = (timeNow - warningList[i].time)/1000 | 0;
                                                  let deltaTimeStr :string;
                                  
                                                  if(deltaTime < 60) {
                                                      deltaTimeStr = deltaTime + 's';
                                                  } else {
                                                      deltaTime = deltaTime/60 | 0;
                                                      if(deltaTime < 60) {
                                                          deltaTimeStr = deltaTime + 'm';
                                                      } else {
                                                          deltaTime = deltaTime/60 | 0;
                                                          if(deltaTime < 24) {
                                                              deltaTimeStr = deltaTime + 'h';
                                                          } else {
                                                              deltaTime = deltaTime/24 | 0;
                                                              deltaTimeStr = deltaTime + 'd';
                                                          }
                                                      }
                                                  }
                                  
                                                  let sourceList = warningListIds.find(e => e.id == warningList[i].source);
                                  
                                                  popupText.push(Icons.GetIcon(sourceList.icon) + ' ' + sourceList.prefix + warningList[i].objId + sourceList.postfix + deltaTimeStr);
                                              }
                                          }
                                      }
                                      else
                                      {
                                          popupText.push('No Warnings');
                                      }
                                  
                                      setStateAsync(popupNotifyHeading, <iobJS.State>{ val: 'Warnungsliste (' + (warnPageNo + 1) + '/' + warnPageCnt + ')', ack: false });
                                      setStateAsync(popupNotifyHeadingColor, <iobJS.State>{ val: rgb_dec565(Yellow).toString(), ack: false });
                                      setStateAsync(popupNotifyButton1Text, <iobJS.State>{ val: warnPageNo != 0 ? 'up' : '', ack: false });
                                      setStateAsync(popupNotifyButton1TextColor, <iobJS.State>{ val: rgb_dec565(White).toString(), ack: false });
                                      setStateAsync(popupNotifyButton2Text, <iobJS.State>{ val: (warnPageNo + 1) != warnPageCnt ? 'down' : '', ack: false });
                                      setStateAsync(popupNotifyButton2TextColor, <iobJS.State>{ val: rgb_dec565(White).toString(), ack: false });
                                      setStateAsync(popupNotifySleepTimeout, <iobJS.State>{ val: getState('0_userdata.0.NSPanel.1.Config.Screensaver.timeoutScreensaver').val, ack: false });
                                      setStateAsync(popupNotifyInternalName, <iobJS.State>{ val: '', ack: false });
                                      setStateAsync(popupNotifyLayout, <iobJS.State>{ val: 1, ack: false });
                                      setStateAsync(popupNotifyFontIdText, <iobJS.State>{ val: 1, ack: false });
                                      setStateAsync(popupNotifyText, <iobJS.State>{ val: popupText.join('\r\n\r\n'), ack: false });
                                  }
                                  
                                  type warningItem = {
                                      objId: string,
                                      time: number,
                                      source: (string | undefined)
                                  };
                                  

                                  @TT-Tom
                                  Danke das war genau der hinweis den ich gebraucht habe.

                                  draexlerD 1 Antwort Letzte Antwort
                                  0
                                  • B Bergi84

                                    @danny_v1
                                    puh das ist aber viel verstreuter Code und sicher noch nicht fehlerfrei. Ich versuch mal zumindest den NSPanel teil zu erklÀren und poste.

                                    Also damit die Liste aufgeht habe ich einen passenden Button Channel in den Objekten unter userdata angelegt:

                                    let mainConfig =  <PageGrid>
                                    {
                                        'type': 'cardGrid',
                                        'heading': 'Einstellungen',
                                        'useColor': true,
                                        'items': [
                                            <PageItem>{ id: '0_userdata.0.NSPanel.1.warning.showAlertInfo', icon: 'alert', name: 'Warnings', offColor: Yellow, onColor: Yellow},
                                    }
                                    

                                    Ich triggere einfach auf das umschalten und zeige anschließen das Notify an. Die Daten sind in mehrere Listen von den jeweiligen Überwachungsscripten aufgeteilt. Und jede liste ist als JSON in einem State der ebenfalls unter userdata gespeichert ist abgelegt. Bei jeder Änderung einer dieser Listen sammle ich alle daten ein sortiere Sie und aktualisiere die Anzeige. Das mach folgender code:

                                    // warn system
                                    createState(NSPanel_Path + 'warning.cnt');
                                    createState(NSPanel_Path + 'warning.aktiv');
                                    
                                    let warnPageNo;
                                    let warnPageCnt;
                                    let warnSubscribeHandler;
                                    let warningList :warningItem[];
                                    let warnItemsPerPage = 4;
                                    
                                    let warningListIds = [
                                        {id: '0_userdata.0.sensorSuperVisor.missingSensors', icon: 'connection', prefix: 'Verloren: ', postfix: ' vor '},
                                        {id: '0_userdata.0.batteryMonitor.batterLow', icon: 'battery-alert-variant-outline', prefix: 'Batterie schwach: ', postfix: ' vor '}
                                    ]
                                    function updateWarnings(aObj: iobJS.ChangedStateObject<any,any>)
                                    {
                                        warningList = [];
                                    
                                        warningListIds.forEach(listEle => {
                                            JSON.parse(getState(listEle.id).val).forEach((e :warningItem) => {
                                                e.source = listEle.id; warningList.push(e);
                                            });
                                        });
                                    
                                        console.log(JSON.stringify(warningListIds));
                                        console.log(JSON.stringify(warningList));
                                    
                                        let listLen = warningList.length;
                                    
                                        warningList.sort((a, b) => a.time - b.time);
                                    
                                        warnPageCnt = (listLen == 0) ? 1 : ((listLen + warnItemsPerPage-1) / warnItemsPerPage | 0);
                                    
                                        console.log('warnPageCnt: ' + warnPageCnt + ', listLen: ' + listLen);
                                    
                                        setState(NSPanel_Path + 'warning.cnt', warningList.length);
                                        setState(NSPanel_Path + 'warning.aktiv', (warningList.length) > 0);
                                    }
                                    updateWarnings(null);
                                    warningListIds.forEach(e => on({id: e.id, change: 'any'}, updateWarnings));
                                    
                                    function showAlert(aObj: iobJS.ChangedStateObject<any,any>)
                                    {
                                        warnPageNo = 0;
                                        console.log('show Alert: ' + aObj.state.val);
                                    
                                        warnSubscribeHandler = on({id: '0_userdata.0.NSPanel.1.popupNotify.popupNotifyAction', change: 'any'}, switchPage);
                                        showAlarmPage();
                                    
                                        if(Debug) {
                                            console.log('show Alarmpage');
                                        }
                                    }
                                    
                                    function switchPage(aObj: iobJS.ChangedStateObject<any,any>)
                                    {
                                        if(aObj.state.val) {
                                            if(warningList.length != 0 && warnPageCnt != warnPageNo + 1) {
                                                warnPageNo = warnPageNo + 1;
                                            }
                                        }
                                        else
                                        {
                                            if(warnPageCnt != 0) {
                                                warnPageNo = warnPageNo - 1;
                                            }
                                        }
                                        showAlarmPage();
                                    
                                        if(Debug) {
                                            console.log('switch Alarmpage');
                                        }
                                    }
                                    on({id: '0_userdata.0.NSPanel.1.warning.showAlertInfo.SET', change: 'any'}, showAlert);
                                    
                                    function showAlarmPage()
                                    {
                                        let itemIndex = 0;
                                        let timeNow = Date.now();
                                    
                                        let popupText :string[] = [];
                                    
                                        if(warningList.length > 0)
                                        {
                                            for(let i = warnPageNo * warnItemsPerPage; i < (warnPageNo + 1)* warnItemsPerPage; i++) {
                                                if(i < warningList.length) {
                                                    let deltaTime = (timeNow - warningList[i].time)/1000 | 0;
                                                    let deltaTimeStr :string;
                                    
                                                    if(deltaTime < 60) {
                                                        deltaTimeStr = deltaTime + 's';
                                                    } else {
                                                        deltaTime = deltaTime/60 | 0;
                                                        if(deltaTime < 60) {
                                                            deltaTimeStr = deltaTime + 'm';
                                                        } else {
                                                            deltaTime = deltaTime/60 | 0;
                                                            if(deltaTime < 24) {
                                                                deltaTimeStr = deltaTime + 'h';
                                                            } else {
                                                                deltaTime = deltaTime/24 | 0;
                                                                deltaTimeStr = deltaTime + 'd';
                                                            }
                                                        }
                                                    }
                                    
                                                    let sourceList = warningListIds.find(e => e.id == warningList[i].source);
                                    
                                                    popupText.push(Icons.GetIcon(sourceList.icon) + ' ' + sourceList.prefix + warningList[i].objId + sourceList.postfix + deltaTimeStr);
                                                }
                                            }
                                        }
                                        else
                                        {
                                            popupText.push('No Warnings');
                                        }
                                    
                                        setStateAsync(popupNotifyHeading, <iobJS.State>{ val: 'Warnungsliste (' + (warnPageNo + 1) + '/' + warnPageCnt + ')', ack: false });
                                        setStateAsync(popupNotifyHeadingColor, <iobJS.State>{ val: rgb_dec565(Yellow).toString(), ack: false });
                                        setStateAsync(popupNotifyButton1Text, <iobJS.State>{ val: warnPageNo != 0 ? 'up' : '', ack: false });
                                        setStateAsync(popupNotifyButton1TextColor, <iobJS.State>{ val: rgb_dec565(White).toString(), ack: false });
                                        setStateAsync(popupNotifyButton2Text, <iobJS.State>{ val: (warnPageNo + 1) != warnPageCnt ? 'down' : '', ack: false });
                                        setStateAsync(popupNotifyButton2TextColor, <iobJS.State>{ val: rgb_dec565(White).toString(), ack: false });
                                        setStateAsync(popupNotifySleepTimeout, <iobJS.State>{ val: getState('0_userdata.0.NSPanel.1.Config.Screensaver.timeoutScreensaver').val, ack: false });
                                        setStateAsync(popupNotifyInternalName, <iobJS.State>{ val: '', ack: false });
                                        setStateAsync(popupNotifyLayout, <iobJS.State>{ val: 1, ack: false });
                                        setStateAsync(popupNotifyFontIdText, <iobJS.State>{ val: 1, ack: false });
                                        setStateAsync(popupNotifyText, <iobJS.State>{ val: popupText.join('\r\n\r\n'), ack: false });
                                    }
                                    
                                    type warningItem = {
                                        objId: string,
                                        time: number,
                                        source: (string | undefined)
                                    };
                                    

                                    @TT-Tom
                                    Danke das war genau der hinweis den ich gebraucht habe.

                                    draexlerD Offline
                                    draexlerD Offline
                                    draexler
                                    schrieb am zuletzt editiert von
                                    #4053

                                    Will das hier nicht kappern ;-) Aber vielleicht kann ja jemand zwei Panels brauchen bzw. scheut das flashen.

                                    https://forum.iobroker.net/topic/69548/verkaufe-zwei-sonoff-nspanel

                                    1 Antwort Letzte Antwort
                                    0
                                    • F Foradh 0

                                      @tt-tom
                                      Die Einstellung ScreensaverInfo.activeBrightness hat bei mir keine Auswirkung auf die Helligkeit der popupNotify

                                      Allerdings bin ich durch deinen Hinweis auf die Benachrichtungen ĂŒber ScreensaverInfo und nicht ĂŒber popupNotify gestoßen.
                                      Diese Anzeige der Benachrichtigung gefĂ€llt mir fĂŒr meinen Fall besser.
                                      Allerdings habe ich auch hier ein paar Probleme...Ich habe mein Blockly entsprechend angepasst und es wird nun der Datenpunkt ScreensaverInfo.popupNotifyText gefĂŒllt. Die Anzeige funktioniert ebenfalls einwandfrei, auch ist das Display nach wie vor korrekt gedimmt und springt nicht auf 100% Helligkeit.
                                      Doch wenn ich nun die Benachrichtigung mit Klick auf das Display beende bleiben die Datenpunkte wie ScreensaverInfo.popupNotifyText mit dem Text bestehen.
                                      Wenn dann eine neue Benachrichtigung mit dem gleichen Text erscheinen soll wird dieser nicht getriggert und auch nichts im Display angezeigt.
                                      Mein Ziel ist es die Benachrichtigungen so einzustellen, dass die Nachricht und evtl. auch die Farbe des Hintergrund geÀndert wird, bis man die Benachrichtigung auf dem Display quittiert, dadurch die Datenpunkte wieder geleert werden und auch das Display wieder in die normale Hintergrundfarbe wechselt.

                                      F Offline
                                      F Offline
                                      Foradh 0
                                      schrieb am zuletzt editiert von
                                      #4054

                                      @foradh-0 sagte in SONOFF NSPanel mit Lovelace UI:

                                      @tt-tom
                                      Die Einstellung ScreensaverInfo.activeBrightness hat bei mir keine Auswirkung auf die Helligkeit der popupNotify

                                      Allerdings bin ich durch deinen Hinweis auf die Benachrichtungen ĂŒber ScreensaverInfo und nicht ĂŒber popupNotify gestoßen.
                                      Diese Anzeige der Benachrichtigung gefĂ€llt mir fĂŒr meinen Fall besser.
                                      Allerdings habe ich auch hier ein paar Probleme...Ich habe mein Blockly entsprechend angepasst und es wird nun der Datenpunkt ScreensaverInfo.popupNotifyText gefĂŒllt. Die Anzeige funktioniert ebenfalls einwandfrei, auch ist das Display nach wie vor korrekt gedimmt und springt nicht auf 100% Helligkeit.
                                      > Doch wenn ich nun die Benachrichtigung mit Klick auf das Display beende bleiben die Datenpunkte wie ScreensaverInfo.popupNotifyText mit dem Text bestehen.
                                      Wenn dann eine neue Benachrichtigung mit dem gleichen Text erscheinen soll wird dieser nicht getriggert und auch nichts im Display angezeigt.
                                      Mein Ziel ist es die Benachrichtigungen so einzustellen, dass die Nachricht und evtl. auch die Farbe des Hintergrund geÀndert wird, bis man die Benachrichtigung auf dem Display quittiert, dadurch die Datenpunkte wieder geleert werden und auch das Display wieder in die normale Hintergrundfarbe wechselt.

                                      Hat evtl. jemand die Benachrichtigungen so konfiguriert wie ich es hier beschrieben hatte und kann mir seine Konfiguration als Beispiel zur VerfĂŒgung stellen?

                                      Vielen Dank im Voraus

                                      T 1 Antwort Letzte Antwort
                                      0
                                      • F Foradh 0

                                        @foradh-0 sagte in SONOFF NSPanel mit Lovelace UI:

                                        @tt-tom
                                        Die Einstellung ScreensaverInfo.activeBrightness hat bei mir keine Auswirkung auf die Helligkeit der popupNotify

                                        Allerdings bin ich durch deinen Hinweis auf die Benachrichtungen ĂŒber ScreensaverInfo und nicht ĂŒber popupNotify gestoßen.
                                        Diese Anzeige der Benachrichtigung gefĂ€llt mir fĂŒr meinen Fall besser.
                                        Allerdings habe ich auch hier ein paar Probleme...Ich habe mein Blockly entsprechend angepasst und es wird nun der Datenpunkt ScreensaverInfo.popupNotifyText gefĂŒllt. Die Anzeige funktioniert ebenfalls einwandfrei, auch ist das Display nach wie vor korrekt gedimmt und springt nicht auf 100% Helligkeit.
                                        > Doch wenn ich nun die Benachrichtigung mit Klick auf das Display beende bleiben die Datenpunkte wie ScreensaverInfo.popupNotifyText mit dem Text bestehen.
                                        Wenn dann eine neue Benachrichtigung mit dem gleichen Text erscheinen soll wird dieser nicht getriggert und auch nichts im Display angezeigt.
                                        Mein Ziel ist es die Benachrichtigungen so einzustellen, dass die Nachricht und evtl. auch die Farbe des Hintergrund geÀndert wird, bis man die Benachrichtigung auf dem Display quittiert, dadurch die Datenpunkte wieder geleert werden und auch das Display wieder in die normale Hintergrundfarbe wechselt.

                                        Hat evtl. jemand die Benachrichtigungen so konfiguriert wie ich es hier beschrieben hatte und kann mir seine Konfiguration als Beispiel zur VerfĂŒgung stellen?

                                        Vielen Dank im Voraus

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

                                        @foradh-0
                                        Der Trigger reagiert auf die Datenpunkte ScreensaverInfo.popupNotifyHeading und ScreensaverInfo.popupNotifyText. Damit der Trigger immer reagiert habe ich zur Meldung (TEXT) immer die Uhrzeit mit eingefĂŒgt. Damit sehe ich auch, wann die Meldung aufgelaufen ist.

                                        Gruß Tom

                                        Wenn meine Hilfe erfolgreich war, benutze bitte das Voting unten rechts im Beitrag

                                        Public Transport
                                        https://github.com/tt-tom17/ioBroker.public-transport
                                        https://github.com/tt-tom17/ioBroker.public-transport/wiki

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

                                        F 1 Antwort Letzte Antwort
                                        1
                                        • T TT-Tom

                                          @foradh-0
                                          Der Trigger reagiert auf die Datenpunkte ScreensaverInfo.popupNotifyHeading und ScreensaverInfo.popupNotifyText. Damit der Trigger immer reagiert habe ich zur Meldung (TEXT) immer die Uhrzeit mit eingefĂŒgt. Damit sehe ich auch, wann die Meldung aufgelaufen ist.

                                          F Offline
                                          F Offline
                                          Foradh 0
                                          schrieb am zuletzt editiert von
                                          #4056

                                          @tt-tom
                                          Vielen Dank Tom 👍

                                          1 Antwort Letzte Antwort
                                          0

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

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

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

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          300

                                          Online

                                          32.9k

                                          Benutzer

                                          83.2k

                                          Themen

                                          1.3m

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

                                          • Du hast noch kein Konto? Registrieren

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