Navigation

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

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    SONOFF NSPanel mit Lovelace UI

    This topic has been deleted. Only users with topic management privileges can see it.
    • Armilar
      Armilar Most Active Forum Testing last edited by

      @marc_d0810

      Perfekt, dann direkt nochmal die:

      FlashNextion http://nspanel.pky.eu/lovelace-ui/github/nspanel-v3.9.4.tft
      

      hinterher und weiterhin viel Spaß mit dem Panel

      Gargano M 2 Replies Last reply Reply Quote 0
      • Armilar
        Armilar Most Active Forum Testing last edited by Armilar

        @mayan

        Je Fenster diese Datenpunkte anlegen:
        91b8a7a1-18ac-4b2f-be19-b5772d12568f-image.png

        Alias Warnung drauflegen
        69f5a45a-34ae-4306-8b09-744a07cdec62-image.png

        Unten in der Script function CreateEntity den case warning ersetzen:

                        case 'warning':
                            type = 'text';
                            iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('alert-outline');
                            iconColor = getState(([pageItem.id, '.LEVEL'].join(''))).val;
                            let itemName = getState(([pageItem.id, '.TITLE'].join(''))).val;
                            let itemInfo = getState(([pageItem.id, '.INFO'].join(''))).val;
                            
                            RegisterEntityWatcher(pageItem.id + '.LEVEL');
                            RegisterEntityWatcher(pageItem.id + '.INFO');
        
                            if (pageItem.useValue) {
                                iconId = itemInfo; 
                            }
        
                            return '~' + type + '~' + itemName + '~' + iconId + '~' + iconColor + '~' + itemName + '~' + itemInfo;
        

        Blockly bauen
        52ef362e-e543-4559-87ed-97f76b85944d-image.png

        <xml xmlns="https://developers.google.com/blockly/xml">
          <block type="on_ext" id="7F/xh~*?3`mc^1*K,W7{" x="112" y="63">
            <mutation xmlns="http://www.w3.org/1999/xhtml" items="1"></mutation>
            <field name="CONDITION">ne</field>
            <field name="ACK_CONDITION"></field>
            <value name="OID0">
              <shadow type="field_oid" id="qpr+xv*z`B2XPr(r@Gr}">
                <field name="oid">0_userdata.0.Test.HomaticKippfenster</field>
              </shadow>
            </value>
            <statement name="STATEMENT">
              <block type="logic_switch_case" id=".@y|@PV*p3IFgM(JcFnf">
                <mutation xmlns="http://www.w3.org/1999/xhtml" case="2"></mutation>
                <value name="CONDITION">
                  <block type="on_source" id="j]X7v|i_Dd2T7C@Vl;Go">
                    <field name="ATTR">state.val</field>
                  </block>
                </value>
                <value name="CASECONDITION0">
                  <block type="text" id="DLCub!@WhKO9ZK!C?l%q">
                    <field name="TEXT">auf</field>
                  </block>
                </value>
                <statement name="CASE0">
                  <block type="control" id="%.r}9HvU-ns1ysooh,KG">
                    <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                    <field name="OID">0_userdata.0.Test.HmIPKippfenseter.date</field>
                    <field name="WITH_DELAY">FALSE</field>
                    <value name="VALUE">
                      <block type="on_source" id="*f[t)GdTGZh]r?=v/7z,">
                        <field name="ATTR">state.val</field>
                      </block>
                    </value>
                    <next>
                      <block type="control" id="wcW.:NEyyLA_MIt,y!2.">
                        <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                        <field name="OID">0_userdata.0.Test.HmIPKippfenseter.color</field>
                        <field name="WITH_DELAY">FALSE</field>
                        <value name="VALUE">
                          <block type="text" id="p9,$Lry4}4q3r?!}mh3i">
                            <field name="TEXT">64332</field>
                          </block>
                        </value>
                      </block>
                    </next>
                  </block>
                </statement>
                <value name="CASECONDITION1">
                  <block type="text" id="](l=z*]A}oS5Arn6-~bl">
                    <field name="TEXT">zu</field>
                  </block>
                </value>
                <statement name="CASE1">
                  <block type="control" id="IRy`*m,Bt0X;A^GCbPhr">
                    <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                    <field name="OID">0_userdata.0.Test.HmIPKippfenseter.date</field>
                    <field name="WITH_DELAY">FALSE</field>
                    <value name="VALUE">
                      <block type="on_source" id="cj7vYeATckU.,KCgbs2z">
                        <field name="ATTR">state.val</field>
                      </block>
                    </value>
                    <next>
                      <block type="control" id="+)+$kxE/1:$u8E{YFuO4">
                        <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                        <field name="OID">0_userdata.0.Test.HmIPKippfenseter.color</field>
                        <field name="WITH_DELAY">FALSE</field>
                        <value name="VALUE">
                          <block type="text" id="RWA7gTWf$LB}(hLem3^X">
                            <field name="TEXT">32495</field>
                          </block>
                        </value>
                      </block>
                    </next>
                  </block>
                </statement>
                <value name="CASECONDITION2">
                  <block type="text" id="qyz0%`sl|n[V*0L:CH`(">
                    <field name="TEXT">kipp</field>
                  </block>
                </value>
                <statement name="CASE2">
                  <block type="control" id="PN7;/9kx_}Vkg.EX(n[Y">
                    <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                    <field name="OID">0_userdata.0.Test.HmIPKippfenseter.date</field>
                    <field name="WITH_DELAY">FALSE</field>
                    <value name="VALUE">
                      <block type="on_source" id="lb5.5S%em0XwKGC{}`g^">
                        <field name="ATTR">state.val</field>
                      </block>
                    </value>
                    <next>
                      <block type="control" id="32quUw$wGhWuHBQMA6ws">
                        <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                        <field name="OID">0_userdata.0.Test.HmIPKippfenseter.color</field>
                        <field name="WITH_DELAY">FALSE</field>
                        <value name="VALUE">
                          <block type="text" id="a=x=.IBp$jo9B-}Bvone">
                            <field name="TEXT">65363</field>
                          </block>
                        </value>
                      </block>
                    </next>
                  </block>
                </statement>
              </block>
            </statement>
          </block>
        </xml>
        

        Dann sollte das Kippfenster mit

        <PageItem>{ id: 'alias.0.NSPanel_1.Kippfenster', useValue: true },
        

        arbeiten

        6616b9ac-1a11-4d4e-ac4d-474f1501b429-Nextion_Editor_yTEII0gClF.gif

        1 Reply Last reply Reply Quote 0
        • M
          Mayan last edited by

          @Armilar

          Es funktioniert mit meinen Fenstern!
          Allerdings musste ich noch ,name: ’’, einfügen sonst werden die Fenster nicht angezeigt.
          6AFBEAB7-5B75-44F5-84E0-8CA06D560327.jpeg

          <PageItem>{ id: "alias.0.Allgemein.Fenster.Schlafz",name:'', useValue: true},
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Wohnz", name:'', useValue: true},
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Kinderz", name: '', useValue: true },
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Essz", name: '', useValue: true },
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Badez", useValue: true },
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Abstellr", useValue: true }
          

          DA02D50D-B4BA-4ACB-BA38-97057EB8880C.jpeg

          <PageItem>{ id: "alias.0.Allgemein.Fenster.Schlafz",name:'', useValue: true},
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Wohnz", name:'', useValue: true},
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Kinderz", name: '', useValue: true },
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Essz", name: '', useValue: true },
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Badez", name: '', useValue: true },
                  <PageItem>{ id: "alias.0.Allgemein.Fenster.Abstellr",name: '', useValue: true }
          

          Ich hatte dieses Verhalten auch vor der Änderung.
          (Da hatte ich nur Icons und Text)
          Im Script function CreateEntity den case warning ersetzen

          case 'warning':
                              type = 'text';
                              iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('alert-outline');
                              iconColor = getState(([pageItem.id, '.LEVEL'].join(''))).val;
                              let itemName = getState(([pageItem.id, '.TITLE'].join(''))).val;
                              let itemInfo = getState(([pageItem.id, '.INFO'].join(''))).val;
                              
                              RegisterEntityWatcher(pageItem.id + '.LEVEL');
                              RegisterEntityWatcher(pageItem.id + '.INFO');
          
                              if (pageItem.useValue) {
                                  iconId = itemInfo; 
                              }
          
                              return '~' + type + '~' + itemName + '~' + iconId + '~' + iconColor + '~' + itemName + '~' + itemInfo;
          

          Ich nutze noch die Version 3.9.0.2

          Ich wusste nicht das der Abfallkalender vom Gerätetyp Warnings sein sollte.
          Habe es mit einem ganz normalen Info laufen.
          94F43844-7F63-45CC-B08D-E0DEA4AAA628.jpeg

          <PageItem>{ id: "alias.0.Allgemein.Restmüll",name: "Restmüll",icon: "trash-can", onColor: Black, offColor: Black},
                  <PageItem>{ id: "alias.0.Allgemein.Leichtverpackungen",name: "Leichtverpackungen",icon: "trash-can", onColor: Yellow, offColor: Yellow},
                  <PageItem>{ id: "alias.0.Allgemein.Papier",name: "Papier", icon: "trash-can", onColor: Blue, offColor: Blue}
          

          Danke für die schnelle Hilfe!

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

            @mayan sagte in SONOFF NSPanel mit Lovelace UI:

            Ich wusste nicht das der Abfallkalender vom Gerätetyp Warnings sein sollte.
            Habe es mit einem ganz normalen Info laufen.

            Wenn du den, so wie bei dir statisch nach dem nächsten Termin je Farbe anordnest, dann reicht auch der Info - also alles korrekt

            Wenn du aber die Icon-Farben dynamisch ändern möchtest und die nächsten anstehenden Termine, ungeachtet aller verfügbaren Tonnenfarben, dann musst du den Warnung benutzen.

            Ich nutze noch die Version 3.9.0.2

            Ist ja bis auf zwei kleine Hotfixes auch die aktuellste...

            1 Reply Last reply Reply Quote 0
            • O
              Oliver Feld last edited by

              Bei mir im Abfallkalender steht neben der Tonne das Datum. Wie stelle ich es ein, dass dort anstatt Datum „Morgen“ bzw. „Übermorgen“ steht?

              Danke und Gruß Olli

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

                @oliver-feld

                Das kommt vom iCal Adapter. Das Script aus dem Wiki schreibt das Datum nicht um.

                1 Reply Last reply Reply Quote 0
                • M
                  Mayan last edited by

                  @Oliver-Feld

                  Das „Morgen“ usw. im Abfallkalender erstelle ich von Daten aus dem Adapter trashschedule, der wiederum die Daten aus dem iCal Adapter bezieht. Bei mir wird größer einer Woche das Datum, ab einer Woche in Tagen und zum Schluss Morgen und Heute angezeigt.
                  CA3FE131-2FB3-40BE-87E2-9F27F70A4473.jpeg

                  1 Reply Last reply Reply Quote 0
                  • P
                    PaNoRu84 @TT-Tom last edited by

                    @tt-tom @Armilar,

                    vielen Dank für eure Hilfe.

                    Ich schulde euch noch ein Foto. Hier kommt es.
                    Ich habe die Idee mit den "Zählen" direkt übernommen.
                    Ist noch nicht final aber funktioniert schon super. Der "Name" ist jetzt ein dynamisches Feld, vielleicht lasse ich da ab einer gewissen Anzahl von offenen Fenstern auch nur die Anzahl anzeigen.
                    Aber super, dass das schonmal so geht. DANKE (hach, jetzt muss ich doch wirklich noch 5-10 weitere NSPanels kaufen 😄 )

                    f157e04b-f813-4542-a274-362d75c1b944-image.png

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

                      @armilar
                      Was ist denn der Unterschied FlashNextionAdv1 zu FlashNextion ?

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

                        @gargano sagte in SONOFF NSPanel mit Lovelace UI:

                        Was ist denn der Unterschied FlashNextionAdv1 zu FlashNextion ?

                        In der Regel benötigst du das nicht

                        FlashNextionAdv[0-5] URL
                        Start's flashing a tft file to the nextion screen with different Modi.

                        • Nextion Upload Proto 1.2 with 921600 Baud (same as FlashNextion): FlashNextionAdv0 http://nspanel.pky.eu/lui.tft
                        • Nextion Upload Proto 1.1 with 921600 Baud: FlashNextionAdv1 http://nspanel.pky.eu/lui.tft
                        • Nextion Upload Proto 1.2 with 115200 Baud: FlashNextionAdv2 http://nspanel.pky.eu/lui.tft
                        • Nextion Upload Proto 1.1 with 115200 Baud: FlashNextionAdv3 http://nspanel.pky.eu/lui.tft
                        • Nextion Upload Proto 1.2 with 256000 Baud: FlashNextionAdv4 http://nspanel.pky.eu/lui.tft
                        • Nextion Upload Proto 1.1 with 256000 Baud: FlashNextionAdv5 http://nspanel.pky.eu/lui.tft
                        • Nextion Upload Proto 1.1 with 921600 Baud and communication init on 9600 Baud: FlashNextionAdv6 http://nspanel.pky.eu/lui.tft

                        Besides the commands, serial input will be published on 'RESULT' Topic, depending on the input in one of the following formats:

                        {"CustomRecv":%s}
                        {"nextion":%s}

                        Armilar 1 Reply Last reply Reply Quote 0
                        • T
                          TT-Tom @Oliver Feld last edited by

                          @oliver-feld

                          hier die Einstellungen im iCal damit "morgen" und so weiter kommt.

                          Bildschirmfoto 2023-02-27 um 13.36.09.png

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

                            Release v4.0.3

                            9b7597a5-3d3d-43d5-b0c7-a4d42d8eac7f-image.png

                            Änderungen in der Config:

                            aus

                            export const config: Config = {
                            

                            wird

                            export const config = <Config> {
                            

                            und die firstScreensaverEntity - fourthScreensaverentity existieren nicht mehr. Erstatz dafür ist das Array bottomScreensaverEntity. Die ersten 4 bottomScreensaverEntity werden auch im Standard-Screensaver genutzt.

                            Des weiteren ist der Erweiterte Screensaver enthalten:
                            837094a5-44e0-4c7c-9251-9e02dc80346c-image.png
                            Zur Konfiguration des Screensavers bitte die Wiki berücksichtigen:
                            https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Config-Screensaver#entity-status-icons-ab-v400

                            Für alle User mit kleinen Hackern zuhause gibt es jetzt die cardUnlock:
                            df037f8b-91cd-418e-aeac-6a54e4e16915-image.png
                            Siehe auch:
                            https://github.com/joBr99/nspanel-lovelace-ui/wiki/ioBroker-Card-Definitionen-(Seiten)#cardunlock-ab-v400

                            Ansonsen gab es diverse Erweiterungen und Minor-Bugfixes:

                            • Eine überarbeitete und erweiterte Squeezebox und diverse Optimierungen von @bembelstemmer
                            • Ein Mode - Fix für die cardThermo und dynamische Icons im Advanced Screensaver (Issue in letzer Sekunde 😉 ) von @Gargano

                            Kurze Upgrade-Empfehlung:

                            • Neues TypeScript anlegen und die Version https://raw.githubusercontent.com/joBr99/nspanel-lovelace-ui/main/ioBroker/NsPanelTs_without_Examples.ts hineinkopieren
                            • altes Script deaktivieren (Fallback)
                            • Konfiguration anhand der Variablen aus dem anderen Script übernehmen (Achtung Config hat einen veränderten Aufbau und kann nicht 1:1 übernommen werden, siehe oben!)
                            • Erweiterungen für Advanced Screensaver aus Wiki oder NSPanel.ts (Script mit Beispielen) migrieren
                            • FlashNextion http://nspanel.pky.eu/lovelace-ui/github/nspanel-v4.0.3.tft

                            Hinweis:

                            • @TT-Tom hat bereits festgestellt, dass es erforderlich sein kann, die vom TS-Script automatisch angelegten 0_userdata.0.NSPanel.X Verzeichnisse und Auto-Aliase zu löschen und neu anlegen zu lassen.

                            Viel Spaß mit dem neuen Release...

                            Gargano wendy2702 2 Replies Last reply Reply Quote 4
                            • P
                              PaNoRu84 last edited by PaNoRu84

                              gesucht: Startpunkt / Übersicht über mehrere Thermostate
                              Ich überlege wie ich als Einstiegpunkt mehrere Thermostate auf einer Seite darstellen kann.
                              Ich hätte gerne eine Darstellung auf der ich die aktuelle Soll-Temperatur von mehrere Thermostaten sehen kann und über Navigation diese dann vertiefen bzw. ändern kann.

                              Meine 1. Idee war einfach InfoPunkte mit den Soll-Werte als Alias anzulegen, davon könnte ich dann ja 6 erstellen.
                              Die Punkte könnten ja sogar als Icon den Wert wieder geben.
                              z.B. so

                              ______________________________
                              |    21      20         18    |
                              |  Büro    Küche       Bad    |
                              |                             |
                              |   20       18        21     |
                              | Kids   Schlafen    Wohnen   |
                              |_____________________________|
                              

                              Mit einem Klick auf die Werte wäre ich dann gerne auf die entsprechende CardThermo gekommen, aber das geht scheinbar nicht, bzw. dann funktioniert der Value nicht mehr.

                              Hat jemand alternative Idee wie ich eine derartige Übersicht mit der Möglichkeit auf die Details tiefer einzutauchen abbilden könnte?

                              Danke für eure Hilfe - ihr leistet hier wirklich einen super Job!!!

                              Armilar 2 Replies Last reply Reply Quote 0
                              • Gargano
                                Gargano @Armilar last edited by Gargano

                                @armilar sagte in SONOFF NSPanel mit Lovelace UI:

                                Release v4.0.3

                                Hab gesehen, Du hast einige Funktionen als async gemacht. Ich hatte vorher den Eindruck, daß manche SendToPanel Aufrufe verschluckt werden. Mal sehen , ob es jetzt besser ist.

                                Wobei lt. Beschreibung eine async Function ohne await das gleiche sein soll wie eine Function ohne async

                                Armilar 1 Reply Last reply Reply Quote 0
                                • W
                                  watcherkb last edited by

                                  Ist es möglich, zwei verschiedene Accuweather Pages zu konfigurieren (für 2 Orte)? Dafür müsste ich wahrscheilich eine zweite Accuweather Instanz erstellen, oder? Gibt es dazu ein Beispiel oder Vorlage?

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

                                    @gargano

                                    Es gab in der Tat ein Problem mit verschluckten Ereignissen (Liegt aber eher bei den Delays von Tasmota und Berry). Daher habe ich die unnötig erzeugten notify~~ auch eleminiert, die in der bExit erzeugt und an das Panel gesendet wurden. Zusätzliches await kann aber auch nicht schaden 😊

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

                                      @watcherkb

                                      Du könntest eine weitere Accuweather-Instanz hinzufügen, das würde sich aber nicht im Screensaver wiederspiegeln, da dort nur eine Instanz genutzt wird. Aber für eine Wetterpage als z.B. eine zusätzliche cardGrid kannst du dann natürlich auf die Datenpunkte der 2. Instanz zugreifen und diese verwenden.

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

                                        @panoru84

                                        Ich sehe mir das mal an. Eigentlich kann das nicht so schwer sein, im Navigationspfad noch ein useValue unterzubringen.

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

                                          @armilar die Bedienung fühlt sich auch etwas flüssiger an

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

                                            @panoru84

                                            Teste das mal

                                            Entsprechenden Code im oberen Teil der function CreateEntity suchen und ersetzen:

                                                                    case 'door':
                                                                    case 'window':
                                                                        if (existsState(pageItem.id + '.ACTUAL')) {
                                                                            if (getState(pageItem.id + '.ACTUAL').val) {
                                                                                iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : o.common.role == 'door' ? Icons.GetIcon('door-open') : Icons.GetIcon('window-open-variant');
                                                                                iconColor = GetIconColor(pageItem, false, useColors);
                                                                            } else {
                                                                                iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : o.common.role == 'door' ? Icons.GetIcon('door-closed') : Icons.GetIcon('window-closed-variant');
                                                                                iconColor = GetIconColor(pageItem, true, useColors);
                                                                            }
                                                                        }
                                                                        break;
                                                                    case 'info':
                                                                        iconId = pageItem.icon !== undefined ? Icons.GetIcon(pageItem.icon) : Icons.GetIcon('gesture-tap-button');
                                                                        iconId2 = pageItem.icon2 !== undefined ? Icons.GetIcon(pageItem.icon2) : Icons.GetIcon('gesture-tap-button');
                                                                        iconColor = GetIconColor(pageItem, true, useColors);
                                                                        if (val === true || val === 'true') {
                                                                            iconColor = GetIconColor(pageItem, true, useColors);
                                                                        } else {
                                                                            iconColor = GetIconColor(pageItem, false, useColors);
                                                                            if (pageItem.icon !== undefined) {
                                                                                if (pageItem.icon2 !== undefined) {
                                                                                    iconId = iconId2;
                                                                                }
                                                                            }
                                                                        };
                                            
                                                                        if (pageItem.useValue) {
                                                                            iconId = val;
                                                                        } 
                                            
                                                                        break;
                                                                    default:
                                                                        return '~delete~~~~~';
                                                                }
                                                                return '~' + type + '~' + 'navigate.' + pageItem.targetPage + '~' + iconId + '~' + iconColor + '~' + name + '~' + buttonText
                                            

                                            Aufruf mit (Punkte entsprechend füllen) :

                                            <PageItem>{ navigate: true, id: '...', targetPage: '...', name: '...', offColor: ..., onColor: ..., useValue: true},
                                            

                                            und targetPage als Subpage definieren

                                            P Gargano 2 Replies Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            892
                                            Online

                                            31.6k
                                            Users

                                            79.6k
                                            Topics

                                            1.3m
                                            Posts

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