Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Vorlage] Multi Ereignislisten Skript

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] Multi Ereignislisten Skript

    This topic has been deleted. Only users with topic management privileges can see it.
    • RK62
      RK62 last edited by

      Alles mögliche versucht, letztendlich ist es ein Zufallsprodukt welche Meldung verarbeitet wird oder welche nicht. Bei der Prüfung von komplexen Schaltvorgänge muss man eben das "normale" Log verwenden, als einfache Statusanzeige für ausgewählte Ereignisse funktioniert es ja.

      Gruß, Ralf

      1 Reply Last reply Reply Quote 0
      • ruhr70
        ruhr70 last edited by

        <-

        EDIT 12.05.2018: Bereich gelöscht, da inhaltlich falsch

        ->

        [EDIT2]

        Das Thema wird wohl, Gott sei dank, nicht bei ioBroker liegen. Ich war ob Deiner Aussage echt geschockt.

        Bei einem Ereignis lese ich das aktuelle Array mit den Ereignissen für diese Liste aus einem Datenpunkt. Der Eintrag wird dann an die richtige Stelle geschrieben und das Array wird wieder zurückgeschrieben. Wenn nun, wie in dem Beispiel, viele Events direkt in Folge kommen, werden die ersten Änderungen noch nicht zurückgeschrieben sein. Und wenn beim 8. Event in dem Beispiel die Liste eingelesen wird, hat sie noch den Zustand vor dem ersten Ereignis (Vermutung). Dann wird die Liste davor sieben Mal bearbeitet, das achte Ereignis liest aber noch das ursprüngliche Array, da die sieben davor noch nicht zurückgeschrieben wurden. Im Array sind die anderen Änderungen noch nicht geschrieben, so dass zum Schluss nur der achte Eintrag ergänzt wird.

        So meine erste Vermutung.

        Wie ich das programmtechnisch löse muss ich sehen. Nehme aber gerne einen Tipp an 😉

        Das sind die beiden Funktionen, um die es geht:

        // Ereignis in der entsprechenden Liste schreiben
        function writeEvent(text,eventlist) {
            var listeArr = readListEvent(pfad+eventlist+".eventlistArr");               // liest die Liste aus einem Datenpunkt
            var neusteOben = listenJson[eventlist].neusteOben;
            if (typeof neusteOben == "undefined") neusteOben = defaultNeusteOben;
            var laenge = listenJson[eventlist].laenge;
            if (typeof laenge == "undefined") laenge = defaultLaenge;
            var zeitstempel = listenJson[eventlist].zeitstempel;
            if (typeof zeitstempel == "undefined") zeitstempel = defaultZeitstempel;
            if(neusteOben) {                                                                            // Liste oben ergänzen (neusteOben = true)
                listeArr.unshift(formatDate(new Date(), zeitstempel)+ trennerZeitstempel + text);       // fügt den Text als Event am Anfag der Liste ien
                if (listeArr.length > laenge) listeArr.pop();                                           // kürzt die Liste hinten, wenn die maximale Länge erreicht ist
            } else {                                                                                    // oder Liste unten ergänzen  (neusteOben = false)
                listeArr.push(formatDate(new Date(), zeitstempel)+ trennerZeitstempel + text);          // fügt den Text als Event am Ende der Liste ien
                if (listeArr.length > laenge) listeArr.shift();                                         // kürzt die Liste oben, wenn die maximale Länge erreicht ist
            }
            writeListEvent(listeArr, pfad+eventlist+".eventlistArr");             // schreibt das Array der Liste in den Datenpunkt zurück
            setState(pfad+eventlist+".eventlistStr",getEventsListStr(listeArr));  // erzeugt aus dem Array den String mit \n für neue Zeilen
            setState(pfad+eventlist+".eventlistHTML",getEventsListHtml(listeArr));// erzeugt aus dem Array den String mit 
        \n für neue Zeilen, html Tags bleiben erhalten
        }
        
        // Subscriptions für die Events je Liste
        // -----------------------------------------------------------------------------
        
        function setSubscriptions() {
        
            on({id:triggerArr,change:'any'}, function (obj) {  // wenn ein neuer Event geschrieben wird
                var eventlist = obj.name.replace(pfad,"").replace(".event","");
                var inWochentag = listenJson[eventlist].inWochtag;
                if (typeof inWochentag == "undefined") inWochentag = defaultInWochenTag;
                if (!obj.newState.ack && obj.newState.val) {
                    if(logOn) log("Event für die Liste '" + eventlist + "' erkannt: " + obj.state.val);
                    writeEvent(obj.state.val,eventlist);
                    if(wochentagStr() != eventlist) {                               // zusätzlich in die Wochentagsliste schreiben, außer es war ein Eintrag für den Wochentag
                        if(inWochentag) writeEvent(obj.state.val,wochentagStr());   // nicht schreiben, wenn die Liste von der Wochentagliste ausgenommen ist
                    }
                    if(wochentagStr() != "heute") {                                 // zusätzlich in die Tagesliste schreiben, außer es war ein Eintrag für die Liste "heute"
                    if(inWochentag) writeEvent(obj.state.val,"heute");              // nicht schreiben, wenn die Liste von der Wochentagliste ausgenommen ist
                    }
                }
            });
            if(logOn) colorLog("Skript: " + name + " -> Subscriptions angelegt","blue",logFarbig);    
        }
        

        Im on() werden die Ereignisse, setState(), über ein anderes Skript korrekt empfangen (puh 🙂 ).

        In writeEvent() verarbeitet. Hier wird das Problem mit der asynchronen Verarbeitung, wie oben beschrieben, liegen und nicht bei ioBroker setState().
        327_history.png

        1 Reply Last reply Reply Quote 0
        • ruhr70
          ruhr70 last edited by

          @RK62:

          Alles mögliche versucht, letztendlich ist es ein Zufallsprodukt welche Meldung verarbeitet wird oder welche nicht. Bei der Prüfung von komplexen Schaltvorgänge muss man eben das "normale" Log verwenden, als einfache Statusanzeige für ausgewählte Ereignisse funktioniert es ja. `

          Ich pack das Skript am Wochenende noch einmal an.

          Die Aussage von apollon77 hat mich erst auf die falsche Spur gebracht, dass ich da nichts ändern kann.

          Liegt aber wohl doch am Skript, siehe ein Post höher.

          1 Reply Last reply Reply Quote 0
          • ruhr70
            ruhr70 last edited by

            @RK62:

            Alles mögliche versucht, letztendlich ist es ein Zufallsprodukt welche Meldung verarbeitet wird oder welche nicht. Bei der Prüfung von komplexen Schaltvorgänge muss man eben das "normale" Log verwenden, als einfache Statusanzeige für ausgewählte Ereignisse funktioniert es ja. `

            Danke noch einmal für Deinen Hinweis.

            Ich habe eine aktualisierte Version (im 1. Post) eingestellt, die keine Ereignisse verschlucken sollte, die schnell hintereinander folgen.

            1 Reply Last reply Reply Quote 0
            • ruhr70
              ruhr70 last edited by

              Neue Version vom Skript und dem globalen Skript im 1. Post.

              1 Reply Last reply Reply Quote 0
              • RK62
                RK62 last edited by

                :!: Respekt :!:

                Läuft jetzt bei mir ohne "Vergesser"!

                Vielen Dank,

                Ralf

                1 Reply Last reply Reply Quote 0
                • S
                  Superdad last edited by

                  Danke! Läuft!

                  1 Reply Last reply Reply Quote 0
                  • apollon77
                    apollon77 last edited by

                    @ruhr70: Was hälst Du davon bei der globalen Event-Funktion auch ein "Array" als "List" Parameter zuzulassen? Ich habe eine globale Eventliste und spezialisiertere (z.B. EIngangstür u.ä. die dann in der Vis an den relevanten Stellen direkt angezeigt werden können - oder halt die "Komplette" Liste … Das würde das durchaus erleichtern die gleiche Botschaft auf einmal in mehrere Liste zu kippen

                    1 Reply Last reply Reply Quote 0
                    • ruhr70
                      ruhr70 last edited by

                      @apollon77:

                      @ruhr70: Was hälst Du davon bei der globalen Event-Funktion auch ein "Array" als "List" Parameter zuzulassen? Ich habe eine globale Eventliste und spezialisiertere (z.B. EIngangstür u.ä. die dann in der Vis an den relevanten Stellen direkt angezeigt werden können - oder halt die "Komplette" Liste … Das würde das durchaus erleichtern die gleiche Botschaft auf einmal in mehrere Liste zu kippen `

                      Halte ich viel von 🙂 Bin für jeden Vorschlag dankbar.

                      Ich glaube zwar nicht, dass ich das selbst nutzen werde, da dreimal event() kopiert fast scheller ist, als ein Array anzulegen. Aber alles, was das Skript flexibler macht… 🙂

                      Dann ändere ich das Skript mal und stell es hier wieder ein.

                      Danke für die Idee!

                      1 Reply Last reply Reply Quote 0
                      • ruhr70
                        ruhr70 last edited by

                        @apollon77:

                        @ruhr70: Was hälst Du davon bei der globalen Event-Funktion auch ein "Array" als "List" Parameter zuzulassen? `

                        Danke noch einmal für die Anregung.

                        Im 1. Post gibt es die neue globale Funktion event() in der Version 0.3.0, welche nun auch ein Array an Listen akzeptiert.

                        In dem Zuge wurde auch die Doku im globalen Skript aktualisiert.

                        Das Hauptskript musste dafür nicht angepasst werden.

                        1 Reply Last reply Reply Quote 0
                        • L
                          ld.stge last edited by

                          Hallo zusammen,

                          zunächst mal RESPEKT vor eurer Arbeit und herzlichen Dank an alle Mitwirkenden.

                          Läuft bei mir bereits ein paar Tage einwandfrei, hätte dennoch eine Frage…

                          ...ist es denn auch möglich die über Blockly erstellten Texteinträge farbig dazustellen?

                          Bisher habe ich es nur geschafft mit Beispiel im Textblock den Text fett zu formatieren.

                          Liebe Grüße

                          Stefan

                          1 Reply Last reply Reply Quote 0
                          • ruhr70
                            ruhr70 last edited by

                            @ld.stge:

                            …ist es denn auch möglich die über Blockly erstellten Texteinträge farbig dazustellen?

                            Bisher habe ich es nur geschafft mit Beispiel im Textblock den Text fett zu formatieren. `

                            Wenn Du die globale event() Funktion verwendest, kannst Du mit dem dritten Parameter die ganze Zeile in einer Farbe einfärben.

                            Im Text funktioniert das wie mit dem

                            Das ist ein Beispiel
                            ````.
                            
                            Färbt das Wort Beispiel blau-
                            1 Reply Last reply Reply Quote 0
                            • L
                              ld.stge last edited by

                              Wow… perfect.

                              You made my day. 😄

                              Besten Dank

                              Grüße

                              Stefan

                              1 Reply Last reply Reply Quote 0
                              • RK62
                                RK62 last edited by

                                Kann es sein, dass die Löschung in den Wochentagen nicht mehr richtig funktioniert?

                                Ich habe das Script etwas modifiziert deshalb stimmen die Zeilennummern nicht genau überein.

                                Jeden Abend kommt diese Meldung im Log:

                                2018-05-26 00:00:00.077  - error: javascript.0 Error in callback: ReferenceError: eventlist is not defined
                                2018-05-26 00:00:00.084  - error: javascript.0     at Object.tagesstart (script.js.esk_prod.AdapterEventList:360:21)
                                2018-05-26 00:00:00.089  - info: javascript.0 script.js.esk_prod.AdapterEventList: [Eventlist default] —————[ Samstag, 26.05.2018 ]—————
                                
                                

                                Das ist bei mir diese Zeile:

                                ~~![](</s><URL url=)https://i.imgur.com/Xz06QEv.png" />

                                Die Inhalte Wochentage werden jetzt auch nicht gelöscht sondern fortgeschrieben.

                                Habe die letzten 3 "Samstage" im Samstag.

                                Oder wurde an den Objekten etwas geändert und ich hätte die für das neue Skript alle mal neu anlegen müssen?

                                Danke, Ralf~~

                                1 Reply Last reply Reply Quote 0
                                • ruhr70
                                  ruhr70 last edited by

                                  Ich schau heute Abend mal danach

                                  Gesendet von iPhone mit Tapatalk

                                  1 Reply Last reply Reply Quote 0
                                  • ruhr70
                                    ruhr70 last edited by

                                    @RK62:

                                    Das ist bei mir diese Zeile: `

                                    sorry. das ist ein Fehler. Die Zeile muss gegen:

                                    `jsonArr[liste] = [];[/code]`
                                    
                                    ersetzt werden.
                                    
                                    Danke für das Log!
                                    
                                    Allerdings ist noch ein zweiter Fehler drin, den ich gerade noch korrigiere.
                                    
                                    Version folgt.
                                    
                                    1 Reply Last reply Reply Quote 0
                                    • ruhr70
                                      ruhr70 last edited by

                                      Zweiter Fehler ist auch korrigiert:

                                      In

                                      function setSubscriptions() {
                                      
                                          on({id:triggerArr,change:'any'}, function (obj) {  // wenn ein neuer Event geschrieben wird
                                              var eventlist = obj.name.replace(pfad,"").replace(".event","");
                                              var inWochentag = listenJson[eventlist].inWochtag;
                                              if (typeof inWochentag == "undefined") inWochentag = defaultInWochenTag;
                                              if (!obj.newState.ack && obj.newState.val) {
                                                  if(logOn) log("Event für die Liste '" + eventlist + "' erkannt: " + obj.state.val);
                                                  writeEvent(obj.state.val,eventlist);
                                                  if(obj.state.val == tagesstartTxt()) return; // 0.2.3 Fix: Tagesstart: nicht noch einmal in eine andere Liste schreiben
                                                  if(wochentagStr() != eventlist) {                               // zusätzlich in die Wochentagsliste schreiben, außer es war ein Eintrag für den Wochentag
                                                      if(inWochentag) writeEvent(obj.state.val,wochentagStr());   // nicht schreiben, wenn die Liste von der Wochentagliste ausgenommen ist
                                                  }
                                                  if(wochentagStr() != "heute") {                                 // zusätzlich in die Tagesliste schreiben, außer es war ein Eintrag für die Liste "heute"
                                                  if(inWochentag) writeEvent(obj.state.val,"heute");              // nicht schreiben, wenn die Liste von der Wochentagliste ausgenommen ist
                                                  }
                                              }
                                          });
                                          if(logOn) log("Skript: " + name + " -> Subscriptions angelegt");    
                                      }
                                      
                                      

                                      Wurde die Zeile:

                                                  if(obj.state.val == tagesstartTxt()) return; // 0.2.3 Fix: Tagesstart: nicht noch einmal in eine andere Liste schreiben
                                      

                                      hinzugefügt.

                                      Ich stelle auch das komplette Vorne ein.

                                      1 Reply Last reply Reply Quote 0
                                      • ruhr70
                                        ruhr70 last edited by

                                        Version 0.2.3 im 1. Post abgelegt

                                        Zwei Änderungen:

                                        In der Funktion tagesstart() einen Variablennamen korrigiert:

                                         `jsonArr[liste] = []; // 0.2.3 Fix[/code]`
                                        
                                        In der Funktion **~~[b]~~on()[/b]** eine Zeile hinzugefügt, um doppelte Tagesstarteinträge zu verhindern:
                                        
                                        `~~[code]~~            if(obj.state.val == tagesstartTxt()) return; // 0.2.3 Fix: Tagesstart: nicht noch einmal in eine andere Liste schreiben[/code]`
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • apollon77
                                          apollon77 last edited by

                                          Hi @ruhr70,

                                          ist die Array-Erweiterung "enthaelt" wirklich nötig?

                                          ein arrayTage.indexOf(string)!==-1 ist equivalent zu "true" … und ===-1 ist false ...

                                          1 Reply Last reply Reply Quote 0
                                          • ruhr70
                                            ruhr70 last edited by

                                            @apollon77:

                                            Hi @ruhr70,

                                            ist die Array-Erweiterung "enthaelt" wirklich nötig?

                                            ein arrayTage.indexOf(string)!==-1 ist equivalent zu "true" … und ===-1 ist false ... `

                                            Habe mir das gerade noch einmal angesehen. War wohl zu kompliziert gedacht. Danke!

                                            Deine Variante klingt um einiges performanter. :mrgreen:

                                            Wieder was gelernt.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.1k
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript template
                                            28
                                            112
                                            17406
                                            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