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

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Material Design Widgets: Alerts Widget

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

      @Scrounger sagte in Material Design Widgets: Alerts Widget:

      @skokarl
      Du kannst doch einzelne Meldungen ganz bequem über das Widget löschen?

      Stimmt, aber ich möchte erreichen dass die Meldung ggf. wieder von selbst verschwindet wenn sich der Alarm erledigt hat. Das kann man doch nicht wirklich immer von Hand machen müssen, das ist nicht so wirklich praktisch. Und dass Script dafür kriege ich nicht alleine hin. 😭

      Scrounger 1 Reply Last reply Reply Quote 0
      • Scrounger
        Scrounger Developer @skokarl last edited by

        @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 1 Reply Last reply Reply Quote 0
        • M
          M.H.Bomber @skokarl last edited by

          @skokarl

          wie edit falsch?

          S 1 Reply Last reply Reply Quote 0
          • S
            skokarl @M.H.Bomber last edited by

            @M-H-Bomber sagte in Material Design Widgets: Alerts Widget:

            @skokarl

            wie edit falsch?

            Ich hatte erst was geschrieben von dem ich nachher dachte das es falsch war.
            Deshalb habe ich noch mal editiert ( edit )
            und gelöscht weil falsch ( falsch )

            1 Reply Last reply Reply Quote 0
            • M
              M.H.Bomber last edited by

              was mache ich falsch
              84682449-5768-4fc4-9b73-e88b90d514d9-grafik.png

              1 Reply Last reply Reply Quote 0
              • ub.privat
                ub.privat @Tirador last edited by

                @Tirador

                bringt keine Besserung.
                Jetzt habe ich folgende meldung:

                javascript.0	2020-03-03 21:31:19.114	error	(17282) at Script.runInContext (vm.js:133:20)
                javascript.0	2020-03-03 21:31:19.114	error	(17282) at script.js.Alarm_Garagentor:1:23
                javascript.0	2020-03-03 21:31:19.113	error	(17282) TypeError: Cannot read property 'sendTo' of undefined
                javascript.0	2020-03-03 21:31:19.113	error	(17282) ^
                javascript.0	2020-03-03 21:31:19.113	error	(17282) materialDesignWidgets.sendTo('javascript.0.materialdesignwidgets.alarm', 'message', 'color');
                javascript.0	2020-03-03 21:31:19.112	error	(17282) script.js.Alarm_Garagentor: script.js.Alarm_Garagentor:1
                

                Script ist "gelb" und folgende Warnung läuft auf:

                21:33:00.339	warn	javascript.0 (17282) Object "script.js.Alarm_Garagentor_Blockly" does not exist
                

                Blockly ist aber vorhanden und auf grün

                b7d97f48-3c2f-464a-9dfe-08c80348b807-grafik.png

                egal ob Script unter "GLOBAL" oder "ROOT" laufen...

                1 Reply Last reply Reply Quote 0
                • ub.privat
                  ub.privat @Tirador last edited by

                  @Tirador

                  muss dich nochmals anschreiben...
                  Mittlerweile habe ich die Scripte "Grün II" und entsprechend abgelegt - also Fehler gefunden.
                  00b2cf19-7f5e-4d4c-9d12-216d79844aed-grafik.png
                  In deinem Screenshot stehen message und color nicht in Hochkommas, bei Scrounger seiner Doku schon! (siehe Bild!)
                  9923b623-883b-4ae9-b296-1f9637a5b2ff-grafik.png

                  Was ist nun korrekt???

                  Im VIS Editor und VIS-Runtime werden trotz Zustandsänderung keine Meldungen erzeugt!
                  D.h., irgendwo muss noch der Wurm drin sein?

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

                    @ub-privat Es ist schwierig zu unterstützen, da ich keinen Fehler erkennen kann auf den Screenshots von dir.

                    Bist Du ganz sicher, dass die falls Bedingung für deinen Datenpunkt TK_01_EG_GARAGE_STATE greift?
                    Ist das ein Datenpunkt der wirklich nur true/false zurückgibt, wie bei mir der Postsensor im Beispiel? Falls nein, dann musst du das Blockly anders abfragen.

                    Was steht denn in deinem angelegten Datenpunkt alertMessages bei dir drin?

                    2020-03-05 19_40_17-objects - ioBroker.png

                    Wenn dort etwas drin steht, liegt es eher an deinem VIS Layout, dass das Widget nicht im Vordergrund ist oder ähnliches.

                    Testweise kannst Du in den Datenpunkt alertMessages z.B. auch mal etwas reinschreiben:

                    [{"text":"✉ Neue Post im Briefkasten!","backgroundColor":"#ffcc00","borderColor":"","icon":"","iconColor":"","fontColor":""}]

                    Das führt bei mir zur Anzeige.

                    Was mir gerade noch aufgefallen ist, bei dir im Screenshot scheint das Script immer wieder neuzustarten (oder hast du es immer gestartet und gestoppt?).

                    Bei mir sieht das Log so aus:
                    2020-03-05 19_49_13-javascript - ioBroker.png

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

                      Hallo,

                      kann ich die Alerts so einrichten, dass sie nach dem Schließen nach einer definierten Zeit wieder auftauchen?
                      z.B.: Reinigung Backofen - die Meldung sollte 60 Tage nach dem letzten Schließen wieder auftauchen, damit er dann wieder gereinigt wird.

                      Vielen Dank

                      Scrounger 1 Reply Last reply Reply Quote 0
                      • Scrounger
                        Scrounger Developer @Coffeelover last edited by

                        @Coffeelover
                        Per Widget Einstellung geht das nicht. Das kann nur mit einem skript realisiert werden.

                        Würde ich wie folgt machen:

                        • einen Datenpunkt erstellen letzteBackofenReinigung mit Datum der letzen Reinigung
                        • skript erstellen das per cron job z.B. jeden Tag um 0h ausgeführt wird und schaut ob das datum heute - datum des Datenpunktes letzteBackofenReinigung > 60 Tage ist
                          -> Wenn ja Nachricht ans Alert Widget schicken.
                        1 Reply Last reply Reply Quote 1
                        • C
                          Coffeelover last edited by

                          So - das Skript habe ich mir nun soweit gebastelt. Leider scheitere ich aber noch an der initialen Einrichtung.

                          Ich habe den Datenpunkt "AlertWaschmaschine" angelegt und mit dem Widget verknüpft.
                          Ich habe das Script unter global abgelegt und in der ersten Zeile den Datenpunkt ergänzt. Der Rest wie gehabt.

                          materialDesignWidgets.sendTo('0_userdata.0.Message.AlertWaschmaschine', 'message', 'color');
                          

                          Dann habe ich ein Blockly angelegt wie auf den Screenshots oben (message / color), Javascript-Funktion angelegt, die Bausteine message & color eingefügt und bei </> ebenfalls diese Zeile eingefügt:

                          materialDesignWidgets.sentTo('0_userdata.0.Message.AlertWaschmaschine', message, color)
                          

                          Die Testnachricht von @Tirador habe ich mal in den Datenpunkt kopiert und kann dann auch den Inhalt im VIS sehen.
                          [{"text":"✉ Neue Post im Briefkasten!","backgroundColor":"#ffcc00","borderColor":"","icon":"","iconColor":"","fontColor":""}]

                          Aber über das Blockly z.B. bekomme ich das nicht getriggert. 😞

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

                            Vielleicht frage ich nochmal allgemeiner in die Runde: Wie muss ich denn vorgehen, um verschiedene Meldungen (=Inhalt unterschiedlicher Datenpunkte) in das Alert Widget zu bekommen. Mir ist der Workflow noch nicht ganz klar. 😞

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

                              @Coffeelover Bitte exportier mal dein Blockly Skript. Eventuell kann man so dem Problem auf die Spur kommen.

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

                                @Tirador Mein Blockly schreibt momentan nur die Testnachricht direkt in den Datenpunkt. Das funktioniert auch. Mir fehlt noch das Verständnis, wie ich mehrere Nachrichten schicken kann. Hilft das Blockly trotzdem?

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

                                  @Coffeelover Vielleicht ist dies für den Einstieg hilfreich: https://www.youtube.com/watch?v=lFvMVJ64A18

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

                                    @Tirador Vielen Dank, das war schon mal sehr aufschlussreich.
                                    Ich habe versucht, das Blockly von oben nachzubauen, aber noch schaltet da nichts.

                                    <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.Message.Test_Schalter_Alert</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.Message.Test_Schalter_Alert</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="update" id="hK23dYlKUJGBWdNO})$2">
                                                <mutation delay_input="false"></mutation>
                                                <field name="OID">0_userdata.0.Message.Test_Alert</field>
                                                <field name="WITH_DELAY">FALSE</field>
                                                <value name="VALUE">
                                                  <block type="logic_boolean" id="e*}tf$31R7J7xbwGUE+H">
                                                    <field name="BOOL">TRUE</field>
                                                  </block>
                                                </value>
                                                <next>
                                                  <block type="procedures_callcustomnoreturn" id="Rsxd`;M38tWnN=v!Um%t">
                                                    <mutation name="AlterMaterialDesign">
                                                      <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">#ff0000</field>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </next>
                                              </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.Message.Test_Schalter_Alert</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="update" id="UtCB2(;+:7/`4=#$I.@j">
                                                    <mutation delay_input="false"></mutation>
                                                    <field name="OID">0_userdata.0.Message.Test_Alert</field>
                                                    <field name="WITH_DELAY">FALSE</field>
                                                    <value name="VALUE">
                                                      <block type="logic_boolean" id="@*A}]`Pn6(qsd~u!SlBZ">
                                                        <field name="BOOL">TRUE</field>
                                                      </block>
                                                    </value>
                                                    <next>
                                                      <block type="procedures_callcustomnoreturn" id="r}{,:7IEsJgqmsFbJX59">
                                                        <mutation name="AlterMaterialDesign">
                                                          <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">#33ff33</field>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </next>
                                                  </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">AlterMaterialDesign</field>
                                        <field name="SCRIPT">bWF0ZXJpYWxEZXNpZ25XaWRnZXRzLnNlbnRUbygnMF91c2VyZGF0YS4wLk1lc3NhZ2UuVGVzdF9BbGVydCcsICdtZXNzYWdlJywgJ2NvbG9yJyk7</field>
                                        <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                                      </block>
                                    </xml>
                                    

                                    Das Scrounger-Script liegt 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);
                                    }
                                    

                                    Der "0_userdata.0.Message.Test_Schalter_Alert" ist als Schalter angelegt.
                                    Der "0_userdata.0.Message.Test_Alert" ist als Objekt angelegt.

                                    Du hast oben einen DP "newPost" der im Blockly aktualisiert wird. Spielt der eine Rolle?

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

                                      Hi @Scrounger, hast du in deiner Widgetsammlung auch ein Widget, das mit JSON-Tabellen insofern umgehen kann, das z. B. der TV Spielfilm Adapter die JSON liefert und in einem Widget dargestellt werden könnte ? Das Alert Widget verarbeitet immerhin schon JSON, zeigt aber leider nur eine Spalte an ...

                                      https://forum.iobroker.net/topic/28447/tv-programm-mini-anzeige-html-tabelle/70

                                      Scrounger 1 Reply Last reply Reply Quote 0
                                      • Scrounger
                                        Scrounger Developer @Bostil last edited by

                                        @Bostil
                                        Table Widget:
                                        https://github.com/Scrounger/ioBroker.vis-materialdesign#table

                                        Hier der Thread dazu:
                                        https://forum.iobroker.net/topic/29658/material-design-widgets-table-widget

                                        Bostil 1 Reply Last reply Reply Quote 1
                                        • Bostil
                                          Bostil @Scrounger last edited by

                                          @Scrounger Danke Scrounger, das war's! TV Spielfilm Infos erscheinen nun im gewohnten material design widget-Glanz! 🙂

                                          Scrounger 1 Reply Last reply Reply Quote 0
                                          • Scrounger
                                            Scrounger Developer @Bostil last edited by

                                            @Bostil
                                            Dann teil das doch mal mit uns.
                                            Aber bitte im richtigen Thread dazu!
                                            https://forum.iobroker.net/topic/29658/material-design-widgets-table-widget

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            529
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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