Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. Energieanzeige (kWh) über HTML Tabelle - vis

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    12
    1
    330

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.9k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.3k

Energieanzeige (kWh) über HTML Tabelle - vis

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascripttemplate
696 Beiträge 37 Kommentatoren 157.5k Aufrufe 46 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • liv-in-skyL liv-in-sky

    @sigi234 in dem json gibt es keinen datenpunkt mit hm-rpc.1.NEQ1662322

    sigi234S Online
    sigi234S Online
    sigi234
    Forum Testing Most Active
    schrieb am zuletzt editiert von sigi234
    #46

    @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

    NEQ1662322

    GELÖSCHT

    Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
    Immer Daten sichern!

    liv-in-skyL 1 Antwort Letzte Antwort
    0
    • sigi234S sigi234

      @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

      NEQ1662322

      GELÖSCHT

      liv-in-skyL Offline
      liv-in-skyL Offline
      liv-in-sky
      schrieb am zuletzt editiert von
      #47

      @sigi234 ok ist drin

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

      sigi234S 1 Antwort Letzte Antwort
      0
      • liv-in-skyL liv-in-sky

        @sigi234 ok ist drin

        sigi234S Online
        sigi234S Online
        sigi234
        Forum Testing Most Active
        schrieb am zuletzt editiert von sigi234
        #48

        @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

        @sigi234 ok ist drin

        Info, habe gerade ein Firmware update für dieses Gerät gemacht.
        Darum ist der Wert hm-rpc.1.NEQ1662322.2.ENERGY_COUNTER auf 0

        Screenshot (1423)_LI.jpg

        Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
        Immer Daten sichern!

        liv-in-skyL 2 Antworten Letzte Antwort
        0
        • sigi234S sigi234

          @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

          @sigi234 ok ist drin

          Info, habe gerade ein Firmware update für dieses Gerät gemacht.
          Darum ist der Wert hm-rpc.1.NEQ1662322.2.ENERGY_COUNTER auf 0

          Screenshot (1423)_LI.jpg

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          schrieb am zuletzt editiert von
          #49

          @sigi234

          ich mache das morgen früh

          bis dann

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

          1 Antwort Letzte Antwort
          0
          • sigi234S sigi234

            @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

            @sigi234 ok ist drin

            Info, habe gerade ein Firmware update für dieses Gerät gemacht.
            Darum ist der Wert hm-rpc.1.NEQ1662322.2.ENERGY_COUNTER auf 0

            Screenshot (1423)_LI.jpg

            liv-in-skyL Offline
            liv-in-skyL Offline
            liv-in-sky
            schrieb am zuletzt editiert von
            #50

            @sigi234 nur noch kurz - ist sofort da gewesen

            Image 21.png

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

            sigi234S 1 Antwort Letzte Antwort
            0
            • liv-in-skyL liv-in-sky

              habe den **virtual-powermeter adapter

              Image 17.png

              wer testen will im ersten post - eine ausnahme - geräte dürfen nicht in einem ordner sein !!!

              die folgenden Settings für den virtual powermeter adapter müssen genauso angelegt sein, wie in der anleitung - auch groß - und kleinschreibung

              Image 18.png

              nach dem anlegen erscheinen die folgenden datenpunkte und davon muss man einen auswählen für sourceanalytixs

              Image 19.png

              ? Offline
              ? Offline
              Ein ehemaliger Benutzer
              schrieb am zuletzt editiert von
              #51

              @liv-in-sky vielen Dank. Morgen setze ich mich da Ran ☺️

              1 Antwort Letzte Antwort
              0
              • liv-in-skyL liv-in-sky

                @sigi234 nur noch kurz - ist sofort da gewesen

                Image 21.png

                sigi234S Online
                sigi234S Online
                sigi234
                Forum Testing Most Active
                schrieb am zuletzt editiert von sigi234
                #52

                @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

                @sigi234 nur noch kurz - ist sofort da gewesen

                Ja, es geht um die kWh

                Screenshot (1426).png

                Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                Immer Daten sichern!

                liv-in-skyL 1 Antwort Letzte Antwort
                0
                • sigi234S sigi234

                  @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

                  @sigi234 nur noch kurz - ist sofort da gewesen

                  Ja, es geht um die kWh

                  Screenshot (1426).png

                  liv-in-skyL Offline
                  liv-in-skyL Offline
                  liv-in-sky
                  schrieb am zuletzt editiert von liv-in-sky
                  #53

                  @sigi234

                  Image 1.png

                  geht über sourceAnalytixs auf dem POWER datenpunkt wo ENERGY_COUNTER drin ist

                  und im script

                  var homematic=true;       var sourceAnalyHM=true;
                  

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

                  sigi234S 1 Antwort Letzte Antwort
                  0
                  • liv-in-skyL liv-in-sky

                    @sigi234

                    Image 1.png

                    geht über sourceAnalytixs auf dem POWER datenpunkt wo ENERGY_COUNTER drin ist

                    und im script

                    var homematic=true;       var sourceAnalyHM=true;
                    
                    sigi234S Online
                    sigi234S Online
                    sigi234
                    Forum Testing Most Active
                    schrieb am zuletzt editiert von sigi234
                    #54

                    @liv-in-sky

                    Ich glaube ich habe noch ein altes Skript

                    GEHT!

                    Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                    Immer Daten sichern!

                    1 Antwort Letzte Antwort
                    0
                    • liv-in-skyL liv-in-sky

                      habe den **virtual-powermeter adapter

                      Image 17.png

                      wer testen will im ersten post - eine ausnahme - geräte dürfen nicht in einem ordner sein !!!

                      die folgenden Settings für den virtual powermeter adapter müssen genauso angelegt sein, wie in der anleitung - auch groß - und kleinschreibung

                      Image 18.png

                      nach dem anlegen erscheinen die folgenden datenpunkte und davon muss man einen auswählen für sourceanalytixs

                      Image 19.png

                      sigi234S Online
                      sigi234S Online
                      sigi234
                      Forum Testing Most Active
                      schrieb am zuletzt editiert von sigi234
                      #55

                      @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

                      wer testen will im ersten post - eine ausnahme - geräte dürfen nicht in einem ordner sein !!!

                      Das verstehe ich nicht?
                      Erledigt

                      Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                      Immer Daten sichern!

                      1 Antwort Letzte Antwort
                      0
                      • liv-in-skyL liv-in-sky

                        habe den **virtual-powermeter adapter

                        Image 17.png

                        wer testen will im ersten post - eine ausnahme - geräte dürfen nicht in einem ordner sein !!!

                        die folgenden Settings für den virtual powermeter adapter müssen genauso angelegt sein, wie in der anleitung - auch groß - und kleinschreibung

                        Image 18.png

                        nach dem anlegen erscheinen die folgenden datenpunkte und davon muss man einen auswählen für sourceanalytixs

                        Image 19.png

                        Bulli BultmannB Offline
                        Bulli BultmannB Offline
                        Bulli Bultmann
                        schrieb am zuletzt editiert von
                        #56

                        @liv-in-sky Gerade noch getestet. Scheint tadelos zu funktionieren.
                        Gruß UB, und gute Nacht.

                        1 Antwort Letzte Antwort
                        0
                        • liv-in-skyL liv-in-sky

                          habe den **virtual-powermeter adapter

                          Image 17.png

                          wer testen will im ersten post - eine ausnahme - geräte dürfen nicht in einem ordner sein !!!

                          die folgenden Settings für den virtual powermeter adapter müssen genauso angelegt sein, wie in der anleitung - auch groß - und kleinschreibung

                          Image 18.png

                          nach dem anlegen erscheinen die folgenden datenpunkte und davon muss man einen auswählen für sourceanalytixs

                          Image 19.png

                          ? Offline
                          ? Offline
                          Ein ehemaliger Benutzer
                          schrieb am zuletzt editiert von
                          #57

                          @liv-in-sky

                          Danke Dir. Hat perfekt geklappt :)

                          Bildschirmfoto 2020-01-23 um 06.58.12.JPG

                          1 Antwort Letzte Antwort
                          0
                          • ? Offline
                            ? Offline
                            Ein ehemaliger Benutzer
                            schrieb am zuletzt editiert von
                            #58

                            @liv-in-sky
                            Du hast im Batterien Script dieses eingebaut:
                            var symbolOK="✅";
                            var symbolKO="❌";

                            Könntest Du das hier auch einbauen?

                            liv-in-skyL 1 Antwort Letzte Antwort
                            0
                            • ? Ein ehemaliger Benutzer

                              @liv-in-sky
                              Du hast im Batterien Script dieses eingebaut:
                              var symbolOK="✅";
                              var symbolKO="❌";

                              Könntest Du das hier auch einbauen?

                              liv-in-skyL Offline
                              liv-in-skyL Offline
                              liv-in-sky
                              schrieb am zuletzt editiert von
                              #59

                              @Yetiberg geht klar

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

                              1 Antwort Letzte Antwort
                              0
                              • liv-in-skyL liv-in-sky

                                @Lenny-CB habe die zeile eingefügt - bitte testen und feedback - erster post

                                die switches sind noch nicht integriert

                                Lenny.CBL Offline
                                Lenny.CBL Offline
                                Lenny.CB
                                Most Active
                                schrieb am zuletzt editiert von Lenny.CB
                                #60

                                @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

                                @Lenny-CB habe die zeile eingefügt - bitte testen und feedback - erster post

                                die switches sind noch nicht integriert

                                konnte leider erst heut testen...
                                Passt soweit (SHP6 fehlt aber noch). :+1:
                                pack mal bitte noch den Teil mit rein.

                                || getState(id).val=="BlitzWolf SHP6"
                                
                                liv-in-skyL 1 Antwort Letzte Antwort
                                0
                                • Lenny.CBL Lenny.CB

                                  @liv-in-sky sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

                                  @Lenny-CB habe die zeile eingefügt - bitte testen und feedback - erster post

                                  die switches sind noch nicht integriert

                                  konnte leider erst heut testen...
                                  Passt soweit (SHP6 fehlt aber noch). :+1:
                                  pack mal bitte noch den Teil mit rein.

                                  || getState(id).val=="BlitzWolf SHP6"
                                  
                                  liv-in-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  schrieb am zuletzt editiert von
                                  #61

                                  @Lenny-CB sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

                                  || getState(id).val=="BlitzWolf SHP6"

                                  done

                                  update des scripts kommt etwas später

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

                                  1 Antwort Letzte Antwort
                                  0
                                  • liv-in-skyL Offline
                                    liv-in-skyL Offline
                                    liv-in-sky
                                    schrieb am zuletzt editiert von liv-in-sky
                                    #62

                                    ich würde tester suchen

                                    thema:

                                    sourceanalytix

                                    ich wollte mal eine gesamtsumme darstellen

                                    • gesamtsumme ist dazugekommen (tabellenende)
                                    • bei nutzung kann man virtualPowermeter als einzelgeräte oder als gesamt (auch beides) anzeigen lassen

                                    leider habe ich festgestellt, dass die pow, blitzwolf, teckin - tasmota geflashed- ja eine gesamt kWh haben, also von beginn der ersten installation - das bedeutet, ich muss auch diese geräte mit sourceanalytixs verbinden, um wenigstens eine monatliche anzeige zu bekommen
                                    ob sourceanalytixs die richtigen werte leifert, habe ich noch nicht festgestellt - ich hoffe das mal

                                    Image 2.png

                                    das ganze project bekommt natürlich erst einen mehrwert, wenn die daten der letzten 4 spalten da sind - und die werden nun (ausnahme : hs.1000) alle über sourceanalytix eingelesen
                                    kompliziert wird es dann noch ein wenig, wenn man über den virtual-powermeter-adapter arbeitet, um zusätzliche werte zu generieren - das habe ich schon weiter oben erklärt

                                    Image 3.png

                                    daher haben sich die settings-variablen auch geändert - es gibt jetzt für jede geräte-kategorie auch eine sourceanalytixs variable - muss aber nicht aktiviert werden - bevor man dies macht, sollte sourceanalytics installiert sein (wichtig - instanz 0) und der datenpunkt auch auf actic stehen - sonst gibt es fehler. das gleiche gilt auch für die virtualPowermeter einstellung -zuerst installieren und eine datenpunkt auf activ schalten (siehe anleitung)

                                    Image 4.png

                                    @Lenny-CB - blitzwolf ist hier auch drin

                                    das script:

                                    //@liv-in-sky Januar 2020 Ver. 23.1.20-15
                                    
                                    //HIER WIRD PFAD UND FILENAME DEFINIERT
                                    const path = "/htmlenergy.html";                   //FIlenamen definieren
                                    const home ='vis.0'                                 //wo soll das file im iobroker-file-system liegen ? (oder z.b auch iqontrol.meta)
                                    let   braucheEinFile=false;                          // bei true wird ein file geschrieben
                                    let   braucheEinVISWidget=true;                     // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile
                                    let dpVIS="controll-own.0.TABELLEN.ENERGY"         //WICHTIG wenn braucheEinVISWidget auf true gesetzt !!  dp zusätzlich für VIS-HTML-Basic-Widget
                                    let dpAnzahl="controll-own.0.TABELLEN.AnzahlEnergiemesser";  //WICHTIG datenpunkt erstellen vom typ "number" - bei 0 kein alarm und größer 0 die anzahl der schlechten batterien
                                    let htmlColorDeviceUeberschrift="#A0C2A0"             //  Farbe der Geräte Marken 
                                    let HTMLbrandSetting="i"                              // style der geräte marken:  möglich b fett; i kursiv; span normal
                                    let triggerBySonoffPower=true;
                                    //---------------------------------------
                                    let mySchedule="  */5 * * * * "; 
                                    
                                    let kwhPreis=0.29;
                                    
                                    // GERÄTE FREISCHALTUNG und SourceAnalytics
                                    
                                    var pow=true;             var sourceAnalyPow=false;
                                    var tuya=true;            var sourceAnalyTuya=false;
                                    var hs100=true;                                                                                                  //tplink
                                    var homematic=true;       var sourceAnalyHM=false;
                                    var blitzwolf=true;       var sourceAnalyBlitz=false;
                                    var teckin=true;          var sourceAnalyTeck=false;
                                    var mihome=true;          var sourceAnalyMihome=false;                                                            //smart-plug
                                    var homee=true;           var sourceAnalyHomee=false;
                                    var gosundSP1x=true;      var sourceAnalyGo=false;
                                    var shelly=true;          var sourceAnalyShelly=false;
                                    var virtualPower=false;    var virtualPowerGesamt=false;
                                    
                                    var gesamt=true;                                            // Spalte Gesamt am ende der tabelle
                                    
                                    var symbolOK="🟢";     // auch möglich: ="✅"  
                                    var symbolKO="🔴";     //z.b. auch "<font color=\"red\"><b>X</b>" für ein rotes kreuz  oder : ="❌"
                                    var symbolWARN="⚠️";    // ="⚠️"
                                    var externalOhneInfo=false;  //noch nicht integriert
                                    
                                    
                                    
                                    
                                    //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 5
                                    var htmlFeld1='Device';       var Feld1lAlign="left";                     // überschrift Tabellen Spalte1 und  Ausrichtung left,right or center
                                    var htmlFeld2='Status';        var Feld2lAlign="center";                      // überschrift Tabellen Spalte2 und  Ausrichtung left,right or center
                                    var htmlFeld3='Amp';         var Feld3lAlign="center";                    // überschrift Tabellen Spalte3 und  Ausrichtung left,right or center
                                    var htmlFeld4='Volt';        var Feld4lAlign="center";                    // überschrift Tabellen Spalte4 und  Ausrichtung left,right or center
                                    var htmlFeld5='Power';        var Feld5lAlign="left";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                    var htmlFeld6='Schalter';        var Feld6lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                    var htmlFeld7='';        var Feld7lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                    var htmlFeld8='';        var Feld8lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                    var htmlFeld9='';        var Feld9lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                    var htmlFeld10='';        var Feld10lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                    
                                    //-----------------------------------
                                    
                                    
                                    //ÜBERSCHRIFT ÜBER TABELLE
                                    let   htmlUberschrift=true;                           // mit Überschrift über der tabelle
                                    let   htmlSignature=false;                              // anstatt der Überscghrift eine signature: - kleiner - anliegend
                                    const htmlFeldUeber='Energy Devices';              // Überschrift und Signature
                                    const htmlFarbUber="white";                         // Farbe der Überschrift
                                    const htmlSchriftWeite="normal";                       // bold, normal - Fettschrift für Überschrift
                                    const htmlÜberFontGroesse="18px";                       // schriftgröße überschrift
                                    //MEHRERE TABELLEN NEBENEINANDER
                                    let   mehrfachTabelle=1;                              // bis zu 4 Tabellen werden nebeneinander geschrieben-  verkürzt das Ganze, dafür etwas breiter - MÖGLICH 1,2,3,oder 4 !!!
                                    const htmlFarbZweiteTabelle="white";                // Farbe der Überschrift bei jeder 2.ten Tabelle
                                    const htmlFarbTableColorUber="#BDBDBD";               // Überschrift in der tabelle - der einzelnen Spalten
                                    //GANZE TABELLE
                                    let abstandZelle="1";
                                    let weite="auto";                                     //Weite der Tabelle
                                    let zentriert=true;                                   //ganze tabelle zentriert
                                    const backgroundAll="#000000";                        //Hintergrund für die ganze Seite - für direkten aufruf oder iqontrol sichtber - keine auswirkung auf vis-widget
                                    const htmlSchriftart="Helvetica";
                                    const htmlSchriftgroesse="14px";
                                    //FELDER UND RAHMEN
                                    let   UeberschriftSpalten=true;                // ein- oder ausblenden der spatlen-überschriften
                                    const htmlFarbFelderschrift="#BDBDBD";                  // SchriftFarbe der Felder
                                    const htmlFarbFelderschrift2="#D8D8D8";                 // SchriftFarbe der Felder für jede 2te Tabelle
                                    const htmlFarbTableColorGradient1="#424242";          //  Gradient - Hintergrund der Tabelle - Verlauffarbe
                                    const htmlFarbTableColorGradient2="#424242";          //  Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
                                    const htmlFarbTableBorderColor="gray";             // Farbe des Rahmen - is tdieser gleich den gradienten, sind die rahmen unsichtbar
                                    let htmlRahmenLinien="cols";                            // Format für Rahmen: MÖGLICH: "none" oder "all" oder "cols" oder "rows"
                                    const htmlSpalte1Weite="auto";                   //  Weite der ersten beiden  Spalten oder z.b. 115px
                                    
                                    // HIER NICHTS  ÄNDERN
                                    
                                    let borderHelpBottum;
                                    let borderHelpRight;
                                    let htmlcenterHelp;
                                    let htmlcenterHelp2;
                                    
                                    if(htmlRahmenLinien=="rows") {borderHelpBottum=1;borderHelpRight=0;}
                                    if(htmlRahmenLinien=="cols") {borderHelpBottum=0;borderHelpRight=1;}
                                    if(htmlRahmenLinien=="none") {borderHelpBottum=0;borderHelpRight=0;}
                                    if(htmlRahmenLinien=="all")  {borderHelpBottum=1;borderHelpRight=1;}
                                    zentriert ? htmlcenterHelp="auto" : htmlcenterHelp="left";
                                    zentriert ? htmlcenterHelp2="center" : htmlcenterHelp2="left";
                                    
                                    
                                    const htmlZentriert='<center>'
                                    const htmlStart=    "<!DOCTYPE html><html lang=\"de\"><head><title>Vorlage</title><meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\">"+
                                                       "<style> * {  margin: 0;} body {background-color: "+backgroundAll+"; margin: 0 auto;  }"+
                                                       " p {padding-top: 10px; padding-bottom: 10px; text-align: "+htmlcenterHelp2+"}"+
                                                      // " div { margin: 0 auto;  margin-left: auto; margin-right: auto;}"+
                                                       " td { padding:"+abstandZelle+"px; border:0px solid "+htmlFarbTableBorderColor+";  border-right:"+borderHelpRight+"px solid "+htmlFarbTableBorderColor+";border-bottom:"+borderHelpBottum+"px solid "+htmlFarbTableBorderColor+";}"+ 
                                                       " table { width: "+weite+";  margin: 0 "+htmlcenterHelp+"; border:1px solid "+htmlFarbTableBorderColor+"; border-spacing=\""+abstandZelle+"0px\" ; }"+   // margin macht center
                                                       "td:nth-child(1) {width: "+htmlSpalte1Weite+"}"+"td:nth-child(2) {width:"+htmlSpalte1Weite+"}"+
                                                       " </style></head><body> <div>";
                                    //const htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-weight: bold\">"+htmlFeldUeber+"</p>";                    
                                    const htmlTabStyle= "<table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"2px\" cellspacing=\""+abstandZelle+"\" cellpadding=\""+abstandZelle+"\" width=\""+weite+"\" rules=\""+htmlRahmenLinien+"\" style=\"color:"+htmlFarbFelderschrift+";  font-size:"+htmlSchriftgroesse+
                                                          "; font-family:"+htmlSchriftart+";background-image: linear-gradient(42deg,"+htmlFarbTableColorGradient2+","+htmlFarbTableColorGradient1+");\">";
                                    const htmlTabUeber1="<tr style=\"color:"+htmlFarbTableColorUber+"; font-weight: bold\">";
                                    const htmlTabUeber3="</tr>";
                                    
                                    
                                    //NICHTS ÄNDERN - abhängig von den oben definierten _Spalten - in diesem Beispiel sind es 5
                                    
                                    
                                    var htmlTabUeber2="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+">&ensp;"+htmlFeld1+"&ensp;</td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+">&ensp;"+htmlFeld2+"&ensp;</td><td  align="+Feld3lAlign+">&ensp;"+htmlFeld3+"&ensp;</td><td align="+Feld4lAlign+
                                                      ">&ensp;"+htmlFeld4+"&ensp;</td><td  align="+Feld5lAlign+">&ensp;"+htmlFeld5+"&ensp;</td><td  align="+Feld6lAlign+">&ensp;"+htmlFeld6+"&ensp;</td><td  align="+Feld7lAlign+">&ensp;"+htmlFeld7+"&ensp;</td><td  align="+Feld8lAlign+">&ensp;"+htmlFeld8+
                                                      "&ensp;</td><td  align="+Feld9lAlign+">&ensp;"+htmlFeld9+"&ensp;</td><td  align="+Feld10lAlign+">&ensp;"+htmlFeld10+"&ensp;</td>";
                                    var htmlTabUeber2_1="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld1+"&ensp;</td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld3+
                                                       "&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld3+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld4+
                                                       "&ensp;</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld5+"&ensp;</td><td align="+Feld6lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld6+"&ensp;</td><td align="+Feld7lAlign+
                                                       " style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld7+"&ensp;</td><td align="+Feld8lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld8+"&ensp;</td><td  align="+Feld9lAlign+">&ensp;"+htmlFeld9+"&ensp;</td><td  align="+Feld10lAlign+">&ensp;"+htmlFeld10+"&ensp;</td>";
                                                           //------------------------------------------------------
                                    
                                    let triggerBySonoffSwitch=false;
                                    var anzahl;
                                    var AkkuAlarm=[];
                                    var htmlOut="";
                                    var mix;
                                    var counter;
                                    var arrTrigger=[];
                                    
                                    var val1; var val2; var val0; var val3; var val4; var val5; var val6; var val7; var val8; var val9;
                                    var htmlTabUeber="";
                                    function writeHTML(){
                                    var gesamtNow=0;
                                    var gesamtMonth=0;
                                    var gesamtMoneyTod=0;
                                    var gesamtMoneyMon=0;
                                    
                                    anzahl=0;
                                    htmlOut="";
                                    counter=-1;
                                    htmlTabUeber="";
                                    switch (mehrfachTabelle) { 
                                       case 1: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber3;  break;
                                       case 2: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break;
                                       case 3: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2+htmlTabUeber2+htmlTabUeber3; break;
                                       case 4: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break;
                                    }; 
                                    if (!UeberschriftSpalten) {htmlTabUeber=""}  
                                    
                                    //--------------------------------------------------------------------------------------------------------------------------------------------------
                                    //---------hier kommt eure schleife rein counter++, tabelleBind() und tabelleFinish() müssen so integriert bleiben !!!------------------------------
                                    //---------alle valx werte müssen von euch bestimmt werden - val0,val1,val2,val3,val4!!!------------------------------------------------------------
                                    //--------------------------------------------------------------------------------------------------------------------------------------------------
                                      var arrSouAna=[];
                                     if (sourceAnalyHM) {
                                                    $("sourceanalytix.0.*").each(function(id, i) {   // kontrolliere ob OPERATING_VOLTAGE vorhanden
                                                  var idc = id.split('.');
                                                 if (idc[2].includes("POWER")  ) {
                                                  if (!arrSouAna.includes(idc[2]) ) { // && idc[2].includes("POWER") ) {
                                               arrSouAna.push(idc[2])} }
                                               });
                                     }
                                        var arrSouAnaAll=[];
                                     if (sourceAnalyTuya || sourceAnalyMihome || sourceAnalyHomee || sourceAnalyShelly || virtualPower || virtualPowerGesamt || sourceAnalyGo || sourceAnalyPow || sourceAnalyBlitz|| sourceAnalyTeck) {
                                                    $("sourceanalytix.0.*").each(function(id, i) {   // kontrolliere ob OPERATING_VOLTAGE vorhanden
                                                  var idc = id.split('.');
                                                   
                                                
                                                  if (!arrSouAnaAll.includes(idc[2]) ) { // && idc[2].includes("POWER") ) {
                                               arrSouAnaAll.push(idc[2]);} 
                                               });
                                     }
                                    // log(arrSouAnaAll.toString());
                                    
                                    if (virtualPower){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">VirtualPower</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    
                                        var arrVirtDev=(getState("virtualpowermeter.0.group_script.info").val).replace(/;$/,"").split(';');
                                      // log(arrVirtDev[1])
                                       for (var i=0;i<arrVirtDev.length;i++) {
                                             anzahl++;
                                           // var ida = arrVirtDev[i].split('.');
                                           
                                              counter++;
                                       //   log(arrVirtDev[i])
                                          var val0help=arrVirtDev[i].replace(/(.+)\..+$/,"$1"); // log("mein dp: "+val0help)    // sonoff.0.Sonoff15.Script_Power
                                          val0=getObject(val0help).common.name;                                // sonoff.0.Sonoff16.Script_Power
                                        //  val0=val0.replace(";","");
                                          val1=true;
                                           val2=" - "; val3=" - ";
                                           val4=getState(val0help+".Script_Power").val+" W"
                                          var sourcerhelper=(val0help+".Script_Total").replace(/\./g,"__");
                                          //var sourcerhelper2=(val0help+".Script_Power").replace(".","___");
                                           //   var  val5_2=getState(val5_1).val ;          //                                                            log(" wo isser " +val5_2.toString())
                                              val5=" - "
                                              val6=" - ";//=getState(id).val + " kWh";
                                              val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                              val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                    
                                                        
                                                        val8=(getState("sourceanalytix.0." + sourcerhelper+".cost.01_current_day").val).toString()+" €";
                                                        val9=(getState("sourceanalytix.0." + sourcerhelper+".cost.03_current_month").val).toString()+" €";
                                                        val7=(getState("sourceanalytix.0." + sourcerhelper+".consumption.03_current_month").val).toString()+" kWh";   
                                                        val6=(getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val).toString()+" kWh" ;
                                                     
                                    
                                              if (!val1) {
                                                 // log("false")
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                 // log("true")
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                    
                                          if (gesamt) {     
                                        //  let val6_1=(getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val); 
                                        //   let val6_1=getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val;
                                       // log(typeof (getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val) )
                                          gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val); 
                                         // let val7_1=(getState("sourceanalytix.0." + sourcerhelper+".consumption.03_current_month").val);
                                          gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".consumption.03_current_month").val);
                                         // let val8_1=(getState("sourceanalytix.0." + sourcerhelper+".cost.01_current_day").val);
                                          gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".cost.01_current_day").val);
                                         // let val9_1=(getState("sourceanalytix.0." + sourcerhelper+".cost.03_current_month").val);
                                          gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".cost.03_current_month").val);
                                          } 
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                     //   log("1------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                       }; //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende virtual
                                    
                                     if (virtualPowerGesamt){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">VirtualPower Gesamt</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                      // keine schleife nötig
                                    
                                             anzahl++;
                                         
                                              counter++;
                                     
                                          val0="Gesamt" //getObject(val0help).common.name;                                // sonoff.0.Sonoff16.Script_Power
                                    
                                          val1=true;
                                           val2=" - "; val3=" - ";
                                           val4= " - "; //getState(val0help+".Script_Power").val+" W"
                                          var sourcerhelper=(val0help+".Script_Total").replace(/\./g,"__");
                                    
                                              val5=" - "
                                              val6=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val).toString(); //=getState(id).val + " kWh";
                                              val7=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.03_current_month").val).toString(); //"" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                              val8=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.01_current_day").val).toString();  //" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.03_current_month").val).toString(); //" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                    
                                              if (!val1) {
                                                 // log("false")
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                 // log("true")
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                          if(!virtualPower && gesamt) {
                                      //    let val6_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val); 
                                          gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val); 
                                      //    let val7_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.03_current_month").val);
                                          gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.03_current_month").val);
                                       //   let val8_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.01_current_day").val);
                                          gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.01_current_day").val);
                                      //    let val9_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.03_current_month").val);
                                          gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.03_current_month").val);
                                          } 
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                       // log(".1------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                      // }; //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende virtual
                                    
                                    
                                    if (pow){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Pow (R2)</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                     $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                       
                                          if (getState(id).val=="Sonoff Pow" || getState(id).val=="Sonoff Pow R2") {
                                             // log (id)
                                             anzahl++;
                                            var ida = id.split('.');
                                           
                                              counter++; 
                                                //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                              val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                              val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                              val2=((getState(id.replace("INFO.Module","ENERGY_Current")).val)*1000).toString()+ " mA";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                              val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                              let val7_1=getState(id.replace("INFO.Module","POWER")).val;        
                                              val7_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                              val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                              val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                              val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(2)+" €";
                                              val9=" - "; //(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(2)+" €";
                                    
                                              let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyPow  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                         let  myId=idhlp;
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                               if (gesamt) {          
                                                         // gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         //gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                         
                                              }         }
                                            
                                              if (!getState(id.replace("INFO.Module","alive")).val) {
                                                 val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                    
                                                 
                                    
                                    
                                                 }
                                          if (gesamt) {  
                                          gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                         // gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                          gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                          //gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                          } 
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                       // log("2------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                      } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                     if (teckin){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Teckin</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                     $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                       
                                          if (getState(id).val=="Teckin") {
                                             // log (id)
                                             anzahl++;
                                            var ida = id.split('.');
                                           
                                              counter++; 
                                                //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                              val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                              val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                              val2=((getState(id.replace("INFO.Module","ENERGY_Current")).val)*1000).toString()+ " mA";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                              val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                              let val7_1=getState(id.replace("INFO.Module","POWER")).val;        
                                              val7_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                              val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                              val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                              val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(2)+" €";
                                              val9=" - ";//(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(2)+" €";
                                            
                                              let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyTeck  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                         let  myId=idhlp;
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                               if (gesamt) {          
                                                      
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                              }         }
                                            
                                              if (!getState(id.replace("INFO.Module","alive")).val) {
                                                 val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                    
                                                 
                                    
                                    
                                                 }
                                          if (gesamt) {  
                                          gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                        //  gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                          gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                        //  gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                          } 
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        log("3------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                      } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    
                                    if (blitzwolf){
                                    
                                                // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                         tabelleAusbessern();
                                         counter=0;
                                         val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                         tabelleAusbessern();
                                         counter=0;
                                         val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">BlitzWolf SHP</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                         val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                         val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                         val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                         val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                         val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                         tabelleAusbessern();
                                         counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                    $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                      
                                         if (getState(id).val=="BlitzWolf SHP"  || getState(id).val=="BlitzWolf SHP7" || getState(id).val=="BlitzWolf SHP8" || getState(id).val=="BlitzWolf SHP6") {
                                            // log (id)
                                            anzahl++;
                                           var ida = id.split('.');
                                          
                                             counter++; 
                                               //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                             val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                             val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                             val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                             val2=getState(id.replace("INFO.Module","ENERGY_Current")).val.toFixed(2)+ " A";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                             val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                             let val5_1=getState(id.replace("INFO.Module","POWER")).val;        
                                             val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                             var val7_2; var val8_2; 
                                             if ( getState(id).val=="BlitzWolf SHP7") {
                                                 let val7_1=getState(id.replace("INFO.Module","POWER1")).val;        
                                             val7_1 ? val7_2=(" <font color=\"lightgreen\"> ")+"ON" : val7_2=(" <font color=\"red\"> ")+"OFF";
                                             let val8_1=getState(id.replace("INFO.Module","POWER2")).val;        
                                             val8_1 ? val8_2=(" <font color=\"lightgreen\"> ")+"ON" : val8_2=(" <font color=\"red\"> ")+"OFF";
                                             val5=val7_2+" "+val8_2;
                                             }
                                             val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                             val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                             val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(2)+" €";
                                             val9=" - ";//(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(2)+" €";
                                           
                                              let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyBlitz  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                         let  myId=idhlp;
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                               if (gesamt) {          
                                                      
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                              }         }
                                            
                                              if (!getState(id.replace("INFO.Module","alive")).val) {
                                                 val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                    
                                                 
                                    
                                    
                                                 }
                                          if (gesamt) {  
                                          gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                         // gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                          gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                        //  gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                          } 
                                            
                                      
                                        tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                       
                                     } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    
                                     if (gosundSP1x){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                         val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Gosund</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                     $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                       
                                          if (getState(id).val.includes("Gosund SP1")) {
                                             // log (id)
                                             anzahl++;
                                            var ida = id.split('.');
                                           
                                               counter++; 
                                                //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                              val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                              val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                              val2=getState(id.replace("INFO.Module","ENERGY_Current")).val.toFixed(2)+ " A";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                              val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                              let val7_1=getState(id.replace("INFO.Module","POWER")).val;        
                                              val7_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                              val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                              val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                              val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(1)+" €";
                                              val9=" - ";//(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(1)+" €";
                                            
                                              let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyGo  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                         let  myId=idhlp;
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                               if (gesamt) {          
                                                      
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                              }         }
                                            
                                              if (!getState(id.replace("INFO.Module","alive")).val) {
                                                 val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                    
                                                 
                                    
                                    
                                                 }
                                          if (gesamt) {  
                                          gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                         // gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                          gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                         // gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                          }      
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        
                                      } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                     if (homee){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Homee</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                    //let mySelector= "homee.*.*.CurrentEnergyUse-190"; mySelector=mySelector.replace(/-.+/,"");
                                     $("homee.*.*.CurrentEnergyUse*").each(function(id, i) {    // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                          var ida = id.split('.');       
                                          var arrHomee=[]
                                                $(ida[0]+"."+ida[1]+"."+ida[2]+".*" ).each(function(id, i) { 
                                                  arrHomee.push(id)
                                    
                                                });
                                    
                                            // log (arrHomee.toString())
                                             anzahl++;
                                            
                                           
                                              counter++; 
                                             
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                              val1=true;
                                              //var val2_1;var val3_1;
                                              val2=" - "; val3=" - ";
                                              for (var i=0;i<arrHomee.length;i++){if(arrHomee[i].includes("Current-"))  val2=(getState(arrHomee[i]).val)*1000 +" mA"}
                                              for (var i=0;i<arrHomee.length;i++){if(arrHomee[i].includes("Voltage"))  val3=(getState(arrHomee[i]).val) +" V"}
                                              
                                              val4=getState(id).val.toString()+" W";
                                              var val5_1;
                                              for (var i=0;i<arrHomee.length;i++){if(arrHomee[i].includes("OnOff"))  val5_1=getState(arrHomee[i]).val}
                                    
                                              val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                              val6=" - ";//=getState(id).val + " kWh";
                                              val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                              val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                            //  log(val1.toString()) 
                                    
                                            
                                             
                                                 let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyHomee  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                 var    myId=id.replace(/\./g,"__")
                                                
                                                        val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                            if (gesamt) {             
                                                         gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                         } }
                                              if (!val1) {
                                                 // log("false")
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                 // log("true")
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                    
                                    
                                             
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                      //  log("4------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                       }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    
                                    
                                     if (shelly){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Shelly</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    
                                     $('shelly.*.*.*.Power').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                       
                                    
                                             // log (id)
                                             anzahl++;
                                            var ida = id.split('.');
                                           
                                              counter++; 
                                    
                                         //     if (parseInt((new Date().getTime())) - val1_1 < 120000) {val1=true} else {val1=false;}  // log(val1.toString())          
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ; //log(val0)
                                              val1=true;
                                              val2=" - "; val3=" - ";
                                              val4=getState(id).val.toString()+" W";
                                    
                                              var val5_1= getState(id.replace("Power","Switch")).val;
                                              val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                              val6=" - ";//=getState(id).val + " kWh";
                                              val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                              val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                            //  log(val1.toString()) 
                                    
                                            
                                               
                                                  let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyShelly  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                 let    myId=id.replace(/\./g,"__")
                                                
                                                        val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                               if (gesamt) {          
                                                         gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                              }         }
                                    
                                              if (!val1) {
                                                 // log("false")
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                 // log("true")
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                    
                                    
                                             
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        
                                       }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    
                                     if (mihome){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Mihome</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    
                                     $('mihome.*.devices.*.load_power').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                       
                                    
                                             // log (id)
                                             anzahl++;
                                            var ida = id.split('.');
                                           
                                              counter++; 
                                    
                                         //     if (parseInt((new Date().getTime())) - val1_1 < 120000) {val1=true} else {val1=false;}  // log(val1.toString())          
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]+"."+ida[3]).common.name ; //log(val0)
                                              val1=true;
                                              val2=" - "; val3=" - ";
                                              val4=getState(id).val.toString()+" W";
                                    
                                              var val5_1= getState(id.replace("load_power","state")).val;
                                              val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                              val6=" - ";//=getState(id).val + " kWh";
                                              val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                              val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                            //  log(val1.toString()) 
                                    
                                            
                                               
                                                  let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyMihome  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                 let    myId=id.replace(/\./g,"__")
                                                
                                                        val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                            if (gesamt) {             
                                                         gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                              }         }
                                    
                                              if (!val1) {
                                                 // log("false")
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                 // log("true")
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                    
                                    
                                             
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        
                                       }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    
                                     if (hs100){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">HS100</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                     $('hs100.*.*.totalNow').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                       
                                    
                                             // log (id)
                                             anzahl++;
                                            var ida = id.split('.');
                                           
                                              counter++; 
                                              var valVersion=getState(id.replace("totalNow","hw_ver")).val;  
                                              var val1_1=Date.parse(getState(id.replace("totalNow","last_update")).val); 
                                              if (parseInt((new Date().getTime())) - val1_1 < 120000) {val1=true} else {val1=false;}  // log(val1.toString())          
                                              val0=getObject(id).common.name ;
                                             
                                              var val4_1=getState(id.replace("totalNow","power")).val.toString();
                                              val4=val4_1.substr(0, 4) + " W";            //getState(id.replace("totalNow","power")).val + " W"     ;    // log (val4)       //.substring(0,4)        
                                              var val2_1=getState(id.replace("totalNow","current")).val.toString();
                                              if(valVersion=="1.0")  {val2=val2_1.substr(0, 5) + " mA";} else {val2=val2_1+ " mA";}  
                                              var val3_1=getState(id.replace("totalNow","voltage")).val.toString();
                                              val3=val3_1.substring(0, 3)+" V";
                                              var val5_1= getState(id.replace("totalNow","state")).val;
                                              val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                              val6=getState(id).val + " kWh";
                                              val7=getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                              val8=(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                            //  log(val1.toString()) 
                                    
                                              if (!val1) {
                                                 // log("false")
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0 ;
                                                  val8=(" <font color=\"red\"> ")+val8;
                                                  val9=(" <font color=\"red\"> ")+val9}
                                              else{
                                                 // log("true")
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                          if (gesamt) {  
                                          gesamtNow=gesamtNow+parseFloat(getState(id).val);
                                          gesamtMonth=gesamtMonth+parseFloat(getState(id.replace("totalNow","totalMonthNow")).val);
                                          gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState(id).val)*kwhPreis;
                                          gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis;
                                          }
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        
                                       }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    
                                     if (homematic){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Homematic</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                     $('hm-rpc.*.*.*.ENERGY_COUNTER').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                       
                                    var ida = id.split('.');
                                                 var arrFilt=[];
                                               
                                              $(ida[0]+"."+ida[1]+"."+ida[2]+"."+ida[3]+".*").each(function(id, i) {   // kontrolliere ob OPERATING_VOLTAGE vorhanden
                                                  var idc = id.split('.');
                                               arrFilt.push(idc[4])
                                               });
                                    
                                               //log(arrFilt.toString())
                                    
                                          //  log (id)
                                    
                                    
                                            if (arrFilt.includes("VOLTAGE")&& arrFilt.includes("POWER") && arrFilt.includes("CURRENT")) {
                                    
                                             anzahl++;
                                            
                                              var stateIdHM=ida[3].toString(); //log(stateIdHM+" -- " +id)
                                              counter++; 
                                          //   var valVersion=getState(id.replace("totalNow","hw_ver")).val;  
                                               
                                               
                                            
                                              val1=!getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"0"+".UNREACH").val   //getState(id.replace("ENERGY_COUNTER","STATE")).val;                  
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;  //val0=getObject(id).common.name ;
                                              val4=getState(id.replace("ENERGY_COUNTER","POWER")).val+ " W"     ;     //log (val4)       //.substring(0,4)        
                                              if (arrFilt.includes("CURRENT")) {val2=getState(id.replace("ENERGY_COUNTER","CURRENT")).val.toFixed(0)+ " mA";} else {val2="-"} 
                                              if (arrFilt.includes("VOLTAGE")) {val3=getState(id.replace("ENERGY_COUNTER","VOLTAGE")).val.toFixed(0)+" V";}  else {val3="-"} 
                                             // log(stateIdHM+" -- " +ida[0]+"."+ida[1]+"."+ida[2]+"."+ida[3])
                                              if (stateIdHM=="6") {
                                                 // log("stateIdHM: "+getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"2"+".STATE").val);
                                                  var val5_1=getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"2"+".STATE").val;
                                                   if(val5_1) { val5=(" <font color=\"lightgreen\"> ")+"ON"} else { val5=(" <font color=\"red\"> ")+"OFF";}}
                                                    else { //val5="-"} 
                                                         
                                                         if (stateIdHM.match("2")) {var val5_1=getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"1"+".STATE").val ; val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";} else {val5="-"}} 
                                    
                                              val6=" - "; // getState(id).val.substring(0,5)+ " kWh";
                                              val7=" - "; // getState(id.replace("totalNow","totalMonthNow")).val.substring(0,5)+ " kWh";
                                              val8=" - "; // (parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=" - "; // (parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                    
                                               //  log ( arrSouAna.indexOf(id.replace(/\./g,"__")).toString()+" id : " +id + " replace : " + id.replace(/\./g,"__")+" nochmal replace: "+id.replace("ENERGY_COUNTER","POWER")) 
                                                     let idhlp=id.replace(/\./g,"__"); idhlp=idhlp.replace("ENERGY_COUNTER","POWER")
                                                     if (sourceAnalyHM  && arrSouAna.indexOf(idhlp)>-1) {   
                                                           let  myId=id.replace(/\./g,"__"); myId=myId.replace("ENERGY_COUNTER","POWER")
                                                           val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €"
                                                           val9=(getState("sourceanalytix.0." + myId+".cost.03_current_month").val)+" €"
                                                           val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                           val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                          if (gesamt) {                  
                                                         gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                              }}
                                    
                                              if(!val1) {
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0;
                                                  val8=(" <font color=\"red\"> ")+" --- ";
                                                  val9=(" <font color=\"red\"> ")+" --- ";}
                                              else{
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                    
                                    
                                             
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        
                                       }  }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    
                                     if (tuya){
                                    
                                                 // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                          tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Tuya</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                    
                                    //sonoff.0.SonoffPow1.INFO.Module
                                     $('tuya.*.*').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                      //  var arrFilt=[];
                                        var ida = id.split('.');
                                      //   var idb;
                                        var checker=false;
                                        var checkCur=false;
                                        var checkVol=false;
                                        var checkPow=false;
                                        var checkOnline=false;
                                        var val5_1=false;  var val5_2=false;
                                      
                                        //log(getObject(id).common.name)
                                       if (getObject(id).common.name == "cur_power")  {checkCur=true; val4=getState(id).val.toString()+" W"; // log(val4.toString())
                                                // log(id)       
                                               
                                              $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {   
                                                  if (getObject(id).common.name == "cur_voltage")  {checkVol=true; val3=getState(id).val.toString()+" V"; }//log(val3.toString())}
                                                });
                                           
                                              $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {  
                                                   if (getObject(id).common.name == "cur_current")  {checkPow=true; val2=getState(id).val.toString()+" mA"; }//log(val2.toString())}
                                                   }); 
                                                
                                             $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {   
                                                    if (getObject(id).common.name.includes("online"))  {checkOnline=true; val1=getState(id).val; }//log(val1.toString())}
                                                  
                                                   });  
                                    
                                                   val5_2=false;
                                              $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {   
                                                    if (getObject(id).common.name ==("power"))  { val5_2=true; val5_1=getState(id).val; }//log(val5_1.toString())}
                                                  
                                                   });  
                                                  }
                                    
                                      // if (getObject(id.replace("cur_current","cur_voltage")).common.name == "cur_voltage")  {checkVol=true}
                                      // if (getObject(id.replace("cur_current","cur_power")).common.name == "cur_power")    {checkPow=true}
                                       
                                       if (checkCur && checkPow && checkVol && checkOnline) checker=true;
                                      // log(checkCur.toString() + checkVol.toString()+ checkPow.toString())///if (getObject(id).common.name == "cur_voltage") {}
                                       ///if (getObject(id).common.name == "cur_power") {}
                                    
                                       if (checker) {
                                    
                                    
                                    
                                            //log (id)
                                             anzahl++;
                                            
                                              var stateIdHM=ida[3]; //log(stateIdHM)
                                              counter++; 
                                          //   var valVersion=getState(id.replace("totalNow","hw_ver")).val;  
                                               
                                               
                                            
                                            //  val1=getState(ida[0]+"."+ida[1]+"."+ida[2]+".cur_current").val   //getState(id.replace("ENERGY_COUNTER","STATE")).val;                  
                                              val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;  //val0=getObject(id).common.name ;
                                             if(val5_2) {if (val5_1)  {val5=(" <font color=\"lightgreen\"> ")+"ON"} else { val5=(" <font color=\"red\"> ")+"OFF";}}
                                                else {if (val1) {val5=" - "} else { val5=(" <font color=\"red\"> ")+" - ";}} 
                                    
                                           
                                              val6=" - "; // getState(id).val.substring(0,5)+ " kWh";
                                              val7=" - "; // getState(id.replace("totalNow","totalMonthNow")).val.substring(0,5)+ " kWh";
                                              val8=" - "; // (parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                              val9=" - "; // (parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                          
                                                   let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                     if (sourceAnalyTuya  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                 let    myId=id.replace(/\./g,"__")
                                                
                                                        val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                        val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                        val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                        val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                              if (gesamt) {           
                                                         gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                         gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                         gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                         gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                              }}
                                              
                                              if(!val1) {
                                                  val1=symbolKO;
                                                  val4=(" <font color=\"red\"> ")+" --- ";
                                                  val2=(" <font color=\"red\"> ")+" --- ";
                                                  val3=(" <font color=\"red\"> ")+" --- ";
                                                  val5=(" <font color=\"red\"> ")+" --- ";
                                                  val6=(" <font color=\"red\"> ")+" --- ";
                                                  val7=(" <font color=\"red\"> ")+" --- ";
                                                  val0=(" <font color=\"red\"> ")+val0;
                                                  val8=(" <font color=\"red\"> ")+" --- ";
                                                  val9=(" <font color=\"red\"> ")+" --- ";}
                                              else{
                                                  val1=symbolOK;
                                                 // val1=(" <font color=\"lightgreen\"> ")+val1
                                                 // val2=(" <font color=\"green\"> ")+val2
                                                 // val3=(" <font color=\"green\"> ")+val3
                                                 // val0=(" <font color=\"green\"> ")+val0
                                                 }
                                    
                                    
                                             
                                       
                                         tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        
                                      } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                    } //ende fritzdect
                                    if (gesamt){
                                           tabelleAusbessern();
                                          counter=0;
                                          val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=0;
                                          val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">GESAMT</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";
                                          val4="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Anzahl<"+HTMLbrandSetting+">";
                                          val5="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Update<"+HTMLbrandSetting+">";
                                          val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                          val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                          val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                          val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          tabelleAusbessern();
                                          counter=-1
                                          val0="alle Geräte";
                                          val1=" - "; 
                                          val2=" - ";
                                          val3=" - ";
                                          val4=anzahl.toString();
                                          if (virtualPower && !virtualPowerGesamt)   val4=anzahl.toString();
                                          if (!virtualPower && virtualPowerGesamt)   val4=anzahl.toString()+"++";
                                          if (virtualPower && virtualPowerGesamt)   val4=(anzahl-1).toString();
                                          val5=formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");;
                                        //  log(typeof gesamtNow +"wert "+gesamtNow )
                                          val6=(gesamtNow.toFixed(3)+"kWh");
                                          val7=(gesamtMonth.toFixed(3)+"kWh");
                                          val8=(gesamtMoneyTod.toFixed(2)+"€");
                                          val9=(gesamtMoneyMon.toFixed(2)+"€");
                                           tabelleBind();
                                    
                                    
                                    }
                                    //-------------------------------------------------------------------------------------------------------------------------------------------------
                                    //--------------------------------------------------Ende der schleife------------------------------------------------------------------------------
                                    //-------------------------------------------------------------------------------------------------------------------------------------------------
                                    
                                          tabelleFinish(); // AB HIER NICHTS ÄNDERN - tabelle fertigstellen
                                        // log(anzahl.toString());
                                          
                                         
                                          if (virtualPower && virtualPowerGesamt)   anzahl=anzahl-1;
                                              setState(dpAnzahl,anzahl); 
                                    } // function ende
                                    
                                    //MAIN:
                                     
                                    schedule(mySchedule,  function () {
                                     writeHTML();
                                     if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/  });}
                                    }); 
                                     writeHTML();
                                    
                                       				 function tabelleBind(){
                                         //HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT - hat man oben 5 Felder definiert, braucht man hier 5 Werte
                                       
                                           switch (mehrfachTabelle) {  
                                             case 1:                    htmlOut=htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>"; break;
                                            case 2:  if(counter%2==0)  {htmlOut = htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>"; } 
                                                                  else {htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>";} break;
                                                                       
                                            case 3: if(counter%3==0 )  {htmlOut = htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>"; } 
                                                                  else { if(counter%3==1 )  { htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>";} 
                                                                                   else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>";}
                                                                             } break;
                                    
                                    
                                            case 4: if(counter%4==0)  {htmlOut = htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>"; } 
                                                                      else {if(counter%2==1 )  { htmlOut = htmlOut+"<td  align="+Feld1lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>";} 
                                                                                   else    {if(counter%2==1 && counter%4==3)  { htmlOut= htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>";} 
                                                                                                     else    {htmlOut = htmlOut = htmlOut+"<td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td>&ensp;"+val1+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>";}}
                                                                             } break;
                                    
                                         } //switch ende
                                    
                                    
                                    
                                    }
                                    
                                    
                                    function tabelleAusbessern() {
                                           switch (mehrfachTabelle) {  
                                             case 1:    break;
                                             case 2:    mix=Math.abs(((counter+1)%2)-mehrfachTabelle);  
                                                        if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                        break;
                                             case 3:    mix =Math.abs(((counter+1)%3)-mehrfachTabelle);
                                                        if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                        if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');   
                                                        break;
                                             case 4:    mix=Math.abs(((counter+1)%4)-mehrfachTabelle);
                                                        if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');
                                                        if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');    
                                                        if(mix==3)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');      
                                                        break; }
                                    }
                                    
                                    function tabelleFinish() {
                                    
                                          // tabelle fertigstellen
                                           switch (mehrfachTabelle) {  
                                             case 1:    break;
                                             case 2:    mix=Math.abs(((counter+1)%2)-mehrfachTabelle);  
                                                        if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                        break;
                                             case 3:    mix =Math.abs(((counter+1)%3)-mehrfachTabelle);
                                                        if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                        if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');   
                                                        break;
                                             case 4:    mix=Math.abs(((counter+1)%4)-mehrfachTabelle);
                                                        if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');
                                                        if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');    
                                                        if(mix==3)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');      
                                                        break; }
                                         
                                                        var htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: "+htmlÜberFontGroesse+"; font-weight:"+htmlSchriftWeite+ "\">"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</p>"; 
                                           var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 70%; text-align: right;\" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</div>"
                                            
                                            if (!htmlSignature) htmlUnter="";
                                              //Ausgabe über VIS html widget - tabelle in datenpunkt schreiben - html tabelle ohne html header und body
                                               var htmlOutVIS="";
                                             //  htmlUberschrift ? htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>" : htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>";
                                                if (htmlUberschrift) 
                                                    { zentriert ? htmlOutVIS=htmlZentriert+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter : htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter ;
                                    
                                                  } else {
                                                   zentriert ?  htmlOutVIS=htmlZentriert+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter :  htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter;
                                    
                                                     }
                                    
                                    // log("bin raus aus tabelleBind");
                                               if (braucheEinVISWidget) setState(dpVIS, htmlOutVIS );
                                    
                                     var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 80%;  text-align: center; \" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</div>"
                                     var htmlEnd="</table>"+htmlUnter+"</div></body>";
                                     if (!htmlSignature) htmlUnter="";
                                    
                                     //mit oder ohne überschrift - zentriert oder links
                                    htmlUberschrift ? htmlOut=htmlStart+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd : htmlOut=htmlStart+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd;
                                     //log(htmlOut);
                                     
                                    
                                    
                                    }
                                    
                                    
                                    
                                    

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

                                    sigi234S ? 2 Antworten Letzte Antwort
                                    0
                                    • liv-in-skyL liv-in-sky

                                      ich würde tester suchen

                                      thema:

                                      sourceanalytix

                                      ich wollte mal eine gesamtsumme darstellen

                                      • gesamtsumme ist dazugekommen (tabellenende)
                                      • bei nutzung kann man virtualPowermeter als einzelgeräte oder als gesamt (auch beides) anzeigen lassen

                                      leider habe ich festgestellt, dass die pow, blitzwolf, teckin - tasmota geflashed- ja eine gesamt kWh haben, also von beginn der ersten installation - das bedeutet, ich muss auch diese geräte mit sourceanalytixs verbinden, um wenigstens eine monatliche anzeige zu bekommen
                                      ob sourceanalytixs die richtigen werte leifert, habe ich noch nicht festgestellt - ich hoffe das mal

                                      Image 2.png

                                      das ganze project bekommt natürlich erst einen mehrwert, wenn die daten der letzten 4 spalten da sind - und die werden nun (ausnahme : hs.1000) alle über sourceanalytix eingelesen
                                      kompliziert wird es dann noch ein wenig, wenn man über den virtual-powermeter-adapter arbeitet, um zusätzliche werte zu generieren - das habe ich schon weiter oben erklärt

                                      Image 3.png

                                      daher haben sich die settings-variablen auch geändert - es gibt jetzt für jede geräte-kategorie auch eine sourceanalytixs variable - muss aber nicht aktiviert werden - bevor man dies macht, sollte sourceanalytics installiert sein (wichtig - instanz 0) und der datenpunkt auch auf actic stehen - sonst gibt es fehler. das gleiche gilt auch für die virtualPowermeter einstellung -zuerst installieren und eine datenpunkt auf activ schalten (siehe anleitung)

                                      Image 4.png

                                      @Lenny-CB - blitzwolf ist hier auch drin

                                      das script:

                                      //@liv-in-sky Januar 2020 Ver. 23.1.20-15
                                      
                                      //HIER WIRD PFAD UND FILENAME DEFINIERT
                                      const path = "/htmlenergy.html";                   //FIlenamen definieren
                                      const home ='vis.0'                                 //wo soll das file im iobroker-file-system liegen ? (oder z.b auch iqontrol.meta)
                                      let   braucheEinFile=false;                          // bei true wird ein file geschrieben
                                      let   braucheEinVISWidget=true;                     // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile
                                      let dpVIS="controll-own.0.TABELLEN.ENERGY"         //WICHTIG wenn braucheEinVISWidget auf true gesetzt !!  dp zusätzlich für VIS-HTML-Basic-Widget
                                      let dpAnzahl="controll-own.0.TABELLEN.AnzahlEnergiemesser";  //WICHTIG datenpunkt erstellen vom typ "number" - bei 0 kein alarm und größer 0 die anzahl der schlechten batterien
                                      let htmlColorDeviceUeberschrift="#A0C2A0"             //  Farbe der Geräte Marken 
                                      let HTMLbrandSetting="i"                              // style der geräte marken:  möglich b fett; i kursiv; span normal
                                      let triggerBySonoffPower=true;
                                      //---------------------------------------
                                      let mySchedule="  */5 * * * * "; 
                                      
                                      let kwhPreis=0.29;
                                      
                                      // GERÄTE FREISCHALTUNG und SourceAnalytics
                                      
                                      var pow=true;             var sourceAnalyPow=false;
                                      var tuya=true;            var sourceAnalyTuya=false;
                                      var hs100=true;                                                                                                  //tplink
                                      var homematic=true;       var sourceAnalyHM=false;
                                      var blitzwolf=true;       var sourceAnalyBlitz=false;
                                      var teckin=true;          var sourceAnalyTeck=false;
                                      var mihome=true;          var sourceAnalyMihome=false;                                                            //smart-plug
                                      var homee=true;           var sourceAnalyHomee=false;
                                      var gosundSP1x=true;      var sourceAnalyGo=false;
                                      var shelly=true;          var sourceAnalyShelly=false;
                                      var virtualPower=false;    var virtualPowerGesamt=false;
                                      
                                      var gesamt=true;                                            // Spalte Gesamt am ende der tabelle
                                      
                                      var symbolOK="🟢";     // auch möglich: ="✅"  
                                      var symbolKO="🔴";     //z.b. auch "<font color=\"red\"><b>X</b>" für ein rotes kreuz  oder : ="❌"
                                      var symbolWARN="⚠️";    // ="⚠️"
                                      var externalOhneInfo=false;  //noch nicht integriert
                                      
                                      
                                      
                                      
                                      //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 5
                                      var htmlFeld1='Device';       var Feld1lAlign="left";                     // überschrift Tabellen Spalte1 und  Ausrichtung left,right or center
                                      var htmlFeld2='Status';        var Feld2lAlign="center";                      // überschrift Tabellen Spalte2 und  Ausrichtung left,right or center
                                      var htmlFeld3='Amp';         var Feld3lAlign="center";                    // überschrift Tabellen Spalte3 und  Ausrichtung left,right or center
                                      var htmlFeld4='Volt';        var Feld4lAlign="center";                    // überschrift Tabellen Spalte4 und  Ausrichtung left,right or center
                                      var htmlFeld5='Power';        var Feld5lAlign="left";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                      var htmlFeld6='Schalter';        var Feld6lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                      var htmlFeld7='';        var Feld7lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                      var htmlFeld8='';        var Feld8lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                      var htmlFeld9='';        var Feld9lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                      var htmlFeld10='';        var Feld10lAlign="center";                    // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                                      
                                      //-----------------------------------
                                      
                                      
                                      //ÜBERSCHRIFT ÜBER TABELLE
                                      let   htmlUberschrift=true;                           // mit Überschrift über der tabelle
                                      let   htmlSignature=false;                              // anstatt der Überscghrift eine signature: - kleiner - anliegend
                                      const htmlFeldUeber='Energy Devices';              // Überschrift und Signature
                                      const htmlFarbUber="white";                         // Farbe der Überschrift
                                      const htmlSchriftWeite="normal";                       // bold, normal - Fettschrift für Überschrift
                                      const htmlÜberFontGroesse="18px";                       // schriftgröße überschrift
                                      //MEHRERE TABELLEN NEBENEINANDER
                                      let   mehrfachTabelle=1;                              // bis zu 4 Tabellen werden nebeneinander geschrieben-  verkürzt das Ganze, dafür etwas breiter - MÖGLICH 1,2,3,oder 4 !!!
                                      const htmlFarbZweiteTabelle="white";                // Farbe der Überschrift bei jeder 2.ten Tabelle
                                      const htmlFarbTableColorUber="#BDBDBD";               // Überschrift in der tabelle - der einzelnen Spalten
                                      //GANZE TABELLE
                                      let abstandZelle="1";
                                      let weite="auto";                                     //Weite der Tabelle
                                      let zentriert=true;                                   //ganze tabelle zentriert
                                      const backgroundAll="#000000";                        //Hintergrund für die ganze Seite - für direkten aufruf oder iqontrol sichtber - keine auswirkung auf vis-widget
                                      const htmlSchriftart="Helvetica";
                                      const htmlSchriftgroesse="14px";
                                      //FELDER UND RAHMEN
                                      let   UeberschriftSpalten=true;                // ein- oder ausblenden der spatlen-überschriften
                                      const htmlFarbFelderschrift="#BDBDBD";                  // SchriftFarbe der Felder
                                      const htmlFarbFelderschrift2="#D8D8D8";                 // SchriftFarbe der Felder für jede 2te Tabelle
                                      const htmlFarbTableColorGradient1="#424242";          //  Gradient - Hintergrund der Tabelle - Verlauffarbe
                                      const htmlFarbTableColorGradient2="#424242";          //  Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
                                      const htmlFarbTableBorderColor="gray";             // Farbe des Rahmen - is tdieser gleich den gradienten, sind die rahmen unsichtbar
                                      let htmlRahmenLinien="cols";                            // Format für Rahmen: MÖGLICH: "none" oder "all" oder "cols" oder "rows"
                                      const htmlSpalte1Weite="auto";                   //  Weite der ersten beiden  Spalten oder z.b. 115px
                                      
                                      // HIER NICHTS  ÄNDERN
                                      
                                      let borderHelpBottum;
                                      let borderHelpRight;
                                      let htmlcenterHelp;
                                      let htmlcenterHelp2;
                                      
                                      if(htmlRahmenLinien=="rows") {borderHelpBottum=1;borderHelpRight=0;}
                                      if(htmlRahmenLinien=="cols") {borderHelpBottum=0;borderHelpRight=1;}
                                      if(htmlRahmenLinien=="none") {borderHelpBottum=0;borderHelpRight=0;}
                                      if(htmlRahmenLinien=="all")  {borderHelpBottum=1;borderHelpRight=1;}
                                      zentriert ? htmlcenterHelp="auto" : htmlcenterHelp="left";
                                      zentriert ? htmlcenterHelp2="center" : htmlcenterHelp2="left";
                                      
                                      
                                      const htmlZentriert='<center>'
                                      const htmlStart=    "<!DOCTYPE html><html lang=\"de\"><head><title>Vorlage</title><meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\">"+
                                                         "<style> * {  margin: 0;} body {background-color: "+backgroundAll+"; margin: 0 auto;  }"+
                                                         " p {padding-top: 10px; padding-bottom: 10px; text-align: "+htmlcenterHelp2+"}"+
                                                        // " div { margin: 0 auto;  margin-left: auto; margin-right: auto;}"+
                                                         " td { padding:"+abstandZelle+"px; border:0px solid "+htmlFarbTableBorderColor+";  border-right:"+borderHelpRight+"px solid "+htmlFarbTableBorderColor+";border-bottom:"+borderHelpBottum+"px solid "+htmlFarbTableBorderColor+";}"+ 
                                                         " table { width: "+weite+";  margin: 0 "+htmlcenterHelp+"; border:1px solid "+htmlFarbTableBorderColor+"; border-spacing=\""+abstandZelle+"0px\" ; }"+   // margin macht center
                                                         "td:nth-child(1) {width: "+htmlSpalte1Weite+"}"+"td:nth-child(2) {width:"+htmlSpalte1Weite+"}"+
                                                         " </style></head><body> <div>";
                                      //const htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-weight: bold\">"+htmlFeldUeber+"</p>";                    
                                      const htmlTabStyle= "<table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"2px\" cellspacing=\""+abstandZelle+"\" cellpadding=\""+abstandZelle+"\" width=\""+weite+"\" rules=\""+htmlRahmenLinien+"\" style=\"color:"+htmlFarbFelderschrift+";  font-size:"+htmlSchriftgroesse+
                                                            "; font-family:"+htmlSchriftart+";background-image: linear-gradient(42deg,"+htmlFarbTableColorGradient2+","+htmlFarbTableColorGradient1+");\">";
                                      const htmlTabUeber1="<tr style=\"color:"+htmlFarbTableColorUber+"; font-weight: bold\">";
                                      const htmlTabUeber3="</tr>";
                                      
                                      
                                      //NICHTS ÄNDERN - abhängig von den oben definierten _Spalten - in diesem Beispiel sind es 5
                                      
                                      
                                      var htmlTabUeber2="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+">&ensp;"+htmlFeld1+"&ensp;</td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+">&ensp;"+htmlFeld2+"&ensp;</td><td  align="+Feld3lAlign+">&ensp;"+htmlFeld3+"&ensp;</td><td align="+Feld4lAlign+
                                                        ">&ensp;"+htmlFeld4+"&ensp;</td><td  align="+Feld5lAlign+">&ensp;"+htmlFeld5+"&ensp;</td><td  align="+Feld6lAlign+">&ensp;"+htmlFeld6+"&ensp;</td><td  align="+Feld7lAlign+">&ensp;"+htmlFeld7+"&ensp;</td><td  align="+Feld8lAlign+">&ensp;"+htmlFeld8+
                                                        "&ensp;</td><td  align="+Feld9lAlign+">&ensp;"+htmlFeld9+"&ensp;</td><td  align="+Feld10lAlign+">&ensp;"+htmlFeld10+"&ensp;</td>";
                                      var htmlTabUeber2_1="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld1+"&ensp;</td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld3+
                                                         "&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld3+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld4+
                                                         "&ensp;</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld5+"&ensp;</td><td align="+Feld6lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld6+"&ensp;</td><td align="+Feld7lAlign+
                                                         " style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld7+"&ensp;</td><td align="+Feld8lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\"&ensp;>"+htmlFeld8+"&ensp;</td><td  align="+Feld9lAlign+">&ensp;"+htmlFeld9+"&ensp;</td><td  align="+Feld10lAlign+">&ensp;"+htmlFeld10+"&ensp;</td>";
                                                             //------------------------------------------------------
                                      
                                      let triggerBySonoffSwitch=false;
                                      var anzahl;
                                      var AkkuAlarm=[];
                                      var htmlOut="";
                                      var mix;
                                      var counter;
                                      var arrTrigger=[];
                                      
                                      var val1; var val2; var val0; var val3; var val4; var val5; var val6; var val7; var val8; var val9;
                                      var htmlTabUeber="";
                                      function writeHTML(){
                                      var gesamtNow=0;
                                      var gesamtMonth=0;
                                      var gesamtMoneyTod=0;
                                      var gesamtMoneyMon=0;
                                      
                                      anzahl=0;
                                      htmlOut="";
                                      counter=-1;
                                      htmlTabUeber="";
                                      switch (mehrfachTabelle) { 
                                         case 1: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber3;  break;
                                         case 2: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break;
                                         case 3: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2+htmlTabUeber2+htmlTabUeber3; break;
                                         case 4: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break;
                                      }; 
                                      if (!UeberschriftSpalten) {htmlTabUeber=""}  
                                      
                                      //--------------------------------------------------------------------------------------------------------------------------------------------------
                                      //---------hier kommt eure schleife rein counter++, tabelleBind() und tabelleFinish() müssen so integriert bleiben !!!------------------------------
                                      //---------alle valx werte müssen von euch bestimmt werden - val0,val1,val2,val3,val4!!!------------------------------------------------------------
                                      //--------------------------------------------------------------------------------------------------------------------------------------------------
                                        var arrSouAna=[];
                                       if (sourceAnalyHM) {
                                                      $("sourceanalytix.0.*").each(function(id, i) {   // kontrolliere ob OPERATING_VOLTAGE vorhanden
                                                    var idc = id.split('.');
                                                   if (idc[2].includes("POWER")  ) {
                                                    if (!arrSouAna.includes(idc[2]) ) { // && idc[2].includes("POWER") ) {
                                                 arrSouAna.push(idc[2])} }
                                                 });
                                       }
                                          var arrSouAnaAll=[];
                                       if (sourceAnalyTuya || sourceAnalyMihome || sourceAnalyHomee || sourceAnalyShelly || virtualPower || virtualPowerGesamt || sourceAnalyGo || sourceAnalyPow || sourceAnalyBlitz|| sourceAnalyTeck) {
                                                      $("sourceanalytix.0.*").each(function(id, i) {   // kontrolliere ob OPERATING_VOLTAGE vorhanden
                                                    var idc = id.split('.');
                                                     
                                                  
                                                    if (!arrSouAnaAll.includes(idc[2]) ) { // && idc[2].includes("POWER") ) {
                                                 arrSouAnaAll.push(idc[2]);} 
                                                 });
                                       }
                                      // log(arrSouAnaAll.toString());
                                      
                                      if (virtualPower){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">VirtualPower</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      
                                          var arrVirtDev=(getState("virtualpowermeter.0.group_script.info").val).replace(/;$/,"").split(';');
                                        // log(arrVirtDev[1])
                                         for (var i=0;i<arrVirtDev.length;i++) {
                                               anzahl++;
                                             // var ida = arrVirtDev[i].split('.');
                                             
                                                counter++;
                                         //   log(arrVirtDev[i])
                                            var val0help=arrVirtDev[i].replace(/(.+)\..+$/,"$1"); // log("mein dp: "+val0help)    // sonoff.0.Sonoff15.Script_Power
                                            val0=getObject(val0help).common.name;                                // sonoff.0.Sonoff16.Script_Power
                                          //  val0=val0.replace(";","");
                                            val1=true;
                                             val2=" - "; val3=" - ";
                                             val4=getState(val0help+".Script_Power").val+" W"
                                            var sourcerhelper=(val0help+".Script_Total").replace(/\./g,"__");
                                            //var sourcerhelper2=(val0help+".Script_Power").replace(".","___");
                                             //   var  val5_2=getState(val5_1).val ;          //                                                            log(" wo isser " +val5_2.toString())
                                                val5=" - "
                                                val6=" - ";//=getState(id).val + " kWh";
                                                val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                                val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                      
                                                          
                                                          val8=(getState("sourceanalytix.0." + sourcerhelper+".cost.01_current_day").val).toString()+" €";
                                                          val9=(getState("sourceanalytix.0." + sourcerhelper+".cost.03_current_month").val).toString()+" €";
                                                          val7=(getState("sourceanalytix.0." + sourcerhelper+".consumption.03_current_month").val).toString()+" kWh";   
                                                          val6=(getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val).toString()+" kWh" ;
                                                       
                                      
                                                if (!val1) {
                                                   // log("false")
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                   // log("true")
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                      
                                            if (gesamt) {     
                                          //  let val6_1=(getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val); 
                                          //   let val6_1=getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val;
                                         // log(typeof (getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val) )
                                            gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".consumption.01_current_day").val); 
                                           // let val7_1=(getState("sourceanalytix.0." + sourcerhelper+".consumption.03_current_month").val);
                                            gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".consumption.03_current_month").val);
                                           // let val8_1=(getState("sourceanalytix.0." + sourcerhelper+".cost.01_current_day").val);
                                            gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".cost.01_current_day").val);
                                           // let val9_1=(getState("sourceanalytix.0." + sourcerhelper+".cost.03_current_month").val);
                                            gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + sourcerhelper+".cost.03_current_month").val);
                                            } 
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                       //   log("1------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                         }; //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende virtual
                                      
                                       if (virtualPowerGesamt){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">VirtualPower Gesamt</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                        // keine schleife nötig
                                      
                                               anzahl++;
                                           
                                                counter++;
                                       
                                            val0="Gesamt" //getObject(val0help).common.name;                                // sonoff.0.Sonoff16.Script_Power
                                      
                                            val1=true;
                                             val2=" - "; val3=" - ";
                                             val4= " - "; //getState(val0help+".Script_Power").val+" W"
                                            var sourcerhelper=(val0help+".Script_Total").replace(/\./g,"__");
                                      
                                                val5=" - "
                                                val6=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val).toString(); //=getState(id).val + " kWh";
                                                val7=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.03_current_month").val).toString(); //"" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                                val8=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.01_current_day").val).toString();  //" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.03_current_month").val).toString(); //" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                      
                                                if (!val1) {
                                                   // log("false")
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                   // log("true")
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                            if(!virtualPower && gesamt) {
                                        //    let val6_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val); 
                                            gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val); 
                                        //    let val7_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.03_current_month").val);
                                            gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.03_current_month").val);
                                         //   let val8_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.01_current_day").val);
                                            gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.01_current_day").val);
                                        //    let val9_1=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.03_current_month").val);
                                            gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.cost.03_current_month").val);
                                            } 
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                         // log(".1------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                        // }; //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende virtual
                                      
                                      
                                      if (pow){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Pow (R2)</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                       $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                         
                                            if (getState(id).val=="Sonoff Pow" || getState(id).val=="Sonoff Pow R2") {
                                               // log (id)
                                               anzahl++;
                                              var ida = id.split('.');
                                             
                                                counter++; 
                                                  //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                                val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                                val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                                val2=((getState(id.replace("INFO.Module","ENERGY_Current")).val)*1000).toString()+ " mA";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                                val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                                let val7_1=getState(id.replace("INFO.Module","POWER")).val;        
                                                val7_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                                val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                                val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                                val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(2)+" €";
                                                val9=" - "; //(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(2)+" €";
                                      
                                                let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyPow  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                           let  myId=idhlp;
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                                 if (gesamt) {          
                                                           // gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           //gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                           
                                                }         }
                                              
                                                if (!getState(id.replace("INFO.Module","alive")).val) {
                                                   val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                      
                                                   
                                      
                                      
                                                   }
                                            if (gesamt) {  
                                            gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                           // gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                            gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                            //gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                            } 
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                         // log("2------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                        } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                       if (teckin){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Teckin</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                       $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                         
                                            if (getState(id).val=="Teckin") {
                                               // log (id)
                                               anzahl++;
                                              var ida = id.split('.');
                                             
                                                counter++; 
                                                  //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                                val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                                val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                                val2=((getState(id.replace("INFO.Module","ENERGY_Current")).val)*1000).toString()+ " mA";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                                val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                                let val7_1=getState(id.replace("INFO.Module","POWER")).val;        
                                                val7_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                                val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                                val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                                val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(2)+" €";
                                                val9=" - ";//(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(2)+" €";
                                              
                                                let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyTeck  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                           let  myId=idhlp;
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                                 if (gesamt) {          
                                                        
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                }         }
                                              
                                                if (!getState(id.replace("INFO.Module","alive")).val) {
                                                   val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                      
                                                   
                                      
                                      
                                                   }
                                            if (gesamt) {  
                                            gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                          //  gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                            gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                          //  gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                            } 
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          log("3------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                        } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      
                                      if (blitzwolf){
                                      
                                                  // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                           tabelleAusbessern();
                                           counter=0;
                                           val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                           tabelleAusbessern();
                                           counter=0;
                                           val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">BlitzWolf SHP</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                           val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                           val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                           val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                           val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                           val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                           tabelleAusbessern();
                                           counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                      $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                        
                                           if (getState(id).val=="BlitzWolf SHP"  || getState(id).val=="BlitzWolf SHP7" || getState(id).val=="BlitzWolf SHP8" || getState(id).val=="BlitzWolf SHP6") {
                                              // log (id)
                                              anzahl++;
                                             var ida = id.split('.');
                                            
                                               counter++; 
                                                 //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                               val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                               val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                               val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                               val2=getState(id.replace("INFO.Module","ENERGY_Current")).val.toFixed(2)+ " A";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                               val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                               let val5_1=getState(id.replace("INFO.Module","POWER")).val;        
                                               val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                               var val7_2; var val8_2; 
                                               if ( getState(id).val=="BlitzWolf SHP7") {
                                                   let val7_1=getState(id.replace("INFO.Module","POWER1")).val;        
                                               val7_1 ? val7_2=(" <font color=\"lightgreen\"> ")+"ON" : val7_2=(" <font color=\"red\"> ")+"OFF";
                                               let val8_1=getState(id.replace("INFO.Module","POWER2")).val;        
                                               val8_1 ? val8_2=(" <font color=\"lightgreen\"> ")+"ON" : val8_2=(" <font color=\"red\"> ")+"OFF";
                                               val5=val7_2+" "+val8_2;
                                               }
                                               val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                               val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                               val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(2)+" €";
                                               val9=" - ";//(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(2)+" €";
                                             
                                                let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyBlitz  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                           let  myId=idhlp;
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                                 if (gesamt) {          
                                                        
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                }         }
                                              
                                                if (!getState(id.replace("INFO.Module","alive")).val) {
                                                   val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                      
                                                   
                                      
                                      
                                                   }
                                            if (gesamt) {  
                                            gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                           // gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                            gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                          //  gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                            } 
                                              
                                        
                                          tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                         
                                       } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      
                                       if (gosundSP1x){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                           val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Gosund</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                       $('sonoff.*.*.INFO.Module').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                         
                                            if (getState(id).val.includes("Gosund SP1")) {
                                               // log (id)
                                               anzahl++;
                                              var ida = id.split('.');
                                             
                                                 counter++; 
                                                  //log("dad   "+getState(id.replace("Info.Module","alive")).val + " ----" +id.replace("Info.Module","alive"))
                                                val1=getState(id.replace("INFO.Module","alive")).val;                   //sonoff.0.SonoffPow1.alive          sonoff.0.SonoffPow1.INFO.Module
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                                val4=getState(id.replace("INFO.Module","ENERGY_Power")).val.toString()+ " W"                       //sonoff.0.SonoffPow2.ENERGY_Power
                                                val2=getState(id.replace("INFO.Module","ENERGY_Current")).val.toFixed(2)+ " A";   //sonoff.0.SonoffPow1.Wifi_RSSIsonoff.0.SonoffPow1.POWER
                                                val3=getState(id.replace("INFO.Module","ENERGY_Voltage")).val.toString()+" V"; 
                                                let val7_1=getState(id.replace("INFO.Module","POWER")).val;        
                                                val7_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                                val6=getState(id.replace("INFO.Module","ENERGY_Today")).val.toFixed(2)+ " kWh";
                                                val7=" - ";//getState(id.replace("INFO.Module","ENERGY_Total")).val.toFixed(2)+ " kWh";
                                                val8=(getState(id.replace("INFO.Module","ENERGY_Today")).val*kwhPreis).toFixed(1)+" €";
                                                val9=" - ";//(getState(id.replace("INFO.Module","ENERGY_Total")).val*kwhPreis).toFixed(1)+" €";
                                              
                                                let idhlp=(id.replace("INFO.Module","ENERGY_Power")); idhlp=idhlp.replace(/\./g,"__");  //log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyGo  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                           let  myId=idhlp;
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          //val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                                 if (gesamt) {          
                                                        
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                }         }
                                              
                                                if (!getState(id.replace("INFO.Module","alive")).val) {
                                                   val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                      
                                                   
                                      
                                      
                                                   }
                                            if (gesamt) {  
                                            gesamtNow=gesamtNow+parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val);
                                           // gesamtMonth=0; //gesamtMonth+getState(id.replace("INFO.Module","ENERGY_Total")).val;
                                            gesamtMoneyTod=gesamtMoneyTod+(parseFloat(getState(id.replace("INFO.Module","ENERGY_Today")).val))*kwhPreis;
                                           // gesamtMoneyMon=0;//(gesamtMoneyMon+getState(id.replace("INFO.Module","ENERGY_Total")).val)*kwhPreis;
                                            }      
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          
                                        } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                       if (homee){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Homee</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                      //let mySelector= "homee.*.*.CurrentEnergyUse-190"; mySelector=mySelector.replace(/-.+/,"");
                                       $("homee.*.*.CurrentEnergyUse*").each(function(id, i) {    // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                            var ida = id.split('.');       
                                            var arrHomee=[]
                                                  $(ida[0]+"."+ida[1]+"."+ida[2]+".*" ).each(function(id, i) { 
                                                    arrHomee.push(id)
                                      
                                                  });
                                      
                                              // log (arrHomee.toString())
                                               anzahl++;
                                              
                                             
                                                counter++; 
                                               
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;
                                                val1=true;
                                                //var val2_1;var val3_1;
                                                val2=" - "; val3=" - ";
                                                for (var i=0;i<arrHomee.length;i++){if(arrHomee[i].includes("Current-"))  val2=(getState(arrHomee[i]).val)*1000 +" mA"}
                                                for (var i=0;i<arrHomee.length;i++){if(arrHomee[i].includes("Voltage"))  val3=(getState(arrHomee[i]).val) +" V"}
                                                
                                                val4=getState(id).val.toString()+" W";
                                                var val5_1;
                                                for (var i=0;i<arrHomee.length;i++){if(arrHomee[i].includes("OnOff"))  val5_1=getState(arrHomee[i]).val}
                                      
                                                val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                                val6=" - ";//=getState(id).val + " kWh";
                                                val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                                val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                              //  log(val1.toString()) 
                                      
                                              
                                               
                                                   let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyHomee  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                   var    myId=id.replace(/\./g,"__")
                                                  
                                                          val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                              if (gesamt) {             
                                                           gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                           } }
                                                if (!val1) {
                                                   // log("false")
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                   // log("true")
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                      
                                      
                                               
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                        //  log("4------------------------------------"+gesamtMonth.toString()+"---"+gesamtMoneyMon.toString())
                                         }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      
                                      
                                       if (shelly){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Shelly</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      
                                       $('shelly.*.*.*.Power').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                         
                                      
                                               // log (id)
                                               anzahl++;
                                              var ida = id.split('.');
                                             
                                                counter++; 
                                      
                                           //     if (parseInt((new Date().getTime())) - val1_1 < 120000) {val1=true} else {val1=false;}  // log(val1.toString())          
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ; //log(val0)
                                                val1=true;
                                                val2=" - "; val3=" - ";
                                                val4=getState(id).val.toString()+" W";
                                      
                                                var val5_1= getState(id.replace("Power","Switch")).val;
                                                val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                                val6=" - ";//=getState(id).val + " kWh";
                                                val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                                val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                              //  log(val1.toString()) 
                                      
                                              
                                                 
                                                    let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyShelly  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                   let    myId=id.replace(/\./g,"__")
                                                  
                                                          val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                                 if (gesamt) {          
                                                           gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                }         }
                                      
                                                if (!val1) {
                                                   // log("false")
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                   // log("true")
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                      
                                      
                                               
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          
                                         }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      
                                       if (mihome){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Mihome</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      
                                       $('mihome.*.devices.*.load_power').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                         
                                      
                                               // log (id)
                                               anzahl++;
                                              var ida = id.split('.');
                                             
                                                counter++; 
                                      
                                           //     if (parseInt((new Date().getTime())) - val1_1 < 120000) {val1=true} else {val1=false;}  // log(val1.toString())          
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]+"."+ida[3]).common.name ; //log(val0)
                                                val1=true;
                                                val2=" - "; val3=" - ";
                                                val4=getState(id).val.toString()+" W";
                                      
                                                var val5_1= getState(id.replace("load_power","state")).val;
                                                val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                                val6=" - ";//=getState(id).val + " kWh";
                                                val7=" - ";//getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                                val8=" - ";//(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=" - ";//(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                              //  log(val1.toString()) 
                                      
                                              
                                                 
                                                    let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyMihome  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                   let    myId=id.replace(/\./g,"__")
                                                  
                                                          val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                              if (gesamt) {             
                                                           gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                }         }
                                      
                                                if (!val1) {
                                                   // log("false")
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                   // log("true")
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                      
                                      
                                               
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          
                                         }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      
                                       if (hs100){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">HS100</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                       $('hs100.*.*.totalNow').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                         
                                      
                                               // log (id)
                                               anzahl++;
                                              var ida = id.split('.');
                                             
                                                counter++; 
                                                var valVersion=getState(id.replace("totalNow","hw_ver")).val;  
                                                var val1_1=Date.parse(getState(id.replace("totalNow","last_update")).val); 
                                                if (parseInt((new Date().getTime())) - val1_1 < 120000) {val1=true} else {val1=false;}  // log(val1.toString())          
                                                val0=getObject(id).common.name ;
                                               
                                                var val4_1=getState(id.replace("totalNow","power")).val.toString();
                                                val4=val4_1.substr(0, 4) + " W";            //getState(id.replace("totalNow","power")).val + " W"     ;    // log (val4)       //.substring(0,4)        
                                                var val2_1=getState(id.replace("totalNow","current")).val.toString();
                                                if(valVersion=="1.0")  {val2=val2_1.substr(0, 5) + " mA";} else {val2=val2_1+ " mA";}  
                                                var val3_1=getState(id.replace("totalNow","voltage")).val.toString();
                                                val3=val3_1.substring(0, 3)+" V";
                                                var val5_1= getState(id.replace("totalNow","state")).val;
                                                val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";
                                                val6=getState(id).val + " kWh";
                                                val7=getState(id.replace("totalNow","totalMonthNow")).val+ " kWh";
                                                val8=(parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=(parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                              //  log(val1.toString()) 
                                      
                                                if (!val1) {
                                                   // log("false")
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0 ;
                                                    val8=(" <font color=\"red\"> ")+val8;
                                                    val9=(" <font color=\"red\"> ")+val9}
                                                else{
                                                   // log("true")
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                            if (gesamt) {  
                                            gesamtNow=gesamtNow+parseFloat(getState(id).val);
                                            gesamtMonth=gesamtMonth+parseFloat(getState(id.replace("totalNow","totalMonthNow")).val);
                                            gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState(id).val)*kwhPreis;
                                            gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis;
                                            }
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          
                                         }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      
                                       if (homematic){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Homematic</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                       $('hm-rpc.*.*.*.ENERGY_COUNTER').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                         
                                      var ida = id.split('.');
                                                   var arrFilt=[];
                                                 
                                                $(ida[0]+"."+ida[1]+"."+ida[2]+"."+ida[3]+".*").each(function(id, i) {   // kontrolliere ob OPERATING_VOLTAGE vorhanden
                                                    var idc = id.split('.');
                                                 arrFilt.push(idc[4])
                                                 });
                                      
                                                 //log(arrFilt.toString())
                                      
                                            //  log (id)
                                      
                                      
                                              if (arrFilt.includes("VOLTAGE")&& arrFilt.includes("POWER") && arrFilt.includes("CURRENT")) {
                                      
                                               anzahl++;
                                              
                                                var stateIdHM=ida[3].toString(); //log(stateIdHM+" -- " +id)
                                                counter++; 
                                            //   var valVersion=getState(id.replace("totalNow","hw_ver")).val;  
                                                 
                                                 
                                              
                                                val1=!getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"0"+".UNREACH").val   //getState(id.replace("ENERGY_COUNTER","STATE")).val;                  
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;  //val0=getObject(id).common.name ;
                                                val4=getState(id.replace("ENERGY_COUNTER","POWER")).val+ " W"     ;     //log (val4)       //.substring(0,4)        
                                                if (arrFilt.includes("CURRENT")) {val2=getState(id.replace("ENERGY_COUNTER","CURRENT")).val.toFixed(0)+ " mA";} else {val2="-"} 
                                                if (arrFilt.includes("VOLTAGE")) {val3=getState(id.replace("ENERGY_COUNTER","VOLTAGE")).val.toFixed(0)+" V";}  else {val3="-"} 
                                               // log(stateIdHM+" -- " +ida[0]+"."+ida[1]+"."+ida[2]+"."+ida[3])
                                                if (stateIdHM=="6") {
                                                   // log("stateIdHM: "+getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"2"+".STATE").val);
                                                    var val5_1=getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"2"+".STATE").val;
                                                     if(val5_1) { val5=(" <font color=\"lightgreen\"> ")+"ON"} else { val5=(" <font color=\"red\"> ")+"OFF";}}
                                                      else { //val5="-"} 
                                                           
                                                           if (stateIdHM.match("2")) {var val5_1=getState(ida[0]+"."+ida[1]+"."+ida[2]+"."+"1"+".STATE").val ; val5_1 ? val5=(" <font color=\"lightgreen\"> ")+"ON" : val5=(" <font color=\"red\"> ")+"OFF";} else {val5="-"}} 
                                      
                                                val6=" - "; // getState(id).val.substring(0,5)+ " kWh";
                                                val7=" - "; // getState(id.replace("totalNow","totalMonthNow")).val.substring(0,5)+ " kWh";
                                                val8=" - "; // (parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=" - "; // (parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                      
                                                 //  log ( arrSouAna.indexOf(id.replace(/\./g,"__")).toString()+" id : " +id + " replace : " + id.replace(/\./g,"__")+" nochmal replace: "+id.replace("ENERGY_COUNTER","POWER")) 
                                                       let idhlp=id.replace(/\./g,"__"); idhlp=idhlp.replace("ENERGY_COUNTER","POWER")
                                                       if (sourceAnalyHM  && arrSouAna.indexOf(idhlp)>-1) {   
                                                             let  myId=id.replace(/\./g,"__"); myId=myId.replace("ENERGY_COUNTER","POWER")
                                                             val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €"
                                                             val9=(getState("sourceanalytix.0." + myId+".cost.03_current_month").val)+" €"
                                                             val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                             val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                            if (gesamt) {                  
                                                           gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                }}
                                      
                                                if(!val1) {
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0;
                                                    val8=(" <font color=\"red\"> ")+" --- ";
                                                    val9=(" <font color=\"red\"> ")+" --- ";}
                                                else{
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                      
                                      
                                               
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          
                                         }  }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      
                                       if (tuya){
                                      
                                                   // UNTERTEILUNG - ÜBERSCHRIFT IN TABELLE
                                            tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Tuya</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";val4="";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                      
                                      //sonoff.0.SonoffPow1.INFO.Module
                                       $('tuya.*.*').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
                                        //  var arrFilt=[];
                                          var ida = id.split('.');
                                        //   var idb;
                                          var checker=false;
                                          var checkCur=false;
                                          var checkVol=false;
                                          var checkPow=false;
                                          var checkOnline=false;
                                          var val5_1=false;  var val5_2=false;
                                        
                                          //log(getObject(id).common.name)
                                         if (getObject(id).common.name == "cur_power")  {checkCur=true; val4=getState(id).val.toString()+" W"; // log(val4.toString())
                                                  // log(id)       
                                                 
                                                $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {   
                                                    if (getObject(id).common.name == "cur_voltage")  {checkVol=true; val3=getState(id).val.toString()+" V"; }//log(val3.toString())}
                                                  });
                                             
                                                $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {  
                                                     if (getObject(id).common.name == "cur_current")  {checkPow=true; val2=getState(id).val.toString()+" mA"; }//log(val2.toString())}
                                                     }); 
                                                  
                                               $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {   
                                                      if (getObject(id).common.name.includes("online"))  {checkOnline=true; val1=getState(id).val; }//log(val1.toString())}
                                                    
                                                     });  
                                      
                                                     val5_2=false;
                                                $(ida[0]+"."+ida[1]+"."+ida[2]+".*").each(function(id, i) {   
                                                      if (getObject(id).common.name ==("power"))  { val5_2=true; val5_1=getState(id).val; }//log(val5_1.toString())}
                                                    
                                                     });  
                                                    }
                                      
                                        // if (getObject(id.replace("cur_current","cur_voltage")).common.name == "cur_voltage")  {checkVol=true}
                                        // if (getObject(id.replace("cur_current","cur_power")).common.name == "cur_power")    {checkPow=true}
                                         
                                         if (checkCur && checkPow && checkVol && checkOnline) checker=true;
                                        // log(checkCur.toString() + checkVol.toString()+ checkPow.toString())///if (getObject(id).common.name == "cur_voltage") {}
                                         ///if (getObject(id).common.name == "cur_power") {}
                                      
                                         if (checker) {
                                      
                                      
                                      
                                              //log (id)
                                               anzahl++;
                                              
                                                var stateIdHM=ida[3]; //log(stateIdHM)
                                                counter++; 
                                            //   var valVersion=getState(id.replace("totalNow","hw_ver")).val;  
                                                 
                                                 
                                              
                                              //  val1=getState(ida[0]+"."+ida[1]+"."+ida[2]+".cur_current").val   //getState(id.replace("ENERGY_COUNTER","STATE")).val;                  
                                                val0=getObject(ida[0]+"."+ida[1]+"."+ida[2]).common.name ;  //val0=getObject(id).common.name ;
                                               if(val5_2) {if (val5_1)  {val5=(" <font color=\"lightgreen\"> ")+"ON"} else { val5=(" <font color=\"red\"> ")+"OFF";}}
                                                  else {if (val1) {val5=" - "} else { val5=(" <font color=\"red\"> ")+" - ";}} 
                                      
                                             
                                                val6=" - "; // getState(id).val.substring(0,5)+ " kWh";
                                                val7=" - "; // getState(id.replace("totalNow","totalMonthNow")).val.substring(0,5)+ " kWh";
                                                val8=" - "; // (parseFloat(getState(id).val)*kwhPreis).toFixed(2)+" €";
                                                val9=" - "; // (parseFloat(getState(id.replace("totalNow","totalMonthNow")).val)*kwhPreis).toFixed(2)+" €";
                                            
                                                     let idhlp=id.replace(/\./g,"__"); // log (idhlp + " --- "+ ida[2]); log(arrSouAna.toString())
                                                       if (sourceAnalyTuya  && arrSouAnaAll.indexOf(idhlp)>-1) {  
                                                   let    myId=id.replace(/\./g,"__")
                                                  
                                                          val8=getState("sourceanalytix.0." + myId+".cost.01_current_day").val+" €";
                                                          val9=getState("sourceanalytix.0." + myId+".cost.03_current_month").val+" €";
                                                          val7=getState("sourceanalytix.0." + myId+".consumption.03_current_month").val+" kWh";   
                                                          val6=getState("sourceanalytix.0." + myId+".consumption.01_current_day").val+" kWh" ;
                                                                if (gesamt) {           
                                                           gesamtNow=gesamtNow+parseFloat(getState("sourceanalytix.0." + myId+".consumption.01_current_day").val);
                                                           gesamtMonth=gesamtMonth+parseFloat(getState("sourceanalytix.0." + myId+".consumption.03_current_month").val);
                                                           gesamtMoneyTod=gesamtMoneyTod+parseFloat(getState("sourceanalytix.0." + myId+".cost.01_current_day").val);
                                                           gesamtMoneyMon=gesamtMoneyMon+parseFloat(getState("sourceanalytix.0." + myId+".cost.03_current_month").val);
                                                }}
                                                
                                                if(!val1) {
                                                    val1=symbolKO;
                                                    val4=(" <font color=\"red\"> ")+" --- ";
                                                    val2=(" <font color=\"red\"> ")+" --- ";
                                                    val3=(" <font color=\"red\"> ")+" --- ";
                                                    val5=(" <font color=\"red\"> ")+" --- ";
                                                    val6=(" <font color=\"red\"> ")+" --- ";
                                                    val7=(" <font color=\"red\"> ")+" --- ";
                                                    val0=(" <font color=\"red\"> ")+val0;
                                                    val8=(" <font color=\"red\"> ")+" --- ";
                                                    val9=(" <font color=\"red\"> ")+" --- ";}
                                                else{
                                                    val1=symbolOK;
                                                   // val1=(" <font color=\"lightgreen\"> ")+val1
                                                   // val2=(" <font color=\"green\"> ")+val2
                                                   // val3=(" <font color=\"green\"> ")+val3
                                                   // val0=(" <font color=\"green\"> ")+val0
                                                   }
                                      
                                      
                                               
                                         
                                           tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                          
                                        } }); //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!  
                                      } //ende fritzdect
                                      if (gesamt){
                                             tabelleAusbessern();
                                            counter=0;
                                            val0=""; val1=""; val2="";val3="";val4="";val5="";val6="";val7="";val8="";val9="";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=0;
                                            val0="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">GESAMT</"+HTMLbrandSetting+">"; val1=""; val2="";val3="";
                                            val4="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Anzahl<"+HTMLbrandSetting+">";
                                            val5="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Update<"+HTMLbrandSetting+">";
                                            val6="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Now<"+HTMLbrandSetting+">";
                                            val7="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">kWh Monat<"+HTMLbrandSetting+">";
                                            val8="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Now<"+HTMLbrandSetting+">";
                                            val9="<font color=\""+htmlColorDeviceUeberschrift+"\"><"+HTMLbrandSetting+">Preis Monat<"+HTMLbrandSetting+">";
                                            tabelleBind(); //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                            tabelleAusbessern();
                                            counter=-1
                                            val0="alle Geräte";
                                            val1=" - "; 
                                            val2=" - ";
                                            val3=" - ";
                                            val4=anzahl.toString();
                                            if (virtualPower && !virtualPowerGesamt)   val4=anzahl.toString();
                                            if (!virtualPower && virtualPowerGesamt)   val4=anzahl.toString()+"++";
                                            if (virtualPower && virtualPowerGesamt)   val4=(anzahl-1).toString();
                                            val5=formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");;
                                          //  log(typeof gesamtNow +"wert "+gesamtNow )
                                            val6=(gesamtNow.toFixed(3)+"kWh");
                                            val7=(gesamtMonth.toFixed(3)+"kWh");
                                            val8=(gesamtMoneyTod.toFixed(2)+"€");
                                            val9=(gesamtMoneyMon.toFixed(2)+"€");
                                             tabelleBind();
                                      
                                      
                                      }
                                      //-------------------------------------------------------------------------------------------------------------------------------------------------
                                      //--------------------------------------------------Ende der schleife------------------------------------------------------------------------------
                                      //-------------------------------------------------------------------------------------------------------------------------------------------------
                                      
                                            tabelleFinish(); // AB HIER NICHTS ÄNDERN - tabelle fertigstellen
                                          // log(anzahl.toString());
                                            
                                           
                                            if (virtualPower && virtualPowerGesamt)   anzahl=anzahl-1;
                                                setState(dpAnzahl,anzahl); 
                                      } // function ende
                                      
                                      //MAIN:
                                       
                                      schedule(mySchedule,  function () {
                                       writeHTML();
                                       if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/  });}
                                      }); 
                                       writeHTML();
                                      
                                         				 function tabelleBind(){
                                           //HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT - hat man oben 5 Felder definiert, braucht man hier 5 Werte
                                         
                                             switch (mehrfachTabelle) {  
                                               case 1:                    htmlOut=htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>"; break;
                                              case 2:  if(counter%2==0)  {htmlOut = htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>"; } 
                                                                    else {htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>";} break;
                                                                         
                                              case 3: if(counter%3==0 )  {htmlOut = htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>"; } 
                                                                    else { if(counter%3==1 )  { htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>";} 
                                                                                     else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>";}
                                                                               } break;
                                      
                                      
                                              case 4: if(counter%4==0)  {htmlOut = htmlOut+"<tr><td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>"; } 
                                                                        else {if(counter%2==1 )  { htmlOut = htmlOut+"<td  align="+Feld1lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>";} 
                                                                                     else    {if(counter%2==1 && counter%4==3)  { htmlOut= htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val0+"&ensp;</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val1+"&ensp;</td><td align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val2+"&ensp;</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">&ensp;"+val3+"&ensp;</td><td align="+Feld5lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td></tr>";} 
                                                                                                       else    {htmlOut = htmlOut = htmlOut+"<td align="+Feld1lAlign+" >&ensp;"+val0+"&ensp;</td><td>&ensp;"+val1+"&ensp;</td><td align="+Feld2lAlign+">&ensp;"+val2+"&ensp;</td><td align="+Feld3lAlign+">&ensp;"+val3+"&ensp;</td><td align="+Feld4lAlign+">&ensp;"+val4+"&ensp;</td><td align="+Feld6lAlign+">&ensp;"+val5+"&ensp;</td><td align="+Feld7lAlign+">&ensp;"+val6+"&ensp;</td><td align="+Feld8lAlign+">&ensp;"+val7+"&ensp;</td><td align="+Feld9lAlign+">&ensp;"+val8+"&ensp;</td><td align="+Feld10lAlign+">&ensp;"+val9+"&ensp;</td>";}}
                                                                               } break;
                                      
                                           } //switch ende
                                      
                                      
                                      
                                      }
                                      
                                      
                                      function tabelleAusbessern() {
                                             switch (mehrfachTabelle) {  
                                               case 1:    break;
                                               case 2:    mix=Math.abs(((counter+1)%2)-mehrfachTabelle);  
                                                          if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                          break;
                                               case 3:    mix =Math.abs(((counter+1)%3)-mehrfachTabelle);
                                                          if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                          if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');   
                                                          break;
                                               case 4:    mix=Math.abs(((counter+1)%4)-mehrfachTabelle);
                                                          if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');
                                                          if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');    
                                                          if(mix==3)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');      
                                                          break; }
                                      }
                                      
                                      function tabelleFinish() {
                                      
                                            // tabelle fertigstellen
                                             switch (mehrfachTabelle) {  
                                               case 1:    break;
                                               case 2:    mix=Math.abs(((counter+1)%2)-mehrfachTabelle);  
                                                          if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                          break;
                                               case 3:    mix =Math.abs(((counter+1)%3)-mehrfachTabelle);
                                                          if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');       
                                                          if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');   
                                                          break;
                                               case 4:    mix=Math.abs(((counter+1)%4)-mehrfachTabelle);
                                                          if(mix==1)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');
                                                          if(mix==2)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');    
                                                          if(mix==3)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');      
                                                          break; }
                                           
                                                          var htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: "+htmlÜberFontGroesse+"; font-weight:"+htmlSchriftWeite+ "\">"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</p>"; 
                                             var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 70%; text-align: right;\" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</div>"
                                              
                                              if (!htmlSignature) htmlUnter="";
                                                //Ausgabe über VIS html widget - tabelle in datenpunkt schreiben - html tabelle ohne html header und body
                                                 var htmlOutVIS="";
                                               //  htmlUberschrift ? htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>" : htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>";
                                                  if (htmlUberschrift) 
                                                      { zentriert ? htmlOutVIS=htmlZentriert+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter : htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter ;
                                      
                                                    } else {
                                                     zentriert ?  htmlOutVIS=htmlZentriert+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter :  htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter;
                                      
                                                       }
                                      
                                      // log("bin raus aus tabelleBind");
                                                 if (braucheEinVISWidget) setState(dpVIS, htmlOutVIS );
                                      
                                       var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 80%;  text-align: center; \" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</div>"
                                       var htmlEnd="</table>"+htmlUnter+"</div></body>";
                                       if (!htmlSignature) htmlUnter="";
                                      
                                       //mit oder ohne überschrift - zentriert oder links
                                      htmlUberschrift ? htmlOut=htmlStart+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd : htmlOut=htmlStart+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd;
                                       //log(htmlOut);
                                       
                                      
                                      
                                      }
                                      
                                      
                                      
                                      

                                      sigi234S Online
                                      sigi234S Online
                                      sigi234
                                      Forum Testing Most Active
                                      schrieb am zuletzt editiert von
                                      #63

                                      @liv-in-sky

                                      
                                      javascript.0	2020-01-24 14:33:51.560	error	(9700) at Script.runInContext (vm.js:133:20)
                                      javascript.0	2020-01-24 14:33:51.560	error	(9700) at script.js.Listen.Energy_Devices1:1343:2
                                      javascript.0	2020-01-24 14:33:51.560	error	(9700) at writeHTML (script.js.Listen.Energy_Devices1:302:148)
                                      javascript.0	2020-01-24 14:33:51.560	error	(9700) TypeError: Cannot read property 'toString' of null
                                      javascript.0	2020-01-24 14:33:51.560	error	(9700) ^
                                      javascript.0	2020-01-24 14:33:51.560	error	(9700) val6=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val).toString(); //=getState(id).val + " kWh";
                                      javascript.0	2020-01-24 14:33:51.560	error	(9700) script.js.Listen.Energy_Devices1: script.js.Listen.Energy_Devices1:302
                                      javascript.0	2020-01-24 14:33:51.559	warn	(9700) at script.js.Listen.Energy_Devices1:1343:2
                                      javascript.0	2020-01-24 14:33:51.559	warn	(9700) at writeHTML (script.js.Listen.Energy_Devices1:302:17)
                                      javascript.0	2020-01-24 14:33:51.559	warn	(9700) getState "sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day" not found (3)
                                      javascript.0	2020-01-24 14:33:51.539	info	(9700) Start javascript script.js.Listen.Energy_Devices1
                                      

                                      Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                      Immer Daten sichern!

                                      ? liv-in-skyL 2 Antworten Letzte Antwort
                                      0
                                      • sigi234S sigi234

                                        @liv-in-sky

                                        
                                        javascript.0	2020-01-24 14:33:51.560	error	(9700) at Script.runInContext (vm.js:133:20)
                                        javascript.0	2020-01-24 14:33:51.560	error	(9700) at script.js.Listen.Energy_Devices1:1343:2
                                        javascript.0	2020-01-24 14:33:51.560	error	(9700) at writeHTML (script.js.Listen.Energy_Devices1:302:148)
                                        javascript.0	2020-01-24 14:33:51.560	error	(9700) TypeError: Cannot read property 'toString' of null
                                        javascript.0	2020-01-24 14:33:51.560	error	(9700) ^
                                        javascript.0	2020-01-24 14:33:51.560	error	(9700) val6=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val).toString(); //=getState(id).val + " kWh";
                                        javascript.0	2020-01-24 14:33:51.560	error	(9700) script.js.Listen.Energy_Devices1: script.js.Listen.Energy_Devices1:302
                                        javascript.0	2020-01-24 14:33:51.559	warn	(9700) at script.js.Listen.Energy_Devices1:1343:2
                                        javascript.0	2020-01-24 14:33:51.559	warn	(9700) at writeHTML (script.js.Listen.Energy_Devices1:302:17)
                                        javascript.0	2020-01-24 14:33:51.559	warn	(9700) getState "sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day" not found (3)
                                        javascript.0	2020-01-24 14:33:51.539	info	(9700) Start javascript script.js.Listen.Energy_Devices1
                                        
                                        ? Offline
                                        ? Offline
                                        Ein ehemaliger Benutzer
                                        schrieb am zuletzt editiert von
                                        #64

                                        @sigi234

                                        Sehr. Hier mein Einstellungen. Ich habe für jeden meiner Gerätegruppe auch den SourceAnalytix aktiviert, um so an die Monatssumme zu kommen

                                        Bildschirmfoto 2020-01-24 um 14.41.16.JPG

                                        24.1.2020, 14:40:20.320	[info ]: javascript.0 (4044) Stop script script.js.Stromgeräte_Tabelle
                                        24.1.2020, 14:40:20.347	[info ]: javascript.0 (4044) Start javascript script.js.Stromgeräte_Tabelle
                                        24.1.2020, 14:40:20.388	[warn ]: javascript.0 (4044)     at writeHTML (script.js.Stromgeräte_Tabelle:302:17)
                                        24.1.2020, 14:40:20.388	[warn ]: javascript.0 (4044)     at script.js.Stromgeräte_Tabelle:1343:2
                                        24.1.2020, 14:40:20.390	[error]: javascript.0 (4044) script.js.Stromgeräte_Tabelle: script.js.Stromgeräte_Tabelle:302
                                        24.1.2020, 14:40:20.391	[error]: javascript.0 (4044)     at writeHTML (script.js.Stromgeräte_Tabelle:302:148)
                                        24.1.2020, 14:40:20.391	[error]: javascript.0 (4044)     at script.js.Stromgeräte_Tabelle:1343:2
                                        24.1.2020, 14:40:40.504	[info ]: javascript.0 (4044) Stop script script.js.Stromgeräte_Tabelle
                                        
                                        liv-in-skyL 1 Antwort Letzte Antwort
                                        0
                                        • sigi234S sigi234

                                          @liv-in-sky

                                          
                                          javascript.0	2020-01-24 14:33:51.560	error	(9700) at Script.runInContext (vm.js:133:20)
                                          javascript.0	2020-01-24 14:33:51.560	error	(9700) at script.js.Listen.Energy_Devices1:1343:2
                                          javascript.0	2020-01-24 14:33:51.560	error	(9700) at writeHTML (script.js.Listen.Energy_Devices1:302:148)
                                          javascript.0	2020-01-24 14:33:51.560	error	(9700) TypeError: Cannot read property 'toString' of null
                                          javascript.0	2020-01-24 14:33:51.560	error	(9700) ^
                                          javascript.0	2020-01-24 14:33:51.560	error	(9700) val6=(getState("sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day").val).toString(); //=getState(id).val + " kWh";
                                          javascript.0	2020-01-24 14:33:51.560	error	(9700) script.js.Listen.Energy_Devices1: script.js.Listen.Energy_Devices1:302
                                          javascript.0	2020-01-24 14:33:51.559	warn	(9700) at script.js.Listen.Energy_Devices1:1343:2
                                          javascript.0	2020-01-24 14:33:51.559	warn	(9700) at writeHTML (script.js.Listen.Energy_Devices1:302:17)
                                          javascript.0	2020-01-24 14:33:51.559	warn	(9700) getState "sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day" not found (3)
                                          javascript.0	2020-01-24 14:33:51.539	info	(9700) Start javascript script.js.Listen.Energy_Devices1
                                          
                                          liv-in-skyL Offline
                                          liv-in-skyL Offline
                                          liv-in-sky
                                          schrieb am zuletzt editiert von liv-in-sky
                                          #65

                                          @sigi234 sagte in Energieanzeige (kWh) über HTML Tabelle - vis:

                                          existiert dieser datenpunkt

                                          sourceanalytix.0.virtualpowermeter__0__group_script__Virtual_Energy_Total_group_script.consumption.01_current_day
                                          

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

                                          sigi234S 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          464

                                          Online

                                          32.5k

                                          Benutzer

                                          81.6k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe