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

  1. ioBroker Community Home
  2. Deutsch
  3. Visualisierung
  4. HTML Tabellen für VIS - Version2

NEWS

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

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

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

HTML Tabellen für VIS - Version2

Geplant Angeheftet Gesperrt Verschoben Visualisierung
templatevis
5 Beiträge 2 Kommentatoren 1.1k Aufrufe 11 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 Offline
    liv-in-skyL Offline
    liv-in-sky
    schrieb am zuletzt editiert von liv-in-sky
    #1

    dachte mir, ich mach mal ein update zu den HTML Tabellen für die VIS.
    ursprung: https://forum.iobroker.net/topic/28021/html-table-für-vis-oder-iqontrol-js-und-blockly

    Neuerungen:

    • nur ein template-script für alle Spaltenzahlen - d.h. spalten können rel. leicht hinzugefügt werden
    • eine seitenleiste (für schalter oder text) - optional
    • die überschriften der tabelle können als schalter genutzt werden z.b. sortierung
    • kleinere design-änderungen
    • datenpunkte werden vom script angelegt (javascript.x.Tabellen@Liv.name)
    • es können bis zu 3 tabellen nebeneinader angezeigt werden
    • die beschreibung am anfang des scriptes ist etwas besser

    beispiel für designs

    • die umschaltung links in der tabelle ist nicht im standard implementiert

    AAdesigns.gif

    Image 1.png

    beispiel für anwendung mit schalter - hier für die instanzen-übersicht

    AApossis.gif


    NeueTabelle-Instanzen-blau-22.2.21.txt

       //@liv-in-sky 2021  27.2.-14:11
    
    // DAS WIDGET IN DER VIS
    // das Standard html-Widget wird genutzt in der VIS - dazu den DP javascript.x.Tabellen@Liv.TestTabelleVIS.HTMLTableVis als binding angeben d.h.
    // im html-teil des widgets wird dier daten punkt in geschweiften klammern angegeben z.B. {javascript.0.Tabellen@Liv.TestTabelleVIS.HTMLTableVis}
    
    // @ts-ignore
    let braucheEinVISWidget=true;                          // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile
    let  dpVIS="TestTabelleVIS"                            // WICHTIG wenn braucheEinVISWidget auf true gesetzt !!  Ist der Name zum datenpunkt anlegen
    let braucheEinJSON=false;                               // bei true wird ein html-tabelle in einen dp geschrieben - siehe nächste zeile
    let  dpJSON="TestTabelleJSON"                          // WICHTIG wenn braucheEinJSON auf true gesetzt !!   Ist der Name zum datenpunkt anlegen
    let mySchedule="  * * * * * ";                         // jede minute  
    
    //ZUSÄTZLICH VARIABLEN
    let mitAlphabet=false;
    let sortierenEIN=true;
    
    //---------------------------------------
    
    //HIER DIE SPALTEN ANZAHL DEFINIEREN - jede Spalte einen Wert - in diesem Beispiel sind es 3 - es MÜSSEN in allen Arrays die GLEICHE Anzahl für die Werte sein
    let val=             ["dummy1","dummy2","dummy3"];              // GLEICHE ANZAHL !! HIER SIND DIE  WERTE, DIE IN DER SCHLEIFE GEFILTERET WERDEN -  jeder val[x] muss unten in der schleife gesetzt werden !!
    let Feld1lAlign=     ["left","center","center"];                // GLEICHE ANZAHL !! AUSRICHTUNG IN DER SPALTE
    let htmlSpalte1Weite=["180px","auto","auto"];                   // GLEICHE ANZAHL !! BREITE DER SPALTE, wenn nicht auto
    let htmlFeld=        ["INSTANCE","SINCE/MEM","STATE/LL"];       // GLEICHE ANZAHL !! NAME/ÜBERSCHRIFT DER SPALTE
    let schalterInSpaltenUeberschrift=[true,true,true];             // WENN BUTTONS INSTALLIERT WERDEN - sonst false
    let symbolSchalter=               ["na","⇄","⇄"];   // SYMBOLE DER BUTTONS - standardmäßig sind die spaltennamen (htmlFeld) genutzt - werden im standard nicht genutzt
    //-----------------------------------
    
    //Symbole für Tabelle z.b.: ⚪  ⚫ ⭕  🔴 🔵 ⏱ 💀 👍 👎 📑 💲 👀 🔹 ✅ ❌ ⚠️ mehr: https://emojiterra.com/de/ oder https://unicode-table.com/de/html-entities/
    
    //hier werden die styles für die tabelle definiert
    //ÜBERSCHRIFT ÜBER TABELLE
    const htmlUberschrift=true;                             // mit Überschrift über der tabelle
    const htmlSignature=false;                               // anstatt der Überscghrift eine signature: - kleiner - anliegend
    const htmlFeldUeber='ioBroker Instanzen';                // für Überschrift und Signature falls htmlUberschrift und htmlSignature ist true
    const htmlFarbUber="white";                              // Farbe der Überschrift
    const htmlSchriftWeite="normal";                         // bold, normal - Fettschrift für Überschrift
    const htmlUEberFontGroesse="18px";                       // schriftgröße überschrift
    //SEITENLEISTE
    const ichWillSeitenLeiste=true;                          // links einblenden einer Seitenleiste
    const nameSeitenLeiste="IOBROKER INSTANCES"
    const breiteSeitenleiste=25;
    const schriftGroesseSeitenleiste=18;
    const abstandSeitentextVonOben=6;
    const htmlFarbSeiteSchrift="#8A8A88";
    const htmlBackgroundFarbeSeitenliste="transparent";
    //MEHRERE TABELLEN NEBENEINANDER
    let mehrfachTabelle=3;                                   // bis zu 3 Tabellen werden nebeneinander geschrieben-  verkürzt das Ganze, dafür etwas breiter - MÖGLICH 1,2,3 !!!
    const trennungsLinie="2";                                // extra trennungslinie bei mehrfachtabellen - evtl auf 0 stellen, wnn htmlRahmenLinien auf none sind
    const farbetrennungsLinie="#C9AF4A";                       // bei mehreren Tabellen nebeneinander wird ein Strich zw. den Tabellen gezogen
    const htmlFarbTableColorUber="black"                     // Spalten-Überschrift in der tabelle - für die einzelnen Spalten //"#BDBDBD"; 
    const htmlFarbZweiteTabelle="black";                     // Farbe der Spalten-Überschrift bei jeder 2.ten Tabelle        
    //ÜBERSCHRIFT SPALTEN - OBERSTE ZEILE IN TAB
    const UeberSchriftHoehe="40";                            // Überschrift bekommt mehr Raum - darunter und darüber - Zellenhöhe
    const LinieUnterUeberschrift="4";                        // Liniehoehe nur unter Spaltenüberschrift  
    const farbeLinieUnterUeberschrift="orange";               // LinienFarbe unter Spaltenüberschrift
    const groesseUeberschrift=14; 
    const UeberschriftStyle="normal"                         // möglich "bold"
    const UeberschriftSpalten=true;                          // ein- oder ausblenden der spatlen-überschriften
    //GANZE TABELLE
    const abstandZelle="2";                                  // legt den abstand in den zellen zum rahmen fest
    const zeilenAbstand=3;                                  // legt den abstand zwischen den zeilen fest
    const farbeUngeradeZeilen="#000000";                     // Farbe für ungerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2 - bei "transparent" gewinnt htmlFarbTableColorGradient1
    const farbeGeradeZeilen="#151515";                       // Farbe für gerade Zeilenanzahl - Hintergrund der Spaltenüberschrift bleibt bei htmlFarbTableColorGradient1/2   - bei "transparent" gewinnt htmlFarbTableColorGradient2
    const weite="auto";                                      // Weite der Tabelle - verhindert das dynamische breiter werden, wenn werte unterschiedliche werte haben
    const zentriert=true;                                    // ganze tabelle zentriert im html Widget
    const backgroundAll="#000000";                           // Hintergrund für die ganze Seite - für direkten aufruf oder iqontrol sichtber - keine auswirkung auf vis-widget
    const htmlSchriftart="Ubuntu-Regular"                    // "Jura-DemiBold"   //"RobotoCondensed-Bold"   //"Helvetica"; .....
    const htmlSchriftgroesse="15px";                         // schriftgröße in den zellen
    const rahmenBreite="0px";                                //mit 0 ist äußerer rahmen weg
    //FELDER UND RAHMEN
    const htmlFarbFelderschrift="#8A8A88";                   // SchriftFarbe der Felder
    const htmlFarbFelderschrift2="#8A8A88";                  // SchriftFarbe der Felder für jede 2te Tabelle
    const htmlGragient=[150,15,50];                          // einstellung des gradienten
    const htmlFarbTableColorGradient1="lightyellow";         // Gradient - Hintergrund der Tabelle - Verlauffarbe
    const htmlFarbTableColorGradient2="orange";              // Gradient - Hintergrund der Tabelle - ist dieser Wert gleich Gradient1 gibt es keinen verlauf
    const htmlFarbTableBorderColor="grey";                   // Farbe des Rahmen - ist dieser gleich den gradienten, sind die rahmen unsichtbar
    let htmlRahmenLinien="none";                             // Format für Rahmen: MÖGLICH: "none" oder "all" oder "cols" oder "rows"
    
    // falls eine extra html datei gebraucht wird
    const path = "/htmlexample.html";                        //FIlenamen definieren
    const home ='vis.0'                                      //wo soll das file im iobroker-file-system liegen ? (oder z.b auch iqontrol.meta)
    let   braucheEinFile=false;                              // bei true wird ein file geschrieben
    
    // AB HIER NICHTS  ÄNDERN -------------------------------------------------------------------------------------------------
    // AB HIER NICHTS  ÄNDERN -------------------------------------------------------------------------------------------------
    // AB HIER NICHTS  ÄNDERN ---------------------------------erst wieder ab Zeile 134----------------------------------------
    
    let borderHelpBottum;
    let borderHelpRight;
    let htmlcenterHelp;
    let htmlcenterHelp2;
    
    if(String(htmlRahmenLinien)=="rows") {borderHelpBottum=1;borderHelpRight=0;}
    if(String(htmlRahmenLinien)=="cols") {borderHelpBottum=0;borderHelpRight=1;}
    if(String(htmlRahmenLinien)=="none") {borderHelpBottum=0;borderHelpRight=0;}
    if(String(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;  http-equiv=\"refresh\" content=\"30\"; 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[0]+"}"+"td:nth-child(2) {width:"+htmlSpalte1Weite[1]+"}"+
                       " </style></head><body> <div>";
    //const htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-weight: bold\">"+htmlFeldUeber+"</p>";                    
    const htmlTabStyle= "<table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\""+rahmenBreite+"\" cellspacing=\""+abstandZelle+"\" cellpadding=\""+abstandZelle+"\" width=\""+weite+"\" rules=\""+htmlRahmenLinien+"\" style=\"color:"+htmlFarbFelderschrift+";  font-size:"+htmlSchriftgroesse+
                          "; font-family:"+htmlSchriftart+";background-image: linear-gradient("+htmlGragient[0]+"deg,"+htmlFarbTableColorGradient2+" "+htmlGragient[1]+"%,"+htmlFarbTableColorGradient1+" "+htmlGragient[2]+"%);\">";
    let htmlTabUeber4="<tr style=\" height:"+UeberSchriftHoehe+"px; color:"+htmlFarbTableColorUber+"; font-size: "+groesseUeberschrift+"px; font-weight: "+UeberschriftStyle+" ;  border-bottom: "+LinieUnterUeberschrift+"px solid "+farbeLinieUnterUeberschrift+" \">";
    const htmlTabUeber3="</tr>";
    
    
    const buttonScript =   '<script> function setOnOtherValue(myval) {	var Self = this;	Self.servConn.getStates(myval, (error, states) => {  console.log(states); self.servConn.setState(myval, !states[myval].val);}  )}'
                         +'</script>'
    
    
    //NICHTS ÄNDERN - abhängig von den oben definierten _Spalten - in diesem Beispiel sind es 3
    let htmlTabUeber2=""
    for (let ue=0;ue<htmlSpalte1Weite.length;ue++) { if (!schalterInSpaltenUeberschrift[ue] ) { 
                                                          htmlTabUeber2=htmlTabUeber2.concat("<td width="+htmlSpalte1Weite[ue]+" align="+Feld1lAlign[ue]+" style=\"color:"+htmlFarbTableColorUber+"\">"+htmlFeld[ue]+"</td>")} 
                                                          else {let valButton="javascript." + instance + ".Tabellen@Liv."+dpVIS+".Spalte"+ue
                                                          htmlTabUeber2=htmlTabUeber2.concat("<td width="+htmlSpalte1Weite[ue]+" align="+Feld1lAlign[ue]+">"+""+"<button  style\=\" border-radius: 4px; border:1px solid; background-color\: "+htmlBackgroundFarbeSeitenliste+"\; color: "+htmlFarbTableColorUber+"; font\-size\:1em\; text\-align:left\" value=\"toggle\" onclick=\"setOnOtherValue\(\'"+valButton+"\')\">"+htmlFeld[ue]+"</button></td>")}  //symbolSchalter[ue]   
                                                          }
    
    
    let  htmlTabUeber2_1=""
    for (let ue=0;ue<htmlSpalte1Weite.length;ue++) { htmlTabUeber2_1=htmlTabUeber2_1.concat("<td width="+htmlSpalte1Weite[ue]+" align="+Feld1lAlign[ue]+" style=\"color:"+htmlFarbZweiteTabelle+"\">"+htmlFeld[ue]+"</td>")}
    
    //------------------------------------------------------
    if ( !(val.length == Feld1lAlign.length && htmlSpalte1Weite.length == htmlFeld.length && val.length == htmlFeld.length) || (mehrfachTabelle<1 || mehrfachTabelle>3) ) 
         { log("Anzahle der Definitions Arrays sind ungleich ODER mehrfachTabelle ist falsch - Script wurde gestoppt !!!","error");
             // @ts-ignore
             stopScript();}
    
    let langeGesamt=0; 
    let htmlTabUeber="";
    let htmlOut="";
    let mix;
    let counter;
    let makeJsonWidget;
    let myObject=[];
    let welcheSortierung=0;
    
    needDP();
    
    function writeHTML(){
    let seitenLeistenTest="";
    let htmlTabUeber1=htmlTabUeber4
    myObject=[]
    let helperLeerzeile=""
    let makeJsonWidget=[];
    htmlOut="";
    counter=-1;
    
    //--------------------------------------------------------------------------------------------------------------------------------------------------
    //---------hier kommt eure schleife rein counter++, tabelleBind() und tabelleFinish() müssen so integriert bleiben !!!------------------------------
    //---------alle val[x] werte müssen von euch bestimmt werden - val[0],val[1],val[2] !!!-------------------------------------------------------------
    //--------------------------------------------------------------------------------------------------------------------------------------------------
    
    
    
    $('system.adapter.*.alive').each(function(id, i) {           // hier eigene schleife definieren und den wert counter++ nicht vergessen  !!!
         
    
    
              var ida = id.split('.');
         
              if(existsState(id) && existsState(id.replace("alive","uptime"))) {
    
              val[0]=ida[2]+"."+ida[3];
             
              val[1]=getState(id.replace("alive","uptime")).val;
              if (existsState(id.replace("alive","memHeapUsed"))) { if(getState("javascript." + instance +".Tabellen@Liv."+dpVIS+".Spalte1").val) { val[1]=getState(id.replace("alive","memHeapUsed")).val}  } 
              val[2]=getState(id).val
              if (existsState(id.replace("alive","logLevel"))) { if(getState("javascript." + instance +".Tabellen@Liv."+dpVIS+".Spalte2").val) { val[2]=getState(id.replace("alive","logLevel")).val}  } 
         
    
            myObject.push({                "value0" : val[0],            //  "INSTANCE"
                                           "value1" : val[1],            //  "SINCE"
                                           "value2" : val[2],            //  "STATUS"
                                           "valueID": getState(id).val   //   ID
                                                           })
                   
              makeJsonWidget.push({        [htmlFeld[0]] : val[0],  //  "INSTANCE"
                                           [htmlFeld[1]] : val[1],  //  "SINCE"
                                           [htmlFeld[2]] : val[2],   //  "STATUS"
                                           "vallly"      : getState(id).val
                                                           })  
            
              
             
        }                                             // diese function muss als letztes in der eigenen schleife aufgerufen werden
       });                                            // Schleifen Ende - je nach schleifenart muss hier etwas geändert werden !!!!!!!!!
    
      // Sortierungen---------------------------------------------------------
    
       if(sortierenEIN ) switch (welcheSortierung) {
           case 0: sortMe("alpha","value0");break;  
           case 1: sortMe("num","value1");break;   
           case 2: sortMe("alpha","value2");break;}
    
            
    
       for(let zz=0;zz<myObject.length;zz++){
    
     // Unterüberschften ------------------------------------------------------       
            if (mitAlphabet){
              if( myObject[zz].value0[0]!=helperLeerzeile){ tabelleAusbessern();
                                                            counter=-1;  for(let ic=0;ic<mehrfachTabelle;ic++ ) { for (let tt=0 ;tt<val.length;tt++) 
                                                                                                                      { tt==0 && ic==0 ? val[tt]=(myObject[zz].value0[0]).toUpperCase() : val[tt]="&ensp;"
                                                                                                                      }   
                                                                                                                  counter++;tabelleBind();langeGesamt++; }
              helperLeerzeile=myObject[zz].value0[0] } ; sortierenEIN=false;}
    
     // Zuteilung der Tabellenspalten-------------------------------------------
    
        val[0]="&ensp;"+myObject[zz].value0
        val[1]=Math.floor( ((myObject[zz].value1)/60/60/24) )+"d "+ Math.floor(((myObject[zz].value1)/60/60) % 24) +"h "+ Math.floor( ((myObject[zz].value1)/60) % 60 )+" m" ;
        if(getState("javascript." + instance +".Tabellen@Liv."+dpVIS+".Spalte1").val) { val[1]=myObject[zz].value1+" MB"}   
        val[2]=myObject[zz].value2;//log(val[2])
        if (!myObject[zz].value2) {val[2]="&cross;"}
        if (myObject[zz].value2)  {val[2]="&check;"}
        if(getState("javascript." + instance +".Tabellen@Liv."+dpVIS+".Spalte2").val) { val[2]=myObject[zz].value2} 
        if (myObject[zz].valueID) {    val[0]="<font color=\""+"#C9AF4A" +"\">"+val[0]+"</font>";
                                       val[1]="<font color=\""+"#C9AF4A" +"\">"+val[1]+"</font>";
                                       val[2]="<font color=\""+"#C9AF4A" +"\">"+val[2]+"</font>";
    
                                  }  
         counter++;                                       // SEHR WICHTIG - MUSS IN JEDER SCHLEIFE INTEGRIERT SEIN
         tabelleBind();                                   // HIER NICHTS ÄNDERN : HIER WERDEN DIE DATEN DER SCHLEIFE ZUSAMMENGESETZT  
         langeGesamt++;                                   // WICHTIG Seitenleiste
       }
    
    //-------------------------------------------------------------------------------------------------------------------------------------------------
    //--------------------------------------------------Ende der schleife------------------------------------------------------------------------------
    //-------------------------------------------------------------------------------------------------------------------------------------------------
    
    // Seitenleiste------------------------------------------------------------   
      let einmalAbstand=`</br>
    `
     for (let f=0;f<abstandSeitentextVonOben;f++){
         seitenLeistenTest=seitenLeistenTest+`<br>
    `}
     for (let i=0;i<nameSeitenLeiste.length;i++){
         seitenLeistenTest=seitenLeistenTest+nameSeitenLeiste[i]+`</br>
    ` }
     htmlTabUeber="";
     if (ichWillSeitenLeiste) htmlTabUeber1=htmlTabUeber1+"<td  style=\" background-color: "+htmlBackgroundFarbeSeitenliste+"; margin-top: 200px; color: "+htmlFarbSeiteSchrift+ ";font-size:"+schriftGroesseSeitenleiste+"px; vertical-align:top; text-align:center \" width=\""+breiteSeitenleiste+"\" rowspan=\""+(langeGesamt+1)+"\">"+seitenLeistenTest+"</td>"
     switch (mehrfachTabelle) { 
       case 1: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber3;  break;
       case 2: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break;
       case 3: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber2_1+htmlTabUeber3; break;
       case 4: htmlTabUeber=htmlTabUeber1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber2+htmlTabUeber2_1+htmlTabUeber3; break;
      };   
      if (!UeberschriftSpalten) {htmlTabUeber=""}
    
          tabelleFinish(); 
          if (braucheEinJSON ) {setStateDelayed("javascript." + instance + ".Tabellen@Liv."+dpVIS+".JSONVis",JSON.stringify(makeJsonWidget),1000 )}
         
    } // function ende
    
    //MAIN:
     
    schedule(mySchedule,  function () { 
     writeHTML();
     if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/  });}
    }); 
    setTimeout(function () {writeHTML();  }, 2050);                                 
    
     function tabelleBind(){
      
       switch (mehrfachTabelle) { 
    
       case 1: if(counter%2==0)   {htmlOut=htmlOut+"<tr cellspacing=\""+abstandZelle+"\"  bgcolor=\""+farbeGeradeZeilen+"\">";
                                   for(let u=0;u<val.length;u++){ htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");
                                                                }  htmlOut=htmlOut.concat("</tr>");   break;
    
                                   } else   {htmlOut=htmlOut+"<tr cellspacing=\""+abstandZelle+"\"  bgcolor=\""+farbeUngeradeZeilen+"\">";
                                             for(let u=0;u<val.length;u++){ htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");
                                                                          }  htmlOut=htmlOut.concat("</tr>");   break;
                                   }
       
       case 2: if(counter%4==0){  if(counter%2==0)  {htmlOut = htmlOut+"<tr cellspacing=\""+abstandZelle+"\"  bgcolor=\""+farbeGeradeZeilen+"\">";
                                                     for(let u=0;u<val.length;u++){ if(u<val.length-1) {htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");} else
                                                                                  {htmlOut=htmlOut.concat("<td style=\" border-right:"+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld1lAlign[u]+">"+val[u]+"</td>")}
                                                                                  }  
                                                                               
                                    } else { for(let u=0;u<val.length;u++){ htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val[u]+"</td>");
                                                                          }  htmlOut=htmlOut.concat("</tr>");  } break;
                               } else {
                                 if(counter%2==0)  {htmlOut=htmlOut+"<tr cellspacing=\""+abstandZelle+"\"  bgcolor=\""+farbeUngeradeZeilen+"\">";
                                                    for(let u=0;u<val.length;u++){  if(u<val.length-1) {htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");} else
                                                                                 {htmlOut=htmlOut.concat("<td style=\" border-right:"+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld1lAlign[u]+">"+val[u]+"</td>")}
                                                                                 }  
                                    } else {        for(let u=0;u<val.length;u++){ htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val[u]+"</td>");
                                                                                 }  htmlOut=htmlOut.concat("</tr>");  }  break;}
    
       case 3: if(counter%2==0)  {  if(counter%3==0 ) {htmlOut = htmlOut+"<tr cellspacing=\""+abstandZelle+"\"  bgcolor=\""+farbeGeradeZeilen+"\">";
                                                       for(let u=0;u<val.length;u++){if(u<val.length-1) {htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");} else
                                                                                    {htmlOut=htmlOut.concat("<td style=\" border-right:"+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld1lAlign[u]+">"+val[u]+"</td>")}
                                                                                                            }  
                                   } else { if(counter%3==1)  {for(let u=0;u<val.length;u++){  if(u<val.length-1) {htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val[u]+"</td>");} else
                                                                                                                  {htmlOut=htmlOut.concat("<td  align="+Feld1lAlign[u]+" style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ "; color:"+htmlFarbFelderschrift2+"\">"+val[u]+"</td>")}
                                                                                                            }  
                                                              } else  { for(let u=0;u<val.length;u++){  htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");
                                                                                                     }  htmlOut=htmlOut.concat("</tr>");  } }  break;
                                 } 
                                 else {
                                    if(counter%3==0 )  {htmlOut = htmlOut+"<tr cellspacing=\""+abstandZelle+"\"  bgcolor=\""+farbeUngeradeZeilen+"\">";
                                                       for(let u=0;u<val.length;u++){ if(u<val.length-1) {htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");} else
                                                                                                         {htmlOut=htmlOut.concat("<td style=\" border-right:"+trennungsLinie+"px solid "+farbetrennungsLinie+ ";\" align="+Feld1lAlign[u]+">"+val[u]+"</td>")}
                                                                                                            }  
                                                                                                            
                                 } else{ if(counter%3==1 )  { for(let u=0;u<val.length;u++){ if(u<val.length-1) {htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+" style=\"color:"+htmlFarbFelderschrift2+"\">"+val[u]+"</td>");} else
                                                                                                                {htmlOut=htmlOut.concat("<td  align="+Feld1lAlign[u]+" style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+ "; color:"+htmlFarbFelderschrift2+"\">"+val[u]+"</td>")}
                                                                                                            }  
                                                             } else {        for(let u=0;u<val.length;u++){ htmlOut=htmlOut.concat("<td align="+Feld1lAlign[u]+">"+val[u]+"</td>");
                                                                                                          }  htmlOut=htmlOut.concat("</tr>"); } } break;
                                 }                                        
    
    
                                    
            } //switch ende
    
    }
    
     function tabelleAusbessern() {         // bessert mei mehrfachtabellen die nicht vollen zeilenn aus - bevor die unterüberschriften kommen
    
    switch (mehrfachTabelle) {
            
           case 1:    break;
           case 2:    let helpMehrfach="</td>";
                      for(let w=0;w<val.length;w++){helpMehrfach=helpMehrfach.concat("<td>&ensp;</td>")};helpMehrfach=helpMehrfach.concat("</tr>")
                      if(counter%2==0)  htmlOut = htmlOut.replace(/<\/td>$/, helpMehrfach);
                      break;
           case 3:   let helpMehrfach2="</td>";
                     for(let w=0;w<val.length;w++){helpMehrfach2=helpMehrfach2.concat("<td>&ensp;</td>")};helpMehrfach2=helpMehrfach2.concat("</tr>")
                     if(counter%3==2)  htmlOut = htmlOut.replace(/<\/td>$/, "</td></tr>");
                     if(counter%3==1)  htmlOut = htmlOut.replace(/<\/td>$/, helpMehrfach2);
                     let helpMehrfach3="</td>";
                     let helpMehrfach31="";for(let w=0;w<val.length;w++){helpMehrfach31=helpMehrfach31.concat("<td>&ensp;</td>")}
                     for(let w=0;w<val.length;w++){if(w<val.length-1) {helpMehrfach3=helpMehrfach3.concat("<td>&ensp;</td>")} else
                                                             {helpMehrfach3=helpMehrfach3.concat("<td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td>"+helpMehrfach31)}
                                                       };helpMehrfach3=helpMehrfach3.concat("</tr>")        
                     if(counter%3==0)  htmlOut = htmlOut.replace(/<\/td>$/, helpMehrfach3);  break; }}
    
     function tabelleFinish() {
    
    switch (mehrfachTabelle) {
            
           case 1:    break;
           case 2:    let helpMehrfach="</td>";
                      for(let w=0;w<val.length;w++){helpMehrfach=helpMehrfach.concat("<td>&ensp;</td>")};helpMehrfach=helpMehrfach.concat("</tr>")
                      if(counter%2==0)  htmlOut = htmlOut.replace(/<\/td>$/, helpMehrfach);
                      break;
           case 3:   let helpMehrfach2="</td>";
                     for(let w=0;w<val.length;w++){helpMehrfach2=helpMehrfach2.concat("<td>&ensp;</td>")};helpMehrfach2=helpMehrfach2.concat("</tr>")
                     if(counter%3==2)  htmlOut = htmlOut.replace(/<\/td>$/, "</td></tr>");
                     if(counter%3==1)  htmlOut = htmlOut.replace(/<\/td>$/, helpMehrfach2);
                     let helpMehrfach3="</td>";
                     let helpMehrfach31="";for(let w=0;w<val.length;w++){helpMehrfach31=helpMehrfach31.concat("<td>&ensp;</td>")}
                     for(let w=0;w<val.length;w++){if(w<val.length-1) {helpMehrfach3=helpMehrfach3.concat("<td>&ensp;</td>")} else
                                                             {helpMehrfach3=helpMehrfach3.concat("<td style=\" border-right: "+trennungsLinie+"px solid "+farbetrennungsLinie+"\">&ensp;</td>"+helpMehrfach31)}
                                                       };helpMehrfach3=helpMehrfach3.concat("</tr>")        
                     if(counter%3==0)  htmlOut = htmlOut.replace(/<\/td>$/, helpMehrfach3);  break; }
         
             var htmlUeber=    "<p style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: "+htmlUEberFontGroesse+"; font-weight:"+htmlSchriftWeite+ "\">"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((new Date().getTime())), "SS:mm:ss");+"</p>"; 
           var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 70%; text-align: center;\" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((new Date().getTime())), "SS:mm:ss");+"</div>";
            
            if (!htmlSignature) htmlUnter="";
                 var htmlOutVIS="";
                 if (htmlUberschrift) 
                    { zentriert ? htmlOutVIS=htmlZentriert+htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter+ buttonScript : htmlOutVIS=htmlUeber+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter+ buttonScript ;
                } else {
                   zentriert ?  htmlOutVIS=htmlZentriert+htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter+ buttonScript :  htmlOutVIS=htmlTabStyle+htmlTabUeber+htmlOut+"</table>"+htmlUnter+ buttonScript;
                }
                     
    
      // log("bin raus aus tabelleBind");
               if (braucheEinVISWidget)  setStateDelayed("javascript." + instance + ".Tabellen@Liv."+dpVIS+".HTMLTableVis", htmlOutVIS ,1000);
    
     var htmlUnter= "<div  style=\"color:"+htmlFarbUber+"; font-family:"+htmlSchriftart+"; font-size: 80%;  text-align: center; \" >"+htmlFeldUeber+"&ensp;&ensp;Last Update: "+formatDate(getDateObject((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 needDP(){
       for(let s=0;s<schalterInSpaltenUeberschrift.length;s++){ if(schalterInSpaltenUeberschrift[s]){
       if (!(await existsStateAsync("javascript." + instance + ".Tabellen@Liv."+dpVIS+".Spalte"+s))) {
           await createStateAsync("Tabellen@Liv."+dpVIS+".Spalte"+s, false,{type: "boolean", name: "Schalter_Spalte"+s, role: "value", read: true, write: true, } ); } 
         }}
    
       if (!(await existsStateAsync("javascript." + instance + ".Tabellen@Liv."+dpVIS+".HTMLTableVis"))) {
           await createStateAsync("Tabellen@Liv."+dpVIS+".HTMLTableVis", "empty",{type: "string", name: "HTML_Standard_Widget_mit_Binding", role: "value", read: true, write: true, } ); } 
        if (!(await existsStateAsync("javascript." + instance + ".Tabellen@Liv."+dpVIS+".JSONVis"))) {
           await createStateAsync("Tabellen@Liv."+dpVIS+".JSONVis", "",{type: "string", name: "JSON Format", role: "value", read: true, write: true, } ); }   
       
    
    
    
    }
      setTimeout(function () { 
    
       let arrTriggerSchalter=[]
       $("javascript." + instance + ".Tabellen@Liv."+dpVIS+".Spalte*").each(function(id, i) {  
              arrTriggerSchalter.push(id) 
       });
     //  log(arrTriggerSchalter.toString())
       on({id: arrTriggerSchalter, ack: false, change: "any"}, function (obj) { 
         //  log(obj.id)
         obj.id=="javascript." + instance + ".Tabellen@Liv."+dpVIS+".Spalte1"  ? welcheSortierung=1 : welcheSortierung=2;
         if (obj.id=="javascript." + instance + ".Tabellen@Liv."+dpVIS+".Spalte0") welcheSortierung=0;
       //  log(String(mehrfachTabelle))
      setTimeout(function () {  
           writeHTML();
           if (braucheEinFile) {writeFile(home, path ,htmlOut, function (error) { /* log('file written');*/  });}
    }, 350);
        
    
         
       });}, 5050);
    
    
    //SORTIEREN
    function sortMe(myType,value){
    
    if(myType=="alpha" ){
       if( typeof myObject[0][value] != "boolean" ){ 
        myObject.sort(function (alpha, beta) {
                if ((alpha[value].toString().toUpperCase()).trim() > (beta[value].toString().toUpperCase()).trim())
                   return 1;
                if ((beta[value].toString().toUpperCase()).trim()> (alpha[value].toUpperCase().toString()).trim())
                   return -1;
                return 0;
               });
       }  else { 
          myObject.sort(function(x, y) {
          return (x[value] === y[value])? 0 : x[value]? -1 : 1; });
       }  }   else { 
               
          myObject.sort(function (alpha, beta) {
                  return  beta[value] -alpha[value];   });}
    
    //    log(JSON.stringify(myObject))
       
    }
     
    
    
    
    
    
    

    bisher realisiert forum link
    Schedules in Javascript Instanzen https://forum.iobroker.net/topic/42501/html-tabelle-für-alle-schedules-in-den-scripten
    Liste für Telegram + VIS https://forum.iobroker.net/topic/42855/html-liste-für-telegram-und-vis
    Liste für Shelly Adapter https://forum.iobroker.net/topic/42903/html-tabelle-für-shelly-device-übersicht

    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
    1
    • liv-in-skyL Offline
      liv-in-skyL Offline
      liv-in-sky
      schrieb am zuletzt editiert von
      #2

      reserviert

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

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

        @dos1973

        kannst du bitte das script ausführen
        danach in den ordner /opt/iobroker/log gehen
        und das shelly file an mich senden

        var fs = require('fs');
        var now =    new Date(); // store current date and time
        var year =   now.getFullYear();
        var month =  addZero(now.getMonth()+1).zero2;
        var day =    addZero(now.getDate()).zero2;
        var Thour =  addZero(now.getHours()).zero2;
        var Tmin =   addZero(now.getMinutes()).zero2;
        var Tsec =   addZero(now.getSeconds()).zero2;
        var logdate = day + '.' + month + '.' + year;
        var logtime = Thour + '-' + Tmin + '-' + Tsec;
        
        var datei = "/opt/iobroker/log";
        
        // Schedule für die Updates
        //schedule("57 15 * * *",  function () {   
        
           var cacheSelectorState = $('state[state.id=shelly.0.*]');
        cacheSelectorState.each(function (id, i) {
           var val1 = getState(id).val;
              if (val1 == null ) 
                 {log(id + " hat keinen state");} 
            else {var zk = "setState('"+id+"', "+val1 +");\n";
                  if( typeof val1 === "string") {
                      zk = "setState('"+id+"', '"+val1+"');\n";
                    /*  log(id + " -- " + val1 + " ----------- " + val1.includes('span'));*/
                      if (val1.includes('span') || val1.includes('class')) {log("------------------------------------------------------------- span oder classn enthalten "+ id);} 
                      else {
                      fs.appendFileSync(datei + "/shelly-" + logdate + "-"+ logtime + ".txt", zk);}}
                  else {
                    /*  log("KEIN STRING " +id + " -- " + val1);*/
                      fs.appendFileSync(datei + "/shelly-" + logdate + "-"+ logtime + ".txt", zk);}
                  };
        //});
        /*
        //var cacheSelectorState = $('state[state.id=javascript.0.*]');
        var cacheSelectorState = $('[id=javascript.0.*]');
        //$('[id=alexa2.0.Echo-Devices.G0911B0592830RM7.Alarm.*.triggered]')
        cacheSelectorState.each(function (id, i) {
           if (!id.includes('scriptEnabled') && !id.includes('scriptProblem') && !id.includes('Log-Script')  && !id.includes('Ereignisliste') && !id.includes('GETPROCESS') ){
           var val1 = getState(id).val;
              if (val1 == null ) 
                 {log(id + " hat keinen state");} 
            else {var zk = "setState('"+id+"', "+val1 +");\n";
                  if(typeof val1 === "string" && !val1.includes('span') && !val1.includes('class')) {
                      zk = "setState('"+id+"', '"+val1+"');\n";
                      log(id + " -- " + val1 + " ----------- " + val1.includes('span'));
                      fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                  else {
                   log("KEIN STRING " +id + " -- " + val1);
                   fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                  };}
        });*/
        
        });
        
        /*
        //var cacheSelectorState = $('state[state.id=javascript.0.*]');
        var cacheSelectorState = $('[id=javascript.0.*]');
        
        cacheSelectorState.each(function (id, i) {
           if (!id.includes('scriptEnabled') && !id.includes('scriptProblem') && !id.includes('Log-Script')  && !id.includes('Ereignisliste') && !id.includes('GETPROCESS') ){
           var val1 = getState(id).val;
              if (val1 == null ) 
                 {log(id + " hat keinen state");} 
            else {var zk = "setState('"+id+"', "+val1 +");\n";
                  if(typeof val1 === "string" && !val1.includes('span') && !val1.includes('class')) {
                      zk = "setState('"+id+"', '"+val1+"');\n";
                      fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                  else {
                      fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                  };}
        });
        
        });
        */
        
        // ---------------------------------------------------------------------------------------
        // Funktion zur Erzeugung von 2 oder 3 führenden Nullen für das Datum Format
        //-----------------------------------------------------------------------------------------------------
        function addZero(i) {
           if (i < 10) {
               j = "00" + i;
               i = "0" + i;
           }
           if (i > 9 && i < 100) {
               j = "0" + i;
           }
           return {
               'zero2' : i,
               'zero3' : j
           };
        } // Ende Funktion
        
        

        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

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

          @dos1973

          kannst du bitte das script ausführen
          danach in den ordner /opt/iobroker/log gehen
          und das shelly file an mich senden

          var fs = require('fs');
          var now =    new Date(); // store current date and time
          var year =   now.getFullYear();
          var month =  addZero(now.getMonth()+1).zero2;
          var day =    addZero(now.getDate()).zero2;
          var Thour =  addZero(now.getHours()).zero2;
          var Tmin =   addZero(now.getMinutes()).zero2;
          var Tsec =   addZero(now.getSeconds()).zero2;
          var logdate = day + '.' + month + '.' + year;
          var logtime = Thour + '-' + Tmin + '-' + Tsec;
          
          var datei = "/opt/iobroker/log";
          
          // Schedule für die Updates
          //schedule("57 15 * * *",  function () {   
          
             var cacheSelectorState = $('state[state.id=shelly.0.*]');
          cacheSelectorState.each(function (id, i) {
             var val1 = getState(id).val;
                if (val1 == null ) 
                   {log(id + " hat keinen state");} 
              else {var zk = "setState('"+id+"', "+val1 +");\n";
                    if( typeof val1 === "string") {
                        zk = "setState('"+id+"', '"+val1+"');\n";
                      /*  log(id + " -- " + val1 + " ----------- " + val1.includes('span'));*/
                        if (val1.includes('span') || val1.includes('class')) {log("------------------------------------------------------------- span oder classn enthalten "+ id);} 
                        else {
                        fs.appendFileSync(datei + "/shelly-" + logdate + "-"+ logtime + ".txt", zk);}}
                    else {
                      /*  log("KEIN STRING " +id + " -- " + val1);*/
                        fs.appendFileSync(datei + "/shelly-" + logdate + "-"+ logtime + ".txt", zk);}
                    };
          //});
          /*
          //var cacheSelectorState = $('state[state.id=javascript.0.*]');
          var cacheSelectorState = $('[id=javascript.0.*]');
          //$('[id=alexa2.0.Echo-Devices.G0911B0592830RM7.Alarm.*.triggered]')
          cacheSelectorState.each(function (id, i) {
             if (!id.includes('scriptEnabled') && !id.includes('scriptProblem') && !id.includes('Log-Script')  && !id.includes('Ereignisliste') && !id.includes('GETPROCESS') ){
             var val1 = getState(id).val;
                if (val1 == null ) 
                   {log(id + " hat keinen state");} 
              else {var zk = "setState('"+id+"', "+val1 +");\n";
                    if(typeof val1 === "string" && !val1.includes('span') && !val1.includes('class')) {
                        zk = "setState('"+id+"', '"+val1+"');\n";
                        log(id + " -- " + val1 + " ----------- " + val1.includes('span'));
                        fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                    else {
                     log("KEIN STRING " +id + " -- " + val1);
                     fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                    };}
          });*/
          
          });
          
          /*
          //var cacheSelectorState = $('state[state.id=javascript.0.*]');
          var cacheSelectorState = $('[id=javascript.0.*]');
          
          cacheSelectorState.each(function (id, i) {
             if (!id.includes('scriptEnabled') && !id.includes('scriptProblem') && !id.includes('Log-Script')  && !id.includes('Ereignisliste') && !id.includes('GETPROCESS') ){
             var val1 = getState(id).val;
                if (val1 == null ) 
                   {log(id + " hat keinen state");} 
              else {var zk = "setState('"+id+"', "+val1 +");\n";
                    if(typeof val1 === "string" && !val1.includes('span') && !val1.includes('class')) {
                        zk = "setState('"+id+"', '"+val1+"');\n";
                        fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                    else {
                        fs.appendFileSync(datei + logdate + "-"+ logtime + ".txt", zk);}
                    };}
          });
          
          });
          */
          
          // ---------------------------------------------------------------------------------------
          // Funktion zur Erzeugung von 2 oder 3 führenden Nullen für das Datum Format
          //-----------------------------------------------------------------------------------------------------
          function addZero(i) {
             if (i < 10) {
                 j = "00" + i;
                 i = "0" + i;
             }
             if (i > 9 && i < 100) {
                 j = "0" + i;
             }
             return {
                 'zero2' : i,
                 'zero3' : j
             };
          } // Ende Funktion
          
          

          D Offline
          D Offline
          dos1973
          schrieb am zuletzt editiert von
          #4

          @liv-in-sky
          ist unterwegs...

          liv-in-skyL 1 Antwort Letzte Antwort
          0
          • D dos1973

            @liv-in-sky
            ist unterwegs...

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

            @dos1973 chat !

            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
            Antworten
            • In einem neuen Thema antworten
            Anmelden zum Antworten
            • Älteste zuerst
            • Neuste zuerst
            • Meiste Stimmen


            Support us

            ioBroker
            Community Adapters
            Donate

            359

            Online

            32.4k

            Benutzer

            81.4k

            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