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.
    • paul53
      paul53 @jackblackson last edited by

      @jackblackson
      Es genügt nicht, die Variable warnstufe nur bei Scriptstart mit dem Wert 0 zu initialisieren. Das muss auch innerhalb von schedule() erfolgen (z.B. in Zeile 41).

      jackblackson 1 Reply Last reply Reply Quote 0
      • jackblackson
        jackblackson @paul53 last edited by jackblackson

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

        @jackblackson
        Es genügt nicht, die Variable warnstufe nur bei Scriptstart mit dem Wert 0 zu initialisieren. Das muss auch innerhalb von schedule() erfolgen (z.B. in Zeile 41).

        Da hast du natürlich recht, hab es im Code aktualisiert, und den schedule auch noch auf stündlich geändert.

        jackblackson paul53 2 Replies Last reply Reply Quote 0
        • jackblackson
          jackblackson @jackblackson last edited by

          Mit dem SVG Widget funktioniert es übrigens, wenn man einen schönen Ampel-Kreis bekommen möchte:

          [{"tpl":"tplShapes","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","svgType":"circle","strokeColor":"{javascript.0.Coronaampel.warnfarbe}","fill":"{javascript.0.Coronaampel.warnfarbe}","strokeWidth":"1","scaleWidth":"1","scaleHeight":"1","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0},"style":{"left":"325px","top":"280px","width":"41px","height":"41px"},"widgetSet":"basic"}]
          
          1 Reply Last reply Reply Quote 0
          • paul53
            paul53 @jackblackson last edited by

            @jackblackson sagte:

            den schedule auch noch auf stündlich geändert.

            So wie oben wird immer noch jede Minute getriggert.

            jackblackson 1 Reply Last reply Reply Quote 0
            • jackblackson
              jackblackson @paul53 last edited by

              @paul53 Jetzt aber - es startet immer eine Minute nach der vollen Stunde.

              Hier noch ein Screenshot meiner Umsetzung:
              fc4374d6-7add-4bc0-a539-d32c8b8d0ac0-grafik.png
              Die Farbe, die aktiv ist, wird immer etwas größer sein, damit klar ist was "leuchtet".

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

                @jackblackson
                Cool wäre es wenn man nach mehreren Orten suchen könnte und auch eine Table DP hätte.
                Oder muss man fur jeden Ort ein Skrip anlegen?

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

                  @sigi234 Ich hab dir mal die Tabellenerstellung noch eingebaut:

                  const url = 'https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_aktuell.json';
                  
                  var warnstufe=0;
                  var htmlwidget ='';
                  var suchwertBezirk = 'Bregenz'
                  var suchwertBundesland = 'Vorarlberg'
                  var farbwertLevel1 = '#04B404'
                  var farbwertLevel2 = '#FFFF00'
                  var farbwertLevel3 = '#FF8000'
                  var farbwertLevel4 = '#DF0101'
                  var warngebiet = ''
                  var directory = 'Coronaampel' //javascript.0.xxx
                  var tableContent = ''
                  
                  createState(directory  + '.warnstufe', {
                      name: 'Corona Warnstufe',
                      read: true, 
                      write: false, 
                      type: "number", 
                      def: 0
                  });
                  
                  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  + '.warntabelle', {
                      name: 'Corona Tabelle',
                      read: true, 
                      write: false, 
                      type: "string", 
                      def: ""
                  });
                  
                  schedule('1 * * * *', function() {
                      warnstufe = 0;
                      tableContent = ''
                      request(url, function(err, response, json) {
                  
                          let arr = JSON.parse(json).warnstufen;
                          //Loop und suche nach Bezirk
                          for(let i = 0; i < arr.length; i++) { 
                             if(arr[i].name == suchwertBezirk){
                               //log(' Warnstufe für ' + suchwertBezirk + ': ' + arr[i].warnstufe)
                               warnstufe = Number(arr[i].warnstufe)}
                               warngebiet = suchwertBezirk
                          }
                          if (warnstufe == 0){
                              //Loop und suche nach Bundesland
                              for(let i = 0; i < arr.length; i++) { 
                                  if(arr[i].name == suchwertBundesland){
                                      //log(' Warnstufe für ' + suchwertBundesland + ': ' + arr[i].warnstufe)
                                      warnstufe = Number(arr[i].warnstufe)
                                      warngebiet = suchwertBundesland
                                 }
                  
                              }
                          }
                          if (warnstufe == 0){
                              log('Keine Warnung für ' + suchwertBezirk + ' und ' + suchwertBundesland + ' gefunden.')
                          }
                          for(let i = 0; i < arr.length; i++) { 
                              fillTable(arr[i].region,arr[i].name,arr[i].warnstufe)
                          }
                          finishTable()
                  
                      saveData()
                  
                      });
                  
                  });
                  
                  function fillTable(gebiet,name,warnstufe){
                      if (tableContent == ''){
                        tableContent = '<table ><tbody>'  
                      }
                      tableContent += '<tr><td>' + gebiet + '</td>'
                      tableContent += '<td>' + name + '</td>'
                      tableContent += '<td>' + warnstufe + '</td>'
                      tableContent += '</tr>';
                  }
                  
                  function finishTable(){
                  
                      tableContent += '</tbody></table>'
                      setState(directory+'.warntabelle',tableContent)
                  }
                  
                  function saveData(){
                      setState(directory+'.warnstufe',warnstufe)
                      setState(directory+'.warngebiet',warngebiet)
                      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',"");
                                  ;
                              }
                  }
                  
                  

                  Wegen mehreren Orten...vielleicht ists am einfachsten, wenn du das Skript mehrfach anlegst, und einfach verschiedene Ordner ganz oben definierst?

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

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

                    Ich hab dir mal die Tabellenerstellung noch eingebaut:

                    DP wird nicht befüllt.

                    Edit: jetzt schon.

                    1 Reply Last reply Reply Quote 1
                    • jackblackson
                      jackblackson last edited by

                      Ich hab mir grad heute das aktualisierte File angesehen, und so wie es aussieht ist dort nicht immer nur der aktuelle Stand eingetragen sondern auch die Historie...somit wird es mit dem einfachen Durchloopen nicht funktionieren..

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

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

                        Ich hab mir grad heute das aktualisierte File angesehen, und so wie es aussieht ist dort nicht immer nur der aktuelle Stand eingetragen sondern auch die Historie...somit wird es mit dem einfachen Durchloopen nicht funktionieren..

                        ja leider, Hast du eine Lösung?

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

                          @jackblackson

                          du kannst ja den stand abfragen und dann das neuste raussuchen und dann die schleife dadurch laufen klassen

                          bzw. es wird wahrscheinlich immer der erste punkt sein, den du brauchst - neuste datum steht unter 0:

                          Image 1.png

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

                            @jackblackson

                            geht es damit ?

                             
                            schedule(' 1 * * * *', function() {
                                warnstufe = 0;
                                tableContent = ''
                                request(url, function(err, response, json) {
                              
                                    let arr = JSON.parse(json)[0].Warnstufen;
                                    log(JSON.stringify(arr))
                                    //Loop und suche nach Bezirk
                                    for(let i = 0; i < arr.length; i++) { 
                                       if(arr[i].name == suchwertBezirk){
                                         //log(' Warnstufe für ' + suchwertBezirk + ': ' + arr[i].warnstufe)
                                         warnstufe = Number(arr[i].warnstufe)}
                                         warngebiet = suchwertBezirk
                            

                            nur zeile 7 geändert
                            und in zeile 8 ein log

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

                              @jackblackson

                              oh mann - die haben auch die namen geändert - die werden groß geschrieben

                              daher bitte testen - ganzes script

                              
                              const url = 'https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_aktuell.json';
                              
                              var warnstufe=0;
                              var htmlwidget ='';
                              var suchwertBezirk = 'Bregenz'
                              var suchwertBundesland = 'Vorarlberg'
                              var farbwertLevel1 = '#04B404'
                              var farbwertLevel2 = '#FFFF00'
                              var farbwertLevel3 = '#FF8000'
                              var farbwertLevel4 = '#DF0101'
                              var warngebiet = ''
                              var directory = 'Coronaampel' //javascript.0.xxx
                              var tableContent = ''
                              
                              createState(directory  + '.warnstufe', {
                                 name: 'Corona Warnstufe',
                                 read: true, 
                                 write: false, 
                                 type: "number", 
                                 def: 0
                              });
                              
                              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  + '.warntabelle', {
                                 name: 'Corona Tabelle',
                                 read: true, 
                                 write: false, 
                                 type: "string", 
                                 def: ""
                              });
                              
                              schedule('  * * * * *', function() {
                                 warnstufe = 0;
                                 tableContent = ''
                                 request(url, function(err, response, json) {
                               
                                     let arr = (JSON.parse(json)[0]).Warnstufen;
                                     log(JSON.stringify(arr))
                                     //Loop und suche nach Bezirk
                                     for(let i = 0; i < arr.length; i++) { 
                                        if(arr[i].Name == suchwertBezirk){
                                          //log(' Warnstufe für ' + suchwertBezirk + ': ' + arr[i].Warnstufe)
                                          warnstufe = Number(arr[i].Warnstufe)}
                                          warngebiet = suchwertBezirk
                                     }
                                     if (warnstufe == 0){
                                         //Loop und suche nach Bundesland
                                         for(let i = 0; i < arr.length; i++) { 
                                             if(arr[i].Name == suchwertBundesland){
                                                 //log(' Warnstufe für ' + suchwertBundesland + ': ' + arr[i].Warnstufe)
                                                 warnstufe = Number(arr[i].Warnstufe)
                                                 warngebiet = suchwertBundesland
                                            }
                              
                                         }
                                     }
                                     if (warnstufe == 0){
                                         log('Keine Warnung für ' + suchwertBezirk + ' und ' + suchwertBundesland + ' gefunden.')
                                     }
                                     for(let i = 0; i < arr.length; i++) { 
                                         fillTable(arr[i].Region,arr[i].Name,arr[i].Warnstufe)
                                     }
                                     finishTable()
                              
                                 saveData()
                              
                                 });
                              
                              });
                              
                              function fillTable(gebiet,name,warnstufe){
                                 if (tableContent == ''){
                                   tableContent = '<table ><tbody>'  
                                 }
                                 tableContent += '<tr><td>' + gebiet + '</td>'
                                 tableContent += '<td>' + name + '</td>'
                                 tableContent += '<td>' + warnstufe + '</td>'
                                 tableContent += '</tr>';
                              }
                              
                              function finishTable(){
                              
                                 tableContent += '</tbody></table>'
                                 setState(directory+'.warntabelle',tableContent)
                              }
                              
                              function saveData(){
                                 setState(directory+'.warnstufe',warnstufe)
                                 setState(directory+'.warngebiet',warngebiet)
                                 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',"");
                                             ;
                                         }
                              }
                              
                              
                              

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

                                @liv-in-sky Funktioniert gut bei mir - danke schon mal! Ich werde nur mein Gelb anpassen müssen, das ist etwas zu grell. Dann hoffen wir das zumindest die technische Umsetzung nun funktioniert, wenn das ganze Konzept sonst schon etwas Anlaufschwierigkeiten hat.

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

                                  @jackblackson

                                  da hatten wir schon viel schlimmere anfangssituationen - mal sehen, was beim nächsten update bei denen wieder geändert wird 😞

                                  bergjet 1 Reply Last reply Reply Quote 0
                                  • jackblackson
                                    jackblackson last edited by jackblackson

                                    Und wieder ist alles Neu..aber immerhin inzwischen mit Changelog:
                                    b1011378-20af-4de6-9d25-3a57c7f6ac75-grafik.png
                                    https://corona-ampel.gv.at/datendownload/

                                    Edit: Bei mir hat es gereicht, auf den neuen Filenamen zu wechseln: https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_aktuell_1.json

                                    1 Reply Last reply Reply Quote 0
                                    • jackblackson
                                      jackblackson last edited by

                                      37d119ee-3ad5-4103-860e-41bf759bd8aa-grafik.png
                                      Datainame ist wieder wie vorher 🤦‍♂️

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

                                        @jackblackson

                                        naja - scheint ein sehr "spontaner" haufen zu sein. aber immer noch besser eine ampel zu haben als keine - sowie bei uns hier

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

                                          @liv-in-sky Uff, bist du so nett und erklärst das einem Laien, wie man das zum laufen bringt?
                                          Ich möchte die https://corona-ampel.gv.at/sites/corona-ampel.gv.at/files/assets/Warnstufen_Corona_Ampel_Gemeinden_aktuell.json Gemeinden anzeigen.
                                          Also meinen Gemeindenamen und die Warnstufe und von welchem Datum der Wert stammt. Das sollte je in einen Datenpunkt.
                                          Den Datenpunkt kann man ja danach in Vis auswerten.
                                          Vielleicht ist dir eine plausible nachvollziehbare Erklärung möglich.
                                          Danke schon mal.

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

                                            @bergjet

                                            ich hoffe es meldet sich jmd anders - ich habe das script garnicht am laufen, weil die "deutschländer" es nicht auf die reihe bekommen - immerhin wird schon mal darüber geredet - ich hatte nur beigetragen beim holen der daten - was ihr damit macht, habe ich garnicht richtig angeschaut

                                            @jackblackson kannst du da bitte mit einspringen ?

                                            bergjet 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

                                            703
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            corona vis
                                            10
                                            217
                                            18921
                                            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