Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Object.<anonymous> finden?

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.3k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.3k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.6k

Object.<anonymous> finden?

Scheduled Pinned Locked Moved Skripten / Logik
51 Posts 5 Posters 3.8k Views 3 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • SMSS Offline
    SMSS Offline
    SMS
    wrote on last edited by
    #1

    Hallo,

    wie finde ich folgenden Fehler:

    javascript.0	08:58:53.560	warn	at Object.<anonymous> (script.js.Küche.Siemens_Spülmaschine:64:3)
    

    Ich hätte jetzt gedacht das in Zeile 64 ein Fehler ist, aber in Zeile 64 finde ich nichts:

    on({ id: [].concat(['0_userdata.0.Küche.Siemens_Spülmaschine_Auto_ein_bei']), change: 'ne' }, async (obj) => {
      let value = obj.state.val;
      let oldValue = obj.oldState.val;
      if ((obj.state ? obj.state.val : '') == 1) {
        Auto_Ein_bei = 1500;
      } else if ((obj.state ? obj.state.val : '') == 2) {
        Auto_Ein_bei = 2000;
      } else if ((obj.state ? obj.state.val : '') == 3) {
        Auto_Ein_bei = 3000;
      } else if ((obj.state ? obj.state.val : '') == 4) {
        Auto_Ein_bei = 4000;
      } else if ((obj.state ? obj.state.val : '') == 0) {
        Auto_Ein_bei = false;
      }
      setState('0_userdata.0.Küche.Auto_ein_bei' /* Auto ein bei */, Auto_Ein_bei, true);
    });
    on({ id: [].concat(['0_userdata.0.Küche.Spülmaschine_Ein/Aus']), change: 'ne' }, async (obj) => {
      let value = obj.state.val;
      let oldValue = obj.oldState.val;
      Uhrzeit = false;
      setState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto' /* Siemens Spülmaschine Auto */, false, true);
      Hand = false;
    

    6211fd64-529d-4554-bc73-be73cdc93ab2-grafik.png
    95568111-10ae-4abe-a4df-9679561c9d59-grafik.png

    Danke!

    haus-automatisierungH CodierknechtC 2 Replies Last reply
    0
    • SMSS SMS

      Hallo,

      wie finde ich folgenden Fehler:

      javascript.0	08:58:53.560	warn	at Object.<anonymous> (script.js.Küche.Siemens_Spülmaschine:64:3)
      

      Ich hätte jetzt gedacht das in Zeile 64 ein Fehler ist, aber in Zeile 64 finde ich nichts:

      on({ id: [].concat(['0_userdata.0.Küche.Siemens_Spülmaschine_Auto_ein_bei']), change: 'ne' }, async (obj) => {
        let value = obj.state.val;
        let oldValue = obj.oldState.val;
        if ((obj.state ? obj.state.val : '') == 1) {
          Auto_Ein_bei = 1500;
        } else if ((obj.state ? obj.state.val : '') == 2) {
          Auto_Ein_bei = 2000;
        } else if ((obj.state ? obj.state.val : '') == 3) {
          Auto_Ein_bei = 3000;
        } else if ((obj.state ? obj.state.val : '') == 4) {
          Auto_Ein_bei = 4000;
        } else if ((obj.state ? obj.state.val : '') == 0) {
          Auto_Ein_bei = false;
        }
        setState('0_userdata.0.Küche.Auto_ein_bei' /* Auto ein bei */, Auto_Ein_bei, true);
      });
      on({ id: [].concat(['0_userdata.0.Küche.Spülmaschine_Ein/Aus']), change: 'ne' }, async (obj) => {
        let value = obj.state.val;
        let oldValue = obj.oldState.val;
        Uhrzeit = false;
        setState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto' /* Siemens Spülmaschine Auto */, false, true);
        Hand = false;
      

      6211fd64-529d-4554-bc73-be73cdc93ab2-grafik.png
      95568111-10ae-4abe-a4df-9679561c9d59-grafik.png

      Danke!

      haus-automatisierungH Online
      haus-automatisierungH Online
      haus-automatisierung
      Developer Most Active
      wrote on last edited by
      #2

      @sms sagte in Object.<anonymous> finden?:

      aber in Zeile 64 finde ich nichts:

      Um die Scripts wird vom Adapter noch etwas Code gepackt, bevor dieser ausgeführt wird. Daher stimmen die Zeilennummern im Callstack nicht.

      Wie genau lautet denn die Fehlermeldung bzw. wie sieht der gesamte Stack des Fehlers aus?

      🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
      🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
      📚 Meine inoffizielle ioBroker Dokumentation

      SMSS 1 Reply Last reply
      0
      • SMSS SMS

        Hallo,

        wie finde ich folgenden Fehler:

        javascript.0	08:58:53.560	warn	at Object.<anonymous> (script.js.Küche.Siemens_Spülmaschine:64:3)
        

        Ich hätte jetzt gedacht das in Zeile 64 ein Fehler ist, aber in Zeile 64 finde ich nichts:

        on({ id: [].concat(['0_userdata.0.Küche.Siemens_Spülmaschine_Auto_ein_bei']), change: 'ne' }, async (obj) => {
          let value = obj.state.val;
          let oldValue = obj.oldState.val;
          if ((obj.state ? obj.state.val : '') == 1) {
            Auto_Ein_bei = 1500;
          } else if ((obj.state ? obj.state.val : '') == 2) {
            Auto_Ein_bei = 2000;
          } else if ((obj.state ? obj.state.val : '') == 3) {
            Auto_Ein_bei = 3000;
          } else if ((obj.state ? obj.state.val : '') == 4) {
            Auto_Ein_bei = 4000;
          } else if ((obj.state ? obj.state.val : '') == 0) {
            Auto_Ein_bei = false;
          }
          setState('0_userdata.0.Küche.Auto_ein_bei' /* Auto ein bei */, Auto_Ein_bei, true);
        });
        on({ id: [].concat(['0_userdata.0.Küche.Spülmaschine_Ein/Aus']), change: 'ne' }, async (obj) => {
          let value = obj.state.val;
          let oldValue = obj.oldState.val;
          Uhrzeit = false;
          setState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto' /* Siemens Spülmaschine Auto */, false, true);
          Hand = false;
        

        6211fd64-529d-4554-bc73-be73cdc93ab2-grafik.png
        95568111-10ae-4abe-a4df-9679561c9d59-grafik.png

        Danke!

        CodierknechtC Offline
        CodierknechtC Offline
        Codierknecht
        Developer Most Active
        wrote on last edited by Codierknecht
        #3

        @sms
        Javascript ist untypisiert. Das heißt: Der Typ einer Variablen ergibt sich aus seiner Verwendung.
        Du mixt hier aber Number (Zahlenwerte) mit Boolean (wahr/falsch).
        b01cf3a3-96de-4f3a-b57d-c631a85b75d8-image.png
        Letztlich schreibst Du damit im Fall der Fälle auch den falschen Typ in den Datenpunkt, denn der wird ja auch entweder Boolean oder Number sein.

        Statt "Falsch" sollte bei 'ner 0 also etwas anderes in den DP geschrieben werden. z.B. eine 0 oder -1.
        Das ganze soll wohl dazu dienen, dass die Spülmaschine nicht automatisch (per Timer) gestartet wird, oder?

        Apropos Spülmachine: Früher oder später (meist früher) wird sich die Verwendung von Umlauten (und anderer Sonderzeichen) in Variablen und ID's rächen.

        Außerdem gibt es für die Prüfung auf verschiedene Werte effizientere Möglichkeiten:
        17d4e5ec-5d27-44b0-acb5-d994d573a304-image.png

        "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

        Proxmox 9.1.1 LXC|8 GB|Core i7-6700
        HmIP|ZigBee|Tasmota|Unifi
        Zabbix Certified Specialist
        Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

        SMSS 1 Reply Last reply
        0
        • haus-automatisierungH haus-automatisierung

          @sms sagte in Object.<anonymous> finden?:

          aber in Zeile 64 finde ich nichts:

          Um die Scripts wird vom Adapter noch etwas Code gepackt, bevor dieser ausgeführt wird. Daher stimmen die Zeilennummern im Callstack nicht.

          Wie genau lautet denn die Fehlermeldung bzw. wie sieht der gesamte Stack des Fehlers aus?

          SMSS Offline
          SMSS Offline
          SMS
          wrote on last edited by
          #4

          @haus-automatisierung meinst du das:

          javascript.0	09:00:34.141	info	Stopping script script.js.Küche.Siemens_Spülmaschine
          javascript.0	09:01:09.265	info	Start JavaScript script.js.Küche.Siemens_Spülmaschine (Blockly)
          javascript.0	09:01:09.300	info	script.js.Küche.Siemens_Spülmaschine: registered 13 subscriptions, 2 schedules, 0 messages, 0 logs and 0 file subscriptions
          homeconnect.0	09:10:21.528	silly	States user redis pmessage homeconnect.0.*/homeconnect.0.013060393307000289.programs.active.BSH_Common_Root_ActiveProgram:{"val":"Dishcare.Dishwasher.Program.Eco50","ack":false,"ts":1745392221521,"q":0,"c":"script.js.Küche.Siemens_Spülmaschine","from":"system.adapter.javascript.0","user":"system.user.admin","lc":1745391503639}
          homeconnect.0	09:10:21.531	silly	States user redis pmessage homeconnect.0.*/homeconnect.0.013060393307000289.settings.BSH_Common_Setting_PowerState:{"val":"BSH.Common.EnumType.OperationState.On","ack":false,"ts":1745392221521,"q":0,"c":"script.js.Küche.Siemens_Spülmaschine","from":"system.adapter.javascript.0","user":"system.user.admin","lc":1745392221521}
          javascript.0	09:10:51.521	warn	at Object.<anonymous> (script.js.Küche.Siemens_Spülmaschine:64:3)
          
          CodierknechtC 1 Reply Last reply
          0
          • SMSS SMS

            @haus-automatisierung meinst du das:

            javascript.0	09:00:34.141	info	Stopping script script.js.Küche.Siemens_Spülmaschine
            javascript.0	09:01:09.265	info	Start JavaScript script.js.Küche.Siemens_Spülmaschine (Blockly)
            javascript.0	09:01:09.300	info	script.js.Küche.Siemens_Spülmaschine: registered 13 subscriptions, 2 schedules, 0 messages, 0 logs and 0 file subscriptions
            homeconnect.0	09:10:21.528	silly	States user redis pmessage homeconnect.0.*/homeconnect.0.013060393307000289.programs.active.BSH_Common_Root_ActiveProgram:{"val":"Dishcare.Dishwasher.Program.Eco50","ack":false,"ts":1745392221521,"q":0,"c":"script.js.Küche.Siemens_Spülmaschine","from":"system.adapter.javascript.0","user":"system.user.admin","lc":1745391503639}
            homeconnect.0	09:10:21.531	silly	States user redis pmessage homeconnect.0.*/homeconnect.0.013060393307000289.settings.BSH_Common_Setting_PowerState:{"val":"BSH.Common.EnumType.OperationState.On","ack":false,"ts":1745392221521,"q":0,"c":"script.js.Küche.Siemens_Spülmaschine","from":"system.adapter.javascript.0","user":"system.user.admin","lc":1745392221521}
            javascript.0	09:10:51.521	warn	at Object.<anonymous> (script.js.Küche.Siemens_Spülmaschine:64:3)
            
            CodierknechtC Offline
            CodierknechtC Offline
            Codierknecht
            Developer Most Active
            wrote on last edited by
            #5

            @sms
            Ist es gewollt, dass Du Dir mit der Logstufe silly für den Homeconnect das Log vollballerst?

            Wenn das nur übergangsweise zu Debug-Zwecken so ist, habe ich nix gesagt ;-)

            "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

            Proxmox 9.1.1 LXC|8 GB|Core i7-6700
            HmIP|ZigBee|Tasmota|Unifi
            Zabbix Certified Specialist
            Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

            SMSS 1 Reply Last reply
            0
            • CodierknechtC Codierknecht

              @sms
              Javascript ist untypisiert. Das heißt: Der Typ einer Variablen ergibt sich aus seiner Verwendung.
              Du mixt hier aber Number (Zahlenwerte) mit Boolean (wahr/falsch).
              b01cf3a3-96de-4f3a-b57d-c631a85b75d8-image.png
              Letztlich schreibst Du damit im Fall der Fälle auch den falschen Typ in den Datenpunkt, denn der wird ja auch entweder Boolean oder Number sein.

              Statt "Falsch" sollte bei 'ner 0 also etwas anderes in den DP geschrieben werden. z.B. eine 0 oder -1.
              Das ganze soll wohl dazu dienen, dass die Spülmaschine nicht automatisch (per Timer) gestartet wird, oder?

              Apropos Spülmachine: Früher oder später (meist früher) wird sich die Verwendung von Umlauten (und anderer Sonderzeichen) in Variablen und ID's rächen.

              Außerdem gibt es für die Prüfung auf verschiedene Werte effizientere Möglichkeiten:
              17d4e5ec-5d27-44b0-acb5-d994d573a304-image.png

              SMSS Offline
              SMSS Offline
              SMS
              wrote on last edited by
              #6

              @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.
              d1973a45-4b87-40c3-a5ff-9dade0057612-grafik.png

              Die Spülmaschine soll angehen, je nachdem welchen Wert ich einstelle und meine PV-Produktion diesen Wert überschreitet.
              Das Ganze sieht so aus:
              f5abb26f-80ad-4dc2-9acf-4ffdd54a3535-grafik.png

              0 bedeutet = AUS

              Die Umlaute werde ich nach und nach elemenieren.

              1 Reply Last reply
              0
              • CodierknechtC Codierknecht

                @sms
                Ist es gewollt, dass Du Dir mit der Logstufe silly für den Homeconnect das Log vollballerst?

                Wenn das nur übergangsweise zu Debug-Zwecken so ist, habe ich nix gesagt ;-)

                SMSS Offline
                SMSS Offline
                SMS
                wrote on last edited by
                #7

                @codierknecht Da ich davon keine Ahnung habe, ... , nein es ist nicht gewollt. Wo ändere ich das?

                CodierknechtC 1 Reply Last reply
                0
                • SMSS SMS

                  @codierknecht Da ich davon keine Ahnung habe, ... , nein es ist nicht gewollt. Wo ändere ich das?

                  CodierknechtC Offline
                  CodierknechtC Offline
                  Codierknecht
                  Developer Most Active
                  wrote on last edited by
                  #8

                  @sms sagte in Object.<anonymous> finden?:

                  Wo ändere ich das?

                  In den Instanzeinstellungen (Expertenmodus)

                  fd257b3b-28e6-462c-b7c6-98e96f511415-image.png

                  "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                  Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                  HmIP|ZigBee|Tasmota|Unifi
                  Zabbix Certified Specialist
                  Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                  SMSS 1 Reply Last reply
                  0
                  • CodierknechtC Codierknecht

                    @sms sagte in Object.<anonymous> finden?:

                    Wo ändere ich das?

                    In den Instanzeinstellungen (Expertenmodus)

                    fd257b3b-28e6-462c-b7c6-98e96f511415-image.png

                    SMSS Offline
                    SMSS Offline
                    SMS
                    wrote on last edited by
                    #9

                    @codierknecht was bedeutet debug?

                    CodierknechtC 1 Reply Last reply
                    0
                    • SMSS SMS

                      @codierknecht was bedeutet debug?

                      CodierknechtC Offline
                      CodierknechtC Offline
                      Codierknecht
                      Developer Most Active
                      wrote on last edited by Codierknecht
                      #10

                      @sms sagte in Object.<anonymous> finden?:

                      was bedeutet debug?

                      Das ist nur ein Beispiel aus meinem Testsystem. Auch damit werden jede Menge Infos ins Log geschrieben, die im stabilen Betrieb nicht wirklich nötig sind.

                      Üblich ist die Einstellung "Info". Wäre hier erstmal meine Empfehlung.

                      Ich gehe noch einen Schritt weiter und stelle die Adapter, die wirklich stabil ihren Dienst verrichten, aber zu viel Zeug ins Log schreiben, auf "Warning".
                      Und wer dann noch zu viel unnützes Zeug plappert, bekommt "Error" und darf damit nur noch bei Fehlern etwas ins Log schreiben. So ist das am Ende des Tages nur noch < 100 kB groß.

                      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                      HmIP|ZigBee|Tasmota|Unifi
                      Zabbix Certified Specialist
                      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                      SMSS 1 Reply Last reply
                      0
                      • CodierknechtC Codierknecht

                        @sms sagte in Object.<anonymous> finden?:

                        was bedeutet debug?

                        Das ist nur ein Beispiel aus meinem Testsystem. Auch damit werden jede Menge Infos ins Log geschrieben, die im stabilen Betrieb nicht wirklich nötig sind.

                        Üblich ist die Einstellung "Info". Wäre hier erstmal meine Empfehlung.

                        Ich gehe noch einen Schritt weiter und stelle die Adapter, die wirklich stabil ihren Dienst verrichten, aber zu viel Zeug ins Log schreiben, auf "Warning".
                        Und wer dann noch zu viel unnützes Zeug plappert, bekommt "Error" und darf damit nur noch bei Fehlern etwas ins Log schreiben. So ist das am Ende des Tages nur noch < 100 kB groß.

                        SMSS Offline
                        SMSS Offline
                        SMS
                        wrote on last edited by SMS
                        #11

                        @codierknecht OK, danke!

                        Das eigentliche Problem liegt jetzt aber hier?

                        @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.
                        d1973a45-4b87-40c3-a5ff-9dade0057612-grafik.png

                        Die Spülmaschine soll angehen, je nachdem welchen Wert ich einstelle und meine PV-Produktion diesen Wert überschreitet.
                        Das Ganze sieht so aus:
                        f5abb26f-80ad-4dc2-9acf-4ffdd54a3535-grafik.png

                        0 bedeutet = AUS

                        haus-automatisierungH 1 Reply Last reply
                        0
                        • SMSS SMS

                          @codierknecht OK, danke!

                          Das eigentliche Problem liegt jetzt aber hier?

                          @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.
                          d1973a45-4b87-40c3-a5ff-9dade0057612-grafik.png

                          Die Spülmaschine soll angehen, je nachdem welchen Wert ich einstelle und meine PV-Produktion diesen Wert überschreitet.
                          Das Ganze sieht so aus:
                          f5abb26f-80ad-4dc2-9acf-4ffdd54a3535-grafik.png

                          0 bedeutet = AUS

                          haus-automatisierungH Online
                          haus-automatisierungH Online
                          haus-automatisierung
                          Developer Most Active
                          wrote on last edited by haus-automatisierung
                          #12

                          Kannst Du mal bitte das komplette Script zeigen? Da fehlt ja definitiv noch Code. Im Screenshot erkennt man ja einen weiteren Trigger usw.

                          @sms sagte in Object.<anonymous> finden?:

                          @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.

                          Das kann man schon so machen, aber schön/sauber ist das nicht. Ist zumindest nicht das Problem hier für die Fehlermeldung.

                          🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                          🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                          📚 Meine inoffizielle ioBroker Dokumentation

                          SMSS CodierknechtC 2 Replies Last reply
                          0
                          • haus-automatisierungH haus-automatisierung

                            Kannst Du mal bitte das komplette Script zeigen? Da fehlt ja definitiv noch Code. Im Screenshot erkennt man ja einen weiteren Trigger usw.

                            @sms sagte in Object.<anonymous> finden?:

                            @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.

                            Das kann man schon so machen, aber schön/sauber ist das nicht. Ist zumindest nicht das Problem hier für die Fehlermeldung.

                            SMSS Offline
                            SMSS Offline
                            SMS
                            wrote on last edited by
                            #13
                            var Uhrzeit, Auto_Ein_bei, Steckdose_Dauerein, Hand, Wartezeit_Verbindungsaufbau, Wartezeit, Wartezeit3, Wartezeit2;
                            
                            
                            on({ id: [].concat(['homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_StartInRelative']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              setState('0_userdata.0.Küche.Siemens_Spülmaschine_Startzeit_Stunden' /* Siemens Spülmaschine Startzeit Stunden */, (getState('homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_StartInRelative').val / 3600), true);
                              setState('0_userdata.0.Küche.Siemens_Spülmaschine_Startzeit_Minuten' /* Siemens Spülmaschine Startzeit Minuten */, (getState('homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_StartInRelative').val / 60), true);
                            });
                            on({ id: [].concat(['sonoff.0.Spülmaschine.alive']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if ((obj.state ? obj.state.val : '') == false) {
                                setState('0_userdata.0.Küche.SD_Spülmaschine_am_Leben' /* SD Spülmaschine am Leben */, false, true);
                              } else {
                                setState('0_userdata.0.Küche.SD_Spülmaschine_am_Leben' /* SD Spülmaschine am Leben */, true, true);
                              }
                            });
                            schedule("0,30 * * * *", async () => {
                              setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbrauch' /* Siemens_Spülmaschine_Verbrauch */, (getState('sonoff.0.Spülmaschine.ENERGY_Total').val - 405.155), true);
                            });
                            on({ id: [].concat(['homeconnect.0.013060393307000289.status.BSH_Common_Status_OperationState']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if ((obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Run') {
                                setState('0_userdata.0.Küche.Spülgänge' /* Spülgänge */, (getState('0_userdata.0.Küche.Spülgänge').val + 1), true);
                              }
                            });
                            on({ id: [].concat(['homeconnect.0.013060393307000289.status.BSH_Common_Status_OperationState']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if ((obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Ready') {
                                setStateDelayed('0_userdata.0.Küche.Siemens_Spülmaschine_Durchnittskosten' /* Siemens Spülmaschine Durchnittskosten */, (getState('0_userdata.0.Küche.Spülmaschine_Verbrauchskosten').val / getState('0_userdata.0.Küche.Spülgänge').val), true, 60000, false);
                              }
                            });
                            schedule("0,30 * * * *", async () => {
                              setState('0_userdata.0.Küche.Spülmaschine_Verbrauchskosten' /* Spülmaschine Verbrauchskosten */, (getState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbrauch').val * getState('javascript.0.Meine_Datenpunkte.Strom.Kosten.Arbeitspreis_/kWh_Bezug_Energieversorger').val), true);
                            });
                            on({ id: [].concat(['homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_RemainingProgramTime']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              setState('0_userdata.0.Küche.Siemens_Spülmaschine_Restlaufzeit' /* Siemens Spülmaschine Restlaufzeit */, (getState('homeconnect.0.013060393307000289.programs.active.options.BSH_Common_Option_RemainingProgramTime').val / 60), true);
                            });
                            scheduleById('0_userdata.0.Haushaltsgeraete.01_Uhrzeit_Spuelmaschine' /* 01_Uhrzeit Spuelmaschine */, async () => {
                              if (Uhrzeit) {
                                setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                              }
                            });
                            on({ id: [].concat(['0_userdata.0.Küche.Siemens_Spülmaschine_Auto_ein_bei']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if ((obj.state ? obj.state.val : '') == 1) {
                                Auto_Ein_bei = 1500;
                              } else if ((obj.state ? obj.state.val : '') == 2) {
                                Auto_Ein_bei = 2000;
                              } else if ((obj.state ? obj.state.val : '') == 3) {
                                Auto_Ein_bei = 3000;
                              } else if ((obj.state ? obj.state.val : '') == 4) {
                                Auto_Ein_bei = 4000;
                              } else if ((obj.state ? obj.state.val : '') == 0) {
                                Auto_Ein_bei = false;
                              }
                              setState('0_userdata.0.Küche.Auto_ein_bei' /* Auto ein bei */, Auto_Ein_bei, true);
                            });
                            on({ id: [].concat(['0_userdata.0.Küche.Spülmaschine_Ein/Aus']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              Uhrzeit = false;
                              setState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto' /* Siemens Spülmaschine Auto */, false, true);
                              Hand = false;
                              if ((obj.state ? obj.state.val : '') == 3) {
                                Uhrzeit = true;
                              } else if ((obj.state ? obj.state.val : '') == 2) {
                                setState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto' /* Siemens Spülmaschine Auto */, true, true);
                              } else if ((obj.state ? obj.state.val : '') == 1) {
                                Hand = true;
                                (() => { if (Auto_Ein_bei) { clearInterval(Auto_Ein_bei); Auto_Ein_bei = null; }})();
                                setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                              } else if ((obj.state ? obj.state.val : '') == 0) {
                                setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, false);
                              }
                            });
                            on({ id: [].concat(['0_userdata.0.Küche.Spülmaschine_Ein/Aus']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              Steckdose_Dauerein = false;
                              if ((obj.state ? obj.state.val : '') == 4) {
                                Steckdose_Dauerein = true;
                                setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                              }
                            });
                            on({ id: '0_userdata.0.Strom.Stromerzeugung_gesamt' /* Stromerzeugung gesamt */, change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if (getState('0_userdata.0.Küche.Siemens_Spülmaschine_Auto').val == true) {
                                if ((obj.state ? obj.state.val : '') >= getState('0_userdata.0.Küche.Auto_ein_bei').val && getState('0_userdata.0.Strom.Batterie.Batterie___60%').val == true) {
                                  setState('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, true);
                                  setStateDelayed('0_userdata.0.Küche.Siemens_Spülmaschine_Auto_ein_bei' /* Siemens Spülmaschine Auto ein bei */, false, true, 120000, false);
                                }
                              }
                            });
                            on({ id: [].concat(['alias.0.Küche.Spülmaschine.SET']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if ((obj.state ? obj.state.val : '') && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val != 1 && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val != 4) {
                                (() => { if (Wartezeit) { clearInterval(Wartezeit); Wartezeit = null; }})();
                                Wartezeit_Verbindungsaufbau = 90;
                                setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                                Wartezeit = setInterval(async () => {
                                  Wartezeit_Verbindungsaufbau = (typeof Wartezeit_Verbindungsaufbau === 'number' ? Wartezeit_Verbindungsaufbau : 0) + -1;
                                  setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                                  if (Wartezeit_Verbindungsaufbau <= 0 && getState('alias.0.Küche.Spülmaschine.SET').val == true) {
                                    (() => { if (Wartezeit) { clearInterval(Wartezeit); Wartezeit = null; }})();
                                    setState('homeconnect.0.013060393307000289.programs.active.BSH_Common_Root_ActiveProgram' /* BSH_Common_Root_ActiveProgram */, 'Dishcare.Dishwasher.Program.Eco50');
                                    setState('homeconnect.0.013060393307000289.settings.BSH_Common_Setting_PowerState' /* Energiezustand */, 'BSH.Common.EnumType.OperationState.On');
                                    if (obj.id && obj?.state && !obj.state.ack) {
                                      await setStateAsync(obj.id, { val: obj.state.val, ack: true });
                                    }
                                  }
                                }, 1000);
                              }
                              if ((obj.state ? obj.state.val : '') && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val == 1) {
                                (() => { if (Wartezeit3) { clearInterval(Wartezeit3); Wartezeit3 = null; }})();
                                Wartezeit_Verbindungsaufbau = 90;
                                setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                                Wartezeit3 = setInterval(async () => {
                                  Wartezeit_Verbindungsaufbau = (typeof Wartezeit_Verbindungsaufbau === 'number' ? Wartezeit_Verbindungsaufbau : 0) + -1;
                                  setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                                  if (Wartezeit_Verbindungsaufbau <= 0) {
                                    (() => { if (Wartezeit3) { clearInterval(Wartezeit3); Wartezeit3 = null; }})();
                                  }
                                }, 1000);
                              }
                              if ((obj.state ? obj.state.val : '') && getState('0_userdata.0.Küche.Spülmaschine_Ein/Aus').val == 4) {
                                (() => { if (Wartezeit2) { clearInterval(Wartezeit2); Wartezeit2 = null; }})();
                                Wartezeit_Verbindungsaufbau = 90;
                                setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                                Wartezeit2 = setInterval(async () => {
                                  Wartezeit_Verbindungsaufbau = (typeof Wartezeit_Verbindungsaufbau === 'number' ? Wartezeit_Verbindungsaufbau : 0) + -1;
                                  setState('0_userdata.0.Küche.Siemens_Spülmaschine_Verbindungszeit' /* Siemens Spülmaschine Verbindungszeit */, Wartezeit_Verbindungsaufbau, true);
                                  if (Wartezeit_Verbindungsaufbau <= 0) {
                                    (() => { if (Wartezeit2) { clearInterval(Wartezeit2); Wartezeit2 = null; }})();
                                  }
                                }, 1000);
                              }
                            });
                            on({ id: [].concat(['homeconnect.0.013060393307000289.status.BSH_Common_Status_OperationState']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if ((obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Run' || (obj.state ? obj.state.val : '') == 'BSH.Common.EnumType.OperationState.Ready') {
                                setStateDelayed('0_userdata.0.Küche.Siemens_Spülmaschine_läuft' /* Siemens_Spülmaschine_läuft */, true, true, 30000, false);
                              }
                            });
                            on({ id: [].concat(['0_userdata.0.Küche.Siemens_Spülmaschine_Restlaufzeit']), change: 'ne' }, async (obj) => {
                              let value = obj.state.val;
                              let oldValue = obj.oldState.val;
                              if ((obj.state ? obj.state.val : '') <= 0 && getState('0_userdata.0.Küche.Siemens_Spülmaschine_läuft').val == true && getState('0_userdata.0.Küche.Siemens_Spülmaschine_Restlaufzeit').val <= 0) {
                                setState('0_userdata.0.Küche.Siemens_Spülmaschine_läuft' /* Siemens_Spülmaschine_läuft */, false, true);
                                setState('0_userdata.0.Küche.Spülmaschine_Ein/Aus' /* Spülmaschine Ein/Aus */, 0, true);
                                setStateDelayed('alias.0.Küche.Spülmaschine.SET' /* Set-Spülmaschine */, false, 300000, false);
                              }
                            });
                            
                            1 Reply Last reply
                            0
                            • haus-automatisierungH haus-automatisierung

                              Kannst Du mal bitte das komplette Script zeigen? Da fehlt ja definitiv noch Code. Im Screenshot erkennt man ja einen weiteren Trigger usw.

                              @sms sagte in Object.<anonymous> finden?:

                              @codierknecht Ich habe das Objekt deshalb extra auf "gemischt" gestellt, dachte das funktioniert so.

                              Das kann man schon so machen, aber schön/sauber ist das nicht. Ist zumindest nicht das Problem hier für die Fehlermeldung.

                              CodierknechtC Offline
                              CodierknechtC Offline
                              Codierknecht
                              Developer Most Active
                              wrote on last edited by
                              #14

                              @haus-automatisierung sagte in Object.<anonymous> finden?:

                              Das kann man schon so machen

                              OT: Ich hatte mal einen Kollegen, der seinen Code eher so "hingerotzt" hat.
                              Für den hatte ich mir Spezialkleidung besorgt:
                              f88760af-bf71-4e22-a264-66f008ebb0be-image.png
                              Was soll ich sagen ... der war nicht mehr lange "Kollege" :grin:

                              "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                              Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                              HmIP|ZigBee|Tasmota|Unifi
                              Zabbix Certified Specialist
                              Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                              SMSS 1 Reply Last reply
                              0
                              • CodierknechtC Codierknecht

                                @haus-automatisierung sagte in Object.<anonymous> finden?:

                                Das kann man schon so machen

                                OT: Ich hatte mal einen Kollegen, der seinen Code eher so "hingerotzt" hat.
                                Für den hatte ich mir Spezialkleidung besorgt:
                                f88760af-bf71-4e22-a264-66f008ebb0be-image.png
                                Was soll ich sagen ... der war nicht mehr lange "Kollege" :grin:

                                SMSS Offline
                                SMSS Offline
                                SMS
                                wrote on last edited by
                                #15

                                @codierknecht Ich habe ja nicht gesagt das es perfekt ist. Das war für mich die Lösung damit da nicht 0 steht. Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

                                paul53P CodierknechtC 2 Replies Last reply
                                0
                                • SMSS SMS

                                  @codierknecht Ich habe ja nicht gesagt das es perfekt ist. Das war für mich die Lösung damit da nicht 0 steht. Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  wrote on last edited by
                                  #16

                                  @sms sagte: Das war für mich die Lösung damit da nicht 0 steht.

                                  Wie wäre es mit Strings?

                                  Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                  Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                  SMSS 1 Reply Last reply
                                  0
                                  • paul53P paul53

                                    @sms sagte: Das war für mich die Lösung damit da nicht 0 steht.

                                    Wie wäre es mit Strings?

                                    SMSS Offline
                                    SMSS Offline
                                    SMS
                                    wrote on last edited by SMS
                                    #17

                                    @paul53 Wie müsste es dann aussehen? Trotzdem Zahlenwerte und true und false gemischt?

                                    paul53P 1 Reply Last reply
                                    0
                                    • SMSS SMS

                                      @codierknecht Ich habe ja nicht gesagt das es perfekt ist. Das war für mich die Lösung damit da nicht 0 steht. Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

                                      CodierknechtC Offline
                                      CodierknechtC Offline
                                      Codierknecht
                                      Developer Most Active
                                      wrote on last edited by
                                      #18

                                      @sms sagte in Object.<anonymous> finden?:

                                      Ich habe ja nicht gesagt das es perfekt ist

                                      Deswegen ja auch "OT". War nicht an Dich adressiert.

                                      Ich könnte natürlich auch einen Zahlenwert reinschreiben, den ich eh nie erreichen werde.

                                      Wäre eine Möglichkeit.
                                      Das Problem ist ja hier, dass eine rein Logische Aussage zusammen mit quantitativen Aussagen in einem einzigen DP zusammen abgebildet werden sollen.

                                      @paul53 sagte in Object.<anonymous> finden?:

                                      Wie wäre es mit Strings?

                                      Fände ich fast noch unschöner.
                                      Ich würde einen bestimmten - unter normalen Umständen niemals erreichbaren - Zahlenwert bevorzugen.

                                      Oder aber z.B. -1 und diesen Sonderfall nochmal explizit prüfen, bevor da etwas losgetreten wird.
                                      Alternative wäre ein Objekt. Mit "On/Off" als Bool und den Zahlenwerten als Number. Fände ich am saubersten.

                                      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                                      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                                      HmIP|ZigBee|Tasmota|Unifi
                                      Zabbix Certified Specialist
                                      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                                      CodierknechtC 1 Reply Last reply
                                      0
                                      • SMSS SMS

                                        @paul53 Wie müsste es dann aussehen? Trotzdem Zahlenwerte und true und false gemischt?

                                        paul53P Offline
                                        paul53P Offline
                                        paul53
                                        wrote on last edited by paul53
                                        #19

                                        @sms sagte: Wie müsste es dann aussehen?

                                        Blockly_temp.JPG

                                        Datenpunkt-Typ: "string".

                                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                        SMSS 1 Reply Last reply
                                        0
                                        • paul53P paul53

                                          @sms sagte: Wie müsste es dann aussehen?

                                          Blockly_temp.JPG

                                          Datenpunkt-Typ: "string".

                                          SMSS Offline
                                          SMSS Offline
                                          SMS
                                          wrote on last edited by
                                          #20

                                          @paul53 werde ich mal ausprobieren

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          371

                                          Online

                                          32.5k

                                          Users

                                          81.7k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe