Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Verstehe die Fehlermeldung nicht

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Verstehe die Fehlermeldung nicht

    This topic has been deleted. Only users with topic management privileges can see it.
    • ?
      A Former User @Matze78 last edited by A Former User

      @matze78 im JavaScript editor wenn du das Skript öffnest hast du oben rechts ein schrauben Schlüssel, klickst du dadrauf ist dort ein Punkt ‚debug‘ der scheint altiviviert zu sein. Diesen deaktivieren und das Script sollte laufen 🙂

      4530AF65-7B8D-412B-9DDC-E7A57294A5F4.jpeg

      M 1 Reply Last reply Reply Quote 0
      • M
        Matze78 @Guest last edited by Matze78

        Vielen Dank @ciddi89 ,

        leider will es aber trotzdem nicht. Jetzt ist die Meldung

        21:44:14.756	warn	javascript.0 (448) at script.js.Aussenbeleuchtung.Aussenbeleuchtung_Türen:47:5
        21:44:14.756	warn	javascript.0 (448) at script.js.Aussenbeleuchtung.Aussenbeleuchtung_Türen:69:3
        21:44:14.756	info	javascript.0 (448) script.js.Aussenbeleuchtung.Aussenbeleuchtung_Türen: getState(id=undefined, timerId=undefined) => not found
        21:44:14.758	warn	javascript.0 (448) at script.js.Aussenbeleuchtung.Aussenbeleuchtung_Türen:57:5
        21:44:14.758	warn	javascript.0 (448) at script.js.Aussenbeleuchtung.Aussenbeleuchtung_Türen:69:3
        21:44:14.758	info	javascript.0 (448) script.js.Aussenbeleuchtung.Aussenbeleuchtung_Türen: registered 0 subscriptions, 5 schedules, 0 messages, 0 logs and 0 file subscriptions
        

        Das Licht schaltet nicht. Ich sehe aber durchaus den Bewegungsmelder, also der Input wechselt auf true...

        Edit: Ich glaube die Variable ist undefined. Das kann jetzt natürlich sein, die wird ja nur über Astro gesetzt. Wie löse ich das denn jetzt? In Javascript geht es iwie nicht (das ist jetzt schreibgeschützt)

        ? 1 Reply Last reply Reply Quote 0
        • ?
          A Former User @Matze78 last edited by A Former User

          @matze78 bei den definitionen ist der jetzige fehler:

          getState(IstNacht).val
          

          Das getState und das .val kannst dz weglassen also nur

          IstNacht === true 
          

          Genau so wie mit hintertueran das sind variabeln und brauchen daher nicht die funktion getState

          if (IstNacht == true) {
            if (getState('shelly.2.SHSW-PM#BCFF4DFCBAF5#1.Relay0.Input').val == true) {
              if (getState('0_userdata.0.Automatiken.Außenbeleuchtung').val == true) {
                setState("shelly.2.SHSW-PM#BCFF4DFCBAF5#1.Relay0.Switch"/*Switch*/, true);
                if (HintertuerAn == false) {
                  setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch"/*Switch*/, true);
                }
              }
            }
          }
          if (IstNacht == true) {
            if (getState('shelly.2.SHSW-PM#BCFF4DFCBAF5#1.Relay0.Input').val == false) {
              if (getState('0_userdata.0.Automatiken.Außenbeleuchtung').val == true) {
                setState("shelly.2.SHSW-PM#BCFF4DFCBAF5#1.Relay0.Switch"/*Switch*/, false);
                if (HintertuerAn == false) {
                  setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch"/*Switch*/, false);
                }
              }
            }
          }
          
          M 1 Reply Last reply Reply Quote 0
          • paul53
            paul53 @Matze78 last edited by

            @matze78 sagte: wo ich einen Namen definiere, damit ich im Blockly nicht zig mal "Switch" sehe

            Im Tab "Objekte" rechts auf dem Bleistift (Objekt bearbeiten) klicken und den Namen ändern.

            M 1 Reply Last reply Reply Quote 0
            • M
              Matze78 @Guest last edited by

              Ok @ciddi89, da hatte ich bei Blockly ein falsches Element genommen, das passt jetzt.

              Das einzige Problem ist jetzt die nicht gesetzte Variable. Ich setze bei Sonnenuntergang-Anfang -10 die "istNacht" auf an. Wenn ich das Script jetzt neu starte kommt er an diesen Punkt natürlich nicht mehr. Wie kann ich diesen Wert danach füllen?

              ? 1 Reply Last reply Reply Quote 0
              • M
                Matze78 @paul53 last edited by

                @paul53
                2af38d66-dfbf-44dc-b886-92e53daa2391-image.png
                Das habe ich eigentlich, in den Objekten steht ja auch der Name - nur in den Scripten nicht.

                paul53 1 Reply Last reply Reply Quote 0
                • ?
                  A Former User @Matze78 last edited by A Former User

                  @matze78 einfach ein falls Block einbauen der den aktuellen Stand prüft. Dies erfordert kein trigger und wird beim script start ausgeführt. ich habe in einigen Skripts sowas wie im Screenshot laufen. Somit kann man variablen neu setzen falls das Script oder iobroker Neustartet. Der timeout muss nicht sein es geht auch ohne. D15EEBB3-C523-410C-BAE4-CA1F41D19CFF.jpeg

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

                    @matze78 sagte: in den Objekten steht ja auch der Name - nur in den Scripten nicht.

                    Ich sehe zum Datenpunkt nur den Namen "Switch", der geändert werden sollte. Den Kanalnamen sieht man im Blockly-Skript nicht.

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

                      @matze78 sagte: Bewegungsmelder an Eingang,

                      Für den BWM fehlt der Trigger.
                      Habe den Trigger ergänzt (hoffe, dass es der richtige Datenpunkt ist) und das Skript vereinfacht:

                      var IstNacht = compareTime(getAstroDate("sunriseEnd", undefined, 10), getAstroDate("sunsetStart", undefined, -10), "not between", null);
                      var HintertuerAn = getState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch").val;
                       
                      schedule({astro: "sunriseEnd", shift: 10}, function () {
                        if (getState('0_userdata.0.Automatiken.Außenbeleuchtung').val) {
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay0.Switch"/*Switch*/, false);
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch"/*Switch*/, false);
                          setState("shelly.2.SHSW-PM#BCFF4DFCBAF5#1.Relay0.Switch"/*Switch*/, false);
                          HintertuerAn = false;
                        }
                        IstNacht = false;
                      });
                      
                      schedule({astro: "sunsetStart", shift: -10}, function () {
                        if (getState('0_userdata.0.Automatiken.Außenbeleuchtung').val) {
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay0.Switch"/*Switch*/, true);
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch"/*Switch*/, true);
                          HintertuerAn = true;
                        }  
                        IstNacht = true;
                      });
                      
                      schedule('0 2 * * *', function () {
                        if (getState('0_userdata.0.Automatiken.Außenbeleuchtung').val) {
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay0.Switch"/*Switch*/, false);
                        }
                      });
                      
                      schedule('0 20 * * *', function () {
                        if (getState('0_userdata.0.Automatiken.Außenbeleuchtung').val) {
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch"/*Switch*/, false);
                          HintertuerAn = false;
                        }
                      });
                      
                      schedule('30 6 * * *', function () {
                        if (getState('0_userdata.0.Automatiken.Außenbeleuchtung').val) {
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay0.Switch"/*Switch*/, true);
                          setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch"/*Switch*/, true);
                          HintertuerAn = true;
                        }
                      });
                      
                      on('shelly.2.SHSW-PM#BCFF4DFCBAF5#1.Relay0.Input', function(dp) {
                          if (IstNacht && getState('0_userdata.0.Automatiken.Außenbeleuchtung').val) {
                              setState("shelly.2.SHSW-PM#BCFF4DFCBAF5#1.Relay0.Switch"/*Switch*/, dp.state.val);
                              if(!HintertuerAn) {
                                  setState("shelly.1.shellypro4pm#083af27d18d4#1.Relay1.Switch"/*Switch*/, dp.state.val);
                              }
                          }
                      });
                      

                      Den Sinn der Abfrage von HintertuerAn verstehe ich allerdings nicht.

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

                        HintertuerAn ist ein Relikt aus alten Zeiten @paul53
                        Das Licht an der Hintertür soll bis 20 Uhr an bleiben, dann spare ich mir das Licht untem im Flur. Damit der Bewegungsmelder das Licht nun aber nicht abschaltet soll er sich merken, ob er es abschalten soll oder eben nicht.

                        7449077b-c386-4c8c-88b7-843a4ba2d3b5-image.png

                        @ciddi89 Ich habe jetzt versucht die Variablen vorzubelegen. Die Nacht wird leider nicht erkannt, das zwischen 20 Uhr und 6:30 allerdings schon...

                        paul53 3 Replies Last reply Reply Quote 0
                        • paul53
                          paul53 @Matze78 last edited by

                          @matze78 sagte: Die Nacht wird leider nicht erkannt

                          Vergleich von Astrozeiten funktioniert nicht über Mitternacht, weshalb man "nicht zwischen SA und SU" verwendet.

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

                            Danke @paul53 , das macht natürlich Sinn...

                            ? 1 Reply Last reply Reply Quote 0
                            • ?
                              A Former User @Matze78 last edited by

                              @matze78 geht nur mit „ist nicht zwischen aufgang und untergang“ wie paul schon schrieb 🙂

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

                                @matze78 sagte: Das Licht an der Hintertür soll bis 20 Uhr an bleiben

                                Was soll um 2:00 Uhr passieren?

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

                                  @matze78 sagte: Ich habe jetzt versucht die Variablen vorzubelegen.

                                  So ist es vollkommen ausreichend:

                                  Bild_2022-09-04_234127607.png

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

                                    @paul53 ab 2 Uhr soll das Licht an der Haustür ausbleiben. Da kommt die Zeitung bei den Nachbarn an und unser Hund schläft im Flur direkt im Lichtkegel 😉

                                    M 1 Reply Last reply Reply Quote 0
                                    • M
                                      Matze78 @Matze78 last edited by

                                      Danke schön @ciddi89 und @paul53, jetzt tut´s

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

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      923
                                      Online

                                      32.0k
                                      Users

                                      80.5k
                                      Topics

                                      1.3m
                                      Posts

                                      3
                                      18
                                      583
                                      Loading More Posts
                                      • Oldest to Newest
                                      • Newest to Oldest
                                      • Most Votes
                                      Reply
                                      • Reply as topic
                                      Log in to reply
                                      Community
                                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                      The ioBroker Community 2014-2023
                                      logo