NEWS
Fenster Script: Liste der offenen Fenster
-
dein Vorschlag klappt nicht, bzw.das Script funktioniert dann nicht, bzw. bringt Fehler.
2020-03-28 23:35:18.465 info (22746) Stop script script.js.1_Überwachung_Wohnung.Fenster_Licht_Status javascript.0 2020-03-28 23:34:32.025 error (22746) at process._tickCallback (internal/process/next_tick.js:68:7) javascript.0 2020-03-28 23:34:32.025 error (22746) at promise.then (/opt/iobroker/node_modules/standard-as-callback/built/index.js:19:49) javascript.0 2020-03-28 23:34:32.025 error (22746) at tryCatcher (/opt/iobroker/node_modules/standard-as-callback/built/utils.js:11:23) javascript.0 2020-03-28 23:34:32.025 error (22746) at client.get (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInRedis.js:580:17) javascript.0 2020-03-28 23:34:32.025 error (22746) at adapter.getForeignState (/opt/iobroker/node_modules/iobroker.javascript/main.js:1055:17) javascript.0 2020-03-28 23:34:32.025 error (22746) at createProblemObject (/opt/iobroker/node_modules/iobroker.javascript/main.js:1464:17) javascript.0 2020-03-28 23:34:32.025 error (22746) at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1411:37) javascript.0 2020-03-28 23:34:32.024 error (22746) at compile (/opt/iobroker/node_modules/iobroker.javascript/main.js:1188:28) javascript.0 2020-03-28 23:34:32.024 error (22746) at Object.createScript (vm.js:277:10) javascript.0 2020-03-28 23:34:32.024 error (22746) at new Script (vm.js:83:7) javascript.0 2020-03-28 23:34:32.024 error (22746) SyntaxError: missing ) after argument list javascript.0 2020-03-28 23:34:32.024 error (22746) ^ javascript.0 2020-03-28 23:34:32.024 error (22746) listlights.forEach((a) => { lights_onText += a + '\n';} javascript.0 2020-03-28 23:34:32.024 error at script.js.1_Überwachung_Wohnung.Fenster_Licht_Status:50 javascript.0 2020-03-28 23:34:32.024 error (22746) script.js.1_Überwachung_Wohnung.Fenster_Licht_Status compile failed:
der Zeilenumbruch wird nicht angenommen, ich habe schon einen DP im VIS um das zu prüfen.
-
@dos1973
jup in meinem Vorschlag hab ich wieder ); vergessen, passiert mir häufiger.listlights.forEach((a) => { lights_onText += a + '\n';});
Aber VIS ist nicht Datenpunkt: schreib mal von hand
1<br>2<br>3 oder 1<br/>2<br/>3 oder 1\n2\n3 oder 1\r\n2\r\n3
in den Datenpunkt. Eines davon wird gehen.
-
ich bekomme immer mehr das Gefühl dass ich in einem DP gar kein Zeilenumbruch haben kann??
auch wenn ich das manuell Eingebe gehts nicht?
ALSO im VIS wird einfach Fließtext ausgegeben, der in dem DP aufgenommen ist -
ich habs gefunden - mein Fehler "natürlich"
if(listlights.length) lights_onText = 'Lampen ein: ' + listlights.join((',<br>'));
aber in VIS hatte ich einen Basic-String genommen, damit gehts natürlich nicht.
Jetzt mit einem HTML Widget gehts. -
@dos1973 said in Fenster Script: Liste der offenen Fenster:
aber in VIS hatte ich einen Basic-String genommen, damit gehts natürlich nicht.
Jetzt mit einem HTML Widget gehts.Hi Dos1973
wie trägst du den datenpunkt in dem HTML widget ein?
Gruss Juergen -
Guten Abend,
Ich würde die Aufzählung auch gerne Verwenden.
Irgendwie werden mir in dem String nur die Homematic ID ausgegeben.
Im Iobroker selber habe Ich den Namen bereits geändert. Bleibt aber das gleiche.
Kann Ich das Script an Irgendeiner stelle abändern, sodass Ich den Namen und nicht die ID ausgegeben bekomme? -
-
@v522533 said in Fenster Script: Liste der offenen Fenster:
Ich habe das hier genutzt.
Passiert aber bei jeden Script hier im Thema.function countOpenWindowsDoors() { var openWindows = 0; var openDoors = 0; // Fenster var windows = getObject("enum.functions.windowstatus").common.members; for(let i = 0; i < windows.length; i++) { var Status = getState(windows[i]).val; if ( Status ) { openWindows = openWindows + 1; } } // Türen var doors = getObject("enum.functions.doorstatus").common.members; for(let i = 0; i < doors.length; i++) { var Status = getState(doors[i]).val; if ( Status ) { openDoors = openDoors + 1; } } var openWindowsText = "Kein Fenster geöffnet"; var openDoorText = "Keine Tür geöffnet"; if ( openWindows > 0 ) { openWindowsText = openWindows + " Fenster geöffnet"; } if ( openDoors > 0 ) { openDoorText = openDoors + " Türe(n) geöffnet"; } setState('Datenpunkte.0.StatusWindowOpenText', openWindowsText ); setState('Datenpunkte.0.StatusDoorOpenText', openDoorText ); setState('Datenpunkte.0.StatusWindowOpen', openWindows, true ); setState('Datenpunkte.0.StatusDoorOpen', openDoors, true ); } function registerSubscription() { $('state(functions=windowstatus)').on(function(obj) { countOpenWindowsDoors(); }); $('state(functions=doorstatus)').on(function(obj) { countOpenWindowsDoors(); }); } registerSubscription(); countOpenWindowsDoors();
-
-
Sry, Ich habe mal fix zum PC gewechselt!
Vom Handy klappt das nicht so gut.Das Script ist folgendes
function countOpenWindowsDoors() { var openWindows = 0; var openDoors = 0; var listWindows = []; var listDoors = []; // Fenster var windows = getObject("enum.functions.fensterstatus").common.members; for(let i = 0; i < windows.length; i++) { var Status = getState(windows[i]).val; if ( Status ) { openWindows++; let id = windows[i].substring(0, windows[i].lastIndexOf('.')); // Device ID listWindows.push(getObject(id).common.name); // Device Name } } // Türen var doors = getObject("enum.functions.turstatus").common.members; for(let i = 0; i < doors.length; i++) { var Status = getState(doors[i]).val; if ( Status ) { openDoors++; let id = windows[i].substring(0, windows[i].lastIndexOf('.')); // Device ID listDoors.push(getObject(id).common.name); // Device Name } } var openWindowsText = "Kein Fenster geöffnet"; var openDoorsText = "Keine Tür geöffnet"; if(listWindows.length) openWindowsText = '' + listWindows.join(', '); if(listDoors.length) openDoorsText = 'Offene Türen: ' + listDoors.join(', '); setState('0_userdata.0.FensteroffenText', openWindowsText, true); setState('0_userdata.0.turoffenText', openDoorsText, true); setState('0_userdata.0.FensteroffenAnzahl', openWindows, true ); setState('0_userdata.0.turoffenAnzahl', openDoors, true ); } $('state(functions=fensterstatus)').on(function(obj) { countOpenWindowsDoors(); }); $('state(functions=turstatus)').on(function(obj) { countOpenWindowsDoors(); }); countOpenWindowsDoors();
Und das schreibt er mir halt!
Nur hätte Ich halt den Namen (in dem Fall Kellertür) dort stehen.
-
@Oak sagte:
Nur hätte Ich halt den Namen (in dem Fall Kellertür) dort stehen.
Welches Objekt hat den Namen "Kellertür"? Das Device oder der Datenpunkt?
Für den Devicename füge eine Zeile ein (an 2 Stellen):let id = windows[i].substring(0, windows[i].lastIndexOf('.')); // Channel ID id = id.substring(0, id.lastIndexOf('.')); // Device ID listDoors.push(getObject(id).common.name); // Device Name
-
@paul53
Sauber das Funktioniert!
Vielen Dank für deine Unsterstützung paul53. -
Guten Morgen in die Runde. Ich habe versucht, alles aus diesem Thread auch umzusetzen... aber es will nicht klappen.
Hier mal die Log Ausgabe (sind alles Magnetkontakte über den MiHome Adapter, nur als Info):
20.2.2021, 07:22:42.392 [info ]: javascript.0 (6691) Start javascript script.js.common.Aufzählungen.Fenster 20.2.2021, 07:22:42.433 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.433 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.435 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.435 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.436 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.436 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.438 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.438 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.441 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.442 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.443 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.443 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.445 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.445 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.447 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.447 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.449 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.449 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.450 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.451 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.452 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.453 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.454 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.454 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.457 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.457 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.458 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.459 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.460 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.460 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.462 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.462 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.463 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.463 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.464 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.465 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.467 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.467 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.472 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:11:22) 20.2.2021, 07:22:42.473 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.474 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:24:22) 20.2.2021, 07:22:42.474 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.476 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:24:22) 20.2.2021, 07:22:42.476 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.478 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:24:22) 20.2.2021, 07:22:42.478 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.479 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:24:22) 20.2.2021, 07:22:42.479 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.480 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:24:22) 20.2.2021, 07:22:42.481 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.482 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:24:22) 20.2.2021, 07:22:42.482 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.483 [warn ]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:24:22) 20.2.2021, 07:22:42.483 [warn ]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1 20.2.2021, 07:22:42.485 [error]: javascript.0 (6691) script.js.common.Aufzählungen.Fenster: script.js.common.Aufzählungen.Fenster:29 20.2.2021, 07:22:42.486 [error]: javascript.0 (6691) at countOpenWindowsDoors (script.js.common.Aufzählungen.Fenster:29:41) 20.2.2021, 07:22:42.486 [error]: javascript.0 (6691) at script.js.common.Aufzählungen.Fenster:54:1
Hier das Script bisher:
function countOpenWindowsDoors() { var openWindows = 0; var openDoors = 0; var listWindows = []; var listDoors = []; // Fenster var windows = getObject("enum.functions.fenster").common.members; for(let i = 0; i < windows.length; i++) { var Status = getState(windows[i]).val; if ( Status ) { openWindows++; let id = windows[i].substring(0, windows[i].lastIndexOf('.')); // Channel ID id = id.substring(0, id.lastIndexOf('.')); // Device ID listWindows.push(getObject(id).common.name); // Device Name } } // Türen var doors = getObject("enum.functions.tür").common.members; for(let i = 0; i < doors.length; i++) { var Status = getState(doors[i]).val; if ( Status ) { openDoors++; let id = windows[i].substring(0, windows[i].lastIndexOf('.')); // Channel ID id = id.substring(0, id.lastIndexOf('.')); // Device ID listDoors.push(getObject(id).common.name); // Device Name } } var openWindowsText = "Kein Fenster geöffnet"; var openDoorsText = "Keine Tür geöffnet"; if (listWindows.length) openWindowsText = 'Offene Fenster: ' + listWindows.join(', '); if (listDoors.length) openDoorsText = 'Offene Türen: ' + listDoors.join(', '); setState('0_userdata.0.Zähler.FensteroffenText', openWindowsText, true); setState('0_userdata.0.Zähler.TuroffenText', openDoorsText, true); setState('0_userdata.0.Zähler.FensteroffenAnzahl', openWindows, true ); setState('0_userdata.0.Zähler.TueroffenAnzahl', openDoors, true ); } $('state(functions=fenster)').on(function(obj) { countOpenWindowsDoors(); }); $('state(functions=tür)').on(function(obj) { countOpenWindowsDoors(); }); countOpenWindowsDoors();
Hier soll er reinschreiben:
und:
Evtl. sieht jemand meinen Fehler.
Danke schon einmal.Liebe Grüße und allen ein schönes Wochenende.
-
@nobody28 sagte: Hier das Script bisher:
Dieses Script funktioniert nur unter folgenden Voraussetzungen:
- Den Enums "enum.functions.fenster" und "enum.functions.tür" sind Datenpunkte zugeordnet
- 2 Ordner-Ebenen über den Datenpunkten existieren Objekte (device), deren Namen ausgegeben werden soll
-
Sorry Paul,
ich kann Dir leider nicht ganz Folgen.
Das sind die Sensoren, und einen exemplarisch aufgeklappt:
Was ist da die besagt 2. Ebene bitte?
Danke schon mal für die Hilfe.
Liebe Grüße
-
@nobody28 sagte: Was ist da die besagt 2. Ebene bitte?
Die gibt es bei Dir nicht als Objekt (Ordner "devices").
Du hast die Gewerke den Kanälen zugeordnet, damit sind die Kanäle in common.members und nicht die Datenpunkte.
Verwende besser die Lösung mit $selector.each().
const idsFenster = $('mihome.0.*.state(functions=fenster)'); const idsTueren = $('mihome.0.*.state(functions=tür)'); function countOpenWindowsDoors() { var openWindows = 0; var openDoors = 0; var listWindows = []; var listDoors = []; // Fenster idsFenster.each(function(id, i) { if(getState(id).val) { openWindows++; id = id.substring(0, id.lastIndexOf('.')); // Channel ID listWindows.push(getObject(id).common.name); // Channel Name } }); // Türen idsTueren.each(function(id, i) { if(getState(id).val) { openDoors++; id = id.substring(0, id.lastIndexOf('.')); // Channel ID listDoors.push(getObject(id).common.name); // Channel Name } }); var openWindowsText = "Kein Fenster geöffnet"; var openDoorsText = "Keine Tür geöffnet"; if (listWindows.length) openWindowsText = 'Offene Fenster: ' + listWindows.join(', '); if (listDoors.length) openDoorsText = 'Offene Türen: ' + listDoors.join(', '); log(openWindowsText); setState('0_userdata.0.Zähler.FensteroffenText', openWindowsText, true); setState('0_userdata.0.Zähler.TuroffenText', openDoorsText, true); setState('0_userdata.0.Zähler.FensteroffenAnzahl', openWindows, true ); setState('0_userdata.0.Zähler.TueroffenAnzahl', openDoors, true ); } idsFenster.on(function(obj) { countOpenWindowsDoors(); }); idsTueren.on(function(obj) { countOpenWindowsDoors(); }); countOpenWindowsDoors();
-
Vielen Dank, das funktioniert auf Anhieb.
Nur mir ist leider der Unterschied zwischen Kanal und Datenpunkt nicht ganz klar.
Kannst du das mit einem einfachen Beispiel wohl erklären?
Vielen Dank.Liebe Grüße
-
@nobody28 sagte: Unterschied zwischen Kanal und Datenpunkt
Ein Datenpunkt ist ein Objekt vom Typ "state" und hat Zustände/Werte (rechts in Deinem Bild). Ein Kanal ist ein Objekt vom Typ "channel" und hat keine Zustände.