Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [Script] MessageHandler: Nachrichten protokollieren +VIS

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    [Script] MessageHandler: Nachrichten protokollieren +VIS

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      Tirador @Uhula last edited by

      @Uhula Super Idee! Kommt mal auf die Todoliste.
      Allerdings würde ich aus Gründen der Abwärtskompatibilität statt "cond" einen neuen Tag "eval:" erfinden, wo man dann das eval vorgeben kann.

      1 Reply Last reply Reply Quote 0
      • T
        Tirador @intruder7 last edited by

        @intruder7 said in [Script] MessageHandler: Nachrichten protokollieren +VIS:

        Moin @all, man kann ja in der Meldung eine View aufrufen. Besteht auch die Möglichkeit einen Dialog aufzurufen? Und wenn nicht, @Tirador kann man das implementieren?

        Ansonsten super Arbeit...👍

        Was meinst Du denn mit Dialog (ein Overlay / Popup)?
        Was ist denn der Anwendungsfall dafür?

        I 1 Reply Last reply Reply Quote 0
        • I
          intruder7 @Tirador last edited by

          @Tirador
          ja genau... sowas wie ein popup. Nennt sich ja Dialog View. Anwendungsfälle hab ich viele. ich lasse mir zB beim Briefkasten die Zeit der letzten Leerung des letzten Einwurfs und ein Snapshot von der Kamera im dialog anzeigen. oder aktuell nur die Anzahl der Lichter und nach draufdrücken mit einem dynamischen table in einem Dialogview die Möglichkeit die Lampen einzeln auszuschalten oder zeigt mein Klingelbutton nur die häufigkeit an wie oft es geklingelt hat, nach dem draufdrücken die Zeiten wann es geklingelt hat, Möglichkeit des Stummschakten oder Aus für eine bestimmte Zeit oder einstellen der Mittagsruhe. Hab auch noch viele mehr.

          Ein Dialog finde ich manchmal einfach besser als extra große Views zu machen.

          Das kann auch ruhig eine Standardgröße haben die man vorher im Skript einstellt.

          Ist ja auch bloß ne Idee

          1 Reply Last reply Reply Quote 0
          • D
            der-eine last edited by

            Die Idee finde ich auch gut, wenn die Kamera eine Bewegung erkannt hat und man klickt auf die Nachricht und man bekommt ein Popup mit einem Bilder von der „Bewegung“. 🤔

            1 Reply Last reply Reply Quote 0
            • T
              Tirador last edited by Tirador

              Auch wenn es technisch reizvoll erscheint das einzubauen:
              Statt dem Dialog View kann man auch auf den normalen View umleiten. Mehr klicken brauche ich ja dann prinzipiell prinzipiell nicht.
              Und die Funktionalität kann man ja wirklich analogi im normalen View abbilden (d.h. Anzeige Screenshot, anzeige lichter / Lichtersteuerung etc.).

              Wenn jemand aber die technische Lösung für den Dialog View aufzeigt, kann ich es gerne noch integrieren.

              1 Reply Last reply Reply Quote 0
              • T
                Tirador last edited by

                @der-eine
                Du wolltest ja noch die Bilder für Gefrierschrank/Kühlschrank geöffnet:

                2020-06-14 09_13_53-vis.png

                MessageStateCreator

                    // Gefrierschrank geöffnet
                    // über eigenen Sensor
                    {
                        msgID: 'FREEZER_DOOR_ISOPEN_INFO', 
                        triggerDP: 'deconz.0.Sensors.56.open',
                        postMsgDP: {dp:'deconz.0.Sensors.56.open', comp: '==', val:true, delayTime: 60, repeatTime: 600},
                        removeMsgDP: {dp:'deconz.0.Sensors.56.open', comp: '==', val:false}, 
                        msgText_1: {text: ''},
                    },
                

                MessageHandler

                       // Offener Gefrierschrank
                        FREEZER_DOOR_ISOPEN_INFO: {msgEvent: [''], logType: 'LAST',  severity: 'ALARM',  msgHeader: "Gefrierschrank geöffnet", msgText: "Bitte Gefrierschrank schließen", quit: false, mdIcon: 'ac_unit', mdIconColor: '', fontColor: '', backgroundColor: ''},
                
                
                1 Reply Last reply Reply Quote 0
                • T
                  Tirador last edited by

                  @der-ein Alarmanlage für das Wiki.

                  Die Alarmanlage basiert auf dem Skript von andreaskos:
                  https://forum.iobroker.net/topic/32885/umfassendes-alarmanlagen-skript/3

                  Es gibt zwei Nachrichten:

                  Eine für die Ausgabe, dass die Alaramanlage an/aus ist:

                  2020-06-14 09_18_15-vis.png

                  2020-06-14 09_20_31-vis.png

                  Eine Nachricht für den ausgelösten Alarm:

                  2020-06-14 09_20_59-vis.png

                  MessageStateCreator

                      // Status Alarmanlage
                      // über Skript von andreaskos
                      // https://forum.iobroker.net/topic/32885/umfassendes-alarmanlagen-skript/3
                      {
                          msgID: 'HOUSE_ALARM_STATUS', 
                          triggerDP: ['javascript.0.Alarmanlage.Output.StatusText'],
                          postMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: false},  
                          removeMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: true}, 
                          msgText_1: {text: 'Aktiv: '},
                          msgText_2: {dp: 'javascript.0.Alarmanlage.Output.StatusText'},
                          msgText_3: {text: '<br>'},
                          msgText_4: {text: 'Status: '},        
                          msgText_5: {dp: 'javascript.0.Alarmanlage.Output.AlarmText'}
                      },
                  
                  
                      // Status Alarmanlage
                      // über Skript von andreaskos
                      // https://forum.iobroker.net/topic/32885/umfassendes-alarmanlagen-skript/3
                      {
                          msgID: 'HOUSE_ALARM_ACTIVE', 
                          triggerDP: ['javascript.0.Alarmanlage.Output.Alarm'],
                          postMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: true},  
                          removeMsgDP: {dp:'javascript.0.Alarmanlage.Output.Alarm', comp: '==', val: false}, 
                          msgText_1: {text: 'Melder: '},
                          msgText_2: {dp: 'javascript.0.Alarmanlage.Output.AlarmingDetector'},
                          msgText_3: {text: '<br>'},
                          msgText_4: {text: 'Status: '},        
                          msgText_5: {dp: 'javascript.0.Alarmanlage.Output.AlarmText'},
                          msgText_6: {text: '<br>'},
                          msgText_7: {text: 'Aktiv: '},
                          msgText_8: {dp: 'javascript.0.Alarmanlage.Output.StatusText'}
                      },
                  

                  MessageHandler

                          // Alarmanlage
                          HOUSE_ALARM_ACTIVE: {msgEvent: [''], logType: 'LAST',  severity: 'ALARM',  msgHeader: "Alarm im Haus", msgText: "", quit: true, visView: 'pageSicherheit', mdIcon: 'notification_important', mdIconColor: '', fontColor: '', backgroundColor: ''},
                  
                  

                  MessageHandler

                        // Status Alarmanlage
                          HOUSE_ALARM_STATUS: {msgEvent: [''], logType: 'LAST',  severity: 'INFO',  msgHeader: "Alarmanlage", msgText: "", quit: false, visView: 'pageSicherheit', mdIcon: 'security', mdIconColor: '', fontColor: '', backgroundColor: ''},
                  
                  
                  1 Reply Last reply Reply Quote 0
                  • D
                    der-eine @Saschag last edited by

                    @Saschag ändere mal an folgender Stelle auf 2.5em (MessageHandler) dann rutschen die Icons nach rechts und sie werden wieder vollständig auf dem iPhone angezeigt.

                    Bildschirmfoto 2020-06-16 um 18.32.42.png

                    S 1 Reply Last reply Reply Quote 0
                    • S
                      Saschag @der-eine last edited by

                      @der-eine

                      Super !! Danke sieht viel besser aus 😁

                      1 Reply Last reply Reply Quote 0
                      • C
                        Conquest last edited by

                        @Tirador

                        Hallo Tirador,
                        erstmal vielen Dank für das tolle Script.
                        Ich habe nur ein kleines Problem mit der Anzeige. Ich kann die Schriftfarbe nicht auf weiß stellen.
                        Kannst du mir helfen?

                        screenshot-192.168.178.46_8082-2020.07.15-19_38_50.png

                        1 Reply Last reply Reply Quote 0
                        • H
                          HoffmannOs last edited by HoffmannOs

                          Moin Moin,
                          ich würde gerne 2 Klingelsensoren von Homematic überwachen bzw als Log ausgeben,
                          Ich habe einmal den Normalen von Homematic und einmal den von HM IP

                          Meine Config : Message State : ```

                          
                          {
                                  msgID: 'Klingel_Sxxx',
                                  triggerDP: 'hm-rpc.1.PEQ0653xx.1.PRESS_SHORT',
                                  postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', change: "any"},
                                  msgText_1: {text: ''},
                                  countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                              },    
                          

                          Ich habe schon mehrere Varianten durch und bekomme es leider einfach nicht hin.
                          Message Handler

                          Klingel_Sxxx: {logType: 'LAST',  severity: 'WARN',  msgHeader: "Klingel Sxxx", msgText: "", quit: true, mdIcon: 'notifications_active', mdIconColor: '', fontColor: '', backgroundColor: ''},
                          
                          T 1 Reply Last reply Reply Quote 0
                          • T
                            Tirador @HoffmannOs last edited by

                            @HoffmannOs said in [Script] MessageHandler: Nachrichten protokollieren +VIS:

                            Moin Moin,
                            ich würde gerne 2 Klingelsensoren von Homematic überwachen bzw als Log ausgeben,
                            Ich habe einmal den Normalen von Homematic und einmal den von HM IP

                            Meine Config : Message State : ```

                            
                            {
                                    msgID: 'Klingel_Sxxx',
                                    triggerDP: 'hm-rpc.1.PEQ0653xx.1.PRESS_SHORT',
                                    postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', change: "any"},
                                    msgText_1: {text: ''},
                                    countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                },    
                            

                            Ich habe schon mehrere Varianten durch und bekomme es leider einfach nicht hin.
                            Message Handler

                            Klingel_Sxxx: {logType: 'LAST',  severity: 'WARN',  msgHeader: "Klingel Sxxx", msgText: "", quit: true, mdIcon: 'notifications_active', mdIconColor: '', fontColor: '', backgroundColor: ''},
                            

                            Bei dem Tag "postMsgDP" fehlt noch ein Wert mit dem die Nachricht ausgelöst wird. Du hast den Datenpunkt angegeben (dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'), den Vergleichsoperator (comp: '=='; d.h. also Vergleich mit "GLEICH"), aber es fehlt der Wert mit dem verglichen werden soll. Ich kenne HM / HM IP nicht. Wenn es ein Contact ist, kann der Datenpunkt z.B. den Wert 0/1 oder true/false annehmen. Sofern er den Wert "true" annimmt, müsste die Deklaration im MessageStateCreator so aussehen:

                                {
                            
                                    msgID: 'Klingel_Sxxx', 
                                    triggerDP: ['hm-rpc.1.PEQ0653xx.1.PRESS_SHORT'],
                                    postMsgDP: {dp:'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT', comp: '==', val: true, change: "any"},
                                    msgText_1: {text: ''},
                                    countEventsDP: 'hm-rpc.1.PEQ0653xxx.1.PRESS_SHORT'
                                }
                            
                            T 1 Reply Last reply Reply Quote 0
                            • T
                              Tirador @Tirador last edited by

                              @All: Ich experimentiere gerade mit Lovelace herum.
                              In Lovelace gibt es nativ eine Nachrichtenfunktion in der Oberfläche.

                              6cf18d0c-ca2b-4b5f-8c2d-ae28601e3631-grafik.png

                              Aktuell kann ich die Nachrichten des MessageHandlers dort schon ausgeben.

                              05caca50-7f20-4a7e-b039-2a002d5634ad-grafik.png

                              Leider gibt es nur eine Formatierung mit Markdown.
                              Natürlich kann man auch über eine eigene Card nachdenken. Eventuell hat jemand eine Idee 😉

                              T 1 Reply Last reply Reply Quote 0
                              • T
                                Tirador @Tirador last edited by Tirador

                                Ich hatte jetzt mal etwas Zeit zu tüfteln.

                                So sieht es nun aus mit der Lovelace-Visualisierung (eigene Card!):

                                7bf84609-310f-4b5e-8cdb-2185f7db6c3c-grafik.png

                                T 1 Reply Last reply Reply Quote 0
                                • T
                                  Tirador @Tirador last edited by

                                  Habe jetzt eine stabiliserte Version:

                                  f6b83963-0d6b-4d02-ab69-ea55b5cdba9f-grafik.png

                                  1 Reply Last reply Reply Quote 0
                                  • M
                                    Mike Hellracer @Tirador last edited by

                                    @Tirador
                                    Hi, habe jetzt alle Scripts installiert die DP unter userdata Messagehandler sind auch da. Aber der "count" zeigt immer 0 Nachrichten. Muss ich da noch weitere Einstellungen machen, oder müsste ich in der Grundkonfiguration zumindest mal ein paar Nachrichten sehen?

                                    D 1 Reply Last reply Reply Quote 0
                                    • D
                                      der-eine @Mike Hellracer last edited by

                                      @Mike-Hellracer wenn Du nur die Skripte eingefügt hast und nicht die Datenpunkte angepasst läuft das Skript nicht. Das siehst Du auch im Log. Sobald ein Datenpunkt bei Dir nicht existiert, wird das Skript gestoppt. Du muss im MessageCreator die Datenpunkte auf Dein System anpassen und die nicht verwendeten auskommentieren damit das Skript läuft.

                                      M 1 Reply Last reply Reply Quote 0
                                      • M
                                        Mike Hellracer @der-eine last edited by

                                        @der-eine
                                        Yep, Danke das war es.

                                        1 Reply Last reply Reply Quote 0
                                        • H
                                          HoffmannOs @der-eine last edited by

                                          @der-eine wäre aus auch mit Unifi möglich?

                                          D 1 Reply Last reply Reply Quote 0
                                          • D
                                            der-eine @HoffmannOs last edited by

                                            @HoffmannOs was genau?

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            749
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            25
                                            336
                                            40976
                                            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