Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. Material Design Widgets: Alerts Widget

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Material Design Widgets: Alerts Widget

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

      ich habe ein script "geschrieben" welches aus den dwd Unwetterwarnungen einen JSON erzeugt, der dann als Allert angezeigt wird.
      Der Text wird als "onclick" erzeugt und befüllt einen State.

      var dwdBackground = [
      		    	"",        // 0
      			    "#ffeb3b", // 1 - Wetterwarnungen (Stufe 1)
      			    "#fb8c00", // 2 - Warnungen vor markantem Wetter (Stufe 2)
      			    "#e53935", // 3 - Unwetterwarnungen (Stufe 3)
      			    "#880e4f", // 4 - Warnungen vor extremem Unwetter (Stufe 4)
      			    "",        // 5 -
      			    "",        // 6 -
      			    "",        // 7 -
      			    "",        // 8 -
      			    "#c99afe", // 9 - Hitzewarnung
      			    "",        // 10
      			    "#c9f",    // 11 - Keine Warnungen
      			    "",        // 12 -
      			    "",        // 13 -
      			    "",        // 14 -
      			    "",        // 15 -
      			    "",        // 16 -
      			    "",        // 17 -
      			    "",        // 18 -
      			    "#fe68fe", // 19 - UV-Warnung
      	        ];
      var indexwar;
      
      on({id: /^dwd\.0\..+object$/}, function (dp) {
          var warning_id = dp.id;
          let pos= warning_id.lastIndexOf('.');
          warning_id = warning_id.substr(0, pos);
          log("Warning_id: " + warning_id);
      
              let headline_state = getState(warning_id + '.headline').val
              let headline = "<p onClick=\"servConn.setState('0_userdata.0.materialdesignwidgets.onlick_alert','" + warning_id + "')\">" + headline_state + "</p>";
      	    let level = getState(warning_id + '.level'/*Warning level*/).val;        
      	    let backgroundcolor = dwdBackground[getState(warning_id + '.severity').val]
      		
              if (headline_state != '') {
                  log("hintergrund: " + backgroundcolor);
                  log("headline: " + headline)
                  materialDesignWidgets.sendTo('0_userdata.0.materialdesignwidgets.alarmDWD', headline, backgroundcolor);
              }
      })
      

      jetzt aktualisiert dwd alle 5 Minuten die Warungen und schreibt diese immer wieder neu in die JSON. ich würde jetzt gern den alten eintrag mit der selbern Warning_id löschen, so das immer nur die letzt drin stehen bleibt bzw. beim löschen der Warnung auch der ensprechende Eintrag gelöscht wird.

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

        @Scrounger

        Hallo,
        vielleicht kann mir jemand von euch helfen. Ich habe das Script unter Global abgelegt. Allerdings bekomme ich folgende Fehler im Log:

        
        javascript.0	2020-10-24 16:28:56.471	error	(22634) at processImmediate (internal/timers.js:461:21)
        javascript.0	2020-10-24 16:28:56.470	error	(22634) at Immediate.<anonymous> (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5384:37)
        javascript.0	2020-10-24 16:28:56.470	error	(22634) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:469:25)
        javascript.0	2020-10-24 16:28:56.470	error	(22634) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1065:38)
        javascript.0	2020-10-24 16:28:56.469	error	(22634) at Object.<anonymous> (script.js.smarthome.system.Test_Alert:13:11)
        javascript.0	2020-10-24 16:28:56.469	error	(22634) at alertMessages (script.js.smarthome.system.Test_Alert:5:27)
        javascript.0	2020-10-24 16:28:56.468	error	(22634) at Object.materialDesignWidgets.sendTo (script.js.smarthome.system.Test_Alert:19:10)
        javascript.0	2020-10-24 16:28:56.467	error	(22634) script.js.smarthome.system.Test_Alert: TypeError: json.push is not a function
        
        
        1 Reply Last reply Reply Quote 0
        • F
          fabian.krauss @liv-in-sky last edited by

          @liv-in-sky said in Material Design Widgets: Alerts Widget:

          @n3ucr0n
          ich nutze als globales script dieses hier um einträge zu löschen

          var materialDesignWidgets = {};
          materialDesignWidgets.sendTo = function (id, text, backgroundColor = '', borderColor = '', icon = '', iconColor = '', fontColor = '') {
             let json = getState(id).val;
           log(id)
             if (json) {
                 try {
          
                     json = JSON.parse(json);
          
                 } catch (e) {
                     json = [];
                     console.warn('Wert ist kein JSON string! Wert wird ersetzt!');
                 }
             } else {
                 json = [];
             }
          
             json.push(
                 {
                     text: text,
                     backgroundColor: backgroundColor,
                     borderColor: borderColor,
                     icon: icon,
                     iconColor: iconColor,
                     fontColor: fontColor
                 }
             )
             setState(id, JSON.stringify(json), true);
            //     setState(id, json, true);
          }
          
          var myJson22aa;
          var myObj22aa;
          var count22aa;
          
          materialDesignWidgets.delete= function (id, textinput) {
          
          myJson22aa=getState(id).val
          myObj22aa=JSON.parse(myJson22aa)
          count22aa=0;
          
          if (myObj22aa.length>0){
          for(let i = 0; i < myObj22aa.length; i++) { 
          if(myObj22aa[i].text == textinput)   count22aa++;}
          
          //log("count" +"   "+count22aa.toString())
          
          if (count22aa>1){
          
                         for(let i = 0; i < myObj22aa.length; i++) {
                            if(myObj22aa[i].text == textinput) {myObj22aa.splice(i, 1);
                            i--;
                            log("bin in viele")}
                         }
                         }else{
                            for(let i = 0; i < myObj22aa.length; i++) {
                             if(myObj22aa[i].text == textinput) {myObj22aa.splice(i, 1);
                             log("bin in einem")}
                            }
                         }
            
          
          
          //  log(JSON.stringify(myObj22aa))
          
          if (count22aa>0) setState(id,JSON.stringify(myObj22aa));
          
          count22aa=0
          }
          }
          
          
          
          
          
          
          
          
          

          z.b.der befehl zum löschen eines eintrages:

          materialDesignWidgets.delete('controll-own.0.AAATEST.TestString2', 'WARNUNG 1234 ');
          

          oder allgemein:

          materialDesignWidgets.delete( 'id des alert datenpunktes', 'verwendeter text des alerts);

          @liv-in-sky: Bin von dem Thema wieder abgekommen und hatte es jetzt wieder auf meinem Back-Log auf Trello gefunden 🙂
          Hab hier rein geschaut und zack dein Skript funktioniert sofort. Vielen Dank fürs Teilen!

          Viele Grüße
          Fabi

          1 Reply Last reply Reply Quote 1
          • Fabsi
            Fabsi last edited by

            Hi,

            Habe soweit alles eingerichtet bekommen. Auf dem PC funktioniert das mit dem Widget wunderbar (wenn ein Runtime auf dem PC öffne). Nur auf dem Android 10 Tablet klappt das nicht so richtig. Ich öffne die iobroker.vis App und verbinde mich mit meinem Host. Alles wird angezeigt und ich kann auch alles schalten und walten. Nur das Alert Widget funktioniert nicht. Wenn ich auf dem Tablet mit einem Browser (chrome) die Vis anzeige öffne, wirds auch alles angezeigt. Woran kann das liegen?

            LG

            F 1 Reply Last reply Reply Quote 0
            • F
              fabian.krauss @Fabsi last edited by

              @Fabsi Der Material Design Widget Adapter unterstützt die Iobroker App nicht richtig. (Steht so auch auf Git).
              Die App ist schon seit Jahren nix mehr richtiges und hat Bugs. Mein Tipp: Verwende Fullybrowser 😉

              R 1 Reply Last reply Reply Quote 0
              • R
                Rosi8818 @fabian.krauss last edited by

                kann mir einer einen Tipp geben, ich stehe auf dem Schlauch und bin noch ziemlicher JS Anfänger.
                Ich spiele gerade mit dem materialDesignWidgets.delete was mir zusätzlich sehr gut gefällt.

                Welchen Befehl soll ich mir "ergoogeln", das ich das die Message durchsuchen kann die ich löschen möchte, aber nicht
                .Text == "Keller voll Wasser" sondern .Text == "Keller*****" .
                Also alles was mit Keller beginnt.

                liv-in-sky 1 Reply Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @Rosi8818 last edited by

                  @rosi8818

                  .text.include("Keller") ist wahr oder falsch - findet alle Keller im text

                  .text.indexOf('Keller')==0 - dann ist Keller am anfang, bei größer 0 ist es an dieser stelle, bei -1 ist es garnich da

                  1 Reply Last reply Reply Quote 1
                  • R
                    Rosi8818 last edited by

                    @liv-in-sky super, danke dann werde ich mal basteln 🙂

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

                      @rosi8818 der Thread ist zwar schon alt aber wie ist der Stand bei Dir?

                      ich habe das jetzt so gelöst:

                      var id = '0_userdata.0.VIS.alerts'/*alerts*/;
                      var alerts = getState(id).val;
                      var json = JSON.parse(alerts);
                      
                      var stringToDelete = "Hallo";
                      
                      const index = json.findIndex(x => x.text === stringToDelete);
                      
                      if (index !== undefined) {
                      
                          delete json[index];
                          var text = JSON.stringify(json);
                      
                          text = text.replace(",null]", "]");
                          text = text.replace(",null,",",");
                      
                          setState(id, text);
                      
                      }
                      

                      ist nicht schön aber tut was es soll, allerdings nur, wenn der exacte String gefunden wird.
                      Vielleicht kann man die Funktion von @Scrounger damit noch erweitern.
                      Evtl. ja noch mit RegEx verfeinern, da kenne ich mich leider gar nicht mit aus.

                      Gruß,
                      Mark

                      M R 2 Replies Last reply Reply Quote 0
                      • M
                        mark77 @mark77 last edited by

                        und nochmal etwas abgewandelt.

                        Einen Datenpunkt erstellen, was gelöscht werden soll.

                        var alertsId      = '0_userdata.0.VIS.alerts'/*alerts -  das JSON für die VIS-Darstellung*/;
                        var alertDeleteId = '0_userdata.0.VIS.alertDelete'/*alertDelete -  der Datenpunkt für den zu löschenden String*/;
                        
                        on(alertDeleteId, function(obj) {
                        
                            var alerts = getState(alertsId).val;
                            var json = JSON.parse(alerts);
                        
                            var stringToDelete = obj.state.val;
                        
                            const index = json.findIndex(x => x.text === stringToDelete);
                        
                            if (index !== undefined) {
                        
                                delete json[index];
                                var text = JSON.stringify(json);
                        
                                text = text.replace(",null]", "]");
                                text = text.replace(",null,",",");
                        
                                setState(alertsId, text);
                        
                            }
                        
                        })
                        
                        1 Reply Last reply Reply Quote 0
                        • R
                          Rosi8818 @mark77 last edited by

                          @mark77 , ich habe nur wenig damit gebastelt ansonsten bin ich da nicht weitergekommen wegen Probleme privater Natur die nicht aufgeschoben werden konnten.
                          Das Thema ist aber noch nicht vom Tisch, ich versuche mich demnächst weiter daran und werde es hier mitteilen. Dein Beispiel kann ich dann nehmen um es etwas einfacher zu haben.
                          Sorry, mehr habe ich nicht 😉

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

                            Ich wollte mich nun auch mal an diesem Widget für die VIS probieren, das Script habe ich unter global abgelegt. So muss ich in diesem Script noch was ändern ?
                            Brauch ich für jede Warnmeldung ein extra Script ? Oder ist das eins für alle Meldungen, die ich haben möchte ?

                            Hier wird immer ein DP angelet, muss ich also die Zeile aus dem Script abändern ?

                            materialDesignWidgets.sendTo = function (id, text, backgroundColor = '', borderColor = '', icon = '', iconColor = '', fontColor = '') {
                            
                            Glasfaser 1 Reply Last reply Reply Quote 0
                            • Glasfaser
                              Glasfaser @D3ltoroxp last edited by

                              @d3ltoroxp sagte in Material Design Widgets: Alerts Widget:

                              das Script habe ich unter global abgelegt. So muss ich in diesem Script noch was ändern ?

                              Nein , ist schon so fertig , nichts ändern.

                              Brauch ich für jede Warnmeldung ein extra Script ?

                              Am Threadanfang siehst du ein Beispiel , wie man es nutzen kann

                              https://forum.iobroker.net/topic/29663/material-design-widgets-alerts-widget/4

                              D3ltoroxp 1 Reply Last reply Reply Quote 1
                              • D3ltoroxp
                                D3ltoroxp @Glasfaser last edited by D3ltoroxp

                                @glasfaser Ok ich hab es jetzt zum laufen gebracht genau nach der verlinkten Anleitung, vielen Dank an der Stelle.

                                Nur wie stelle ich das jetzt an, das ich mehrere Meldungen auf dem Display habe ? Ich habe mal versucht händisch in den DP verschiedene Messages zu schreiben, es steht immer nur ein Alarm mit der letzten Meldung auf dem Display, im Widget habe ich eingestellt 8 z.B.

                                EDIT ::

                                Ich hab auch noch die Variante gefunden um das Alert automatisch löschen zu lassen, daran hab ich mich auch mal versucht, aber das löschen klappt noch nicht.

                                Das ist mein Blockly für das erstellen und eigentlich löschen eines Alerts.

                                a1c83592-b9e1-4f1d-a113-35082a8898d8-grafik.png

                                Das ist das abgeänderte Script von @liv-in-sky

                                
                                
                                var materialDesignWidgets = {};
                                
                                materialDesignWidgets.sendTo = function (id, text, backgroundColor = '', borderColor = '', icon = '', iconColor = '', fontColor = '') {
                                
                                   let json = getState(id).val;
                                
                                 log(id)
                                
                                   if (json) {
                                
                                       try {
                                
                                 
                                
                                           json = JSON.parse(json);
                                
                                 
                                
                                       } catch (e) {
                                
                                           json = [];
                                
                                           console.warn('Wert ist kein JSON string! Wert wird ersetzt!');
                                
                                       }
                                
                                   } else {
                                
                                       json = [];
                                
                                   }
                                
                                 
                                
                                   json.push(
                                
                                       {
                                
                                           text: text,
                                
                                           backgroundColor: backgroundColor,
                                
                                           borderColor: borderColor,
                                
                                           icon: icon,
                                
                                           iconColor: iconColor,
                                
                                           fontColor: fontColor
                                
                                       }
                                
                                   )
                                
                                   setState(id, JSON.stringify(json), true);
                                
                                  //     setState(id, json, true);
                                
                                }
                                
                                 
                                
                                var myJson22aa;
                                
                                var myObj22aa;
                                
                                var count22aa;
                                
                                 
                                
                                materialDesignWidgets.delete= function (id, textinput) {
                                
                                 
                                
                                myJson22aa=getState(id).val
                                
                                myObj22aa=JSON.parse(myJson22aa)
                                
                                count22aa=0;
                                
                                 
                                
                                if (myObj22aa.length>0){
                                
                                for(let i = 0; i < myObj22aa.length; i++) { 
                                
                                if(myObj22aa[i].text == textinput)   count22aa++;}
                                
                                 
                                
                                //log("count" +"   "+count22aa.toString())
                                
                                 
                                
                                if (count22aa>1){
                                
                                 
                                
                                               for(let i = 0; i < myObj22aa.length; i++) {
                                
                                                  if(myObj22aa[i].text == textinput) {myObj22aa.splice(i, 1);
                                
                                                  i--;
                                
                                                  log("bin in viele")}
                                
                                               }
                                
                                               }else{
                                
                                                  for(let i = 0; i < myObj22aa.length; i++) {
                                
                                                   if(myObj22aa[i].text == textinput) {myObj22aa.splice(i, 1);
                                
                                                   log("bin in einem")}
                                
                                                  }
                                
                                               }
                                
                                  
                                
                                 
                                
                                 
                                
                                //  log(JSON.stringify(myObj22aa))
                                
                                 
                                
                                if (count22aa>0) setState(id,JSON.stringify(myObj22aa));
                                
                                 
                                
                                count22aa=0
                                
                                }
                                
                                }
                                

                                Und in meiner Funktion AlertMessage Auto Delet

                                habe ich folgendes stehen :

                                materialDesignWidgets.delete('0_userdata.0.vis.AlertWidget.AlertMessages', 'message');
                                

                                Das sagt die Log ::

                                16:58:07.594	error	javascript.0 (6468) script.js.VIS.Alerts.Sensor_connection_lost: SyntaxError: Unexpected end of JSON input
                                16:58:07.596	error	javascript.0 (6468) at Object.materialDesignWidgets.delete (script.js.VIS.Alerts.Sensor_connection_lost:80:16)
                                16:58:07.596	error	javascript.0 (6468) at AlertMessage_Auto_Delet (script.js.VIS.Alerts.Sensor_connection_lost:10:33)
                                16:58:07.597	error	javascript.0 (6468) at script.js.VIS.Alerts.Sensor_connection_lost:37:7
                                16:58:07.597	error	javascript.0 (6468) at script.js.VIS.Alerts.Sensor_connection_lost:40:3
                                
                                svenomatt 1 Reply Last reply Reply Quote 0
                                • C
                                  Coffeelover last edited by

                                  @liv-in-sky Hi. Ich versuche gerade, deine Möglichkeit zum Löschen nachzubauen. Ich bekomme allerdings das Blockly nicht hin, mit dem ich den Alert inkl. ID erzeugen / löschen kann.

                                  Anbei mein Export. Das global Script von dir habe ich übernommen unter global.
                                  In den Funktionen steht:

                                  materialDesignWidgets.sendTo('0_userdata.0.Alert.Alertmessage', id, message, color, );
                                  

                                  und
                                  materialDesignWidgets.delete(id, message);

                                  582fe3bc-1116-4fb9-bb1c-f6e05c74d06a-grafik.png

                                  <xml xmlns="https://developers.google.com/blockly/xml">
                                    <variables>
                                      <variable id="=Ut$d@[FM_%wP@Tr$e_2">id</variable>
                                      <variable id=")0Q{^m~~hxNDJ-+T2t6w">message</variable>
                                      <variable id="4u_R(nvk[1;jt$=}RtM0">color</variable>
                                    </variables>
                                    <block type="on_ext" id="htG$ftnD|+dec}BK7ONm" x="63" y="38">
                                      <mutation xmlns="http://www.w3.org/1999/xhtml" items="1"></mutation>
                                      <field name="CONDITION">any</field>
                                      <field name="ACK_CONDITION"></field>
                                      <value name="OID0">
                                        <shadow type="field_oid" id="[(0c+QMnycfw+9^U;$O7">
                                          <field name="oid">0_userdata.0.Alert.SwitchTest</field>
                                        </shadow>
                                      </value>
                                      <statement name="STATEMENT">
                                        <block type="controls_if" id="4lD40^K_uOV~GUDpAw,!">
                                          <value name="IF0">
                                            <block type="logic_compare" id="KLAQ3)zE]]H(;FU(Iuty">
                                              <field name="OP">EQ</field>
                                              <value name="A">
                                                <block type="get_value" id="B!WNR-Z|]i==DZ)2*Oe3">
                                                  <field name="ATTR">val</field>
                                                  <field name="OID">0_userdata.0.Alert.SwitchTest</field>
                                                </block>
                                              </value>
                                              <value name="B">
                                                <block type="logic_boolean" id="#lUQcN/F$hn~Fs~j:TTB">
                                                  <field name="BOOL">TRUE</field>
                                                </block>
                                              </value>
                                            </block>
                                          </value>
                                          <statement name="DO0">
                                            <block type="update" id="GZ)NF${Zz8,eYE3cFn(:">
                                              <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                              <field name="OID">0_userdata.0.Alert.Alert1</field>
                                              <field name="WITH_DELAY">FALSE</field>
                                              <value name="VALUE">
                                                <block type="logic_boolean" id="W~BRjB?r+!9CY#InDqq.">
                                                  <field name="BOOL">TRUE</field>
                                                </block>
                                              </value>
                                              <next>
                                                <block type="procedures_callcustomnoreturn" id="AAZj9j=w8=Tx*h=Rd?E7">
                                                  <mutation name="AlertMaterialDesign">
                                                    <arg name="id"></arg>
                                                    <arg name="message"></arg>
                                                    <arg name="color"></arg>
                                                  </mutation>
                                                  <value name="ARG0">
                                                    <block type="math_number" id="P@Ql%#r`c]49Ak$].#;e">
                                                      <field name="NUM">5</field>
                                                    </block>
                                                  </value>
                                                  <value name="ARG1">
                                                    <block type="text" id="xNiuZ-=xz%d]#.9BS,tu">
                                                      <field name="TEXT">Neue Post im Briefkasten!</field>
                                                    </block>
                                                  </value>
                                                  <value name="ARG2">
                                                    <block type="colour_picker" id="84kKfIA}c5AiN#u/(}{+">
                                                      <field name="COLOUR">#ffcc00</field>
                                                    </block>
                                                  </value>
                                                </block>
                                              </next>
                                            </block>
                                          </statement>
                                          <next>
                                            <block type="controls_if" id="L/yG_/(ui+p~;FZ]aU@E">
                                              <value name="IF0">
                                                <block type="logic_compare" id="=azPmlDJ]tqNwR4@Rjh%">
                                                  <field name="OP">EQ</field>
                                                  <value name="A">
                                                    <block type="get_value" id="V*4jf,wckJI0/nvvWc-q">
                                                      <field name="ATTR">val</field>
                                                      <field name="OID">0_userdata.0.Alert.SwitchTest</field>
                                                    </block>
                                                  </value>
                                                  <value name="B">
                                                    <block type="logic_boolean" id="CU8qa0-N6Sf03VD[Ad=Y">
                                                      <field name="BOOL">FALSE</field>
                                                    </block>
                                                  </value>
                                                </block>
                                              </value>
                                              <statement name="DO0">
                                                <block type="update" id="uN,HM8Hy#gEX2eTn[|r=">
                                                  <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                                  <field name="OID">0_userdata.0.Alert.Alert1</field>
                                                  <field name="WITH_DELAY">FALSE</field>
                                                  <value name="VALUE">
                                                    <block type="logic_boolean" id="$9#=o3[T}t?sGp8t!iG6">
                                                      <field name="BOOL">FALSE</field>
                                                    </block>
                                                  </value>
                                                  <next>
                                                    <block type="procedures_callcustomnoreturn" id="!L`bn38vl1:c|^fj}+1]">
                                                      <mutation name="AlertMaterialDesignDelete">
                                                        <arg name="id"></arg>
                                                        <arg name="message"></arg>
                                                      </mutation>
                                                      <value name="ARG0">
                                                        <block type="math_number" id="=67e@W[4N.@91(vlg})}">
                                                          <field name="NUM">5</field>
                                                        </block>
                                                      </value>
                                                      <value name="ARG1">
                                                        <block type="text" id="s.hjQDPZq?;GMe/}1QNE">
                                                          <field name="TEXT">Neue Post im Briefkasten!</field>
                                                        </block>
                                                      </value>
                                                    </block>
                                                  </next>
                                                </block>
                                              </statement>
                                            </block>
                                          </next>
                                        </block>
                                      </statement>
                                    </block>
                                    <block type="procedures_defcustomnoreturn" id="/XN%MvZ2GnXAjVrqd=+Q" x="63" y="738">
                                      <mutation statements="false">
                                        <arg name="id" varid="=Ut$d@[FM_%wP@Tr$e_2"></arg>
                                        <arg name="message" varid=")0Q{^m~~hxNDJ-+T2t6w"></arg>
                                        <arg name="color" varid="4u_R(nvk[1;jt$=}RtM0"></arg>
                                      </mutation>
                                      <field name="NAME">AlertMaterialDesign</field>
                                      <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLnNlbmRUbygnMF91c2VyZGF0YS4wLkFsZXJ0LkFsZXJ0bWVzc2FnZScsIGlkLCBtZXNzYWdlLCBjb2xvciwgKTsg</field>
                                      <comment pinned="false" h="80" w="160">Material Design Alert</comment>
                                    </block>
                                    <block type="procedures_defcustomnoreturn" id="k/9Y,J7=/b*2eA*Gau%X" x="63" y="812">
                                      <mutation statements="false">
                                        <arg name="id" varid="=Ut$d@[FM_%wP@Tr$e_2"></arg>
                                        <arg name="message" varid=")0Q{^m~~hxNDJ-+T2t6w"></arg>
                                      </mutation>
                                      <field name="NAME">AlertMaterialDesignDelete</field>
                                      <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLmRlbGV0ZShpZCwgbWVzc2FnZSk7IA==</field>
                                      <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                                    </block>
                                  </xml>
                                  

                                  VG & Danke

                                  liv-in-sky 2 Replies Last reply Reply Quote 0
                                  • liv-in-sky
                                    liv-in-sky @Coffeelover last edited by liv-in-sky

                                    @coffeelover

                                    ich denke, du verwechsels die id

                                    die id ist der datenpunkt, die im widget als dp angegeben ist - die id steht also im javascript teil - sie ist fest, außer du hast mehrere verschiedene alert widgets

                                    das löschen sucht nach der message- die ist die "id" für das löschen

                                    import blockly

                                    <xml xmlns="https://developers.google.com/blockly/xml">
                                      <variables>
                                        <variable id="B-d2{p:M42V6flSuvK+V">message</variable>
                                        <variable id="xYJzlMC^@H4F0Gi|Dk17">color</variable>
                                      </variables>
                                      <block type="procedures_callcustomnoreturn" id="AAZj9j=w8=Tx*h=Rd?E7" x="813" y="288">
                                        <mutation name="AlertMaterialDesign">
                                          <arg name="message"></arg>
                                          <arg name="color"></arg>
                                        </mutation>
                                        <value name="ARG0">
                                          <block type="text" id="xNiuZ-=xz%d]#.9BS,tu">
                                            <field name="TEXT">Neue Post im Briefkasten!</field>
                                          </block>
                                        </value>
                                        <value name="ARG1">
                                          <block type="colour_picker" id="84kKfIA}c5AiN#u/(}{+">
                                            <field name="COLOUR">#cc0000</field>
                                          </block>
                                        </value>
                                      </block>
                                      <block type="procedures_callcustomnoreturn" id="o56fmxo^jf`YH-Gr.cNG" disabled="true" x="712" y="412">
                                        <mutation name="AlertMaterialDesignDelete">
                                          <arg name="message"></arg>
                                        </mutation>
                                        <value name="ARG0">
                                          <block type="text" id="oh0D/o3@2@/{b+XuysX/">
                                            <field name="TEXT">Neue Post im Briefkasten!</field>
                                          </block>
                                        </value>
                                      </block>
                                      <block type="procedures_defcustomnoreturn" id="/XN%MvZ2GnXAjVrqd=+Q" x="637" y="513">
                                        <mutation statements="false">
                                          <arg name="message" varid="B-d2{p:M42V6flSuvK+V"></arg>
                                          <arg name="color" varid="xYJzlMC^@H4F0Gi|Dk17"></arg>
                                        </mutation>
                                        <field name="NAME">AlertMaterialDesign</field>
                                        <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLnNlbmRUbygnMF91c2VyZGF0YS4wLkFsYXJtLU1hdGVyaWFsRGVzaWduLkhpbndlaXNlTWVzc2FnZXMnLCAgbWVzc2FnZSwgY29sb3IgKTsg</field>
                                        <comment pinned="false" h="80" w="160">Material Design Alert</comment>
                                      </block>
                                      <block type="procedures_defcustomnoreturn" id="k/9Y,J7=/b*2eA*Gau%X" x="637" y="563">
                                        <mutation statements="false">
                                          <arg name="message" varid="B-d2{p:M42V6flSuvK+V"></arg>
                                        </mutation>
                                        <field name="NAME">AlertMaterialDesignDelete</field>
                                        <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLmRlbGV0ZSgnMF91c2VyZGF0YS4wLkFsYXJtLU1hdGVyaWFsRGVzaWduLkhpbndlaXNlTWVzc2FnZXMnLCBtZXNzYWdlKTsg</field>
                                        <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                                      </block>
                                    </xml>
                                    

                                    Image 9.png

                                    du musst deine datenpunkte wieder reinschreiben - habe meine benutzt

                                    Image 10.png

                                    1 Reply Last reply Reply Quote 2
                                    • liv-in-sky
                                      liv-in-sky @Coffeelover last edited by liv-in-sky

                                      @coffeelover

                                      ich habe das bei mir anders gelöst - ich habe ein extra script und extra datenpunkte

                                      zum setzen eines alerts muss ich nur einen dp setzen
                                      zum löschen einen anderen (siehe kommentar im blockly - das kann überall - in jedem script - verwendet werden)
                                      somit muss ich nicht immer die functionen mitschleppen - natürlich könnte man das globale script damit abschalten und direkt darin eine function verwenden - war ich zu faul, um das zu ändern 😞

                                      Image 11.png

                                      Image 12.png

                                      das ,xxx, ist nur dazu da, um kommas im text verwenden zu können - ginge auch nr mit komma

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

                                        @liv-in-sky Vielen Dank - jetzt ist der Groschen gefallen. Ich hatte tatsächlich deine Lösung und die anskizzierte Lösung von Scrounger vermischt. Jetzt klappt hinzufügen und Löschen perfekt.

                                        1 Reply Last reply Reply Quote 0
                                        • svenomatt
                                          svenomatt @D3ltoroxp last edited by svenomatt

                                          bräuchte ebenfalls eure Hilfe, habe es jetzt ebenfalls hingekommen eine Nachricht anzuzeigen. was ich nicht hin gekomme mehre Nachrichten untereinander zu erzeugen. Hast du eine Losung gefunden?

                                          vielleicht kann mir jemand auf die Sprünge helfen.

                                          svenomatt 1 Reply Last reply Reply Quote 0
                                          • svenomatt
                                            svenomatt @svenomatt last edited by svenomatt

                                            @svenomatt

                                            Habe den Fehler selbst finden können. Hatte den Datenpunkt als Objekt (Zustandstyp) gewählt. Muss aber ein "String" sein.

                                            • Anbei meine Zusammenstellung.

                                            "Vielleicht kann sie jemand gebrauchen (als eine kleine Zusammenfassung zu sehen.)"

                                            folgenden geht damit

                                            • mehre Nachrichten werden angezeigt
                                            • einzelne Nachrichten können gelöscht werden. (alles mittels Blockly)
                                            1. Javascript unter "Global" anlegen

                                            var materialDesignWidgets = {};
                                            
                                            materialDesignWidgets.sendTo = function (id, text, backgroundColor = '', borderColor = '', icon = '', iconColor = '', fontColor = '') {
                                            
                                               let json = getState(id).val;
                                            
                                             log(id)
                                            
                                               if (json) {
                                            
                                                   try {
                                             
                                            
                                                       json = JSON.parse(json);
                                            
                                             
                                            
                                                   } catch (e) {
                                            
                                                       json = [];
                                            
                                                       console.warn('Wert ist kein JSON string! Wert wird ersetzt!');
                                            
                                                   }
                                            
                                               } else {
                                            
                                                   json = [];
                                            
                                               }
                                            
                                             
                                            
                                               json.push(
                                            
                                                   {
                                            
                                                       text: text,
                                            
                                                       backgroundColor: backgroundColor,
                                            
                                                       borderColor: borderColor,
                                            
                                                       icon: icon,
                                            
                                                       iconColor: iconColor,
                                            
                                                       fontColor: fontColor
                                            
                                                   }
                                            
                                               )
                                            
                                               setState(id, JSON.stringify(json), true);
                                            
                                              //     setState(id, json, true);
                                            
                                            }
                                             
                                            var myJson22aa;
                                            
                                            var myObj22aa;
                                            
                                            var count22aa;
                                            
                                            // Sucht innerhalb des Datenpunktes die Textnachricht anhand des Textinhaltes und löscht diese
                                            materialDesignWidgets.delete= function (id, textinput) {
                                            
                                            
                                            myJson22aa=getState(id).val
                                            
                                            myObj22aa=JSON.parse(myJson22aa)
                                            
                                            count22aa=0;
                                            
                                            if (myObj22aa.length>0){
                                            
                                            for(let i = 0; i < myObj22aa.length; i++) { 
                                            
                                            if(myObj22aa[i].text == textinput)   count22aa++;}
                                            
                                             //log("count" +"   "+count22aa.toString())
                                             
                                            if (count22aa>1){
                                            
                                            
                                                           for(let i = 0; i < myObj22aa.length; i++) {
                                            
                                                              if(myObj22aa[i].text == textinput) {myObj22aa.splice(i, 1);
                                            
                                                              i--;
                                            
                                                              log("bin in viele")}
                                            
                                                           }
                                            
                                                           }else{
                                            
                                                              for(let i = 0; i < myObj22aa.length; i++) {
                                            
                                                               if(myObj22aa[i].text == textinput) {myObj22aa.splice(i, 1);
                                            
                                                               log("bin in einem")}
                                            
                                                              }
                                            
                                                           }
                                              
                                            //  log(JSON.stringify(myObj22aa))
                                            
                                             
                                            if (count22aa>0) setState(id,JSON.stringify(myObj22aa));
                                            
                                             
                                            count22aa=0
                                            
                                            }
                                            
                                            }
                                            
                                            

                                            1. Datenpunkt erstellen, bei mir "sAlarm"
                                            • Wichtig der Datenpunkt muss den Zustandstyp "string" haben


                                            Screenshot 2021-11-23 135016.png
                                            Screenshot 2021-11-23 135249.png

                                            1. Blockly Funktion

                                            Screenshot


                                            Screenshot 2021-11-23 135753.png

                                            Export Blockly

                                            <xml xmlns="https://developers.google.com/blockly/xml">
                                              <variables>
                                                <variable id="FAhazIMG=Z}@HNI+T[VK">message</variable>
                                                <variable id="*]nWmg4pJG}Ljh%L_A?P">color</variable>
                                                <variable id=";lNb`g`,Cra:u/HA=zT+">borderColor</variable>
                                                <variable id="7E-?W0(WI?@#y^g=#k!5">icon</variable>
                                                <variable id="RjU^^ep#60]8Je./|ggB">iconColor</variable>
                                                <variable id="(![CothNimXpMUV8ee38">fontColor</variable>
                                              </variables>
                                              <block type="procedures_defcustomnoreturn" id="2+/YmhZKI?ON7;Y:{{2)" x="238" y="-537">
                                                <mutation statements="false">
                                                  <arg name="message" varid="FAhazIMG=Z}@HNI+T[VK"></arg>
                                                  <arg name="color" varid="*]nWmg4pJG}Ljh%L_A?P"></arg>
                                                  <arg name="borderColor" varid=";lNb`g`,Cra:u/HA=zT+"></arg>
                                                  <arg name="icon" varid="7E-?W0(WI?@#y^g=#k!5"></arg>
                                                  <arg name="iconColor" varid="RjU^^ep#60]8Je./|ggB"></arg>
                                                  <arg name="fontColor" varid="(![CothNimXpMUV8ee38"></arg>
                                                </mutation>
                                                <field name="NAME">alert-Messages</field>
                                                <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLnNlbmRUbygnMF91c2VyZGF0YS4wLnNBbGFybScsIG1lc3NhZ2UsIGNvbG9yLCBib3JkZXJDb2xvciwgaWNvbiwgaWNvbkNvbG9yLCBmb250Q29sb3IsKTsgDQog</field>
                                                <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                                              </block>
                                              <block type="procedures_defcustomnoreturn" id="vEP!05(E`0lzqNHQ}!)s" x="513" y="-487">
                                                <mutation statements="false">
                                                  <arg name="message" varid="FAhazIMG=Z}@HNI+T[VK"></arg>
                                                </mutation>
                                                <field name="NAME">alert-delet</field>
                                                <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLmRlbGV0ZSgnMF91c2VyZGF0YS4wLnNBbGFybScsIG1lc3NhZ2UpOyANCiA=</field>
                                                <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                                              </block>
                                              <block type="on" id="3iER$AuJU*~#Bq=Y!,3?" x="238" y="-463">
                                                <field name="OID">0_userdata.0.schalter</field>
                                                <field name="CONDITION">ne</field>
                                                <field name="ACK_CONDITION"></field>
                                                <statement name="STATEMENT">
                                                  <block type="controls_if" id="`|MfI?P;NlH0Dw/o3,It">
                                                    <value name="IF0">
                                                      <block type="logic_compare" id="6OusOyRZ3vVfhM%Z95y8">
                                                        <field name="OP">EQ</field>
                                                        <value name="A">
                                                          <block type="get_value" id="c{vEXdJ*^.LLs%@:h*xt">
                                                            <field name="ATTR">val</field>
                                                            <field name="OID">0_userdata.0.schalter</field>
                                                          </block>
                                                        </value>
                                                        <value name="B">
                                                          <block type="logic_boolean" id="814TkXQUVU;[/iunjS%U">
                                                            <field name="BOOL">TRUE</field>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </value>
                                                    <statement name="DO0">
                                                      <block type="procedures_callcustomnoreturn" id="r}{,:7IEsJgqmsFbJX59">
                                                        <mutation name="alert-Messages">
                                                          <arg name="message"></arg>
                                                          <arg name="color"></arg>
                                                          <arg name="borderColor"></arg>
                                                          <arg name="icon"></arg>
                                                          <arg name="iconColor"></arg>
                                                          <arg name="fontColor"></arg>
                                                        </mutation>
                                                        <value name="ARG0">
                                                          <block type="text" id="teE;3a^k](_MCro4GQh0">
                                                            <field name="TEXT">Keine neue Post</field>
                                                          </block>
                                                        </value>
                                                        <value name="ARG1">
                                                          <block type="colour_picker" id="hh[W#y(eQE]VN7l}(s=^">
                                                            <field name="COLOUR">#ff0000</field>
                                                          </block>
                                                        </value>
                                                        <value name="ARG3">
                                                          <block type="text" id="-/cEjgw%j;9o5LHKJd:]">
                                                            <field name="TEXT">pine-tree-fire</field>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </statement>
                                                    <next>
                                                      <block type="controls_if" id="`=J6Mm!(ocg`=s}dmx+S">
                                                        <value name="IF0">
                                                          <block type="logic_compare" id="c~W6f-J!3Pp^6$rZHW:J">
                                                            <field name="OP">EQ</field>
                                                            <value name="A">
                                                              <block type="get_value" id="(#9e$N9H$P0p`6],B4KA">
                                                                <field name="ATTR">val</field>
                                                                <field name="OID">0_userdata.0.schalter</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="logic_boolean" id="fQoVSDW0kLz*0XzEVQxM">
                                                                <field name="BOOL">FALSE</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <statement name="DO0">
                                                          <block type="procedures_callcustomnoreturn" id=";ml%a*}m.oMd3Dyau{^:">
                                                            <mutation name="alert-delet">
                                                              <arg name="message"></arg>
                                                            </mutation>
                                                            <value name="ARG0">
                                                              <block type="text" id="`9b+-08-A~;LKr+(`A,u">
                                                                <field name="TEXT">Keine neue Post</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </statement>
                                                      </block>
                                                    </next>
                                                  </block>
                                                </statement>
                                              </block>
                                            </xml>
                                            

                                            1. Datenpunkt mit Alertswigdet in vis einbinden


                                            Screenshot 2021-11-23 141701.png

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            726
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            vis
                                            28
                                            105
                                            12558
                                            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