Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. Problem mit "Fenster offen Script"

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Problem mit "Fenster offen Script"

    This topic has been deleted. Only users with topic management privileges can see it.
    • Negalein
      Negalein Global Moderator last edited by

      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(/(&nbsp;|<([^>]+)>)/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);
      });
      

      bf74d7a6-ec23-47d4-921a-15ed4d55f6ae-image.png

      Codierknecht 1 Reply Last reply Reply Quote 0
      • Codierknecht
        Codierknecht Developer Most Active @Negalein last edited by

        @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);
        });
        
        paul53 Negalein 3 Replies Last reply Reply Quote 0
        • paul53
          paul53 @Codierknecht last edited by

          @codierknecht sagte: Geht auch etwas schlanker ...

          Bei HM(IP) werden so auch andere Datenpunkte als "STATE" erfasst, da "window" dem Kanal zugeordnet ist.

          Codierknecht 1 Reply Last reply Reply Quote 1
          • Negalein
            Negalein Global Moderator @Codierknecht last edited by

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

            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);
            });
            
            paul53 1 Reply Last reply Reply Quote 0
            • paul53
              paul53 @Negalein last edited by

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

              Negalein 1 Reply Last reply Reply Quote 0
              • Negalein
                Negalein Global Moderator @paul53 last edited by

                @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
                71a6c38a-4fd9-4178-b43d-e3c9adb9e50d-image.png

                paul53 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @Negalein last edited by

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

                  Negalein 1 Reply Last reply Reply Quote 0
                  • Negalein
                    Negalein Global Moderator @paul53 last edited by

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

                    Codierknecht 1 Reply Last reply Reply Quote 0
                    • Codierknecht
                      Codierknecht Developer Most Active @Negalein last edited by

                      @negalein sagte in Problem mit "Fenster offen Script":

                      Jedes Fenster, oder reicht ein Fenster auf/zu?

                      Ein beliebiges aus der Liste.

                      Negalein 1 Reply Last reply Reply Quote 0
                      • Codierknecht
                        Codierknecht Developer Most Active @paul53 last edited by

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

                        1 Reply Last reply Reply Quote 0
                        • Negalein
                          Negalein Global Moderator @Codierknecht last edited by

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

                          8ea2e1d5-4c9e-44fc-9d5c-8580415abb7a-image.png

                          99e1922f-7d52-4de3-9db7-e94b0e03140c-image.png

                          Codierknecht 1 Reply Last reply Reply Quote 0
                          • Codierknecht
                            Codierknecht Developer Most Active @Negalein last edited by

                            @negalein
                            Feuert der Trigger denn?
                            Bau dort mal eine Logausgabe ein.

                            Negalein 1 Reply Last reply Reply Quote 0
                            • Negalein
                              Negalein Global Moderator @Codierknecht last edited by

                              @codierknecht sagte in Problem mit "Fenster offen Script":

                              Bau dort mal eine Logausgabe ein.

                              magst mir da helfen? 😉

                              Codierknecht 1 Reply Last reply Reply Quote 0
                              • Codierknecht
                                Codierknecht Developer Most Active @Negalein last edited by

                                @negalein

                                on(ids, function () {
                                  log('Trigger feuert!');
                                  ...
                                });
                                
                                Negalein 1 Reply Last reply Reply Quote 0
                                • Negalein
                                  Negalein Global Moderator @Codierknecht last edited by Negalein

                                  @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

                                  Codierknecht 1 Reply Last reply Reply Quote 0
                                  • Codierknecht
                                    Codierknecht Developer Most Active @Negalein last edited by

                                    @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);
                                    });
                                    
                                    Negalein 1 Reply Last reply Reply Quote 0
                                    • Negalein
                                      Negalein Global Moderator @Codierknecht last edited by

                                      @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
                                      
                                      1 Reply Last reply Reply Quote 0
                                      • Negalein
                                        Negalein Global Moderator @Codierknecht last edited by

                                        @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 die Gesamtanzahl der Fenster.

                                        Sorry, hab mich oben etwas unklar ausgedrückt.

                                        Codierknecht paul53 2 Replies Last reply Reply Quote 0
                                        • Codierknecht
                                          Codierknecht Developer Most Active @Negalein last edited by

                                          @negalein
                                          Weißt Du nicht, wie viele Fenster Dein Haus hat? 😁 😁 😁

                                          Negalein 1 Reply Last reply Reply Quote 0
                                          • Negalein
                                            Negalein Global Moderator @Codierknecht last edited by

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

                                            Codierknecht 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            872
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            6
                                            71
                                            2600
                                            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