Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Status von Fensterkontakten anzeigen

    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

    Status von Fensterkontakten anzeigen

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

      @amsernat

      Kann es sein, dass du keine Homematic Fensterkontakte verwendest?
      Laut deinem Script von oben verwendest du Xiaomi.

      const idVis = 'Batterie.MiHomeBatterietausch';
      const batt = $('mihome.0.*.percent');
      

      Ich erinnere mich daran, dass es da so glaube ich einen Unterschied mit *.state und *.STATE gibt.

      So schaut mein Script mit Xiaomi aus:

      /* Status Zahl Fenster
      Homematic var cacheSelectorLevel = $('channel[state.id=*.STATE](functions="Fenster")');
      Mi var cacheSelectorState = $('state[id=*.state](functions="Fenster")');
      {1}
      */
      var logging = true;
       
      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);
      });
      
      A 1 Reply Last reply Reply Quote 1
      • A
        amsernat @Negalein last edited by

        @Negalein sagte in Status von Fensterkontakten anzeigen:

        @amsernat

        Kann es sein, dass du keine Homematic Fensterkontakte verwendest?
        Laut deinem Script von oben verwendest du Xiaomi.

        const idVis = 'Batterie.MiHomeBatterietausch';
        const batt = $('mihome.0.*.percent');
        

        Ich erinnere mich daran, dass es da so glaube ich einen Unterschied mit *.state und *.STATE gibt.

        So schaut mein Script mit Xiaomi aus:

        /* Status Zahl Fenster
        Homematic var cacheSelectorLevel = $('channel[state.id=*.STATE](functions="Fenster")');
        Mi var cacheSelectorState = $('state[id=*.state](functions="Fenster")');
        {1}
        */
        var logging = true;
         
        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);
        });
        

        ja, ich habe nur Xiaomi...

        Negalein smartboart 2 Replies Last reply Reply Quote 0
        • Negalein
          Negalein Global Moderator @amsernat last edited by

          @amsernat sagte in Status von Fensterkontakten anzeigen:

          ja, ich habe nur Xiaomi...

          Dann versuch mal das ich dir gepostet habe.

          A 1 Reply Last reply Reply Quote 0
          • A
            amsernat @smartboart last edited by

            @smartboart sagte in Status von Fensterkontakten anzeigen:

            die states sollten aber laut deinem script unter Status abgelegt werden.
            Wenn du

            var cacheSelectorState = $('state[state.id=*.STATE](functions="fenster")')
            

            fenster klein schreibst, dann ist das unter den Enum Funktionen natürlich richtig wenn es dort auch klein ist...

            Halte das Script mal an, lösche die Objekte wo sie abgelegt sind und lösche mal den browser cache.. Dann starte das script neu...

            sorry. ich habe den falschen skript dir gesendet...es war dein.
            hier meins:

            function fensterstatus(zustand) {
                var meldung;
                switch (zustand) {
                    case true:
                        meldung = '';
                    break;
                    case false:
                        meldung = 'zu';
                    break;
                }
                return(meldung);
            }
             
            createState('zählen_Fenster.anzahlFenster', {     // wenn benötigt: Anzahl der vorhandenen Fenster
                type: 'number',
                min: 0,
                def: 0,
                role: 'value'
            });
            createState('zählen_Fenster.anzahlFensterauf', {  // Anzahl der Fenster, die auf sind als Variable unter Javascript.0 anlegen
                type: 'number',
                min: 0,
                def: 0,
                role: 'value'
            });
            createState('zählen_Fenster.textFensterauf', {      // Anzahl der offenen Fenster und deren Namen als Variable unter Javascript.0 anlegen
                type: 'string',
                def: ' ',
                role: 'value'
            });
             
             
            const miFenster  = $('channel[state.id=*.state](functions=fenster)');
             
             
            function countFenster() {
                 // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Fenster auf 0
                var anzahlFenster = 0;
                var anzahlFensterauf = 0;
                var textFensterauf = [];
             
             
                miFenster.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 obj    = getObject(id);
                    var name = getObject(id).common.name;
                    var devicename = name;
                    if (status  || status === true || status === 1 ) {  // wenn Zustand offen, dann wird die Anzahl der Fenster hochgezählt
                         ++anzahlFensterauf;
                         textFensterauf.push(devicename + ' ' + fensterstatus(status) + ' ');  // Name und Zustand zum Array hinzufügen
                    }                
                    log('Fenster #' + (i+1) + ': ' + devicename + ' ' + fensterstatus(status)/* + ' (' + status + ' / ' + typeof status + ')'*/);
                    ++anzahlFenster;                                                        // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
                }); 
              
                // Schleifen sind durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                log("Text: " + textFensterauf);
                log("Anzahl Fenster: " + anzahlFenster + " - davon Fenster auf: " +  anzahlFensterauf);
             
                // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                setState("zählen_Fenster.textFensterauf", textFensterauf.join(', '));    // Schreibt die aktuelle Namen der offenen Fenster
                setState("zählen_Fenster.anzahlFensterauf", textFensterauf.length);         // Schreibt die aktuelle Anzahl der offenen Fenster
                setState("zählen_Fenster.anzahlFenster", anzahlFenster);                    // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Fenster
            }
             
            countFenster(); // Skriptstart
             
            miFenster.on(function(obj) {    // bei Zustandänderung *. state im Gewerk Fenster
                log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);              // Info im Log, welcher Zustand sich geändert hat
                countFenster();
            });
             
            // Variable für Ansage aufbereiten
            createState('zählen_Fenster.textFensteraufAnsage', {
                type: 'string',
                def: ' ',
                role: 'value'
            });  
            // Anzahl der Fenster, die auf sind, für Ansage aufbereitet
            var idQuelle = 'javascript.0.zählen_Fenster.textFensterauf',
                idAnsage = 'javascript.0.zählen_Fenster.textFensteraufAnsage';
             
            on(idQuelle, function (obj) {
                var text = obj.state.val;
            //    text = text.replace(/RHS/g, 'Drehgriff');
            //    text = text.replace(/TFK/g, 'Reedkontakt');
                text = (text.length > 1) ? 'Geöffnete Fenster: ' + text : 'Alle Fenster sind verschlossen';
                setState(idAnsage, text);
            });
            
            
            smartboart 1 Reply Last reply Reply Quote 0
            • smartboart
              smartboart @amsernat last edited by

              @amsernat sagte in Status von Fensterkontakten anzeigen:

              ja, ich habe nur Xiaomi...

              Aber im Moment geht es doch erstmalum den Ablageort unter den Objekten... Klar state und STATE ist ein Unterschied...Einfach im Objektbaum schaun wie der Sensor dort angelegt ist..

              1 Reply Last reply Reply Quote 1
              • smartboart
                smartboart @amsernat last edited by

                @amsernat sagte in Status von Fensterkontakten anzeigen:

                createState('zählen_Fenster.anzahlFenster', { // wenn benötigt: Anzahl der vorhandenen Fenster

                dann ist doch klar du hast es ja ohne die Variablen angelegt..

                createState('zählen_Fenster.anzahlFenster', {     // wenn benötigt: Anzahl der vorhandenen Fenster
                
                    type: 'number',
                
                    min: 0,
                
                    def: 0,
                
                    role: 'value'
                
                });
                
                smartboart 1 Reply Last reply Reply Quote 1
                • smartboart
                  smartboart last edited by

                  so legt er die states direkt in javascript.0.zählen_Fenster
                  ab..

                  1 Reply Last reply Reply Quote 1
                  • smartboart
                    smartboart @smartboart last edited by

                    Warum hast du das so abgeändert?

                    A 1 Reply Last reply Reply Quote 0
                    • A
                      amsernat @smartboart last edited by amsernat

                      @smartboart sagte in Status von Fensterkontakten anzeigen:

                      Warum hast du das so abgeändert?

                      ich dachte es wäre rechtig.... 😞 sorry, ich kenne mich nicht gut aus...

                      ich habe nun javascript angehalten, alle objekte gelöscht und dein Skript für xiaomi genommen.

                      A 1 Reply Last reply Reply Quote 0
                      • A
                        amsernat @amsernat last edited by

                        @amsernat
                        ich starte von 0 an 😉

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

                          @Negalein sagte in Status von Fensterkontakten anzeigen:

                          @amsernat sagte in Status von Fensterkontakten anzeigen:

                          ja, ich habe nur Xiaomi...

                          Dann versuch mal das ich dir gepostet habe.

                          hier der LOG:

                          18:42:19.411	info	javascript.0 Stop script script.js.common.TuerFensterKontakt
                          18:42:22.072	info	javascript.0 Start javascript script.js.common.TuerFensterKontakt
                          18:42:22.074	info	javascript.0 script.js.common.TuerFensterKontakt: registered 1 subscription and 0 schedules
                          18:42:24.057	info	javascript.0 script.js.common.TuerFensterKontakt: Auslöser Skriptstart
                          18:42:24.057	info	javascript.0 script.js.common.TuerFensterKontakt: ++++++ Fenster Anzahl ++++
                          18:42:24.057	info	javascript.0 script.js.common.TuerFensterKontakt: #### Mi #####
                          18:42:24.058	info	javascript.0 script.js.common.TuerFensterKontakt: #### DIMMER #####
                          18:42:24.058	info	javascript.0 script.js.common.TuerFensterKontakt: Text:
                          18:42:24.058	info	javascript.0 script.js.common.TuerFensterKontakt: Anzahl Fenster: 0 # davon Fenster offen: 0
                          

                          😞
                          Objekte:
                          4f1766dc-f3ff-4bae-a46a-cdfbdc7bb7ac-image.png

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

                            Wenn du alle Fensterkontakte des gleichen Typ hast, kannst du das originale immer nehmen. dann langt ein enum welches eventuell angepasste werden muss...wie sehen deine States der Kontakte den aus, welche Kontakte hast du?

                            A 1 Reply Last reply Reply Quote 0
                            • A
                              amsernat @smartboart last edited by

                              @smartboart sagte in Status von Fensterkontakten anzeigen:

                              Wenn du alle Fensterkontakte des gleichen Typ hast, kannst du das originale immer nehmen. dann langt ein enum...wie sehen deine States der Kontakte den aus, welche Kontakte hast du?

                              alle kontakte sind Xiaomi/aqara, und werden alle korrekt angezeigt.
                              c6775b1d-5a17-4d80-95a2-2a1744a7a012-image.png

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

                                 
                                
                                var cacheSelectorState = $('state[state.id=*.state](functions="fenster")'); // Gewerk Facade
                                
                                1 Reply Last reply Reply Quote 0
                                • smartboart
                                  smartboart last edited by smartboart

                                  nimmst das originale script unt passt nur den pfad an..

                                   
                                  
                                  var cacheSelectorState = $('state[state.id=*.state](functions="fenster")'); // Gewerk Facade
                                  

                                  Wichtig ist state statt STATE und Fenster entsprechend deiner Schreibweise in den Enum Funktionen..

                                  A 2 Replies Last reply Reply Quote 0
                                  • A
                                    amsernat @smartboart last edited by

                                    @smartboart sagte in Status von Fensterkontakten anzeigen:

                                    nimmst das originale script unt passt nur den pfad an..

                                    welches war nun das Original? 😂 😂 😂

                                    1 Reply Last reply Reply Quote 0
                                    • A
                                      amsernat @smartboart last edited by amsernat

                                      @smartboart sagte in Status von Fensterkontakten anzeigen:

                                      nimmst das originale script unt passt nur den pfad an..

                                       
                                      
                                      var cacheSelectorState = $('state[state.id=*.state](functions="fenster")'); // Gewerk Facade
                                      

                                      Wichtig ist state statt STATE und Fenster entsprechend deiner Schreibweise in den Enum Funktionen..

                                      klar F und f ....

                                      e7fe0689-d149-4bc0-affd-3a17b1df2897-image.png

                                      hat gefunkt...
                                      e6cae903-a2d9-4556-8777-242f199e2cd6-image.png

                                      1 Reply Last reply Reply Quote 0
                                      • K
                                        Kuddel last edited by

                                        Bei mir sieht das so aus

                                        c2d9daab-22d1-40b7-9d9d-4a28642a3998-grafik.png

                                        Und auf der Startseite habe ich noch eine Übersicht für EG und OG
                                        16397e28-38d5-4cf0-9d95-69c17a523f3e-grafik.png

                                        C 1 Reply Last reply Reply Quote 0
                                        • S
                                          sourex @eric2905 last edited by

                                          @eric2905
                                          Hallo,
                                          ich steige gerade von OpenHab auf IoBroker um weswegen ich da noch so einige Schwierigkeiten habe.
                                          Mir gefällt dein Beispiel von Jqui mit wondow handle sehr gut. Ich möchte das auch so umsetzten allerdings scheitere ich daran nur den Rahmen grün oder rot werden zu lassen. Den ganzen Hintergrund schaffe ich, das sieht aber nicht gut aus 🙂
                                          Könntest du mir bitte sagen wie das geht ?? Die Beschriftung zu den Icons ist ein eigenes Widget oder ? die finde ich nämlich auch nicht.

                                          Danke für deine Arbeit schon einmal

                                          1 Reply Last reply Reply Quote 0
                                          • Z
                                            zokkai last edited by

                                            Hallo, meine Umsetzung sieht wie folgt aus:

                                            Bild_Vis-iobroker.jpg

                                            Für die wechselnde Rahmenfarbe habe ich umständlicher Weise zwei Widgets übereinandergelegt und über die Sichtbarkeit gesteuert.
                                            Es geht wohl auch über Bindings, aber das schien mir auf den ersten Blick zu kompliziert.
                                            Evtl. hat es ja einer damit realisiert??

                                            Gruss

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            834
                                            Online

                                            31.9k
                                            Users

                                            80.2k
                                            Topics

                                            1.3m
                                            Posts

                                            31
                                            117
                                            29132
                                            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