Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [Script] MessageHandler: Nachrichten protokollieren +VIS

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.7k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.2k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

[Script] MessageHandler: Nachrichten protokollieren +VIS

Scheduled Pinned Locked Moved JavaScript
336 Posts 25 Posters 70.2k Views 40 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • D der-eine

    @Tirador danke, genau so brauch ichs fürs Wiki! :+1:

    @all zeigt uns doch mal eure Messages damit wir sie ins Wiki aufnehmen können. :grin:

    B Offline
    B Offline
    BoehserWolf
    wrote on last edited by
    #266

    @der-eine
    Noch zwei Meldungen für alle die eine USV haben und per NUT überwachen.

    f1954a0d-a773-4ec4-bec7-feab24cc9efa-grafik.png

    MessageStateCreator:

    // USV Alarmmeldungen
    {
    	msgID: 'USV_ALARM', 
    	triggerDP: 'nut.0.status.online',
    	postMsgDP: {dp:'nut.0.status.online', comp: '!=', val:true},
    	removeMsgDP: {dp:'nut.0.status.online', comp: '==', val:true}, // Nachricht enfernen, wenn die Bedingung eintritt
    	msgText_1: {text: 'Stromausfall'},
    	countEventsDP: ''
    },
    

    32f0e76c-4eb1-4d01-8328-924c411156e2-grafik.png
    MessageStateCreator:

    // USV Alarmmeldungen
    {
    	msgID: 'USV_ALARM', 
    	triggerDP: 'nut.0.status.replacebattery',
    	postMsgDP: {dp:'nut.0.status.replacebattery', comp: '==', val:true},
    	removeMsgDP: {dp:'nut.0.status.replacebattery', comp: '!=', val:true}, // Nachricht enfernen, wenn die Bedingung eintritt
    	msgText_1: {text: 'Batterie defekt, tauschen'},
    	countEventsDP: ''
    },
    

    MessageHandler:

    // USV Alarmmeldungen
    USV_ALARM:
    {
    	msgEvent: [''], 
    	logType: 'LAST', 
    	severity: 'ALARM', 
    	msgHeader: "USV", 
    	msgText: "", 
    	quit: false, 
    	visView: 'pageStatus', 
    	mdIcon: 'power_off', 
    	mdIconColor: '', 
    	fontColor: '', 
    	backgroundColor: ''
    },
    
    1 Reply Last reply
    0
    • I Offline
      I Offline
      intruder7
      wrote on last edited by
      #267

      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...:+1:

      T 1 Reply Last reply
      0
      • D Offline
        D Offline
        der-eine
        wrote on last edited by
        #268

        Danke @Saschag & @BoehserWolf Messages habe ich mit aufgenommen. :+1:

        1 Reply Last reply
        0
        • UhulaU Offline
          UhulaU Offline
          Uhula
          wrote on last edited by
          #269

          @Tirador Ein Hinweis, wie man die Vergleiche der DP zum Triggern/Removen alternativ und flexibler eingeben könnte:

          triggerDP: 'nut.0.status.replacebattery',
          postMsgDP: {cond:'nut.0.status.replacebattery==true'},
          removeDP: {cond:'nut.0.status.replacebattery!=true'},
          

          Dann könnte man auch mit Template-Strings (``) arbeiten (wenn triggerDP zur Laufzeit bekannt ist):

          triggerDP: 'nut.0.status.replacebattery',
          postMsgDP: {cond:`${triggerDP}==true`},
          removeDP: {cond:`${triggerDP}!==true`},
          

          Dann würde auch so etwas gehen:

          triggerDP: 'nut.0.status.replacebattery',
          postMsgDP: {cond:'nut.0.status.replacebattery==0 || nut.0.status.replacebattery==2'},
          removeDP: {cond:'nut.0.status.replacebattery==1 || nut.0.status.replacebattery==3'},
          
          triggerDP: 'nut.0.status.replacebattery',
          postMsgDP: {cond:`${triggerDP}==0 || ${triggerDP}==2`},
          removeDP: {cond:`${triggerDP}==1 || ${triggerDP}==3`},
          

          Du kannst solche String-Anweisungen dann in Javascript einfach via eval() ausführen lassen. Nur, falls eine solche Flexibilität mal gefordert wird. Es sind dann alle Vergleiche möglich, sogar Umrechnungen usw. - eben alles, was gültiges Javascript ist.

          Uhula - Leise und Weise
          Ex: ioBroker on Gigabyte NUC Proxmox

          T 1 Reply Last reply
          0
          • UhulaU Uhula

            @Tirador Ein Hinweis, wie man die Vergleiche der DP zum Triggern/Removen alternativ und flexibler eingeben könnte:

            triggerDP: 'nut.0.status.replacebattery',
            postMsgDP: {cond:'nut.0.status.replacebattery==true'},
            removeDP: {cond:'nut.0.status.replacebattery!=true'},
            

            Dann könnte man auch mit Template-Strings (``) arbeiten (wenn triggerDP zur Laufzeit bekannt ist):

            triggerDP: 'nut.0.status.replacebattery',
            postMsgDP: {cond:`${triggerDP}==true`},
            removeDP: {cond:`${triggerDP}!==true`},
            

            Dann würde auch so etwas gehen:

            triggerDP: 'nut.0.status.replacebattery',
            postMsgDP: {cond:'nut.0.status.replacebattery==0 || nut.0.status.replacebattery==2'},
            removeDP: {cond:'nut.0.status.replacebattery==1 || nut.0.status.replacebattery==3'},
            
            triggerDP: 'nut.0.status.replacebattery',
            postMsgDP: {cond:`${triggerDP}==0 || ${triggerDP}==2`},
            removeDP: {cond:`${triggerDP}==1 || ${triggerDP}==3`},
            

            Du kannst solche String-Anweisungen dann in Javascript einfach via eval() ausführen lassen. Nur, falls eine solche Flexibilität mal gefordert wird. Es sind dann alle Vergleiche möglich, sogar Umrechnungen usw. - eben alles, was gültiges Javascript ist.

            T Offline
            T Offline
            Tirador
            wrote on last edited by
            #270

            @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
            0
            • I intruder7

              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...:+1:

              T Offline
              T Offline
              Tirador
              wrote on last edited by
              #271

              @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...:+1:

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

              I 1 Reply Last reply
              0
              • T Tirador

                @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...:+1:

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

                I Offline
                I Offline
                intruder7
                wrote on last edited by
                #272

                @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
                0
                • D Offline
                  D Offline
                  der-eine
                  wrote on last edited by
                  #273

                  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
                  0
                  • T Offline
                    T Offline
                    Tirador
                    wrote on last edited by Tirador
                    #274

                    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
                    0
                    • T Offline
                      T Offline
                      Tirador
                      wrote on last edited by
                      #275

                      @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
                      0
                      • T Offline
                        T Offline
                        Tirador
                        wrote on last edited by
                        #276

                        @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
                        0
                        • S Saschag

                          @der-eine
                          so habe heute auf die Version 0.7 umgestellt und nun sieht es beim iPhone leider wie bei Dir aus ;-(

                          D Offline
                          D Offline
                          der-eine
                          wrote on last edited by
                          #277

                          @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
                          0
                          • D der-eine

                            @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 Offline
                            S Offline
                            Saschag
                            wrote on last edited by
                            #278

                            @der-eine

                            Super !! Danke sieht viel besser aus :grin:

                            1 Reply Last reply
                            0
                            • C Offline
                              C Offline
                              Conquest
                              wrote on last edited by
                              #279

                              @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
                              0
                              • H Offline
                                H Offline
                                HoffmannOs
                                wrote on last edited by HoffmannOs
                                #280

                                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
                                0
                                • H 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 Offline
                                  T Offline
                                  Tirador
                                  wrote on last edited by
                                  #281

                                  @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
                                  0
                                  • T Tirador

                                    @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 Offline
                                    T Offline
                                    Tirador
                                    wrote on last edited by
                                    #282

                                    @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
                                    0
                                    • T Tirador

                                      @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 Offline
                                      T Offline
                                      Tirador
                                      wrote on last edited by Tirador
                                      #283

                                      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
                                      0
                                      • T 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 Offline
                                        T Offline
                                        Tirador
                                        wrote on last edited by
                                        #284

                                        Habe jetzt eine stabiliserte Version:

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

                                        1 Reply Last reply
                                        0
                                        • T Tirador

                                          Ich habe ein paar Skript erstellt als Infrastruktur zur Protokollierung von Nachrichten/Ereignissen.
                                          Zusätzlich gibt es ein MDCSS v2 Widget, dass die protokollierten Nachrichten anzeigt.
                                          Nachrichten können damit als kompakte Darstellung des globalen Systemzustands in VIS verwendet werden.

                                          Die Idee ist es, alle relevanten Informationen auf "einen Blick" zu erkennen. Wichtige und kritische Ereignisse werden daher in der Liste zentral oben platziert. Unwichtigere Informationen eher unten.

                                          Beispiel Vis-Ansicht:
                                          demo_messagehandler.gif

                                          Beispiel: Lovelace-Ansicht
                                          lovelace.png

                                          Kernfunktionen:

                                          • Ermöglicht es Nachrichten aus Skripten auszulösen und zu entfernen. Dies kann über zwei Wege erfolgen:

                                            • Automatisches Erzeugen/Entfernen von Nachrichten über das Javascript MessageStateCreator.

                                              • Es werden konfigurierte Datenpunkte überwacht und bei konfigurierten Bedingungen Nachrichten erzeugt oder auch entfernt.
                                              • Die Textausgabe der Nachrichten kann auch konfiguriert werden und dynamisch erzeugt werden.
                                              • Nachrichten können erst nach einer Verzögerungszeit ausgelöst werden.
                                              • Nachrichten können kontinuierlich nach einer Wiederholungszeit ausgelöst werden (dient zum erneuten Senden von Pushs per Email / Telegram)
                                            • Javascript-Funktionen postMessage(..) oder removeMessage(..) für den Einsatz in eigenen Skripten.

                                          • Es können entweder alle Nachrichten eines Nachrichtentyps protokolliert werden oder immer nur die letzte eingetretende Nachricht.

                                          • Nachrichten werden nach Prioritäten visuell in VIS dargestellt. Es stehen zwei VIS-Ausgaben zur Verfügung:

                                            • einfache HTML-Tabelle (ohne Schnickschnack)
                                          • Lovelace-Kartenausgabe über Markdown-Card mit Datenpunkt {0_userdata.0.messageHandler.messages.markdown}

                                          • Material Design CSS 2.0 Card für Uhula.

                                          • Nachrichten können (optional) in VIS global und auch einzeln quittiert werden.

                                          • Nachrichten können mit einem VIS-View verknüpft werden. Aus dem VIS Widget kann somit direkt in den View verzweigt werden.

                                          • Mit einer Nachricht können ein oder mehrere Ereignisse ausgelöst werden:

                                            • Senden einer Email
                                            • Senden einer Pushover-Nachricht
                                            • Senden einer Telegram-Pushnachricht
                                          • Nachrichtendefinition: Nachrichten werden über eine Konfigurationsstruktur definiert und damit wesentliche Eigenschaften der Nachricht bestimmt, darunter:

                                            • Nachrichtenüberschrift
                                            • Nachrichtentext
                                            • Kritikalität (Information, Warnung, Alarm etc.) / Priorität
                                            • Icon für die VIS Ausgabe
                                            • Farbe des Icons
                                            • VIS-View
                                            • Nachrichtenereignis (Senden eines Telegrams / Email)

                                          Beispiele für Nachrichten:

                                          • Alarmanlage ausgelöst!
                                          • Wasseralarm
                                          • Erinnerung Fenster lüften!
                                          • Erinnerung Fenster zu lange geöffnet!
                                          • Aktuell offene Fenster
                                          • Aktuell
                                          • Aktuell offene Türen
                                          • Lichter angeschaltet
                                          • Aktive Steckdosen
                                          • Post im Briefkasten mit Datum letzter Einwurf
                                          • Nächster Müllabfuhrtermin mit Information zur Tonne
                                          • DWD Wetterwarnung
                                          • Bewegung erkannt
                                          • Internetverbindung Offline
                                          • Termine des Tages
                                          • Termine morgen
                                          • Corona-Statistiken
                                          • Temperaturen
                                          • ...

                                          Sourcen / Anleitung und Projekt auf Github:

                                          https://github.com/St0Ma/ioBroker-MessageHandler

                                          In diesem Thread könnt ihr gerne Fragen stellen. Ich versuche im Rahmen meiner Möglichkeiten Support zu geben.

                                          M Offline
                                          M Offline
                                          Mike Hellracer
                                          wrote on last edited by
                                          #285

                                          @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
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          473

                                          Online

                                          32.7k

                                          Users

                                          82.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe