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. Visualisierung
  4. Material Design Widgets: Alerts Widget

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.1k

Material Design Widgets: Alerts Widget

Scheduled Pinned Locked Moved Visualisierung
vis
105 Posts 28 Posters 18.6k Views 37 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.
  • EnduranceE Endurance

    @Tirador said in Material Design Widgets: Alerts Widget:

    Beispiel: Ich löse eine Nachricht aus, wenn ein Fenster zu lange geöffnet ist.
    Wenn jemand das Fenster schließt kann die Nachricht wieder entfernt werden.

    Hast du dazu schon eine Lösung gefunden? (eventuell kann das Script ja die richtige Message im DP wieder löschen?)

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

    @Endurance ich habe eine ganz andere Lösung dafür gefunden. Schau Mal

    MessageHandler

    1 Reply Last reply
    0
    • EnduranceE Endurance

      @Tirador
      Jetzt läuft es, eventuell ist in der Doku (https://github.com/Scrounger/ioBroker.vis-materialdesign#alerts) was falsch:
      materialDesignWidgets.sendTo('datapoint_id', 'message', 'color');

      ich habs nun so, und dann funktioniert es (bei mir zumindest)
      materialDesignWidgets.sendTo('datapoint_id', message, color); #ohne die ' vor und nach message und color

      Keine Ahnung ob das nur bei mir ein Problem war, aber eventuell kann @Scrounger ja die Doku anpassen.

      ScroungerS Offline
      ScroungerS Offline
      Scrounger
      Developer
      wrote on last edited by
      #55

      @Endurance sagte in Material Design Widgets: Alerts Widget:

      @Tirador
      Jetzt läuft es, eventuell ist in der Doku (https://github.com/Scrounger/ioBroker.vis-materialdesign#alerts) was falsch:

      Und was soll falsch sein?
      Sorry bei blockly kann ich euch nicht unterstützen, davon hab ich keine Ahnung.

      1 Reply Last reply
      0
      • C Offline
        C Offline
        Coffeelover
        wrote on last edited by
        #56

        @Endurance sagte in Material Design Widgets: Alerts Widget:

        materialDesignWidgets.sendTo('datapoint_id', message, color);

        Hi,

        da du es zum Laufen gebracht hast:

        • die oben zitierte Zeile hast du in dem Blockly hinter die <> eingefügt, oder? Inkl. Strichpunkt?
        • Hast du die Zeile auch in dem Script unter global eingefügt? Oder beginnt das mit
        var materialDesignWidgets = {};
        

        ?

        1 Reply Last reply
        1
        • EnduranceE Offline
          EnduranceE Offline
          Endurance
          wrote on last edited by
          #57

          Das wäre das Script, hab ich nicht unter Global laufen:
          6003b8b0-1a34-4e2d-8e37-f2fdaddbaf0b-image.png

          materialDesignWidgets.sendTo('0_userdata.0.Alerts.Alerts', message, color, bordercolor, icon, iconcolor, fontcolor);
          

          Das folgende läuft unter Global: (das hab ich aber auch nicht angepasst, kannst du eigentlich direkt so importieren)

          var materialDesignWidgets = {};
          materialDesignWidgets.sendTo = function (id, text, backgroundColor = '', borderColor = '', icon = '', iconColor = '', fontColor = '') {
              let json = getState(id).val;
           
              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);
          }
          
          1 Reply Last reply
          1
          • C Offline
            C Offline
            Coffeelover
            wrote on last edited by
            #58

            Update: Ich habe es jetzt auch zum Laufen bekommen.

            Das Blockly:

            <xml xmlns="http://www.w3.org/1999/xhtml">
              <variables>
                <variable type="" id="nz0rx9L*~pp:[bA(tw|W">message</variable>
                <variable type="" id="ymqtd+2_ynW#!@yc_l[q">color</variable>
              </variables>
              <block type="on" id="3iER$AuJU*~#Bq=Y!,3?" x="363" y="-487">
                <field name="OID">0_userdata.0.Testpunkt_für_Widget</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.Testpunkt_für_Widget</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="Rsxd`;M38tWnN=v!Um%t">
                        <mutation name="alertMessages">
                          <arg name="message"></arg>
                          <arg name="color"></arg>
                        </mutation>
                        <value name="ARG0">
                          <block type="text" id="69-skaEfHNdRn,U~S!JV">
                            <field name="TEXT">Neue Post</field>
                          </block>
                        </value>
                        <value name="ARG1">
                          <block type="colour_picker" id="~_opI=Y3^-H}@@l/OYxq">
                            <field name="COLOUR">#3366ff</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.Testpunkt_für_Widget</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="r}{,:7IEsJgqmsFbJX59">
                            <mutation name="alertMessages">
                              <arg name="message"></arg>
                              <arg name="color"></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>
                          </block>
                        </statement>
                      </block>
                    </next>
                  </block>
                </statement>
              </block>
              <block type="procedures_defcustomnoreturn" id="2+/YmhZKI?ON7;Y:{{2)" x="388" y="13">
                <mutation statements="false">
                  <arg name="message" varid="nz0rx9L*~pp:[bA(tw|W"></arg>
                  <arg name="color" varid="ymqtd+2_ynW#!@yc_l[q"></arg>
                </mutation>
                <field name="NAME">alertMessages</field>
                <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLnNlbmRUbygnMF91c2VyZGF0YS4wLk1lc3NhZ2UuV2FzY2htYXNjaGluZV9BbGVydCcsIG1lc3NhZ2UsIGNvbG9yKTs=</field>
                <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
              </block>
            </xml>
            

            Und das Script unter global:

            var materialDesignWidgets = {};
            materialDesignWidgets.sendTo = function (id, text, backgroundColor = '', borderColor = '', icon = '', iconColor = '', fontColor = '') {
                let json = getState(id).val;
             
                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);
            }
            
            Vielleicht hilft es noch jemandem von euch weiter.
            
            1 Reply Last reply
            0
            • S Offline
              S Offline
              sveni_lee
              wrote on last edited by
              #59

              ich habe mich auch mal an dem alerts-widget versucht. Mein Ziel war es eine kurze Meldung anzeigen zu lassen wenn der DWD Adapter eine Warnung ausgibt.

              on({id: 'dwd.0.warning.object'/*JSON object with warning*/}, function () {
              
                  var headline = getState('dwd.0.warning.headline'/*Warning headline*/).val;
              	var level = getState('dwd.0.warning.level'/*Warning level*/).val;
                  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 backgroundcolor = dwdBackground[getState('dwd.0.warning.severity'/*Warning severity*/).val]
              	
              	let json = getState("0_userdata.0.materialdesignwidgets.alarmDWD").val;
               
                  if (json) {
                      try {
              
                          json = JSON.parse(json);
              
                      } catch (e) {
                          json = [];
                          console.warn('Wert ist kein JSON string! Wert wird ersetzt!');
                      }
                  } else {
                      json = [];
                  }
              

              as funktioniert auch soweit... Allerdings habe ch festgestellt, das die json die ich erstelle "vollläuft". will heißen, immer wenn der DWD-Adapter den schedule ausführt wird ein neuer Eintrag in der json erzeugt... das führt früher oder später zum Absturz.
              Hat jemnd eventuell einen besseren Ansatz? Es können bei mir auch bis zu 3 Unwetterwarnungen angezeigt werden und es gibt auch warnungen vom Server wie bekomme ich das alles in eine json?

              Gruß
              Sveni_Lee

              C 1 Reply Last reply
              0
              • S sveni_lee

                ich habe mich auch mal an dem alerts-widget versucht. Mein Ziel war es eine kurze Meldung anzeigen zu lassen wenn der DWD Adapter eine Warnung ausgibt.

                on({id: 'dwd.0.warning.object'/*JSON object with warning*/}, function () {
                
                    var headline = getState('dwd.0.warning.headline'/*Warning headline*/).val;
                	var level = getState('dwd.0.warning.level'/*Warning level*/).val;
                    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 backgroundcolor = dwdBackground[getState('dwd.0.warning.severity'/*Warning severity*/).val]
                	
                	let json = getState("0_userdata.0.materialdesignwidgets.alarmDWD").val;
                 
                    if (json) {
                        try {
                
                            json = JSON.parse(json);
                
                        } catch (e) {
                            json = [];
                            console.warn('Wert ist kein JSON string! Wert wird ersetzt!');
                        }
                    } else {
                        json = [];
                    }
                

                as funktioniert auch soweit... Allerdings habe ch festgestellt, das die json die ich erstelle "vollläuft". will heißen, immer wenn der DWD-Adapter den schedule ausführt wird ein neuer Eintrag in der json erzeugt... das führt früher oder später zum Absturz.
                Hat jemnd eventuell einen besseren Ansatz? Es können bei mir auch bis zu 3 Unwetterwarnungen angezeigt werden und es gibt auch warnungen vom Server wie bekomme ich das alles in eine json?

                Gruß
                Sveni_Lee

                C Offline
                C Offline
                Coffeelover
                wrote on last edited by
                #60

                @sveni_lee Du müsstest nach meinem Ermessen den aktuellen Wert in eine Variable übernehmen und nur bei Änderung an den Datenpunkt weitergeben bzw. ins JSON schreiben.

                1 Reply Last reply
                0
                • ScroungerS Scrounger

                  @skokarl
                  Ok jetzt hab ich es verstanden was du möchtest.
                  Das kannst nur per skript erreichen. Du müsstest im json objekt eine Id einführen um eindeutig zu identifizieren, welche Nachricht gezielt gelöscht werden soll.
                  Und das ist sehr individuell weil es davon abhängt, wie die nachticht rein kommt und wie man mit bekommt das die nachricht nicht mehr aktiv ist.

                  N Offline
                  N Offline
                  n3ucr0n
                  wrote on last edited by
                  #61

                  @Scrounger said in Material Design Widgets: Alerts Widget:

                  @skokarl
                  Ok jetzt hab ich es verstanden was du möchtest.
                  Das kannst nur per skript erreichen. Du müsstest im json objekt eine Id einführen um eindeutig zu identifizieren, welche Nachricht gezielt gelöscht werden soll.
                  Und das ist sehr individuell weil es davon abhängt, wie die nachticht rein kommt und wie man mit bekommt das die nachricht nicht mehr aktiv ist.

                  Danke für das tolle Widget und für die ganze Hilfe bisher.

                  Könntest Du mir helfen wie ich das Skript verändern müsste, damit ALLE Nachrichten im Widget nach einer Gewissen Zeit in Sekunden automatisch wieder ausgeblendet werden?
                  Ich würde gerne 2 verschiedene Altert Widgets in meine VIS bauen.
                  Einmal eine mit der Standardfunktion (Benachrichtigungen müssen über das "X" manuell geschlossen werden) und einmal, wo die Nachrichten sich nach X sekunden automatisch ausblenden.

                  Danke für die Hilfe.

                  ScroungerS 1 Reply Last reply
                  0
                  • N n3ucr0n

                    @Scrounger said in Material Design Widgets: Alerts Widget:

                    @skokarl
                    Ok jetzt hab ich es verstanden was du möchtest.
                    Das kannst nur per skript erreichen. Du müsstest im json objekt eine Id einführen um eindeutig zu identifizieren, welche Nachricht gezielt gelöscht werden soll.
                    Und das ist sehr individuell weil es davon abhängt, wie die nachticht rein kommt und wie man mit bekommt das die nachricht nicht mehr aktiv ist.

                    Danke für das tolle Widget und für die ganze Hilfe bisher.

                    Könntest Du mir helfen wie ich das Skript verändern müsste, damit ALLE Nachrichten im Widget nach einer Gewissen Zeit in Sekunden automatisch wieder ausgeblendet werden?
                    Ich würde gerne 2 verschiedene Altert Widgets in meine VIS bauen.
                    Einmal eine mit der Standardfunktion (Benachrichtigungen müssen über das "X" manuell geschlossen werden) und einmal, wo die Nachrichten sich nach X sekunden automatisch ausblenden.

                    Danke für die Hilfe.

                    ScroungerS Offline
                    ScroungerS Offline
                    Scrounger
                    Developer
                    wrote on last edited by
                    #62

                    @n3ucr0n sagte in Material Design Widgets: Alerts Widget:

                    wo die Nachrichten sich nach X sekunden automatisch ausblenden.

                    würde das mit setTimeout() machen. Also wenn die nachricht rein kommt, dann json aktualisieren und die setTimeout() Funktion starten. Sobald diese aufgerufen wird im json nach der zuvor hinzugefügten nachricht suchen und diese entfernen.

                    So mal die Theorie, bsp code dafür hab ich nicht, musst also selbst schreiben ;-)
                    wenn du wo hängst, einfach deinen code hier posten, dann hilft dir sicher immer jemand weiter.

                    1 Reply Last reply
                    0
                    • F Offline
                      F Offline
                      fabian.krauss
                      wrote on last edited by
                      #63

                      @Scrounger

                      Wollte mal Rückmelden, dass es bei mir super klappt. Bin aber auch nur noch unter JS unterwegs. :-)

                      Danke für die gute Widget Bib! Ist mittlerweile meine Lieblingsbib für VIS.

                      Ich würde mich mal an das Thema eventbasiertes Löschen eines Alerts ran wagen (wurde hier ja schon mal diskutiert).
                      Hast du da einen Ansatzpunkt wie man am besten wieder ein "Element" im Array identifiziert und rauslöscht?

                      Danke!

                      ScroungerS 1 Reply Last reply
                      0
                      • F fabian.krauss

                        @Scrounger

                        Wollte mal Rückmelden, dass es bei mir super klappt. Bin aber auch nur noch unter JS unterwegs. :-)

                        Danke für die gute Widget Bib! Ist mittlerweile meine Lieblingsbib für VIS.

                        Ich würde mich mal an das Thema eventbasiertes Löschen eines Alerts ran wagen (wurde hier ja schon mal diskutiert).
                        Hast du da einen Ansatzpunkt wie man am besten wieder ein "Element" im Array identifiziert und rauslöscht?

                        Danke!

                        ScroungerS Offline
                        ScroungerS Offline
                        Scrounger
                        Developer
                        wrote on last edited by
                        #64

                        @fabian-krauss
                        Was meinst du genau mit eventbasiert. Gib mir mal ein konkretes beispiel was du realisieren möchtest.

                        F 1 Reply Last reply
                        0
                        • D Offline
                          D Offline
                          dos1973
                          wrote on last edited by
                          #65

                          Ich glaube, er meint das ein Alert Meldung sich auch von selbst wieder schliesst.

                          1 Reply Last reply
                          0
                          • ScroungerS Scrounger

                            @fabian-krauss
                            Was meinst du genau mit eventbasiert. Gib mir mal ein konkretes beispiel was du realisieren möchtest.

                            F Offline
                            F Offline
                            fabian.krauss
                            wrote on last edited by
                            #66

                            @Scrounger ja machen wir es an einem Beispiel:

                            Ich habe in einem Wassermelder eine Batterie deren Spannungswert ich als trigger Nutze.
                            Aktuell gebe ich ein Alert aus wenn die Spannung unter ein bestimmtes Level fällt. Dazu nutze ich deine Funktion.
                            Wenn ich nun her gehe und die Batterie tausche, würde ich mit einer if Abfrage im trigger >= 98% eine Funktion aufrufen die mir diesen Alert löscht.
                            Mir ist bewusst, dass man nach einem Art Schlüssel löschen müsste, z.b. dem Namen oder einer zusätzlichen Bestandteil im JSON.

                            Versteht man es jetzt besser ?

                            Danke für deine Mühe

                            ScroungerS N 2 Replies Last reply
                            0
                            • F fabian.krauss

                              @Scrounger ja machen wir es an einem Beispiel:

                              Ich habe in einem Wassermelder eine Batterie deren Spannungswert ich als trigger Nutze.
                              Aktuell gebe ich ein Alert aus wenn die Spannung unter ein bestimmtes Level fällt. Dazu nutze ich deine Funktion.
                              Wenn ich nun her gehe und die Batterie tausche, würde ich mit einer if Abfrage im trigger >= 98% eine Funktion aufrufen die mir diesen Alert löscht.
                              Mir ist bewusst, dass man nach einem Art Schlüssel löschen müsste, z.b. dem Namen oder einer zusätzlichen Bestandteil im JSON.

                              Versteht man es jetzt besser ?

                              Danke für deine Mühe

                              ScroungerS Offline
                              ScroungerS Offline
                              Scrounger
                              Developer
                              wrote on last edited by Scrounger
                              #67

                              @fabian-krauss

                              Du könntest eine property für die id einführen, z.B. so:

                                     {
                              		"text": "we have a new message",
                              		"backgroundColor": "",
                              		"borderColor": "darkred",
                              		"icon": "message-alert-outline",
                              		"iconColor": "darkred",
                              		"fontColor": "blue",
                              "meineId": "0_userdata.0.meinDatenpunkt"
                              	}
                              

                              und wenn sich der Wert des Datenpunkt ändert, suchst du nach der Id im json object, löscht oder aktualisiertst diesen.

                              liv-in-skyL 1 Reply Last reply
                              0
                              • ScroungerS Scrounger

                                @fabian-krauss

                                Du könntest eine property für die id einführen, z.B. so:

                                       {
                                		"text": "we have a new message",
                                		"backgroundColor": "",
                                		"borderColor": "darkred",
                                		"icon": "message-alert-outline",
                                		"iconColor": "darkred",
                                		"fontColor": "blue",
                                "meineId": "0_userdata.0.meinDatenpunkt"
                                	}
                                

                                und wenn sich der Wert des Datenpunkt ändert, suchst du nach der Id im json object, löscht oder aktualisiertst diesen.

                                liv-in-skyL Offline
                                liv-in-skyL Offline
                                liv-in-sky
                                wrote on last edited by liv-in-sky
                                #68

                                @Scrounger

                                ich verstehe nicht, warum der 2.te json eintrag kein icon hat - kannst du mir da bitte einen tipp geben - bild ist im browser und einem anderem script erreichbar

                                [
                                   {
                                   	"text": "WARNUNG Lebensmittel ",
                                   	"backgroundColor": "black",
                                   	"borderColor": "ligthgreen",
                                   	"icon": "/vis.0/armin/img/temporarily_not_available.png",
                                   	"iconColor": "lightgreen",
                                   	"fontColor": "lightgreen",
                                   	"id": "alerts_0"
                                   },
                                   {
                                   	"text": "WARNUNG Lebensmittel ",
                                   	"backgroundColor": "black",
                                   	"borderColor": "ligthgreen",
                                   	"icon": "https://www.lebensmittelwarnung.de/bvl-lmw-de/opensaga/attachment/6754e0a8-e7ee-400a-920f-879c2c2afe49/Unbenannt.JPG",
                                   	"iconColor": "lightgreen",
                                   	"fontColor": "lightgreen",
                                   	"id": "alerts_3"
                                   },
                                   {
                                   	"text": "WARNUNG Lebensmittel ",
                                   	"backgroundColor": "black",
                                   	"borderColor": "ligthgreen",
                                   	"icon": "https://lh5.googleusercontent.com/-2p7hRaaaaaaawc6fTdc1KI/AAAAAAAAAAA/bvbOvhaaaaaaaaaalS4dbDt2tHh4PuQCOQCEAE/s100/photo.jpg",
                                   	"iconColor": "lightgreen",
                                   	"fontColor": "lightgreen"
                                   }
                                ]
                                

                                Image 5.png

                                nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                ScroungerS 1 Reply Last reply
                                0
                                • F fabian.krauss

                                  @Scrounger ja machen wir es an einem Beispiel:

                                  Ich habe in einem Wassermelder eine Batterie deren Spannungswert ich als trigger Nutze.
                                  Aktuell gebe ich ein Alert aus wenn die Spannung unter ein bestimmtes Level fällt. Dazu nutze ich deine Funktion.
                                  Wenn ich nun her gehe und die Batterie tausche, würde ich mit einer if Abfrage im trigger >= 98% eine Funktion aufrufen die mir diesen Alert löscht.
                                  Mir ist bewusst, dass man nach einem Art Schlüssel löschen müsste, z.b. dem Namen oder einer zusätzlichen Bestandteil im JSON.

                                  Versteht man es jetzt besser ?

                                  Danke für deine Mühe

                                  N Offline
                                  N Offline
                                  n3ucr0n
                                  wrote on last edited by
                                  #69

                                  @fabian-krauss danke das du dich der Thematik annimmst!
                                  Wenn das mal läuft, wäre es Hammer! Ich als dau bin da auf Leute wie Dich angewiesen! :innocent: :relieved:

                                  liv-in-skyL 1 Reply Last reply
                                  0
                                  • N n3ucr0n

                                    @fabian-krauss danke das du dich der Thematik annimmst!
                                    Wenn das mal läuft, wäre es Hammer! Ich als dau bin da auf Leute wie Dich angewiesen! :innocent: :relieved:

                                    liv-in-skyL Offline
                                    liv-in-skyL Offline
                                    liv-in-sky
                                    wrote on last edited by liv-in-sky
                                    #70

                                    @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);

                                    nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                    N F 3 Replies Last reply
                                    1
                                    • N Offline
                                      N Offline
                                      n3ucr0n
                                      wrote on last edited by
                                      #71

                                      Ich werde leider es am Wochenende dazu kommen es mir genauer anzuschauen aber ich freue mich Schon drauf 🙂 danke!

                                      1 Reply Last reply
                                      0
                                      • liv-in-skyL liv-in-sky

                                        @Scrounger

                                        ich verstehe nicht, warum der 2.te json eintrag kein icon hat - kannst du mir da bitte einen tipp geben - bild ist im browser und einem anderem script erreichbar

                                        [
                                           {
                                           	"text": "WARNUNG Lebensmittel ",
                                           	"backgroundColor": "black",
                                           	"borderColor": "ligthgreen",
                                           	"icon": "/vis.0/armin/img/temporarily_not_available.png",
                                           	"iconColor": "lightgreen",
                                           	"fontColor": "lightgreen",
                                           	"id": "alerts_0"
                                           },
                                           {
                                           	"text": "WARNUNG Lebensmittel ",
                                           	"backgroundColor": "black",
                                           	"borderColor": "ligthgreen",
                                           	"icon": "https://www.lebensmittelwarnung.de/bvl-lmw-de/opensaga/attachment/6754e0a8-e7ee-400a-920f-879c2c2afe49/Unbenannt.JPG",
                                           	"iconColor": "lightgreen",
                                           	"fontColor": "lightgreen",
                                           	"id": "alerts_3"
                                           },
                                           {
                                           	"text": "WARNUNG Lebensmittel ",
                                           	"backgroundColor": "black",
                                           	"borderColor": "ligthgreen",
                                           	"icon": "https://lh5.googleusercontent.com/-2p7hRaaaaaaawc6fTdc1KI/AAAAAAAAAAA/bvbOvhaaaaaaaaaalS4dbDt2tHh4PuQCOQCEAE/s100/photo.jpg",
                                           	"iconColor": "lightgreen",
                                           	"fontColor": "lightgreen"
                                           }
                                        ]
                                        

                                        Image 5.png

                                        ScroungerS Offline
                                        ScroungerS Offline
                                        Scrounger
                                        Developer
                                        wrote on last edited by
                                        #72

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

                                        @Scrounger

                                        ich verstehe nicht, warum der 2.te json eintrag kein icon hat - kannst du mir da bitte einen tipp geben - bild ist im browser und einem anderem script erreichbar
                                        Image 5.png

                                        Muss ich mir anschauen, bin aber grad im Urlaub, dauert also noch.
                                        Steht was in der console des browsers?

                                        1 Reply Last reply
                                        0
                                        • liv-in-skyL Offline
                                          liv-in-skyL Offline
                                          liv-in-sky
                                          wrote on last edited by
                                          #73

                                          @Scrounger
                                          danke - aber
                                          das hat mittlerweile mit einem anderen bild funktioniert- werd das beobachten) genieße den urlaub - den hast du dir verdient

                                          nach einem gelösten Thread wäre es sinnvoll dies in der Überschrift des ersten Posts einzutragen [gelöst]-... Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat. Forum-Tools: PicPick https://picpick.app/en/download/ und ScreenToGif https://www.screentogif.com/downloads.html

                                          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

                                          755

                                          Online

                                          32.6k

                                          Users

                                          82.1k

                                          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