NEWS
Problem mit "Fenster offen Script"
-
Hallo
Ich verwende dieses Script um mir die Anzahl der Fenster (Xiaomi & Hm-IP) anzuzeigen.
Nur mit Xiaomi funktioniert es.
Aber gemischt mit Xiaomi & Hm-IP zeigt es nur die 4 Xiaomi an.
Trotz richtiger Funktion (Fenster) wird der Hm-IP nicht mitgezählt.Funktioniert eine Mischung generell nicht, oder passt im Script etwas nicht?
/* Status Zahl Fenster Homematic var cacheSelectorLevel = $('channel[state.id=*.STATE](functions="Fenster")'); Mi var cacheSelectorState = $('state[id=*.state](functions="Fenster")'); {1} */ var logging = false; var idAnzahlEin = 'javascript.0.Status.Fenster.Anzahl_auf', idAnzahl = 'javascript.0.Status.Fenster.Anzahl', idText = 'javascript.0.Status.Fenster.Text', idRaum = 'javascript.0.Status.Fenster.Raum', // <---- NEU idAnsage = 'javascript.0.Status.Fenster.Ansage'; // Ab hier nix mehr ändern createState(idAnzahl, { // wenn benötigt: Anzahl der vorhandenen Lichter type: 'number', name: 'Anzahl aller Fenster', min: 0, def: 0, role: 'value' }); createState(idAnzahlEin, { // Anzahl der Fenster, die auf sind als Variable unter Javascript.0 anlegen type: 'number', name: 'Anzahl der offenen Fenster', min: 0, def: 0, role: 'value' }); createState(idText, { // Anzahl der brennenden Lichter und deren Namen als Variable unter Javascript.0 anlegen type: 'string', name: 'Offene Fenster', desc: 'Namen der offenen Fenster', def: ' ', role: 'value' }); createState(idAnsage, { type: 'string', name: 'Offene Fenster (Ansage)', desc: 'Namen der offenen Fenster (für Ansage aufbereitet)', def: ' ', role: 'value' }); createState(idRaum, { // Räume, in denen Lichter brennen // <---- NEU type: 'string', name: 'Räume mit offenen Fenster', desc: 'Namen der Räume, in denen Fenster offen sind', def: ' ', role: 'value' }); //var cacheSelectorState = $('channel[state.id=*.STATE](functions="Licht")'); // Gewerk Licht var cacheSelectorLevel = $('channel[state.id=*.LEVEL](functions="XXX")'); //var cacheSelectorHue = $('state[id=*.on](functions=Licht)'); var cacheSelectorState2 = $('channel[state.id=*.STATE](functions="Fenster")'); //Homematic var cacheSelectorState = $('state[id=*.state](functions="Fenster")'); //Mi function checkDevices(obj) { // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht auf 0 var anzahlLichterAn = 0; var anzahlLichter = 0; var textLichterAn = []; var textRaum = []; if (logging) { log('++++++ Fenster Anzahl ++++ '); log('#### Mi ##### '); } cacheSelectorState.each(function(id, i) { // Schleife für jedes gefundenen Element *.state im Gewerk Fenster var status = getState(id).val; // Zustand *.state abfragen (jedes Element) var deviceId = id.substring(0, id.lastIndexOf(".")); var devicename = getObject(deviceId).common.name; var raumname = getObject(id, "rooms").enumNames[0]; if (logging) { log('---Mi----'); log('Raum: ' + JSON.stringify(raumname)); log('Status: ' + status); } if (status) { // wenn Zustand = true, dann wird die Anzahl der Fenster hochgezählt ++anzahlLichterAn; textLichterAn.push(devicename); // Zu Array hinzufügen textRaum.push(raumname); // <---- NEU } ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status }); cacheSelectorState2.each(function(id, i) { // Schleife für jedes gefundenen Element *.ON im Gewerk Licht var obj = getObject(id); var name = getObject(id).common.name; var status = getState(id).val; // Zustand *.STATE abfragen (jedes Element) var devicename = name.substring(0, name.indexOf(".STATE")); //.state aus Text entfernen var raumname = getObject(id, "rooms"); // <---- NEU // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen) // if ( (devicename.search(/(CUX)|(K2)|(K3)|(VK)|(:)/ig) == -1) ) { if (logging) { log('---Homematic----'); log('Kanal: ' + name); log('Status: ' + status); } if (status) { // wenn Zustand = true, dann wird die Anzahl der Lichter hochgezählt ++anzahlLichterAn; textLichterAn.push(devicename); // Zu Array hinzufügen textRaum.push(raumname.enumNames); // <---- NEU } ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status // } // ENDE VK-Abfrage }); if (logging) log('#### DIMMER ##### '); cacheSelectorLevel.each(function(id, i) { // Schleife für jedes gefundenen Element *.LEVEL im Gewerk Licht var obj = getObject(id); var name = getObject(id).common.name; var status = getState(id).val; // Zustand *.LEVEL abfragen (jedes Element) var devicename = name.substring(0, name.indexOf(".LEVEL")); //.state aus Text entfernen var raumname = getObject(id, "rooms"); // <---- NEU // ########## Abfrage ob Virtueller Kanal? VK oder : im Namen) // if ( (devicename.search(/(CUX)|(K2)|(K3)|(V10)|(VK)|(:)/ig) == -1) ) { // Geräte mit diesen Strings im namen nicht beachten if (logging) { log('-------'); log('Kanal: ' + name); log('Status: ' + status + '%'); } if (parseFloat(status) > 0) { // Wenn Dimmwert über 0 ++anzahlLichterAn; textLichterAn.push(devicename); // Zu Array hinzufügen textRaum.push(raumname.enumNames); // <---- NEU } ++anzahlLichter; // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status // } // Ende Abfrage VK }); // Array mit Lichternamen sortieren textLichterAn.sort(); textRaum.sort(); // <---- NEU // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben if (logging) log("Text: " + textLichterAn); if (logging) log("Anzahl Fenster: " + anzahlLichter + " # davon Fenster offen: " + anzahlLichterAn); // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS) setState(idText, textLichterAn.join(', ')); // Schreibt die aktuelle Namen der eingeschalteten Lichter setState(idAnzahlEin, textLichterAn.length); // Schreibt die aktuelle Anzahl der eingeschalteten Lichter setState(idAnzahl, anzahlLichter); // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht // setState(idRaum, textRaum.join(',<br>')); // Räume, in denen Licht brennt // <---- NEU setState(idRaum, textRaum.join(', ')); // Räume, in denen Licht brennt // <---- NEU } // Trigger cacheSelectorState.on(function(obj) { // bei Zustandänderung *.STATE im Gewerk Licht if (logging) log('Auslösender Schalter: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat checkDevices(); }); cacheSelectorState2.on(function(obj) { // bei Zustandänderung *.ON von HUE Lampen im Gewerk Licht if (logging) log('Auslösende Homematic: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat checkDevices(); }); cacheSelectorLevel.on(function(obj) { // bei Zustandänderung *.LEVEL im Gewerk Licht if (logging) log('Auslösender Dimmer: ' + obj.id + ': ' + obj.state.val); // Info im Log, welcher Zustand sich geändert hat checkDevices(); }); function main() { setTimeout(function() { if (logging) log('Auslöser Skriptstart'); checkDevices(); }, 2000); } main(); // Skriptstart-Auslöser // Aufbereitung für Ansage function strip_tags(data) { var rueckgabe = data.replace(/( |<([^>]+)>)/ig, " "); return (rueckgabe); } on(idText, function(obj) { var text = obj.state.val; text = (getState(idAnzahl).val > 0) ? 'Fenster offen: ' + strip_tags(text) : 'Alle Fenster geschlossen'; setState(idAnsage, text); });
-
@negalein
180 Zeilen Code, um die Anzahl geöffneter Fenster zu erhalten?Geht auch etwas schlanker ...
const ids = Array.prototype.slice.apply($("(functions=window)")); on(ids, function () { let count = 0; for (let id of ids) { if (getState(id).val) count++; } setState("0_userdata.0.Vis.fenster", count, true); });
-
@codierknecht sagte: Geht auch etwas schlanker ...
Bei HM(IP) werden so auch andere Datenpunkte als "STATE" erfasst, da "window" dem Kanal zugeordnet ist.
-
@codierknecht sagte in Problem mit "Fenster offen Script":
Geht auch etwas schlanker ...
Danke!
Hatte das Script vor langer Zeit aus dem Forum.Hab deines an mich angepasst.
Aber Anzahl bleibt bei0
.Hab ich noch einen Fehler?
const ids = Array.prototype.slice.apply($("(functions=Fenster)")); on(ids, function () { let count = 0; for (let id of ids) { if (getState(id).val) count++; } setState("0_userdata.0.Fenster.Anzahl", count, true); });
-
@negalein sagte: Anzahl bleibt bei 0
Ist "Fenster" in der ID "enum.functions.Fenster" genau so geschrieben? Die Schreibweise (groß / klein) muss wie in der ID sein.
-
@paul53 sagte in Problem mit "Fenster offen Script":
Ist "Fenster" in der ID "enum.functions.Fenster" genau so geschrieben? Die Schreibweise (groß / klein) muss wie in der ID sein.
Ja
-
@negalein
Dann prüfe den Selektor per Log:const ids = Array.prototype.slice.apply($("(functions=Fenster)")); log(ids);
Es muss ein Array mit 5 IDs im Log erscheinen.
Außerdem muss erst ein Fenster geöffnet oder geschlossen werden, damit der Trigger auslöst. -
@paul53 sagte in Problem mit "Fenster offen Script":
Es muss ein Array mit 5 IDs im Log erscheinen.
Ja, das erscheint.
javascript.0 2024-01-16 00:04:05.482 info script.js.Fenster.Fensterzaehlen_HmIP: [ 'hm-rpc.0.0000DD898F6D97.1.STATE', 'mihome.0.devices.magnet_158d0002ec2655.state', 'mihome.0.devices.magnet_158d000316d3ad.state', 'mihome.0.devices.magnet_158d00032b770e.state', 'mihome.0.devices.magnet_158d0003cd589f.state']
Außerdem muss erst ein Fenster geöffnet oder geschlossen werden, damit der Trigger auslöst
Ah, das wusste ich nicht.
Jedes Fenster, oder reicht ein Fenster auf/zu?
Dann werd ich mal bis morgen warten. -
@negalein sagte in Problem mit "Fenster offen Script":
Jedes Fenster, oder reicht ein Fenster auf/zu?
Ein beliebiges aus der Liste.
-
@paul53 sagte in Problem mit "Fenster offen Script":
Bei HM(IP) werden so auch andere Datenpunkte als "STATE" erfasst, da "window" dem Kanal zugeordnet ist.
Das ist meine Funktion, die mit meiner enum läuft.
Ein bisschen anpassen darf der TE dann auch noch -
@codierknecht sagte in Problem mit "Fenster offen Script":
Ein beliebiges aus der Liste.
zeigt leider immer noch
0
, obwohl vorhin ein Fenster geöffnet wurde. -
@negalein
Feuert der Trigger denn?
Bau dort mal eine Logausgabe ein. -
@codierknecht sagte in Problem mit "Fenster offen Script":
Bau dort mal eine Logausgabe ein.
magst mir da helfen?
-
on(ids, function () { log('Trigger feuert!'); ... });
-
@codierknecht sagte in Problem mit "Fenster offen Script":
log('Trigger feuert!');
Abfeuern positiv
21:10:55.936 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: registered 5 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 21:14:11.443 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Trigger feuert!
Ziel bleibt bei
0
-
@negalein
OK - dann mal auf die ausführliche Art:const ids = Array.prototype.slice.apply($("(functions=Fenster)")); on(ids, function () { let count = 0; for (let id of ids) { log('prüfe Status für ' + id); let isOpen = getState(id).val; log('Status: ' + isOpen); if (isOpen) count++; } log(count + ' Fenster geöffnet'); setState("0_userdata.0.Fenster.Anzahl", count, true); });
-
@codierknecht sagte in Problem mit "Fenster offen Script":
OK - dann mal auf die ausführliche Art:
21:28:39.622 info javascript.0 (379909) Start javascript script.js.Fenster.Fensterzaehlen_HmIP 21:28:39.640 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: registered 5 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für hm-rpc.0.0000DD898F6D97.1.STATE 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: 1 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d0002ec2655.state 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d000316d3ad.state 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d00032b770e.state 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d0003cd589f.state 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:30:12.028 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: 1 Fenster geöffnet 21:31:17.352 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für hm-rpc.0.0000DD898F6D97.1.STATE 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: 0 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d0002ec2655.state 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d000316d3ad.state 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d00032b770e.state 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: prüfe Status für mihome.0.devices.magnet_158d0003cd589f.state 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: Status: false 21:31:17.353 info javascript.0 (379909) script.js.Fenster.Fensterzaehlen_HmIP: 0 Fenster geöffnet
-
@codierknecht sagte in Problem mit "Fenster offen Script":
180 Zeilen Code, um die Anzahl geöffneter Fenster zu erhalten?
hab jetzt nochmal von oben gelesen.
Mir gehts nicht um die
geöffneten
, sondern um dieGesamtanzahl
der Fenster.Sorry, hab mich oben etwas unklar ausgedrückt.
-
@negalein
Weißt Du nicht, wie viele Fenster Dein Haus hat? -
@codierknecht sagte in Problem mit "Fenster offen Script":
Weißt Du nicht, wie viele Fenster Dein Haus hat?
wie heißt es so schön?
IOT müsste oft IDF heißen ---> Internet der Faulen