NEWS
[Gelöst] Benötige Hilfe mit Node-Red in Verbindung mit homee
-
Hallo zusammen,
ich bin absoluter Neuling im Thema Node-Red. Habe zwar schon vieles gelesen und Videos dazu angesehen, aber den Durchblick habe ich dadurch nicht erlangt.Momentan geht es im Großteil erstmal darum meinen homee in der Vis zu visualisieren.
Folgendes möchte ich realisieren, ohne zu wissen, ob das alles mit der homee-api möglich ist:
- Meinen homee mit Node-Red verbinden
- Auslesen der Logdatei und diese in einer Tabelle abbilden
- Auslesen der Heizpläne, diese in der Vis darstellen und eventuell auch über die Vis zu ändern
- Nicht erreichbare Geräte auslesen und in deiner Tabelle abbilden
- Auslesen der aktuellen Geodaten bei Abwesenheit und diese auf einer Map darstellen
- Erstellen einer Geräteliste und diese in einer Tabelle abbilden
Wäre schön, wenn mich hierbei jemand unterstützen könnte und mich in die Welt von Node-Red einführt.
Wünsche allen noch ein gesundes und erfolgreiches Jahr 2023.
EDIT am 24.03.2023:
Ich hab es es mit der unermüdlichen Unterstützung von @mickym geschafft einen Großteil meiner Liste zu realisieren. Bevor ich mit der Zusammenfassung anfange, möchte ich mich nochmals herzlich bei @mickym bedanken, ohne dessen Hilfe hätte ich das ganze nicht umsetzten können.
Hier ein paar Bilder meiner VIS vom homee:
zu 1. Meinen homee mit Node-Red verbinden, dass war noch relativ einfach
Dazu im Node Red -> oben rechts Burger Menü - Palette verwalten (Palette) - Installieren:
node-red-contrib-homee -> Installieren.
Man muss aber nur den echten homee-Namen (oder IP) eingeben, sowie einen bestehenden Nutzer und Passwort (kein kleiner homee). Jetzt kann man mit
Node-Red auf die Geräte von homee zugreifen.zu 2. Auslesen der Logdatei und diese in einer Tabelle abbilden - wurde umgesetzt anbei der Flow und eine kurze Erklärung
Es werden nur die letzten 50 Einträge aus den Log geholt, die Anzahl kann man im Flow anpassen. Es dauert bei mir 2 -3 Sekunden bis der Log geholt wird.
homee Logfile.jsonzu 3. Auslesen der Heizpläne, diese in der Vis darstellen und eventuell auch über die Vis zu ändern - wurde umgesetzt anbei der Flow und eine kurze Erklärung
Ich benutze für die Visualisierung der Heizpläne den heatingcontrol Adapter, die Steuerung läuft über homee. Der Flow erstellt eine Tabelle und schreibt die
Regelungszeiten und Temperaturen in die dafür vorgesehenen Datenpunkte des heatingcontrol Adapters, dazu habe ich die Anzahl der Regelungszeiten an die
benötigte Anzahl des Adapters angepasst.
homee Pläne.jsonzu 4. Nicht erreichbare Geräte auslesen und in deiner Tabelle abbilden und
zu 6. Erstellen einer Geräteliste und diese in einer Tabelle abbilden - Diese beiden Punkte wurden zusammengepackt und umgesetzt anbei der Flow
Es wird eine Tabelle erstellt und zusätzlich eine Pushnachricht generiert, falls eine Gerät nicht erreichbar ist und über die homeeApp ausgegeben
Den Flow mit der Pushnachricht hatte ich im homee Forum gefunden und @mickym hat in an meine Bedürfnisse angepasst. Um in der Tabelle zwischen
batteriebetriebene und strombetriebene Geräte zu unterscheiden, habe ich mir in der homeeApp unter "Notiz" bei jedem Stromer einen Kommentar mit "Plug"
gesetzt. Zusätzlich habe ich mir bei allen Geräten unter "Notiz" noch die Typenbezeichnung der Geräte hinzugefügt.
homee Geräteliste.jsonzu 5. Auslesen der aktuellen Geodaten bei Abwesenheit und diese auf einer Map darstellen - nicht umgesetzt, da Geodaten nur in der App vorhanden, nicht in der Api
Zusätzlich kamen noch 2 Punkte auf die Liste:
7. Auslesen der Settings und gewisse Daten in Datenpunkte schreiben - wurde umgesetzt, anbei der Flow
homee Settings.json8. homeegramme auslesen und in eine Tabelle schreiben - wurde umgesetzt, anbei der Flow
homeegramme.jsonHier ist noch ein Flow, damit ihr seht wie ich die Api eingebunden habe
homee.jsonZum Schluss, hier noch meine VIS, hierfür benötigt ihr den "Material Design Widgets Adapter"
System_homee_Statistik.txt
System_homee_Pläne_Liste.txt
System_homee_Logdatei_Steuerung.txt
System_homee_Logdatei_Liste.txt
System_homee_Logdatei.txt
System_homee_homeegrammliste.txt
System_homee_Geräteliste.txt
System_homee.txtWenn ihr Fragen, oder Verbesserungen habt, gerne hier schreiben
-
@oli Musst Du den homee mit Node-Red verbinden oder hast verwendest Du bereits den Adapter im iobroker? Beides acht keinen Sinn.
Wenn Du anstelle des iobroker Adapters homee direkt in Node-Red anbinden willst geht das https://flows.nodered.org/node/node-red-contrib-homee nur beides macht keinen Sinn. Ich empfehle halt immer wenn Du den iobroker verwendest, dann greife auf die HW über den iobroker zu, falls das nicht gut funktioniert oder der Adapter Bugs hat, dann nehme ich direkt die Nodes.
Sind ja einige Projekte, die Du realisieren willst. Vis ist ja eine Visualisierung im iobroker - was hast Du denn im iobroker schon gemacht?
-
danke für deine Antwort
Momentan verwende ich tatsächlich beides, um herauszufinden, was meinen Bedürfnissen mehr entspricht. Was ich bis jetzt herausgefunden habe ist, dass über Node Red mehr Attribute ausgegeben werden als über den Adapter (zB nicht erreichbare Geräte).Ich benutze ioBroker hauptsächlich zur Visualisierung meines Smart Home und steuere dieses zu 95% über homee. Für meine Visualisierung habe ich bereits einiges über Javaskript gelöst, hier mal ein Beispiel meiner jetzigen von homee:
-
@oli Nun mit NodeRed - die Nodes basieren ja ebenfalls aus JS hast Du nicht nur den Vorteil. dass Du quasi den funktionalen Ablauf besser verfolgen und vorstellen kannst, sondern jede Node ist ja quasi eine kleine Funktion, die Dir eine Menge Codierarbeit erspart. Falls es doch notwendig wird kannst Du jederzeit Javascript in function Nodes schreiben.
Grundsätzlich ist die Visualisierung sekundär für NodeRed. Es ist eine Logikmaschine und konkurriert im iobroker Umfeld mit Blockly oder reinem JS. Du hast aber eben noch die Nodes, die Adapter ersetzen können und wie gesagt für den Ablauf ist dieses Tool in meinen Augen den anderen beiden um Welten voraus.
Ein wichtiger Bestandteil von NodeRed zusammen mit dem iobroker ist aber die Zustandsverwaltung. Wenn Du NodeRed alleine betreibst, benötigst Du in der Regel einen mqtt-Broker zur Speicherung der Zustände. Mit dem iobroker hast Du aber eine tolle Datenbank der Zustände, die grafisch Dir jederzeit einen Überblick gibt.
Mit NodeRed kannst Du nun die Zustände auch im iobroker speichern und das ist ein unschlagbares Gespann.
Bei den Tabellen kannst Du mit NodeRed durch die wesentliche bessere Objektunterstützung auch easy mit den JSON Tabellen zu arbeiten.
Wenn Du also richtig strukturiert vorgehst:
- Eingangsdaten sammeln
- Daten verarbeiten
- Ausgeben - etwas steuern oder visualisieren und ggf. speichern
kannst Du all Deine Wünsche umsetzen. Helfen kann ich Dir allerdings nur, wenn Du dann konkret wirst und wir eng getaktet und zeitnah posten um ein Projekt umzusetzen.
-
@mickym
habe jetzt endlich mal die Zeit gefunden, mich wieder etwas intensiver mit dem Thema zu beschäftigen und schon kommen die ersten Fragen.Auf youtube einen Flow aus dem homee Forum gefunden und versucht ihn auf meine Bedürfnisse anzupassen
Ich möchte den Flow zusätzlich mit einem Button aus der Vis auslösen, dass funktioniert aber leider so nicht, wie ich es mir vorgestellt habe, wo muss ich den Startbutton anschließen, damit der Flow ausgeführt wird?
Zudem möchte ich aus der Funktions-Node die Variable "zaeleraus" in deinen zusätzlichen Datenpunkt in ioBroker schreiben, muss ich mir da eine zusätzliche Funktion anlegen, oder wie stelle ich das am besten an?
-
@oli Also ehrlich gesagt - werde ich Dir auf diese Art nicht viel helfen können. Insbesondere wenn man fremde Flows übernimmt und sich da erst rein denken muss, ist es oft besser man schreibt die selbst.
Triggern als via Button im Vis tust Du wenn Du den Datenpunkt beschreibst - also zum Beispiel Deinen Start-datenpunkt:
Das Problem ist aber da VIS nur unbestätigte Werte schickt, dass Du diese heraus filterst, also entweder auf all events oder auf ack = false stellen.
Dann halte ich es gerade am Anfang wenn Du mit NodeRed beginnen willst - es für einen furchtbaren Fehler mit function NOdes zu codieren. NodeRed ist ein grafisches Tool, womit man sowas weitgehenst vermeiden will und das ist Spaghetti-Code.
Diese ganze Funktion kann zumindest isoliert so nicht funktionieren. Es fehlt der Kontext (globaler Kontext) und die verlinkten Flows. (s. 1. Zeile).
Dann werden sogenannte Template Literals in seinem JavaScript Code verwendet - alles gut und schön, ist aber für Laien schlecht zu lesen (https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals)
Diese ganze function Node ist für mich so nicht nachvollziehbar und deshalb kann ich da nicht helfen.
Ich würde an Deiner Stelle lieber selber was entwickeln, als solche Flows aus dem Netz zu nehmen.
Zudem möchte ich aus der Funktions-Node die Variable "zaeleraus" in deinen zusätzlichen Datenpunkt in ioBroker schreiben, muss ich mir da eine zusätzliche Funktion anlegen, oder wie stelle ich das am besten an?
Ich habs mal versucht zu simulieren - ich finde es ehrlich gesagt ...
Ich hab mal die Ausgabe simuliert:
Die Zählerausvariable wird in dem Objekt "Nicht Verfügbar" und dort in Anzahl ausgegeben. Alleine Leerzeichen in Eigenschaftsnamen ist einfach schlechter Stil:
Du kannst hinter die function Node noch folgende Change Node dahinter hängen;
Das extrahiert Dir dann die zähleraus Variable wieder aus dem Objekt und Du kannst es wegschreiben.
Also wie gesagt - wenn es bei Dir tut ist es ja fein - wenn dann musst du ggf. halt die Daten mitliefern.
-
@mickym
erstmal danke für deine Antwort, sorry wahrscheinlich ein typischer Anfängerfehler (kopieren, versuchen zu verstehen und versuchen dieses anzupassen).Die homeeApi spuckt leider nur zahlen und kryptische Wörter aus, hier mal ein Beispiel eines Heizungsthermostats:
Der ursprüngliche Flow liest den Punkt "state" aus, 1 = Verfügbar, 2 = nicht Verfügbar, 12 = wird Aktualisiert, erstellt einen Text und löst eine Pushnachricht in der homee App mit diesem Text aus. Dieses funktioniert auch. Das schreiben in einen Datenpunkt von ioBroker und den Startbutton habe ich zusätzlich noch hinzugefügt.
Ich fange auch gerne nochmal bei null an, wie würdest du das denn umsetzen?
-
@oli Wenn Du Daten hier rein kopieren möchtest das man die verwenden kann, dann bitte nicht über kopieren des Textes aus dem Debugfenster sondern in dem Du den Wert direkt aus dem Debugfenster direkt kopierst und hier in Code-Tags einfügst.
Also immer rechts neben den Wert und dann über Wert kopieren hier in CodeTags einfügen.
-
@oli sagte in Benötige Hilfe mit Node-Red in Verbindung mit homee:
Ich fange auch gerne nochmal bei null an, wie würdest du das denn umsetzen?
Nun da würde ich generell immer mit den Daten anfangen und dann was Du alles erreichen möchtest.
-
Vom Prinzip möchte ich das umsetzten, was der der Flow bis jetzt zum großen Teil auch schon macht:
- Alles Geräte nach ihrem Status abfragen
- Die Anzahl der Geräte nach dem jeweilen Status zählen
- Einen Text mit Namen, Status und Anzahl verfassen
- Eine Pushnachricht in der homee App mit dem Text auslösen
- Den Text in einen Datenpunkt schreiben.
- Die Anzahl der nicht Verfügbaren Geräte in einen Datenpunkt schreiben
- Die ganze Aktion zusätzlich mit einem Button starten
-
Nun wie gesagt . wenn du zufrieden bist - ist ja OK.
Ich habe mal deine Daten genommen:
Ist das nun ein Gerät - und was sind die 15 Attribute zu dem Gerät. Sorry kenn mich halt mit homee 0,0 aus.
-
ja, dass ist nur 1 Gerät von 46. In den Attributen stehen die einzelnen Werte drin, wie z.B. Temperatur und Batteriestand u.s.w
-
@oli OK . das heisst die Attribute interessieren nicht, sondern es ist nur der Status in der "node" Eigenschaft selbst relevant und nicht die Attribute?
Kannst Du mir dann auch das komplette Array - oder halt mehrere Geräte mit unterschiedlichem Status genauso zur Verfügung stellen. Wenn das ggf. zu groß ist, dann halt in eine Datei packen.
-
-
So hier mal wieder eine Version ohne function Node - mit Spaghetti-Code.
Ja ich musste auch erst lernen, wie man JSONATA liest - wir können das gerne genauer anschauen, aber Du musst Dich halt generell mit Objekte und Arrays auseinandersetzen.
Ich hab einfach die verschiedenen Filterfunktionen und Möglichkeiten von JSONATA genutzt. Im Prinzip dient dir diese ganzen Debug Nodes, damit du siehst, wie Du selektierst und auf verschiedenene Eigenschaften der Objekte zugreifst.
Im Prinzip habe ich alle Geräte nicht nur nach den Status (aktiv, inaktiv, updating) getrennt, sondern dies auch im Flow-Kontext gespeichert, so dass Du zeitlich unabhängig auf diese Informationen zugreifen kannst.
Hier eine Inject Node - aber das kann natürlich auch ein trigger Datenpunkt über VIS sein.
Ich hab jetzt mal bewusst nicht die Namen, sondern die phonetischen Namen gewählt - aber das dient ja alles nur der Demo.
Es wird unten nicht nur mit der template Node gezeigt, wie Du eine Textausgabe erzeugst, sondern ich hab mal HTML Code verwendet.
Diese seite wird im iobroker Home Verzeichnis gespeichert. So könnte dann ein Report aussehen:Somit schau ich mal - was ich von Deinem Pflichtenheft erledigt habe:
- Alles Geräte nach ihrem Status abfragen => erledigt
- Die Anzahl der Geräte nach dem jeweilen Status zählen => erledigt
- Einen Text mit Namen, Status und Anzahl verfassen => erledigt - ich habe HTML code erzeugt, aber reiner Text ist ja einfacher
- Eine Pushnachricht in der homee App mit dem Text auslösen => musst Du machen - bzw. halt das von dem bestehenden Flow übernehmen
- Den Text in einen Datenpunkt schreiben. => Nun da brauchst Du ja nur ein iobroker Out Node an die Ausgabe die Du wünschst dranhängen
- Die Anzahl der nicht Verfügbaren Geräte in einen Datenpunkt schreiben => erledigt nur noch iobroker-Out Node dranhängen
- Die ganze Aktion zusätzlich mit einem Button starten => erledigt, trigger mit VIS
Hier nun der Flow zum Import und Ausprobieren:
Die Inject Node mit den Daten der 46 Geräte ist in diesem Export nicht enthalten - also den Dateninput musst Du halt liefern.
Der Vorteil nicht alles in einer function Node zu verstecken ist halt auch, dass Du individuell Aktionen mit bestimmten Geräten ggf. anschließen kannst.
Und zum Schluss - Du hast so einen Flow dann selbst erarbeitet. Ich kann Dich nur ermuntern, das zu Probieren, anstelle im Netz nach fertigen Flows zu suchen. Es kann eine Anregung sein - man muss das Rad nicht neu erfinden. Der Mensch, der den Flow gemacht hat, ist zwar ein sehr fitter Javascript Programmierer (diese template Literals habe ich noch nie benutzt), aber er kapselt viel zu viel in der function Node und beschneidet deshalb die Möglichkeiten eines Flows.
-
wow, erstmal vielen Dank, dass muss ich mir heute nach dem aufstehen mal etwas genau anschauen, momentan erschlägt es mich erstmal.
Da werden bestimmt einige Fragen aufkommen, mit denen ich auf dich zukommen werde
-
@mickym
habe mir das ganze mal angesehen und versucht durch zu blicken, aber leider funktioniert es nicht.Der Obere Teil sieht wie folgt aus:
Bei den Debug-Nodes der einzelnen Geräte kommt immer folgendes:
Bei der Debug-Node 5 schreibt er folgendes:
{"attribute":{"id":358,"node_id":56,"instance":0,"minimum":0,"maximum":20,"current_value":0.412,"target_value":0.412,"last_value":0.438,"unit":"A","step_value":1,"editable":0,"type":193,"state":1,"last_changed":1678519354,"changed_by":1,"changed_by_id":0,"based_on":1,"data":"","name":"","options":{"history":{"day":1,"week":26,"month":6}}}}
Aber nach meinem Verständnis, sollte doch eigentlich die "node" abgefragt werden, nicht die "attribute"
{"node":{"id":29,"name":"EG%20%2F%20Wohnzimmer%20%2F%20Netatmo","profile":3014,"image":"default","favorite":0,"order":42,"protocol":9,"routing":0,"state":1,"state_changed":1678428037,"added":1607519624,"history":0,"cube_type":8,"note":"","services":5,"phonetic_name":"Klima%20Wohnzimmer","owner":1,"security":0,"attributes":[{"id":253,"node_id":29,"instance":0,"minimum":0,"maximum":50,"current_value":20.6,"target_value":20.6,"last_value":20.5,"unit":"%C2%B0C","step_value":0.5,"editable":0,"type":5,"state":1,"last_changed":1678519389,"changed_by":1,"changed_by_id":0,"based_on":4,"data":"","name":"","options":{"history":{"day":1,"week":26,"month":6}}},{"id":254,"node_id":29,"instance":0,"minimum":0,"maximum":100,"current_value":33,"target_value":33,"last_value":34,"unit":"%25","step_value":1,"editable":0,"type":7,"state":1,"last_changed":1678515784,"changed_by":1,"changed_by_id":0,"based_on":4,"data":"","name":"","options":{"history":{"day":1,"week":26,"month":6}}},{"id":255,"node_id":29,"instance":0,"minimum":0,"maximum":5000,"current_value":444,"target_value":444,"last_value":449,"unit":"ppm","step_value":50,"editable":0,"type":20,"state":1,"last_changed":1678519389,"changed_by":1,"changed_by_id":0,"based_on":4,"data":"","name":"","options":{"history":{"day":1,"week":26,"month":6}}},{"id":256,"node_id":29,"instance":0,"minimum":35,"maximum":120,"current_value":32,"target_value":32,"last_value":33,"unit":"dB","step_value":1,"editable":0,"type":93,"state":1,"last_changed":1678515183,"changed_by":1,"changed_by_id":0,"based_on":4,"data":"","name":"","options":{"history":{"day":1,"week":26,"month":6}}},{"id":257,"node_id":29,"instance":0,"minimum":260,"maximum":1160,"current_value":1003.7,"target_value":1003.7,"last_value":1003.6,"unit":"mBar","step_value":5,"editable":0,"type":94,"state":1,"last_changed":1678519389,"changed_by":1,"changed_by_id":0,"based_on":4,"data":"","name":"","options":{"history":{"day":1,"week":26,"month":6}}},{"id":258,"node_id":29,"instance":0,"minimum":0,"maximum":4,"current_value":4,"target_value":4,"last_value":2,"unit":"n%2Fa","step_value":1,"editable":0,"type":33,"state":1,"last_changed":1677083197,"changed_by":1,"changed_by_id":0,"based_on":4,"data":"","name":""},{"id":475,"node_id":29,"instance":0,"minimum":0,"maximum":1,"current_value":1,"target_value":1,"last_value":0,"unit":"","step_value":1,"editable":1,"type":385,"state":1,"last_changed":0,"changed_by":0,"changed_by_id":0,"based_on":0,"data":"","name":""}]}}
Wenn dem so ist, wo kann ich das ändern?
-
@oli Nein dem ist nicht so - im Gegenteil die attribute werden entfernt. - Ich denke wir haben ggf. nicht mit der gleichen Datenbasis gearbeitet.
Bei mir sind also in dem Input alle 46 Geräte zu sehen.
Mit der Change Node - werden im Gegenteil die einzelnen attribute weggenommen.
Also haben wir eine unterschiedliche Ausgangsbasis. Kommen denn die Geräte einzeln an? oder insgesamt?
Ich habe halt mit der Datenbasis gearbeitet, bei der alle Geräte aufeinmal ankommen. Also im Prinzip mit dem was Du mir in der Datei aus : https://forum.iobroker.net/post/960869 geschickt hast.
Deswegen heißt mein Array auch nodes und nicht node.
Jetzt ist halt die Frage - kannst Du das auch so machen oder müssen wir die einzelnen Geräte mühsam sammeln? Wenn die Geräte einzeln ankommen - müssen wir den Flow umändern.
Also sag mir, ob die Geräte sich da nun einzeln melden oder ob Du die ganze Geräteliste als Input zur Verfügung stellen kannst?
Im Prinzip hat der wohl die Nodes global gesammelt, da dies in der 1. Zeile der function Node so steht:
const nodes = global.get('homee.nodes');
Falls dem so ist, kannst Du mal in Deinem globalen Kontext schauen, ob da die vollständigen Nodeliste drin ist
?
Wenn ja dann - ignorieren wir nämlich den Input und setzen die payload am Anfang auf den globalen Kontext.
Also schau mal, was ggf. hier in Deinem globalen Kontext drin steht:
Du musst rechts auf das Aktualisieren Icon drücken.
Falls dem so ist, wie ich vermute, dann ist das was rein kommt in Deinen Flow nur ein trigger - den wir später auch verfeinern können.
Du kannst die payload - wie in der function Node auf alle Nodes setzen, wenn Du vorher noch folgende Change Node dran machst:
die Change Node muss folgenden Inhalt haben:
Im Prinzip holen wir dann bei jedem Geräteupdate die vollständige Liste bzw. analysieren diese.
Im Prinzip filtert er aus, dass nur diese Ereignisse triggern:
if((msg.payload.node && ((msg.payload.node.state === 2)||(msg.payload.node.state === 12)))||msg.payload === true)
das müssen wir halt nochmal schauen, ob das Sinn macht. Das bedeutet, dass momentan die Auswertung nur läuft wenn die payload nur true ist oder die payload eine Eigenschaft node hat, deren states 2 oder 12 ist.
Ich hoffe ich habe mich verständlich ausgedrückt. - Also setze mal die payload auf den globalen Kontext, mit der Change Node und mit den triggern überlegen wir uns noch.
=====================================================================================
So ich hab das jetzt nochmal simuliert:
Wenn bei Dir der globale Kontext so aussieht:
Dann sollte jetzt dieser ganze Flow funktionieren, indem Du einfach auf den trigger Knopf drückst oder auch von Deinem anderen Flow triggern lässt:
Wenn Du dann unten den Trigger Report anklickst - dann solltest Du im Debug Fenster folgende Daten erhalten:
{ "active": { "count": 44, "names": "Bewegungsmelder Kirsten\nBewegungsmelder Oliver\nLuftreiniger\nNachtlicht TV\nNachtlicht Kirsten\n\nNachtlicht Oliver\nHeizung Wohnzimmer Balkon\nWaschmaschine\nMultimedia\nRauchmelder Flur Dachgeschoss\nRauchmelder Flur Erdgeschoss\nRauchmelder Flur Keller\nFenster Bad\nBalkontür Esszimmer\nBalkontür Wohnzimmer\nFenster Toilette\nFenster Büro Rechts\nFenster Büro Links\nSchlafzimmer Rauchmelder\nRauchmelder Schlafzimmer Keller\nHeizung Büro\nVitrine Wohnzimmer\nTemperatur Weinkühlschrank\nHeizung Wohnzimmer Links\nSchrank Wohnzimmer\nHeizung Esszimmer\nHeizung Toilette\nWeinschrank Wohnzimmer\nThermostat Wohnzimmer\nComputer\nKühlschrank\nGeschirrspüler\nWassersensor Küche\nHeizung Bad\nKlima Wohnzimmer\nKlima Balkon\nKlima Büro\nKlima Schlafzimmer\nKlimaanlage\nTablet\nStehlampe Wohnzimmer\nBar Wohnzimmer\nTemperatur Kühlschrank" }, "inactive": { "count": 1, "names": "Licht Glasvitrine Flur" }, "updating": { "count": 0, "names": "Keine Geräte im Aktualisierungsstatus" }, "summary": "Nicht alle Geräte bereit!" }
-
@mickym
sieht bei mir so aus:
-
@oli Ok - dann lass mich noch eine kleine Modifikation machen.