Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

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

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.2k

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

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

Object.<anonymous> finden?

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
51 Beiträge 5 Kommentatoren 3.8k Aufrufe 3 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • SMSS Offline
    SMSS Offline
    SMS
    schrieb am zuletzt editiert von
    #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 Antworten Letzte Antwort
    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
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      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 Online
        CodierknechtC Online
        Codierknecht
        Developer Most Active
        schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          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 Online
            CodierknechtC Online
            Codierknecht
            Developer Most Active
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von
                #7

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

                CodierknechtC 1 Antwort Letzte Antwort
                0
                • SMSS SMS

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

                  CodierknechtC Online
                  CodierknechtC Online
                  Codierknecht
                  Developer Most Active
                  schrieb am zuletzt editiert von
                  #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 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von
                    #9

                    @codierknecht was bedeutet debug?

                    CodierknechtC 1 Antwort Letzte Antwort
                    0
                    • SMSS SMS

                      @codierknecht was bedeutet debug?

                      CodierknechtC Online
                      CodierknechtC Online
                      Codierknecht
                      Developer Most Active
                      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                      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
                        schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                        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
                          schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
                          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
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            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 Online
                              CodierknechtC Online
                              Codierknecht
                              Developer Most Active
                              schrieb am zuletzt editiert von
                              #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 Antwort Letzte Antwort
                              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
                                schrieb am zuletzt editiert von
                                #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 Antworten Letzte Antwort
                                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
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  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
                                    schrieb am zuletzt editiert von SMS
                                    #17

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

                                    paul53P 1 Antwort Letzte Antwort
                                    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 Online
                                      CodierknechtC Online
                                      Codierknecht
                                      Developer Most Active
                                      schrieb am zuletzt editiert von
                                      #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 Antwort Letzte Antwort
                                      0
                                      • SMSS SMS

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

                                        paul53P Offline
                                        paul53P Offline
                                        paul53
                                        schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                        0
                                        • paul53P paul53

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

                                          Blockly_temp.JPG

                                          Datenpunkt-Typ: "string".

                                          SMSS Offline
                                          SMSS Offline
                                          SMS
                                          schrieb am zuletzt editiert von
                                          #20

                                          @paul53 werde ich mal ausprobieren

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          852

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe