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.
    • 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
                      • Codierknecht
                        Codierknecht Developer Most Active @Negalein last edited by

                        @negalein

                        const ids = Array.prototype.slice.apply($("(functions=window)"));
                        
                        log(ids);
                        
                        on(ids, function () {
                          let open = 0;
                          for (let id of ids) {
                            if (getState(id).val) open++;
                          }
                        
                          let count = ids.length;
                          log(open + ' von ' + count + ' Fenstern geöffnet');
                        
                          setState("0_userdata.0.Fenster.Anzahl", count, true);
                          setState("0_userdata.0.Fenster.Offen", open, true);
                        
                        });
                        

                        Die Anzahl der vorhandenen Fenster ändert sich erfahrungsgemäß recht selten.

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

                          @negalein sagte: die Gesamtanzahl der Fenster.

                          const ids = Array.prototype.slice.apply($("(functions=Fenster)"));
                          setState("0_userdata.0.Fenster.Anzahl", ids.length, true);
                          
                          Negalein 1 Reply Last reply Reply Quote 1
                          • Negalein
                            Negalein Global Moderator @Codierknecht last edited by

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

                            Die Anzahl der vorhandenen Fenster ändert sich erfahrungsgemäß recht selten.

                            Da hast du Recht! 🙂

                            Liegt irgendwie an meiner Situation. Alles was mein Leben erleichtert, nutze ich.
                            Leider kommen da auch oft Ideen, die eigentlich nicht wirklich nötig wären.
                            Wie diese Anzahl. 😹 😹

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

                              @Codierknecht @paul53

                              Danke, funktioniert 🙂

                              a798129f-4b84-4b76-8d1f-f0d9a48f0408-image.png

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

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

                                Gesamtanzahl der Fenster.

                                Hallo Paul!

                                Jetzt steh ich wieder an und bräuchte dein (oder jeder der helfen könnte) Fachwissen.

                                Hab ein paar Fenstersensoren neu montiert und der Funktion Tuer zugewiesen.
                                Neuen DP in 0_userdata.0.Tuer.Anzahl als Zahl angelegt.

                                Trotz mMn passendem Script (musste ja nur DP und Funktion tauschen) meint er es sind immer 0.

                                const ids = Array.prototype.slice.apply($("(functions=Tuer)"));
                                setState("0_userdata.0.Tuer.Anzahl", ids.length, true);
                                

                                2838a9b9-4909-4696-a30d-5c1c89d11a57-image.png

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

                                  @negalein sagte: der Funktion Tuer zugewiesen.

                                  Lautet die ID "enum.functions.Tuer"? Oder ist "tuer" in der ID klein geschrieben?
                                  Nach dem Erstellen von "Tuer" mal die Javascript-Instanz neu gestartet?

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

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

                                    Lautet die ID "enum.functions.Tuer"? Oder ist "tuer" in der ID klein geschrieben?

                                    Danke, das war der Fehler.

                                    Ich hatte auch das Beispiel von @Codierknecht versucht (sogar klein geschrieben), weil mir mit dem uralt-Script jetzt die Anzahl der offenen nicht mehr angezeigt wird.
                                    Da bekam ich bei .Anzahl und .Offen auch nur 0.

                                    Im Log war auch nichts.

                                    const ids = Array.prototype.slice.apply($("(functions=tuer)"));
                                     
                                    log(ids);
                                     
                                    on(ids, function () {
                                      let open = 0;
                                      for (let id of ids) {
                                        if (getState(id).val) open++;
                                      }
                                     
                                      let count = ids.length;
                                      log(open + ' von ' + count + ' Tür geöffnet');
                                     
                                      setState("0_userdata.0.Tuer.Anzahl", count, true);
                                      setState("0_userdata.0.Tuer.Offen", open, true);
                                     
                                    });
                                    
                                    1 Reply Last reply Reply Quote 0
                                    • A
                                      Adnim last edited by

                                      Hallo,
                                      hänge mich mal hier an, da das Thema das gleiche ist 🙂

                                      benutze noch das Device Counter Script. Da gibt es auch noch so eine schöne Liste welche Fenster offen sind.
                                      Würde das aber gerne unter Userdata haben und nicht unter Javascript.

                                      Bekomme es aber einfach nicht hin. Kann mir da mal jemand helfen?

                                      //Add device rules
                                      //addDeviceCounter("lowbat",         $('channel[state.id=*LOWBAT]'),                     true);
                                      //addDeviceCounter("lowbat",         $('channel[state.id=*lowbat]'),                      true);
                                      //addDeviceCounter("sticky_unreach", $('channel[state.id=*.STICKY_UNREACH]'),              true);
                                      //addDeviceCounter("unreach",        $('channel[state.id=*.UNREACH]'),                     true);
                                      //addDeviceCounter("config_pending", $('channel[state.id=*.CONFIG_PENDING]'),              true);
                                      addDeviceCounter("Motion",  $('channel[state.id=*.MOTION]'),               true);
                                      //addDeviceCounter("DutyCycle",  $('channel[state.id=*.DUTYCYCLE]'),               true);
                                      //addDeviceCounter("Spannungsüberwachung",  $('channel[state.id=*.VOLTAGE]'),           function(state){return state<200;});
                                      addDeviceCounter("Auskühlschutz",  $('channel[state.id=*.ACTUAL_TEMPERATURE]'),           function(state){return state<16;});
                                      //addDeviceCounter("ERROR",  $('channel[state.id=*.ERROR*]'),               function(state){return state>0;});
                                      //addDeviceCounter("ERROR1", $('channel[state.id=*.ERROR*]').each(function(id, i) {
                                       // log(id))};
                                      addDeviceCounter("Heizbedarf",  $('channel[state.id=*.VALVE_STATE]'),           function(state){return state>13;});
                                      //addDeviceCounter("Alive",         $('channel[state.id=*alive]'),                     false);
                                      //addDeviceCounter("CONNECTED",         $('channel[state.id=*.connected]'),                     false);
                                      //addDeviceCounter("open_shutters",  $('channel{TYPE=BLIND}[state.id=*.LEVEL]'),           function(state){return state>0;});
                                      addDeviceCounter("open_windows",   $('channel{TYPE=SHUTTER_CONTACT}[state.id=*.STATE]'), true);
                                      
                                      
                                      
                                      
                                      
                                      /******************************************
                                       * Code - do not change anything bellow this line *
                                       ******************************************/
                                      
                                      function addDeviceCounter(name, selector, val_to_count) {
                                      
                                          //Total amount of devices found by selector
                                          var state_total = 'deviceCounter.' + name + '.total';
                                          createState(state_total, 0);
                                          //List of devices that match condition
                                          var state_list = 'deviceCounter.' + name + '.list';
                                          createState(state_list, "");
                                          //Number of devices that match condition
                                          var state_counter = 'deviceCounter.' + name + '.counter';
                                      
                                          createState(state_counter, 0);
                                          function countDevs(obj) {
                                              var d_count = 0;
                                              var d_list  = [];
                                      
                                              selector.each(function (id, i) {
                                                  var status = getState(id).val;
                                                  var obj    = getObject(id);
                                                  if ((typeof val_to_count === 'function' && val_to_count(status)) ||
                                                      (typeof val_to_count === 'boolean'  && val_to_count == status)) {
                                                      //Get parent object
                                                     var parentChannelId = id.slice(id.lastIndexOf("."));
                                                      var parentDevicelId = id.split(".").slice(0,-2).join(".");
                                                      var deviceObject = getObject(parentDevicelId);
                                                      //remember device name
                                                      d_list.push(deviceObject.common.name);
                                                  }                
                                                  ++d_count;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                                              }); 
                                      
                                      //if ("state_counter" > 0) {event(name + "(" + d_count + "): " + d_list);
                                      //}
                                      
                                              setState(state_list,     d_list.join('<br>'));
                                              setState(state_counter,  d_list.length);
                                              setState(state_total,    d_count);
                                          }
                                      
                                          //Re-evaluate when a device status changes
                                          selector.on(function(obj) {    // bei Zustandänderung *. LOWBAT in allen Gewerken
                                              countDevs(obj);
                                          });
                                      
                                          //Re-evaluate each hour
                                          schedule("*/60 * * * *", countDevs);
                                          
                                          //Evaluate for the first time
                                          countDevs();
                                      }
                                      
                                      
                                      paul53 1 Reply Last reply Reply Quote 0
                                      • paul53
                                        paul53 @Adnim last edited by

                                        @adnim sagte: Würde das aber gerne unter Userdata haben und nicht unter Javascript.

                                        In Zeilen 31, 34 und 37 vor 'deviceCounter.' zusätzlich '0_userdata.0.' einfügen.
                                        Beispiel Zeile 31:

                                            var state_total = '0_userdata.0.deviceCounter.' + name + '.total';
                                        
                                        A 1 Reply Last reply Reply Quote 1
                                        • A
                                          Adnim @paul53 last edited by Adnim

                                          @paul53

                                          danach kommt aber das im Log:

                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at script.js.common.DeviceCounter1:79:3
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at script.js.common.DeviceCounter1:10:1
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at addDeviceCounter (script.js.common.DeviceCounter1:76:5)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at countDevs (script.js.common.DeviceCounter1:64:9)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1929:20)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	State "0_userdata.0.deviceCounter.Auskühlschutz.total" not found
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at script.js.common.DeviceCounter1:79:3
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at script.js.common.DeviceCounter1:10:1
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at addDeviceCounter (script.js.common.DeviceCounter1:76:5)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at countDevs (script.js.common.DeviceCounter1:63:9)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.847	warn	at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1929:20)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.846	warn	State "0_userdata.0.deviceCounter.Auskühlschutz.counter" not found
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.846	warn	at script.js.common.DeviceCounter1:79:3
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.846	warn	at script.js.common.DeviceCounter1:10:1
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.846	warn	at addDeviceCounter (script.js.common.DeviceCounter1:76:5)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.846	warn	at countDevs (script.js.common.DeviceCounter1:62:9)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.846	warn	at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1929:20)
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.846	warn	State "0_userdata.0.deviceCounter.Auskühlschutz.list" not found
                                          
                                          javascript.0
                                          2024-04-21 09:04:49.067	info	Start javascript script.js.common.DeviceCounter1
                                          

                                          Edit: Scheint aber nur beim ersten Start zu sein, skript funktioniert. Danke!

                                          1 Reply Last reply Reply Quote 0
                                          • werner2000x
                                            werner2000x last edited by

                                            Bei mir werden keine offene Fenster angezeigt.
                                            Ich habe in den objekten den Fenstern die Rolle "sensor. Window" gegeben.
                                            Ist das richtig oder muss das "Fenster" sein?
                                            Gibt es zu dem script ggf. eine Anleitung?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            600
                                            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