Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Corona-Ampel Österreich in VIS anzeigen

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    17
    1
    521

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    5.3k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.4k

Corona-Ampel Österreich in VIS anzeigen

Scheduled Pinned Locked Moved ioBroker Allgemein
coronavis
217 Posts 10 Posters 33.9k Views 9 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • liv-in-skyL liv-in-sky

    @bergjet

    bei mir nicht

    Image 4.png

    refresh mal den browser

    sigi234S Online
    sigi234S Online
    sigi234
    Forum Testing Most Active
    wrote on last edited by sigi234
    #85

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

    refresh mal den browser

    @bergjet
    Und Objekte aktualisieren und 1 Minute warten.

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

    1 Reply Last reply
    0
    • liv-in-skyL liv-in-sky

      @sigi234 danke

      bergjetB Offline
      bergjetB Offline
      bergjet
      wrote on last edited by
      #86

      @liv-in-sky Danke, nun stimmt es auch bei mir. Keine Ahnung woran es lag.
      Perfekt und danke an @liv-in-sky für die Arbeit.

      homee, ioBroker, iMac, iPhone, Sonos, Alaxa

      1 Reply Last reply
      0
      • liv-in-skyL liv-in-sky

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

        @liv-in-sky Bei mir kommt im log

        javascript.0	2020-10-04 16:54:00.839	error	(30979) Request error: Error: write EPROTO 3070048720:error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small:../deps/openssl/openssl/ssl/statem/statem_clnt.c:2150:
        javascript.0	2020-10-04 16:54:00.837	error	(30979) Error in request callback: SyntaxError: Unexpected token u in JSON at position 0
        

        moment du hast da das problem mit dem ssl key

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

        bergjetB Offline
        bergjetB Offline
        bergjet
        wrote on last edited by
        #87

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

        moment du hast da das problem mit dem ssl key

        Muss man sich Sorgen machen wenn man SECLEVEL=1 auf 1 setzt?

        homee, ioBroker, iMac, iPhone, Sonos, Alaxa

        liv-in-skyL 1 Reply Last reply
        0
        • bergjetB bergjet

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

          moment du hast da das problem mit dem ssl key

          Muss man sich Sorgen machen wenn man SECLEVEL=1 auf 1 setzt?

          liv-in-skyL Offline
          liv-in-skyL Offline
          liv-in-sky
          wrote on last edited by
          #88

          @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

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

          sigi234S 1 Reply Last reply
          0
          • liv-in-skyL liv-in-sky

            @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

            sigi234S Online
            sigi234S Online
            sigi234
            Forum Testing Most Active
            wrote on last edited by
            #89

            @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

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

            liv-in-skyL 1 Reply Last reply
            0
            • sigi234S sigi234

              @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-skyL Offline
              liv-in-skyL Offline
              liv-in-sky
              wrote on last edited by liv-in-sky
              #90

              @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

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

              sigi234S F 3 Replies Last reply
              0
              • liv-in-skyL 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

                sigi234S Online
                sigi234S Online
                sigi234
                Forum Testing Most Active
                wrote on last edited by
                #91

                @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.

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

                1 Reply Last reply
                0
                • liv-in-skyL 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

                  sigi234S Online
                  sigi234S Online
                  sigi234
                  Forum Testing Most Active
                  wrote on last edited by sigi234
                  #92

                  @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

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

                  bergjetB 1 Reply Last reply
                  0
                  • sigi234S 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

                    bergjetB Offline
                    bergjetB Offline
                    bergjet
                    wrote on last edited by
                    #93

                    @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.

                    homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                    sigi234S 1 Reply Last reply
                    0
                    • bergjetB bergjet

                      @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.

                      sigi234S Online
                      sigi234S Online
                      sigi234
                      Forum Testing Most Active
                      wrote on last edited by sigi234
                      #94

                      @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.:grinning:

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

                      liv-in-skyL 2 Replies Last reply
                      0
                      • sigi234S 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.:grinning:

                        liv-in-skyL Offline
                        liv-in-skyL Offline
                        liv-in-sky
                        wrote on last edited by liv-in-sky
                        #95

                        @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

                        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

                        bergjetB 1 Reply Last reply
                        1
                        • sigi234S 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.:grinning:

                          liv-in-skyL Offline
                          liv-in-skyL Offline
                          liv-in-sky
                          wrote on last edited by
                          #96

                          @sigi234

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

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

                          sigi234S 1 Reply Last reply
                          0
                          • liv-in-skyL liv-in-sky

                            @sigi234

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

                            sigi234S Online
                            sigi234S Online
                            sigi234
                            Forum Testing Most Active
                            wrote on last edited by sigi234
                            #97

                            @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.

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

                            liv-in-skyL 1 Reply Last reply
                            0
                            • sigi234S 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-skyL Offline
                              liv-in-skyL Offline
                              liv-in-sky
                              wrote on last edited by
                              #98

                              @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

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

                              sigi234S 1 Reply Last reply
                              1
                              • liv-in-skyL liv-in-sky

                                @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

                                sigi234S Online
                                sigi234S Online
                                sigi234
                                Forum Testing Most Active
                                wrote on last edited by sigi234
                                #99

                                @liv-in-sky

                                Danke, ich teste es.

                                Funktioniert einwandfrei. Tolle Arbeit. :+1:

                                Screenshot (766)_LI.jpg

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

                                liv-in-skyL 1 Reply Last reply
                                0
                                • sigi234S sigi234

                                  @liv-in-sky

                                  Danke, ich teste es.

                                  Funktioniert einwandfrei. Tolle Arbeit. :+1:

                                  Screenshot (766)_LI.jpg

                                  liv-in-skyL Offline
                                  liv-in-skyL Offline
                                  liv-in-sky
                                  wrote on last edited by liv-in-sky
                                  #100

                                  @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

                                  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

                                  jackblacksonJ 1 Reply Last reply
                                  0
                                  • liv-in-skyL 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

                                    jackblacksonJ Offline
                                    jackblacksonJ Offline
                                    jackblackson
                                    wrote on last edited by
                                    #101

                                    @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-skyL sigi234S 2 Replies Last reply
                                    0
                                    • jackblacksonJ jackblackson

                                      @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-skyL Offline
                                      liv-in-skyL Offline
                                      liv-in-sky
                                      wrote on last edited by
                                      #102

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

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

                                      sigi234S 1 Reply Last reply
                                      0
                                      • jackblacksonJ jackblackson

                                        @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.

                                        sigi234S Online
                                        sigi234S Online
                                        sigi234
                                        Forum Testing Most Active
                                        wrote on last edited by
                                        #103

                                        @jackblackson

                                        Natürlich geht auch der Dank an dich.

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

                                        1 Reply Last reply
                                        1
                                        • liv-in-skyL liv-in-sky

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

                                          sigi234S Online
                                          sigi234S Online
                                          sigi234
                                          Forum Testing Most Active
                                          wrote on last edited by sigi234
                                          #104

                                          @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?

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

                                          liv-in-skyL G 3 Replies Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

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

                                          423

                                          Online

                                          32.7k

                                          Users

                                          82.5k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe