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. JavaScript
  5. setState()-Aufrufe haben immer ack == true

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    18
    1
    627

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.3k

setState()-Aufrufe haben immer ack == true

Geplant Angeheftet Gesperrt Verschoben JavaScript
15 Beiträge 4 Kommentatoren 814 Aufrufe 2 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.
  • S Offline
    S Offline
    selector
    schrieb am zuletzt editiert von
    #1

    Hi @all,

    wenn ich aus einem Script setState aufrufe und das entstehende Ereignis mit on(...) abfange, ist in dem Objekt, welches an den Callback in on übergeben wird, die Eigenschaft ack immer true.

    Läuft da was falsch, oder habe ich da ein Verständnisproblem zu der Funktion? Die Doku finde ich da nicht sehr aufschlussreich.

    Nach meinem Verständnis sollte zumindest ein Aufruf von setState(..., false) -> also Parameter zwei auf false, doch zumindest ack=false erwirken. Ich habe auch die Überladung der Funktion mit dem Callback-Parameter drei ausprobiert, gleiches Ergebnis (wobei mir nicht ganz klar ist wozu der Callack genutzt werden könnte.

    Mein Script hier setzt den Datenpunkt

    function mirrorOn() {
        setState('zigbee.0.dc8e95fffe15d81a.state', true, false);
    }
    

    und hier fange ich das Ereignis ab:

    on({id: 'zigbee.0.dc8e95fffe15d81a.state', ack: true, change: 'any'}, function (obj) {
        console.log('manual mirrow state change to: ' + obj.state.val)
        console.log(obj)
        if (obj.state.val == true) {
            setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON');
        } else {
            setState('0_userdata.0.rooms.bathroom.mirrow_state', 'OFF');
        }
    });
    

    Hintergrund für die Programmierung ist, dass ich einen Heizspiegel an einem Zigbee Schalter sowohl per VIS als auch per Hardware-Schalter an dem Zigbee-Schalter schalten möchte. Wenn der Schalter per Hardware geschaltet wird, muss der Modus in VIS aktualisiert werden, bei Aktualisierungen durch VIS bzw das Script soll der Modus nicht geändert werden.

    das ist eine Log-Ausgabe von dem Script:

    javascript.0	12:18:00.257	info	script.js.rooms.bathroom.heatingmirror: manual mirrow state change to: false
    javascript.0	12:18:00.258	info	script.js.rooms.bathroom.heatingmirror: EventObj { id: 'zigbee.0.dc8e95fffe15d81a.state', newState: { val: false, ts: 1735557480254, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' }, oldState: { val: false, ts: 1735557480152, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' }, state: { val: false, ts: 1735557480254, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' } }
    

    Hat jemand eine Idee? Ich glaube eher nicht in einem Fehler in dem Adapter, das wäre ja bestimmt schon aufgefallen.

    Script-Engine: 8.8.3 (1~)
    Admin: 6.13.16

    Hat jemand ne Idee wo mein Denkfehler ist?
    Danke und Grüße,
    Sel

    paul53P haus-automatisierungH 2 Antworten Letzte Antwort
    0
    • S selector

      Hi @all,

      wenn ich aus einem Script setState aufrufe und das entstehende Ereignis mit on(...) abfange, ist in dem Objekt, welches an den Callback in on übergeben wird, die Eigenschaft ack immer true.

      Läuft da was falsch, oder habe ich da ein Verständnisproblem zu der Funktion? Die Doku finde ich da nicht sehr aufschlussreich.

      Nach meinem Verständnis sollte zumindest ein Aufruf von setState(..., false) -> also Parameter zwei auf false, doch zumindest ack=false erwirken. Ich habe auch die Überladung der Funktion mit dem Callback-Parameter drei ausprobiert, gleiches Ergebnis (wobei mir nicht ganz klar ist wozu der Callack genutzt werden könnte.

      Mein Script hier setzt den Datenpunkt

      function mirrorOn() {
          setState('zigbee.0.dc8e95fffe15d81a.state', true, false);
      }
      

      und hier fange ich das Ereignis ab:

      on({id: 'zigbee.0.dc8e95fffe15d81a.state', ack: true, change: 'any'}, function (obj) {
          console.log('manual mirrow state change to: ' + obj.state.val)
          console.log(obj)
          if (obj.state.val == true) {
              setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON');
          } else {
              setState('0_userdata.0.rooms.bathroom.mirrow_state', 'OFF');
          }
      });
      

      Hintergrund für die Programmierung ist, dass ich einen Heizspiegel an einem Zigbee Schalter sowohl per VIS als auch per Hardware-Schalter an dem Zigbee-Schalter schalten möchte. Wenn der Schalter per Hardware geschaltet wird, muss der Modus in VIS aktualisiert werden, bei Aktualisierungen durch VIS bzw das Script soll der Modus nicht geändert werden.

      das ist eine Log-Ausgabe von dem Script:

      javascript.0	12:18:00.257	info	script.js.rooms.bathroom.heatingmirror: manual mirrow state change to: false
      javascript.0	12:18:00.258	info	script.js.rooms.bathroom.heatingmirror: EventObj { id: 'zigbee.0.dc8e95fffe15d81a.state', newState: { val: false, ts: 1735557480254, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' }, oldState: { val: false, ts: 1735557480152, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' }, state: { val: false, ts: 1735557480254, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' } }
      

      Hat jemand eine Idee? Ich glaube eher nicht in einem Fehler in dem Adapter, das wäre ja bestimmt schon aufgefallen.

      Script-Engine: 8.8.3 (1~)
      Admin: 6.13.16

      Hat jemand ne Idee wo mein Denkfehler ist?
      Danke und Grüße,
      Sel

      paul53P Offline
      paul53P Offline
      paul53
      schrieb am zuletzt editiert von paul53
      #2

      @selector sagte: Hat jemand ne Idee wo mein Denkfehler ist?

      Der Adapter bestätigt nach Ausführung das Kommando.
      Wenn du im Trigger "ack: true" weg lässt, wirst du sehen, dass erst unbestätigt getriggert wird.

      @selector sagte in setState()-Aufrufe haben immer ack == true:

      Wenn der Schalter per Hardware geschaltet wird, muss der Modus in VIS aktualisiert werden, bei Aktualisierungen durch VIS bzw das Script soll der Modus nicht geändert werden.

      Dann ändere den Trigger auf change: 'ne'.

      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

      T 1 Antwort Letzte Antwort
      0
      • S selector

        Hi @all,

        wenn ich aus einem Script setState aufrufe und das entstehende Ereignis mit on(...) abfange, ist in dem Objekt, welches an den Callback in on übergeben wird, die Eigenschaft ack immer true.

        Läuft da was falsch, oder habe ich da ein Verständnisproblem zu der Funktion? Die Doku finde ich da nicht sehr aufschlussreich.

        Nach meinem Verständnis sollte zumindest ein Aufruf von setState(..., false) -> also Parameter zwei auf false, doch zumindest ack=false erwirken. Ich habe auch die Überladung der Funktion mit dem Callback-Parameter drei ausprobiert, gleiches Ergebnis (wobei mir nicht ganz klar ist wozu der Callack genutzt werden könnte.

        Mein Script hier setzt den Datenpunkt

        function mirrorOn() {
            setState('zigbee.0.dc8e95fffe15d81a.state', true, false);
        }
        

        und hier fange ich das Ereignis ab:

        on({id: 'zigbee.0.dc8e95fffe15d81a.state', ack: true, change: 'any'}, function (obj) {
            console.log('manual mirrow state change to: ' + obj.state.val)
            console.log(obj)
            if (obj.state.val == true) {
                setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON');
            } else {
                setState('0_userdata.0.rooms.bathroom.mirrow_state', 'OFF');
            }
        });
        

        Hintergrund für die Programmierung ist, dass ich einen Heizspiegel an einem Zigbee Schalter sowohl per VIS als auch per Hardware-Schalter an dem Zigbee-Schalter schalten möchte. Wenn der Schalter per Hardware geschaltet wird, muss der Modus in VIS aktualisiert werden, bei Aktualisierungen durch VIS bzw das Script soll der Modus nicht geändert werden.

        das ist eine Log-Ausgabe von dem Script:

        javascript.0	12:18:00.257	info	script.js.rooms.bathroom.heatingmirror: manual mirrow state change to: false
        javascript.0	12:18:00.258	info	script.js.rooms.bathroom.heatingmirror: EventObj { id: 'zigbee.0.dc8e95fffe15d81a.state', newState: { val: false, ts: 1735557480254, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' }, oldState: { val: false, ts: 1735557480152, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' }, state: { val: false, ts: 1735557480254, ack: true, lc: 1735486097119, from: 'system.adapter.zigbee.0', q: 0, c: undefined, user: 'system.user.admin' } }
        

        Hat jemand eine Idee? Ich glaube eher nicht in einem Fehler in dem Adapter, das wäre ja bestimmt schon aufgefallen.

        Script-Engine: 8.8.3 (1~)
        Admin: 6.13.16

        Hat jemand ne Idee wo mein Denkfehler ist?
        Danke und Grüße,
        Sel

        haus-automatisierungH Online
        haus-automatisierungH Online
        haus-automatisierung
        Developer Most Active
        schrieb am zuletzt editiert von
        #3

        @selector sagte in setState()-Aufrufe haben immer ack == true:

        Läuft da was falsch, oder habe ich da ein Verständnisproblem zu der Funktion? Die Doku finde ich da nicht sehr aufschlussreich.

        Eventuell hilft Dir die Erklärung ja: https://www.youtube.com/watch?v=p5FyeifYUnw

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

        1 Antwort Letzte Antwort
        0
        • paul53P paul53

          @selector sagte: Hat jemand ne Idee wo mein Denkfehler ist?

          Der Adapter bestätigt nach Ausführung das Kommando.
          Wenn du im Trigger "ack: true" weg lässt, wirst du sehen, dass erst unbestätigt getriggert wird.

          @selector sagte in setState()-Aufrufe haben immer ack == true:

          Wenn der Schalter per Hardware geschaltet wird, muss der Modus in VIS aktualisiert werden, bei Aktualisierungen durch VIS bzw das Script soll der Modus nicht geändert werden.

          Dann ändere den Trigger auf change: 'ne'.

          T Nicht stören
          T Nicht stören
          ticaki
          schrieb am zuletzt editiert von
          #4

          @paul53

          müsste man da nicht noch zusätzlich auf from testen?

          Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

          Spenden

          paul53P haus-automatisierungH 3 Antworten Letzte Antwort
          0
          • T ticaki

            @paul53

            müsste man da nicht noch zusätzlich auf from testen?

            paul53P Offline
            paul53P Offline
            paul53
            schrieb am zuletzt editiert von
            #5

            @ticaki sagte: müsste man da nicht noch zusätzlich auf from testen?

            Kann man, aber

            on({id: 'zigbee.0.dc8e95fffe15d81a.state', ack: true, change: 'ne'}
            

            sollte ausreichen, da bei Bestätigung der Änderung aus Vis oder Javascript keine Wertänderung erfolgt, denn diese erfolgte vorher unbestätigt.

            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

            S 1 Antwort Letzte Antwort
            0
            • T ticaki

              @paul53

              müsste man da nicht noch zusätzlich auf from testen?

              haus-automatisierungH Online
              haus-automatisierungH Online
              haus-automatisierung
              Developer Most Active
              schrieb am zuletzt editiert von
              #6

              @ticaki sagte in setState()-Aufrufe haben immer ack == true:

              müsste man da nicht noch zusätzlich auf from testen?

              from wird in diesem Fall immer zigbee.0 sein (für bestätigte Werte). Und javascript.0 für unbestätigte Werte. Es kommt also stark drauf an, was genau man eigentlich wissen möchte und wann man eine Aktion auslösen will.

              In diesem Fall sollte man die Darstellung in VIS wohl nur dann "nachziehen", wenn die Aktion auch wirklich ausgeführt wurde (= bestätigt ist). Und nicht dann, wenn die Aktion angestoßen wurde.

              PS: Eigene Datenpunkte sollte man bestätigt setzen. Also

              setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
              

              Den Vergleich mit true kann man sich schenken:

                  if (obj.state.val) {
                      setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
                  } else {
                      setState('0_userdata.0.rooms.bathroom.mirrow_state', 'OFF', true);
                  }
              

              Und dann könnte man das auch komplett kürzen:

              setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
              

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

              T 1 Antwort Letzte Antwort
              0
              • paul53P paul53

                @ticaki sagte: müsste man da nicht noch zusätzlich auf from testen?

                Kann man, aber

                on({id: 'zigbee.0.dc8e95fffe15d81a.state', ack: true, change: 'ne'}
                

                sollte ausreichen, da bei Bestätigung der Änderung aus Vis oder Javascript keine Wertänderung erfolgt, denn diese erfolgte vorher unbestätigt.

                S Offline
                S Offline
                selector
                schrieb am zuletzt editiert von
                #7

                Erstmal danke für die Posts,

                @paul53 said in setState()-Aufrufe haben immer ack == true:

                sollte ausreichen, da bei Bestätigung der Änderung aus Vis oder Javascript keine Wertänderung erfolgt, denn diese erfolgte vorher unbestätigt.

                das war auch meine Annahme.

                @paul53

                Auch das hatte ich schon ausprobiert. Es wird aber immer mit ack=true bestätigt, egal ob ich

                setState([object-path], true) oder
                setState([object-path], true, false) oder
                setState([object-path], true, false, ()=>{})

                aufrufe.

                Den Trigger auf 'ne' Ändern hilft, nicht, das bestimmt ja nur ob der Event-Handler nur aufgerufen wird, wenn eine Änderung zum Vor-Zustand erfolgt. Das kann bei mir sowohl durch den Manuellen Taster, als auch durch VIS sein.

                from ist, wie @haus-automatisierung schon gesagt hat, immer gleich.

                PS: Eigene Datenpunkte sollte man bestätigt setzen. Also

                Warum sollten die immer bestätigt gesetzt werden? Ich hätte jetzt gedacht, dass man über das ack-Flag nur steuert, ob der dahinterliegende Event-Mechanismus getriggert wird. Aber ich gucke mir jetzt erstmal das verlinkte Video an. Danke für den Link.

                1 Antwort Letzte Antwort
                0
                • haus-automatisierungH haus-automatisierung

                  @ticaki sagte in setState()-Aufrufe haben immer ack == true:

                  müsste man da nicht noch zusätzlich auf from testen?

                  from wird in diesem Fall immer zigbee.0 sein (für bestätigte Werte). Und javascript.0 für unbestätigte Werte. Es kommt also stark drauf an, was genau man eigentlich wissen möchte und wann man eine Aktion auslösen will.

                  In diesem Fall sollte man die Darstellung in VIS wohl nur dann "nachziehen", wenn die Aktion auch wirklich ausgeführt wurde (= bestätigt ist). Und nicht dann, wenn die Aktion angestoßen wurde.

                  PS: Eigene Datenpunkte sollte man bestätigt setzen. Also

                  setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
                  

                  Den Vergleich mit true kann man sich schenken:

                      if (obj.state.val) {
                          setState('0_userdata.0.rooms.bathroom.mirrow_state', 'ON', true);
                      } else {
                          setState('0_userdata.0.rooms.bathroom.mirrow_state', 'OFF', true);
                      }
                  

                  Und dann könnte man das auch komplett kürzen:

                  setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
                  
                  T Nicht stören
                  T Nicht stören
                  ticaki
                  schrieb am zuletzt editiert von ticaki
                  #8

                  @haus-automatisierung

                  Mein Gedanke dabei war das man von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (z.B. Relais ähnlich shelly 1)

                  Edit: Beispiel geändert

                  Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                  Spenden

                  paul53P 1 Antwort Letzte Antwort
                  0
                  • T ticaki

                    @haus-automatisierung

                    Mein Gedanke dabei war das man von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (z.B. Relais ähnlich shelly 1)

                    Edit: Beispiel geändert

                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von paul53
                    #9

                    @ticaki sagte: von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (taster, schalter usw)

                    ... zusammen mit Bestätigung. Wenn die Änderung per Javascript, Vis oder Admin erfolgt, bekommt man auch change: 'ne' von "zigbee.0", aber unbestätigt.

                    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

                    S T 2 Antworten Letzte Antwort
                    0
                    • paul53P paul53

                      @ticaki sagte: von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (taster, schalter usw)

                      ... zusammen mit Bestätigung. Wenn die Änderung per Javascript, Vis oder Admin erfolgt, bekommt man auch change: 'ne' von "zigbee.0", aber unbestätigt.

                      S Offline
                      S Offline
                      selector
                      schrieb am zuletzt editiert von
                      #10

                      ok, danke, ich weiß jetzt was mein Denkfehler war und warum eigene Datenpunkt im Gegensatz von Datenpunkten von Adaptern Bestätigt gesetzt werden sollten, das Video hat mir geholfen und. Problem war

                      1. Ich setze den Datenpunkt unbestätigt
                      2. Der Zigbee-Adapter nimmt das zum anlass den Schalter zu schalten
                      3. und sendet ein bestätigtes Event, welches ich dann abgefangen habe
                      1 Antwort Letzte Antwort
                      0
                      • paul53P paul53

                        @ticaki sagte: von zigbee.0 nur change: 'ne' bekommt, wenn die Änderung von einem Zigbeegerät angestossen wurde. (taster, schalter usw)

                        ... zusammen mit Bestätigung. Wenn die Änderung per Javascript, Vis oder Admin erfolgt, bekommt man auch change: 'ne' von "zigbee.0", aber unbestätigt.

                        T Nicht stören
                        T Nicht stören
                        ticaki
                        schrieb am zuletzt editiert von ticaki
                        #11

                        @paul53

                        change: 'ne' löst nur aus wenn sich der Wert ändert .

                        "ne" (not equal) New value must be not equal to the old one (state.val != oldState.val) If pattern is id-string this value is used by default

                        und nur durch das bestätigen ändert sich ja nicht der Wert... oder hat sich da was geändert?

                        Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                        Spenden

                        paul53P 1 Antwort Letzte Antwort
                        0
                        • T ticaki

                          @paul53

                          change: 'ne' löst nur aus wenn sich der Wert ändert .

                          "ne" (not equal) New value must be not equal to the old one (state.val != oldState.val) If pattern is id-string this value is used by default

                          und nur durch das bestätigen ändert sich ja nicht der Wert... oder hat sich da was geändert?

                          paul53P Offline
                          paul53P Offline
                          paul53
                          schrieb am zuletzt editiert von paul53
                          #12

                          @ticaki sagte: und nur durch das bestätigen ändert sich ja nicht der Wert...

                          Das war meine Aussage. Nur, wenn sich der Wert durch manuelle Betätigung vor Ort ändert, kommen change: 'ne', ack: true von "zigbee.0" gleichzeitig.

                          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

                          S 1 Antwort Letzte Antwort
                          0
                          • T ticaki

                            @paul53

                            müsste man da nicht noch zusätzlich auf from testen?

                            paul53P Offline
                            paul53P Offline
                            paul53
                            schrieb am zuletzt editiert von paul53
                            #13

                            @ticaki sagte: müsste man da nicht noch zusätzlich auf from testen?

                            Will man nur eine Trigger-Schleife verhindern, sollte man from testen:

                            on({id: 'zigbee.0.dc8e95fffe15d81a.state', change: 'ne', fromNe: 'system.adapter.javascript.0'}, function (obj) {
                                console.log('manual mirrow state change to: ' + obj.state.val)
                                console.log(obj)
                                setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
                            });
                            

                            EDIT: So kommt auch eine Änderung per Admin (Tab "Objekte") in der Visualisierung an.

                            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

                            T 1 Antwort Letzte Antwort
                            0
                            • paul53P paul53

                              @ticaki sagte: müsste man da nicht noch zusätzlich auf from testen?

                              Will man nur eine Trigger-Schleife verhindern, sollte man from testen:

                              on({id: 'zigbee.0.dc8e95fffe15d81a.state', change: 'ne', fromNe: 'system.adapter.javascript.0'}, function (obj) {
                                  console.log('manual mirrow state change to: ' + obj.state.val)
                                  console.log(obj)
                                  setState('0_userdata.0.rooms.bathroom.mirrow_state', obj.state.val ? 'ON' : 'OFF', true);
                              });
                              

                              EDIT: So kommt auch eine Änderung per Admin (Tab "Objekte") in der Visualisierung an.

                              T Nicht stören
                              T Nicht stören
                              ticaki
                              schrieb am zuletzt editiert von
                              #14

                              @paul53
                              Jetzt passt es, habs dann wohl falsch gelesen. Ich benutze from/fromNe im Kontext von Shellys um Automatismen zu deaktivieren.

                              Weather-Warnings Espresense NSPanel-Lovelace-ui Tagesschau

                              Spenden

                              1 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @ticaki sagte: und nur durch das bestätigen ändert sich ja nicht der Wert...

                                Das war meine Aussage. Nur, wenn sich der Wert durch manuelle Betätigung vor Ort ändert, kommen change: 'ne', ack: true von "zigbee.0" gleichzeitig.

                                S Offline
                                S Offline
                                selector
                                schrieb am zuletzt editiert von
                                #15

                                @paul53 said in setState()-Aufrufe haben immer ack == true:

                                @ticaki sagte: und nur durch das bestätigen ändert sich ja nicht der Wert...

                                Das war meine Aussage. Nur, wenn sich der Wert durch manuelle Betätigung vor Ort ändert, kommen change: 'ne', ack: true von "zigbee.0" gleichzeitig.

                                Ja, danke nochmal. Auch das ist korrekt, da hatte ich auch erst einen Denkfehler.

                                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

                                553

                                Online

                                32.5k

                                Benutzer

                                81.6k

                                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