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.7k

  • 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

    @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.

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

    @armilar Wunderbar, funktioniert jetzt, danke!

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

    ArmilarA 1 Reply Last reply
    1
    • theknutT theknut

      @armilar Wunderbar, funktioniert jetzt, danke!

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

      @theknut

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

      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

        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
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          234

                                          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