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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Emails empfangen.

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.1k

Emails empfangen.

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
119 Beiträge 31 Kommentatoren 23.0k Aufrufe 28 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • liv-in-skyL liv-in-sky

    @M-A-X
    sendintent - habe ich noch nicht gerafft - was startet der ? den browser ?

    dann sollte tasker aber auch einen http get an iobroker wegbekommen

    M Offline
    M Offline
    M-A-X
    schrieb am zuletzt editiert von M-A-X
    #72

    @liv-in-sky
    Oh man ich schmeiße alles durch einander. Natürlich mit nem GET http request.
    Ich versuche es gerade hier zu testen mit nem 'warte 5 Sekunden' vorher, damit ich das handy sperren kann, aber das klappt nicht. Muss es nochmal versuchen wenn ich die homezone verlasse.

    Edit: ich war dumm. Hatte den state nicht geändert, sodass meine Bedingung nicht getriggert wurde. Es klappt jetzt. Vielen Dank

    Edit2: habe es übrigens nie nur mit tasker (ohne Autolocation) hin bekommen. Der gps Bereich trigger von tasker war extrem unzuverlässig

    liv-in-skyL 1 Antwort Letzte Antwort
    0
    • M M-A-X

      @liv-in-sky
      Oh man ich schmeiße alles durch einander. Natürlich mit nem GET http request.
      Ich versuche es gerade hier zu testen mit nem 'warte 5 Sekunden' vorher, damit ich das handy sperren kann, aber das klappt nicht. Muss es nochmal versuchen wenn ich die homezone verlasse.

      Edit: ich war dumm. Hatte den state nicht geändert, sodass meine Bedingung nicht getriggert wurde. Es klappt jetzt. Vielen Dank

      Edit2: habe es übrigens nie nur mit tasker (ohne Autolocation) hin bekommen. Der gps Bereich trigger von tasker war extrem unzuverlässig

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

      @M-A-X

      richtig testen kannst du wahrscheinlich nur, wenn das handy mal längere zeit nicht aktiv war - du wirst dir wohl einen anderen trigger überlegen müssen, sonst fragen sich die nachbarn, warum der kerl solange da steht :-)

      ich kenne das aber gut - habe trigger wenn whatsapp kommt und soll dann auf vis angezeigt werden - auch bei mir funktioniert das nicht immer, weil das handy manchmal nicht aufwacht, wenn eine whatsapp kommt - funktioniert mit ca 80-90 % zuverlässigkeit

      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

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

        @M-A-X

        richtig testen kannst du wahrscheinlich nur, wenn das handy mal längere zeit nicht aktiv war - du wirst dir wohl einen anderen trigger überlegen müssen, sonst fragen sich die nachbarn, warum der kerl solange da steht :-)

        ich kenne das aber gut - habe trigger wenn whatsapp kommt und soll dann auf vis angezeigt werden - auch bei mir funktioniert das nicht immer, weil das handy manchmal nicht aufwacht, wenn eine whatsapp kommt - funktioniert mit ca 80-90 % zuverlässigkeit

        M Offline
        M Offline
        M-A-X
        schrieb am zuletzt editiert von
        #74

        @liv-in-sky
        So. Habs getestet. Klappt recht gut. Leider habe ich bisher nur die kostenlose iobroker Version und jedes verlassen und betreten der zone zählt als Anfrage, sodass die 20 inklusivanfragen schnell aufgebraucht werden :) Muss wohl die pro Version her ;)

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

          @ilovegym

          habe dein script noch ein wenig aufgebohrt - ne tabelle - was sonst :-)

          Image 1.png

          bis jetzt kann man sortieren

          • wieviele mails angezeigt werden sollen
          • welche sender abgefragt werden sollen
          Master67M Offline
          Master67M Offline
          Master67
          schrieb am zuletzt editiert von Master67
          #75

          @liv-in-sky sagte in Emails empfangen.:

          @ilovegym

          habe dein script noch ein wenig aufgebohrt - ne tabelle - was sonst :-)

          Image 1.png

          bis jetzt kann man sortieren

          • wieviele mails angezeigt werden sollen
          • welche sender abgefragt werden sollen

          Das Script läuft, die Tabelle aber nicht, bin nicht so Fit in Vis (meine Vis ist nur Rudimentär) ich verstehe was ein "html-widget" ist aber nicht was ist mit "binding" gemeint ist!

          Gruß Master67

          liv-in-skyL 1 Antwort Letzte Antwort
          0
          • Master67M Master67

            @liv-in-sky sagte in Emails empfangen.:

            @ilovegym

            habe dein script noch ein wenig aufgebohrt - ne tabelle - was sonst :-)

            Image 1.png

            bis jetzt kann man sortieren

            • wieviele mails angezeigt werden sollen
            • welche sender abgefragt werden sollen

            Das Script läuft, die Tabelle aber nicht, bin nicht so Fit in Vis (meine Vis ist nur Rudimentär) ich verstehe was ein "html-widget" ist aber nicht was ist mit "binding" gemeint ist!

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

            @Master67 das binding bedeutet, dass in der vis anstatt ein fester wert, ein inhalt eines datenpunktes angezeigt wird

            z.b die höhe eines widgets wird normalerweise als fester wert eingegeben. wenn du aber ein binding anstatt eines festen wertes einträgst, wird die höhe des widgets aus einem anderen datenpunkt ausgelesen - damit ist die ganze sache dynamischer, weil du die höhe individuell berechnene kannst

            im html widget wird durch binding gesagt, die vis soll sich den inhalt(wert) in einem datenpunkt holen - der datenpunkt wird durch das script definiert

            beispiel 1 : im html widget wird eine feste tabelle eingegeben - unflexibel:

            Image 1.png

            beispiel2: hier wird ein binding angewendet - eine geschweifte klammer um einen datenpunkt - damit ist der inhalt des widgets dynamisch - wird der dp geändert - wird der inhalt geändert

            Image 2.png

            das binding kann in fast jedem vis feld genutzt werden - schriftgröße, schriftart, widgethöhe, widgetbreite, .............
            es können sogar kleine berechnungen mit diesem binding gemacht werden

            hier mal ein beispiel, wie sich ein widget durch binding vertikal bewegen läßt - im binding wird noch eine kleine berechnung mit einem dp gemacht

            anim-gif8.gif

            Image 3.png

            {value:javascript.0.GETPROCESS.CPUIdleALL; value=Math.floor(290-(value*1.4))}
            

            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

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

              @Master67 das binding bedeutet, dass in der vis anstatt ein fester wert, ein inhalt eines datenpunktes angezeigt wird

              z.b die höhe eines widgets wird normalerweise als fester wert eingegeben. wenn du aber ein binding anstatt eines festen wertes einträgst, wird die höhe des widgets aus einem anderen datenpunkt ausgelesen - damit ist die ganze sache dynamischer, weil du die höhe individuell berechnene kannst

              im html widget wird durch binding gesagt, die vis soll sich den inhalt(wert) in einem datenpunkt holen - der datenpunkt wird durch das script definiert

              beispiel 1 : im html widget wird eine feste tabelle eingegeben - unflexibel:

              Image 1.png

              beispiel2: hier wird ein binding angewendet - eine geschweifte klammer um einen datenpunkt - damit ist der inhalt des widgets dynamisch - wird der dp geändert - wird der inhalt geändert

              Image 2.png

              das binding kann in fast jedem vis feld genutzt werden - schriftgröße, schriftart, widgethöhe, widgetbreite, .............
              es können sogar kleine berechnungen mit diesem binding gemacht werden

              hier mal ein beispiel, wie sich ein widget durch binding vertikal bewegen läßt - im binding wird noch eine kleine berechnung mit einem dp gemacht

              anim-gif8.gif

              Image 3.png

              {value:javascript.0.GETPROCESS.CPUIdleALL; value=Math.floor(290-(value*1.4))}
              
              Master67M Offline
              Master67M Offline
              Master67
              schrieb am zuletzt editiert von
              #77

              @liv-in-sky .... Danke für die Info..... aber da bin ich jetzt raus ;-)
              Das übersteigt das was ich mit "meiner" Vis und meinen Fähigkeiten machen kann!

              Gruß Master67

              liv-in-skyL 1 Antwort Letzte Antwort
              0
              • Master67M Master67

                @liv-in-sky .... Danke für die Info..... aber da bin ich jetzt raus ;-)
                Das übersteigt das was ich mit "meiner" Vis und meinen Fähigkeiten machen kann!

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

                @Master67 sorry wollt dich nicht abschrecken - aber das mit dem binding für die tabelle iist klar geworden - mehr brauchst du ja im moment nicht

                du nimmst deinen datenpunkt, welches das script schreibt und setzt ihn in geschweiften klammer in das widget

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

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

                  @Master67 sorry wollt dich nicht abschrecken - aber das mit dem binding für die tabelle iist klar geworden - mehr brauchst du ja im moment nicht

                  du nimmst deinen datenpunkt, welches das script schreibt und setzt ihn in geschweiften klammer in das widget

                  Image 2.png

                  Master67M Offline
                  Master67M Offline
                  Master67
                  schrieb am zuletzt editiert von
                  #79

                  @liv-in-sky sagte in Emails empfangen.:

                  @Master67 sorry wollt dich nicht abschrecken - aber das mit dem binding für die tabelle iist klar geworden - mehr brauchst du ja im moment nicht

                  du nimmst deinen datenpunkt, welches das script schreibt und setzt ihn in geschweiften klammer in das widget

                  Image 2.png

                  Japp habe ich versucht und sieht "Bescheiden" aus :-)

                  <table>
                    <tr>
                      <td>Absender:</td>      
                      <td align="right"><b>{  javascript.0.Email-Forum.from_address}</b></td>
                    </tr>      
                    <tr>
                      <td>Betreff:</td>      
                      <td align="right"><b>{ javascript.0.Email-Forum.mail_subject}</b></td>
                    </tr>   
                    <tr>
                      <td>Inhalt:</td>      
                      <td align="right"><b>{ javascript.0.Email-Forum.mail_text}</b></td>
                    </tr>     
                  </table>
                  

                  Gruß Master67

                  liv-in-skyL 1 Antwort Letzte Antwort
                  0
                  • Master67M Master67

                    @liv-in-sky sagte in Emails empfangen.:

                    @Master67 sorry wollt dich nicht abschrecken - aber das mit dem binding für die tabelle iist klar geworden - mehr brauchst du ja im moment nicht

                    du nimmst deinen datenpunkt, welches das script schreibt und setzt ihn in geschweiften klammer in das widget

                    Image 2.png

                    Japp habe ich versucht und sieht "Bescheiden" aus :-)

                    <table>
                      <tr>
                        <td>Absender:</td>      
                        <td align="right"><b>{  javascript.0.Email-Forum.from_address}</b></td>
                      </tr>      
                      <tr>
                        <td>Betreff:</td>      
                        <td align="right"><b>{ javascript.0.Email-Forum.mail_subject}</b></td>
                      </tr>   
                      <tr>
                        <td>Inhalt:</td>      
                        <td align="right"><b>{ javascript.0.Email-Forum.mail_text}</b></td>
                      </tr>     
                    </table>
                    
                    liv-in-skyL Offline
                    liv-in-skyL Offline
                    liv-in-sky
                    schrieb am zuletzt editiert von
                    #80

                    @Master67
                    achso - ich dacht du nutzt das script hier :

                    https://forum.iobroker.net/topic/36558/html-tabelle-für-email-postfach

                    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

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

                      @Master67
                      achso - ich dacht du nutzt das script hier :

                      https://forum.iobroker.net/topic/36558/html-tabelle-für-email-postfach

                      Master67M Offline
                      Master67M Offline
                      Master67
                      schrieb am zuletzt editiert von
                      #81

                      @liv-in-sky sagte in Emails empfangen.:

                      @Master67
                      achso - ich dacht du nutzt das script hier :

                      https://forum.iobroker.net/topic/36558/html-tabelle-für-email-postfach

                      Japp.... aber irgendwie muss ich ja die Infos in die Vis bekommen :-)

                      Gruß Master67

                      1 Antwort Letzte Antwort
                      0
                      • D3ltoroxpD Offline
                        D3ltoroxpD Offline
                        D3ltoroxp
                        schrieb am zuletzt editiert von
                        #82

                        So ich habe auch für mir E-Mails in der VIS anzeigen zu lassen, oder zumindest Nachrichten zukommen zu lassen. Habe div. Tools im Lokalen Netzwerk, die mir bei Aktionen und Statusänderungen Mails senden können. Diese würde ich gerne in ioB in einen DP Punk schreiben lassen, damit ich sie in der VIS anzeigen lassen kann.

                        Ich habe dazu diesen Thread gefunden.

                        Ich gehe wie folgt vor ?

                        npm install mail-listener4
                        

                        Mail-Listener4 im Java Adapter mit eintragen
                        In dem anderen Thread stehen noch Settings die wohl zum mail listener 4 gehören, wie komm ich da ran ?

                        Könnte ich hierzu auch noch einen lokalen Mailserver aufsetzten, womit ich nur lokal Infos senden und empfangen kann ? So muss das nicht über einen Fremdserver laufen, muss ja nicht jeder wissen über was ich mich so informieren lasse und wann man die Klospülung betätigt wird :grin:

                        Das Script in ein neu erstelltest Java Script importieren und anpassen ?

                        1 Antwort Letzte Antwort
                        0
                        • Salzer MichaelS Offline
                          Salzer MichaelS Offline
                          Salzer Michael
                          schrieb am zuletzt editiert von
                          #83

                          Hallöle liebes Forum

                          Hab mich ein wenig Versucht am E-Mail empfang.
                          Der funktioniert auch
                          nun wollte ich diese Tabelle in der VIS aktivieren.
                          c9a070fb-48b6-4293-a6f5-12092e782800-image.png

                          Ich hab aber das Problem das bei "Betreff" der Text nicht richtig angezeigt wird.
                          Hat wer ne Idee warum ?

                          liv-in-skyL Salzer MichaelS 2 Antworten Letzte Antwort
                          0
                          • Salzer MichaelS Salzer Michael

                            Hallöle liebes Forum

                            Hab mich ein wenig Versucht am E-Mail empfang.
                            Der funktioniert auch
                            nun wollte ich diese Tabelle in der VIS aktivieren.
                            c9a070fb-48b6-4293-a6f5-12092e782800-image.png

                            Ich hab aber das Problem das bei "Betreff" der Text nicht richtig angezeigt wird.
                            Hat wer ne Idee warum ?

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

                            @salzer-michael

                            denke mal, du nutzt die variablen für das regex falsch - poste doch mal dein setting des scriptes

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

                            1 Antwort Letzte Antwort
                            0
                            • Salzer MichaelS Salzer Michael

                              Hallöle liebes Forum

                              Hab mich ein wenig Versucht am E-Mail empfang.
                              Der funktioniert auch
                              nun wollte ich diese Tabelle in der VIS aktivieren.
                              c9a070fb-48b6-4293-a6f5-12092e782800-image.png

                              Ich hab aber das Problem das bei "Betreff" der Text nicht richtig angezeigt wird.
                              Hat wer ne Idee warum ?

                              Salzer MichaelS Offline
                              Salzer MichaelS Offline
                              Salzer Michael
                              schrieb am zuletzt editiert von
                              #85

                              @salzer-michael

                              Script:
                              //@liv-in-sky 2020 5.9.20-10:42

                              var maillistenerSetting = {
                              username: "*@gmail.com", // hier Email Adresse eintragen
                              password: "
                              ", // hier Passwort eintragen
                              host: "imap.gmail.com",
                              port: 993, // imap port
                              tls: true,
                              connTimeout: 10000, // Default by node-imap
                              authTimeout: 5000, // Default by node-imap,
                              debug: null, // Or your custom function with only one incoming argument. Default: null
                              tlsOptions: { rejectUnauthorized: false },
                              mailbox: "Inbox", // mailbox to monitor
                              searchFilter: ["ALL"], // the search filter being used after an IDLE notification has been retrieved
                              markSeen: false, // all fetched email willbe marked as seen and not fetched next time
                              fetchUnreadOnStart: true, // use it only if you want to get all unread email on lib start. Default is false,
                              mailParserOptions: {streamAttachments: true}, // options to be passed to mailParser lib.
                              attachments: false, // download attachments as they are encountered to the project directory
                              attachmentOptions: { directory: "attachments/" }}

                              //HIER WIRD PFAD UND FILENAME DEFINIERT
                              const path = "/stoerungsdienst.html"; //FIlenamen definieren
                              const home ='javascript.0' //wo soll das file im iobroker-file-system liegen ? (oder z.b auch iqontrol.meta)
                              let braucheEinVISWidget=true; // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile
                              //let dpVIS="javascript.0.Email-Stoerungsdienst.AAATEST.TestHTML" //WICHTIG wenn "braucheEinVISWidget" auf true gesetzt !! dp zusätzlich für VIS-HTML-Basic-Widget
                              let javascriptInstanzOrdner="javascript.0.Email-Stoerungsdienst" // unterordner unter genutzter javascript-instanz z.b. javascript.0.Email-Serien
                              let mySchedule=" */1 * * * * "; //nicht unter eine minute einstellen !!!!!!!
                              var styleUeber="span" // oder "i" oder "b"
                              var farbeUeber="lightblue" // farbe für mails vom heutiger tag
                              var mitSeqnu=true; // zeigt email nummer an vor Absender
                              var wichtigeMails=[] //["iobroker3@online.de","no-personal@online.de"]// oder wenn leer == ALLE ==> [] -> whiteList Logic
                              var anzahlMails=10; // anzahl sichtbarer mails in tabelle
                              var kuerzungSubject=35;
                              var kuerzungText=120;
                              var myRegex=/[ (ioB)roker(.+)].+/; // erstes Regex für Subject - "" für leer
                              var myRegexErsetzen="$1 $2"; // erstes Regex Subject Ersetzen mit - "" für leer
                              var myRegex2=/[|] .+/g; // zweites Regex für Subject - "" für leer
                              var myRegex2Ersetzen=""; // zweites Regex Subject Ersetzen mit - "" für leer
                              var myRegex3=/\n/g; // erstes Regex für Text - "" für leer
                              var myRegex3Ersetzen="" ; // erstes Regex Text Ersetzen mit - "" für leer
                              var myRegex4=/(.+?) hat auf (.+?) (geantwortet)..+/gm; // zweites Regex für Text - "" für leer
                              var myReg4Ersetzen=" <b>REPLY</b>: $1 - $2"; // zweites Regex Text Ersetzen mit - "" für leer
                              var myRegex5=/(.+?) hat deinen Beitrag (.+?) (positiv bewertet)..+/gm; // drittes Regex für Text - "" für leer
                              var myReg5Ersetzen=" <b>POSITIV</b>: $1 - $2"; // drittes Regex Text Ersetzen mit - "" für leer
                              var myRegex6=/(ioB)roker(.+)/; // erstes Regex für Absender - "" für leer
                              var myRegex6Ersetzen="$1 $2" ; // erstes Regex Absender Ersetzen mit - "" für leer
                              //---------------------------------------

                              //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 4
                              var htmlFeld1='Von'; var Feld1lAlign="left"; // überschrift Tabellen Spalte1 und Ausrichtung left,right or center
                              var htmlFeld2=' Betreff '; var Feld2lAlign="left"; // ü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='Inhalt'; var Feld4lAlign="left"; // überschrift Tabellen Spalte4 und Ausrichtung left,right or center
                              //-----------------------------------

                              //ÜBERSCHRIFT ÜBER TABELLE
                              let htmlUberschrift=true; // mit Überschrift über der tabelle
                              let htmlSignature=false; // anstatt der Überscghrift eine signature: - kleiner - anliegend
                              const htmlFeldUeber='E-Mails: BG Störungsdienst'; // Überschrift und Signature
                              const htmlFarbUber="white"; // Farbe der Überschrift
                              const htmlSchriftWeite="normal"; // bold, normal - Fettschrift für Überschrift
                              const htmlÜberFontGroesse="18px"; // schriftgröße überschrift
                              //MEHRERE TABELLEN NEBENEINANDER
                              let mehrfachTabelle=1; // bis zu 4 Tabellen werden nebeneinander geschrieben- verkürzt das Ganze, dafür etwas breiter - MÖGLICH 1,2,3,oder 4 !!!
                              const trennungsLinie="2"; //extra trennungslinie bei mehrfachtabellen - evtl auf 0 stellen, wnn htmlRahmenLinien auf none sind
                              const farbetrennungsLinie="white";
                              const htmlFarbZweiteTabelle="white"; // Farbe der Überschrift bei jeder 2.ten Tabelle
                              const htmlFarbTableColorUber="#BDBDBD"; // Überschrift in der tabelle - der einzelnen Spalten
                              //ÜBERSCHRIFT SPALTEN
                              const UeberSchriftHöhe="35"; //Überschrift bekommt mehr Raum - darunter und darüber - Zellenhöhe
                              const LinieUnterUeberschrift="3"; // Linie nur unter Spaltenüberschrift -
                              const farbeLinieUnterUeberschrift="white";
                              const groesseUeberschrift=16;
                              const UeberschriftStyle="normal" // möglich "bold"
                              //GANZE TABELLE
                              let abstandZelle=6;
                              let farbeUngeradeZeilen="#000000"; //Farbe für ungerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2
                              let farbeGeradeZeilen="#333333"; //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="Helvetica";
                              const htmlSchriftgroesse="14px";
                              //FELDER UND RAHMEN
                              let UeberschriftSpalten=true; // ein- oder ausblenden der spatlen-überschriften
                              const htmlFarbFelderschrift="#BDBDBD"; // SchriftFarbe der Felder
                              const htmlFarbFelderschrift2="#D8D8D8"; // SchriftFarbe der Felder für jede 2te Tabelle
                              const htmlFarbTableColorGradient1="#424242"; // Gradient - Hintergrund der Tabelle - Verlauffarbe
                              const htmlFarbTableColorGradient2="#424242"; // Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
                              const htmlFarbTableBorderColor="grey"; // Farbe des Rahmen - is tdieser gleich den gradienten, sind die rahmen unsichtbar
                              let htmlRahmenLinien="none"; // 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 "auto";

                              // 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=""+UeberSchriftHöhe+"" 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 4

                              var htmlTabUeber2="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+"> "+htmlFeld1+" </td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+"> "+htmlFeld2+" </td><td align="+Feld3lAlign+"> "+htmlFeld3+" </td><td align="+Feld4lAlign+"> "+htmlFeld4+" </td>";
                              var htmlTabUeber2_1="<td width="+htmlSpalte1Weite+" align=="+Feld1lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld1+" </td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld2+
                              " </td><td align=="+Feld3lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld3+" </td><td align="+Feld4lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld4+
                              " </td>";
                              //------------------------------------------------------

                              let braucheEinFile=false; // bei true wird ein file geschrieben
                              var mailobj =[]
                              createState(javascriptInstanzOrdner+".Reception");
                              createState(javascriptInstanzOrdner+".from_address");
                              createState(javascriptInstanzOrdner+".from_name");
                              createState(javascriptInstanzOrdner+".mail_subject");
                              createState(javascriptInstanzOrdner+".mail_text");
                              createState(javascriptInstanzOrdner+".mail_date");
                              createState(javascriptInstanzOrdner+".Anzahl");
                              createState(javascriptInstanzOrdner+".Tabelle");
                              var htmlOut="";
                              var mix;
                              var counter;
                              var val1; var val2; var val0; var val3;
                              var htmlTabUeber="";

                              function writeHTML(){

                              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 !!!---------------------------------------------------------------------
                              //--------------------------------------------------------------------------------------------------------------------------------------------------

                              getMail().then( () =>{
                              // log("jetztttttttttttttttttttttttttttttttttttttttt")
                              setTimeout(function(){
                              // log("array= "+mailobj[0].from+"lang "+mailobj.length.toString())
                              if (mailobj.length>0) {
                              // log("jetzt2")
                              //log( "lang: " + mailobj.length.toString()+"string: "+mailobj.toString() )
                              setState(javascriptInstanzOrdner+ ".from_address", mailobj[mailobj.length-1].address);
                              setState(javascriptInstanzOrdner+ ".from_name", mailobj[mailobj.length-1].from);
                              setState(javascriptInstanzOrdner+ ".mail_subject", mailobj[mailobj.length-1].text); //.subject
                              setState(javascriptInstanzOrdner+ ".mail_text",mailobj[mailobj.length-1].text);
                              setState(javascriptInstanzOrdner+ ".mail_date", mailobj[mailobj.length-1].date);
                              setState(javascriptInstanzOrdner+ ".Anzahl", mailobj[mailobj.length-1].number);

                              mailobj.sort(function(a, b){
                              return b.date_num - a.date_num;
                              });

                              for (let i=0;i<mailobj.length;i++){

                                    mitSeqnu ? val0="("+mailobj[i].number+") "+ mailobj[i].from : val0=mailobj[i].from
                                    val0=val0.replace(myRegex6,myRegex6Ersetzen)
                                    val1=mailobj[i].subject //.substring(0,45)
                                     val1=val1.replace(/Ã"/g, "&Auml;")
                                     val1=val1.replace(/Ã"/g, "&Auml;")
                                     val1=val1.replace(/Ã"/g, "&Auml;")
                                     val1=val1.replace(/ä/g, "&auml;")
                                     val1=val1.replace(/Ü/g, "&Uuml;")
                                     val1=val1.replace(/ü/g, "&uuml;")
                                     val1=val1.replace(/Ã-/g, "&Ouml;")
                                     val1=val1.replace(/ö/g, "&ouml;")
                                     val1=val1.replace(/ß/g, "&szlig;")
                                      
                                    val2=  formatDate(getDateObject(((new Date(mailobj[i].date).getTime()))), "TT.MM.JJ - SS:mm")
                                    let  val22help=  formatDate(getDateObject(((new Date(mailobj[i].date).getTime()))), "TT.MM.JJ")
                                    let val2help=formatDate(getDateObject(((new Date().getTime()))), "TT.MM.JJ")
                                    
                                    val1=val1.replace(myRegex,myRegexErsetzen).substring(0,kuerzungSubject)
                                    val1=val1.replace(myRegex2,myRegex2Ersetzen)
                              
                                    val3=mailobj[i].text.trim().substring(0,kuerzungText)
                                    if (val3.includes("doctype")) val3="ersetzt: HTML Code"
                                    val3=val3.replace(myRegex3,myRegex3Ersetzen)
                                    val3=val3.replace(myRegex4,myReg4Ersetzen)        
                                    val3=val3.replace(myRegex5,myReg5Ersetzen)  
                              
                              
                                 if (val22help==val2help){
                                        
                                     val0= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val0
                                     val1= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val1
                                     val2= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val2
                                     val3= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val3
                                 }
                              
                              
                              if( i <= anzahlMails )  {
                               
                               if(wichtigeMails.length>0){
                                                         for (var aa=0 ;aa <wichtigeMails.length;aa++){
                                                             if(wichtigeMails[aa]==mailobj[i].address) {counter++;tabelleBind()};} //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                                         } else {counter++;tabelleBind()}
                                 }
                              

                              // }
                              } //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!

                              //-------------------------------------------------------------------------------------------------------------------------------------------------
                              //--------------------------------------------------Ende der schleife------------------------------------------------------------------------------
                              //-------------------------------------------------------------------------------------------------------------------------------------------------

                                tabelleFinish(); // AB HIER NICHTS ÄNDERN - tabelle fertigstellen
                                 }
                              

                              },13000);
                              })

                              } // function ende

                              //MAIN:

                              schedule(mySchedule, function () {
                              writeHTML();//log("jetz")
                              if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/ });}
                              });
                              //writeHTML();

                              function tabelleBind(){
                              //HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT - hat man oben 4 Felder definiert, braucht man hier 4 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></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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                              ";\"align="+Feld4lAlign+">"+val3+"</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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                              ";\" align="+Feld4lAlign+">"+val3+"</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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                  ";\" align="+Feld4lAlign+">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                  ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</td>";} 
                                                                         else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                  ";\" align="+Feld4lAlign+">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                  ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</td>";} 
                                                                         else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld4lAlign+">"+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=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ "color:"+htmlFarbFelderschrift2+"\">"+val3+"</td></tr>";} 
                                                                                           else    {htmlOut  = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld4lAlign+">"+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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</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+"  color:"+htmlFarbFelderschrift2+"\">"+val3+"</td></tr>";} 
                                                                                           else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"align="+Feld4lAlign+">"+val3+"</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></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></tr>');      
                                           if(counter%3==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</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></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></tr>");
                                           if(counter%4==1)  htmlOut = htmlOut.replace(/<\/td>$/, "</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></tr>");    
                                           if(counter%4==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");      
                                           break; } 
                              
                              
                                   var htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: "+htmlÜberFontGroesse+"; font-weight:"+htmlSchriftWeite+ "\">"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</p>"; 
                                 var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 70%; text-align: right;\" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</div>";
                                  
                                  if (!htmlSignature) htmlUnter="";
                                    //Ausgabe über VIS html widget - tabelle in datenpunkt schreiben - html tabelle ohne html header und body
                                     var htmlOutVIS="";
                                   //  htmlUberschrift ? htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>" : htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>";
                                      if (htmlUberschrift) 
                                          { zentriert ? htmlOutVIS=htmlZentriert+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter : htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter ;
                              
                                        } else {
                                         zentriert ?  htmlOutVIS=htmlZentriert+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter :  htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter;
                              
                                           }
                              

                              // log("bin raus aus tabelleBind");
                              if (braucheEinVISWidget) setState(javascriptInstanzOrdner+ ".Tabelle", htmlOutVIS );

                              var htmlUnter= "<div style="color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 80%; text-align: center; " >"+htmlFeldUeber+"  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);

                              }

                              async function getMail() { //log("start")
                              return new Promise(resolve => {
                              var MailListener = require("mail-listener4");
                              var mailListener = new MailListener(
                              maillistenerSetting
                              );
                              mailobj=[];
                              mailListener.start();
                              mailListener.on("server:connected", function(){/console.log("imapconconnected")/;});
                              mailListener.on("server:disconnected", function(){/console.log("imapDisconnected");/});
                              mailListener.on("error", function(err){console.log(err);});
                              mailListener.on("mail", function(mail, seqno, attributes){

                                let theName ="Unbekannt"
                                let theText="FEHLER beim Lesen oder leer"
                                 if (mail.from[0].name!="" && mail.from[0].name!=undefined && mail.from[0].name!=null)  theName=mail.from[0].name
                                 if (mail.text!="" && mail.text!=undefined && mail.text!=null)   theText=mail.text
                              //  log(mail.subject)
                                
                                 mailobj.push(
                                         {
                                             from:  theName,
                                             address: mail.from[0].address,    
                                             subject: mail.subject,
                                             text:  theText,
                                             date:  mail.date,
                                             date_num: new Date(mail.date).getTime(),
                                             number: seqno
                                         })
                              

                              });//log("fertig");

                                setTimeout(function(){mailListener.stop();resolve();},10000);
                              

                              }); //prom

                              }

                              Vielen Dank im vorraus

                              liv-in-skyL 2 Antworten Letzte Antwort
                              0
                              • Salzer MichaelS Salzer Michael

                                @salzer-michael

                                Script:
                                //@liv-in-sky 2020 5.9.20-10:42

                                var maillistenerSetting = {
                                username: "*@gmail.com", // hier Email Adresse eintragen
                                password: "
                                ", // hier Passwort eintragen
                                host: "imap.gmail.com",
                                port: 993, // imap port
                                tls: true,
                                connTimeout: 10000, // Default by node-imap
                                authTimeout: 5000, // Default by node-imap,
                                debug: null, // Or your custom function with only one incoming argument. Default: null
                                tlsOptions: { rejectUnauthorized: false },
                                mailbox: "Inbox", // mailbox to monitor
                                searchFilter: ["ALL"], // the search filter being used after an IDLE notification has been retrieved
                                markSeen: false, // all fetched email willbe marked as seen and not fetched next time
                                fetchUnreadOnStart: true, // use it only if you want to get all unread email on lib start. Default is false,
                                mailParserOptions: {streamAttachments: true}, // options to be passed to mailParser lib.
                                attachments: false, // download attachments as they are encountered to the project directory
                                attachmentOptions: { directory: "attachments/" }}

                                //HIER WIRD PFAD UND FILENAME DEFINIERT
                                const path = "/stoerungsdienst.html"; //FIlenamen definieren
                                const home ='javascript.0' //wo soll das file im iobroker-file-system liegen ? (oder z.b auch iqontrol.meta)
                                let braucheEinVISWidget=true; // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile
                                //let dpVIS="javascript.0.Email-Stoerungsdienst.AAATEST.TestHTML" //WICHTIG wenn "braucheEinVISWidget" auf true gesetzt !! dp zusätzlich für VIS-HTML-Basic-Widget
                                let javascriptInstanzOrdner="javascript.0.Email-Stoerungsdienst" // unterordner unter genutzter javascript-instanz z.b. javascript.0.Email-Serien
                                let mySchedule=" */1 * * * * "; //nicht unter eine minute einstellen !!!!!!!
                                var styleUeber="span" // oder "i" oder "b"
                                var farbeUeber="lightblue" // farbe für mails vom heutiger tag
                                var mitSeqnu=true; // zeigt email nummer an vor Absender
                                var wichtigeMails=[] //["iobroker3@online.de","no-personal@online.de"]// oder wenn leer == ALLE ==> [] -> whiteList Logic
                                var anzahlMails=10; // anzahl sichtbarer mails in tabelle
                                var kuerzungSubject=35;
                                var kuerzungText=120;
                                var myRegex=/[ (ioB)roker(.+)].+/; // erstes Regex für Subject - "" für leer
                                var myRegexErsetzen="$1 $2"; // erstes Regex Subject Ersetzen mit - "" für leer
                                var myRegex2=/[|] .+/g; // zweites Regex für Subject - "" für leer
                                var myRegex2Ersetzen=""; // zweites Regex Subject Ersetzen mit - "" für leer
                                var myRegex3=/\n/g; // erstes Regex für Text - "" für leer
                                var myRegex3Ersetzen="" ; // erstes Regex Text Ersetzen mit - "" für leer
                                var myRegex4=/(.+?) hat auf (.+?) (geantwortet)..+/gm; // zweites Regex für Text - "" für leer
                                var myReg4Ersetzen=" <b>REPLY</b>: $1 - $2"; // zweites Regex Text Ersetzen mit - "" für leer
                                var myRegex5=/(.+?) hat deinen Beitrag (.+?) (positiv bewertet)..+/gm; // drittes Regex für Text - "" für leer
                                var myReg5Ersetzen=" <b>POSITIV</b>: $1 - $2"; // drittes Regex Text Ersetzen mit - "" für leer
                                var myRegex6=/(ioB)roker(.+)/; // erstes Regex für Absender - "" für leer
                                var myRegex6Ersetzen="$1 $2" ; // erstes Regex Absender Ersetzen mit - "" für leer
                                //---------------------------------------

                                //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 4
                                var htmlFeld1='Von'; var Feld1lAlign="left"; // überschrift Tabellen Spalte1 und Ausrichtung left,right or center
                                var htmlFeld2=' Betreff '; var Feld2lAlign="left"; // ü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='Inhalt'; var Feld4lAlign="left"; // überschrift Tabellen Spalte4 und Ausrichtung left,right or center
                                //-----------------------------------

                                //ÜBERSCHRIFT ÜBER TABELLE
                                let htmlUberschrift=true; // mit Überschrift über der tabelle
                                let htmlSignature=false; // anstatt der Überscghrift eine signature: - kleiner - anliegend
                                const htmlFeldUeber='E-Mails: BG Störungsdienst'; // Überschrift und Signature
                                const htmlFarbUber="white"; // Farbe der Überschrift
                                const htmlSchriftWeite="normal"; // bold, normal - Fettschrift für Überschrift
                                const htmlÜberFontGroesse="18px"; // schriftgröße überschrift
                                //MEHRERE TABELLEN NEBENEINANDER
                                let mehrfachTabelle=1; // bis zu 4 Tabellen werden nebeneinander geschrieben- verkürzt das Ganze, dafür etwas breiter - MÖGLICH 1,2,3,oder 4 !!!
                                const trennungsLinie="2"; //extra trennungslinie bei mehrfachtabellen - evtl auf 0 stellen, wnn htmlRahmenLinien auf none sind
                                const farbetrennungsLinie="white";
                                const htmlFarbZweiteTabelle="white"; // Farbe der Überschrift bei jeder 2.ten Tabelle
                                const htmlFarbTableColorUber="#BDBDBD"; // Überschrift in der tabelle - der einzelnen Spalten
                                //ÜBERSCHRIFT SPALTEN
                                const UeberSchriftHöhe="35"; //Überschrift bekommt mehr Raum - darunter und darüber - Zellenhöhe
                                const LinieUnterUeberschrift="3"; // Linie nur unter Spaltenüberschrift -
                                const farbeLinieUnterUeberschrift="white";
                                const groesseUeberschrift=16;
                                const UeberschriftStyle="normal" // möglich "bold"
                                //GANZE TABELLE
                                let abstandZelle=6;
                                let farbeUngeradeZeilen="#000000"; //Farbe für ungerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2
                                let farbeGeradeZeilen="#333333"; //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="Helvetica";
                                const htmlSchriftgroesse="14px";
                                //FELDER UND RAHMEN
                                let UeberschriftSpalten=true; // ein- oder ausblenden der spatlen-überschriften
                                const htmlFarbFelderschrift="#BDBDBD"; // SchriftFarbe der Felder
                                const htmlFarbFelderschrift2="#D8D8D8"; // SchriftFarbe der Felder für jede 2te Tabelle
                                const htmlFarbTableColorGradient1="#424242"; // Gradient - Hintergrund der Tabelle - Verlauffarbe
                                const htmlFarbTableColorGradient2="#424242"; // Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
                                const htmlFarbTableBorderColor="grey"; // Farbe des Rahmen - is tdieser gleich den gradienten, sind die rahmen unsichtbar
                                let htmlRahmenLinien="none"; // 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 "auto";

                                // 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=""+UeberSchriftHöhe+"" 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 4

                                var htmlTabUeber2="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+"> "+htmlFeld1+" </td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+"> "+htmlFeld2+" </td><td align="+Feld3lAlign+"> "+htmlFeld3+" </td><td align="+Feld4lAlign+"> "+htmlFeld4+" </td>";
                                var htmlTabUeber2_1="<td width="+htmlSpalte1Weite+" align=="+Feld1lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld1+" </td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld2+
                                " </td><td align=="+Feld3lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld3+" </td><td align="+Feld4lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld4+
                                " </td>";
                                //------------------------------------------------------

                                let braucheEinFile=false; // bei true wird ein file geschrieben
                                var mailobj =[]
                                createState(javascriptInstanzOrdner+".Reception");
                                createState(javascriptInstanzOrdner+".from_address");
                                createState(javascriptInstanzOrdner+".from_name");
                                createState(javascriptInstanzOrdner+".mail_subject");
                                createState(javascriptInstanzOrdner+".mail_text");
                                createState(javascriptInstanzOrdner+".mail_date");
                                createState(javascriptInstanzOrdner+".Anzahl");
                                createState(javascriptInstanzOrdner+".Tabelle");
                                var htmlOut="";
                                var mix;
                                var counter;
                                var val1; var val2; var val0; var val3;
                                var htmlTabUeber="";

                                function writeHTML(){

                                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 !!!---------------------------------------------------------------------
                                //--------------------------------------------------------------------------------------------------------------------------------------------------

                                getMail().then( () =>{
                                // log("jetztttttttttttttttttttttttttttttttttttttttt")
                                setTimeout(function(){
                                // log("array= "+mailobj[0].from+"lang "+mailobj.length.toString())
                                if (mailobj.length>0) {
                                // log("jetzt2")
                                //log( "lang: " + mailobj.length.toString()+"string: "+mailobj.toString() )
                                setState(javascriptInstanzOrdner+ ".from_address", mailobj[mailobj.length-1].address);
                                setState(javascriptInstanzOrdner+ ".from_name", mailobj[mailobj.length-1].from);
                                setState(javascriptInstanzOrdner+ ".mail_subject", mailobj[mailobj.length-1].text); //.subject
                                setState(javascriptInstanzOrdner+ ".mail_text",mailobj[mailobj.length-1].text);
                                setState(javascriptInstanzOrdner+ ".mail_date", mailobj[mailobj.length-1].date);
                                setState(javascriptInstanzOrdner+ ".Anzahl", mailobj[mailobj.length-1].number);

                                mailobj.sort(function(a, b){
                                return b.date_num - a.date_num;
                                });

                                for (let i=0;i<mailobj.length;i++){

                                      mitSeqnu ? val0="("+mailobj[i].number+") "+ mailobj[i].from : val0=mailobj[i].from
                                      val0=val0.replace(myRegex6,myRegex6Ersetzen)
                                      val1=mailobj[i].subject //.substring(0,45)
                                       val1=val1.replace(/Ã"/g, "&Auml;")
                                       val1=val1.replace(/Ã"/g, "&Auml;")
                                       val1=val1.replace(/Ã"/g, "&Auml;")
                                       val1=val1.replace(/ä/g, "&auml;")
                                       val1=val1.replace(/Ü/g, "&Uuml;")
                                       val1=val1.replace(/ü/g, "&uuml;")
                                       val1=val1.replace(/Ã-/g, "&Ouml;")
                                       val1=val1.replace(/ö/g, "&ouml;")
                                       val1=val1.replace(/ß/g, "&szlig;")
                                        
                                      val2=  formatDate(getDateObject(((new Date(mailobj[i].date).getTime()))), "TT.MM.JJ - SS:mm")
                                      let  val22help=  formatDate(getDateObject(((new Date(mailobj[i].date).getTime()))), "TT.MM.JJ")
                                      let val2help=formatDate(getDateObject(((new Date().getTime()))), "TT.MM.JJ")
                                      
                                      val1=val1.replace(myRegex,myRegexErsetzen).substring(0,kuerzungSubject)
                                      val1=val1.replace(myRegex2,myRegex2Ersetzen)
                                
                                      val3=mailobj[i].text.trim().substring(0,kuerzungText)
                                      if (val3.includes("doctype")) val3="ersetzt: HTML Code"
                                      val3=val3.replace(myRegex3,myRegex3Ersetzen)
                                      val3=val3.replace(myRegex4,myReg4Ersetzen)        
                                      val3=val3.replace(myRegex5,myReg5Ersetzen)  
                                
                                
                                   if (val22help==val2help){
                                          
                                       val0= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val0
                                       val1= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val1
                                       val2= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val2
                                       val3= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val3
                                   }
                                
                                
                                if( i <= anzahlMails )  {
                                 
                                 if(wichtigeMails.length>0){
                                                           for (var aa=0 ;aa <wichtigeMails.length;aa++){
                                                               if(wichtigeMails[aa]==mailobj[i].address) {counter++;tabelleBind()};} //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                                           } else {counter++;tabelleBind()}
                                   }
                                

                                // }
                                } //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!

                                //-------------------------------------------------------------------------------------------------------------------------------------------------
                                //--------------------------------------------------Ende der schleife------------------------------------------------------------------------------
                                //-------------------------------------------------------------------------------------------------------------------------------------------------

                                  tabelleFinish(); // AB HIER NICHTS ÄNDERN - tabelle fertigstellen
                                   }
                                

                                },13000);
                                })

                                } // function ende

                                //MAIN:

                                schedule(mySchedule, function () {
                                writeHTML();//log("jetz")
                                if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/ });}
                                });
                                //writeHTML();

                                function tabelleBind(){
                                //HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT - hat man oben 4 Felder definiert, braucht man hier 4 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></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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                ";\"align="+Feld4lAlign+">"+val3+"</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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                ";\" align="+Feld4lAlign+">"+val3+"</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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                    ";\" align="+Feld4lAlign+">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                    ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</td>";} 
                                                                           else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                    ";\" align="+Feld4lAlign+">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                    ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</td>";} 
                                                                           else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld4lAlign+">"+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=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ "color:"+htmlFarbFelderschrift2+"\">"+val3+"</td></tr>";} 
                                                                                             else    {htmlOut  = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld4lAlign+">"+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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</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+"  color:"+htmlFarbFelderschrift2+"\">"+val3+"</td></tr>";} 
                                                                                             else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"align="+Feld4lAlign+">"+val3+"</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></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></tr>');      
                                             if(counter%3==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</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></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></tr>");
                                             if(counter%4==1)  htmlOut = htmlOut.replace(/<\/td>$/, "</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></tr>");    
                                             if(counter%4==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");      
                                             break; } 
                                
                                
                                     var htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: "+htmlÜberFontGroesse+"; font-weight:"+htmlSchriftWeite+ "\">"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</p>"; 
                                   var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 70%; text-align: right;\" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</div>";
                                    
                                    if (!htmlSignature) htmlUnter="";
                                      //Ausgabe über VIS html widget - tabelle in datenpunkt schreiben - html tabelle ohne html header und body
                                       var htmlOutVIS="";
                                     //  htmlUberschrift ? htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>" : htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>";
                                        if (htmlUberschrift) 
                                            { zentriert ? htmlOutVIS=htmlZentriert+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter : htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter ;
                                
                                          } else {
                                           zentriert ?  htmlOutVIS=htmlZentriert+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter :  htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter;
                                
                                             }
                                

                                // log("bin raus aus tabelleBind");
                                if (braucheEinVISWidget) setState(javascriptInstanzOrdner+ ".Tabelle", htmlOutVIS );

                                var htmlUnter= "<div style="color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 80%; text-align: center; " >"+htmlFeldUeber+"  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);

                                }

                                async function getMail() { //log("start")
                                return new Promise(resolve => {
                                var MailListener = require("mail-listener4");
                                var mailListener = new MailListener(
                                maillistenerSetting
                                );
                                mailobj=[];
                                mailListener.start();
                                mailListener.on("server:connected", function(){/console.log("imapconconnected")/;});
                                mailListener.on("server:disconnected", function(){/console.log("imapDisconnected");/});
                                mailListener.on("error", function(err){console.log(err);});
                                mailListener.on("mail", function(mail, seqno, attributes){

                                  let theName ="Unbekannt"
                                  let theText="FEHLER beim Lesen oder leer"
                                   if (mail.from[0].name!="" && mail.from[0].name!=undefined && mail.from[0].name!=null)  theName=mail.from[0].name
                                   if (mail.text!="" && mail.text!=undefined && mail.text!=null)   theText=mail.text
                                //  log(mail.subject)
                                  
                                   mailobj.push(
                                           {
                                               from:  theName,
                                               address: mail.from[0].address,    
                                               subject: mail.subject,
                                               text:  theText,
                                               date:  mail.date,
                                               date_num: new Date(mail.date).getTime(),
                                               number: seqno
                                           })
                                

                                });//log("fertig");

                                  setTimeout(function(){mailListener.stop();resolve();},10000);
                                

                                }); //prom

                                }

                                Vielen Dank im vorraus

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

                                @salzer-michael

                                poste das ganze bitte in code tags - ist lesbarer

                                zum thema - versuche mal diese variablen so zu nutzen:

                                var myRegex=""; // erstes Regex für Subject - "" für leer
                                var myRegexErsetzen=""; // erstes Regex Subject Ersetzen mit - "" für leer
                                var myRegex2=""; // zweites Regex für Subject - "" für leer
                                var myRegex2Ersetzen=""; // zweites Regex Subject Ersetzen mit - "" für leer
                                

                                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

                                Salzer MichaelS 1 Antwort Letzte Antwort
                                0
                                • Salzer MichaelS Salzer Michael

                                  @salzer-michael

                                  Script:
                                  //@liv-in-sky 2020 5.9.20-10:42

                                  var maillistenerSetting = {
                                  username: "*@gmail.com", // hier Email Adresse eintragen
                                  password: "
                                  ", // hier Passwort eintragen
                                  host: "imap.gmail.com",
                                  port: 993, // imap port
                                  tls: true,
                                  connTimeout: 10000, // Default by node-imap
                                  authTimeout: 5000, // Default by node-imap,
                                  debug: null, // Or your custom function with only one incoming argument. Default: null
                                  tlsOptions: { rejectUnauthorized: false },
                                  mailbox: "Inbox", // mailbox to monitor
                                  searchFilter: ["ALL"], // the search filter being used after an IDLE notification has been retrieved
                                  markSeen: false, // all fetched email willbe marked as seen and not fetched next time
                                  fetchUnreadOnStart: true, // use it only if you want to get all unread email on lib start. Default is false,
                                  mailParserOptions: {streamAttachments: true}, // options to be passed to mailParser lib.
                                  attachments: false, // download attachments as they are encountered to the project directory
                                  attachmentOptions: { directory: "attachments/" }}

                                  //HIER WIRD PFAD UND FILENAME DEFINIERT
                                  const path = "/stoerungsdienst.html"; //FIlenamen definieren
                                  const home ='javascript.0' //wo soll das file im iobroker-file-system liegen ? (oder z.b auch iqontrol.meta)
                                  let braucheEinVISWidget=true; // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile
                                  //let dpVIS="javascript.0.Email-Stoerungsdienst.AAATEST.TestHTML" //WICHTIG wenn "braucheEinVISWidget" auf true gesetzt !! dp zusätzlich für VIS-HTML-Basic-Widget
                                  let javascriptInstanzOrdner="javascript.0.Email-Stoerungsdienst" // unterordner unter genutzter javascript-instanz z.b. javascript.0.Email-Serien
                                  let mySchedule=" */1 * * * * "; //nicht unter eine minute einstellen !!!!!!!
                                  var styleUeber="span" // oder "i" oder "b"
                                  var farbeUeber="lightblue" // farbe für mails vom heutiger tag
                                  var mitSeqnu=true; // zeigt email nummer an vor Absender
                                  var wichtigeMails=[] //["iobroker3@online.de","no-personal@online.de"]// oder wenn leer == ALLE ==> [] -> whiteList Logic
                                  var anzahlMails=10; // anzahl sichtbarer mails in tabelle
                                  var kuerzungSubject=35;
                                  var kuerzungText=120;
                                  var myRegex=/[ (ioB)roker(.+)].+/; // erstes Regex für Subject - "" für leer
                                  var myRegexErsetzen="$1 $2"; // erstes Regex Subject Ersetzen mit - "" für leer
                                  var myRegex2=/[|] .+/g; // zweites Regex für Subject - "" für leer
                                  var myRegex2Ersetzen=""; // zweites Regex Subject Ersetzen mit - "" für leer
                                  var myRegex3=/\n/g; // erstes Regex für Text - "" für leer
                                  var myRegex3Ersetzen="" ; // erstes Regex Text Ersetzen mit - "" für leer
                                  var myRegex4=/(.+?) hat auf (.+?) (geantwortet)..+/gm; // zweites Regex für Text - "" für leer
                                  var myReg4Ersetzen=" <b>REPLY</b>: $1 - $2"; // zweites Regex Text Ersetzen mit - "" für leer
                                  var myRegex5=/(.+?) hat deinen Beitrag (.+?) (positiv bewertet)..+/gm; // drittes Regex für Text - "" für leer
                                  var myReg5Ersetzen=" <b>POSITIV</b>: $1 - $2"; // drittes Regex Text Ersetzen mit - "" für leer
                                  var myRegex6=/(ioB)roker(.+)/; // erstes Regex für Absender - "" für leer
                                  var myRegex6Ersetzen="$1 $2" ; // erstes Regex Absender Ersetzen mit - "" für leer
                                  //---------------------------------------

                                  //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 4
                                  var htmlFeld1='Von'; var Feld1lAlign="left"; // überschrift Tabellen Spalte1 und Ausrichtung left,right or center
                                  var htmlFeld2=' Betreff '; var Feld2lAlign="left"; // ü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='Inhalt'; var Feld4lAlign="left"; // überschrift Tabellen Spalte4 und Ausrichtung left,right or center
                                  //-----------------------------------

                                  //ÜBERSCHRIFT ÜBER TABELLE
                                  let htmlUberschrift=true; // mit Überschrift über der tabelle
                                  let htmlSignature=false; // anstatt der Überscghrift eine signature: - kleiner - anliegend
                                  const htmlFeldUeber='E-Mails: BG Störungsdienst'; // Überschrift und Signature
                                  const htmlFarbUber="white"; // Farbe der Überschrift
                                  const htmlSchriftWeite="normal"; // bold, normal - Fettschrift für Überschrift
                                  const htmlÜberFontGroesse="18px"; // schriftgröße überschrift
                                  //MEHRERE TABELLEN NEBENEINANDER
                                  let mehrfachTabelle=1; // bis zu 4 Tabellen werden nebeneinander geschrieben- verkürzt das Ganze, dafür etwas breiter - MÖGLICH 1,2,3,oder 4 !!!
                                  const trennungsLinie="2"; //extra trennungslinie bei mehrfachtabellen - evtl auf 0 stellen, wnn htmlRahmenLinien auf none sind
                                  const farbetrennungsLinie="white";
                                  const htmlFarbZweiteTabelle="white"; // Farbe der Überschrift bei jeder 2.ten Tabelle
                                  const htmlFarbTableColorUber="#BDBDBD"; // Überschrift in der tabelle - der einzelnen Spalten
                                  //ÜBERSCHRIFT SPALTEN
                                  const UeberSchriftHöhe="35"; //Überschrift bekommt mehr Raum - darunter und darüber - Zellenhöhe
                                  const LinieUnterUeberschrift="3"; // Linie nur unter Spaltenüberschrift -
                                  const farbeLinieUnterUeberschrift="white";
                                  const groesseUeberschrift=16;
                                  const UeberschriftStyle="normal" // möglich "bold"
                                  //GANZE TABELLE
                                  let abstandZelle=6;
                                  let farbeUngeradeZeilen="#000000"; //Farbe für ungerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2
                                  let farbeGeradeZeilen="#333333"; //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="Helvetica";
                                  const htmlSchriftgroesse="14px";
                                  //FELDER UND RAHMEN
                                  let UeberschriftSpalten=true; // ein- oder ausblenden der spatlen-überschriften
                                  const htmlFarbFelderschrift="#BDBDBD"; // SchriftFarbe der Felder
                                  const htmlFarbFelderschrift2="#D8D8D8"; // SchriftFarbe der Felder für jede 2te Tabelle
                                  const htmlFarbTableColorGradient1="#424242"; // Gradient - Hintergrund der Tabelle - Verlauffarbe
                                  const htmlFarbTableColorGradient2="#424242"; // Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
                                  const htmlFarbTableBorderColor="grey"; // Farbe des Rahmen - is tdieser gleich den gradienten, sind die rahmen unsichtbar
                                  let htmlRahmenLinien="none"; // 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 "auto";

                                  // 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=""+UeberSchriftHöhe+"" 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 4

                                  var htmlTabUeber2="<td width="+htmlSpalte1Weite+" align="+Feld1lAlign+"> "+htmlFeld1+" </td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+"> "+htmlFeld2+" </td><td align="+Feld3lAlign+"> "+htmlFeld3+" </td><td align="+Feld4lAlign+"> "+htmlFeld4+" </td>";
                                  var htmlTabUeber2_1="<td width="+htmlSpalte1Weite+" align=="+Feld1lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld1+" </td><td width="+htmlSpalte1Weite+" align="+Feld2lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld2+
                                  " </td><td align=="+Feld3lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld3+" </td><td align="+Feld4lAlign+" style="color:"+htmlFarbZweiteTabelle+""> "+htmlFeld4+
                                  " </td>";
                                  //------------------------------------------------------

                                  let braucheEinFile=false; // bei true wird ein file geschrieben
                                  var mailobj =[]
                                  createState(javascriptInstanzOrdner+".Reception");
                                  createState(javascriptInstanzOrdner+".from_address");
                                  createState(javascriptInstanzOrdner+".from_name");
                                  createState(javascriptInstanzOrdner+".mail_subject");
                                  createState(javascriptInstanzOrdner+".mail_text");
                                  createState(javascriptInstanzOrdner+".mail_date");
                                  createState(javascriptInstanzOrdner+".Anzahl");
                                  createState(javascriptInstanzOrdner+".Tabelle");
                                  var htmlOut="";
                                  var mix;
                                  var counter;
                                  var val1; var val2; var val0; var val3;
                                  var htmlTabUeber="";

                                  function writeHTML(){

                                  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 !!!---------------------------------------------------------------------
                                  //--------------------------------------------------------------------------------------------------------------------------------------------------

                                  getMail().then( () =>{
                                  // log("jetztttttttttttttttttttttttttttttttttttttttt")
                                  setTimeout(function(){
                                  // log("array= "+mailobj[0].from+"lang "+mailobj.length.toString())
                                  if (mailobj.length>0) {
                                  // log("jetzt2")
                                  //log( "lang: " + mailobj.length.toString()+"string: "+mailobj.toString() )
                                  setState(javascriptInstanzOrdner+ ".from_address", mailobj[mailobj.length-1].address);
                                  setState(javascriptInstanzOrdner+ ".from_name", mailobj[mailobj.length-1].from);
                                  setState(javascriptInstanzOrdner+ ".mail_subject", mailobj[mailobj.length-1].text); //.subject
                                  setState(javascriptInstanzOrdner+ ".mail_text",mailobj[mailobj.length-1].text);
                                  setState(javascriptInstanzOrdner+ ".mail_date", mailobj[mailobj.length-1].date);
                                  setState(javascriptInstanzOrdner+ ".Anzahl", mailobj[mailobj.length-1].number);

                                  mailobj.sort(function(a, b){
                                  return b.date_num - a.date_num;
                                  });

                                  for (let i=0;i<mailobj.length;i++){

                                        mitSeqnu ? val0="("+mailobj[i].number+") "+ mailobj[i].from : val0=mailobj[i].from
                                        val0=val0.replace(myRegex6,myRegex6Ersetzen)
                                        val1=mailobj[i].subject //.substring(0,45)
                                         val1=val1.replace(/Ã"/g, "&Auml;")
                                         val1=val1.replace(/Ã"/g, "&Auml;")
                                         val1=val1.replace(/Ã"/g, "&Auml;")
                                         val1=val1.replace(/ä/g, "&auml;")
                                         val1=val1.replace(/Ü/g, "&Uuml;")
                                         val1=val1.replace(/ü/g, "&uuml;")
                                         val1=val1.replace(/Ã-/g, "&Ouml;")
                                         val1=val1.replace(/ö/g, "&ouml;")
                                         val1=val1.replace(/ß/g, "&szlig;")
                                          
                                        val2=  formatDate(getDateObject(((new Date(mailobj[i].date).getTime()))), "TT.MM.JJ - SS:mm")
                                        let  val22help=  formatDate(getDateObject(((new Date(mailobj[i].date).getTime()))), "TT.MM.JJ")
                                        let val2help=formatDate(getDateObject(((new Date().getTime()))), "TT.MM.JJ")
                                        
                                        val1=val1.replace(myRegex,myRegexErsetzen).substring(0,kuerzungSubject)
                                        val1=val1.replace(myRegex2,myRegex2Ersetzen)
                                  
                                        val3=mailobj[i].text.trim().substring(0,kuerzungText)
                                        if (val3.includes("doctype")) val3="ersetzt: HTML Code"
                                        val3=val3.replace(myRegex3,myRegex3Ersetzen)
                                        val3=val3.replace(myRegex4,myReg4Ersetzen)        
                                        val3=val3.replace(myRegex5,myReg5Ersetzen)  
                                  
                                  
                                     if (val22help==val2help){
                                            
                                         val0= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val0
                                         val1= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val1
                                         val2= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val2
                                         val3= "<font color=\""+farbeUeber +"\"><"+styleUeber+">" + val3
                                     }
                                  
                                  
                                  if( i <= anzahlMails )  {
                                   
                                   if(wichtigeMails.length>0){
                                                             for (var aa=0 ;aa <wichtigeMails.length;aa++){
                                                                 if(wichtigeMails[aa]==mailobj[i].address) {counter++;tabelleBind()};} //HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  - diese function muss als letztes in der eigenen schleife aufgerufen werden
                                                             } else {counter++;tabelleBind()}
                                     }
                                  

                                  // }
                                  } //Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!

                                  //-------------------------------------------------------------------------------------------------------------------------------------------------
                                  //--------------------------------------------------Ende der schleife------------------------------------------------------------------------------
                                  //-------------------------------------------------------------------------------------------------------------------------------------------------

                                    tabelleFinish(); // AB HIER NICHTS ÄNDERN - tabelle fertigstellen
                                     }
                                  

                                  },13000);
                                  })

                                  } // function ende

                                  //MAIN:

                                  schedule(mySchedule, function () {
                                  writeHTML();//log("jetz")
                                  if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/ });}
                                  });
                                  //writeHTML();

                                  function tabelleBind(){
                                  //HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT - hat man oben 4 Felder definiert, braucht man hier 4 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></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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                  ";\"align="+Feld4lAlign+">"+val3+"</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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                  ";\" align="+Feld4lAlign+">"+val3+"</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></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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                      ";\" align="+Feld4lAlign+">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                      ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</td>";} 
                                                                             else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                      ";\" align="+Feld4lAlign+">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+
                                                                                      ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</td>";} 
                                                                             else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld4lAlign+">"+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=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"; color:"+htmlFarbFelderschrift2+"\">"+val3+"</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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";color:"+htmlFarbFelderschrift2+"\">"+val2+"</td><td  align="+Feld4lAlign+" style=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ "color:"+htmlFarbFelderschrift2+"\">"+val3+"</td></tr>";} 
                                                                                               else    {htmlOut  = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"align="+Feld4lAlign+">"+val3+"</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld4lAlign+">"+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=\"border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ ";color:"+htmlFarbFelderschrift2+"\">"+val3+"</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+"  color:"+htmlFarbFelderschrift2+"\">"+val3+"</td></tr>";} 
                                                                                               else    {htmlOut = htmlOut+"<td align="+Feld1lAlign+">"+val0+"</td><td align="+Feld2lAlign+">"+val1+"</td><td align="+Feld3lAlign+">"+val2+"</td><td  style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+";\"align="+Feld4lAlign+">"+val3+"</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></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></tr>');      
                                               if(counter%3==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</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></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></tr>");
                                               if(counter%4==1)  htmlOut = htmlOut.replace(/<\/td>$/, "</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></tr>");    
                                               if(counter%4==0)  htmlOut = htmlOut.replace(/<\/td>$/, "</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 style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td><td>&ensp;</td></tr>");      
                                               break; } 
                                  
                                  
                                       var htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: "+htmlÜberFontGroesse+"; font-weight:"+htmlSchriftWeite+ "\">"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</p>"; 
                                     var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 70%; text-align: right;\" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((parseFloat((new Date().getTime())))), "SS:mm:ss");+"</div>";
                                      
                                      if (!htmlSignature) htmlUnter="";
                                        //Ausgabe über VIS html widget - tabelle in datenpunkt schreiben - html tabelle ohne html header und body
                                         var htmlOutVIS="";
                                       //  htmlUberschrift ? htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>" : htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>";
                                          if (htmlUberschrift) 
                                              { zentriert ? htmlOutVIS=htmlZentriert+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter : htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter ;
                                  
                                            } else {
                                             zentriert ?  htmlOutVIS=htmlZentriert+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter :  htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter;
                                  
                                               }
                                  

                                  // log("bin raus aus tabelleBind");
                                  if (braucheEinVISWidget) setState(javascriptInstanzOrdner+ ".Tabelle", htmlOutVIS );

                                  var htmlUnter= "<div style="color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 80%; text-align: center; " >"+htmlFeldUeber+"  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);

                                  }

                                  async function getMail() { //log("start")
                                  return new Promise(resolve => {
                                  var MailListener = require("mail-listener4");
                                  var mailListener = new MailListener(
                                  maillistenerSetting
                                  );
                                  mailobj=[];
                                  mailListener.start();
                                  mailListener.on("server:connected", function(){/console.log("imapconconnected")/;});
                                  mailListener.on("server:disconnected", function(){/console.log("imapDisconnected");/});
                                  mailListener.on("error", function(err){console.log(err);});
                                  mailListener.on("mail", function(mail, seqno, attributes){

                                    let theName ="Unbekannt"
                                    let theText="FEHLER beim Lesen oder leer"
                                     if (mail.from[0].name!="" && mail.from[0].name!=undefined && mail.from[0].name!=null)  theName=mail.from[0].name
                                     if (mail.text!="" && mail.text!=undefined && mail.text!=null)   theText=mail.text
                                  //  log(mail.subject)
                                    
                                     mailobj.push(
                                             {
                                                 from:  theName,
                                                 address: mail.from[0].address,    
                                                 subject: mail.subject,
                                                 text:  theText,
                                                 date:  mail.date,
                                                 date_num: new Date(mail.date).getTime(),
                                                 number: seqno
                                             })
                                  

                                  });//log("fertig");

                                    setTimeout(function(){mailListener.stop();resolve();},10000);
                                  

                                  }); //prom

                                  }

                                  Vielen Dank im vorraus

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

                                  @salzer-michael

                                  code tags so nutzen:

                                  https://forum.iobroker.net/post/394912https://forum.iobroker.net/post/394912

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

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

                                    @salzer-michael

                                    poste das ganze bitte in code tags - ist lesbarer

                                    zum thema - versuche mal diese variablen so zu nutzen:

                                    var myRegex=""; // erstes Regex für Subject - "" für leer
                                    var myRegexErsetzen=""; // erstes Regex Subject Ersetzen mit - "" für leer
                                    var myRegex2=""; // zweites Regex für Subject - "" für leer
                                    var myRegex2Ersetzen=""; // zweites Regex Subject Ersetzen mit - "" für leer
                                    
                                    Salzer MichaelS Offline
                                    Salzer MichaelS Offline
                                    Salzer Michael
                                    schrieb am zuletzt editiert von
                                    #88

                                    @liv-in-sky

                                    Perfekt

                                    läuft

                                    Stell ne Kanne Kaffe ins Forum ;-)
                                    Danke

                                    Salzer MichaelS 1 Antwort Letzte Antwort
                                    0
                                    • Salzer MichaelS Salzer Michael

                                      @liv-in-sky

                                      Perfekt

                                      läuft

                                      Stell ne Kanne Kaffe ins Forum ;-)
                                      Danke

                                      Salzer MichaelS Offline
                                      Salzer MichaelS Offline
                                      Salzer Michael
                                      schrieb am zuletzt editiert von
                                      #89

                                      @liv-in-sky
                                      kannst du mir beim blockly auch helfen ?
                                      wenn neue mail da ist hätt ich gerne anruf über telegramm mit x versuchen ausser ich quittiere vorher
                                      derzeitiger versuch klappt nicht .
                                      blockly wird nicht gestartet bei neuer mail
                                      wenns stoppe und starte dann klappts mit anruf.
                                      quittieren wenn den anruf empfangen hab (derzeit button in VIS) schluckt er mir so auch nicht.
                                      a3cbd82b-5811-40f1-aad2-9087e2d011d8-image.png

                                      liv-in-skyL 1 Antwort Letzte Antwort
                                      0
                                      • Salzer MichaelS Salzer Michael

                                        @liv-in-sky
                                        kannst du mir beim blockly auch helfen ?
                                        wenn neue mail da ist hätt ich gerne anruf über telegramm mit x versuchen ausser ich quittiere vorher
                                        derzeitiger versuch klappt nicht .
                                        blockly wird nicht gestartet bei neuer mail
                                        wenns stoppe und starte dann klappts mit anruf.
                                        quittieren wenn den anruf empfangen hab (derzeit button in VIS) schluckt er mir so auch nicht.
                                        a3cbd82b-5811-40f1-aad2-9087e2d011d8-image.png

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

                                        @salzer-michael

                                        erstmal zur theorie

                                        • wenn du einen trigger nutzt, mußt du die anderen bausteine IN den trigger setzen

                                        Image 1.png

                                        • ein trigger ist immer außen - daher trigger soll nicht in der "wiederhole 2 mal" sein !!

                                        • wie willst du den ablauf, wenn innerhalb von 180 sek nochmal eine mail kommt ? soll das immer ausgeführt werden ?

                                        • für was benötigst du den datenpunkt neueStörungsmail - für dieses script ist er nicht nötig - da der trigger ja schon da ist. ich habe ihn mal reingenommen - damit könntest du auch das script sperren, wenn innerhalb der 180 sek noch eine mail kommt

                                        damit wird der trigger ausgeführt 180 sek gewartet und nochmal ausgeführt - jedesmal, wenn die anzahl der anrufe größer wird- ich habe das nicht ausgefüllt - nur die blockly's eingesetzt

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

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

                                          @salzer-michael

                                          erstmal zur theorie

                                          • wenn du einen trigger nutzt, mußt du die anderen bausteine IN den trigger setzen

                                          Image 1.png

                                          • ein trigger ist immer außen - daher trigger soll nicht in der "wiederhole 2 mal" sein !!

                                          • wie willst du den ablauf, wenn innerhalb von 180 sek nochmal eine mail kommt ? soll das immer ausgeführt werden ?

                                          • für was benötigst du den datenpunkt neueStörungsmail - für dieses script ist er nicht nötig - da der trigger ja schon da ist. ich habe ihn mal reingenommen - damit könntest du auch das script sperren, wenn innerhalb der 180 sek noch eine mail kommt

                                          damit wird der trigger ausgeführt 180 sek gewartet und nochmal ausgeführt - jedesmal, wenn die anzahl der anrufe größer wird- ich habe das nicht ausgefüllt - nur die blockly's eingesetzt

                                          Image 4.png

                                          Salzer MichaelS Offline
                                          Salzer MichaelS Offline
                                          Salzer Michael
                                          schrieb am zuletzt editiert von
                                          #91

                                          @liv-in-sky

                                          Wollte das grad testen
                                          Danke für s Anleiten

                                          leider bekomm ich im Javascript jetzt angezeigt
                                          e
                                          19:06:00.723 info javascript.0 (2602) script.js.common.störungsmailabruf.mailundtabelle: {'type':'no','textCode':'ALERT','source':'authentication'}

                                          hab aber nüscht geändert gegenüber mittag
                                          Ideen ?

                                          Salzer MichaelS liv-in-skyL 2 Antworten Letzte Antwort
                                          0
                                          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

                                          433

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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