Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. ioBroker Allgemein
  4. gelöst: wie vorgehen JavaScript Update viele Script Fehler

NEWS

  • Neues YouTube-Video: Visualisierung im Devices-Adapter
    BluefoxB
    Bluefox
    13
    1
    602

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    2.0k

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    11
    1
    878

gelöst: wie vorgehen JavaScript Update viele Script Fehler

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
16 Beiträge 3 Kommentatoren 951 Aufrufe 2 Beobachtet
  • Ä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.
  • R Rosi8818

    Ich möchte von JavaScript 5.1.3 auf 5.2.13 updaten. Hatte es auch versucht und bin wieder zurückgegangen.
    Warum, ich hatte in fast allen Scripten Fehler ohne Ende und kam nicht weiter. Einige konnte ich selber lösen aber nicht alle.

    Ich möchte das jetzt Stück für Stück angehen, wie gehe ich am besten vor?
    Script Engine auf Debug, updaten über die Oberfläche und dann jedes einzelne Script angehen mit Hilfe aus dem Forum?
    Die meisten Scripte sind hier im Forum mit Hilfe entstanden oder waren schon fertig und sind von mir angepasst worden.
    Diese liefen mit 5.1.3 ohne Fehler.

    Ich bin nicht der Experte (auch wenn die Ansicht auf Experte steht!), benötige also vermutlich bei den Scripten Schützenhilfe und möchte falls nötig alle wichtigen Informationen vorliegen haben.

    Thomas BraunT Online
    Thomas BraunT Online
    Thomas Braun
    Most Active
    schrieb am zuletzt editiert von Thomas Braun
    #2

    @rosi8818

    Welche Fehler waren es denn?
    Ich vermute, dass die alle aus einer ähnlichen Ecke kommen.

    Linux-Werkzeugkasten:
    https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
    NodeJS Fixer Skript:
    https://forum.iobroker.net/topic/68035/iob-node-fix-skript
    iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

    R 1 Antwort Letzte Antwort
    0
    • Thomas BraunT Thomas Braun

      @rosi8818

      Welche Fehler waren es denn?
      Ich vermute, dass die alle aus einer ähnlichen Ecke kommen.

      R Offline
      R Offline
      Rosi8818
      schrieb am zuletzt editiert von Rosi8818
      #3

      @thomas-braun meist gin es um falsche Datentypen o wie ich das gesehen hatte. Ich habe bei der Menge der Logeinträge alles gelöscht (über die Oberfläche, auf dem Server müssten sie noch sein) und würde jetzt quasi neu starten mit dem update und dann gezielt die Dinge raussuchen.
      Ja du hast Recht, es sah aus als wenn alle das gleiche Problem hatten.

      Thomas BraunT 1 Antwort Letzte Antwort
      0
      • R Rosi8818

        @thomas-braun meist gin es um falsche Datentypen o wie ich das gesehen hatte. Ich habe bei der Menge der Logeinträge alles gelöscht (über die Oberfläche, auf dem Server müssten sie noch sein) und würde jetzt quasi neu starten mit dem update und dann gezielt die Dinge raussuchen.
        Ja du hast Recht, es sah aus als wenn alle das gleiche Problem hatten.

        Thomas BraunT Online
        Thomas BraunT Online
        Thomas Braun
        Most Active
        schrieb am zuletzt editiert von
        #4

        @rosi8818

        Ich würde den Adapter wieder hochziehen und dann die Dinge peu a peu angehen. Vermutlich sind das auch überwiegend keine Fehler sondern nur Hinweise.

        Linux-Werkzeugkasten:
        https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
        NodeJS Fixer Skript:
        https://forum.iobroker.net/topic/68035/iob-node-fix-skript
        iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

        R 1 Antwort Letzte Antwort
        0
        • Thomas BraunT Thomas Braun

          @rosi8818

          Ich würde den Adapter wieder hochziehen und dann die Dinge peu a peu angehen. Vermutlich sind das auch überwiegend keine Fehler sondern nur Hinweise.

          R Offline
          R Offline
          Rosi8818
          schrieb am zuletzt editiert von
          #5

          @thomas-braun okay, den Adapter auf Debug stellen oder so lassen, was ist besser?
          Im Scriptfenster waren auf jeden Fall alle Meldungen rot

          Thomas BraunT 1 Antwort Letzte Antwort
          0
          • R Rosi8818

            @thomas-braun okay, den Adapter auf Debug stellen oder so lassen, was ist besser?
            Im Scriptfenster waren auf jeden Fall alle Meldungen rot

            Thomas BraunT Online
            Thomas BraunT Online
            Thomas Braun
            Most Active
            schrieb am zuletzt editiert von
            #6

            @rosi8818
            Auf debug wirst du wohl erschlagen mit Meldungen. Also zuerst mal auf Error setzen und die dann erledigen und dann das loglevel wieder auf Info drehen.

            Linux-Werkzeugkasten:
            https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
            NodeJS Fixer Skript:
            https://forum.iobroker.net/topic/68035/iob-node-fix-skript
            iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

            R 1 Antwort Letzte Antwort
            0
            • Thomas BraunT Thomas Braun

              @rosi8818
              Auf debug wirst du wohl erschlagen mit Meldungen. Also zuerst mal auf Error setzen und die dann erledigen und dann das loglevel wieder auf Info drehen.

              R Offline
              R Offline
              Rosi8818
              schrieb am zuletzt editiert von
              #7

              @thomas-braun okay, dann werde ich jetzt erstmal sichern und dann langsam loslegen. Danke

              R 1 Antwort Letzte Antwort
              0
              • R Rosi8818

                @thomas-braun okay, dann werde ich jetzt erstmal sichern und dann langsam loslegen. Danke

                R Offline
                R Offline
                Rosi8818
                schrieb am zuletzt editiert von
                #8

                so habe jetzt das Update JavaScript auf 5.2.13 durchgeführt, jetzt kommen die Fehler unten, wo und wie kann ich jetzt ansetzen?

                im Logfile auf ERROR

                javascript.0	2021-12-14 11:39:27.697	error	(4641) at Script.runInContext (vm.js:144:12)
                javascript.0	2021-12-14 11:39:27.696	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:724:3
                javascript.0	2021-12-14 11:39:27.696	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:552:2
                javascript.0	2021-12-14 11:39:27.695	error	(4641) at writeHTML (script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:233:24)
                javascript.0	2021-12-14 11:39:27.694	error	(4641) at JSON.parse (<anonymous>)
                javascript.0	2021-12-14 11:39:27.694	error	(4641) script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben: SyntaxError: Unexpected token o in JSON at position 1
                javascript.0	2021-12-14 11:39:26.981	error	(4641) at Script.runInContext (vm.js:144:12)
                javascript.0	2021-12-14 11:39:26.980	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:724:3
                javascript.0	2021-12-14 11:39:26.980	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:552:2
                javascript.0	2021-12-14 11:39:26.979	error	(4641) at writeHTML (script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:233:24)
                javascript.0	2021-12-14 11:39:26.978	error	(4641) at JSON.parse (<anonymous>)
                javascript.0	2021-12-14 11:39:26.969	error	(4641) script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben: SyntaxError: Unexpected token o in JSON at position 1
                

                im Scriptfenster nach neustarten des Scripts

                11:40:48.986	error	javascript.0 (4641) script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben: SyntaxError: Unexpected token o in JSON at position 1
                11:40:48.988	error	javascript.0 (4641) at writeHTML (script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:233:24)
                11:40:48.989	error	javascript.0 (4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:552:2
                11:40:48.989	error	javascript.0 (4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:724:3
                
                Thomas BraunT 1 Antwort Letzte Antwort
                0
                • R Rosi8818

                  so habe jetzt das Update JavaScript auf 5.2.13 durchgeführt, jetzt kommen die Fehler unten, wo und wie kann ich jetzt ansetzen?

                  im Logfile auf ERROR

                  javascript.0	2021-12-14 11:39:27.697	error	(4641) at Script.runInContext (vm.js:144:12)
                  javascript.0	2021-12-14 11:39:27.696	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:724:3
                  javascript.0	2021-12-14 11:39:27.696	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:552:2
                  javascript.0	2021-12-14 11:39:27.695	error	(4641) at writeHTML (script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:233:24)
                  javascript.0	2021-12-14 11:39:27.694	error	(4641) at JSON.parse (<anonymous>)
                  javascript.0	2021-12-14 11:39:27.694	error	(4641) script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben: SyntaxError: Unexpected token o in JSON at position 1
                  javascript.0	2021-12-14 11:39:26.981	error	(4641) at Script.runInContext (vm.js:144:12)
                  javascript.0	2021-12-14 11:39:26.980	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:724:3
                  javascript.0	2021-12-14 11:39:26.980	error	(4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:552:2
                  javascript.0	2021-12-14 11:39:26.979	error	(4641) at writeHTML (script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:233:24)
                  javascript.0	2021-12-14 11:39:26.978	error	(4641) at JSON.parse (<anonymous>)
                  javascript.0	2021-12-14 11:39:26.969	error	(4641) script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben: SyntaxError: Unexpected token o in JSON at position 1
                  

                  im Scriptfenster nach neustarten des Scripts

                  11:40:48.986	error	javascript.0 (4641) script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben: SyntaxError: Unexpected token o in JSON at position 1
                  11:40:48.988	error	javascript.0 (4641) at writeHTML (script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:233:24)
                  11:40:48.989	error	javascript.0 (4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:552:2
                  11:40:48.989	error	javascript.0 (4641) at script.js.VIS.kalender.Kalenderaufbereitungen-mit_vielen_Sonderfarben:724:3
                  
                  Thomas BraunT Online
                  Thomas BraunT Online
                  Thomas Braun
                  Most Active
                  schrieb am zuletzt editiert von
                  #9

                  @rosi8818 sagte in wie vorgehen JavaScript Update mit vielen Script Fehlern:

                  Kalenderaufbereitungen-mit_vielen_Sonderfarben

                  Was steht denn da drin?

                  Linux-Werkzeugkasten:
                  https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                  NodeJS Fixer Skript:
                  https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                  iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                  R 1 Antwort Letzte Antwort
                  1
                  • Thomas BraunT Thomas Braun

                    @rosi8818 sagte in wie vorgehen JavaScript Update mit vielen Script Fehlern:

                    Kalenderaufbereitungen-mit_vielen_Sonderfarben

                    Was steht denn da drin?

                    R Offline
                    R Offline
                    Rosi8818
                    schrieb am zuletzt editiert von
                    #10

                    @thomas-braun hier das Script (ich hoffe sind keine Daten drin die keiner sehen soll) ;)

                     /*@liv-in-sky 2020  29.1.2021 12:18
                      genutzt für Material-Design -> let weiter unten
                    
                     *** HauptScript löst Kalenderaufbereitungen ab ***
                    
                     für das Widgets der wichtigsten Ereignisse in der VIS
                     mit Blacklist und Sonderfarbe
                    
                     --> 0_userdata.0.Tabellen.ical.
                    
                     */
                    //HIER WIRD PFAD UND FILENAME DEFINIERT
                    const path = "/htmlexample.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="0_userdata.0.Tabellen.ical.Termine";         //WICHTIG wenn "braucheEinVISWidget" auf true gesetzt !!  dp zusätzlich für VIS-HTML-Basic-Widget
                    //let dpTSJson=["ical.0.data.table","ical.1.data.table"];                        //mehrere Instanzen zusammenfügen
                    let dpTSJson=["ical.0.data.table","ical.1.data.table","ical.2.data.table","ical.3.data.table",];
                    let dpTSJsonCalName=["Rosemeyer","nächste Kalender"];                        //mehrere Instanzen zusammenfügen
                    let   braucheMaterialDesignWidgetTable=true;        // bei true wird ein json in einen dp geschrieben - MUSS ANGELEGT WERDEN !!!
                    let dpMaterialWidgetTable="0_userdata.0.Tabellen.ical.MaterialWidgetTable";  // WICHTIG wenn braucheMaterialDesignWidgetTable auf true MATERIALDESIGN Table Widget - datenpunkt anlegen: zeichenkette 
                     
                    // seting für extra datenpunkte
                    let ichWillDpNextRunning=true;
                    let dpTerminNext="0_userdata.0.Tabellen.ical.TerminNext";                    // WICHTIG wenn ichWillDpNextRunning auf true  - datenpunkt anlegen: zeichenkette
                    let dpTerminRunning="0_userdata.0.Tabellen.ical.TerminRunning";               // WICHTIG wenn ichWillDpNextRunning auf true - datenpunkt anlegen: zeichenkette  
                    let dpTerminNextGanzerTag="0_userdata.0.Tabellen.ical.TerminNextGanzerTag";   // WICHTIG wenn ichWillDpNextRunning auf true  - datenpunkt anlegen: zeichenkette 
                     
                     let wievielTage=50
                     let styleEinTagHTML="span"                                  // style der zeile wenn unter einem tag:  möglich b fett; i kursiv; span normal
                                                                                // Original span - zeigt mit b die markierten Einträge fett
                     let sortedByInstanz=false;
                     let nurAnfangsZeit=false;
                    let ganzTaegigAusdruck="&RightArrowLeftArrow;";             // "ganztägig" oder "den ganzen Tag" oder &laquo; &RightArrowLeftArrow;
                     let bisVariable="&longmapsto;"                              // wenn gerade läuft - running event zeichen
                     let ersetze0MitWert="0"                                     // z.b. "heute" 
                     let ersetze1MitWert="morgen"                                // z.b "morgen"
                     
                     // regex zum event-text ändern
                     //let myFilterRegexEvent=/Biathlon(: .*)/;                  // Regex für EventAnzeige: event=event.replace(myFilterRegexEvent,myFilterRegexEvent2)
                     //let myFilterRegexEvent2="Biat$1";                         // z.b. Geburtstag':   myFilterRegexEvent=/(.*) Geburtstag/; myFilterRegexEvent2="$1"
                     
                     let myFilterRegexEvent5=[/Biathlon(: .*)/,/(GELBE)R SACK/];                        // Regex für EventAnzeige: event=event.replace(myFilterRegexEvent,myFilterRegexEvent2)
                     let myFilterRegexEvent6=["Biat$1","$1 Tonne"];                               // z.b. Geburtstag':   myFilterRegexEvent5=[/(.*) Geburtstag/];  let myFilterRegexEvent6=[""$1"]; 
                                                                                             // WICHTIG : gleiche anzahl in den beide Variablen
                     
                     let mySchedule3="  */30 * * * * ";                       //alle 30 minuten //eigentlich unnötig, da das script auf änderung des ical datenpunktes triggert
                      
                     let wiederholAnzeige="true";                                // es werden pfeile am ende des event-eintraägs hinzugefügt, wenn es eine wiederholung ist
                     let myWhiteListArray=[];                                    // momentan ohne [] whitelist sonst z.b ["URLAUB","frei"]  auf großschreibung achten
                     let myBlackListArray=["Simvastatin", "Abfuhr", "Gelber Sack","Biotonne","Papiersammlung","Glassammlung","Hausmüll 2W","Hausmüll 4W"]; // momentan ohne [] blacklist sonst z.b ["Biathlon",Tabletten nehmen]  auf großschreibung achten
                     
                     let mySonderFarbeArr=["Ralf:"];               //  ohne [] termine, die besonders hervorgehoben werden sollen sonst z.b ["Biathlon",Tabletten nehmen] am besten mit sortedByInstanz=false;
                     let mySonderSymbol="&#9055;"+"&ensp;";        //  🔸 🚘 ⚪  ⚫ ⭕  🔴 🔵 🟠 ⏱ 💀 👍 👎 📑 💲 👀   mehr: https://emojiterra.com/de/ oder https://unicode-table.com/de/html-entities/
                                                                   //  (⌾ &#9022;) (🔹 &#128313;) (🍏 &#127823;) 💰 💸 (❗ &#10071;) (⬩ &#11049;) (● &#9679;)  (⍟ &#9734;->Stern) 
                                                                   //  (⌾ &#9055;) (⧇ &#10695;) (🎂 &#127874;) (🟡 &#128993;) (🔵 &#128309;) (🟢 &#128994;) (🔴 &#128308;)
                                                                   //  (ℜ &#8476;) (ℛ &#8475;)
                    let mySonderFarbeArrRiko=["Riko:"];
                    let mySonderSymbolRiko="&#9022;"+"&ensp;"; 
                    
                    let mySonderFarbeArrTUEV=["TÜV:","Steuer"];
                    let mySonderSymbolTUEV="⬩"+"&ensp;"; 
                    
                    let mySonderFarbeArrErnte=["Ernte:"];
                    let mySonderSymbolErnte="&#127823;"+"&ensp;"; 
                    
                    let mySonderFarbeArrArzt=["Arzt:"];
                    let mySonderSymbolArzt="&#9734;"+"&ensp;"; 
                    
                    let mySonderFarbeArrUrlaub=["Urlaub:"];
                    let mySonderSymbolUrlaub="&#128313;"+"&ensp;"; 
                    
                    let mySonderFarbeArrConny=["Conny:"];
                    let mySonderSymbolConny="&#128309;"+"&ensp;"; 
                    
                    let mySonderFarbeArrRebecca=["Rebecca:"];
                    let mySonderSymbolRebecca="&#128993;"+"&ensp;"; 
                    
                    let mySonderFarbeArrGeburtstag=["Geburtstag von"];
                    let mySonderSymbolGeburtstag="&#127874;"+"&ensp;"; 
                    
                    let mySonderFarbeArrWichtig=["WICHTIG:"];
                    let mySonderSymbolWichtig="&#10071;"+"&ensp;"; 
                    
                    // let mySonderFarbeArrUrlaub=["Urlaub:"];
                    // let mySonderSymbolUrlaub="&#9734;"+"&ensp;"; 
                    //---------------------------------------
                     
                    //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 4
                    var htmlFeld1='EVENT';       var Feld1lAlign="left";          // überschrift Tabellen Spalte1 und  Ausrichtung left,right or center
                    var htmlFeld2='ZEIT';        var Feld2lAlign="center";        // überschrift Tabellen Spalte2 und  Ausrichtung left,right or center
                    var htmlFeld3='DATUM';         var Feld3lAlign="center";      // überschrift Tabellen Spalte3 und  Ausrichtung left,right or center
                    var htmlFeld4='WTAG';        var Feld4lAlign="center";        // überschrift Tabellen Spalte4 und  Ausrichtung left,right or center
                    var htmlFeld5='TAGE';        var Feld5lAlign="center";        // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                    //-----------------------------------
                     
                     
                    //ÜBERSCHRIFT ÜBER TABELLE
                    let   htmlUberschrift=false;                // mit Überschrift über der tabelle
                    let   htmlSignature=false;                  // anstatt der Überscghrift eine signature: - kleiner - anliegend
                    const htmlFeldUeber='Ical';                 // Überschrift und Signature
                    const htmlFarbUber="green";                 // Farbe der Überschrift
                    const htmlSchriftWeite="normal";            // bold, normal - Fettschrift für Überschrift
                    const htmlUeberFontGroesse="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 trennungsLinie="2";                   //extra trennungslinie bei mehrfachtabellen - evtl auf 0 stellen, wnn htmlRahmenLinien auf none sind
                    const htmlFarbZweiteTabelle="black";        // Farbe der Überschrift bei jeder 2.ten Tabelle
                    const htmlFarbTableColorUber="black";       // Überschrift in der tabelle - der einzelnen Spalten BDBDBD
                    //ÜBERSCHRIFT SPALTEN
                    const UeberSchriftHoehe=25;                  //Überschrift bekommt mehr Raum - darunter und darüber - Zellenhöhe
                    const LinieUnterUeberschrift="2";           // Linie nur unter Spaltenüberschrift - 
                    const farbetrennungsLinie="white";
                    const farbeLinieUnterUeberschrift="black";
                    const groesseUeberschrift=16;
                    const UeberschriftStyle="normal"            // möglich "bold"
                    //GANZE TABELLE
                    let abstandZelle="3";
                    let farbeUngeradeZeilen="#333333"//"#1C1C1C";        //Farbe für ungerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2
                    let farbeGeradeZeilen="black"//"black";              //Farbe für gerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2
                    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=""     //"Jura-DemiBold"   //"RobotoCondensed-Bold"   //"Helvetica";
                    const htmlSchriftgroesse="16px";
                    //FELDER UND RAHMEN
                    let   UeberschriftSpalten=true;                // ein- oder ausblenden der spatlen-überschriften
                    const htmlFarbFelderschrift="#D8D8D8";                  // SchriftFarbe der Felder
                    const htmlFarbFelderschrift2="#D8D8D8";                 // SchriftFarbe der Felder für jede 2te Tabelle
                    const htmlFarbTableColorGradient1="orange";          //  Gradient - Hintergrund der Tabelle - Verlauffarbe
                    const htmlFarbTableColorGradient2="green";          //  Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
                    const htmlFarbTableBorderColor="transparent";             // 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 height=\""+UeberSchriftHoehe+"\" style=\"color:"+htmlFarbTableColorUber+"; font-size: "+groesseUeberschrift+"px; font-weight: "+UeberschriftStyle+" ;  border-bottom: "+LinieUnterUeberschrift+"px solid "+farbeLinieUnterUeberschrift+" \">";
                    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  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>";
                    var htmlTabUeber2_1="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld1+"&ensp;</td><td  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>";
                                           //------------------------------------------------------
                     
                    //im MD List Widget
                     let farbeNurEinTag="yellow"                               //statusBarColor im MD List Widget wenn nur noch ein tag
                     let farbeStandardBar="#d5d3b4"                            //// nicht benutzt!! statusBarColor im MD List Widget wenn normal
                    //im HTML Widget
                    //let bildergröße=24
                     let farbeEinTagHTML="#CB9529"                             // wird nicht mehr genutzt!!  Farbe der zeile in html tabelle wenn unter einem tag:
                    let   braucheMaterialDesignWidget=false;             // bei true wird ein json in einen dp geschrieben - MUSS ANGELEGT WERDEN !!!
                     
                    let dpMaterialWidget="0_userdata.0.Tabellen.ical.MaterialWidget";    // WICHTIG wenn braucheMaterialDesignWidget auf true MATERIALDESIGN List Widget - datenpunkt anlegen : zeichenkette  
                     
                    var htmlOut="";
                    var mix;
                    var counter;
                    var val1; var val2; var val0; var val3; var val4;
                    var htmlTabUeber="";
                    //var wochentag = ['Sonntag','Montag','Dienstag','Mittwoch','Donnerstag','Freitag','Samstag' ]
                    var myJsonWidget=[]; 
                    var myJsonWidget2=[];
                    var json1; var json2; var json3; var json4; var json44; var json5;
                    let oldID="";
                    let inDpNext="";
                    let inDpRunning=[];
                    let inDpRunning2="";
                    let inDpGanzTag="";
                    let helperTerminNext="";
                    function writeHTML(){
                     
                    oldID="";
                     
                    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!!!------------------------------------------------------------
                    //--------------------------------------------------------------------------------------------------------------------------------------------------
                    let myData=[];
                    let myData2=[];
                    let myData3=[];
                    inDpNext=""
                    inDpRunning=[];
                     inDpRunning2="";
                     
                    inDpGanzTag="";
                     
                    for (let i=0;i<dpTSJson.length;i++) {
                       //20210809 nach Fehler, gelöst aus Forum: vorher let myDpInput=(getState(dpTSJson[i]).val);
                       let myDpInput=(JSON.parse(getState(dpTSJson[i]).val));
                      
                    
                    // hier kann der Kalendername abgefangen werden   - RRO
                    
                         for  (let b=0;b<myDpInput.length;b++) { myDpInput[b].myIDID=dpTSJsonCalName[i];}
                      
                       myData=myData.concat(myDpInput)          //myData=myData.concat(getState(dpTSJson[i]).val)
                      
                    }
                     
                    
                    
                    //WHITELIST FILTER
                     
                    if (myWhiteListArray.length>0){
                    for(let myind in myWhiteListArray) { for (let rr=0;rr<myData.length;rr++) {
                                                              if (myData[rr].event.includes(myWhiteListArray[myind]) ) { myData2.push(myData[rr])}
                                                                     }}
                    //log(JSON.stringify(myData2))
                     
                    myData=[];
                    myData=JSON.parse(JSON.stringify(myData2))
                    }
                     
                     
                     
                    //BLACKLIST FILTER
                     
                    if (myBlackListArray.length>0){let oldStuff=""
                    for (let rr=0;rr<myData.length;rr++) { let mycount=0;
                                                           for(let myind in myBlackListArray){
                                                            //log(myData[rr].event+" ---- "+myBlackListArray[myind]+" -----"+myData[rr].event.includes(myBlackListArray[myind]) )
                                                              if (myData[rr].event.includes(myBlackListArray[myind]) ) { mycount++  }}
                                                                    if(mycount==0) {  myData3.push(myData[rr]);}
                                                                                                
                                                              }
                                                                                                                       
                    myData=[];
                    myData=JSON.parse(JSON.stringify(myData3))
                    
                    }
                    
                     // class = Kalender -RRO hier evtl. Abfrage aus ical2Calender-FarbScala einfügen
                    
                    if (!sortedByInstanz){
                    myData.sort(function(a, b){
                                                   return new Date(a._date).getTime() - new Date(b._date).getTime();      // return parseInt(new Date(b.date).getTime()) - parseInt(a.date);
                                                  });}
                    if (false){
                    myData.sort(function (alpha, beta) {
                                 if (alpha.event.toUpperCase() > beta.event.toUpperCase())
                                    return 1;
                                 if (beta.event.toUpperCase() > alpha.event.toUpperCase())
                                    return -11;
                                 return 0;
                                });      
                    }                         
                    
                    // NEXT TERMIN
                       for (let x=0;x<myData.length;x++ ) {
                               if (!myData[x].date.includes("&#8594;") && myData[x].date.includes(":") && !myData[x].date.includes("01:00-00:00"))
                                   {   helperTerminNext=myData[x].date
                                       helperTerminNext=helperTerminNext.replace(/(.+?\..*?\.).* (\d\d\:\d\d)-\d\d\:\d\d/,"$1 $2: ");  
                                                 
                                    if(   formatDate(getDateObject(myData[x]._date), "DD.MM") == formatDate(getDateObject((new Date().getTime())), "DD.MM") ) {helperTerminNext=helperTerminNext.replace(/.+? (\d\d\:\d\d)/,"Heute $1: ")} // : helperTerminNext=helperTerminNext.replace(/(.+?\..*?\.).* (\d\d\:\d\d)-\d\d\:\d\d/,"$1 $2")   
                                 
                               //  log(  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM") +"  "+formatDate(getDateObject((new Date().getTime())), "DD.MM"))
                                   if (  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM") == formatDate(getDateObject(myData[x]._date), "DD.MM") ) {
                                         helperTerminNext=helperTerminNext.replace(/.+? (\d\d\:\d\d)/,"Morgen $1: "); }
                          
                                       inDpNext=helperTerminNext+" "+myData[x].event;
                                                         
                                    break;}
                       }
                    //NEXT GANZER TAG
                     
                       for (let x=0;x<myData.length;x++ ) {
                               if ((!myData[x].date.includes("&#8594;") && !myData[x].date.includes(":") &&  formatDate(getDateObject(myData[x]._date), "DD.MM") != formatDate(getDateObject((new Date().getTime())), "DD.MM")) || 
                                       (!myData[x].date.includes("&#8594;") && myData[x].date.includes("01:00") &&  formatDate(getDateObject(myData[x]._date), "DD.MM") != formatDate(getDateObject((new Date().getTime())), "DD.MM")) )
                                  { helperTerminNext=myData[x].date
                                   // log(helperTerminNext)
                                    let morgen =  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM"); //log(morgen)
                                    
                                    if (  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM") == formatDate(getDateObject(myData[x]._date), "DD.MM") ) {
                                          helperTerminNext="Morgen: " ;
                                       //   log("-"+helperTerminNext)
                                          }
                                   
                                                      
                               inDpGanzTag=helperTerminNext+" "+myData[x].event ; 
                                       
                               break;}
                       }   
                     
                    // LÄUFT GERADE
                     
                       for (let x=0;x<myData.length;x++ ) {
                               if (myData[x].date.includes("&#8594;")   && myData[x].date.includes(":") && !myData[x].date.includes("00:00") )
                     
                                   {   helperTerminNext=myData[x].date.replace("&#8594;","")
                                   helperTerminNext=helperTerminNext.replace(/.+? (.?)/,"bis: $1")
                                   inDpRunning.push(helperTerminNext+" "+myData[x].event)
                                   
                                    } }
                         inDpRunning.length>0 ? inDpRunning2=inDpRunning[inDpRunning.length-1]  :  inDpRunning2=""          
                       
                     
                    //myData=getState(dpTSJson).val;
                    //log(JSON.stringify(myData)) 
                    for (var index in myData ) {             // hier eigene schleife definieren
                     
                    if(oldID!=myData[index].myIDID && sortedByInstanz) {
                     
                        counter++;
                        val0="<font color=\""+myData[index]._calColor +"\"><b>"+myData[index].myIDID;
                        val1="";
                        val2="";
                        val3="";
                        val4="";
                        oldID= myData[index].myIDID
                        tabelleBind();
                         matDes(true,myData[index]._calColor);
                    } //else {
                    val1="";val2="";
                     
                         if(Math.ceil(Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000 )-1 <=wievielTage){
                            counter++
                           val0=myData[index].event
                           if (myFilterRegexEvent5.length==myFilterRegexEvent6.length){
                           for(let z=0;z<myFilterRegexEvent5.length;z++){val0=val0.replace(myFilterRegexEvent5[z],myFilterRegexEvent6[z])}}
                         //  val0=val0.replace(myFilterRegexEvent,myFilterRegexEvent2)
                           let val2help=myData[index].date
                         //  log(val2help+"  ---  "+myData[index].event)
                     
                     
                           nurAnfangsZeit ? val1=val2help.replace(/.+? (\d\d\:\d\d)-\d\d\:\d\d/,"$1") : val1=val2help.replace(/.+? (.+)/,"$1") //ZEIT
                        //   log(val1.includes(".")+ " val1= "+val1)
                          
                           val1.includes(".") && nurAnfangsZeit ? val1=ganzTaegigAusdruck : val1=val1             //&& !nurAnfangsZeit
                           !val2help.includes(":") && !nurAnfangsZeit ? val1=ganzTaegigAusdruck : val1=val1  
                           val2=val2help.replace(/(.+?) .+/,"$1") //DATUM
                           
                            let val3help=false; // zuständig für Farbe heute
                            let helpi=false;
                            if (myData[index]._rule==" ") helpi=true
                        // log("---- "+val2+" ---val2help:  "+val2help+"      ++++"+myData[index]._allDay+"    +++++  "+val0+"  rrule-!"+myData[index]._rule+"!"+helpi)
                    //////////// IST GERADE AM LAUFEN - anderes Format 
                           if ( myData[index].date.includes("&#8594;") && myData[index].rule!=" " && myData[index].date.includes(":") ) {val1=ganzTaegigAusdruck;                                 val2=formatDate(getDateObject(myData[index]._date), "DD.MM.YYYY")} 
                           if ( val2.includes("&#8594;") && !myData[index]._allDay )                                      {val1=ganzTaegigAusdruck;                                 val2=formatDate(getDateObject(myData[index]._date), "DD.MM.YYYY")}       
                            if ( myData[index].date.includes("&#8594;") && myData[index].rule!=" " && !myData[index].date.includes("00:00") )                     {val1=val2help.replace(/.+? .+? (.+)/, bisVariable+"$1"); val2=formatDate(getDateObject(myData[index]._date), "DD.MM.YYYY")}
                          //  log("val1 : "+val1+"  val2: "+val2)
                            
                    /////////// HEUTE       
                           // log(formatDate(getDateObject(myData[index]._date), "DD.MM") +"   "+ formatDate(getDateObject((new Date().getTime())), "DD.MM"))
                            if (formatDate(getDateObject(myData[index]._date), "DD.MM") == formatDate(getDateObject((new Date().getTime())), "DD.MM") ) {
                                   val3help=true;        //FARBE HEUTE       
                                   
                                   val4=0;               // TAGE HEUTE  
                    ////////// AB MORGEN               
                            } else{
                                  let val44help=Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000
                                 // log(val44help.toString())
                     
                                  val4=Math.ceil(Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000 )-1
                                //  log((Number(formatDate(getDateObject(myData[index]._date), "hh"))*60) + Number(formatDate(getDateObject(myData[index]._date), "mm")).toString() +"--------"+(Number(formatDate(getDateObject((new Date().getTime())), "hh"))*60) + Number(formatDate(getDateObject((new Date().getTime())), "mm")).toString())
                                  if (   (Number(formatDate(getDateObject(myData[index]._date), "hh"))*60) + Number(formatDate(getDateObject(myData[index]._date), "mm"))  <  (Number(formatDate(getDateObject((new Date().getTime())), "hh"))*60) + Number(formatDate(getDateObject((new Date().getTime())), "mm")) ) 
                                         {if(!myData[index]._date.includes("&#8594;")) val4=Math.ceil(Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000 );
                                      //   log(myData[index].date.replace(/.*? (01\:00\-00\:00)/,"$1"))
                                        // if(myData[index].date.replace(/.*? (01\:00\-00\:00)/,"$1")=="01:00-00:00") val1=ganzTaegigAusdruck;
                                        if(myData[index].date.includes("01:00-00:00")) val1=ganzTaegigAusdruck
                                         }
                                  }
                     
                            val3=formatDate(getDateObject(myData[index]._date), "W")
                           if (myData[index]._rule==" rrule " && wiederholAnzeige) val0=val0+" &#8595;"
                     
                            if (val4.toString()=="0") val4=ersetze0MitWert;
                            if (val4.toString()=="1") val4=ersetze1MitWert;
                     
                           
                             let istSonderfarbe=false;
                             let val01=val0; let val02=val2; let val03=val3; let val04=val4; let val11=val1;
                             if (mySonderFarbeArr.length>0 ){ for(let myind in mySonderFarbeArr){if(val0.includes(mySonderFarbeArr[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbol+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }   
                             if (mySonderFarbeArrRiko.length>0 ){ for(let myind in mySonderFarbeArrRiko){if(val0.includes(mySonderFarbeArrRiko[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolRiko+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }   
                            if (mySonderFarbeArrTUEV.length>0 ){ for(let myind in mySonderFarbeArrTUEV){if(val0.includes(mySonderFarbeArrTUEV[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolTUEV+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }                                          
                            if (mySonderFarbeArrErnte.length>0 ){ for(let myind in mySonderFarbeArrErnte){if(val0.includes(mySonderFarbeArrErnte[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolErnte+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }      
                            if (mySonderFarbeArrArzt.length>0 ){ for(let myind in mySonderFarbeArrArzt){if(val0.includes(mySonderFarbeArrArzt[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolArzt+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }      
                            if (mySonderFarbeArrUrlaub.length>0 ){ for(let myind in mySonderFarbeArrUrlaub){if(val0.includes(mySonderFarbeArrUrlaub[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolUrlaub+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }      
                           if (mySonderFarbeArrConny.length>0 ){ for(let myind in mySonderFarbeArrConny){if(val0.includes(mySonderFarbeArrConny[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolConny+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }                                             
                           if (mySonderFarbeArrRebecca.length>0 ){ for(let myind in mySonderFarbeArrRebecca){if(val0.includes(mySonderFarbeArrRebecca[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolRebecca+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }      
                           if (mySonderFarbeArrGeburtstag.length>0 ){ for(let myind in mySonderFarbeArrGeburtstag){if(val0.includes(mySonderFarbeArrGeburtstag[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolGeburtstag+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }                                            
                          if (mySonderFarbeArrWichtig.length>0 ){ for(let myind in mySonderFarbeArrWichtig){if(val0.includes(mySonderFarbeArrWichtig[myind]) ){
                                                                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolWichtig+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                istSonderfarbe=true;
                                                                                }}
                                                           }      
                               //istSonderfarbe=false                           
                               //console.log(myData[index]._calColor); -> Farbcode
                            if(val3help && sortedByInstanz ){
                                val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val03+"<\/"+styleEinTagHTML+">";
                                val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val04+"<\/"+styleEinTagHTML+">";
                                val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val11+"<\/"+styleEinTagHTML+">";
                                val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val02+"<\/"+styleEinTagHTML+">";
                               !istSonderfarbe ?  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val0+"<\/"+styleEinTagHTML+">" : val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                 } 
                            if (val3help && !sortedByInstanz ){
                                     val3="<font color=\""+myData[0]._calColor +"\"><"+styleEinTagHTML+">"+val03+"<\/"+styleEinTagHTML+">";
                                     val4="<font color=\""+myData[0]._calColor  +"\"><"+styleEinTagHTML+">"+val04+"<\/"+styleEinTagHTML+">";
                                     val1="<font color=\""+myData[0]._calColor  +"\"><"+styleEinTagHTML+">"+val11+"<\/"+styleEinTagHTML+">";
                                     val2="<font color=\""+myData[0]._calColor  +"\"><"+styleEinTagHTML+">"+val02+"<\/"+styleEinTagHTML+">";
                                !istSonderfarbe ?  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val0+"<\/"+styleEinTagHTML+">" : val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                 } 
                     
                         
                     
                           oldID= myData[index].myIDID
                     
                           matDes(val3help,myData[index]._calColor);
                     
                      
                       
                         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 der schleife------------------------------------------------------------------------------
                    //-------------------------------------------------------------------------------------------------------------------------------------------------
                     
                          tabelleFinish(); // AB HIER NICHTS ÄNDERN - tabelle fertigstellen
                                       setState(dpTerminRunning,inDpRunning2)
                                       setState(dpTerminNext,inDpNext)
                                       setState(dpTerminNextGanzerTag,inDpGanzTag);
                    } // function ende
                     
                    //MAIN:
                     
                    schedule(mySchedule3,  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:  if(counter%2==0) {  htmlOut=htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>"; break; } else
                                                      {  htmlOut=htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>"; break; } 
                           
                            case 2: if(counter%4==0){
                                       if(counter%2==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"  align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                  else {htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>";} break;
                                   }else{
                                                  if(counter%2==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                  else {htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val4+"</td></tr>";} break;}
                                                       
                            case 3:  if(counter%2==0)   {
                                     if(counter%3==0 )  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                  else { if(counter%3==1 )  { htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\" color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                   else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>";}
                                                             } break;} else{
                                     if(counter%3==0 )  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                  else { if(counter%3==1 )  { htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                   else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>";}
                                                             } break; }
                     
                            case 4:  if(counter%8==0)   {
                                     if(counter%4==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val4+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val3+"</td>"; } 
                                                      else {if(counter%4==1 )  { htmlOut = htmlOut+"<td  align="+Feld1lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                   else    {if(counter%4==3)  { htmlOut= htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val4+"</td></tr>";} 
                                                                                     else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>";}}
                                                             } break;} else{
                                     if(counter%4==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val3+"</td>"; } 
                                                      else {if(counter%4==1 )  { htmlOut = htmlOut+"<td  align="+Feld1lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                   else    {if(counter%4==3)  { htmlOut= htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val4+"</td></tr>";} 
                                                                                     else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>";}}
                                                             } break; }
                     
                         } //switch ende
                     
                     
                     
                    }
                     
                    function tabelleFinish() {
                     
                          // tabelle fertigstellen
                    switch (mehrfachTabelle) {  
                           case 1:    break;
                     
                           case 2:    
                                      if(counter%2==0)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');
                                    
                                      break;
                     
                           case 3:   if(counter%3==2)  htmlOut = htmlOut.replace(/<\/td>$/, "</td></tr>");
                                     if(counter%3==1)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");        
                                     if(counter%3==0)      htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");
                                   
                                      break;
                           case 4:   if(counter%4==3)  htmlOut = htmlOut.replace(/<\/td>$/, "</td></tr>");
                                     if(counter%4==2)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");
                                     if(counter%4==1)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");    
                                     if(counter%4==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&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: "+htmlUeberFontGroesse+"; 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>"
                     
                     if (!htmlSignature) htmlUnter="";
                    var htmlEnd="</table>"+htmlUnter+"</div></body>";
                     //mit oder ohne überschrift - zentriert oder links
                    htmlUberschrift ? htmlOut=htmlStart+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd : htmlOut=htmlStart+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd;
                     //log(htmlOut);
                     
                    if (braucheMaterialDesignWidget) {
                         
                           setState(dpMaterialWidget,JSON.stringify(myJsonWidget2)); 
                           myJsonWidget2=[];
                    }
                    if (braucheMaterialDesignWidgetTable) {
                      
                      setState(dpMaterialWidgetTable,JSON.stringify(myJsonWidget)); 
                         myJsonWidget=[];
                    }
                    }
                     
                     
                     
                     
                    function makeJsonWidget(vax1,vax2,vax3,vax4,vax44,vax5) {
                    //log(vax5+vax3)
                    
                       if ( braucheMaterialDesignWidgetTable) {
                      myJsonWidget.push({
                        /*  Originaleinträge  abgeändert RRO
                          Event : vax1,
                          Zeit : vax2,
                          Datum : vax3,
                          W_tag : vax4, 
                          Tage : vax44
                         */
                          W_tag : vax4, 
                          Datum : vax3,
                          Zeit : vax2,
                          Event : vax1,
                          Tage : vax44
                      }
                     
                      );}
                     
                    //	log(myJsonWidget)
                    if (braucheMaterialDesignWidget) {
                    let mysubText = `<div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                    <div style="flex: 1;">${vax4}</div>
                                    <div style="color: black; font-size: 18px; font-family: RobotoCondensed-LightItalic; text-align: right;">${vax3}</div>
                                    </div>`
                           if(vax3<=1)   vax5=farbeNurEinTag               
                      
                         myJsonWidget2.push({
                                   text: vax2,
                                   subText: mysubText,
                                   statusBarColor: vax5,
                                   image: vax1,
                                   imageColor: "",
                                   listType: "text",
                                   showValueLabel: false,
                                   name: vax2,
                                   status: vax3,
                                   Wert : vax3,
                                   Hersteller : vax4
                               });
                    }
                     }
                     
                    on({id: dpTSJson, change: "ne"}, function (obj) { 
                           //log(getState(dpANLEGEN).val+"----refresh");
                         
                           var timeout2 = setTimeout(function () {
                             
                       writeHTML();
                      
                        }, 1500);
                    });
                     
                    function matDes(val3help,color) {
                        if (braucheMaterialDesignWidget || braucheMaterialDesignWidgetTable) {
                                if(val3help && sortedByInstanz){json5=color;}
                                if (val3help && !sortedByInstanz){}
                               json1=val0; json2=val1; json3=val2; json4=val3;json44=val4;json5=farbeStandardBar;
                                makeJsonWidget(json1,json2,json3,json4,json44,json5);
                    }
                    };
                     
                     
                    
                    liv-in-skyL 1 Antwort Letzte Antwort
                    0
                    • R Rosi8818

                      @thomas-braun hier das Script (ich hoffe sind keine Daten drin die keiner sehen soll) ;)

                       /*@liv-in-sky 2020  29.1.2021 12:18
                        genutzt für Material-Design -> let weiter unten
                      
                       *** HauptScript löst Kalenderaufbereitungen ab ***
                      
                       für das Widgets der wichtigsten Ereignisse in der VIS
                       mit Blacklist und Sonderfarbe
                      
                       --> 0_userdata.0.Tabellen.ical.
                      
                       */
                      //HIER WIRD PFAD UND FILENAME DEFINIERT
                      const path = "/htmlexample.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="0_userdata.0.Tabellen.ical.Termine";         //WICHTIG wenn "braucheEinVISWidget" auf true gesetzt !!  dp zusätzlich für VIS-HTML-Basic-Widget
                      //let dpTSJson=["ical.0.data.table","ical.1.data.table"];                        //mehrere Instanzen zusammenfügen
                      let dpTSJson=["ical.0.data.table","ical.1.data.table","ical.2.data.table","ical.3.data.table",];
                      let dpTSJsonCalName=["Rosemeyer","nächste Kalender"];                        //mehrere Instanzen zusammenfügen
                      let   braucheMaterialDesignWidgetTable=true;        // bei true wird ein json in einen dp geschrieben - MUSS ANGELEGT WERDEN !!!
                      let dpMaterialWidgetTable="0_userdata.0.Tabellen.ical.MaterialWidgetTable";  // WICHTIG wenn braucheMaterialDesignWidgetTable auf true MATERIALDESIGN Table Widget - datenpunkt anlegen: zeichenkette 
                       
                      // seting für extra datenpunkte
                      let ichWillDpNextRunning=true;
                      let dpTerminNext="0_userdata.0.Tabellen.ical.TerminNext";                    // WICHTIG wenn ichWillDpNextRunning auf true  - datenpunkt anlegen: zeichenkette
                      let dpTerminRunning="0_userdata.0.Tabellen.ical.TerminRunning";               // WICHTIG wenn ichWillDpNextRunning auf true - datenpunkt anlegen: zeichenkette  
                      let dpTerminNextGanzerTag="0_userdata.0.Tabellen.ical.TerminNextGanzerTag";   // WICHTIG wenn ichWillDpNextRunning auf true  - datenpunkt anlegen: zeichenkette 
                       
                       let wievielTage=50
                       let styleEinTagHTML="span"                                  // style der zeile wenn unter einem tag:  möglich b fett; i kursiv; span normal
                                                                                  // Original span - zeigt mit b die markierten Einträge fett
                       let sortedByInstanz=false;
                       let nurAnfangsZeit=false;
                      let ganzTaegigAusdruck="&RightArrowLeftArrow;";             // "ganztägig" oder "den ganzen Tag" oder &laquo; &RightArrowLeftArrow;
                       let bisVariable="&longmapsto;"                              // wenn gerade läuft - running event zeichen
                       let ersetze0MitWert="0"                                     // z.b. "heute" 
                       let ersetze1MitWert="morgen"                                // z.b "morgen"
                       
                       // regex zum event-text ändern
                       //let myFilterRegexEvent=/Biathlon(: .*)/;                  // Regex für EventAnzeige: event=event.replace(myFilterRegexEvent,myFilterRegexEvent2)
                       //let myFilterRegexEvent2="Biat$1";                         // z.b. Geburtstag':   myFilterRegexEvent=/(.*) Geburtstag/; myFilterRegexEvent2="$1"
                       
                       let myFilterRegexEvent5=[/Biathlon(: .*)/,/(GELBE)R SACK/];                        // Regex für EventAnzeige: event=event.replace(myFilterRegexEvent,myFilterRegexEvent2)
                       let myFilterRegexEvent6=["Biat$1","$1 Tonne"];                               // z.b. Geburtstag':   myFilterRegexEvent5=[/(.*) Geburtstag/];  let myFilterRegexEvent6=[""$1"]; 
                                                                                               // WICHTIG : gleiche anzahl in den beide Variablen
                       
                       let mySchedule3="  */30 * * * * ";                       //alle 30 minuten //eigentlich unnötig, da das script auf änderung des ical datenpunktes triggert
                        
                       let wiederholAnzeige="true";                                // es werden pfeile am ende des event-eintraägs hinzugefügt, wenn es eine wiederholung ist
                       let myWhiteListArray=[];                                    // momentan ohne [] whitelist sonst z.b ["URLAUB","frei"]  auf großschreibung achten
                       let myBlackListArray=["Simvastatin", "Abfuhr", "Gelber Sack","Biotonne","Papiersammlung","Glassammlung","Hausmüll 2W","Hausmüll 4W"]; // momentan ohne [] blacklist sonst z.b ["Biathlon",Tabletten nehmen]  auf großschreibung achten
                       
                       let mySonderFarbeArr=["Ralf:"];               //  ohne [] termine, die besonders hervorgehoben werden sollen sonst z.b ["Biathlon",Tabletten nehmen] am besten mit sortedByInstanz=false;
                       let mySonderSymbol="&#9055;"+"&ensp;";        //  🔸 🚘 ⚪  ⚫ ⭕  🔴 🔵 🟠 ⏱ 💀 👍 👎 📑 💲 👀   mehr: https://emojiterra.com/de/ oder https://unicode-table.com/de/html-entities/
                                                                     //  (⌾ &#9022;) (🔹 &#128313;) (🍏 &#127823;) 💰 💸 (❗ &#10071;) (⬩ &#11049;) (● &#9679;)  (⍟ &#9734;->Stern) 
                                                                     //  (⌾ &#9055;) (⧇ &#10695;) (🎂 &#127874;) (🟡 &#128993;) (🔵 &#128309;) (🟢 &#128994;) (🔴 &#128308;)
                                                                     //  (ℜ &#8476;) (ℛ &#8475;)
                      let mySonderFarbeArrRiko=["Riko:"];
                      let mySonderSymbolRiko="&#9022;"+"&ensp;"; 
                      
                      let mySonderFarbeArrTUEV=["TÜV:","Steuer"];
                      let mySonderSymbolTUEV="⬩"+"&ensp;"; 
                      
                      let mySonderFarbeArrErnte=["Ernte:"];
                      let mySonderSymbolErnte="&#127823;"+"&ensp;"; 
                      
                      let mySonderFarbeArrArzt=["Arzt:"];
                      let mySonderSymbolArzt="&#9734;"+"&ensp;"; 
                      
                      let mySonderFarbeArrUrlaub=["Urlaub:"];
                      let mySonderSymbolUrlaub="&#128313;"+"&ensp;"; 
                      
                      let mySonderFarbeArrConny=["Conny:"];
                      let mySonderSymbolConny="&#128309;"+"&ensp;"; 
                      
                      let mySonderFarbeArrRebecca=["Rebecca:"];
                      let mySonderSymbolRebecca="&#128993;"+"&ensp;"; 
                      
                      let mySonderFarbeArrGeburtstag=["Geburtstag von"];
                      let mySonderSymbolGeburtstag="&#127874;"+"&ensp;"; 
                      
                      let mySonderFarbeArrWichtig=["WICHTIG:"];
                      let mySonderSymbolWichtig="&#10071;"+"&ensp;"; 
                      
                      // let mySonderFarbeArrUrlaub=["Urlaub:"];
                      // let mySonderSymbolUrlaub="&#9734;"+"&ensp;"; 
                      //---------------------------------------
                       
                      //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 4
                      var htmlFeld1='EVENT';       var Feld1lAlign="left";          // überschrift Tabellen Spalte1 und  Ausrichtung left,right or center
                      var htmlFeld2='ZEIT';        var Feld2lAlign="center";        // überschrift Tabellen Spalte2 und  Ausrichtung left,right or center
                      var htmlFeld3='DATUM';         var Feld3lAlign="center";      // überschrift Tabellen Spalte3 und  Ausrichtung left,right or center
                      var htmlFeld4='WTAG';        var Feld4lAlign="center";        // überschrift Tabellen Spalte4 und  Ausrichtung left,right or center
                      var htmlFeld5='TAGE';        var Feld5lAlign="center";        // überschrift Tabellen Spalte5 und  Ausrichtung left,right or center
                      //-----------------------------------
                       
                       
                      //ÜBERSCHRIFT ÜBER TABELLE
                      let   htmlUberschrift=false;                // mit Überschrift über der tabelle
                      let   htmlSignature=false;                  // anstatt der Überscghrift eine signature: - kleiner - anliegend
                      const htmlFeldUeber='Ical';                 // Überschrift und Signature
                      const htmlFarbUber="green";                 // Farbe der Überschrift
                      const htmlSchriftWeite="normal";            // bold, normal - Fettschrift für Überschrift
                      const htmlUeberFontGroesse="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 trennungsLinie="2";                   //extra trennungslinie bei mehrfachtabellen - evtl auf 0 stellen, wnn htmlRahmenLinien auf none sind
                      const htmlFarbZweiteTabelle="black";        // Farbe der Überschrift bei jeder 2.ten Tabelle
                      const htmlFarbTableColorUber="black";       // Überschrift in der tabelle - der einzelnen Spalten BDBDBD
                      //ÜBERSCHRIFT SPALTEN
                      const UeberSchriftHoehe=25;                  //Überschrift bekommt mehr Raum - darunter und darüber - Zellenhöhe
                      const LinieUnterUeberschrift="2";           // Linie nur unter Spaltenüberschrift - 
                      const farbetrennungsLinie="white";
                      const farbeLinieUnterUeberschrift="black";
                      const groesseUeberschrift=16;
                      const UeberschriftStyle="normal"            // möglich "bold"
                      //GANZE TABELLE
                      let abstandZelle="3";
                      let farbeUngeradeZeilen="#333333"//"#1C1C1C";        //Farbe für ungerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2
                      let farbeGeradeZeilen="black"//"black";              //Farbe für gerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2
                      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=""     //"Jura-DemiBold"   //"RobotoCondensed-Bold"   //"Helvetica";
                      const htmlSchriftgroesse="16px";
                      //FELDER UND RAHMEN
                      let   UeberschriftSpalten=true;                // ein- oder ausblenden der spatlen-überschriften
                      const htmlFarbFelderschrift="#D8D8D8";                  // SchriftFarbe der Felder
                      const htmlFarbFelderschrift2="#D8D8D8";                 // SchriftFarbe der Felder für jede 2te Tabelle
                      const htmlFarbTableColorGradient1="orange";          //  Gradient - Hintergrund der Tabelle - Verlauffarbe
                      const htmlFarbTableColorGradient2="green";          //  Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
                      const htmlFarbTableBorderColor="transparent";             // 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 height=\""+UeberSchriftHoehe+"\" style=\"color:"+htmlFarbTableColorUber+"; font-size: "+groesseUeberschrift+"px; font-weight: "+UeberschriftStyle+" ;  border-bottom: "+LinieUnterUeberschrift+"px solid "+farbeLinieUnterUeberschrift+" \">";
                      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  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>";
                      var htmlTabUeber2_1="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+" style=\"color:"+htmlFarbZweiteTabelle+"\">&ensp;"+htmlFeld1+"&ensp;</td><td  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>";
                                             //------------------------------------------------------
                       
                      //im MD List Widget
                       let farbeNurEinTag="yellow"                               //statusBarColor im MD List Widget wenn nur noch ein tag
                       let farbeStandardBar="#d5d3b4"                            //// nicht benutzt!! statusBarColor im MD List Widget wenn normal
                      //im HTML Widget
                      //let bildergröße=24
                       let farbeEinTagHTML="#CB9529"                             // wird nicht mehr genutzt!!  Farbe der zeile in html tabelle wenn unter einem tag:
                      let   braucheMaterialDesignWidget=false;             // bei true wird ein json in einen dp geschrieben - MUSS ANGELEGT WERDEN !!!
                       
                      let dpMaterialWidget="0_userdata.0.Tabellen.ical.MaterialWidget";    // WICHTIG wenn braucheMaterialDesignWidget auf true MATERIALDESIGN List Widget - datenpunkt anlegen : zeichenkette  
                       
                      var htmlOut="";
                      var mix;
                      var counter;
                      var val1; var val2; var val0; var val3; var val4;
                      var htmlTabUeber="";
                      //var wochentag = ['Sonntag','Montag','Dienstag','Mittwoch','Donnerstag','Freitag','Samstag' ]
                      var myJsonWidget=[]; 
                      var myJsonWidget2=[];
                      var json1; var json2; var json3; var json4; var json44; var json5;
                      let oldID="";
                      let inDpNext="";
                      let inDpRunning=[];
                      let inDpRunning2="";
                      let inDpGanzTag="";
                      let helperTerminNext="";
                      function writeHTML(){
                       
                      oldID="";
                       
                      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!!!------------------------------------------------------------
                      //--------------------------------------------------------------------------------------------------------------------------------------------------
                      let myData=[];
                      let myData2=[];
                      let myData3=[];
                      inDpNext=""
                      inDpRunning=[];
                       inDpRunning2="";
                       
                      inDpGanzTag="";
                       
                      for (let i=0;i<dpTSJson.length;i++) {
                         //20210809 nach Fehler, gelöst aus Forum: vorher let myDpInput=(getState(dpTSJson[i]).val);
                         let myDpInput=(JSON.parse(getState(dpTSJson[i]).val));
                        
                      
                      // hier kann der Kalendername abgefangen werden   - RRO
                      
                           for  (let b=0;b<myDpInput.length;b++) { myDpInput[b].myIDID=dpTSJsonCalName[i];}
                        
                         myData=myData.concat(myDpInput)          //myData=myData.concat(getState(dpTSJson[i]).val)
                        
                      }
                       
                      
                      
                      //WHITELIST FILTER
                       
                      if (myWhiteListArray.length>0){
                      for(let myind in myWhiteListArray) { for (let rr=0;rr<myData.length;rr++) {
                                                                if (myData[rr].event.includes(myWhiteListArray[myind]) ) { myData2.push(myData[rr])}
                                                                       }}
                      //log(JSON.stringify(myData2))
                       
                      myData=[];
                      myData=JSON.parse(JSON.stringify(myData2))
                      }
                       
                       
                       
                      //BLACKLIST FILTER
                       
                      if (myBlackListArray.length>0){let oldStuff=""
                      for (let rr=0;rr<myData.length;rr++) { let mycount=0;
                                                             for(let myind in myBlackListArray){
                                                              //log(myData[rr].event+" ---- "+myBlackListArray[myind]+" -----"+myData[rr].event.includes(myBlackListArray[myind]) )
                                                                if (myData[rr].event.includes(myBlackListArray[myind]) ) { mycount++  }}
                                                                      if(mycount==0) {  myData3.push(myData[rr]);}
                                                                                                  
                                                                }
                                                                                                                         
                      myData=[];
                      myData=JSON.parse(JSON.stringify(myData3))
                      
                      }
                      
                       // class = Kalender -RRO hier evtl. Abfrage aus ical2Calender-FarbScala einfügen
                      
                      if (!sortedByInstanz){
                      myData.sort(function(a, b){
                                                     return new Date(a._date).getTime() - new Date(b._date).getTime();      // return parseInt(new Date(b.date).getTime()) - parseInt(a.date);
                                                    });}
                      if (false){
                      myData.sort(function (alpha, beta) {
                                   if (alpha.event.toUpperCase() > beta.event.toUpperCase())
                                      return 1;
                                   if (beta.event.toUpperCase() > alpha.event.toUpperCase())
                                      return -11;
                                   return 0;
                                  });      
                      }                         
                      
                      // NEXT TERMIN
                         for (let x=0;x<myData.length;x++ ) {
                                 if (!myData[x].date.includes("&#8594;") && myData[x].date.includes(":") && !myData[x].date.includes("01:00-00:00"))
                                     {   helperTerminNext=myData[x].date
                                         helperTerminNext=helperTerminNext.replace(/(.+?\..*?\.).* (\d\d\:\d\d)-\d\d\:\d\d/,"$1 $2: ");  
                                                   
                                      if(   formatDate(getDateObject(myData[x]._date), "DD.MM") == formatDate(getDateObject((new Date().getTime())), "DD.MM") ) {helperTerminNext=helperTerminNext.replace(/.+? (\d\d\:\d\d)/,"Heute $1: ")} // : helperTerminNext=helperTerminNext.replace(/(.+?\..*?\.).* (\d\d\:\d\d)-\d\d\:\d\d/,"$1 $2")   
                                   
                                 //  log(  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM") +"  "+formatDate(getDateObject((new Date().getTime())), "DD.MM"))
                                     if (  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM") == formatDate(getDateObject(myData[x]._date), "DD.MM") ) {
                                           helperTerminNext=helperTerminNext.replace(/.+? (\d\d\:\d\d)/,"Morgen $1: "); }
                            
                                         inDpNext=helperTerminNext+" "+myData[x].event;
                                                           
                                      break;}
                         }
                      //NEXT GANZER TAG
                       
                         for (let x=0;x<myData.length;x++ ) {
                                 if ((!myData[x].date.includes("&#8594;") && !myData[x].date.includes(":") &&  formatDate(getDateObject(myData[x]._date), "DD.MM") != formatDate(getDateObject((new Date().getTime())), "DD.MM")) || 
                                         (!myData[x].date.includes("&#8594;") && myData[x].date.includes("01:00") &&  formatDate(getDateObject(myData[x]._date), "DD.MM") != formatDate(getDateObject((new Date().getTime())), "DD.MM")) )
                                    { helperTerminNext=myData[x].date
                                     // log(helperTerminNext)
                                      let morgen =  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM"); //log(morgen)
                                      
                                      if (  formatDate(getDateObject((new Date().getTime())+(1000 * 60 * 60 * 24 * 1)), "DD.MM") == formatDate(getDateObject(myData[x]._date), "DD.MM") ) {
                                            helperTerminNext="Morgen: " ;
                                         //   log("-"+helperTerminNext)
                                            }
                                     
                                                        
                                 inDpGanzTag=helperTerminNext+" "+myData[x].event ; 
                                         
                                 break;}
                         }   
                       
                      // LÄUFT GERADE
                       
                         for (let x=0;x<myData.length;x++ ) {
                                 if (myData[x].date.includes("&#8594;")   && myData[x].date.includes(":") && !myData[x].date.includes("00:00") )
                       
                                     {   helperTerminNext=myData[x].date.replace("&#8594;","")
                                     helperTerminNext=helperTerminNext.replace(/.+? (.?)/,"bis: $1")
                                     inDpRunning.push(helperTerminNext+" "+myData[x].event)
                                     
                                      } }
                           inDpRunning.length>0 ? inDpRunning2=inDpRunning[inDpRunning.length-1]  :  inDpRunning2=""          
                         
                       
                      //myData=getState(dpTSJson).val;
                      //log(JSON.stringify(myData)) 
                      for (var index in myData ) {             // hier eigene schleife definieren
                       
                      if(oldID!=myData[index].myIDID && sortedByInstanz) {
                       
                          counter++;
                          val0="<font color=\""+myData[index]._calColor +"\"><b>"+myData[index].myIDID;
                          val1="";
                          val2="";
                          val3="";
                          val4="";
                          oldID= myData[index].myIDID
                          tabelleBind();
                           matDes(true,myData[index]._calColor);
                      } //else {
                      val1="";val2="";
                       
                           if(Math.ceil(Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000 )-1 <=wievielTage){
                              counter++
                             val0=myData[index].event
                             if (myFilterRegexEvent5.length==myFilterRegexEvent6.length){
                             for(let z=0;z<myFilterRegexEvent5.length;z++){val0=val0.replace(myFilterRegexEvent5[z],myFilterRegexEvent6[z])}}
                           //  val0=val0.replace(myFilterRegexEvent,myFilterRegexEvent2)
                             let val2help=myData[index].date
                           //  log(val2help+"  ---  "+myData[index].event)
                       
                       
                             nurAnfangsZeit ? val1=val2help.replace(/.+? (\d\d\:\d\d)-\d\d\:\d\d/,"$1") : val1=val2help.replace(/.+? (.+)/,"$1") //ZEIT
                          //   log(val1.includes(".")+ " val1= "+val1)
                            
                             val1.includes(".") && nurAnfangsZeit ? val1=ganzTaegigAusdruck : val1=val1             //&& !nurAnfangsZeit
                             !val2help.includes(":") && !nurAnfangsZeit ? val1=ganzTaegigAusdruck : val1=val1  
                             val2=val2help.replace(/(.+?) .+/,"$1") //DATUM
                             
                              let val3help=false; // zuständig für Farbe heute
                              let helpi=false;
                              if (myData[index]._rule==" ") helpi=true
                          // log("---- "+val2+" ---val2help:  "+val2help+"      ++++"+myData[index]._allDay+"    +++++  "+val0+"  rrule-!"+myData[index]._rule+"!"+helpi)
                      //////////// IST GERADE AM LAUFEN - anderes Format 
                             if ( myData[index].date.includes("&#8594;") && myData[index].rule!=" " && myData[index].date.includes(":") ) {val1=ganzTaegigAusdruck;                                 val2=formatDate(getDateObject(myData[index]._date), "DD.MM.YYYY")} 
                             if ( val2.includes("&#8594;") && !myData[index]._allDay )                                      {val1=ganzTaegigAusdruck;                                 val2=formatDate(getDateObject(myData[index]._date), "DD.MM.YYYY")}       
                              if ( myData[index].date.includes("&#8594;") && myData[index].rule!=" " && !myData[index].date.includes("00:00") )                     {val1=val2help.replace(/.+? .+? (.+)/, bisVariable+"$1"); val2=formatDate(getDateObject(myData[index]._date), "DD.MM.YYYY")}
                            //  log("val1 : "+val1+"  val2: "+val2)
                              
                      /////////// HEUTE       
                             // log(formatDate(getDateObject(myData[index]._date), "DD.MM") +"   "+ formatDate(getDateObject((new Date().getTime())), "DD.MM"))
                              if (formatDate(getDateObject(myData[index]._date), "DD.MM") == formatDate(getDateObject((new Date().getTime())), "DD.MM") ) {
                                     val3help=true;        //FARBE HEUTE       
                                     
                                     val4=0;               // TAGE HEUTE  
                      ////////// AB MORGEN               
                              } else{
                                    let val44help=Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000
                                   // log(val44help.toString())
                       
                                    val4=Math.ceil(Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000 )-1
                                  //  log((Number(formatDate(getDateObject(myData[index]._date), "hh"))*60) + Number(formatDate(getDateObject(myData[index]._date), "mm")).toString() +"--------"+(Number(formatDate(getDateObject((new Date().getTime())), "hh"))*60) + Number(formatDate(getDateObject((new Date().getTime())), "mm")).toString())
                                    if (   (Number(formatDate(getDateObject(myData[index]._date), "hh"))*60) + Number(formatDate(getDateObject(myData[index]._date), "mm"))  <  (Number(formatDate(getDateObject((new Date().getTime())), "hh"))*60) + Number(formatDate(getDateObject((new Date().getTime())), "mm")) ) 
                                           {if(!myData[index]._date.includes("&#8594;")) val4=Math.ceil(Math.floor( ((new Date(myData[index]._date).getTime() - new Date().getTime())/60/60/24) )/1000 );
                                        //   log(myData[index].date.replace(/.*? (01\:00\-00\:00)/,"$1"))
                                          // if(myData[index].date.replace(/.*? (01\:00\-00\:00)/,"$1")=="01:00-00:00") val1=ganzTaegigAusdruck;
                                          if(myData[index].date.includes("01:00-00:00")) val1=ganzTaegigAusdruck
                                           }
                                    }
                       
                              val3=formatDate(getDateObject(myData[index]._date), "W")
                             if (myData[index]._rule==" rrule " && wiederholAnzeige) val0=val0+" &#8595;"
                       
                              if (val4.toString()=="0") val4=ersetze0MitWert;
                              if (val4.toString()=="1") val4=ersetze1MitWert;
                       
                             
                               let istSonderfarbe=false;
                               let val01=val0; let val02=val2; let val03=val3; let val04=val4; let val11=val1;
                               if (mySonderFarbeArr.length>0 ){ for(let myind in mySonderFarbeArr){if(val0.includes(mySonderFarbeArr[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbol+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }   
                               if (mySonderFarbeArrRiko.length>0 ){ for(let myind in mySonderFarbeArrRiko){if(val0.includes(mySonderFarbeArrRiko[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolRiko+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }   
                              if (mySonderFarbeArrTUEV.length>0 ){ for(let myind in mySonderFarbeArrTUEV){if(val0.includes(mySonderFarbeArrTUEV[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolTUEV+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }                                          
                              if (mySonderFarbeArrErnte.length>0 ){ for(let myind in mySonderFarbeArrErnte){if(val0.includes(mySonderFarbeArrErnte[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolErnte+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }      
                              if (mySonderFarbeArrArzt.length>0 ){ for(let myind in mySonderFarbeArrArzt){if(val0.includes(mySonderFarbeArrArzt[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolArzt+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }      
                              if (mySonderFarbeArrUrlaub.length>0 ){ for(let myind in mySonderFarbeArrUrlaub){if(val0.includes(mySonderFarbeArrUrlaub[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolUrlaub+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }      
                             if (mySonderFarbeArrConny.length>0 ){ for(let myind in mySonderFarbeArrConny){if(val0.includes(mySonderFarbeArrConny[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolConny+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }                                             
                             if (mySonderFarbeArrRebecca.length>0 ){ for(let myind in mySonderFarbeArrRebecca){if(val0.includes(mySonderFarbeArrRebecca[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolRebecca+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }      
                             if (mySonderFarbeArrGeburtstag.length>0 ){ for(let myind in mySonderFarbeArrGeburtstag){if(val0.includes(mySonderFarbeArrGeburtstag[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolGeburtstag+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }                                            
                            if (mySonderFarbeArrWichtig.length>0 ){ for(let myind in mySonderFarbeArrWichtig){if(val0.includes(mySonderFarbeArrWichtig[myind]) ){
                                                                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val03+"<\/"+styleEinTagHTML+">";
                                                                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val04+"<\/"+styleEinTagHTML+">";
                                                                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val11+"<\/"+styleEinTagHTML+">";
                                                                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+"</font>"+val02+"<\/"+styleEinTagHTML+">";  // val0="<font color=\""+mySonderFarbe +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                                                                  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbolWichtig+"</font>"+val01+"<\/"+styleEinTagHTML+">"
                                                                                  istSonderfarbe=true;
                                                                                  }}
                                                             }      
                                 //istSonderfarbe=false                           
                                 //console.log(myData[index]._calColor); -> Farbcode
                              if(val3help && sortedByInstanz ){
                                  val3="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val03+"<\/"+styleEinTagHTML+">";
                                  val4="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val04+"<\/"+styleEinTagHTML+">";
                                  val1="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val11+"<\/"+styleEinTagHTML+">";
                                  val2="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val02+"<\/"+styleEinTagHTML+">";
                                 !istSonderfarbe ?  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val0+"<\/"+styleEinTagHTML+">" : val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                   } 
                              if (val3help && !sortedByInstanz ){
                                       val3="<font color=\""+myData[0]._calColor +"\"><"+styleEinTagHTML+">"+val03+"<\/"+styleEinTagHTML+">";
                                       val4="<font color=\""+myData[0]._calColor  +"\"><"+styleEinTagHTML+">"+val04+"<\/"+styleEinTagHTML+">";
                                       val1="<font color=\""+myData[0]._calColor  +"\"><"+styleEinTagHTML+">"+val11+"<\/"+styleEinTagHTML+">";
                                       val2="<font color=\""+myData[0]._calColor  +"\"><"+styleEinTagHTML+">"+val02+"<\/"+styleEinTagHTML+">";
                                  !istSonderfarbe ?  val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+val0+"<\/"+styleEinTagHTML+">" : val0="<font color=\""+myData[index]._calColor +"\"><"+styleEinTagHTML+">"+mySonderSymbol+val01+"<\/"+styleEinTagHTML+">"
                                   } 
                       
                           
                       
                             oldID= myData[index].myIDID
                       
                             matDes(val3help,myData[index]._calColor);
                       
                        
                         
                           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 der schleife------------------------------------------------------------------------------
                      //-------------------------------------------------------------------------------------------------------------------------------------------------
                       
                            tabelleFinish(); // AB HIER NICHTS ÄNDERN - tabelle fertigstellen
                                         setState(dpTerminRunning,inDpRunning2)
                                         setState(dpTerminNext,inDpNext)
                                         setState(dpTerminNextGanzerTag,inDpGanzTag);
                      } // function ende
                       
                      //MAIN:
                       
                      schedule(mySchedule3,  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:  if(counter%2==0) {  htmlOut=htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>"; break; } else
                                                        {  htmlOut=htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>"; break; } 
                             
                              case 2: if(counter%4==0){
                                         if(counter%2==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"  align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                    else {htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>";} break;
                                     }else{
                                                    if(counter%2==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                    else {htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val4+"</td></tr>";} break;}
                                                         
                              case 3:  if(counter%2==0)   {
                                       if(counter%3==0 )  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                    else { if(counter%3==1 )  { htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\" color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                     else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>";}
                                                               } break;} else{
                                       if(counter%3==0 )  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>"; } 
                                                    else { if(counter%3==1 )  { htmlOut = htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                     else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td align="+Feld5lAlign+">"+val4+"</td></tr>";}
                                                               } break; }
                       
                              case 4:  if(counter%8==0)   {
                                       if(counter%4==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeGeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val4+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val3+"</td>"; } 
                                                        else {if(counter%4==1 )  { htmlOut = htmlOut+"<td  align="+Feld1lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                     else    {if(counter%4==3)  { htmlOut= htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val4+"</td></tr>";} 
                                                                                       else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>";}}
                                                               } break;} else{
                                       if(counter%4==0)  {htmlOut = htmlOut+"<tr bgcolor=\""+farbeUngeradeZeilen+"\"><td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val3+"</td>"; } 
                                                        else {if(counter%4==1 )  { htmlOut = htmlOut+"<td  align="+Feld1lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td  align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val4+"</td>";} 
                                                                     else    {if(counter%4==3)  { htmlOut= htmlOut+"<td align="+Feld1lAlign+"  style=\"color:"+htmlFarbFelderschrift2+"\">"+val0+"</td><td  align="+Feld2lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val1+"</td><td align="+Feld3lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val3+"</td><td align="+Feld5lAlign+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val4+"</td></tr>";} 
                                                                                       else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+" >"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\" align="+Feld5lAlign+">"+val4+"</td>";}}
                                                               } break; }
                       
                           } //switch ende
                       
                       
                       
                      }
                       
                      function tabelleFinish() {
                       
                            // tabelle fertigstellen
                      switch (mehrfachTabelle) {  
                             case 1:    break;
                       
                             case 2:    
                                        if(counter%2==0)  htmlOut = htmlOut.replace(/<\/td>$/, '</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>');
                                      
                                        break;
                       
                             case 3:   if(counter%3==2)  htmlOut = htmlOut.replace(/<\/td>$/, "</td></tr>");
                                       if(counter%3==1)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");        
                                       if(counter%3==0)      htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");
                                     
                                        break;
                             case 4:   if(counter%4==3)  htmlOut = htmlOut.replace(/<\/td>$/, "</td></tr>");
                                       if(counter%4==2)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");
                                       if(counter%4==1)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");    
                                       if(counter%4==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&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: "+htmlUeberFontGroesse+"; 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>"
                       
                       if (!htmlSignature) htmlUnter="";
                      var htmlEnd="</table>"+htmlUnter+"</div></body>";
                       //mit oder ohne überschrift - zentriert oder links
                      htmlUberschrift ? htmlOut=htmlStart+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd : htmlOut=htmlStart+htmlTabStyle+htmlTabUeber+htmlOut+htmlEnd;
                       //log(htmlOut);
                       
                      if (braucheMaterialDesignWidget) {
                           
                             setState(dpMaterialWidget,JSON.stringify(myJsonWidget2)); 
                             myJsonWidget2=[];
                      }
                      if (braucheMaterialDesignWidgetTable) {
                        
                        setState(dpMaterialWidgetTable,JSON.stringify(myJsonWidget)); 
                           myJsonWidget=[];
                      }
                      }
                       
                       
                       
                       
                      function makeJsonWidget(vax1,vax2,vax3,vax4,vax44,vax5) {
                      //log(vax5+vax3)
                      
                         if ( braucheMaterialDesignWidgetTable) {
                        myJsonWidget.push({
                          /*  Originaleinträge  abgeändert RRO
                            Event : vax1,
                            Zeit : vax2,
                            Datum : vax3,
                            W_tag : vax4, 
                            Tage : vax44
                           */
                            W_tag : vax4, 
                            Datum : vax3,
                            Zeit : vax2,
                            Event : vax1,
                            Tage : vax44
                        }
                       
                        );}
                       
                      //	log(myJsonWidget)
                      if (braucheMaterialDesignWidget) {
                      let mysubText = `<div style="display: flex; flex-direction: row; line-height: 1.3; padding-left: 1px; padding-right: 8px; align-items: center;">
                                      <div style="flex: 1;">${vax4}</div>
                                      <div style="color: black; font-size: 18px; font-family: RobotoCondensed-LightItalic; text-align: right;">${vax3}</div>
                                      </div>`
                             if(vax3<=1)   vax5=farbeNurEinTag               
                        
                           myJsonWidget2.push({
                                     text: vax2,
                                     subText: mysubText,
                                     statusBarColor: vax5,
                                     image: vax1,
                                     imageColor: "",
                                     listType: "text",
                                     showValueLabel: false,
                                     name: vax2,
                                     status: vax3,
                                     Wert : vax3,
                                     Hersteller : vax4
                                 });
                      }
                       }
                       
                      on({id: dpTSJson, change: "ne"}, function (obj) { 
                             //log(getState(dpANLEGEN).val+"----refresh");
                           
                             var timeout2 = setTimeout(function () {
                               
                         writeHTML();
                        
                          }, 1500);
                      });
                       
                      function matDes(val3help,color) {
                          if (braucheMaterialDesignWidget || braucheMaterialDesignWidgetTable) {
                                  if(val3help && sortedByInstanz){json5=color;}
                                  if (val3help && !sortedByInstanz){}
                                 json1=val0; json2=val1; json3=val2; json4=val3;json44=val4;json5=farbeStandardBar;
                                  makeJsonWidget(json1,json2,json3,json4,json44,json5);
                      }
                      };
                       
                       
                      
                      liv-in-skyL Offline
                      liv-in-skyL Offline
                      liv-in-sky
                      schrieb am zuletzt editiert von liv-in-sky
                      #11

                      @rosi8818 sagte in wie vorgehen JavaScript Update mit vielen Script Fehlern:

                      zeile 233 muss so sein:

                         let myDpInput=getState(dpTSJson[i]).val
                      

                      Image 1.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

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

                        @rosi8818 sagte in wie vorgehen JavaScript Update mit vielen Script Fehlern:

                        zeile 233 muss so sein:

                           let myDpInput=getState(dpTSJson[i]).val
                        

                        Image 1.png

                        R Offline
                        R Offline
                        Rosi8818
                        schrieb am zuletzt editiert von Rosi8818
                        #12

                        @liv-in-sky , wow so schnell... hab es eingesetzt und neu gestartet, jetzt ohne Fehler. Zu mindestens sehe ich keine mehr.
                        Gibt es einen Grund warum das mit der Version 5.1.3 noch lief und jetzt nicht mehr?
                        Ich bin nicht der Experte möchte nur ganz grob verstehen wenn man das grob erklären kann.

                        ich synce gerade mein Outlook und anschl. die Adapter, mal sehen ob er den neuen Kalendereintrag übernimmt. ich sage hier bescheid

                        liv-in-skyL 1 Antwort Letzte Antwort
                        0
                        • R Rosi8818

                          @liv-in-sky , wow so schnell... hab es eingesetzt und neu gestartet, jetzt ohne Fehler. Zu mindestens sehe ich keine mehr.
                          Gibt es einen Grund warum das mit der Version 5.1.3 noch lief und jetzt nicht mehr?
                          Ich bin nicht der Experte möchte nur ganz grob verstehen wenn man das grob erklären kann.

                          ich synce gerade mein Outlook und anschl. die Adapter, mal sehen ob er den neuen Kalendereintrag übernimmt. ich sage hier bescheid

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

                          @rosi8818

                          weil auch gleichzeitig der ical adapter seine daten neu schrieb, kam es für 1-3 wochen zu diesem problem, weil der js-controller auch die daten anders gelesen hat - aber so funktioniert es und wird wohl auch so bleiben

                          je nachdem, was man upgedatet hatte, mußten die daten unterschiedlich gelesen werden

                          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

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

                            @rosi8818

                            weil auch gleichzeitig der ical adapter seine daten neu schrieb, kam es für 1-3 wochen zu diesem problem, weil der js-controller auch die daten anders gelesen hat - aber so funktioniert es und wird wohl auch so bleiben

                            je nachdem, was man upgedatet hatte, mußten die daten unterschiedlich gelesen werden

                            R Offline
                            R Offline
                            Rosi8818
                            schrieb am zuletzt editiert von Rosi8818
                            #14

                            @liv-in-sky danke, das leuchtet ein... dann mach ich ich mal an die nächsten Problem die im Logfile stehen

                            dieses Problem ist gelöst und der Kalendereintrag schon mal in der VIS aufgetaucht. Super

                            liv-in-skyL 1 Antwort Letzte Antwort
                            0
                            • R Rosi8818

                              @liv-in-sky danke, das leuchtet ein... dann mach ich ich mal an die nächsten Problem die im Logfile stehen

                              dieses Problem ist gelöst und der Kalendereintrag schon mal in der VIS aufgetaucht. Super

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

                              @rosi8818 wenn du keine weiteren ical dp in irgendeinem script ausliest, wird dieser fehler nicht nochmal vorkommen :-)

                              viel spaß

                              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

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

                                @rosi8818 wenn du keine weiteren ical dp in irgendeinem script ausliest, wird dieser fehler nicht nochmal vorkommen :-)

                                viel spaß

                                R Offline
                                R Offline
                                Rosi8818
                                schrieb am zuletzt editiert von
                                #16

                                @liv-in-sky nein habe ich nicht, Danke nochmal...

                                1 Antwort Letzte Antwort
                                0

                                Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

                                Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

                                Mit deinem Input könnte dieser Beitrag noch besser werden 💗

                                Registrieren Anmelden
                                Antworten
                                • In einem neuen Thema antworten
                                Anmelden zum Antworten
                                • Älteste zuerst
                                • Neuste zuerst
                                • Meiste Stimmen


                                Support us

                                ioBroker
                                Community Adapters
                                Donate
                                FAQ Cloud / IOT
                                HowTo: Node.js-Update
                                HowTo: Backup/Restore
                                Downloads
                                BLOG

                                588

                                Online

                                32.9k

                                Benutzer

                                83.0k

                                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