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

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

Community Forum

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

NEWS

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

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

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

Corona-Ampel Österreich in VIS anzeigen

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
coronavis
217 Beiträge 10 Kommentatoren 28.6k Aufrufe 9 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • 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
    schrieb am zuletzt editiert von
    #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 Antwort Letzte Antwort
    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
      schrieb am zuletzt editiert von
      #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 Antwort Letzte Antwort
      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
        schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
        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
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          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
            schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
                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
                  schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                  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
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    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
                      schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                      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
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        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
                          schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                          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
                            schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von
                              #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 Antworten Letzte Antwort
                              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
                                schrieb am zuletzt editiert von
                                #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 Antwort Letzte Antwort
                                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
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  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
                                    schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
                                    0
                                    • sigi234S sigi234

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

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

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

                                      @sigi234

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

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

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

                                      1 Antwort Letzte Antwort
                                      0
                                      • sigi234S sigi234

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

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

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

                                        @sigi234

                                        refresh und sortierung

                                        anim-gif6.gif

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

                                        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 Antwort Letzte Antwort
                                        1
                                        • liv-in-skyL liv-in-sky

                                          @sigi234 @bergjet

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

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

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

                                          bergjetB Offline
                                          bergjetB Offline
                                          bergjet
                                          schrieb am zuletzt editiert von
                                          #107

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

                                          homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                          liv-in-skyL 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

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

                                          317

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe