Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [Lovelace] HTML Code anzeigen

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Lovelace] HTML Code anzeigen

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

      Hallo zusammen

      Ich bin gerade dabei meine Lovelace UI zu überarbeiten. Dabei möchte ich die Daten des Pollenflug Adapters anzeigen. Die Daten werden vom Adapter in einem Objekt als JSON abgespeichert.

      Leider kann Lovelace kein JSON direkt zur Anzeige bringen. Daher muss ich den Umweg gehen und das JSON in HTML wandeln. Dies wird durch folgendes Script erledigt, dass ich hier im Forum entdeckt habe.

      /******************************************************************************************************
       * JSON-Datenpunkt in HTML umwandeln
       * --------------------------------------------------------------
       * Zweck:      Überwacht einen JSON-Datenpunkt und sobald geändert, wird JSON in HTML umgewandelt und
       *             in einem eigenen Datenpunkt ausgegeben
       * Publiziert: https://forum.iobroker.net/topic/32540/json-zu-html-und-in-datei-schreiben-ablegen
       * Autor:      Mic-M (Github) | Mic (ioBroker)
       * --------------------------------------------------------------------------------------
       * Change Log:
       *  0.0.1  Mic-M   * Initial release
       ******************************************************************************************************/
      
      /*********************************************************************************************
       * Einstellungen
       *********************************************************************************************/
      // JSON-Datenpunkt
      const g_jsonState = 'logparser.0.filters.Info.json';
      
      // Neuer Datenpunkt für HTML-Ausgabe
      const g_htmlState = 'javascript.0.html-tables.log-Info';
      
      // Spalte entfernen (für Log Parser Adapter 'ts' nehmen, da dieser autmatisch den timestamp hinzufügt),
      // sonst leer lassen
      const g_removeColumn = 'ts';
      
      
      /*********************************************************************************************
       * Ab hier nichts mehr ändern
       *********************************************************************************************/
      main();
      function main() {
      
          // Create state for HTML, if not yet existing
          createState(g_htmlState, {'name':'HTML Table', 'type':'string', 'read':true, 'write':false, 'role':'html', 'def':'' }, () => {
              // State created, so let's subscribe to the given JSON state
              on({id: g_jsonState, change:'ne'}, function(obj) {
                  // JSON state changed            
                  if(obj.state.val && obj.state.val.length > 10) {
                      // state is not empty
                      const jsonObject = JSON.parse(obj.state.val);
                      if(g_removeColumn) {
                          for (let lpEntry of jsonObject) {
                              delete lpEntry[g_removeColumn];
                          }
                      }
                      setState(g_htmlState, json2table(jsonObject, ''));
                  }
              });
      
          });
      
      }
      
      
      
      /**
       * Convert JSON to HTML table
       * Source: https://travishorn.com/building-json2table-turn-json-into-an-html-table-a57cf642b84a
       * 
       * @param {object}  jsonObject    The JSON as object.
       * @param {string}  [classes]     Optional: You can apply one or multiple classes (space separated) to <table>.
       * @return {string}               The HTML result as string
       */
      function json2table(jsonObject, classes = '') {
          const cols = Object.keys(jsonObject[0]);
      
          let headerRow = '';
          let bodyRows = '';
      
          classes = classes || '';
      
          cols.map(function(col) {
              headerRow += '<th>' + capitalizeFirstLetter(col) + '</th>';
          });
      
          jsonObject.map(function(row) {
      
              bodyRows += '<tr>';
      
              cols.map(function(colName) {
                  bodyRows += '<td>' + row[colName] + '</td>';
              })
      
              bodyRows += '</tr>';
      
          });
      
          const addClasses = (classes && classes.length > 1) ? ' class="' + classes + '"' : '';
          return '<table' + addClasses + '><thead><tr>' +
                  headerRow +
                  '</tr></thead><tbody>' +
                  bodyRows +
                  '</tbody></table>';
      
          function capitalizeFirstLetter(string) {
              return string.charAt(0).toUpperCase() + string.slice(1);
          }
      
      }
      

      Das HTML Objekt kann ich dann per Markdown Card anzeigen lassen.

      8dd8e9f8-c754-42f1-917b-fb9d2817896b-image.png

      Nun komme ich zu meinem Problem. Ich würde gerne die Anzeige des HTML etwas verändern. Zufrieden wäre ich, wenn die Spalten auf die komplette Card sich verteilen würden. Leider kenne ich mich mit HTML nicht aus und meine Google Recherche brachte keinen Erfolg.
      Das i-Tüpfelchen wäre dann, wenn die Tabelle jede Zeile eine andere Hintergrundfarbe hätte. Dies würde die Lesbarkeit verbessern.

      Vielleicht kann mir jemand hier im Forum helfen.

      Gruß aus RLP
      Tobi

      M 1 Reply Last reply Reply Quote 1
      • M
        MCU @dontobi last edited by

        @dontobi Im Script wird ein DP zurückgegeben: javascript.0.html-tables.log-Info
        Wo wird der in Lovelace angegeben?
        Laut der Beschreibung und der Bilder wird das Script nicht genutzt.

        dontobi 1 Reply Last reply Reply Quote 0
        • dontobi
          dontobi @MCU last edited by

          @mcu Ich hab das Script aus dem Forum kopiert, weil ich es selber nicht geschrieben habe. Wollte damit die Credits dem Ersteller geben. Ich hab die Datenpunkte nach meinen Bedürfnissen angepasst. Dementsprechend nutze ich andere Objekte.

          M 1 Reply Last reply Reply Quote 0
          • M
            MCU @dontobi last edited by MCU

            @dontobi Dann zeig doch Deine Einstellungen zum Script und die richtigen DPs in Lovelace.
            Grundsätzlich musst du zu Deiner Tabelle entsprechend die Style-Infos für die Tabelle und class-Infos mitgeben, damit man die Tabelle entsprechend farbig formatiert.
            Hast du eine HTML in einem DP?
            Zum Beispiel: backitup.0.history.html

            d3c5fc09-1aec-4f51-9174-59355f9cf076-image.png

            Trag den Inhalt vom DP dann mal in Inhalt (Benötigt) ein. Wie wird das angezeigt?

            Oder ein Beispiel-HTML:

            <!DOCTYPE html>
            <html>
            <head>
            <style>
            h1 {
              background-color: green;
            }
            
            div {
              background-color: lightblue;
            }
            
            p {
              background-color: yellow;
            }
            </style>
            </head>
            <body>
            
            <h1>CSS background-color example!</h1>
            <div>
            This is a text inside a div element.
            <p>This paragraph has its own background color.</p>
            We are still in the div element.
            </div>
            
            </body>
            </html>
            

            Laut Lovelace-Test kann man einen HTML-DP mit angeben:

            type: markdown
            content: '{ical.1.data.html}'
            title: Termine
            

            Ich habe mal für Jarvis eine HTML-Tabelle geschrieben:
            066b2225-9e75-4e1c-b02c-8b1aac383f0a-image.png

            Falls Dich das interessiert:

            https://forum.iobroker.net/topic/30668/jarvis-v2-2-0-just-another-remarkable-vis/4607 (Erklärung)
            https://forum.iobroker.net/topic/30668/jarvis-v2-2-0-just-another-remarkable-vis/4617 (script)

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

              Nachdem ich nun etwas Zeit habe, möchte ich hier ein Update geben.

              Ich hab das JSON_to_HTML Script erweitert und dieses sieht nun so aus...

              /******************************************************************************************************
               * JSON-Datenpunkt in HTML umwandeln
               * --------------------------------------------------------------
               * Zweck:      Überwacht einen JSON-Datenpunkt und sobald geändert, wird JSON in HTML umgewandelt und
               *             in einem eigenen Datenpunkt ausgegeben
               * Publiziert: https://forum.iobroker.net/topic/32540/json-zu-html-und-in-datei-schreiben-ablegen
               * Autor:      Mic-M (Github)   | Mic (ioBroker)
               * Co-Autor:   dontobi (Github) | dontobi (ioBroker)
               * --------------------------------------------------------------------------------------
               * Change Log:
               *  0.0.1  Mic-M     * Initial release
               *  0.0.2  dontobi   * more than one object
               ******************************************************************************************************/
              
              /*********************************************************************************************
               * Einstellungen
               *********************************************************************************************/
              // JSON-Datenpunkte
              const g_jsonState_1 = 'pollenflug.0.region#101.summary.json_index_today';
              const g_jsonState_2 = 'pollenflug.0.region#101.summary.json_index_tomorrow';
              
              // Neuer Datenpunkt für HTML-Ausgabe
              const g_htmlState_1 = 'javascript.0.HTML.pollen_index_today';
              const g_htmlState_2 = 'javascript.0.HTML.pollen_index_tomorrow';
              
              // Spalte entfernen (für Log Parser Adapter 'ts' nehmen, da dieser autmatisch den timestamp hinzufügt),
              // sonst leer lassen
              const g_removeColumn = '';
              
              
              /*********************************************************************************************
               * Ab hier nichts mehr ändern
               *********************************************************************************************/
              main();
              function main() {
              
                  // Create state for HTML, if not yet existing
                  createState(g_htmlState_1, {'name':'HTML Table', 'type':'string', 'read':true, 'write':true, 'role':'html', 'def':'' }, () => {
                      // State created, so let's subscribe to the given JSON state
                      on({id: g_jsonState_1, change:'ne'}, function(obj) {
                          // JSON state changed            
                          if(obj.state.val && obj.state.val.length > 10) {
                              // state is not empty
                              const jsonObject_1 = JSON.parse(obj.state.val);
                              if(g_removeColumn) {
                                  for (let lpEntry of jsonObject_1) {
                                      delete lpEntry[g_removeColumn];
                                  }
                              }
                              setState(g_htmlState_1, json2table(jsonObject_1, ''));
                          }
                      });
                  });
                  // Create state for HTML, if not yet existing
                  createState(g_htmlState_2, {'name':'HTML Table', 'type':'string', 'read':true, 'write':true, 'role':'html', 'def':'' }, () => {
                      // State created, so let's subscribe to the given JSON state
                      on({id: g_jsonState_2, change:'ne'}, function(obj) {
                          // JSON state changed            
                          if(obj.state.val && obj.state.val.length > 10) {
                              // state is not empty
                              const jsonObject_2 = JSON.parse(obj.state.val);
                              if(g_removeColumn) {
                                  for (let lpEntry of jsonObject_2) {
                                      delete lpEntry[g_removeColumn];
                                  }
                              }
                              setState(g_htmlState_2, json2table(jsonObject_2, ''));
                          }
                      });
                  });
              }
              
              /**
               * Convert JSON to HTML table
               * Source: https://travishorn.com/building-json2table-turn-json-into-an-html-table-a57cf642b84a
               * 
               * @param {object}  jsonObject    The JSON as object.
               * @param {string}  [classes]     Optional: You can apply one or multiple classes (space separated) to <table>.
               * @return {string}               The HTML result as string
               */
              function json2table(jsonObject, classes = '') {
                  const cols = Object.keys(jsonObject[0]);
                  let headerRow = '';
                  let bodyRows = '';
                  classes = classes || '';
                  cols.map(function(col) {
                      headerRow += '<th>' + capitalizeFirstLetter(col) + '</th>';
                  });
                  jsonObject.map(function(row) {
                      bodyRows += '<tr>';
                      cols.map(function(colName) {
                          bodyRows += '<td>' + row[colName] + '</td>';
                      })
                      bodyRows += '</tr>';
                  });
                  const addClasses = (classes && classes.length > 1) ? ' class="' + classes + '"' : '';
                  return '<table' + addClasses + '><thead><tr>' +
                          headerRow +
                          '</tr></thead><tbody>' +
                          bodyRows +
                          '</tbody></table>';
                  function capitalizeFirstLetter(string) {
                      return string.charAt(0).toUpperCase() + string.slice(1);
                  }
              }
              

              In den Datenpunkten javascript.0.HTML.pollen_index_today und javascript.0.HTML.pollen_index_tomorrow steht dann folgendes...

              <table><thead><tr><th>Pollen</th><th>Riskindex</th><th>Riskindextext</th></tr></thead><tbody><tr><td>Hasel</td><td>0</td><td>keine Belastung</td></tr><tr><td>Birke</td><td>0</td><td>keine Belastung</td></tr><tr><td>Esche</td><td>0</td><td>keine Belastung</td></tr><tr><td>Erle</td><td>0</td><td>keine Belastung</td></tr><tr><td>Graeser</td><td>3</td><td>geringe bis mittlere Belastung</td></tr><tr><td>Beifuss</td><td>0</td><td>keine Belastung</td></tr><tr><td>Ambrosia</td><td>0</td><td>keine Belastung</td></tr><tr><td>Roggen</td><td>0</td><td>keine Belastung</td></tr></tbody></table>
              
              <table><thead><tr><th>Pollen</th><th>Riskindex</th><th>Riskindextext</th></tr></thead><tbody><tr><td>Hasel</td><td>0</td><td>keine Belastung</td></tr><tr><td>Birke</td><td>0</td><td>keine Belastung</td></tr><tr><td>Esche</td><td>0</td><td>keine Belastung</td></tr><tr><td>Erle</td><td>0</td><td>keine Belastung</td></tr><tr><td>Graeser</td><td>4</td><td>mittlere Belastung</td></tr><tr><td>Beifuss</td><td>0</td><td>keine Belastung</td></tr><tr><td>Ambrosia</td><td>0</td><td>keine Belastung</td></tr><tr><td>Roggen</td><td>0</td><td>keine Belastung</td></tr></tbody></table>
              

              Die Markdown Card in meiner Lovelace Config sieht dann so aus...

              type: markdown
              content: >-
                <h3>Pollenbelastung Heute:</h3>
                {javascript.0.HTML.pollen_index_today}<hr>
                <h3>Pollenbelastung Morgen:</h3>
                {javascript.0.HTML.pollen_index_tomorrow}
              

              Ergebnis ist dann das hier...
              0d05043e-4270-4095-85b1-b09806cb6c34-image.png

              Ich werde jetzt mal mit den Tipps aus dem Beitrag 3 testen, ob das mit der Markdown Card überhaupt so klappt. Wenn ich mehr weiß, werde ich es hier dokumentieren.

              David G. 1 Reply Last reply Reply Quote 0
              • David G.
                David G. @dontobi last edited by David G.

                @dontobi

                Kleine Anmerkung, Lovelace wird farbige Tabellen immer ignorieren. Der ignoriert da viele Infos (vermutlich für ein einheitliches Erscheibungsbild, glaube der wendet in Tabellen sogar Farben vom Theme an).
                Ich habe bisher nur Text bunt bekommen.

                EDIT:
                Man kann auch zb mit Blockly direkt eine json verarbeiten.
                Ich erstellt mit aus einer json vom tvspielfilm Adapter eine Tabelle.

                Screenshot_20210708-180026_Firefox.jpg

                <block xmlns="https://developers.google.com/blockly/xml" type="on" id="ubL@LBF!,o_rkk4*V?$c" x="113" y="163">
                  <field name="OID">tvspielfilm.0.json.raw.heute2015</field>
                  <field name="CONDITION">ne</field>
                  <field name="ACK_CONDITION"></field>
                  <statement name="STATEMENT">
                    <block type="variables_set" id="W?1q7FaV,*wmZaIkPQ*o">
                      <field name="VAR" id="(m}dH@gw]g]CrCq4X:^O">Liste</field>
                      <value name="VALUE">
                        <block type="convert_json2object" id="-+dC_oJ;-(a!X+qq3ItL">
                          <value name="VALUE">
                            <block type="on_source" id="W9LY54G8%@AW$,Dv.c1;">
                              <field name="ATTR">state.val</field>
                            </block>
                          </value>
                        </block>
                      </value>
                      <next>
                        <block type="variables_set" id="*Gbs7`LVq2ggdi|-gk1#">
                          <field name="VAR" id="^u_U-Az-`mhCz~(F_#oT">text</field>
                          <value name="VALUE">
                            <block type="text" id="D2QaAKbM6V%.nH8G!WO8">
                              <field name="TEXT"></field>
                            </block>
                          </value>
                          <next>
                            <block type="controls_for" id="VAh4_5skpQ(-58)cTsN5">
                              <field name="VAR" id="x(8OtWm-n$bsM}t4],DO">i</field>
                              <value name="FROM">
                                <shadow type="math_number" id="UtEruMTPhi^T~g$#4=X%">
                                  <field name="NUM">1</field>
                                </shadow>
                              </value>
                              <value name="TO">
                                <shadow type="math_number" id="SL!L;!$5LE6b.-i2{-x8">
                                  <field name="NUM">10</field>
                                </shadow>
                                <block type="lists_length" id="IA8x7(aD91K?{^4e{t?p">
                                  <value name="VALUE">
                                    <block type="variables_get" id="Uw=RBKOt~o^7pvz5@?jp">
                                      <field name="VAR" id="(m}dH@gw]g]CrCq4X:^O">Liste</field>
                                    </block>
                                  </value>
                                </block>
                              </value>
                              <value name="BY">
                                <shadow type="math_number" id="X?ku5(f{C?`POZ9}Ykn$">
                                  <field name="NUM">1</field>
                                </shadow>
                              </value>
                              <statement name="DO">
                                <block type="variables_set" id="?x8p%;#1!zl^M{*-WeD_">
                                  <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                  <value name="VALUE">
                                    <block type="lists_getIndex" id="!p81u1HNh}swg_ZCMWGd">
                                      <mutation statement="false" at="true"></mutation>
                                      <field name="MODE">GET</field>
                                      <field name="WHERE">FROM_START</field>
                                      <value name="VALUE">
                                        <block type="variables_get" id="3ETVK*E:VqCH}#kblamq">
                                          <field name="VAR" id="(m}dH@gw]g]CrCq4X:^O">Liste</field>
                                        </block>
                                      </value>
                                      <value name="AT">
                                        <block type="variables_get" id="4ZY9FTQA,JoJx!nEg^nc">
                                          <field name="VAR" id="x(8OtWm-n$bsM}t4],DO">i</field>
                                        </block>
                                      </value>
                                    </block>
                                  </value>
                                  <next>
                                    <block type="variables_set" id="j5Gdw_u6HAN7$Hwd1Sk,">
                                      <field name="VAR" id="WND~1`M#LY[oSWchGJ;/">Titel</field>
                                      <value name="VALUE">
                                        <block type="get_attr" id="V=ixw;0O?aW0sXtNbLyR">
                                          <value name="PATH">
                                            <shadow type="text" id="XE}T12XOKYB-U6A8etD(">
                                              <field name="TEXT">title</field>
                                            </shadow>
                                          </value>
                                          <value name="OBJECT">
                                            <block type="variables_get" id="Aqx9nyk[/uZhLuG|WKW]">
                                              <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                            </block>
                                          </value>
                                        </block>
                                      </value>
                                      <next>
                                        <block type="variables_set" id="7n/:wb/R14Kz[S(YP^)z">
                                          <field name="VAR" id="qkP}SP]Wsh}w_3jlwPM=">Sender</field>
                                          <value name="VALUE">
                                            <block type="get_attr" id="si%nmaEYZ8yF2`)aXAA[">
                                              <value name="PATH">
                                                <shadow type="text" id="Vv?R@/OzO]p40i%9sCnd">
                                                  <field name="TEXT">station</field>
                                                </shadow>
                                              </value>
                                              <value name="OBJECT">
                                                <block type="variables_get" id="Dv389p@`@/Y3}]gx``_e">
                                                  <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                                </block>
                                              </value>
                                            </block>
                                          </value>
                                          <next>
                                            <block type="variables_set" id="aKy)HU06-POy;kU_BZb-">
                                              <field name="VAR" id="Cb`$KNa=.y/wQjyFtN6F">Zeit</field>
                                              <value name="VALUE">
                                                <block type="get_attr" id="`wPRO=fu4+XJSLOOaSO0">
                                                  <value name="PATH">
                                                    <shadow type="text" id="%IZ(eKv9iMml(NI-f]5P">
                                                      <field name="TEXT">time</field>
                                                    </shadow>
                                                  </value>
                                                  <value name="OBJECT">
                                                    <block type="variables_get" id="3Hno*M89!AaJIE6(3=33">
                                                      <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                                    </block>
                                                  </value>
                                                </block>
                                              </value>
                                              <next>
                                                <block type="variables_set" id="X)I9aAIj8q}#(,lBLoA8">
                                                  <field name="VAR" id="=H4KnMf9.v,`_]uv_6#?">Bild</field>
                                                  <value name="VALUE">
                                                    <block type="get_attr" id=";tsY?ta87G!Ip{x3uz#T">
                                                      <value name="PATH">
                                                        <shadow type="text" id="HmVz%-OkrSIKER](18V:">
                                                          <field name="TEXT">imgUrl</field>
                                                        </shadow>
                                                      </value>
                                                      <value name="OBJECT">
                                                        <block type="variables_get" id="Vq9etR=Lc?:t?%0IUjP9">
                                                          <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                                        </block>
                                                      </value>
                                                    </block>
                                                  </value>
                                                  <next>
                                                    <block type="variables_set" id="86DEYVo??R/@i_!:f`H?">
                                                      <field name="VAR" id=",,-mG}Ve8pp=2QR3G0v$">Beschreibung</field>
                                                      <value name="VALUE">
                                                        <block type="get_attr" id="vr3`]9_k0Ke3+G;BPe0$">
                                                          <value name="PATH">
                                                            <shadow type="text" id="g}99n.xJZe2a;])BF`jI">
                                                              <field name="TEXT">description</field>
                                                            </shadow>
                                                          </value>
                                                          <value name="OBJECT">
                                                            <block type="variables_get" id="C?}|MWY(:zJSY(62Q!L-">
                                                              <field name="VAR" id="B=:MPlbZ]`U`oQR_H1ZO">obj</field>
                                                            </block>
                                                          </value>
                                                        </block>
                                                      </value>
                                                      <next>
                                                        <block type="variables_set" id=",AX3xaQpP,RI_FeH!Xx|">
                                                          <field name="VAR" id="^u_U-Az-`mhCz~(F_#oT">text</field>
                                                          <value name="VALUE">
                                                            <block type="text_join" id="oc7)%`;1Y7hZ,{LSK@n^">
                                                              <mutation items="14"></mutation>
                                                              <value name="ADD0">
                                                                <block type="variables_get" id="A]OKm4e`3x(zLzn6s(QN">
                                                                  <field name="VAR" id="^u_U-Az-`mhCz~(F_#oT">text</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD1">
                                                                <block type="text" id="@UfRgRh#-n,^e{wnY,#$">
                                                                  <field name="TEXT">&lt;tr valign="top"&gt;&lt;th rowspan="2" ALIGN="LEFT" valign="top"&gt;</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD2">
                                                                <block type="text" id="SmFyDO|0Dgd0$?eaA`Sg">
                                                                  <field name="TEXT"> &lt;img src="</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD3">
                                                                <block type="variables_get" id="bJfAhLxPp7#nS|JLsb$2">
                                                                  <field name="VAR" id="=H4KnMf9.v,`_]uv_6#?">Bild</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD4">
                                                                <block type="text" id="V(@hQGqP#lM:3RU#|B.M">
                                                                  <field name="TEXT">" width="500px" valign="top"&gt;</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD5">
                                                                <block type="text" id="QL$OjZdV(xM6KUL/dmLz">
                                                                  <field name="TEXT">&lt;/th&gt;&lt;th ALIGN="LEFT"&gt;&lt;font size="3"&gt;</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD6">
                                                                <block type="variables_get" id="fIhTLcQB}M=fC^B;!y[3">
                                                                  <field name="VAR" id="Cb`$KNa=.y/wQjyFtN6F">Zeit</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD7">
                                                                <block type="text" id="gX^e$Yd~=w#@sewo9`#+">
                                                                  <field name="TEXT">&amp;nbsp;|&amp;nbsp;</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD8">
                                                                <block type="variables_get" id=";1!SxOtb)P*,f@2txLG+">
                                                                  <field name="VAR" id="qkP}SP]Wsh}w_3jlwPM=">Sender</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD9">
                                                                <block type="text" id="!PY*^%g4j-ZU}v{?r%xr">
                                                                  <field name="TEXT">&amp;nbsp;|&amp;nbsp;</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD10">
                                                                <block type="variables_get" id="7r#.X6VO;Q,F#?pc,v0W">
                                                                  <field name="VAR" id="WND~1`M#LY[oSWchGJ;/">Titel</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD11">
                                                                <block type="text" id="cHmPNGVArXff^;r4UFx9">
                                                                  <field name="TEXT">&lt;/th&gt;&lt;/tr&gt;&lt;tr&gt;&lt;td ALIGN="LEFT"&gt;&lt;font size="2"&gt;</field>
                                                                </block>
                                                              </value>
                                                              <value name="ADD12">
                                                                <block type="text_getSubstring" id="6N[/%V@1Q[0YvLVKJ?~=">
                                                                  <mutation at1="true" at2="true"></mutation>
                                                                  <field name="WHERE1">FROM_START</field>
                                                                  <field name="WHERE2">FROM_START</field>
                                                                  <value name="STRING">
                                                                    <block type="variables_get" id="JK9,5eYH6s8U9Jv-ZBcr">
                                                                      <field name="VAR" id=",,-mG}Ve8pp=2QR3G0v$">Beschreibung</field>
                                                                    </block>
                                                                  </value>
                                                                  <value name="AT1">
                                                                    <block type="math_number" id="v-Z:lGRy$;zzt0LH{])|">
                                                                      <field name="NUM">1</field>
                                                                    </block>
                                                                  </value>
                                                                  <value name="AT2">
                                                                    <block type="math_number" id="?%hQ{jpe?6;.(D/`m7_8">
                                                                      <field name="NUM">300</field>
                                                                    </block>
                                                                  </value>
                                                                </block>
                                                              </value>
                                                              <value name="ADD13">
                                                                <block type="text" id="P{0@!YzHS)23b;XH%g*4">
                                                                  <field name="TEXT">&lt;/tr&gt;</field>
                                                                </block>
                                                              </value>
                                                            </block>
                                                          </value>
                                                        </block>
                                                      </next>
                                                    </block>
                                                  </next>
                                                </block>
                                              </next>
                                            </block>
                                          </next>
                                        </block>
                                      </next>
                                    </block>
                                  </next>
                                </block>
                              </statement>
                              <next>
                                <block type="update" id="=iOOU)DZOb[YQgsxVq={">
                                  <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                  <field name="OID">0_userdata.0.VIS.tvprogramm.2015</field>
                                  <field name="WITH_DELAY">FALSE</field>
                                  <value name="VALUE">
                                    <block type="text_join" id=")4[foVL+;!xdhFv($WVn">
                                      <mutation items="3"></mutation>
                                      <value name="ADD0">
                                        <block type="text" id="rqH.Tp+,./Gm@C8e99ZY">
                                          <field name="TEXT">&lt;table&gt;</field>
                                        </block>
                                      </value>
                                      <value name="ADD1">
                                        <block type="variables_get" id="4R$*aP-tIeoXAU7-OHcp">
                                          <field name="VAR" id="^u_U-Az-`mhCz~(F_#oT">text</field>
                                        </block>
                                      </value>
                                      <value name="ADD2">
                                        <block type="text" id="3Nljk,tpV27x(#;V?7mB">
                                          <field name="TEXT">&lt;/table&gt;</field>
                                        </block>
                                      </value>
                                    </block>
                                  </value>
                                </block>
                              </next>
                            </block>
                          </next>
                        </block>
                      </next>
                    </block>
                  </statement>
                </block>
                

                Screenshot_20210708-180052_Fully Kiosk Browser.jpg

                Hatte das damals glaube mit Hilfe von @paul53 erstellt.

                Könntest ja sogar den Riskindex auswerten und die Zahl oder Spalte entsprechend formatieren.

                Und noch ein kleiner Tipp.
                Es gibt online unzählige HTML Tabellen Generatoren. Dort generieren was du brauchst und dann in Blockly nachbauen (für eine Spalte).

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

                  Ich hab die letzte Stunde ein wenig herum probiert und ebenfalls feststellen müssen, dass Lovelace die Farben komplett ignoriert. Nun ja, ist nicht sonderlich schlimm.

                  Abgesehen davon habe ich nun das Script das @MCU verlinkt hat auf meine Bedürfnisse angepasst. Dazu eine kurze Erklärung: Die Bilder wurden nicht skaliert und wurden dadurch für mich zu groß dargestellt. Daher habe ich diese aus dem Script gelöscht. Des Weiteren auch alles was mit der Farbgebung des Textes bzw. des Hintergrunds zu tun hat. Zum Abschluss habe ich dann noch die Textgröße raus genommen und am HTML Code ein wenig optimiert, so dass folgendes Ergebnis heraus kam.

                  1c50045f-61bf-469d-b57f-793dce4e3978-image.png

                  createState('javascript.0.Pollenflug.Html','',false, {read: true, write: true, name: "HTML Pollenflug", type: "string", role: "text", def: "" });
                  createState('javascript.0.Pollenflug.HtmlSet','false',false, {read: true, write: true, name: "HTML erzeugen", type: "boolean", role: "button", def: "false" });
                  createState('javascript.0.Pollenflug.LandesKennung','#101',false, {read: true, write: true, name: "Landeskennung", type: "string", role: "text", def: "",
                             states:{'#11':'Schleswig-Holstein und Hamburg - Inseln und Marschen',
                                     '#12':'Schleswig-Holstein und Hamburg - Geest, Schleswig-Holstein und Hamburg',
                                     '#20':'Mecklenburg-Vorpommern ',
                                     '#31':'Niedersachsen und Bremen - Westl. Niedersachsen/Bremen',
                                     '#32':'Niedersachsen und Bremen - Östl. Niedersachsen',
                                     '#41':'Nordrhein-Westfalen - Rhein.-Westfäl. Tiefland',
                                     '#42':'Nordrhein-Westfalen - Ostwestfalen',
                                     '#43':'Nordrhein-Westfalen - Mittelgebirge NRW',
                                     '#50':'Brandenburg und Berlin ',
                                     '#61':'Sachsen-Anhalt - Tiefland Sachsen-Anhalt',
                                     '#62':'Sachsen-Anhalt - Harz',
                                     '#71':'Thüringen - Tiefland Thüringen',
                                     '#72':'Thüringen - Mittelgebirge Thüringen',
                                     '#81':'Sachsen - Tiefland Sachsen',
                                     '#82':'Sachsen - Mittelgebirge Sachsen',
                                     '#91':'Hessen - Nordhessen und hess. Mittelgebirge',
                                     '#92':'Hessen - Rhein-Main',
                                     '#101':'Rheinland-Pfalz und Saarland - Rhein, Pfalz, Nahe und Mosel',
                                     '#102':'Rheinland-Pfalz und Saarland - Mittelgebirgsbereich Rheinland-Pfalz',
                                     '#103':'Rheinland-Pfalz und Saarland - Saarland',
                                     '#111':'Baden-Württemberg - Oberrhein und unteres Neckartal',
                                     '#112':'Baden-Württemberg - Hohenlohe/mittlerer Neckar/Oberschwaben',
                                     '#113':'Baden-Württemberg - Mittelgebirge Baden-Württemberg',
                                     '#121':'Bayern - Allgäu/Oberbayern/Bay. Wald',
                                     '#122':'Bayern - Donauniederungen',
                                     '#123':'Bayern - Bayern n. der Donau, o. Bayr. Wald, o. Mainfranken',
                                     '#124':'Bayern - Mainfranken'
                             } });
                  
                  // Html-erzeugen Boolean ausführen
                  setState('javascript.0.Pollenflug.HtmlSet',false);
                  on({id: 'javascript.0.Pollenflug.HtmlSet', change: "ne"}, function (obj) {
                      if (getState('javascript.0.Pollenflug.HtmlSet').val == true){
                          html_erzeugen();
                      }
                      setState('javascript.0.Pollenflug.HtmlSet',false);
                  });
                  // 11:05 HTML neu erstellen , da 11:00 die Daten erneuert werden
                  schedule("5 11 * * *", async function () {
                      setState("javascript.0.Pollenflug.HtmlSet", true);
                  });
                  
                  // HTML erstellen
                  function html_erzeugen() { 
                      let region = getState('javascript.0.Pollenflug.LandesKennung').val;
                      let pollen =['Ambrosia','Beifuss','Birke','Erle','Esche','Graeser','Hasel','Roggen'];
                      let txt_today = [];
                      let txt_tomorrow = [];
                      let txt_today_idx = [];
                      let txt_tomorrow_idx = [];
                      let pos = 0;
                      for (let i=0; i < pollen.length ; i++){
                          txt_today_idx[i] = getState('pollenflug.0.region'+region+'.'+ pollen[i]+'.index_today').val 
                          txt_today[i] = getState('pollenflug.0.region'+region+'.'+ pollen[i]+'.text_today').val 
                          pos = txt_today[i].indexOf(pollen[i]);
                          txt_today[i] = txt_today[i].substr(0,pos-5);
                          txt_today[i] = txt_today[i].replace(' Belastung','');
                          txt_tomorrow_idx[i] = getState('pollenflug.0.region'+region+'.'+ pollen[i]+'.index_tomorrow').val
                          txt_tomorrow[i] = getState('pollenflug.0.region'+region+'.'+ pollen[i]+'.text_tomorrow').val     
                          pos = txt_tomorrow[i].indexOf(pollen[i]);
                          txt_tomorrow[i] = txt_tomorrow[i].substr(0,pos-5);
                          txt_tomorrow[i] = txt_tomorrow[i].replace(' Belastung','');
                      }
                  
                      let htmlStr = '';
                      var dateheute = new Date();
                      let obj = getObject("javascript.0.Pollenflug.LandesKennung");
                      let Landeskenn = obj.common.states[getState("javascript.0.Pollenflug.LandesKennung").val];
                      var date = formatDate(dateheute, 'DD.MM.YYYY ');
                      htmlStr = ['<table id="table" width="100%" border="1">'].join('');
                      htmlStr = htmlStr + '<h2>Pollenflug Vorhersage vom ' + date +'</h2>';
                      htmlStr = htmlStr + ['<tr align="center"><th><b>Typ</b></th><th><b>Heute</b></th><th><b>Morgen</b></th></tr>'].join(''); //,'<tr><th>-</th><th>-</th><th>-</th><th>-</th></tr>'
                  
                      for (let j = 0; j< pollen.length ; j++) {
                          htmlStr = htmlStr + '<tr>';
                          htmlStr = htmlStr + '<td width="33%" align="center">'+ pollen[j] +'</td>';
                          htmlStr = htmlStr + '<td width="33%" align="center">'+ txt_today[j] +'</td>';
                          htmlStr = htmlStr + '<td width="33%" align="center">'+ txt_tomorrow[j] +'</td>';
                          htmlStr = htmlStr + '</tr>';
                      };
                  
                      //Ende von HTML
                      htmlStr = htmlStr + '</table>';
                      setState('javascript.0.Pollenflug.Html', htmlStr);
                  };
                  

                  Wie gesagt... für mich reicht das und ich bin zufrieden. Eine schöne Lovelace Card wäre zwar ziemlich cool, aber dazu fehlt es mir an Know-How, um eine solche zu erstellen.

                  David G. Garfonso 2 Replies Last reply Reply Quote 0
                  • David G.
                    David G. @dontobi last edited by

                    @dontobi

                    Gut, dass du zufrieden bist.
                    Aber evtl lohnt es sich, die Tabellen manuell zu erstellen.

                    Man kann dann alles perfekt selber beeinflussen.

                    Mache ich hier am selben Weg (nur mit einem Selektor anstatt json).

                    Screenshot_20210708-193341_Fully Kiosk Browser.jpg

                    dontobi 1 Reply Last reply Reply Quote 0
                    • dontobi
                      dontobi @David G. last edited by

                      @david-g Ich überlege es mir nochmal. Wie machst du das denn mit dem grünen bzw. roten Punkt?

                      David G. 1 Reply Last reply Reply Quote 0
                      • David G.
                        David G. @dontobi last edited by

                        @dontobi

                        Die Punkte sind einfach ein Schriftzeichen in großer Schriftart.

                        Beim Text erstellen in Blockly kann man auch mit falls Regeln arbeiten. Fall wert war dann grün, falls falsch rot.

                        Screenshot_20210708-212451_Firefox.jpg

                        Das Skript ist aber was komplexer.
                        Es erkennt alle hmip Geräte automatisch und liest die Namen aus.
                        Poste ich, falls du Interesse hast.

                        dontobi 1 Reply Last reply Reply Quote 0
                        • dontobi
                          dontobi @David G. last edited by

                          @david-g Das wäre cool. Ich mach das mit dem LowBat etwas anders, aber so wie du es hast, finde ich das gut aufgebaut. Außerdem könnte ich Teile davon dann für die Pollenflug Sache verwenden.

                          Wenn du das Script hier postest, könntest du es dann als JavaScript tun? Du kannst das Blockly ja in JS wandeln und dann Copy & Paste betreiben.

                          Danke schonmal. Ich werde dann mein Script dann ebenfalls veröffentlichen (wenn es dann fertig ist).

                          David G. 1 Reply Last reply Reply Quote 0
                          • David G.
                            David G. @dontobi last edited by

                            @dontobi

                            Hey,

                            hab die nächten Tage leider keinen PC.
                            Am Smartphone bekomme ich den JS Code leider nicht kopiert......
                            Der Editor klappt da nicht wirklich und es gibt keinen Export Button.

                            Deshalb hier als blockly.
                            Am Montag reiche ich JS nach, außer du hast es bis dahin selber umgewandelt.
                            Kannst ja kurz Bescheid geben.

                            Hab grad gesehen, dass ich noch minütlich Trigger. Stelle ich gelegentlich mal noch auf einen selector basierten Trigger um ^^.

                            <xml xmlns="https://developers.google.com/blockly/xml">
                              <variables>
                                <variable id="I?IY,pbmgtKHwd9L]VLd">id</variable>
                                <variable id="SKh+R[G%ptX]9uv^hB,!">wahr</variable>
                                <variable id=";O,|I4cqK/q|U6dt.?NN">falsch</variable>
                                <variable id="%62`(Q[9y{,UvP3o}T|/">i</variable>
                                <variable id="GI^dumJfw0)4Nzi2HVw`">ParentID</variable>
                                <variable id="bcl|+G6)P$l:,Gn9x$[Q">lowbat</variable>
                                <variable id="HxY9T=|.h|4{.1*`d}f1">bat_status</variable>
                              </variables>
                              <block type="procedures_defcustomreturn" id="S;%2#n?7.W0Cko92rdS9" x="1288" y="412">
                                <mutation statements="false">
                                  <arg name="id" varid="I?IY,pbmgtKHwd9L]VLd"></arg>
                                </mutation>
                                <field name="NAME">checkBatt</field>
                                <field name="SCRIPT">aWYoZXhpc3RzU3RhdGUoaWQpKSByZXR1cm4gZ2V0U3RhdGUoaWQpLnZhbDsgLy8gZmFsc2UgLyB0cnVlDQpyZXR1cm4gLTE=</field>
                                <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                              </block>
                              <block type="procedures_defcustomreturn" id="z1v5P%=uhnATnl`x*fMU" x="1287" y="462">
                                <mutation statements="false">
                                  <arg name="id" varid="I?IY,pbmgtKHwd9L]VLd"></arg>
                                </mutation>
                                <field name="NAME">GetObjectByID</field>
                                <field name="SCRIPT">cmV0dXJuIGdldE9iamVjdChpZCk7</field>
                                <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                              </block>
                              <block type="schedule" id="=M?}+$74/A|+fu)hob?*" x="1242" y="503">
                                <field name="SCHEDULE">* * * * *</field>
                                <statement name="STATEMENT">
                                  <block type="variables_set" id="dZ;P0S=A~Ue9U{sxWFjF">
                                    <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                    <value name="VALUE">
                                      <block type="text" id="1Rdn%LJ,UsyiTo}^fQyi">
                                        <field name="TEXT"></field>
                                      </block>
                                    </value>
                                    <next>
                                      <block type="variables_set" id="JoJ{Z)?hFmCa3B.z1B~;">
                                        <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                        <value name="VALUE">
                                          <block type="text" id="I)B703c6WPKo}@_L8ai^">
                                            <field name="TEXT"></field>
                                          </block>
                                        </value>
                                        <next>
                                          <block type="controls_forEach" id="VXic[*WK}rqr0-!U:EFy">
                                            <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                            <value name="LIST">
                                              <block type="selector" id="vI2MD73D2c=a4z1nh`=`">
                                                <field name="TEXT">hm-rpc.0.*.0.UNREACH</field>
                                              </block>
                                            </value>
                                            <statement name="DO">
                                              <block type="variables_set" id="5%|F-TdcQ{4t*4:+v!]w">
                                                <field name="VAR" id="GI^dumJfw0)4Nzi2HVw`">ParentID</field>
                                                <value name="VALUE">
                                                  <block type="text_getSubstring" id="`QFsslqwXJcDRwUQ_z;$" inline="false">
                                                    <mutation at1="true" at2="true"></mutation>
                                                    <field name="WHERE1">FROM_START</field>
                                                    <field name="WHERE2">FROM_START</field>
                                                    <value name="STRING">
                                                      <block type="variables_get" id="2K5mqiyK-@A,u?+%_r-I">
                                                        <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                                      </block>
                                                    </value>
                                                    <value name="AT1">
                                                      <block type="math_number" id="_q*GktBrg4YS~$oc@#.$">
                                                        <field name="NUM">1</field>
                                                      </block>
                                                    </value>
                                                    <value name="AT2">
                                                      <block type="math_arithmetic" id="BHxb,^*vvK^,t3OWIp~N" inline="false">
                                                        <field name="OP">MINUS</field>
                                                        <value name="A">
                                                          <shadow type="math_number" id="V4^8g/Fq~(QA(Gn,=_g9">
                                                            <field name="NUM">1</field>
                                                          </shadow>
                                                          <block type="text_indexOf" id=";@~lMPhmFt@}zblOq8}z" inline="false">
                                                            <field name="END">LAST</field>
                                                            <value name="VALUE">
                                                              <block type="variables_get" id="ZxgO1Qq@jpN)?*](o;s%">
                                                                <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                                              </block>
                                                            </value>
                                                            <value name="FIND">
                                                              <shadow type="text" id="xWkYFdwM0dR_rBOFM|zY">
                                                                <field name="TEXT">.0.UNREACH</field>
                                                              </shadow>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <value name="B">
                                                          <shadow type="math_number" id="h-25vZ[WT=N4?QJ3saG%">
                                                            <field name="NUM">1</field>
                                                          </shadow>
                                                        </value>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </value>
                                                <next>
                                                  <block type="variables_set" id="]#h,OlCGqp|Xu%g%t]fR">
                                                    <field name="VAR" id="bcl|+G6)P$l:,Gn9x$[Q">lowbat</field>
                                                    <value name="VALUE">
                                                      <block type="procedures_callcustomreturn" id="L)~9B;.,JfjE%hP/.+j6">
                                                        <mutation name="checkBatt">
                                                          <arg name="id"></arg>
                                                        </mutation>
                                                        <value name="ARG0">
                                                          <block type="text_join" id="3Vb3KsM%DTu`Cp-9wV~*" inline="true">
                                                            <mutation items="2"></mutation>
                                                            <value name="ADD0">
                                                              <block type="variables_get" id="XHy1]LjzT`@I3KM.RoB)">
                                                                <field name="VAR" id="GI^dumJfw0)4Nzi2HVw`">ParentID</field>
                                                              </block>
                                                            </value>
                                                            <value name="ADD1">
                                                              <block type="text" id=":qM48sM-]Tx5wZ.9IY%{">
                                                                <field name="TEXT">.0.LOW_BAT</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </value>
                                                    <next>
                                                      <block type="controls_if" id="{5{SXmhUl.bI~$~,]@%H">
                                                        <mutation elseif="1" else="1"></mutation>
                                                        <value name="IF0">
                                                          <block type="logic_compare" id="`c+]]])m$+/rHTcAH%;Y">
                                                            <field name="OP">EQ</field>
                                                            <value name="A">
                                                              <block type="variables_get" id=")e{W$Vn#jAUtn^%3GHc+">
                                                                <field name="VAR" id="bcl|+G6)P$l:,Gn9x$[Q">lowbat</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="logic_boolean" id="Mm)T;yt!9DV704UE_CqK">
                                                                <field name="BOOL">TRUE</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <statement name="DO0">
                                                          <block type="variables_set" id="3F7g/g6B{8,e[M.rzFYZ">
                                                            <field name="VAR" id="HxY9T=|.h|4{.1*`d}f1">bat_status</field>
                                                            <value name="VALUE">
                                                              <block type="text" id="xndGMC0F7X,6,D.@|!r5">
                                                                <field name="TEXT">&lt;font size="3"&gt;&lt;b&gt;&lt;font color=red&gt;●&lt;/font&gt;</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </statement>
                                                        <value name="IF1">
                                                          <block type="logic_compare" id="s!$,pxb]peq=(59h9u.+">
                                                            <field name="OP">EQ</field>
                                                            <value name="A">
                                                              <block type="variables_get" id="N!|2zNx4?F+$Y_:^1#i1">
                                                                <field name="VAR" id="bcl|+G6)P$l:,Gn9x$[Q">lowbat</field>
                                                              </block>
                                                            </value>
                                                            <value name="B">
                                                              <block type="logic_boolean" id="q8Ot[T@:H_+pfHHh{)/p">
                                                                <field name="BOOL">FALSE</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <statement name="DO1">
                                                          <block type="variables_set" id="EyUf|`9l#sbDYWMxMo9r">
                                                            <field name="VAR" id="HxY9T=|.h|4{.1*`d}f1">bat_status</field>
                                                            <value name="VALUE">
                                                              <block type="text" id="m*so88GuyHQnkdJq4A]T">
                                                                <field name="TEXT">&lt;font size="3"&gt;&lt;b&gt;&lt;font color=green&gt;●&lt;/font&gt;</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </statement>
                                                        <statement name="ELSE">
                                                          <block type="variables_set" id="-8fG~$`@6wy)#_`9I,It">
                                                            <field name="VAR" id="HxY9T=|.h|4{.1*`d}f1">bat_status</field>
                                                            <value name="VALUE">
                                                              <block type="text" id="=`5BiDIMgSVnu3uT7hQ#">
                                                                <field name="TEXT">&lt;font size="3"&gt;&lt;b&gt;&lt;font color=grey&gt;●&lt;/font&gt;</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </statement>
                                                        <next>
                                                          <block type="controls_if" id="[t4#.[R7stu?S`@$u3BW">
                                                            <mutation else="1"></mutation>
                                                            <value name="IF0">
                                                              <block type="get_value_var" id="Iq+@rH{{dyJ9HWgoI~T4">
                                                                <field name="ATTR">val</field>
                                                                <value name="OID">
                                                                  <shadow type="text">
                                                                    <field name="TEXT"></field>
                                                                  </shadow>
                                                                  <block type="variables_get" id="B)n%:}PX%zZGvt#JtbR(">
                                                                    <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                                                  </block>
                                                                </value>
                                                              </block>
                                                            </value>
                                                            <statement name="DO0">
                                                              <block type="variables_set" id="S+Gd]Tap?Ej$]1P.V.(_">
                                                                <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                                                <value name="VALUE">
                                                                  <block type="text_join" id="5?soV=/V!gT:YP;%=C7*">
                                                                    <mutation items="6"></mutation>
                                                                    <value name="ADD0">
                                                                      <block type="variables_get" id="t5Hgf|mSwoVqQ}(:~9Y7">
                                                                        <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD1">
                                                                      <block type="text" id="xa}qmEJ|8{^pBcPkIB|C">
                                                                        <field name="TEXT">&lt;tr&gt;&lt;td&gt;</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD2">
                                                                      <block type="get_attr" id="N%K=-ar/nF2t;vp68{4;" inline="false">
                                                                        <value name="PATH">
                                                                          <shadow type="text" id="NEKfB0mKYNB9yf[p[(LM">
                                                                            <field name="TEXT">common.name</field>
                                                                          </shadow>
                                                                        </value>
                                                                        <value name="OBJECT">
                                                                          <block type="procedures_callcustomreturn" id="mBvJ_WhP|}o*z}@Nf9Gx">
                                                                            <mutation name="GetObjectByID">
                                                                              <arg name="id"></arg>
                                                                            </mutation>
                                                                            <value name="ARG0">
                                                                              <block type="variables_get" id="D:=8pGehBP5ZOKH2LV2?">
                                                                                <field name="VAR" id="GI^dumJfw0)4Nzi2HVw`">ParentID</field>
                                                                              </block>
                                                                            </value>
                                                                          </block>
                                                                        </value>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD3">
                                                                      <block type="text" id="2WmqZ^-K89eQ9Z!T.Sg!">
                                                                        <field name="TEXT">&lt;/td&gt; &lt;td ALIGN="CENTER"&gt;&lt;font size="3"&gt;&lt;b&gt;&lt;font color=red&gt;●&lt;/font&gt; &lt;/td&gt;&lt;td ALIGN="CENTER"&gt;</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD4">
                                                                      <block type="variables_get" id="}%Hb9#YD[@-lo7hcVYhD">
                                                                        <field name="VAR" id="HxY9T=|.h|4{.1*`d}f1">bat_status</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD5">
                                                                      <block type="text" id=".L`Q2|+8S@wrpEV*d/a8">
                                                                        <field name="TEXT">&lt;/td&gt;&lt;/tr&gt;</field>
                                                                      </block>
                                                                    </value>
                                                                  </block>
                                                                </value>
                                                              </block>
                                                            </statement>
                                                            <statement name="ELSE">
                                                              <block type="variables_set" id="sh;fX7NWP+]`^FcnbVjU">
                                                                <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                                                <value name="VALUE">
                                                                  <block type="text_join" id="|Xz[CQA5p*BCe{uu*,ir">
                                                                    <mutation items="6"></mutation>
                                                                    <value name="ADD0">
                                                                      <block type="variables_get" id="F4J0jDpn[Na[1p8Ruf=%">
                                                                        <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD1">
                                                                      <block type="text" id="C+UnHlb%GLN.|tA3o,`C">
                                                                        <field name="TEXT">&lt;tr&gt;&lt;td&gt;</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD2">
                                                                      <block type="get_attr" id="=z[7ycSqfif0h~4Sz*|=" inline="false">
                                                                        <value name="PATH">
                                                                          <shadow type="text" id="C*^0Xt3cP0zy%F4#veYO">
                                                                            <field name="TEXT">common.name</field>
                                                                          </shadow>
                                                                        </value>
                                                                        <value name="OBJECT">
                                                                          <block type="procedures_callcustomreturn" id=",{*p|W,%6Npy^h.,(XSP">
                                                                            <mutation name="GetObjectByID">
                                                                              <arg name="id"></arg>
                                                                            </mutation>
                                                                            <value name="ARG0">
                                                                              <block type="variables_get" id="dgPrr_H^_1Z}0!cS+Iw{">
                                                                                <field name="VAR" id="GI^dumJfw0)4Nzi2HVw`">ParentID</field>
                                                                              </block>
                                                                            </value>
                                                                          </block>
                                                                        </value>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD3">
                                                                      <block type="text" id="yNUk#G;)wLb1Xq!/%A[M">
                                                                        <field name="TEXT">&lt;/td&gt; &lt;td ALIGN="CENTER"&gt;&lt;font size="3"&gt;&lt;b&gt;&lt;font color=green&gt;●&lt;/font&gt; &lt;/td&gt;&lt;td ALIGN="CENTER"&gt;</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD4">
                                                                      <block type="variables_get" id="VQX+=n{:bA6;Voo_O+,9">
                                                                        <field name="VAR" id="HxY9T=|.h|4{.1*`d}f1">bat_status</field>
                                                                      </block>
                                                                    </value>
                                                                    <value name="ADD5">
                                                                      <block type="text" id="C0b:_R_m#%.`Mh9$d)or">
                                                                        <field name="TEXT">&lt;/td&gt;&lt;/tr&gt;</field>
                                                                      </block>
                                                                    </value>
                                                                  </block>
                                                                </value>
                                                              </block>
                                                            </statement>
                                                          </block>
                                                        </next>
                                                      </block>
                                                    </next>
                                                  </block>
                                                </next>
                                              </block>
                                            </statement>
                                            <next>
                                              <block type="update" id="|*Wyl;F2(g0J1J^:!x68">
                                                <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                                <field name="OID">0_userdata.0.VIS.Akkumeldungen.hmip_akku_tabelle</field>
                                                <field name="WITH_DELAY">FALSE</field>
                                                <value name="VALUE">
                                                  <block type="text_join" id="CF52S*}*)[vTA|Y~w+@1">
                                                    <mutation items="5"></mutation>
                                                    <value name="ADD0">
                                                      <block type="text" id="yxd%qU_@2Bv39AdiqwQ*">
                                                        <field name="TEXT">&lt;table style="width: 100%;"&gt; &lt;tbody&gt; &lt;tr&gt; &lt;td width=100%&gt;&lt;b&gt;&lt;font size="3"&gt;Gerät&lt;/b&gt;&lt;/td&gt;&lt;/font&gt; &lt;td ALIGN="CENTER"&gt;&lt;b&gt;&lt;font size="3"&gt;Empfang&lt;/td&gt;&lt;td&gt;&lt;b&gt;&lt;font size="3"&gt;Batterie&lt;/td&gt;&lt;/b&gt;&lt;/font&gt; &lt;/tr&gt;</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD1">
                                                      <block type="text" id="`hArP:}QO5fa:5w(*q*y">
                                                        <field name="TEXT">&lt;tr&gt; &lt;td colspan="3"&gt; &lt;hr&gt; &lt;/dt&gt; &lt;/tr&gt;</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD2">
                                                      <block type="variables_get" id="!NM$6J~B9mGR:#`~#8V_">
                                                        <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD3">
                                                      <block type="variables_get" id="JwXRwyMGnb)]ut6eTQc-">
                                                        <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD4">
                                                      <block type="text" id="#E/@/Eiu!x|i4nvHP^wR">
                                                        <field name="TEXT">&lt;/tbody&gt; &lt;/table&gt;</field>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </value>
                                              </block>
                                            </next>
                                          </block>
                                        </next>
                                      </block>
                                    </next>
                                  </block>
                                </statement>
                              </block>
                              <block type="on" id="k)/GPwn,Ai1xQWMru#XP" x="2588" y="913">
                                <field name="OID">Object ID</field>
                                <field name="CONDITION">ne</field>
                                <field name="ACK_CONDITION"></field>
                                <statement name="STATEMENT">
                                  <block type="controls_if" id="~qvH+0YpjVp,Up4H}rse">
                                    <value name="IF0">
                                      <block type="logic_operation" id="$F8H_ZGF@RaAR[2,0g@]" inline="false">
                                        <field name="OP">AND</field>
                                        <value name="A">
                                          <block type="logic_operation" id="JI^H99UL7*O/y}9[BZ5x" inline="false">
                                            <field name="OP">AND</field>
                                            <value name="A">
                                              <block type="on_source" id="L#/tdkWZf)v+u?-:^kS`">
                                                <field name="ATTR">state.val</field>
                                              </block>
                                            </value>
                                            <value name="B">
                                              <block type="time_compare_ex" id="noas!J;rd}@=E1Qd.@E2">
                                                <mutation xmlns="http://www.w3.org/1999/xhtml" end_time="false" actual_time="true"></mutation>
                                                <field name="USE_ACTUAL_TIME">TRUE</field>
                                                <field name="OPTION">&gt;</field>
                                                <value name="START_TIME">
                                                  <shadow type="text" id="CWa`#oUK-B%`3Bry#VDS">
                                                    <field name="TEXT">12:00</field>
                                                  </shadow>
                                                  <block type="time_astro" id=":0;^TEMPv9K+l#d-d]YC">
                                                    <field name="TYPE">sunset</field>
                                                    <field name="OFFSET">0</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </value>
                                          </block>
                                        </value>
                                        <value name="B">
                                          <block type="logic_operation" id="6HFQ1rviOw$8,5ab?ROD" inline="false">
                                            <field name="OP">AND</field>
                                            <value name="A">
                                              <block type="time_compare_ex" id="5JfqNvMgj2*He))e-bGJ">
                                                <mutation xmlns="http://www.w3.org/1999/xhtml" end_time="true" actual_time="true"></mutation>
                                                <field name="USE_ACTUAL_TIME">TRUE</field>
                                                <field name="OPTION">between</field>
                                                <value name="START_TIME">
                                                  <shadow type="text" id="WAylgVP*SYA=qW^$ES`e">
                                                    <field name="TEXT">14:00</field>
                                                  </shadow>
                                                </value>
                                                <value name="END_TIME">
                                                  <shadow type="text" id="pznz.fMKcd3czBZ?l/Ay">
                                                    <field name="TEXT">22:00</field>
                                                  </shadow>
                                                </value>
                                              </block>
                                            </value>
                                            <value name="B">
                                              <block type="logic_compare" id="3d{67P$K+J5-#dyCuE^G">
                                                <field name="OP">LTE</field>
                                                <value name="A">
                                                  <block type="get_value" id="I:P-,dUTS@U3Z[AiQ[^K">
                                                    <field name="ATTR">val</field>
                                                    <field name="OID">ID auswählen</field>
                                                  </block>
                                                </value>
                                                <value name="B">
                                                  <block type="math_number" id="g:F-yJ%D5@7_P)jwDi@c">
                                                    <field name="NUM">50</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </value>
                                          </block>
                                        </value>
                                      </block>
                                    </value>
                                    <statement name="DO0">
                                      <block type="control" id="lm317`C#He/{X%x[F!(R">
                                        <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                        <field name="OID">Object ID</field>
                                        <field name="WITH_DELAY">FALSE</field>
                                        <value name="VALUE">
                                          <block type="logic_boolean" id="uzij$_~_@5k{U)aW66,b">
                                            <field name="BOOL">TRUE</field>
                                          </block>
                                        </value>
                                        <next>
                                          <block type="control" id=".j,+D!_Mt#l;l~6IP1A!">
                                            <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                            <field name="OID">Object ID</field>
                                            <field name="WITH_DELAY">FALSE</field>
                                            <value name="VALUE">
                                              <block type="logic_boolean" id="Jg;[1]jF[mo{EizsSwuA">
                                                <field name="BOOL">TRUE</field>
                                              </block>
                                            </value>
                                            <next>
                                              <block type="control" id="~iWc#B_bEL9}g%-)e9LS">
                                                <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                                <field name="OID">Object ID</field>
                                                <field name="WITH_DELAY">FALSE</field>
                                                <value name="VALUE">
                                                  <block type="logic_boolean" id="Hsf+3)OE!tt_;o=EZT#/">
                                                    <field name="BOOL">TRUE</field>
                                                  </block>
                                                </value>
                                              </block>
                                            </next>
                                          </block>
                                        </next>
                                      </block>
                                    </statement>
                                  </block>
                                </statement>
                              </block>
                              <block type="schedule" id="vD?4P8_4h^iJ*OF2qK3T" x="1275" y="1883">
                                <field name="SCHEDULE">0 0 24 1 *</field>
                                <statement name="STATEMENT">
                                  <block type="variables_set" id="4z}3tFM[-B{$a.kc+AvI">
                                    <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                    <value name="VALUE">
                                      <block type="text" id="TDX|#FJ[@IY2flT%*Ikm">
                                        <field name="TEXT"></field>
                                      </block>
                                    </value>
                                    <next>
                                      <block type="variables_set" id="t8YDPBWZu(+tuQ=|$/v+">
                                        <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                        <value name="VALUE">
                                          <block type="text" id="1Q4hfJ5mP1Pd);Vs|2`3">
                                            <field name="TEXT"></field>
                                          </block>
                                        </value>
                                        <next>
                                          <block type="controls_forEach" id="G7PG7kH]5v]J~XpYRiD$">
                                            <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                            <value name="LIST">
                                              <block type="selector" id="g(:3UAD1EV!Q6#O:Pc*n">
                                                <field name="TEXT">hm-rpc.0.*.0.LOW_BAT</field>
                                              </block>
                                            </value>
                                            <statement name="DO">
                                              <block type="variables_set" id="*C,vv*VbOX)IE.%^D/9?">
                                                <field name="VAR" id="GI^dumJfw0)4Nzi2HVw`">ParentID</field>
                                                <value name="VALUE">
                                                  <block type="text_getSubstring" id="dMr`:~LUI3vG34f@AWGr" inline="false">
                                                    <mutation at1="true" at2="true"></mutation>
                                                    <field name="WHERE1">FROM_START</field>
                                                    <field name="WHERE2">FROM_START</field>
                                                    <value name="STRING">
                                                      <block type="variables_get" id="wxx`|q~AE%:JXvKbUp$6">
                                                        <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                                      </block>
                                                    </value>
                                                    <value name="AT1">
                                                      <block type="math_number" id="k)h).MDG(CzMy^n]mvCZ">
                                                        <field name="NUM">1</field>
                                                      </block>
                                                    </value>
                                                    <value name="AT2">
                                                      <block type="math_arithmetic" id="$y?j]UtW}2#Q|scXW`#F" inline="false">
                                                        <field name="OP">MINUS</field>
                                                        <value name="A">
                                                          <shadow type="math_number">
                                                            <field name="NUM">1</field>
                                                          </shadow>
                                                          <block type="text_indexOf" id="f=6l*(HC)l}`yZ].kX1f" inline="false">
                                                            <field name="END">LAST</field>
                                                            <value name="VALUE">
                                                              <block type="variables_get" id="M(r]/tAs,IgzQ~qj^-?S">
                                                                <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                                              </block>
                                                            </value>
                                                            <value name="FIND">
                                                              <shadow type="text" id="xK!Ejybg64*Y@)ela+3U">
                                                                <field name="TEXT">.0.LOW_BAT</field>
                                                              </shadow>
                                                            </value>
                                                          </block>
                                                        </value>
                                                        <value name="B">
                                                          <shadow type="math_number" id=":+{f~P]eWuHfU.y.t2ns">
                                                            <field name="NUM">1</field>
                                                          </shadow>
                                                        </value>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </value>
                                                <next>
                                                  <block type="controls_if" id="F2[688lSe+i|}y`y[T4o">
                                                    <mutation else="1"></mutation>
                                                    <value name="IF0">
                                                      <block type="get_value_var" id="Js,.0!~%88879Wf.uU1c">
                                                        <field name="ATTR">val</field>
                                                        <value name="OID">
                                                          <shadow type="text">
                                                            <field name="TEXT"></field>
                                                          </shadow>
                                                          <block type="variables_get" id="sxXQE%d=|*;,I(uh6o7M">
                                                            <field name="VAR" id="%62`(Q[9y{,UvP3o}T|/">i</field>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </value>
                                                    <statement name="DO0">
                                                      <block type="variables_set" id="0y)YwvPcZTf}bJf2q6_f">
                                                        <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                                        <value name="VALUE">
                                                          <block type="text_join" id="cYUYaybd((-9`2gK04={">
                                                            <mutation items="4"></mutation>
                                                            <value name="ADD0">
                                                              <block type="variables_get" id="*wS*l4WiZ?fbph3$$@KI">
                                                                <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                                              </block>
                                                            </value>
                                                            <value name="ADD1">
                                                              <block type="text" id="qJyH83oSM~)2ecb_HElw">
                                                                <field name="TEXT">&lt;tr&gt;&lt;td&gt;</field>
                                                              </block>
                                                            </value>
                                                            <value name="ADD2">
                                                              <block type="get_attr" id="~CNz_;si-7?/iUJ}O}sh" inline="false">
                                                                <value name="PATH">
                                                                  <shadow type="text" id="T]X-o3-j=0:52yBK?TZU">
                                                                    <field name="TEXT">common.name</field>
                                                                  </shadow>
                                                                </value>
                                                                <value name="OBJECT">
                                                                  <block type="procedures_callcustomreturn" id="$q1kDs~(/Y%wY(w_Gt^5">
                                                                    <mutation name="GetObjectByID">
                                                                      <arg name="id"></arg>
                                                                    </mutation>
                                                                    <value name="ARG0">
                                                                      <block type="variables_get" id="5`07PGHm^NaU=;881/{+">
                                                                        <field name="VAR" id="GI^dumJfw0)4Nzi2HVw`">ParentID</field>
                                                                      </block>
                                                                    </value>
                                                                  </block>
                                                                </value>
                                                              </block>
                                                            </value>
                                                            <value name="ADD3">
                                                              <block type="text" id="t2@Ef3wM8fAk+6Rzh)kB">
                                                                <field name="TEXT">&lt;/td&gt; &lt;td ALIGN="CENTER"&gt;&lt;font size="3"&gt;&lt;b&gt;&lt;font color=red&gt;●&lt;/font&gt; &lt;/td&gt; &lt;/tr&gt;</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </statement>
                                                    <statement name="ELSE">
                                                      <block type="variables_set" id="CK-4IOyf7c^=*:)CI{:.">
                                                        <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                                        <value name="VALUE">
                                                          <block type="text_join" id="%_AS.K%88@/4h5n]+/Z)">
                                                            <mutation items="4"></mutation>
                                                            <value name="ADD0">
                                                              <block type="variables_get" id="()Tbz+lM!6E%=sY$7SYA">
                                                                <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                                              </block>
                                                            </value>
                                                            <value name="ADD1">
                                                              <block type="text" id="}84f{/MFSl^t=(q7esHj">
                                                                <field name="TEXT">&lt;tr&gt;&lt;td&gt;</field>
                                                              </block>
                                                            </value>
                                                            <value name="ADD2">
                                                              <block type="get_attr" id="0{=v$qHI8[5M4.,lUM1+" inline="false">
                                                                <value name="PATH">
                                                                  <shadow type="text" id="6-H/m^+6F;gdO!98+7N+">
                                                                    <field name="TEXT">common.name</field>
                                                                  </shadow>
                                                                </value>
                                                                <value name="OBJECT">
                                                                  <block type="procedures_callcustomreturn" id="!*hR{4AyjwRZ!Rj1[f]+">
                                                                    <mutation name="GetObjectByID">
                                                                      <arg name="id"></arg>
                                                                    </mutation>
                                                                    <value name="ARG0">
                                                                      <block type="variables_get" id="-N?(LGF^^^@0U[DVPZ,(">
                                                                        <field name="VAR" id="GI^dumJfw0)4Nzi2HVw`">ParentID</field>
                                                                      </block>
                                                                    </value>
                                                                  </block>
                                                                </value>
                                                              </block>
                                                            </value>
                                                            <value name="ADD3">
                                                              <block type="text" id="~86TCmJVtP+EyDRPOB7H">
                                                                <field name="TEXT">&lt;/td&gt; &lt;td ALIGN="CENTER"&gt;&lt;font size="3"&gt;&lt;b&gt;&lt;font color=green&gt;●&lt;/font&gt; &lt;/td&gt; &lt;/tr&gt;</field>
                                                              </block>
                                                            </value>
                                                          </block>
                                                        </value>
                                                      </block>
                                                    </statement>
                                                  </block>
                                                </next>
                                              </block>
                                            </statement>
                                            <next>
                                              <block type="update" id="MdJIcB`laE/C88CVWs}L">
                                                <mutation xmlns="http://www.w3.org/1999/xhtml" delay_input="false"></mutation>
                                                <field name="OID">0_userdata.0.VIS.Akkumeldungen.hmip_akku_tabelle</field>
                                                <field name="WITH_DELAY">FALSE</field>
                                                <value name="VALUE">
                                                  <block type="text_join" id="z%zS`jgXUt(H}rDq:*lG">
                                                    <mutation items="5"></mutation>
                                                    <value name="ADD0">
                                                      <block type="text" id="r@OG:#VL@y/meB1lX*Tb">
                                                        <field name="TEXT">&lt;table style="width: 100%;"&gt; &lt;tbody&gt; &lt;tr&gt; &lt;td width=100%&gt;&lt;b&gt;&lt;font size="3"&gt;Gerät&lt;/b&gt;&lt;/td&gt;&lt;/font&gt; &lt;td ALIGN="CENTER"&gt;&lt;b&gt;&lt;font size="3"&gt;Batteriestatus&lt;/td&gt;&lt;/b&gt;&lt;/font&gt; &lt;/tr&gt;</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD1">
                                                      <block type="text" id="33x|0nNDQbgdS6_Ot$Zq">
                                                        <field name="TEXT">&lt;tr&gt; &lt;td colspan="3"&gt; &lt;hr&gt; &lt;/dt&gt; &lt;/tr&gt;</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD2">
                                                      <block type="variables_get" id="ysv$)6zoPcsG4:n3]`v|">
                                                        <field name="VAR" id=";O,|I4cqK/q|U6dt.?NN">falsch</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD3">
                                                      <block type="variables_get" id="GRuS/b{_-A/#w*w2Y,87">
                                                        <field name="VAR" id="SKh+R[G%ptX]9uv^hB,!">wahr</field>
                                                      </block>
                                                    </value>
                                                    <value name="ADD4">
                                                      <block type="text" id="X|y`L8o!0RAd?VKIrJKS">
                                                        <field name="TEXT">&lt;/tbody&gt; &lt;/table&gt;</field>
                                                      </block>
                                                    </value>
                                                  </block>
                                                </value>
                                              </block>
                                            </next>
                                          </block>
                                        </next>
                                      </block>
                                    </next>
                                  </block>
                                </statement>
                              </block>
                            </xml>
                            
                            dontobi 1 Reply Last reply Reply Quote 0
                            • dontobi
                              dontobi @David G. last edited by

                              @david-g Das hier ist mein aktueller Stand. Halt nur ohne eine Schleife, was das ganze vereinfachen würde. Ich habe aber eine Idee, wie ich es machen kann, dazu fehlt mir aber heute die Zeit.

                              // Markdown Aufbereitung - Pollenflug
                              var ambrosia_morgen, ambrosia, beifuss_morgen, beifuss, birke_morgen, birke, erle_morgen, erle, esche_morgen, esche, graeser_morgen, graeser, hasel_morgen, hasel, roggen_morgen, roggen;
                              schedule("5 11 * * *", async function () {
                                if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 0) {
                                  ambrosia_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 1) {
                                  ambrosia_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 2) {
                                  ambrosia_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 3) {
                                  ambrosia_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 4) {
                                  ambrosia_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 5) {
                                  ambrosia_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 6) {
                                  ambrosia_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Ambrosia.index_today").val == 0) {
                                  ambrosia = ['<tr><td><b>Ambrosia</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',ambrosia_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_today").val == 1) {
                                  ambrosia = ['<tr><td><b>Ambrosia</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',ambrosia_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_today").val == 2) {
                                  ambrosia = ['<tr><td><b>Ambrosia</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',ambrosia_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_today").val == 3) {
                                  ambrosia = ['<tr><td><b>Ambrosia</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',ambrosia_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_today").val == 4) {
                                  ambrosia = ['<tr><td><b>Ambrosia</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',ambrosia_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_today").val == 5) {
                                  ambrosia = ['<tr><td><b>Ambrosia</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',ambrosia_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Ambrosia.index_today").val == 6) {
                                  ambrosia = ['<tr><td><b>Ambrosia</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',ambrosia_morgen,'</td></tr>'].join('');
                                }
                                if (getState("pollenflug.0.region#101.Ambrosia.index_tomorrow").val == 0) {
                                  beifuss_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_tomorrow").val == 1) {
                                  beifuss_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_tomorrow").val == 2) {
                                  beifuss_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_tomorrow").val == 3) {
                                  beifuss_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_tomorrow").val == 4) {
                                  beifuss_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_tomorrow").val == 5) {
                                  beifuss_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_tomorrow").val == 6) {
                                  beifuss_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Beifuss.index_today").val == 0) {
                                  beifuss = ['<tr><td><b>Beifuss</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',beifuss_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_today").val == 1) {
                                  beifuss = ['<tr><td><b>Beifuss</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',beifuss_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_today").val == 2) {
                                  beifuss = ['<tr><td><b>Beifuss</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',beifuss_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_today").val == 3) {
                                  beifuss = ['<tr><td><b>Beifuss</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',beifuss_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_today").val == 4) {
                                  beifuss = ['<tr><td><b>Beifuss</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',beifuss_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_today").val == 5) {
                                  beifuss = ['<tr><td><b>Beifuss</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',beifuss_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Beifuss.index_today").val == 6) {
                                  beifuss = ['<tr><td><b>Beifuss</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',beifuss_morgen,'</td></tr>'].join('');
                                }
                                if (getState("pollenflug.0.region#101.Birke.index_tomorrow").val == 0) {
                                  birke_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Birke.index_tomorrow").val == 1) {
                                  birke_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Birke.index_tomorrow").val == 2) {
                                  birke_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Birke.index_tomorrow").val == 3) {
                                  birke_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Birke.index_tomorrow").val == 4) {
                                  birke_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Birke.index_tomorrow").val == 5) {
                                  birke_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Birke.index_tomorrow").val == 6) {
                                  birke_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Birke.index_today").val == 0) {
                                  birke = ['<tr><td><b>Birke</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',birke_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Birke.index_today").val == 1) {
                                  birke = ['<tr><td><b>Birke</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',birke_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Birke.index_today").val == 2) {
                                  birke = ['<tr><td><b>Birke</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',birke_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Birke.index_today").val == 3) {
                                  birke = ['<tr><td><b>Birke</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',birke_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Birke.index_today").val == 4) {
                                  birke = ['<tr><td><b>Birke</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',birke_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Birke.index_today").val == 5) {
                                  birke = ['<tr><td><b>Birke</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',birke_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Birke.index_today").val == 6) {
                                  birke = ['<tr><td><b>Birke</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',birke_morgen,'</td></tr>'].join('');
                                }
                                if (getState("pollenflug.0.region#101.Erle.index_tomorrow").val == 0) {
                                  erle_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Erle.index_tomorrow").val == 1) {
                                  erle_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Erle.index_tomorrow").val == 2) {
                                  erle_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Erle.index_tomorrow").val == 3) {
                                  erle_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Erle.index_tomorrow").val == 4) {
                                  erle_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Erle.index_tomorrow").val == 5) {
                                  erle_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Erle.index_tomorrow").val == 6) {
                                  erle_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Erle.index_today").val == 0) {
                                  erle = ['<tr><td><b>Erle</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',erle_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Erle.index_today").val == 1) {
                                  erle = ['<tr><td><b>Erle</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',erle_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Erle.index_today").val == 2) {
                                  erle = ['<tr><td><b>Erle</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',erle_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Erle.index_today").val == 3) {
                                  erle = ['<tr><td><b>Erle</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',erle_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Erle.index_today").val == 4) {
                                  erle = ['<tr><td><b>Erle</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',erle_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Erle.index_today").val == 5) {
                                  erle = ['<tr><td><b>Erle</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',erle_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Erle.index_today").val == 6) {
                                  erle = ['<tr><td><b>Erle</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',erle_morgen,'</td></tr>'].join('');
                                }
                                if (getState("pollenflug.0.region#101.Esche.index_tomorrow").val == 0) {
                                  esche_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Esche.index_tomorrow").val == 1) {
                                  esche_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Esche.index_tomorrow").val == 2) {
                                  esche_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Esche.index_tomorrow").val == 3) {
                                  esche_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Esche.index_tomorrow").val == 4) {
                                  esche_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Esche.index_tomorrow").val == 5) {
                                  esche_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Esche.index_tomorrow").val == 6) {
                                  esche_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Esche.index_today").val == 0) {
                                  esche = ['<tr><td><b>Esche</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',esche_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Esche.index_today").val == 1) {
                                  esche = ['<tr><td><b>Esche</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',esche_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Esche.index_today").val == 2) {
                                  esche = ['<tr><td><b>Esche</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',esche_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Esche.index_today").val == 3) {
                                  esche = ['<tr><td><b>Esche</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',esche_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Esche.index_today").val == 4) {
                                  esche = ['<tr><td><b>Esche</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',esche_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Esche.index_today").val == 5) {
                                  esche = ['<tr><td><b>Esche</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',esche_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Esche.index_today").val == 6) {
                                  esche = ['<tr><td><b>Esche</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',esche_morgen,'</td></tr>'].join('');
                                }
                                if (getState("pollenflug.0.region#101.Graeser.index_tomorrow").val == 0) {
                                  graeser_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Graeser.index_tomorrow").val == 1) {
                                  graeser_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Graeser.index_tomorrow").val == 2) {
                                  graeser_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Graeser.index_tomorrow").val == 3) {
                                  graeser_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Graeser.index_tomorrow").val == 4) {
                                  graeser_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Graeser.index_tomorrow").val == 5) {
                                  graeser_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Graeser.index_tomorrow").val == 6) {
                                  graeser_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Graeser.index_today").val == 0) {
                                  graeser = ['<tr><td><b>Gräser</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',graeser_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Graeser.index_today").val == 1) {
                                  graeser = ['<tr><td><b>Gräser</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',graeser_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Graeser.index_today").val == 2) {
                                  graeser = ['<tr><td><b>Gräser</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',graeser_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Graeser.index_today").val == 3) {
                                  graeser = ['<tr><td><b>Gräser</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',graeser_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Graeser.index_today").val == 4) {
                                  graeser = ['<tr><td><b>Gräser</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',graeser_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Graeser.index_today").val == 5) {
                                  graeser = ['<tr><td><b>Gräser</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',graeser_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Graeser.index_today").val == 6) {
                                  graeser = ['<tr><td><b>Gräser</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',graeser_morgen,'</td></tr>'].join('');
                                }
                                if (getState("pollenflug.0.region#101.Hasel.index_tomorrow").val == 0) {
                                  hasel_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Hasel.index_tomorrow").val == 1) {
                                  hasel_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Hasel.index_tomorrow").val == 2) {
                                  hasel_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Hasel.index_tomorrow").val == 3) {
                                  hasel_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Hasel.index_tomorrow").val == 4) {
                                  hasel_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Hasel.index_tomorrow").val == 5) {
                                  hasel_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Hasel.index_tomorrow").val == 6) {
                                  hasel_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Hasel.index_today").val == 0) {
                                  hasel = ['<tr><td><b>Hasel</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',hasel_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Hasel.index_today").val == 1) {
                                  hasel = ['<tr><td><b>Hasel</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',hasel_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Hasel.index_today").val == 2) {
                                  hasel = ['<tr><td><b>Hasel</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',hasel_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Hasel.index_today").val == 3) {
                                  hasel = ['<tr><td><b>Hasel</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',hasel_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Hasel.index_today").val == 4) {
                                  hasel = ['<tr><td><b>Hasel</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',hasel_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Hasel.index_today").val == 5) {
                                  hasel = ['<tr><td><b>Hasel</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',hasel_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Hasel.index_today").val == 6) {
                                  hasel = ['<tr><td><b>Hasel</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',hasel_morgen,'</td></tr>'].join('');
                                }
                                if (getState("pollenflug.0.region#101.Roggen.index_tomorrow").val == 0) {
                                  roggen_morgen = '<font size="3"><b><font color=#00FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Roggen.index_tomorrow").val == 1) {
                                  roggen_morgen = '<font size="3"><b><font color=#80FF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Roggen.index_tomorrow").val == 2) {
                                  roggen_morgen = '<font size="3"><b><font color=#FFFF00>●</font>';
                                } else if (getState("pollenflug.0.region#101.Roggen.index_tomorrow").val == 3) {
                                  roggen_morgen = '<font size="3"><b><font color=#FFC400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Roggen.index_tomorrow").val == 4) {
                                  roggen_morgen = '<font size="3"><b><font color=#FF8800>●</font>';
                                } else if (getState("pollenflug.0.region#101.Roggen.index_tomorrow").val == 5) {
                                  roggen_morgen = '<font size="3"><b><font color=#FF4400>●</font>';
                                } else if (getState("pollenflug.0.region#101.Roggen.index_tomorrow").val == 6) {
                                  roggen_morgen = '<font size="3"><b><font color=#FF0000>●</font>';
                                }
                                if (getState("pollenflug.0.region#101.Roggen.index_today").val == 0) {
                                  roggen = ['<tr><td><b>Roggen</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#00FF00>●</font> </td><td ALIGN="CENTER">',roggen_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Roggen.index_today").val == 1) {
                                  roggen = ['<tr><td><b>Roggen</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#80FF00>●</font> </td><td ALIGN="CENTER">',roggen_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Roggen.index_today").val == 2) {
                                  roggen = ['<tr><td><b>Roggen</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFFF00>●</font> </td><td ALIGN="CENTER">',roggen_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Roggen.index_today").val == 3) {
                                  roggen = ['<tr><td><b>Roggen</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FFC400>●</font> </td><td ALIGN="CENTER">',roggen_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Roggen.index_today").val == 4) {
                                  roggen = ['<tr><td><b>Roggen</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF8800>●</font> </td><td ALIGN="CENTER">',roggen_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Roggen.index_today").val == 5) {
                                  roggen = ['<tr><td><b>Roggen</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF4400>●</font> </td><td ALIGN="CENTER">',roggen_morgen,'</td></tr>'].join('');
                                } else if (getState("pollenflug.0.region#101.Roggen.index_today").val == 6) {
                                  roggen = ['<tr><td><b>Roggen</b>','</td> <td ALIGN="CENTER"><font size="3"><b><font color=#FF0000>●</font> </td><td ALIGN="CENTER">',roggen_morgen,'</td></tr>'].join('');
                                }
                                setState("javascript.0.Lovelace.pollenflug"/*pollenflug*/, (['<table style="width: 100%;"> <tbody> <tr> <td width=100%><b><font size="3">Typ</b></td></font> <td ALIGN="CENTER"><b><font size="3">Heute</td><td><b><font size="3">Morgen</td></b></font> </tr>','<tr> <td colspan="3"> <hr> </dt> </tr>',ambrosia,beifuss,birke,erle,esche,graeser,hasel,roggen,'</tbody> </table>'].join('')), true);
                              });
                              
                              1 Reply Last reply Reply Quote 0
                              • Garfonso
                                Garfonso Developer @dontobi last edited by Garfonso

                                @dontobi said in [Lovelace] HTML Code anzeigen:

                                ebenfalls feststellen müssen, dass Lovelace die Farben komplett ignoriert

                                Habt ihr mal versucht Klassen zu nutzen, die Lovelace selber nutzt?
                                Oder zumindest die Variablen als Farbe? Also z.B. sowas: var(--primary-background)

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

                                  Okay. Ich hatte Zeit und habe das Script vereinfacht und möchte es euch zur Verfügung stellen. Zusätzlich werde ich das Script auch im Lovelace Thread posten.

                                  Hier der Code des Scripts. Wer es für sich anpassen möchte, sollte das Objekt (Zeile 4 und 15) und die Region (Zeile 22 und 23) anpassen.

                                  // Pollenflug - Aufbereitung der Daten für die Anzeige in der Lovelace UI
                                  
                                  createState('javascript.0.Lovelace.pollenflug', { name: 'Pollenflug - HTML', type: 'string', read: true, write: true, });
                                  
                                  // Um 11:00 Uhr werden die Adapter-Daten aktualisiert - 11:05 Uhr werden die HTML-Daten neu erzeugt
                                  schedule("5 11 * * *", async function () {
                                      let htmlStr = '';
                                      let pollen =['Ambrosia','Beifuss','Birke','Erle','Esche','Graeser','Hasel','Roggen'];
                                      htmlStr = ['<table style="width: 100%;"><tbody><tr><td width=100%><b><font size="3">Typ</b></td></font><td ALIGN="CENTER"><b><font size="3">Heute</td><td><b><font size="3">Morgen</td></b></font></tr><tr><td colspan="3"><hr></dt></tr>'].join('');
                                      for (let j = 0; j< pollen.length ; j++) {
                                          htmlStr = htmlStr + auswertung(pollen[j]);
                                      }
                                      htmlStr = htmlStr + ['</tbody></table>'].join('');
                                      setState('javascript.0.Lovelace.pollenflug', htmlStr, true);
                                  });
                                  
                                  function auswertung(name){
                                      let html = '';
                                      let farbe_heute = '';
                                      let farbe_morgen = '';
                                      const heute = getState('pollenflug.0.region#101.'+name+'.index_today').val;
                                      const morgen = getState('pollenflug.0.region#101.'+name+'.index_tomorrow').val;
                                      // Berechnung Pollenflug heute
                                      if (heute == 0) {
                                          farbe_heute = '#00FF00';
                                      } else if (heute == 1) {
                                          farbe_heute = '#FFFF00';
                                      } else if (heute == 2) {
                                          farbe_heute = '#FFCC00';
                                      } else if (heute == 3) {
                                          farbe_heute = '#FF9900';
                                      } else if (heute == 4) {
                                          farbe_heute = '#FF6600';
                                      } else if (heute == 5) {
                                          farbe_heute = '#FF3300';
                                      } else if (heute == 6) {
                                          farbe_heute = '#FF0000';
                                      }
                                      // Berechnung Pollenflug morgen
                                      if (morgen == 0) {
                                          farbe_morgen = '#00FF00';
                                      } else if (morgen == 1) {
                                          farbe_morgen = '#FFFF00';
                                      } else if (morgen == 2) {
                                          farbe_morgen = '#FFCC00';
                                      } else if (morgen == 3) {
                                          farbe_morgen = '#FF9900';
                                      } else if (morgen == 4) {
                                          farbe_morgen = '#FF6600';
                                      } else if (morgen == 5) {
                                          farbe_morgen = '#FF3300';
                                      } else if (morgen == 6) {
                                          farbe_morgen = '#FF0000';
                                      }
                                      // Setze die Daten zusammen
                                      html = ['<tr><td><b>',name,'</b>','</td><td ALIGN="CENTER"><font size="3" color=',farbe_heute,'>●</font></td><td ALIGN="CENTER"><font size="3" color=',farbe_morgen,'>●</font></td></tr>'].join('');
                                      return html;
                                  }
                                  

                                  Ergebnis sieht dann so aus.
                                  4dfb5051-0946-4ba9-815f-c3f5edc29217-image.png

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

                                    Hallo zusammen,
                                    ich weiß dass der Thread schon relativalt ist, hoffe aber trotzdem auf Unterstützung, da ich den Code aufgrund von mangelnder Programmierkenntnis nicht ganz verstehe.

                                    Ich habe eine JSON Datei, die ich mir immer als Tabelle in VIS angezeigt habe. Bin jetzt aber auf Lovelace umgestiegen und versuche diese zu integrieren.
                                    Das Skript aus dem ersten Post funktioniert schonmal, meine Werte werden jedoch nicht übernommen.
                                    28dcac7e-cc7b-4bf6-974e-e207889c5a9f-grafik.png

                                    Meine JSON Datei:

                                    [{"Strom":"Gesamt","Jetzt":"1287.59","Letztes":"1179.32","Kosten":"424.90 | 389.18"},{"Strom":1,"DiesesJahr":"366.64","LetztesJahr":"0.00","Kosten":"120.99 | 0.00"},{"Strom":2,"DiesesJahr":"362.87","LetztesJahr":"0.00","Kosten":"119.75 | 0.00"},{"Strom":3,"DiesesJahr":"334.36","LetztesJahr":"425.00","Kosten":"110.34 | 0.00"},{"Strom":4,"DiesesJahr":"223.72","LetztesJahr":"365.00","Kosten":"73.83 | 0.00"},{"Strom":5,"DiesesJahr":"0.00","LetztesJahr":"285.00","Kosten":"0.00 | 0.00"},{"Strom":6,"DiesesJahr":"0.00","LetztesJahr":"239.00","Kosten":"0.00 | 0.00"},{"Strom":7,"DiesesJahr":"0.00","LetztesJahr":"250.00","Kosten":"0.00 | 0.00"},{"Strom":8,"DiesesJahr":"0.00","LetztesJahr":"278.00","Kosten":"0.00 | 0.00"},{"Strom":9,"DiesesJahr":"0.00","LetztesJahr":"259.88","Kosten":"0.00 | 85.76"},{"Strom":10,"DiesesJahr":"0.00","LetztesJahr":"254.38","Kosten":"0.00 | 83.95"},{"Strom":11,"DiesesJahr":"0.00","LetztesJahr":"293.34","Kosten":"0.00 | 96.80"},{"Strom":12,"DiesesJahr":"0.00","LetztesJahr":"371.72","Kosten":"0.00 | 122.67"}]
                                    

                                    Der generierte HTML Code:

                                    <table><thead><tr><th>Strom</th><th>Jetzt</th><th>Letztes</th><th>Kosten</th></tr></thead><tbody><tr><td>Gesamt</td><td>1287.53</td><td>1179.32</td><td>424.88 | 389.18</td></tr><tr><td>1</td><td>undefined</td><td>undefined</td><td>120.99 | 0.00</td></tr><tr><td>2</td><td>undefined</td><td>undefined</td><td>119.75 | 0.00</td></tr><tr><td>3</td><td>undefined</td><td>undefined</td><td>110.34 | 0.00</td></tr><tr><td>4</td><td>undefined</td><td>undefined</td><td>73.81 | 0.00</td></tr><tr><td>5</td><td>undefined</td><td>undefined</td><td>0.00 | 0.00</td></tr><tr><td>6</td><td>undefined</td><td>undefined</td><td>0.00 | 0.00</td></tr><tr><td>7</td><td>undefined</td><td>undefined</td><td>0.00 | 0.00</td></tr><tr><td>8</td><td>undefined</td><td>undefined</td><td>0.00 | 0.00</td></tr><tr><td>9</td><td>undefined</td><td>undefined</td><td>0.00 | 85.76</td></tr><tr><td>10</td><td>undefined</td><td>undefined</td><td>0.00 | 83.95</td></tr><tr><td>11</td><td>undefined</td><td>undefined</td><td>0.00 | 96.80</td></tr><tr><td>12</td><td>undefined</td><td>undefined</td><td>0.00 | 122.67</td></tr></tbody></table>
                                    

                                    Kann mir jemand helfen?

                                    David G. 1 Reply Last reply Reply Quote 0
                                    • David G.
                                      David G. @planetkeane last edited by

                                      @planetkeane

                                      Das Problem liegt hier nicht bei lovelace sondern im Script das den Code generiert.

                                      Man sieht ja schon, dass im HTML alles fehlt.

                                      Man müsste das Script mal sehen (wobei ich da auch nur bei blockly etwas helfen könnte).

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

                                        @David-G Ja klar, es liegt definitiv am Script. Daher wollte ich auch die Hilfe, falls jemand weiß, was zu tun ist.

                                        Das Skript:

                                        /******************************************************************************************************
                                         * JSON-Datenpunkt in HTML umwandeln
                                         * --------------------------------------------------------------
                                         * Zweck:      Überwacht einen JSON-Datenpunkt und sobald geändert, wird JSON in HTML umgewandelt und
                                         *             in einem eigenen Datenpunkt ausgegeben
                                         * Publiziert: https://forum.iobroker.net/topic/32540/json-zu-html-und-in-datei-schreiben-ablegen
                                         * Autor:      Mic-M (Github) | Mic (ioBroker)
                                         * --------------------------------------------------------------------------------------
                                         * Change Log:
                                         *  0.0.1  Mic-M   * Initial release
                                         ******************************************************************************************************/
                                        
                                        /*********************************************************************************************
                                         * Einstellungen
                                         *********************************************************************************************/
                                        // JSON-Datenpunkt
                                        const g_jsonState = 'logparser.0.filters.Info.json';
                                        
                                        // Neuer Datenpunkt für HTML-Ausgabe
                                        const g_htmlState = 'javascript.0.html-tables.log-Info';
                                        
                                        // Spalte entfernen (für Log Parser Adapter 'ts' nehmen, da dieser autmatisch den timestamp hinzufügt),
                                        // sonst leer lassen
                                        const g_removeColumn = 'ts';
                                        
                                        
                                        /*********************************************************************************************
                                         * Ab hier nichts mehr ändern
                                         *********************************************************************************************/
                                        main();
                                        function main() {
                                        
                                            // Create state for HTML, if not yet existing
                                            createState(g_htmlState, {'name':'HTML Table', 'type':'string', 'read':true, 'write':false, 'role':'html', 'def':'' }, () => {
                                                // State created, so let's subscribe to the given JSON state
                                                on({id: g_jsonState, change:'ne'}, function(obj) {
                                                    // JSON state changed            
                                                    if(obj.state.val && obj.state.val.length > 10) {
                                                        // state is not empty
                                                        const jsonObject = JSON.parse(obj.state.val);
                                                        if(g_removeColumn) {
                                                            for (let lpEntry of jsonObject) {
                                                                delete lpEntry[g_removeColumn];
                                                            }
                                                        }
                                                        setState(g_htmlState, json2table(jsonObject, ''));
                                                    }
                                                });
                                        
                                            });
                                        
                                        }
                                        
                                        
                                        
                                        /**
                                         * Convert JSON to HTML table
                                         * Source: https://travishorn.com/building-json2table-turn-json-into-an-html-table-a57cf642b84a
                                         * 
                                         * @param {object}  jsonObject    The JSON as object.
                                         * @param {string}  [classes]     Optional: You can apply one or multiple classes (space separated) to <table>.
                                         * @return {string}               The HTML result as string
                                         */
                                        function json2table(jsonObject, classes = '') {
                                            const cols = Object.keys(jsonObject[0]);
                                        
                                            let headerRow = '';
                                            let bodyRows = '';
                                        
                                            classes = classes || '';
                                        
                                            cols.map(function(col) {
                                                headerRow += '<th>' + capitalizeFirstLetter(col) + '</th>';
                                            });
                                        
                                            jsonObject.map(function(row) {
                                        
                                                bodyRows += '<tr>';
                                        
                                                cols.map(function(colName) {
                                                    bodyRows += '<td>' + row[colName] + '</td>';
                                                })
                                        
                                                bodyRows += '</tr>';
                                        
                                            });
                                        
                                            const addClasses = (classes && classes.length > 1) ? ' class="' + classes + '"' : '';
                                            return '<table' + addClasses + '><thead><tr>' +
                                                    headerRow +
                                                    '</tr></thead><tbody>' +
                                                    bodyRows +
                                                    '</tbody></table>';
                                        
                                            function capitalizeFirstLetter(string) {
                                                return string.charAt(0).toUpperCase() + string.slice(1);
                                            }
                                        
                                        }
                                        
                                        Garfonso 1 Reply Last reply Reply Quote 0
                                        • Garfonso
                                          Garfonso Developer @planetkeane last edited by

                                          Dein JSON passt halt nicht zum Skript. Das Skript geht davon aus, dass du in jedem Array Eintrag ein Objekt hast mit denselben Feldern. Bei dir heißen die aber anders. Beim ersten steht nur "Letztes" und beim zweiten heißt es dann "Letztes Jahr" oder "Jetzt" und "Dieses Jahr".

                                          Entweder musst du dein JSON so bauen, dass die Felder immer identisch sind oder das Skript anpassen (wobei du dann den Tabellen Header auch anders machen musst oder so).

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

                                            Ich habe mir jetzt ein neues Skript gebaut, dass direkt aus den Objekten von Sourceanalytix eine HTML Tabelle erstellt. Diese funktioniert auch ganz gut, obwohl ich da bestimmt noch ein paar Verbesserungen durchführen werde.

                                            Falls es jemanden interessiert:

                                            
                                            
                                            // Erstelle ein HTML-Objekt im Verzeichnis 0_userdata.0.test
                                            /*
                                            *   >>>>>>> Hier Eingabewerte <<<<<<<
                                            */
                                            var anzeigeName = 'Computer';
                                            var verzeichnisSave = '0_userdata.0.HTML.StromverbrauchComputer';
                                            var verzeichnisPfad = 'sourceanalytix.0.0_userdata__0__Energiezaehler__Computer';
                                            // 1 für "consumed", 2 für delivered
                                            var methode = 2;
                                            
                                            //>>>>>>>>>>>>>>>>>>>>>>>>>><<<<<<<<<<<<<<<<<<<
                                            
                                            
                                            
                                            createState(verzeichnisSave, {
                                                type: 'string',
                                                common: {
                                                    name: 'HTML-Objekt',
                                                    role: 'html',
                                                    read: true,
                                                    write: false,
                                                },
                                                native: {},
                                            });
                                            
                                            
                                            //schedule("*/30 * * * *", async function () {
                                            on({ id: [].concat(['0_userdata.0.TabellenHTMLAktualisieren']), change: "any" }, async function (obj) {
                                                var value = obj.state.val;
                                                var oldValue = obj.oldState.val;
                                            
                                            
                                                // Jahresvariablen
                                                var aktuellesDatum = new Date(),
                                                    jahr = aktuellesDatum.getFullYear(),
                                                    vorJahr = jahr - 1;
                                            
                                                // Gesamtvariable
                                                var GesamtJetzt = 0,
                                                    GesamtVorher = 0,
                                                    GesamtKostenJetzt = 0,
                                                    GesamtKostenVorher = 0;
                                            
                                                /*
                                                *   Hier den Spaltennamen eingeben
                                                */
                                            
                                                // Erstelle den HTML-Code für die Tabelle
                                                var tableHTML = '<table><thead><tr><th>' + anzeigeName + '</th><th>Dieses Jahr</th><th>Letztes Jahr</th><th>Kosten</th></tr></thead><tbody>';
                                                var names = "";
                                                for (var i = 1; i <= 12; i++) {
                                                    var month = (i < 10) ? "0" + i : i;
                                                    if (i == 1) {
                                                        names = "January";
                                                    } else if (i == 2) {
                                                        names = "February";
                                                    } else if (i == 3) {
                                                        names = "March";
                                                    } else if (i == 4) {
                                                        names = "April";
                                                    } else if (i == 5) {
                                                        names = "May";
                                                    } else if (i == 6) {
                                                        names = "June";
                                                    } else if (i == 7) {
                                                        names = "July";
                                                    } else if (i == 8) {
                                                        names = "August";
                                                    } else if (i == 9) {
                                                        names = "September";
                                                    } else if (i == 10) {
                                                        names = "October";
                                                    } else if (i == 11) {
                                                        names = "November";
                                                    } else if (i == 12) {
                                                        names = "December";
                                                    }
                                            
                                                    /*
                                                    *       Hier den Quellpfad angeben
                                                    */
                                                    if (methode == 1) {
                                                        var valueThisYear = getState(verzeichnisPfad + '.' + jahr + ".consumed.months." + month + "_" + names).val;
                                                        var cost = valueThisYear * 0.33;
                                                        GesamtJetzt += valueThisYear;
                                                        var valueLastYear = getState(verzeichnisPfad + '.' + vorJahr + ".consumed.months." + month + "_" + names).val;
                                                        var costLast = valueLastYear * 0.33;
                                                        GesamtVorher += valueLastYear;
                                                        GesamtKostenJetzt += cost;
                                                        tableHTML += '<tr><td>' + i + '</td><td>' + valueThisYear + '</td><td>' + valueLastYear + '</td><td>' + cost.toFixed(2) + ' | ' + costLast.toFixed(2) + '</td></tr>';
                                            
                                                    } else if (methode == 2) {
                                                        var valueThisYear = getState(verzeichnisPfad + '.' + jahr + ".delivered.months." + month + "_" + names).val;
                                                        var cost = valueThisYear * 0.33;
                                                        GesamtJetzt += valueThisYear;
                                                        var valueLastYear = getState(verzeichnisPfad + '.' + vorJahr + ".delivered.months." + month + "_" + names).val;
                                                        GesamtVorher += valueLastYear;
                                                        var costLast = valueLastYear * 0.33;
                                                        GesamtKostenJetzt += cost;
                                                        tableHTML += '<tr><td>' + i + '</td><td>' + valueThisYear + '</td><td>' + valueLastYear + '</td><td>' + cost.toFixed(2) + ' | ' + costLast.toFixed(2) + '</td></tr>';
                                                    }
                                                }
                                                // Zwei Nachkommastellen
                                                GesamtJetzt = Math.round(GesamtJetzt * 100) / 100;
                                                GesamtVorher = Math.round(GesamtVorher * 100) / 100;
                                                GesamtKostenJetzt = Math.round(GesamtKostenJetzt * 100) / 100;
                                                GesamtKostenVorher = GesamtVorher * 0.33;
                                                GesamtKostenVorher = Math.round(GesamtKostenVorher * 100) / 100;
                                                tableHTML += '<tr><td>' + "Ge" + '</td><td>' + GesamtJetzt + '</td><td>' + GesamtVorher + '</td><td>' + GesamtKostenJetzt + ' | ' + GesamtKostenVorher + '</td></tr>';
                                            
                                                tableHTML += '</tbody></table>';
                                            
                                            
                                                /*
                                                *       Hier den Speicherpfad angeben (2x)
                                                */
                                            
                                                // Schreibe den HTML-Code in den HTML-Objektzustand als Zeichenfolge
                                                setState(verzeichnisSave, { val: tableHTML, ack: true });
                                            
                                                // Lese den HTML-Code als Zeichenfolge
                                                var tableHTMLString = getState(verzeichnisSave).val;
                                            
                                                // Gib den HTML-Code in der Konsole aus
                                                // console.log(tableHTMLString);
                                            
                                            });
                                            
                                            1 Reply Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            906
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            20
                                            1518
                                            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