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 @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
                                      • paul53
                                        paul53 @werner2000x last edited by paul53

                                        @werner2000x sagte: die Rolle "sensor. Window" gegeben.

                                        Richtige Rolle: "sensor.window"
                                        Wenn nach der Rolle selektiert werden soll, dann mit so einem Selektor

                                        $('*[role=sensor.window]')
                                        
                                        werner2000x 1 Reply Last reply Reply Quote 0
                                        • werner2000x
                                          werner2000x @paul53 last edited by werner2000x

                                          @paul53 Ich bekomme kein Ergebnis, immer 0 erkannte Fenster.
                                          Ich habe allerdings kein Homematic.

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

                                            @werner2000x sagte: immer 0 erkannte Fenster.

                                            Zeige bitte Datenpunkte.
                                            Was ergibt?

                                            log($('*[role=sensor.window]'));
                                            

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

                                            Ich habe allerdings kein Homematic.

                                            Das hat nichts mit HomeMatic zu tun.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            735
                                            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