Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [gelöst] Elegantere Programmierung?

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [gelöst] Elegantere Programmierung?

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      skorpil @paul53 last edited by

      @paul53 ich verzweifele wieder an mir selber, weil ich nicht weiss, wie!

      on({id: idThermBarKellerFeucht, change: 'ne'}, function (data) {
          if(data.state.val > 65 && !getState(heizStatusBar).val && getState(idThermBarKellerTemp).val < 17 && !getState(idSommer).val) {
      

      Dieses Script reagiert ja auf jede not equal Änderung der
      id: idThermBarKellerFeucht, change: 'ne'.

      Das soll es aber nicht, denn dann wird (siehe oben) jedesmal die else Anweisung ausgeführt. Die On Anweisung soll nur ausgeführt werden, wenn idThermBarKellerFeucht größer ist als 65. Wie muß die dazugehörige ON Anweisung aussehen?

      Sorry für die doofe Frage. Ich habe mir schon eine Programmbibliotek mit Java Schnipseln angelegt, aber da sind immer nur On Anweisungen mit val: true (or false), also bollean, drinnen. Es fehlt mir die ON Anweisung zur Reaktion auf Wertänderungen (number).

      paul53 2 Replies Last reply Reply Quote 0
      • paul53
        paul53 @skorpil last edited by paul53

        @skorpil sagte: Die On Anweisung soll nur ausgeführt werden, wenn idThermBarKellerFeucht größer ist als 65.

        Siehe Doku:

        on({id: idThermBarKellerFeucht,  valGt: 65, oldValLe: 65}, function (data) {
        

        EDIT: Wie soll so wieder auf den CEN-Modus zurück gesetzt werden?

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

          @skorpil sagte: jedesmal die else Anweisung ausgeführt.

          Damit nur in den CEN-Modus geschaltet wird, wenn die Feuchtigkeit wieder unter 65 % sinkt, mache es besser so:

          on(idThermBarKellerFeucht, function (data) {
              if(!getState(idSommer).val) {
                  if(data.state.val > 65) {
                      // mit 2 auf CEN setzen, mit 1 auf AUTO 
                      if(data.oldState.val <= 65 && getState(idThermBarKellerTemp).val < 17 && !getState(heizStatusBar).val) {
                          sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 1}}, res => {
                              log(JSON.stringify(res));
                          });
                      }
                  } else if(data.oldState.val > 65) {
                      // mit 2 auf CEN setzen, mit 1 auf AUTO 
                      sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 2}}, res => {
                          log(JSON.stringify(res));
                      });
                      setStateDelayed(idThermBarKellerSetpoint, 15, 12000); 
                  }
              }
          });
          

          Wie wird "heizStatusBar" gebildet?

          S 2 Replies Last reply Reply Quote 1
          • S
            skorpil @paul53 last edited by

            @paul53 sagte in [gelöst] Elegantere Programmierung?:

                                                                                                                                        on(idThermBarKellerFeucht, function (data) {                                                                                                                                                                                if(!getState(idSommer).val) {                                                                                                                                                                                    if(data.state.val > 65) {                                                                                                                                                                                        // mit 2 auf CEN setzen, mit 1 auf AUTO                                                                                                                                                                                         if(data.oldState.val <= 65 && getState(idThermBarKellerTemp).val < 17 && !getState(heizStatusBar).val) {                                                                                                                                                                                            sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 1}}, res => {                                                                                                                                                                                                log(JSON.stringify(res));                                                                                                                                                                                            });                                                                                                                                                                                        }                                                                                                                                                                                    } else if(data.oldState.val > 65) {                                                                                                                                                                                        // mit 2 auf CEN setzen, mit 1 auf AUTO                                                                                                                                                                                         sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 2}}, res => {                                                                                                                                                                                            log(JSON.stringify(res));                                                                                                                                                                                        });                                                                                                                                                                                        setStateDelayed(idThermBarKellerSetpoint, 15, 12000);                                                                                                                                                                                     }                                                                                                                                                                                }                                                                                                                                                                            });                                            
            

            heizStatusBar ist eine SV und kommt aus der homematic mit den Zuständen Aus(0) und Ein(1)

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

              @paul53 sagte in [gelöst] Elegantere Programmierung?:

                                                                                                                                          on(idThermBarKellerFeucht, function (data) {                                                                                                                                                                                if(!getState(idSommer).val) {                                                                                                                                                                                    if(data.state.val > 65) {                                                                                                                                                                                        // mit 2 auf CEN setzen, mit 1 auf AUTO                                                                                                                     if(data.oldState.val <= 65 && getState(idThermBarKellerTemp).val < 17 && !getState(heizStatusBar).val) {                                                                                                                        sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 1}}, res => {                                                                                                                            log(JSON.stringify(res));                                                                                                                        });                                                                                                                    }                                                                                                                } else if(data.oldState.val > 65) {                                                                                                                    // mit 2 auf CEN setzen, mit 1 auf AUTO                                                                                                                     sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 2}}, res => {                                                                                                                        log(JSON.stringify(res));                                                                                                                    });                                                                                                                    setStateDelayed(idThermBarKellerSetpoint, 15, 12000);                                                                                                                 }                                                                                                            }                                                                                                        });                        
              

              noch eine Frage: WARUM so? Was ist da besser?

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

                @skorpil sagte: WARUM so? Was ist da besser?

                Wenn nur beim Überschreiten des Feuchtegrenzwertes getriggert wird, wird nie in den CEN-Modus zurück geschaltet, wenn die Feuchte zurück geht.
                Im Sommer soll der Modus sicherlich nicht verändert werden?

                @skorpil sagte: SV und kommt aus der homematic mit den Zuständen Aus(0) und Ein(1)

                Wann schaltet sie auf Ein?

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

                  @paul53 sie wird manuell geschaltet. Meist ist sie aus. Aber, wenn ich die Bar heizen will, schalte ich sie ein.

                  Zum besseren Verständnis hier mal Bilder des homematic Programms, dass ich nun in javascript abbilden möchte:

                  Programm.jpg

                  P1.jpg

                  P2.jpg

                  Einfach ist das ja alles nicht. Danke für Deine unermüdliche Hilfe.

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

                    @skorpil
                    Das HM-Programm triggert, wenn die Schwelle überschritten (Dann...) und wenn sie unterschritten (Sonst) wird.

                    Besser wäre eine Hysterese.

                    S 2 Replies Last reply Reply Quote 0
                    • S
                      skorpil @paul53 last edited by

                      @paul53 mit Deinem letzten JavaScript Programm ist ja alles super! Das passt.

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

                        @paul53 ich habe Dich hier nicht richtig verstanden.

                        Die Bilder der Programme aus der Homematic sollten nur demonstrieren, was ich nun in Java Skript programmieren möchte.

                        Du schreibst von der Hysterese, die Du für besser hältst. Haben wir die jetzt in Deinem letztenJava Skript so abgebildet, wie du es für richtig hältst?

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

                          @skorpil sagte: Haben wir die jetzt in Deinem letztenJava Skript so abgebildet, wie du es für richtig hältst?

                          Nein, das hat keine Hysterese.

                          EDIT: Mit 5 % Hysterese:

                          on(idThermBarKellerFeucht, function (data) {
                              if(!getState(idSommer).val) {
                                  if(data.state.val > 65 && data.oldState.val <= 65) {
                                      // mit 2 auf CEN setzen, mit 1 auf AUTO 
                                      if(getState(idThermBarKellerTemp).val < 17 && !getState(heizStatusBar).val) {
                                          sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 1}}, res => {
                                              log(JSON.stringify(res));
                                          });
                                      }
                                  } else if(data.state.val <= 60 && data.oldState.val > 60) { // 5 % Hysterese
                                      // mit 2 auf CEN setzen, mit 1 auf AUTO 
                                      sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': 2}}, res => {
                                          log(JSON.stringify(res));
                                      });
                                      setStateDelayed(idThermBarKellerSetpoint, 15, 12000); 
                                  }
                              }
                          });
                          

                          Besser wäre ein eigener Hilfsdatenpunkt, der bei Wertänderung den Modus an den MASTER-Parameter sendet und in dem man den zuletzt gesendeten Modus sieht. Das könnte so aussehen:

                          // ###########################################
                          //            Deklarationen
                          // ###########################################
                          const heizStatusBar = 'hm-rega.0.23436'/*Heizstatus (BAR)*/;
                          const idThermBarKellerTemp ='hm-rpc.0.JEQ0553882.1.TEMPERATURE'/*Thermostat Bar Keller 0 TEMPERATURE*/;
                          const idThermBarKellerSetpoint = 'hm-rpc.0.JEQ0553882.2.SETPOINT'/*Thermostat Bar Keller 1 SETPOINT*/
                          const idThermBarKellerFeucht = 'hm-rpc.0.JEQ0553882.1.HUMIDITY'/*Thermostat Bar Keller 0 HUMIDITY*/;
                          const idSommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
                          const idModus = '0_userdata.0.Keller.Bar.Thermostat.Modus';
                           
                           
                          // ###########################################
                          //                  Programm
                          // ###########################################
                          var mode = getState(idModus).val; // Modus bei Skriptstart
                          
                          on(idThermBarKellerFeucht, function (data) {
                              if(!getState(idSommer).val) {
                                  if(data.state.val > 65 && getState(idThermBarKellerTemp).val < 17 && !getState(heizStatusBar).val) {
                                      mode = 1; // AUTO
                                  } else if(data.state.val <= 60) { // 5 % Hysterese
                                      mode = 2; // CEN
                                  }
                                  setState(idModus, mode, true);
                              }
                          });
                          
                          on(idModus, function(dp) {
                              sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': dp.state.val}}, res => {
                                  log(res);
                              });
                              if(dp.state.val == 2) setStateDelayed(idThermBarKellerSetpoint, 15, 12000);
                          });
                          
                          S 3 Replies Last reply Reply Quote 1
                          • S
                            skorpil @paul53 last edited by

                            @paul53 gerade erst gesehen. Wahnsinn! Daaaaaanke. Ich schaue mir das morgen in Ruhe an.

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

                              @paul53 sagte in [gelöst] Elegantere Programmierung?:

                              Besser wäre ein eigener Hilfsdatenpunkt, der bei Wertänderung den Modus an den MASTER-Parameter sendet und in dem man den zuletzt gesendeten Modus sieht. Das könnte so aussehen:

                              So, bin wieder da und habe diese Variante übernommen. Frage nur: warum ist das besser?

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

                                @skorpil sagte: warum ist das besser?

                                Man hat einen Datenpunkt, der den Modus anzeigt und über den man den Modus bei Bedarf auch mal manuell (innerhalb der Hysterese) ändern kann.

                                1 Reply Last reply Reply Quote 1
                                • S
                                  skorpil @paul53 last edited by

                                  @paul53 ich kriege für diese Zeile

                                  
                                  setState(idModus, mode, true);
                                  
                                  

                                  eine Fehlermeldung:

                                  
                                  You are assigning a number to the state "javascript.0.BenutzerVariablen.idModus" which expects a boolean. Please fix your code to use a boolean or change the state type to number. This warning might become an error in future versions.
                                  
                                  
                                  paul53 1 Reply Last reply Reply Quote 0
                                  • paul53
                                    paul53 @skorpil last edited by paul53

                                    @skorpil sagte: which expects a boolean

                                    Ändere den Datenpunkt-Typ von "javascript.0.BenutzerVariablen.idModus" in "number", denn er enthält die Werte 1 oder 2. Erweitere die Objekteigenschaften um common.states:

                                    {
                                        "1": "AUTO",
                                        "2": "CEN"
                                    }
                                    
                                    S 1 Reply Last reply Reply Quote 1
                                    • S
                                      skorpil @paul53 last edited by

                                      @paul53 sagte in [gelöst] Elegantere Programmierung?:

                                      Erweitere die Objekteigenschaften um common.states:

                                      das Script sieht jetzt so aus. Ich mußte mit createState den Datenpunkt anlegen. Sonst ging es nicht. Er steht auf "number". Die genannte Fehlermeldung kommt dennoch.

                                      // ###########################################
                                      //            Deklarationen
                                      // ###########################################
                                      const heizStatusBar = 'hm-rega.0.23436'/*Heizstatus (BAR)*/;
                                      const idThermBarKellerTemp ='hm-rpc.0.JEQ0553882.1.TEMPERATURE'/*Thermostat Bar Keller 0 TEMPERATURE*/;
                                      const idThermBarKellerSetpoint = 'hm-rpc.0.JEQ0553882.2.SETPOINT'/*Thermostat Bar Keller 1 SETPOINT*/
                                      const idThermBarKellerFeucht = 'hm-rpc.0.JEQ0553882.1.HUMIDITY'/*Thermostat Bar Keller 0 HUMIDITY*/;
                                      const idSommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
                                      
                                      // Datenpunkt erstellen (für andere Scripte);
                                      createState('javascript.0.BenutzerVariablen.FeuchtigkeitsschutzKellerBar', '', {
                                          name: 'idFeuchtigkeitBarModus',
                                          type: 'number'
                                      });
                                      const idFeuchtigkeitBarModus = 'javascript.0.BenutzerVariablen.FeuchtigkeitsschutzKellerBar'/**/;
                                      
                                       
                                      // ###########################################
                                      //                  Programm
                                      // ###########################################
                                      var mode = getState(idFeuchtigkeitBarModus).val; // Modus bei Skriptstart
                                      
                                      on(idThermBarKellerFeucht, function (data) {
                                          if(!getState(idSommer).val) {
                                              if(data.state.val > 65 && getState(idThermBarKellerTemp).val < 17 && !getState(heizStatusBar).val) {
                                                  mode = 1; // AUTO
                                              } else if(data.state.val <= 60) { // 5 % Hysterese
                                                  mode = 2; // CEN
                                              }
                                              setState(idFeuchtigkeitBarModus, mode, true);
                                          }
                                      });
                                       
                                      on(idFeuchtigkeitBarModus, function(dp) {
                                          sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': dp.state.val}}, res => {
                                              log(res);
                                          });
                                          if(dp.state.val == 2) setStateDelayed(idThermBarKellerSetpoint, 15, 12000);
                                      });
                                      

                                      Mir ist aber auch nicht klar, WO ich "Erweitere die Objekteigenschaften um common.states:" durchführen muß. Danke für Hilfe

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

                                        @skorpil sagte: Die genannte Fehlermeldung kommt dennoch.

                                        Die bezieht sich auf einen anderen Datenpunkt als im gezeigten Skript.

                                        You are assigning a number to the state "javascript.0.BenutzerVariablen.idModus" which expects a boolean.
                                        

                                        @skorpil sagte in [gelöst] Elegantere Programmierung?:

                                        WO ich "Erweitere die Objekteigenschaften um common.states:" durchführen muß.

                                        Unter "OBJEKTDATEN":

                                          "type": "state",
                                          "common": {
                                            "name": "Kellerbar Modus",
                                            "role": "level.mode",
                                            "type": "number",
                                            "states": {
                                              "1": "AUTO",
                                              "2": "CEN"
                                            },
                                            "min": 1,
                                            "max": 2,
                                            "def": 1,
                                            "read": true,
                                            "write": true
                                          },
                                        
                                        S 1 Reply Last reply Reply Quote 0
                                        • S
                                          skorpil @paul53 last edited by skorpil

                                          @paul53 so das habe ich jetzt gefunden 😉 und wiefolgt geändert:

                                          {
                                            "common": {
                                              "name": "idFeuchtigkeitBarModus",
                                              "role": "level.mode",
                                              "type": "number",
                                              "states": {
                                                "1": "AUTO",
                                                "2": "CEN"
                                              },
                                              "min": 1,
                                              "max": 2,
                                              "def": 1,
                                              "read": true,
                                              "write": true
                                            },
                                            "native": {
                                              "name": "idFeuchtigkeitBarModus",
                                              "type": "number",
                                              "role": "level.mode"
                                            },
                                            "type": "state",
                                            "_id": "javascript.0.BenutzerVariablen.FeuchtigkeitsschutzKellerBar",
                                            "acl": {
                                              "object": 1636,
                                              "state": 1636,
                                              "owner": "system.user.admin",
                                              "ownerGroup": "system.group.administrator"
                                            },
                                            "from": "system.adapter.admin.0",
                                            "user": "system.user.admin",
                                            "ts": 1678544548349
                                          }
                                          

                                          Zur Sicherheit hier noch einmal das zugehörige Script:

                                          // ###########################################
                                          //            Deklarationen
                                          // ###########################################
                                          const heizStatusBar = 'hm-rega.0.23436'/*Heizstatus (BAR)*/;
                                          const idThermBarKellerTemp ='hm-rpc.0.JEQ0553882.1.TEMPERATURE'/*Thermostat Bar Keller 0 TEMPERATURE*/;
                                          const idThermBarKellerSetpoint = 'hm-rpc.0.JEQ0553882.2.SETPOINT'/*Thermostat Bar Keller 1 SETPOINT*/
                                          const idThermBarKellerFeucht = 'hm-rpc.0.JEQ0553882.1.HUMIDITY'/*Thermostat Bar Keller 0 HUMIDITY*/;
                                          const idSommer = 'hm-rega.0.11457'/*SOMMER Hzg  Wohnb  ALLES (Var )*/;
                                          
                                          // Datenpunkt erstellen (für andere Scripte);
                                          createState('javascript.0.BenutzerVariablen.FeuchtigkeitsschutzKellerBar', '', {
                                              name: 'idFeuchtigkeitBarModus',
                                              type: 'number'
                                          });
                                          const idFeuchtigkeitBarModus = 'javascript.0.BenutzerVariablen.FeuchtigkeitsschutzKellerBar'/**/;
                                          
                                           
                                          // ###########################################
                                          //                  Programm
                                          // ###########################################
                                          var mode = getState(idFeuchtigkeitBarModus).val; // Modus bei Skriptstart
                                          
                                          on(idThermBarKellerFeucht, function (data) {
                                              if(!getState(idSommer).val) {
                                                  if(data.state.val > 65 && getState(idThermBarKellerTemp).val < 17 && !getState(heizStatusBar).val) {
                                                      mode = 1; // AUTO
                                                  } else if(data.state.val <= 60) { // 5 % Hysterese
                                                      mode = 2; // CEN
                                                  }
                                                  setState(idFeuchtigkeitBarModus, mode, true);
                                              }
                                          });
                                           
                                          on(idFeuchtigkeitBarModus, function(dp) {
                                              sendTo('hm-rpc.0', 'putParamset', {ID: 'JEQ0553882:2', paramType: 'MASTER', params: {'MODE_TEMPERATUR_REGULATOR': dp.state.val}}, res => {
                                                  log(res);
                                              });
                                              if(dp.state.val == 2) setStateDelayed(idThermBarKellerSetpoint, 15, 12000);
                                          });
                                          

                                          und da ich noch ein Geräte im Einsatz habe in einem anderen Zimmer:

                                          {
                                            "common": {
                                              "name": "idFeuchtigkeitJoergModus",
                                              "type": "number",
                                              "role": "level.mode",
                                              "states": {
                                                "1": "AUTO",
                                                "2": "CEN"
                                              },
                                              "min": 1,
                                              "max": 2,
                                              "def": 1,
                                              "read": true,
                                              "write": true
                                            },
                                            "native": {
                                              "name": "idFeuchtigkeitJoergModus",
                                              "type": "number",
                                              "role": "level.mode"
                                            },
                                            "type": "state",
                                            "_id": "javascript.0.BenutzerVariablen.FeuchtigkeitsschutzJoergKeller",
                                            "acl": {
                                              "object": 1636,
                                              "state": 1636,
                                              "owner": "system.user.admin",
                                              "ownerGroup": "system.group.administrator"
                                            },
                                            "from": "system.adapter.admin.0",
                                            "user": "system.user.admin",
                                            "ts": 1678544841925
                                          }
                                          

                                          Ist das dann so in Ordnung? Denn mit den OBJEKTDATEN jabe ich mich bislang noch nie befasst!

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

                                            @skorpil sagte: Ist das dann so in Ordnung?

                                            Ja, allerdings würde ich keine Namen verwenden, die mit "id" beginnen.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            697
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            10
                                            325
                                            37174
                                            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