Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Corona-Ampel Österreich in VIS anzeigen

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Corona-Ampel Österreich in VIS anzeigen

    This topic has been deleted. Only users with topic management privileges can see it.
    • liv-in-sky
      liv-in-sky @bergjet last edited by

      @bergjet

      eher nicht - mit ubuntu läuft es direkt - also nehme ich an, da ist der level auch 1 - bei sigi mit windows ist das auch standard

      ich habe es nie gegoogelt, ob das ein problem ist - aber ich denke das ist ok

      ich hab es auch nicht zurückgeändert

      sigi234 1 Reply Last reply Reply Quote 0
      • sigi234
        sigi234 Forum Testing Most Active @liv-in-sky last edited by

        @liv-in-sky

        Hallo, kann man in der Tabelle auch sortieren? Kannst du das einbauen?

        Screenshot (761)_LI.jpg

        Ev. ist das Interessant:

        https://coronaampeliframe.web.app/gkz.html

        liv-in-sky 1 Reply Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @sigi234 last edited by liv-in-sky

          @sigi234

          zur richtigstellung:
          das ist nicht mein script - das hat @jackblackson gemacht - ih habe es nur geändert, weil er sich nicht gemeldet hat

          zum thema sortieren

          • dauerhafte sortierung (über setting im script)
          • sortierung, die du über vis steuern kannst
          • nach was sortieren ?warnstufe, gkz, ort ?

          gäbe es das in DE; ich hätte eigentlich interesse, zu wissen, was in den nachbargebieten von meinem standort los ist (bzw, arbeit verwandschaft,..) - in der vis: eine ampel für meinen standort und außenrum die nachbar-gebiete als farbige punkte (oder kleine ampeln) - das bedeutet, anstatt einen bereich zu suchen, eine anahl an gesuchten gebieten als datenpunkte darzustellen
          oder die tabelle nur mit den werten , die mich interessieren - es sin in der tabelle über 2000 datensätze -wer wird das jemals ansehen ? sind da nur 10 werte oder so, in der tabelle, mit farbigen punkten, wäre interessanter und man würde es sofort sehen in der tabelle

          sigi234 F 3 Replies Last reply Reply Quote 0
          • sigi234
            sigi234 Forum Testing Most Active @liv-in-sky last edited by

            @liv-in-sky sagte in Corona-Ampel Österreich in VIS anzeigen:

            zur richtigstellung:
            das ist nicht mein script - das hat @jackblackson gemacht - ih habe es nur geändert, weil er sich nicht gemeldet hat

            Upps, geändert.

            1 Reply Last reply Reply Quote 0
            • sigi234
              sigi234 Forum Testing Most Active @liv-in-sky last edited by sigi234

              @liv-in-sky sagte in Corona-Ampel Österreich in VIS anzeigen:

              @sigi234
              zum thema sortieren

              • dauerhafte sortierung (über setting im script)

              Ja

              • sortierung, die du über vis steuern kannst

              Ja

              • nach was sortieren ?warnstufe, gkz, ort ?

              gkz weil nur diese eindeutig ist

              gäbe es das in DE; ich hätte eigentlich interesse, zu wissen, was in den nachbargebieten von meinem standort los ist

              Ja

              (bzw, arbeit verwandschaft,..) - in der vis: eine ampel für meinen standort und außenrum die nachbar-gebiete als farbige punkte (oder kleine ampeln) - das bedeutet, anstatt einen bereich zu suchen, eine anahl an gesuchten gebieten als datenpunkte darzustellen

              Ja

              oder die tabelle nur mit den werten , die mich interessieren - es sin in der tabelle über 2000 datensätze -wer wird das jemals ansehen ? sind da nur 10 werte oder so, in der tabelle, mit farbigen punkten, wäre interessanter und man würde es sofort sehen in der tabelle

              Ja , ich brauche nicht ganz Österreich. Wie du schon erwähnt hast reicht eigentlich die Umgebung. Daher wäre eine Option im Skript gut: Bundesländer, Bezirke

              9 Bundesländer: Burgenland, Kärnten, Niederösterreich, Oberösterreich, Salzburg, Steiermark, Tirol, Vorarlberg, Wien
              94 Bezirke
              2.095 Gemeinden
              

              polbezirke.xlsx

              bergjet 1 Reply Last reply Reply Quote 0
              • bergjet
                bergjet @sigi234 last edited by

                @sigi234 said in Corona-Ampel Österreich in VIS anzeigen:

                reicht eigentlich die Umgebung

                Du könntest mehrere Skripte laufen lassen mit den für dich interessanten GKZ
                Du musst nur in jedem Skript ein anderes Directory angeben.

                sigi234 1 Reply Last reply Reply Quote 0
                • sigi234
                  sigi234 Forum Testing Most Active @bergjet last edited by sigi234

                  @bergjet sagte in Corona-Ampel Österreich in VIS anzeigen:

                  @sigi234 said in Corona-Ampel Österreich in VIS anzeigen:

                  reicht eigentlich die Umgebung

                  Du könntest mehrere Skripte laufen lassen mit den für dich interessanten GKZ
                  Du musst nur in jedem Skript ein anderes Directory angeben.

                  Natürlich auch eine Möglichkeit.

                  Ich denke auch das Deutschland bald eine Ampel bekommt.😀

                  liv-in-sky 2 Replies Last reply Reply Quote 0
                  • liv-in-sky
                    liv-in-sky @sigi234 last edited by liv-in-sky

                    @sigi234 @bergjet

                    habe mich für's erste für ein json als ausgabe entschieden - damit kann man ein json-widget (z.b. invento in diesem beispiel) nutzen - man kann im script die gkz's eingeben, die man haben will

                    Image 2.png
                    habe eine auswahl dieser gebiete im script angegeben

                    im moment bin ich noch etwas verwirrt - es gibt jetzt 2 urls - eines gesamt, eines mit gemeinden - was ist der unterschied - im allgemeinen sind ja auch gemeinden drin - habe momentan beide urls abgefragt und in einem array vereint - weiß noch nicht, ob da was doppelt ist

                    bergjet 1 Reply Last reply Reply Quote 1
                    • liv-in-sky
                      liv-in-sky @sigi234 last edited by

                      @sigi234

                      die sortierung muss noch gemacht werden - dann gibt es wieder was zum testen - könnte aber etwas dauern

                      sigi234 1 Reply Last reply Reply Quote 0
                      • sigi234
                        sigi234 Forum Testing Most Active @liv-in-sky last edited by sigi234

                        @liv-in-sky sagte in Corona-Ampel Österreich in VIS anzeigen:

                        @sigi234

                        die sortierung muss noch gemacht werden - dann gibt es wieder was zum testen - könnte aber etwas dauern

                        Super

                        @liv-in-sky sagte in Corona-Ampel Österreich in VIS anzeigen:

                        im moment bin ich noch etwas verwirrt - es gibt jetzt 2 urls - eines gesamt, eines mit gemeinden - was ist der unterschied

                        Ausschlaggebend ist die GKZ

                        Zitat:
                        18. September 2020: Ein zusätzliches File auf Gemeindeebene wird zur Verfügung gestellt. Das Gemeindefile enthält im die Warnstufen auf Gemeindeebene in chronologischer Form. Das Schema entspricht dem des Datenfiles.

                        liv-in-sky 1 Reply Last reply Reply Quote 0
                        • liv-in-sky
                          liv-in-sky @sigi234 last edited by

                          @sigi234

                          bitte testen - muss jetzt leider weg

                          dp Sortierung kann 1,2,3 oder 4 gesetzt werden - der json dp - ist für json-widget

                          //5.10.2020 14:00
                          const url2 = 'https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_aktuell.json';
                          const url = 'https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_Gemeinden_aktuell.json';
                          var warnstufe=0;
                          var htmlwidget ='';
                          var arrStand="";
                          var sucheGKZ="80111"
                          var zusatzRegionen=["7","10716","40807","40809","40810","40824","10508","10706","80112","405","5","50326","50329"]
                          
                          var farbwertLevel1 = '#04B404'
                          var farbwertLevel2 = '#FFFF00'
                          var farbwertLevel3 = '#FF8000'
                          var farbwertLevel4 = '#DF0101'
                          var warngebiet = ''
                          var warnregion="";
                          var anzahl=0;
                          var gkz=""
                          var directory = 'Coronaampel' //javascript.0.xxx
                          var tableContent = ''
                          var dpSort;
                          
                          createState(directory  + '.warnstufe', {
                             name: 'Corona Warnstufe',
                             read: true, 
                             write: false, 
                             type: "number", 
                             def: 0
                          });
                          createState(directory  + '.anzahl', {
                             name: 'Corona Anzahl',
                             read: true, 
                             write: false, 
                             type: "number", 
                             def: 0
                          });
                          createState(directory  + '.Sortierung', {
                             name: 'Corona Sortierung',
                             read: true, 
                             write: true, 
                             type: "number", 
                             def: 1
                          });
                          
                          createState(directory  + '.warngebiet', {
                             name: 'Corona Warngebiet',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          
                          createState(directory  + '.warnfarbe', {
                             name: 'Corona Warnfarbe',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          createState(directory  + '.geholt', {
                             name: 'Corona Datum',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          
                          createState(directory  + '.GKZ', {
                             name: 'Corona GKZ',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          
                          createState(directory  + '.warnregion', {
                             name: 'Corona Region',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          
                          createState(directory  + '.stand', {
                             name: 'Corona stand',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          
                          createState(directory  + '.warntabelle', {
                             name: 'Corona Tabelle',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          
                          
                          createState(directory  + '.jsonTable', {
                             name: 'Corona jsonTabelle',
                             read: true, 
                             write: false, 
                             type: "string", 
                             def: ""
                          });
                          var myObj=[];
                          
                          schedule('  */30 * * * * *', function() {
                             dpSort=getState(directory+'.Sortierung').val
                             myObj=[];
                             warnstufe = 0;
                             tableContent = ''
                             request(url, function(err, response, json) {
                           
                                 let arr = (JSON.parse(json)[0]).Warnstufen;
                                  arrStand = (JSON.parse(json)[0]).Stand;
                               //  log(JSON.stringify(arr))
                               //  log(arr.flat(1))
                                 //log(arrStand.toString())
                                 //Loop und suche nach Bezirk
                          
                                request(url2, function(err, response, json) {
                           
                                 let arr2 = (JSON.parse(json)[0]).Warnstufen;
                               log(arr.length.toString())
                                 arr= arr.concat(arr2)
                                    log(arr.length.toString())
                              for(var z = 0; z < zusatzRegionen.length; z++) {    
                                  for(let i = 0; i < arr.length; i++) { 
                                    if(arr[i].GKZ == zusatzRegionen[z]){
                                      myObj.push(arr[i])
                                      break;
                                      }
                                 }
                              }
                              
                              for(let i = 0; i < arr.length; i++) { 
                                    if(arr[i].GKZ == sucheGKZ){
                                      //log(' Warnstufe für ' + suchwertBezirk + ': ' + arr[i].Warnstufe)
                                      warnstufe = Number(arr[i].Warnstufe);
                                      gkz=sucheGKZ
                                      warnregion=arr[i].Region
                                      warngebiet = arr[i].Name 
                                     break;}}
                          
                                 anzahl=arr.length
                          
                          
                          
                          
                          
                                 for(let i = 0; i < arr.length; i++) { 
                                     fillTable(arr[i].Region,arr[i].Name,arr[i].Warnstufe,arr[i].GKZ)
                                 }
                                 finishTable()
                          
                             
                          
                          
                          
                             saveData()
                          
                             });
                             });
                          
                          });
                          
                          function fillTable(gebiet,name,warnstufe,gkz){
                             if (tableContent == ''){
                               tableContent = '<table ><tbody>'  
                             }
                             tableContent += '<tr><td>' + gebiet + '</td>'
                             tableContent += '<td>' + gkz + '</td>'
                             tableContent += '<td>' + name + '</td>'
                             tableContent += '<td>' + warnstufe + '</td>'
                             tableContent += '</tr>';
                          }
                          
                          function finishTable(){
                          
                             tableContent += '</tbody></table>'
                             setState(directory+'.warntabelle',tableContent)
                          }
                          
                          function saveData(){
                               sotiereJson(dpSort)    
                                     
                          
                             jsonWarn()
                              setState(directory+'.jsonTable',JSON.stringify(myObj))
                          
                          
                             setState(directory+'.anzahl',anzahl)
                           //  setState(directory+'.searchbyGKZ',suchGKZactivieren)
                             setState(directory+'.warnstufe',warnstufe)
                             setState(directory+'.warngebiet',warngebiet)
                             setState(directory+'.GKZ',gkz)
                             setState(directory+'.warnregion',warnregion)
                             setState(directory+'.geholt',formatDate(getDateObject((new Date().getTime())), "hh:mm"))
                             setState(directory+'.stand',   formatDate(getDateObject(arrStand.toString()), "TT:MM:JJJJ -  SS:mm"));
                             switch (warnstufe) {
                                         case 1: 
                                                         setState(directory+'.warnfarbe',farbwertLevel1)
                                                         break;
                                         case 2: 
                                                          setState(directory+'.warnfarbe',farbwertLevel2)
                                                         break;
                                         case 3: 
                                                         setState(directory+'.warnfarbe',farbwertLevel3)
                                                         break;
                                         case 4   : 
                                                         setState(directory+'.warnfarbe',farbwertLevel4)
                                                         break;
                                         default: setState(directory+'.warnfarbe',"");
                                         ;
                                     }
                          }
                          
                          function jsonWarn(){
                          
                              for(let i = 0; i < myObj.length; i++) { 
                                var istWarnstufe=Number(myObj[i].Warnstufe)
                                 switch (istWarnstufe) {
                                         case 1: 
                                                         myObj[i].Warnstufe="🟢"
                                                         break;
                                         case 2: 
                                                         myObj[i].Warnstufe="🟡"
                                                         break;
                                         case 3: 
                                                         myObj[i].Warnstufe="🔴"
                                                         break;
                                         case 4   : 
                                                         myObj[i].Warnstufe="depp"
                                                         break;
                                         default: myObj[i].Warnstufe="?";
                                         ;
                                     }
                                   }
                                   }
                                   
                          
                          function sotiereJson(mySort) {
                             // log(mySort.toString())
                          switch (mySort) {
                                         case 1: 
                                                          myObj.sort(function (alpha, beta) {
                                                               if (alpha.Region > beta.Region )
                                      
                                                               return 1;
                                                               if (beta.Region > alpha.Region)
                                                               return -1;
                                                               return 0;
                                                            }); 
                                                         break;
                                         case 2: 
                                                         myObj.sort(function (alpha, beta) {
                                                              if (Number(alpha.GKZ) > Number(beta.GKZ) )
                                                              return 1;
                                                             if (Number(beta.GKZ) > Number(alpha.GKZ)  )
                                                             return -1;
                                                             return 0;
                                                                 }); 
                                                         break;
                                         case 3: 
                                                       myObj.sort(function (alpha, beta) {
                                                              if (alpha.Name > beta.Name )
                                      
                                                              return 1;
                                                             if (beta.Name > alpha.Name)
                                                             return -1;
                                                             return 0;
                                     });
                                                         break;
                                         case 4   : 
                                                         myObj.sort(function(a, b){
                                                         return b.Warnstufe - a.Warnstufe;
                                                         });
                                                         break;
                                         default:        myObj.sort(function(a, b){
                                                         return b.Warnstufe - a.Warnstufe;
                                                         });
                                         ;
                                     }
                          
                          
                          
                          }
                          
                          
                          
                          
                          
                          

                          Image 3.png

                          sigi234 1 Reply Last reply Reply Quote 1
                          • sigi234
                            sigi234 Forum Testing Most Active @liv-in-sky last edited by sigi234

                            @liv-in-sky

                            Danke, ich teste es.

                            Funktioniert einwandfrei. Tolle Arbeit. 👍

                            Screenshot (766)_LI.jpg

                            liv-in-sky 1 Reply Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @sigi234 last edited by liv-in-sky

                              @sigi234 klasse, dass es funktioniert und durch deine vis wieder verschönert wird 🙂

                              vergiß nicht das schedule umzustellen - ich glaube zum testen hatte ich alle 30 sek drin

                              jackblackson 1 Reply Last reply Reply Quote 0
                              • jackblackson
                                jackblackson @liv-in-sky last edited by

                                @liv-in-sky Danke für deine starke Unterstützung, ich hab zwar schon etwas Javascript geübt, aber Profi bin ich noch keiner. Find es genial wie du mein einfaches Skript inzwischen perfektioniert hast.

                                liv-in-sky sigi234 2 Replies Last reply Reply Quote 0
                                • liv-in-sky
                                  liv-in-sky @jackblackson last edited by

                                  @jackblackson
                                  freut mich, dass du das so positiv aufnimmst - dein script war aber auch gut vorbereitet - habe nur etwas dazugefügt

                                  sigi234 1 Reply Last reply Reply Quote 0
                                  • sigi234
                                    sigi234 Forum Testing Most Active @jackblackson last edited by

                                    @jackblackson

                                    Natürlich geht auch der Dank an dich.

                                    1 Reply Last reply Reply Quote 1
                                    • sigi234
                                      sigi234 Forum Testing Most Active @liv-in-sky last edited by sigi234

                                      @liv-in-sky
                                      Die Daten werden nur Freitags aktualisiert, ein Cron mit Freitag 15:00 Uhr wäre ja dann ausreichend?

                                      Ev. ein DP um es Manuel aus zu lösen?

                                      liv-in-sky G 3 Replies Last reply Reply Quote 0
                                      • liv-in-sky
                                        liv-in-sky @sigi234 last edited by

                                        @sigi234

                                        hatte ich auch schon daran gedacht - ich habe mir eine werteliste in der vis gemacht, damit ich das sortieren auswählen kann -- da ist aber das gleiche thema - wenn ich anders sortieren will, muss ja auch die tabelle neu erstellt werden

                                        @jackblackson möchtest du das übernehmen, oder soll ich mich versuchen - ich dachte daran, alles im schedule als funtion zu machen - dann kann man das auch "solo" aufrufen

                                        1 Reply Last reply Reply Quote 0
                                        • liv-in-sky
                                          liv-in-sky @sigi234 last edited by

                                          @sigi234

                                          refresh und sortierung

                                          anim-gif6.gif

                                          //6.10.2020 9:00
                                          const url2 = 'https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_aktuell.json';
                                          const url = 'https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_Gemeinden_aktuell.json';
                                          var warnstufe=0;
                                          var htmlwidget ='';
                                          var arrStand="";
                                          var sucheGKZ="7"
                                          var zusatzRegionen=["80111","10716","40807","40809","40810","40824","10508","10706","80112","405","5","50326","50329"]
                                          
                                          var farbwertLevel1 = '#04B404'
                                          var farbwertLevel2 = '#FFFF00'
                                          var farbwertLevel3 = '#FF8000'
                                          var farbwertLevel4 = '#DF0101'
                                          var warngebiet = ''
                                          var warnregion="";
                                          var anzahl=0;
                                          var gkz=""
                                          var directory = 'Coronaampel' //javascript.0.xxx
                                          var tableContent = ''
                                          var dpSort;
                                          
                                          createState(directory  + '.warnstufe', {
                                             name: 'Corona Warnstufe',
                                             read: true, 
                                             write: false, 
                                             type: "number", 
                                             def: 0
                                          });
                                          createState(directory  + '.anzahl', {
                                             name: 'Corona Anzahl',
                                             read: true, 
                                             write: false, 
                                             type: "number", 
                                             def: 0
                                          });
                                          createState(directory  + '.Sortierung', {
                                             name: 'Corona Sortierung',
                                             read: true, 
                                             write: true, 
                                             type: "number", 
                                             def: 1
                                          });
                                          createState(directory  + '.Refresh', {
                                             name: 'Corona Refresh',
                                             read: true, 
                                             write: true, 
                                             type: "boolean", 
                                             def: false
                                          });
                                          
                                          createState(directory  + '.warngebiet', {
                                             name: 'Corona Warngebiet',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          
                                          createState(directory  + '.warnfarbe', {
                                             name: 'Corona Warnfarbe',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          createState(directory  + '.geholt', {
                                             name: 'Corona Datum',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          
                                          createState(directory  + '.GKZ', {
                                             name: 'Corona GKZ',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          
                                          createState(directory  + '.warnregion', {
                                             name: 'Corona Region',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          
                                          createState(directory  + '.stand', {
                                             name: 'Corona stand',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          
                                          createState(directory  + '.warntabelle', {
                                             name: 'Corona Tabelle',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          
                                          
                                          createState(directory  + '.jsonTable', {
                                             name: 'Corona jsonTabelle',
                                             read: true, 
                                             write: false, 
                                             type: "string", 
                                             def: ""
                                          });
                                          var myObj=[];
                                          
                                          schedule(' 14 */4 * * *', function() { 
                                          main()
                                          });
                                          
                                          setTimeout(function(){main()},10000);
                                          
                                          
                                          
                                          function main() {   dpSort=getState(directory+'.Sortierung').val
                                             myObj=[];
                                             warnstufe = 0;
                                             tableContent = ''
                                             request(url, function(err, response, json) {
                                           
                                                 let arr = (JSON.parse(json)[0]).Warnstufen;
                                                  arrStand = (JSON.parse(json)[0]).Stand;
                                               //  log(JSON.stringify(arr))
                                               //  log(arr.flat(1))
                                                 //log(arrStand.toString())
                                                 //Loop und suche nach Bezirk
                                          
                                                request(url2, function(err, response, json) {
                                           
                                                 let arr2 = (JSON.parse(json)[0]).Warnstufen;
                                              // log(arr.length.toString())
                                                 arr= arr.concat(arr2)
                                                //    log(arr.length.toString())
                                              for(var z = 0; z < zusatzRegionen.length; z++) {    
                                                  for(let i = 0; i < arr.length; i++) { 
                                                    if(arr[i].GKZ == zusatzRegionen[z]){
                                                      myObj.push(arr[i])
                                                      break;
                                                      }
                                                 }
                                              }
                                              
                                              for(let i = 0; i < arr.length; i++) { 
                                                    if(arr[i].GKZ == sucheGKZ){
                                                      //log(' Warnstufe für ' + suchwertBezirk + ': ' + arr[i].Warnstufe)
                                                      warnstufe = Number(arr[i].Warnstufe);
                                                      gkz=sucheGKZ
                                                      warnregion=arr[i].Region
                                                      warngebiet = arr[i].Name 
                                                     break;}}
                                          
                                                 anzahl=arr.length
                                          
                                          
                                          
                                          
                                          
                                                 for(let i = 0; i < arr.length; i++) { 
                                                     fillTable(arr[i].Region,arr[i].Name,arr[i].Warnstufe,arr[i].GKZ)
                                                 }
                                                 finishTable()
                                          
                                             
                                          
                                          
                                          
                                             saveData()
                                          
                                             });
                                             });
                                          
                                          }
                                          
                                          function fillTable(gebiet,name,warnstufe,gkz){
                                             if (tableContent == ''){
                                               tableContent = '<table ><tbody>'  
                                             }
                                             tableContent += '<tr><td>' + gebiet + '</td>'
                                             tableContent += '<td>' + gkz + '</td>'
                                             tableContent += '<td>' + name + '</td>'
                                             tableContent += '<td>' + warnstufe + '</td>'
                                             tableContent += '</tr>';
                                          }
                                          
                                          function finishTable(){
                                          
                                             tableContent += '</tbody></table>'
                                             setState(directory+'.warntabelle',tableContent)
                                          }
                                          
                                          function saveData(){
                                               sotiereJson(dpSort)    
                                                     
                                          
                                             jsonWarn()
                                              setState(directory+'.jsonTable',JSON.stringify(myObj))
                                          
                                             setState(directory+'.Refresh',false)
                                             setState(directory+'.anzahl',anzahl)
                                           //  setState(directory+'.searchbyGKZ',suchGKZactivieren)
                                             setState(directory+'.warnstufe',warnstufe)
                                             setState(directory+'.warngebiet',warngebiet)
                                             setState(directory+'.GKZ',gkz)
                                             setState(directory+'.warnregion',warnregion)
                                             setState(directory+'.geholt',formatDate(getDateObject((new Date().getTime())), "hh:mm"))
                                             setState(directory+'.stand',   formatDate(getDateObject(arrStand.toString()), "TT:MM:JJJJ -  SS:mm"));
                                             switch (warnstufe) {
                                                         case 1: 
                                                                         setState(directory+'.warnfarbe',farbwertLevel1)
                                                                         break;
                                                         case 2: 
                                                                          setState(directory+'.warnfarbe',farbwertLevel2)
                                                                         break;
                                                         case 3: 
                                                                         setState(directory+'.warnfarbe',farbwertLevel3)
                                                                         break;
                                                         case 4   : 
                                                                         setState(directory+'.warnfarbe',farbwertLevel4)
                                                                         break;
                                                         default: setState(directory+'.warnfarbe',"");
                                                         ;
                                                     }
                                          }
                                          
                                          function jsonWarn(){
                                          
                                              for(let i = 0; i < myObj.length; i++) { 
                                                var istWarnstufe=Number(myObj[i].Warnstufe)
                                                 switch (istWarnstufe) {
                                                         case 1: 
                                                                         myObj[i].Warnstufe="🟢"
                                                                         break;
                                                         case 2: 
                                                                         myObj[i].Warnstufe="🟡"
                                                                         break;
                                                         case 3: 
                                                                         myObj[i].Warnstufe="🔴"
                                                                         break;
                                                         case 4   : 
                                                                         myObj[i].Warnstufe="depp"
                                                                         break;
                                                         default: myObj[i].Warnstufe="?";
                                                         ;
                                                     }
                                                   }
                                                   }
                                                   
                                          
                                          function sotiereJson(mySort) {
                                             // log(mySort.toString())
                                          switch (mySort) {
                                                         case 1: 
                                                                          myObj.sort(function (alpha, beta) {
                                                                               if (alpha.Region > beta.Region )
                                                      
                                                                               return 1;
                                                                               if (beta.Region > alpha.Region)
                                                                               return -1;
                                                                               return 0;
                                                                            }); 
                                                                         break;
                                                         case 2: 
                                                                         myObj.sort(function (alpha, beta) {
                                                                              if (Number(alpha.GKZ) > Number(beta.GKZ) )
                                                                              return 1;
                                                                             if (Number(beta.GKZ) > Number(alpha.GKZ)  )
                                                                             return -1;
                                                                             return 0;
                                                                                 }); 
                                                                         break;
                                                         case 3: 
                                                                       myObj.sort(function (alpha, beta) {
                                                                              if (alpha.Name > beta.Name )
                                                      
                                                                              return 1;
                                                                             if (beta.Name > alpha.Name)
                                                                             return -1;
                                                                             return 0;
                                                     });
                                                                         break;
                                                         case 4   : 
                                                                         myObj.sort(function(a, b){
                                                                         return b.Warnstufe - a.Warnstufe;
                                                                         });
                                                                         break;
                                                         default:        myObj.sort(function(a, b){
                                                                         return b.Warnstufe - a.Warnstufe;
                                                                         });
                                                         ;
                                                     }
                                          
                                          
                                          
                                          }
                                          
                                          on({id: 'javascript.'+instance+'.'+directory  + '.Sortierung', change: "any"}, function (obj) { 
                                             
                                              main()
                                          
                                          });
                                           on({id: 'javascript.'+instance+'.'+directory  + '.Refresh', val: true}, function (obj) { 
                                             
                                              main()
                                              
                                          
                                          });
                                          
                                          
                                          
                                          

                                          sigi234 1 Reply Last reply Reply Quote 1
                                          • bergjet
                                            bergjet @liv-in-sky last edited by

                                            @liv-in-sky Sehr schön. Ich brauche nur noch jemand, der mir dieses Widget erklärt. Invento, welches und was wird wo eingetragen?

                                            liv-in-sky 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

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

                                            879
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            corona vis
                                            10
                                            217
                                            18874
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo