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

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. Hardware
  4. SONOFF NSPanel mit Lovelace UI

NEWS

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

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

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

SONOFF NSPanel mit Lovelace UI

SONOFF NSPanel mit Lovelace UI

Scheduled Pinned Locked Moved Hardware
lovelace uinspanelsonoff
7.7k Posts 271 Posters 6.7m Views 253 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • ArmilarA Armilar

    @theknut

    Super - war ne härtere Nuss als ursprünglich angenommen 😊

    theknutT Offline
    theknutT Offline
    theknut
    wrote on last edited by theknut
    #4486

    @armilar Ich werd demnächst auch mal noch was auf Github beisteuern. Nur paar Kleinigkeiten...

    Gleich noch eine Anschlussfrage: Besteht irgendwie die Möglichkeit ein Bild (jpg, png, ...) an das Panel zu schicken und als Popup anzuzeigen? Wenn ja, wie würde das gehen? Ich würde mich auch an der Implementation beteiligen, falls das umsetzbar wäre.

    ☕ @ https://ko-fi.com/theknut

    ArmilarA 1 Reply Last reply
    1
    • theknutT theknut

      @armilar Ich werd demnächst auch mal noch was auf Github beisteuern. Nur paar Kleinigkeiten...

      Gleich noch eine Anschlussfrage: Besteht irgendwie die Möglichkeit ein Bild (jpg, png, ...) an das Panel zu schicken und als Popup anzuzeigen? Wenn ja, wie würde das gehen? Ich würde mich auch an der Implementation beteiligen, falls das umsetzbar wäre.

      ArmilarA Offline
      ArmilarA Offline
      Armilar
      Most Active Forum Testing
      wrote on last edited by
      #4487

      @theknut

      Leider nein. Bilder funktionieren nicht... nur Icons und die sind alle in einem TTF

      Ich werd demnächst auch mal noch was auf Github beisteuern. Nur paar Kleinigkeiten...

      Immer zu 😉

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

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

      theknutT 1 Reply Last reply
      0
      • ArmilarA Armilar

        @theknut

        Leider nein. Bilder funktionieren nicht... nur Icons und die sind alle in einem TTF

        Ich werd demnächst auch mal noch was auf Github beisteuern. Nur paar Kleinigkeiten...

        Immer zu 😉

        theknutT Offline
        theknutT Offline
        theknut
        wrote on last edited by
        #4488

        @armilar schade.... wäre echt nice gewesen wenn man einen Snapshot von der Überwachungskamera anzeigen könnte, wenn jemand klingelt.

        ☕ @ https://ko-fi.com/theknut

        ArmilarA 1 Reply Last reply
        0
        • theknutT theknut

          @armilar schade.... wäre echt nice gewesen wenn man einen Snapshot von der Überwachungskamera anzeigen könnte, wenn jemand klingelt.

          ArmilarA Offline
          ArmilarA Offline
          Armilar
          Most Active Forum Testing
          wrote on last edited by Armilar
          #4489

          @theknut

          Ich weiß - habe über mache Dinge auch schon getrauert - Ist trotzdem der coolste Lichtschalter 😊

          Falls du noch einen ESP32 rumliegen hast:
          https://github.com/joBr99/nspanel-lovelace-ui/wiki/NSPanel-Nextion-Editor

          Kannst auch direkt die Nextion HMI sehen...

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

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

          ArmilarA 1 Reply Last reply
          0
          • ArmilarA Armilar

            @theknut

            Ich weiß - habe über mache Dinge auch schon getrauert - Ist trotzdem der coolste Lichtschalter 😊

            Falls du noch einen ESP32 rumliegen hast:
            https://github.com/joBr99/nspanel-lovelace-ui/wiki/NSPanel-Nextion-Editor

            Kannst auch direkt die Nextion HMI sehen...

            ArmilarA Offline
            ArmilarA Offline
            Armilar
            Most Active Forum Testing
            wrote on last edited by Armilar
            #4490

            v4.3.3.19 - Dimmode Fix

            e6a5daa4-47ac-4a43-a1a9-879e239a8692-image.png

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

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

            1 Reply Last reply
            2
            • ArmilarA Armilar

              @bhenyamin sagte in SONOFF NSPanel mit Lovelace UI:

              per Shelly Plug die normale Kaffeemaschine vom Strom - (Ja ich weiss, klingt unschön)

              Nein, ist absolut okay und mache ich bei diversen Geräten ohne smarte Funktionen genauso.

              Müsste mit einem zweckentfremdeten popupTimer gehen... Muss ich mir aber kurz ansehen... Gib mir etwas Zeit...

              EDIT: @TT-Tom wird sich den popupTimer mal ansehen...

              B Offline
              B Offline
              Bhenyamin
              wrote on last edited by
              #4491

              @armilar said in SONOFF NSPanel mit Lovelace UI:

              @bhenyamin sagte in SONOFF NSPanel mit Lovelace UI:

              per Shelly Plug die normale Kaffeemaschine vom Strom - (Ja ich weiss, klingt unschön)

              Nein, ist absolut okay und mache ich bei diversen Geräten ohne smarte Funktionen genauso.

              Müsste mit einem zweckentfremdeten popupTimer gehen... Muss ich mir aber kurz ansehen... Gib mir etwas Zeit...

              EDIT: @TT-Tom wird sich den popupTimer mal ansehen...

              😄 😄 "ich weiss, klingt unschön" zielte auf die frühe Uhrzeit ab, für die ich meine Frau oft nicht beneide. Ansonsten halte ich das auch absolut für safe bei so analogen Geräten, die sich ja insb. selbst nochmal über Thermoschalter etc. absichern.
              Aber Danke für deine Bestätigung. 🙂

              1 Reply Last reply
              0
              • ArmilarA Armilar

                @bhenyamin

                9ddffb47-ac57-42f3-a284-9b3939c598db-Nextion_Editor_RAZZgQRgxV.gif

                Für die Kaffeemaschine und den Shelly gibt es auch eine Lösung. Haben einen neuen Alias-Typen eingeführt.

                Anleitung (Mini-Script) und Funktionalität folgt mit der nächsten Version.

                B Offline
                B Offline
                Bhenyamin
                wrote on last edited by
                #4492

                @armilar said in SONOFF NSPanel mit Lovelace UI:

                @bhenyamin

                9ddffb47-ac57-42f3-a284-9b3939c598db-Nextion_Editor_RAZZgQRgxV.gif

                Für die Kaffeemaschine und den Shelly gibt es auch eine Lösung. Haben einen neuen Alias-Typen eingeführt.

                Anleitung (Mini-Script) und Funktionalität folgt mit der nächsten Version.

                Ja stark! Genau so habe ich gedacht! Wie geil! Super...

                ArmilarA 1 Reply Last reply
                1
                • B Bhenyamin

                  @armilar said in SONOFF NSPanel mit Lovelace UI:

                  @bhenyamin

                  9ddffb47-ac57-42f3-a284-9b3939c598db-Nextion_Editor_RAZZgQRgxV.gif

                  Für die Kaffeemaschine und den Shelly gibt es auch eine Lösung. Haben einen neuen Alias-Typen eingeführt.

                  Anleitung (Mini-Script) und Funktionalität folgt mit der nächsten Version.

                  Ja stark! Genau so habe ich gedacht! Wie geil! Super...

                  ArmilarA Offline
                  ArmilarA Offline
                  Armilar
                  Most Active Forum Testing
                  wrote on last edited by
                  #4493

                  @bhenyamin

                  @TT-Tom bastelt noch etwas rum - kommt dann mit der v4.3.3.20

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

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

                  1 Reply Last reply
                  1
                  • D Offline
                    D Offline
                    damst
                    wrote on last edited by
                    #4494

                    Hey Zusammen,

                    arbeite mich seit ein paar Tagen in das NSPanel mit LUI ein, bisher klappt alles ganz gut.
                    An dieser Stelle ein großes Lob an die Macher!

                    Leider finde ich nichts zum einbinden der Datenpunkte einer HMIP-BROLL Rollosteuerung.
                    HMIP erwartet für den Level Datenpunkt eine Angabe von 0 - 1. Also wären 25% = 0.25

                    Ich habe versucht über die minValue und maxValue zu arbeiten, leider klappt dies nicht. Das Rollo wird entweder einfach zu gefahren, oder auf.

                    Hat hier jemand eine Lösung wie ich das umgesetzt bekomme?

                    Viele Grüße.

                    1 Reply Last reply
                    0
                    • ArmilarA Offline
                      ArmilarA Offline
                      Armilar
                      Most Active Forum Testing
                      wrote on last edited by Armilar
                      #4495

                      @damst

                      Am Besten wäre es mal die Datenpunkte vom HmIP-BROLL zu senden

                      Und das aktuelle PageItem mit dem Rollo.

                      Ich bin heute den ganzen Tag nicht in Reichweite eines Test-Rechners... Ich denke es gibt so den einen oder anderen mit einem HmIP-BROLL im Thread und das Thema wird sich lösen lassen.

                      Erster Ansatz wäre dem Alias eine Konvertierung (val * 100) beim lesen mitzugeben und (val / 100) beim schreiben. Ansonsten könnte ich erst morgen wieder unterstützen.

                      Ich hätte angenommen, dass der BROLL auch einen Level von 0-100% unterstützt.

                      Ist der an einer CCU oder am AP?

                      EDIT: Es ging Anfang des Jahres um den BROLL im Post von @mading :
                      https://forum.iobroker.net/post/929657

                      Er hat übrigens einen Datenpunkt Level von 0-100 wenn ich das richtig sehe...

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

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

                      M D 2 Replies Last reply
                      0
                      • T Offline
                        T Offline
                        TT-Tom
                        wrote on last edited by
                        #4496

                        Update v4.3.3.20

                        v43320.png

                        Nextion_Editor_M0iQy5KkDb.gif

                        das Update bringt jetzt einen "Wecker" mit, wir nutzen dazu die popupSeite Timer, welche ihr schon vom Countdown kennt. Um die Nutzung zu erleichtern, im Bezug auf das erstellen der Datenpunkte haben wir zwei Scrpite erstellt. Diese steuern auch den Countdown bzw. den Wecker.

                        Script für Wecker

                        Script für Countdown

                        Die Scripte werden im Javascript - Adapter ganz normal unter "common" gespeichert.

                        vor den ersten Start des Script müssen diese Datenpunkte angepasst werden.

                        const dp_userdata: string = '0_userdata.0.NSPanel';
                        const dp_alias: string = 'alias.0.NSPanel';
                        

                        Im Script "Wecker" (Alarm_clock.ts) ist dieser DatenPunkt wichtig für die Auslösung, diesen müsst ihr selbst erstellen vom Type Boolean oder ihr könnt hier auch einen DatenPunkt eintragen, der auf true gesetzt werden soll z.B. bei einem Shelly den Switch.

                        // dpAction wird wenn der Wecker gestellt wird auf false geschaltet
                        // dpAction wird wenn die Weckzeit erreicht ist auf true geschaltet
                        // Der nachfolgende Datenpunkt muss manuell erstellt werden...
                        const dpAction: string = '0_userdata.0.example_boolean';
                        

                        Im Script Countdown ist dieser DP noch nicht von Bedeutung, ihr könnt aber in diesem Bereich das Script erweitern, um eine Reaktion am Ende des Countdowns zu erzielen.

                                setState(dp_userdata + '.Countdown.Time', 0,  false);
                                setState(dp_userdata + '.Countdown.State', 'idle', false);
                                // An dieser Stelle kann auch noch eine Meldung an Alexa oder Telegram, etc. erfolgen
                              }
                        

                        Wenn das Script dann gestartet wurde, bekommt ihr nach dem Erstellen der Datenpunkte im Log einen fertigen PageItem angezeigt. Diesen könnt ihr kopieren und in eure Seite (z.B. cardGrid) einfügen. hier das Beispiel für den Countdown

                        2023-12-08 19:44:11.429  - info    javascript.1 (8773) script.js.common.Testcenter.Countdown_NSPanel: <PageItem>{id: alias.0.NSPanel.Countown, name: 'Timer'}
                        

                        Viel Spass und einen schönen 2. Advent wünschen Euch
                        @Armilar und TT-Tom

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

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

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

                        T 1 Reply Last reply
                        5
                        • T TT-Tom

                          Update v4.3.3.20

                          v43320.png

                          Nextion_Editor_M0iQy5KkDb.gif

                          das Update bringt jetzt einen "Wecker" mit, wir nutzen dazu die popupSeite Timer, welche ihr schon vom Countdown kennt. Um die Nutzung zu erleichtern, im Bezug auf das erstellen der Datenpunkte haben wir zwei Scrpite erstellt. Diese steuern auch den Countdown bzw. den Wecker.

                          Script für Wecker

                          Script für Countdown

                          Die Scripte werden im Javascript - Adapter ganz normal unter "common" gespeichert.

                          vor den ersten Start des Script müssen diese Datenpunkte angepasst werden.

                          const dp_userdata: string = '0_userdata.0.NSPanel';
                          const dp_alias: string = 'alias.0.NSPanel';
                          

                          Im Script "Wecker" (Alarm_clock.ts) ist dieser DatenPunkt wichtig für die Auslösung, diesen müsst ihr selbst erstellen vom Type Boolean oder ihr könnt hier auch einen DatenPunkt eintragen, der auf true gesetzt werden soll z.B. bei einem Shelly den Switch.

                          // dpAction wird wenn der Wecker gestellt wird auf false geschaltet
                          // dpAction wird wenn die Weckzeit erreicht ist auf true geschaltet
                          // Der nachfolgende Datenpunkt muss manuell erstellt werden...
                          const dpAction: string = '0_userdata.0.example_boolean';
                          

                          Im Script Countdown ist dieser DP noch nicht von Bedeutung, ihr könnt aber in diesem Bereich das Script erweitern, um eine Reaktion am Ende des Countdowns zu erzielen.

                                  setState(dp_userdata + '.Countdown.Time', 0,  false);
                                  setState(dp_userdata + '.Countdown.State', 'idle', false);
                                  // An dieser Stelle kann auch noch eine Meldung an Alexa oder Telegram, etc. erfolgen
                                }
                          

                          Wenn das Script dann gestartet wurde, bekommt ihr nach dem Erstellen der Datenpunkte im Log einen fertigen PageItem angezeigt. Diesen könnt ihr kopieren und in eure Seite (z.B. cardGrid) einfügen. hier das Beispiel für den Countdown

                          2023-12-08 19:44:11.429  - info    javascript.1 (8773) script.js.common.Testcenter.Countdown_NSPanel: <PageItem>{id: alias.0.NSPanel.Countown, name: 'Timer'}
                          

                          Viel Spass und einen schönen 2. Advent wünschen Euch
                          @Armilar und TT-Tom

                          T Offline
                          T Offline
                          TT-Tom
                          wrote on last edited by
                          #4497

                          @tt-tom

                          Noch eine Erklärung zum Wecker.
                          am Symbol könnt ihr den Status und die eingestellte Weckzeit erkennen.

                          Wecker ein.png
                          Wecker ein

                          Wecker aus.png
                          Wecker aus

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

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

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

                          1 Reply Last reply
                          2
                          • ArmilarA Armilar

                            @damst

                            Am Besten wäre es mal die Datenpunkte vom HmIP-BROLL zu senden

                            Und das aktuelle PageItem mit dem Rollo.

                            Ich bin heute den ganzen Tag nicht in Reichweite eines Test-Rechners... Ich denke es gibt so den einen oder anderen mit einem HmIP-BROLL im Thread und das Thema wird sich lösen lassen.

                            Erster Ansatz wäre dem Alias eine Konvertierung (val * 100) beim lesen mitzugeben und (val / 100) beim schreiben. Ansonsten könnte ich erst morgen wieder unterstützen.

                            Ich hätte angenommen, dass der BROLL auch einen Level von 0-100% unterstützt.

                            Ist der an einer CCU oder am AP?

                            EDIT: Es ging Anfang des Jahres um den BROLL im Post von @mading :
                            https://forum.iobroker.net/post/929657

                            Er hat übrigens einen Datenpunkt Level von 0-100 wenn ich das richtig sehe...

                            M Online
                            M Online
                            mading
                            wrote on last edited by
                            #4498

                            @armilar @damst

                            Ich verwende ein Blockly, um einen Rolladen mit den HW Tasten zu bewegen. Kannst du aber sicher analog verwenden:

                            IMG_1813.jpeg

                            
                            <xml xmlns="https://developers.google.com/blockly/xml">
                              <block type="comment" id="ZbJz+/[p1rajA5=A_Jer" x="163" y="188">
                                <field name="COMMENT">NSPanel HW Buttons Rolladen UG Büro hoch/ runter</field>
                                <next>
                                  <block type="on" id="eg!xq0T5*|mP_W-*@x!n">
                                    <field name="OID">mqtt.1.SmartHome.NSPanel_1.stat.POWER1</field>
                                    <field name="CONDITION">ne</field>
                                    <field name="ACK_CONDITION"></field>
                                    <statement name="STATEMENT">
                                      <block type="controls_if" id="J.e]tOLx_Dy,!Pk#2Ds8">
                                        <value name="IF0">
                                          <block type="logic_compare" id="84*dZQ!phLqJM)VGg_7J">
                                            <field name="OP">EQ</field>
                                            <value name="A">
                                              <block type="on_source" id="{_qF%I9_m_u.av;`!S1u">
                                                <field name="ATTR">state.val</field>
                                              </block>
                                            </value>
                                            <value name="B">
                                              <block type="text" id="M4#3.o%.#;){.U@0SF[T">
                                                <field name="TEXT">ON</field>
                                              </block>
                                            </value>
                                          </block>
                                        </value>
                                        <statement name="DO0">
                                          <block type="control" id="rX[aMW`4Y}pEF.HXDxeJ">
                                            <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                            <field name="OID">hm-rpc.0.00111A49A1BD55.4.LEVEL</field>
                                            <field name="WITH_DELAY">FALSE</field>
                                            <value name="VALUE">
                                              <block type="math_number" id="P2t}lcI8;=Lul[Pd(m#:">
                                                <field name="NUM">100</field>
                                              </block>
                                            </value>
                                          </block>
                                        </statement>
                                      </block>
                                    </statement>
                                    <next>
                                      <block type="on" id="#r:^6n(/2fD=H,`}GfN5">
                                        <field name="OID">mqtt.1.SmartHome.NSPanel_1.stat.POWER2</field>
                                        <field name="CONDITION">ne</field>
                                        <field name="ACK_CONDITION"></field>
                                        <statement name="STATEMENT">
                                          <block type="controls_if" id=",)L?:v;*RO^UrfdAW|vp">
                                            <value name="IF0">
                                              <block type="logic_compare" id="DriV5:M(,I2k^s}XZyjr">
                                                <field name="OP">EQ</field>
                                                <value name="A">
                                                  <block type="on_source" id="8._u#%.BN^x5Rf$^R@CO">
                                                    <field name="ATTR">state.val</field>
                                                  </block>
                                                </value>
                                                <value name="B">
                                                  <block type="text" id="vF9sdr98LEJUGgyFIJsQ">
                                                    <field name="TEXT">ON</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </value>
                                            <statement name="DO0">
                                              <block type="control" id="pD,JDj,v-lo~7`kHi5D,">
                                                <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                                <field name="OID">hm-rpc.0.00111A49A1BD55.4.LEVEL</field>
                                                <field name="WITH_DELAY">FALSE</field>
                                                <value name="VALUE">
                                                  <block type="math_number" id="QluVuVi#f0xw;eCMV#mW">
                                                    <field name="NUM">0</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </statement>
                                          </block>
                                        </statement>
                                      </block>
                                    </next>
                                  </block>
                                </next>
                              </block>
                            </xml>
                            
                            
                            1 Reply Last reply
                            1
                            • ArmilarA Armilar

                              @damst

                              Am Besten wäre es mal die Datenpunkte vom HmIP-BROLL zu senden

                              Und das aktuelle PageItem mit dem Rollo.

                              Ich bin heute den ganzen Tag nicht in Reichweite eines Test-Rechners... Ich denke es gibt so den einen oder anderen mit einem HmIP-BROLL im Thread und das Thema wird sich lösen lassen.

                              Erster Ansatz wäre dem Alias eine Konvertierung (val * 100) beim lesen mitzugeben und (val / 100) beim schreiben. Ansonsten könnte ich erst morgen wieder unterstützen.

                              Ich hätte angenommen, dass der BROLL auch einen Level von 0-100% unterstützt.

                              Ist der an einer CCU oder am AP?

                              EDIT: Es ging Anfang des Jahres um den BROLL im Post von @mading :
                              https://forum.iobroker.net/post/929657

                              Er hat übrigens einen Datenpunkt Level von 0-100 wenn ich das richtig sehe...

                              D Offline
                              D Offline
                              damst
                              wrote on last edited by
                              #4499

                              @armilar @mading

                              Guten Morgen,

                              danke ihr beiden. Der Tipp mit der Konvertierung hat geholfen.
                              Die BROLL's hängen am AP.

                              1 Reply Last reply
                              2
                              • T TT-Tom

                                @ompi

                                so ist jetzt auf Github, die Werte sollten auch schon bei dir passen. Habe viel geändert, darum bitte das ganze Script ersetzen.

                                O Offline
                                O Offline
                                ompi
                                wrote on last edited by
                                #4500

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

                                @ompi

                                so ist jetzt auf Github, die Werte sollten auch schon bei dir passen. Habe viel geändert, darum bitte das ganze Script ersetzen.

                                Vielen Dank! Klappt alles, wie gewünscht!

                                Grüße
                                ompi

                                1 Reply Last reply
                                2
                                • ArmilarA Offline
                                  ArmilarA Offline
                                  Armilar
                                  Most Active Forum Testing
                                  wrote on last edited by Armilar
                                  #4501

                                  Heute mal etwas NSPanel-Off-Topic und für die Alexa-Freunde unter euch:

                                  Habe ein kleines externes Type-Script zur Synchronisierung der Alexa-Timer und der NSPanel-Countdown's in der popupTimer. Vielleicht ist es ja für den ein oder anderen interessant? 🙂

                                  // External TypeScript (TS) by @Armilar (2023-12-11)
                                  
                                  /*************************************************************************************
                                  * Use Case                                                                           *
                                  * 1. Es soll, wenn irgendein Alexa-Echo-Gerät im Haus einen Timer z.B. per Sprache   *
                                  *    gesetzt bekommt, dieser als Countdown auch im NSPanel übernommen werden.        *
                                  * 2. Es soll, wenn ein Countdown in einem definierten NSPanel eingestellt wird,      *
                                  *    auch ein Timer im primären Amazon Echo gesetzt werden.                          *
                                  * 3. Wenn ein Timer/Countdown über Alexa oder NSpanel gesetzt wird, dann soll sich   *
                                  *    der Die Seite mit dem aktiven Countdown öffnen (!!! aktuell nur bis zur         *
                                  *    entsprechenden Seite des PageArrays im NSPanelTs.ts möglich, da das popupTimer  *
                                  *    aktuell "noch" über das Display mit dem Finger aufgeschaltet werden "muss" !!!) *
                                  * 4. Es soll keine optionale Programmierung im NSPanelTs.ts erforderlich sein!       *
                                  * 5. Hinweis: Alexa-Zeit und System-Zeit können voneinander abweichen, wenn kein     *
                                  *    NTP-Server auf dem ioBroker-Betriebssystem läuft!                               *
                                  **************************************************************************************/
                                  
                                  // Für mehr Informationen beim Test von "false" auf "true" setzen
                                  const Debug = true;
                                  
                                  // z.B. Seriennummer des Echo Büro - wird nur benötigt, wenn über das NSPanel ein Countdown gesetzt wird 
                                  //An Deine Seriennummer anpassen
                                  const primaryEchoDeviceSerial = 'G070RRXXXXXXXXXX'; 
                                  
                                  // Datenpunkte für den Countdown-Timer im bestimmten NSPanel X
                                  const NSPanel_Path: string = '0_userdata.0.NSPanel.1.' // für PageNavi-Datenpunkt
                                  const dpZustand: string = '0_userdata.0.Timer.NSPanel.1.Countdown.Zustand';
                                  const dpSekunden: string = '0_userdata.0.Timer.NSPanel.1.Countdown.Sekunden';
                                  
                                  // Wird benötigt um die Page (cardGrid oder cardEntities) mit dem CountdownTimer aufzuschalten. Bei mir ist der Timer auf Page-Nr.: 10
                                  // Genutzt wird der Datenpunkt des Panels in 0_userdata -->  PageNavi
                                  const timerPageArray: number = 10;
                                  
                                  /********************* Ab hier keine Änderungen mehr erforderlich *******************/
                                  let vInterval: any = null;
                                  let countInterval: number = 0;
                                  
                                  //let vTimeout: any = null; // Wird erst benötigt, wenn popupTimer auch aufgeschaltet werden kann 
                                                              // oder irgendwann eine cardTimer existiert!
                                  
                                  // Trigger löst aus wenn im Haus irgendein Timer über Alexa gesetzt wird 
                                  on({ id: [].concat(Array.prototype.slice.apply($('alexa2.0.Echo-Devices.*.Timer.activeTimerList'))), change: 'ne' }, async (obj) => {
                                  
                                      // Lösche falls rückwärtszählendes Interval läuft
                                      clearInterval(vInterval);
                                      
                                      // Erzeuge Array mit getriggertem Echo
                                      let deviceSerialNumber: any = obj.deviceId.split('.');
                                      // Zerlege Pfad und hole Seriennummer des getriggerten Echo
                                      let deviceSerialNr: string = deviceSerialNumber[3];
                                  
                                      if (Debug) {
                                          log('activeTimerList wurde durch Device ' + deviceSerialNr + ' geändert', 'info');
                                      }
                                  
                                      let timerObj = JSON.parse(getState('alexa2.0.Echo-Devices.' + deviceSerialNr + '.Timer.activeTimerList').val);
                                      
                                      // ermitteln der Anzahl aktiver Timer
                                      let activeTimerListLength = timerObj.length;
                                      
                                      let timerList: any = [];
                                      //Liest alle Echo-Timer in Array timerList ein
                                      for (let i = 0; i < timerObj.length; i++) {
                                          timerList[i] = getAttr(timerObj, i + '.triggerTime');
                                      }
                                  
                                      // Sortiere alle Timer der Größe nach (klein zuerst)
                                      timerList = timerList.sort(function(a: any,b: any) {
                                          return a - b;
                                      });
                                  
                                      // Wenn mindestens 1 Timer aktiv ist
                                      if (activeTimerListLength > 0) {
                                  
                                          if (Debug) {
                                              log(getState('alexa2.0.Echo-Devices.' + deviceSerialNr + '.Timer.activeTimerList').val, 'info');
                                          }
                                  
                                          // Startzeit für Timer ist "Jetzt"
                                          let timerStartTime: any = (new Date().getTime());
                                          let start: string = (formatDate(getDateObject(timerStartTime), "YYYY-MM-DD hh:mm:ss"));
                                          // Nur der kleinste sortierte Timer muss auf dem NSPanel angezeigt werden. 
                                          // Alle gestellten Timer werden der Reihe nach abgearbeitet.
                                          let timerEndTime: any = timerList[0];        
                                          let end: string = (formatDate(getDateObject(timerEndTime), "YYYY-MM-DD hh:mm:ss"));
                                  
                                          if (Debug) {
                                              log(String(calculateTimeDifferenceInSeconds(start, end)), 'info');
                                          }
                                  
                                          // Ermittel verbleibende Sekunden
                                          let countRemainingSeconds = calculateTimeDifferenceInSeconds(start, end);
                                          // Setze Countdown-Datenpunkt auf aktiv
                                          await setStateAsync(dpZustand, <iobJS.State>{ val: 'active', ack: true });
                                          
                                          // Schalte Timer cardGrid/cardEntities auf
                                          await setStateAsync(NSPanel_Path + 'PageNavi', 
                                                              <iobJS.State>{ val: '{ "pagetype": "page","pageId": ' + timerPageArray + ' }', ack: true });
                                  
                                          // Es darf nur ein Interval zur gleichen Zeit existieren
                                          if (countInterval <= 1) {
                                  
                                              log(activeTimerListLength + ' Timer aktiv', 'info')
                                  
                                              countInterval = 1;
                                              vInterval = setInterval(async function(){
                                                  // Dekrmentiere um 1 Sekunde
                                                  countRemainingSeconds -= 1;
                                  
                                                  // Wenn Timer auf 0 angekommen
                                                  if(countRemainingSeconds === 0){
                                                      clearInterval(vInterval);
                                                      await setStateAsync(dpZustand, <iobJS.State>{ val: 'pause', ack: true });
                                                  }
                                  
                                                  if (Debug) {
                                                      log(String(countRemainingSeconds), 'info');
                                                  }
                                  
                                                  setState(dpSekunden, countRemainingSeconds);
                                  
                                              }, 1000);
                                          }
                                      } else {
                                          log('Kein Alexa Countdown Timer aktiv', 'info');
                                          // Lösche falls noch ein rückwärtszählendes Interval läuft
                                          clearInterval(vInterval);
                                          vInterval = null;
                                          countInterval = 0;
                                          await setStateAsync(dpSekunden, <iobJS.State>{ val: 0, ack: true });
                                          await setStateAsync(dpZustand, <iobJS.State>{ val: 'idle', ack: true });
                                      }
                                  });
                                  
                                  // Trigger löst aus, wenn ein Countdown im NSPanel gesetzt wird und soll Alexa Timer stellen
                                  // Löst aber auch aus, wenn Alexa-Timer DP verändert. Daher Einschränkung auf einen einzigen Countdown-Timer
                                  on({ id: [].concat([dpSekunden]), change: 'ne' }, async (obj) => {
                                      // Nur wenn kein Countdown aktiv ist und noch kein Countdown-Timer läuft
                                      if (getState(dpZustand).val === 'idle' && vInterval === null) {
                                          
                                          if (Debug) {
                                              log('NSPanel hat Countdown von: ' + obj.state.val + ' Sekunden bekommen', 'info');
                                          }
                                          
                                          setState('alexa2.0.Echo-Devices.' + primaryEchoDeviceSerial + '.Commands.textCommand', 
                                                   'Stelle Timer auf' + obj.state.val + ' Sekunden');
                                  
                                      }
                                  });
                                  
                                  // Funktion zur Ermittlung der Sekunden aus zwei Zeitstempeln
                                  function calculateTimeDifferenceInSeconds(start: string, end: string) : number {
                                  
                                      const startTime: any = new Date(start);
                                      const endTime: any = new Date(end);
                                      const diffInMilliseconds = endTime - startTime;
                                      const diffInSeconds = Math.floor(diffInMilliseconds / 1000);
                                      
                                      return diffInSeconds;
                                  
                                  }
                                  

                                  Da es ja TypeScript ist, habe ich es so gut es geht versucht zu kommentieren...

                                  Viel Spaß bei der Benutzung oder bei der Anpassung...

                                  VG
                                  Armilar 😊

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

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

                                  theknutT 1 Reply Last reply
                                  3
                                  • ArmilarA Armilar

                                    Heute mal etwas NSPanel-Off-Topic und für die Alexa-Freunde unter euch:

                                    Habe ein kleines externes Type-Script zur Synchronisierung der Alexa-Timer und der NSPanel-Countdown's in der popupTimer. Vielleicht ist es ja für den ein oder anderen interessant? 🙂

                                    // External TypeScript (TS) by @Armilar (2023-12-11)
                                    
                                    /*************************************************************************************
                                    * Use Case                                                                           *
                                    * 1. Es soll, wenn irgendein Alexa-Echo-Gerät im Haus einen Timer z.B. per Sprache   *
                                    *    gesetzt bekommt, dieser als Countdown auch im NSPanel übernommen werden.        *
                                    * 2. Es soll, wenn ein Countdown in einem definierten NSPanel eingestellt wird,      *
                                    *    auch ein Timer im primären Amazon Echo gesetzt werden.                          *
                                    * 3. Wenn ein Timer/Countdown über Alexa oder NSpanel gesetzt wird, dann soll sich   *
                                    *    der Die Seite mit dem aktiven Countdown öffnen (!!! aktuell nur bis zur         *
                                    *    entsprechenden Seite des PageArrays im NSPanelTs.ts möglich, da das popupTimer  *
                                    *    aktuell "noch" über das Display mit dem Finger aufgeschaltet werden "muss" !!!) *
                                    * 4. Es soll keine optionale Programmierung im NSPanelTs.ts erforderlich sein!       *
                                    * 5. Hinweis: Alexa-Zeit und System-Zeit können voneinander abweichen, wenn kein     *
                                    *    NTP-Server auf dem ioBroker-Betriebssystem läuft!                               *
                                    **************************************************************************************/
                                    
                                    // Für mehr Informationen beim Test von "false" auf "true" setzen
                                    const Debug = true;
                                    
                                    // z.B. Seriennummer des Echo Büro - wird nur benötigt, wenn über das NSPanel ein Countdown gesetzt wird 
                                    //An Deine Seriennummer anpassen
                                    const primaryEchoDeviceSerial = 'G070RRXXXXXXXXXX'; 
                                    
                                    // Datenpunkte für den Countdown-Timer im bestimmten NSPanel X
                                    const NSPanel_Path: string = '0_userdata.0.NSPanel.1.' // für PageNavi-Datenpunkt
                                    const dpZustand: string = '0_userdata.0.Timer.NSPanel.1.Countdown.Zustand';
                                    const dpSekunden: string = '0_userdata.0.Timer.NSPanel.1.Countdown.Sekunden';
                                    
                                    // Wird benötigt um die Page (cardGrid oder cardEntities) mit dem CountdownTimer aufzuschalten. Bei mir ist der Timer auf Page-Nr.: 10
                                    // Genutzt wird der Datenpunkt des Panels in 0_userdata -->  PageNavi
                                    const timerPageArray: number = 10;
                                    
                                    /********************* Ab hier keine Änderungen mehr erforderlich *******************/
                                    let vInterval: any = null;
                                    let countInterval: number = 0;
                                    
                                    //let vTimeout: any = null; // Wird erst benötigt, wenn popupTimer auch aufgeschaltet werden kann 
                                                                // oder irgendwann eine cardTimer existiert!
                                    
                                    // Trigger löst aus wenn im Haus irgendein Timer über Alexa gesetzt wird 
                                    on({ id: [].concat(Array.prototype.slice.apply($('alexa2.0.Echo-Devices.*.Timer.activeTimerList'))), change: 'ne' }, async (obj) => {
                                    
                                        // Lösche falls rückwärtszählendes Interval läuft
                                        clearInterval(vInterval);
                                        
                                        // Erzeuge Array mit getriggertem Echo
                                        let deviceSerialNumber: any = obj.deviceId.split('.');
                                        // Zerlege Pfad und hole Seriennummer des getriggerten Echo
                                        let deviceSerialNr: string = deviceSerialNumber[3];
                                    
                                        if (Debug) {
                                            log('activeTimerList wurde durch Device ' + deviceSerialNr + ' geändert', 'info');
                                        }
                                    
                                        let timerObj = JSON.parse(getState('alexa2.0.Echo-Devices.' + deviceSerialNr + '.Timer.activeTimerList').val);
                                        
                                        // ermitteln der Anzahl aktiver Timer
                                        let activeTimerListLength = timerObj.length;
                                        
                                        let timerList: any = [];
                                        //Liest alle Echo-Timer in Array timerList ein
                                        for (let i = 0; i < timerObj.length; i++) {
                                            timerList[i] = getAttr(timerObj, i + '.triggerTime');
                                        }
                                    
                                        // Sortiere alle Timer der Größe nach (klein zuerst)
                                        timerList = timerList.sort(function(a: any,b: any) {
                                            return a - b;
                                        });
                                    
                                        // Wenn mindestens 1 Timer aktiv ist
                                        if (activeTimerListLength > 0) {
                                    
                                            if (Debug) {
                                                log(getState('alexa2.0.Echo-Devices.' + deviceSerialNr + '.Timer.activeTimerList').val, 'info');
                                            }
                                    
                                            // Startzeit für Timer ist "Jetzt"
                                            let timerStartTime: any = (new Date().getTime());
                                            let start: string = (formatDate(getDateObject(timerStartTime), "YYYY-MM-DD hh:mm:ss"));
                                            // Nur der kleinste sortierte Timer muss auf dem NSPanel angezeigt werden. 
                                            // Alle gestellten Timer werden der Reihe nach abgearbeitet.
                                            let timerEndTime: any = timerList[0];        
                                            let end: string = (formatDate(getDateObject(timerEndTime), "YYYY-MM-DD hh:mm:ss"));
                                    
                                            if (Debug) {
                                                log(String(calculateTimeDifferenceInSeconds(start, end)), 'info');
                                            }
                                    
                                            // Ermittel verbleibende Sekunden
                                            let countRemainingSeconds = calculateTimeDifferenceInSeconds(start, end);
                                            // Setze Countdown-Datenpunkt auf aktiv
                                            await setStateAsync(dpZustand, <iobJS.State>{ val: 'active', ack: true });
                                            
                                            // Schalte Timer cardGrid/cardEntities auf
                                            await setStateAsync(NSPanel_Path + 'PageNavi', 
                                                                <iobJS.State>{ val: '{ "pagetype": "page","pageId": ' + timerPageArray + ' }', ack: true });
                                    
                                            // Es darf nur ein Interval zur gleichen Zeit existieren
                                            if (countInterval <= 1) {
                                    
                                                log(activeTimerListLength + ' Timer aktiv', 'info')
                                    
                                                countInterval = 1;
                                                vInterval = setInterval(async function(){
                                                    // Dekrmentiere um 1 Sekunde
                                                    countRemainingSeconds -= 1;
                                    
                                                    // Wenn Timer auf 0 angekommen
                                                    if(countRemainingSeconds === 0){
                                                        clearInterval(vInterval);
                                                        await setStateAsync(dpZustand, <iobJS.State>{ val: 'pause', ack: true });
                                                    }
                                    
                                                    if (Debug) {
                                                        log(String(countRemainingSeconds), 'info');
                                                    }
                                    
                                                    setState(dpSekunden, countRemainingSeconds);
                                    
                                                }, 1000);
                                            }
                                        } else {
                                            log('Kein Alexa Countdown Timer aktiv', 'info');
                                            // Lösche falls noch ein rückwärtszählendes Interval läuft
                                            clearInterval(vInterval);
                                            vInterval = null;
                                            countInterval = 0;
                                            await setStateAsync(dpSekunden, <iobJS.State>{ val: 0, ack: true });
                                            await setStateAsync(dpZustand, <iobJS.State>{ val: 'idle', ack: true });
                                        }
                                    });
                                    
                                    // Trigger löst aus, wenn ein Countdown im NSPanel gesetzt wird und soll Alexa Timer stellen
                                    // Löst aber auch aus, wenn Alexa-Timer DP verändert. Daher Einschränkung auf einen einzigen Countdown-Timer
                                    on({ id: [].concat([dpSekunden]), change: 'ne' }, async (obj) => {
                                        // Nur wenn kein Countdown aktiv ist und noch kein Countdown-Timer läuft
                                        if (getState(dpZustand).val === 'idle' && vInterval === null) {
                                            
                                            if (Debug) {
                                                log('NSPanel hat Countdown von: ' + obj.state.val + ' Sekunden bekommen', 'info');
                                            }
                                            
                                            setState('alexa2.0.Echo-Devices.' + primaryEchoDeviceSerial + '.Commands.textCommand', 
                                                     'Stelle Timer auf' + obj.state.val + ' Sekunden');
                                    
                                        }
                                    });
                                    
                                    // Funktion zur Ermittlung der Sekunden aus zwei Zeitstempeln
                                    function calculateTimeDifferenceInSeconds(start: string, end: string) : number {
                                    
                                        const startTime: any = new Date(start);
                                        const endTime: any = new Date(end);
                                        const diffInMilliseconds = endTime - startTime;
                                        const diffInSeconds = Math.floor(diffInMilliseconds / 1000);
                                        
                                        return diffInSeconds;
                                    
                                    }
                                    

                                    Da es ja TypeScript ist, habe ich es so gut es geht versucht zu kommentieren...

                                    Viel Spaß bei der Benutzung oder bei der Anpassung...

                                    VG
                                    Armilar 😊

                                    theknutT Offline
                                    theknutT Offline
                                    theknut
                                    wrote on last edited by
                                    #4502

                                    Ist es möglich dynamisch ein Popup mit Text hochkommen zu lassen? Die Idee ist bspw. das Display einzuschalten "Trockner fertig" als Popup anzuzeigen. Dann kann man auf "OK" klicken, Popup schließt sich und das Display geht wieder aus. Wenn nein, dann könnte ich mich da mal dran setzen zu implementieren.

                                    ☕ @ https://ko-fi.com/theknut

                                    ArmilarA 1 Reply Last reply
                                    0
                                    • theknutT theknut

                                      Ist es möglich dynamisch ein Popup mit Text hochkommen zu lassen? Die Idee ist bspw. das Display einzuschalten "Trockner fertig" als Popup anzuzeigen. Dann kann man auf "OK" klicken, Popup schließt sich und das Display geht wieder aus. Wenn nein, dann könnte ich mich da mal dran setzen zu implementieren.

                                      ArmilarA Offline
                                      ArmilarA Offline
                                      Armilar
                                      Most Active Forum Testing
                                      wrote on last edited by
                                      #4503

                                      @theknut

                                      Es gibt sogar zwei

                                      popupNotify
                                      https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#popupnotify

                                      Screensaver-Notification
                                      https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker---FAQ-&-Anleitungen#3-info-screensaver-info-auf-request

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

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

                                      theknutT 1 Reply Last reply
                                      1
                                      • ArmilarA Armilar

                                        @theknut

                                        Es gibt sogar zwei

                                        popupNotify
                                        https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#popupnotify

                                        Screensaver-Notification
                                        https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker---FAQ-&-Anleitungen#3-info-screensaver-info-auf-request

                                        theknutT Offline
                                        theknutT Offline
                                        theknut
                                        wrote on last edited by
                                        #4504

                                        @armilar yeah, vielen Dank! Hab mittlerweile auch den Emulator am Laufen, teste ich dann mal.

                                        ☕ @ https://ko-fi.com/theknut

                                        ArmilarA T 3 Replies Last reply
                                        1
                                        • theknutT theknut

                                          @armilar yeah, vielen Dank! Hab mittlerweile auch den Emulator am Laufen, teste ich dann mal.

                                          ArmilarA Offline
                                          ArmilarA Offline
                                          Armilar
                                          Most Active Forum Testing
                                          wrote on last edited by
                                          #4505

                                          @theknut

                                          Zum Entwickeln ist der wirklich besser 😊

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

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

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          601

                                          Online

                                          32.4k

                                          Users

                                          81.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe