Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. VIS-Tabelle für WLAN Wetterstation

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    VIS-Tabelle für WLAN Wetterstation

    This topic has been deleted. Only users with topic management privileges can see it.
    • SBorg
      SBorg Forum Testing Most Active @Nashra last edited by

      @nashra sagte in VIS-Tabelle für WLAN Wetterstation:

      Kein Fehler mehr, aber ist das ok mit der Ausgabe

      Sieht gut aus. Wenn auch deine Tabelle in der VIS funktioniert warten wir mal bis zum nächsten Monatswechsel 🙂
      Die "console.log..." kannst du nun alle entfernen oder per "//" auskommentieren, sonst wird dein Log über kurz oder lang recht voll 😉

      Nashra 2 Replies Last reply Reply Quote 1
      • Nashra
        Nashra Most Active Forum Testing @SBorg last edited by

        @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

        @nashra sagte in VIS-Tabelle für WLAN Wetterstation:

        Kein Fehler mehr, aber ist das ok mit der Ausgabe

        Sieht gut aus. Wenn auch deine Tabelle in der VIS funktioniert warten wir mal bis zum nächsten Monatswechsel 🙂
        Die "console.log..." kannst du nun alle entfernen oder per "//" auskommentieren, sonst wird dein Log über kurz oder lang recht voll 😉

        Ja, hatte ich schon gemacht mit //
        Ok, dann warten wir mal bis Ende des Monats was dann passiert.
        Vielen Dank erstmal 👍

        1 Reply Last reply Reply Quote 0
        • SBorg
          SBorg Forum Testing Most Active last edited by

          Noch eine kleine Änderung wer denn möchte. Wenn man es jetzt in der VIS öffnet, springt er ja automatisch zum Januar 2023. Die Daten gibt es aber erst am 01. Februar. Wäre doch schön wenn er immer einen Monat weniger als den aktuellen springen würde (und für den Januar zzgl. noch -1 Jahr 🙂 ).

          Einfach den kpl. Scheduler im Skript ersetzen:

          schedule('*/30 * * * *', function() { 
            //Patch -1 Monat bzw. Jahr, damit immer etwas angezeigt wird (aktuelle Monatsdaten gibt es ja hier noch keine)
              let MonatTmp = parseInt(formatDate(getDateObject((new Date().getTime())), "MM"));
              let JahrTmp = 0;
              if (MonatTmp>1) { MonatTmp--; } else { MonatTmp = 12; JahrTmp = -1; }  
            setState("javascript." + instance + ".Wetterstation.MonatAuswahl", MonatTmp) ;
            setStateDelayed("javascript." + instance + ".Wetterstation.AuswahlJahr", parseInt(formatDate(getDateObject((new Date().getTime())), "JJJJ"))+JahrTmp ,10000);
          });
          
          1 Reply Last reply Reply Quote 1
          • Nashra
            Nashra Most Active Forum Testing @SBorg last edited by

            @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

            @nashra sagte in VIS-Tabelle für WLAN Wetterstation:

            Kein Fehler mehr, aber ist das ok mit der Ausgabe

            Sieht gut aus. Wenn auch deine Tabelle in der VIS funktioniert warten wir mal bis zum nächsten Monatswechsel 🙂
            Die "console.log..." kannst du nun alle entfernen oder per "//" auskommentieren, sonst wird dein Log über kurz oder lang recht voll 😉

            Hallo @SBorg
            es hat funktioniert, Tabelle zeigt Werte richtig an 👍 👍 👍

            SBorg 1 Reply Last reply Reply Quote 0
            • SBorg
              SBorg Forum Testing Most Active @Nashra last edited by

              @nashra 😀 😎 👍 Trotzdem merkwürdig das ist...

              Nashra 1 Reply Last reply Reply Quote 0
              • Nashra
                Nashra Most Active Forum Testing @SBorg last edited by

                @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                @nashra 😀 😎 👍 Trotzdem merkwürdig das ist...

                jep, da hast du Recht aber ganz ehrlich, ist mir egal, hauptsache läuft jetzt 😁

                1 Reply Last reply Reply Quote 0
                • Negalein
                  Negalein Global Moderator @SBorg last edited by Negalein

                  @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                  Das Design wird dir bekannt vorkommen, "deine" Version des Skriptes bei mir:

                  Hallo

                  Hast du eine aktuelle View davon?

                  Bei mir kommt in der View undefinied.

                  30f02c6c-ea06-46d5-abfd-3bc25d91525e-image.png

                  SBorg 1 Reply Last reply Reply Quote 0
                  • SBorg
                    SBorg Forum Testing Most Active @Negalein last edited by

                    @negalein
                    Ich glaube eher du hast da ein rudimentäres Problem (ich antworte gleich im WLAN-Skript Thread).
                    Da hat sich seit Uhrzeiten nichts dran geändert:
                    Bild 002.png

                    // @liv-in-sky 4.10.2021 11:45
                    //forum: https://forum.iobroker.net/topic/38286/vis-tabelle-f%C3%BCr-wlan-wetterstation
                    
                    const dataInputPath="0_userdata.0.Statistik.Wetter.Data";  //SEHR WICHTIG !!!!!!!!!
                    const inhaltFarbe="black";
                    const inhaltHintergrund="lightgray";
                    const monatFarbe="white";
                    const hintergrund="gray";
                    const htmlFarbTableBorderColor="black";
                    const abstandZelle=6;
                    const htmlRahmenLinien="all";
                    const htmlSchriftgroessehtmlSchriftart=""; //nicht verwendbar!
                    const htmlFarbFelderschrift="red";         //nicht verwendbar!
                    const htmlSchriftgroesse="13px";
                    const htmlSchriftart="Ubuntu-Light";       //"monospace" oder z.b. "Helvetica"
                    const weite="auto";                        //oder "500px"
                    
                    let myTable="table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"2px\" cellspacing=\""+abstandZelle+"\" cellpadding=\""+abstandZelle+"\" width=\""+weite+"\" rules=\""+htmlRahmenLinien+"\" style=\"color:"+htmlFarbFelderschrift+";  font-size:"+htmlSchriftgroesse+
                                        "; font-family:"+htmlSchriftart+";\"";
                    
                    const varData={ 
                                 Tiefstwert:       { einheit:"°C",   name:"Minimum Temperatur"},
                                 Hoechstwert:      { einheit:"°C",   name:"Maximum Temperatur"}, 
                                 Temp_Durchschnitt:{ einheit:"°C",   name:"Durchschnittstemperatur"},
                                 Max_Windboee:     { einheit:'km/h', name:"Max Windböe"},
                                 Max_Regenmenge:   { einheit:'l/m²', name:"Max. Regen/Tag"},
                                 Regenmenge_Monat: { einheit:'l/m²', name:"Regen"},
                                 Regentage:        { einheit:"",     name:"Regentage"},
                                 sehr_kalte_Tage:  { einheit:"",     name:"Sehr kalte Tage (Min. unter -10°C)"},
                                 Eistage:          { einheit:"",     name:"Eistage (Max. unter 0°C)"},
                                 Frost_Tage:       { einheit:"",     name:"Frosttage (Min. unter 0°C)"},
                                 kalte_Tage:       { einheit:"",     name:"Kalte Tage (Max. unter 10°C)"},
                                 warme_Tage:       { einheit:"",     name:"Warme Tage (über 20°C)"},
                                 Sommertage:       { einheit:"",     name:"Sommertage (über 25°C)"},
                                 Tropennaechte:    { einheit:"",     name:"Tropennächte (Min. über 20°C)"},
                                 heisse_Tage:      { einheit:"",     name:"Heiße Tage (über 30°C)"},
                                 Wuestentage:      { einheit:"",     name:"Wüstentage (über 35°C)"}
                    };  
                    const table_rowspan = Object.keys(varData).length + 1;
                    
                    const monate =["JANUAR","FEBRUAR","MÄRZ","APRIL","MAI","JUNI","JULI","AUGUST","SEPTEMBER","OKTOBER","NOVEMBER","DEZEMBER"];
                    
                    //--------------------------nix mehr ändern ab hier--------------------------------------
                    let myObj;
                    let myArrAll=[]
                    let myArrErstellt=[]
                    let tableContent;
                    let monWahlVIS;
                    let lastThree;
                    
                    //----------------------------------------------------------------------------------------
                    function dataStuff(){
                    let myArrAll=[]
                    let mySelector=dataInputPath+'.*.*'
                    $(mySelector).each(function(id) {
                    let ida=id.split("."); let lang=ida.length; let jahri=lang-2; let moni=lang-1;
                    let obj2 = { jahr: ida[jahri]};
                    let obj3 = { monat: ida[moni]};
                    let formathelp=getState(id).val;
                    let helper;
                    
                    if (typeof(formathelp)=="object") {helper=getState(id).val[0];} 
                     else if (typeof(formathelp)=="string") { helper=String(getState(id).val);
                                                              if (helper.indexOf("[")>=0) { helper=JSON.parse(helper.substring(1, helper.length-1)); }
                                                                else { helper=JSON.parse(helper); }  
                                                              }
                     else { helper=JSON.parse(getState(id).val); }
                    
                    helper={ ...helper, ...obj2, ...obj3}
                    myArrAll.push(JSON.stringify(helper))
                    });
                    
                    //log(myArrAll)
                    tableContent = ""  
                    myObj=JSON.parse("["+myArrAll.toString()+"]")
                    if (lastThree==0) {
                    
                    //KOPFZEILE
                    let choseMonth=monate[monWahlVIS-1]
                    let choseMonthArr=choseMonth.split('')
                    let test=""
                    for (let i=0;i<choseMonthArr.length;i++){
                    
                    // log(choseMonthArr[i])
                     test=test+choseMonthArr[i]+`
                     `    
                    }
                    
                    //log(test)
                    //tableContent+='<td  class=\"test-klein\"  rowspan=\"17\"\">'+choseMonth+'</td><td>Wetterwerte</td>'
                    tableContent+='<td class=\"myWetterStation\" width=\"25px\"  style=\"color:'+monatFarbe+';font-size:26px; background-color:'+hintergrund+' ; vertical-align:middle; text-align:center \"   rowspan='+table_rowspan+'\">'+test+'</td><td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\>Jahreswerte</td>'
                    
                    for (let i=0;i<myObj.length;i++) {
                     if(parseInt(myObj[i].monat)==monWahlVIS){
                    tableContent += '<td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\ align=center>'  + myObj[i].jahr+'</td>'}
                    }; tableContent="<tr style=\"font-weight\:bold\">"+tableContent+"</tr>"
                    
                    //RESTZEILEN
                    for(var index in varData){
                     tableContent+='<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\">'+varData[index].name+'</td>'
                     for (let i=0;i<myObj.length;i++) {
                        if(myObj[i].monat==monWahlVIS){
                          tableContent += '<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\" align=right>' + myObj[i][index] + ' '+ varData[index].einheit+'</td>'}
                                                      }; tableContent="<tr>"+tableContent+"</tr>"
                    }
                    } //lastThree
                    else {
                    //log(myObj[0].monat)
                      myObj.sort(function (alpha, beta) {
                               if (parseInt(alpha.monat) > parseInt(beta.monat))
                                   return 1;
                                if (parseInt(beta.monat) > parseInt(alpha.monat))
                                   return -1;
                                return 0;});
                            //    log(myObj[0].monat)
                    //KOPFZEILE LASTTHREE
                    let choseJahr=lastThree.toString()//formatDate(getDateObject((new Date().getTime())), "JJJJ")//monate[monWahlVIS-1]
                    let choseMonthArr=choseJahr.split('')
                    let test=""
                    for (let i=0;i<choseMonthArr.length;i++){
                    // log(choseMonthArr[i])
                     test=test+choseMonthArr[i]+`
                     `    
                    }
                    
                    //log(test)
                    //tableContent+='<td  class=\"test-klein\"  rowspan=\"17\"\">'+choseMonth+'</td><td>Wetterwerte</td>'
                    tableContent+='<td class=\"myWetterStation\" width=\"25px\"  style=\"color:'+monatFarbe+';font-size:26px; background-color:'+hintergrund+' ; vertical-align:middle; text-align:center \"   rowspan='+table_rowspan+'\">'+test+'</td><td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\>Wetterwerte</td>'
                    
                    for (let i=0;i<myObj.length;i++) {
                     if( parseInt(myObj[i].jahr)==parseInt(choseJahr) ){ //&& (parseInt(myObj[i].monat)==parseInt(monWahlVIS) || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-1 || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-2)){
                    tableContent += '<td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\ align=center>'  + monate[parseInt(myObj[i].monat)-1]+'</td>';}
                    }; tableContent="<tr style=\"font-weight\:bold\">"+tableContent+"</tr>"
                    
                    //RESTZEILEN
                    for(var index in varData){
                     tableContent+='<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\">'+varData[index].name+'</td>'
                     for (let i=0;i<myObj.length;i++) {
                      if( parseInt(myObj[i].jahr)==parseInt(choseJahr) ){ //&& (parseInt(myObj[i].monat)==parseInt(monWahlVIS) || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-1 || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-2)){
                          tableContent += '<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\" align=right>' + myObj[i][index] + ' '+ varData[index].einheit+'</td>'}
                                                      }; tableContent="<tr>"+tableContent+"</tr>"
                    }
                    }
                    tableContent = '<'+myTable+' ><tbody>'+tableContent+'</tbody></table >'
                    //log(tableContent)
                    setState("0_userdata." + instance + ".Wetterstation.MonthlyDaten",tableContent)
                    }
                    
                    //--------------------------------------------------------------------------------------------------
                    async function main() {
                     if (!(await existsStateAsync("0_userdata." + instance + ".Wetterstation.MonthlyDaten"))) {
                         await createStateAsync("0_userdata." + instance + ".Wetterstation.MonthlyDaten", "leer", {type: "string", name: "MonthlyDaten", role: "value", read: true, write: true, } ); }
                     if (!(await existsStateAsync("0_userdata." + instance + "..Wetterstation.MonatAuswahl"))) {
                         await createStateAsync("0_userdata." + instance + ".Wetterstation.MonatAuswahl", 10, {type: "number", name: "MonatAuswahl", role: "value", read: true, write: true, } ); } 
                     if (!(await existsStateAsync("0_userdata." + instance + ".Wetterstation.AuswahlJahr"))) {
                         await createStateAsync("0_userdata." + instance + ".Wetterstation.AuswahlJahr", 0, {type: "number", name: "AuswahlJahr", role: "value", read: true, write: true, } ); } 
                     lastThree = (await getStateAsync("0_userdata." + instance + ".Wetterstation.AuswahlJahr")).val //? lastThree=true : lastThree=false;  
                     monWahlVIS=((await getStateAsync("0_userdata." + instance + ".Wetterstation.MonatAuswahl")).val ) 
                     dataStuff(); 
                    }
                    
                    //-----------------------------------------------------------------------------------------------------
                    main()
                    
                    on({id: "0_userdata." + instance + ".Wetterstation.MonatAuswahl", change: "any"}, async function (obj) {
                     main()
                    });
                    
                    on({id: "0_userdata." + instance + ".Wetterstation.AuswahlJahr", change: "any"}, async function (obj) {
                     main()
                    });
                    
                    schedule('*/30 * * * *', function() { 
                     //Patch -1 Monat bzw. Jahr, damit immer etwas angezeigt wird (aktuelle Monatsdaten gibt es ja hier noch keine)
                       let MonatTmp = parseInt(formatDate(getDateObject((new Date().getTime())), "MM"));
                       let JahrTmp = 0;
                       if (MonatTmp>1) { MonatTmp--; } else { MonatTmp = 12; JahrTmp = -1; }  
                     setState("0_userdata." + instance + ".Wetterstation.MonatAuswahl", MonatTmp) ;
                     setStateDelayed("0_userdata." + instance + ".Wetterstation.AuswahlJahr", parseInt(formatDate(getDateObject((new Date().getTime())), "JJJJ"))+JahrTmp ,10000);
                    });
                    
                    


                    Springt immer zu aktuellem Monat minus 1 (also gerade heute dann automatisch auf Mai), im Januar dann auf Dezember und minus 1 Jahr.

                    Negalein 1 Reply Last reply Reply Quote 0
                    • Negalein
                      Negalein Global Moderator @SBorg last edited by Negalein

                      @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                      Da hat sich seit Uhrzeiten nichts dran geändert:

                      Hast du auch einen VIS-Export für mich?

                      SBorg 1 Reply Last reply Reply Quote 0
                      • SBorg
                        SBorg Forum Testing Most Active @Negalein last edited by

                        @negalein
                        Ist wahrscheinlich gleich mit deinem

                        [{"tpl":"tplJquiSelectList","data":{"oid":"0_userdata.0.Wetterstation.AuswahlJahr","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":true,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","values":"0;2020;2021;2022;2023;2024","texts":"All Years;2020;2021;2022;2023;2024","height":"100","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,"no_style":true},"style":{"left":"160px","top":"375px","box-shadow":"8px 8px 8px rgba(20, 20, 20, 50)"},"widgetSet":"jqui"},{"tpl":"tplHtml","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":true,"g_css_background":false,"g_css_shadow_padding":true,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","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,"html":"{0_userdata.0.Wetterstation.MonthlyDaten}"},"style":{"left":"160px","top":"405px","width":"auto","height":"auto","font-family":"","color":"#f7f51d","z-index":"1","box-shadow":"8px 8px 8px rgba(20, 20, 20, 50)"},"widgetSet":"basic"},{"tpl":"tplJquiSelectList","data":{"oid":"0_userdata.0.Wetterstation.MonatAuswahl","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":true,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","values":"1;2;3;4;5;6;7;8;9;10;11;12","texts":"JANUAR;FEBRUAR;MÄRZ;APRIL;MAI;JUNI;JULI;AUGUST;SEPTEMBER;OKTOBER;NOVEMBER;DEZEMBER","height":"100","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,"no_style":true},"style":{"left":"260px","top":"375px","width":"100px","height":"","box-shadow":"8px 8px 8px rgba(20, 20, 20, 50)","z-index":"1"},"widgetSet":"jqui"}]
                        
                        T 1 Reply Last reply Reply Quote 1
                        • T
                          tritor @SBorg last edited by

                          @sborg

                          habe heute mal die Vis aktiviert und muß sagen, bin begeistert.

                          1 Reply Last reply Reply Quote 0
                          • First post
                            Last post

                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          457
                          Online

                          31.9k
                          Users

                          80.1k
                          Topics

                          1.3m
                          Posts

                          vis
                          11
                          101
                          10251
                          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