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. Tester
  4. jarvis v3.0.0 - just another remarkable vis

NEWS

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

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

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

jarvis v3.0.0 - just another remarkable vis

Geplant Angeheftet Gesperrt Verschoben Tester
jarvismaterialmaterial uimaterialdesignvisvisualisierungvisualization
4.5k Beiträge 254 Kommentatoren 2.7m Aufrufe 209 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.
  • hotspot_2H hotspot_2

    @mcu Für was Geräte-DP anlegen? Im JSON Editor kann ich es nicht reinkopieren ;-)

    M Online
    M Online
    MCU
    schrieb am zuletzt editiert von MCU
    #3134

    @hotspot_2 Es wird ja im Script ein JSON-DP angelegt. Dieser muss als Geräte-DP in jarvis zugeordnet werden. Dann kann man den wiederum in der jsonTable zuordnen.
    Zeig mal bitte Dein Script.

    NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
    Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

    hotspot_2H 1 Antwort Letzte Antwort
    0
    • M MCU

      @hotspot_2 Es wird ja im Script ein JSON-DP angelegt. Dieser muss als Geräte-DP in jarvis zugeordnet werden. Dann kann man den wiederum in der jsonTable zuordnen.
      Zeig mal bitte Dein Script.

      hotspot_2H Online
      hotspot_2H Online
      hotspot_2
      schrieb am zuletzt editiert von
      #3135

      @mcu

      Dann vermute ich mal habe ich zu wild editiert nach deinem letzten Tipp

      Aber gerne, hier mal das Skript:

      let heizungDP = '[{"Heizung"}:{"Heute"}:{"Gestern"}:{"Vorgestern"]]';
      let aktDP = true;
      let schedDP = 5;
      
      let arrDP =''; // ArrayDP für PV
      let schedulePattern = '*/1 * * * *'; // alle x Minuten aktualisieren
       
       
      var schedule1;
      if (getState(schedDP).val){
         // Direkt neue Pattern wirken lassen, aber nur wenn aktiviert
         (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
         schedule1 = schedule(schedulePattern, async function () {
             tableJSONSet();
         });
      }
       
      on({id: schedDP, change: "any"}, function (obj) {
         let value = obj.state.val;
         if (value){
             (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
             schedule1 = schedule(schedulePattern, async function () {
                 tableJSONSet();
             });
             
         }else{
             (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
         }
      });
       
      on({id: aktDP, change: "any"}, function (obj) {
         let value = obj.state.val;
         if (value){
             tableJSONSet();
             setTimeout(function(){
                 setStateDelayed(aktDP,false,3000,false);
             },2000);
             
         }
      });
       
      function tableJSONSet(){
         let jsonArr=[];
         // 1.Reihe
         let json1= {};
         json1.Title ="Brenner gelaufen";
         json1.Aktuell = getState('0_userdata.0.heizung.brenner_gelaufen_heute').val;
         json1.Tag = getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val;
         json1.Woche = getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val;
         jsonArr.push(json1);
         
         let json2 = {};
         json2.Title ="Wie oft?";
         json2.Aktuell = getState('0_userdata.0.testwert').val;
         json2.Tag = "";
         json2.Woche = "";
         jsonArr.push(json2);
         
         let json3 = {};
         json3.Title ="Laden";
         json3.Aktuell = getState('0_userdata.0.testwert').val;
         json3.Tag = "";
         json3.Woche = "";
         jsonArr.push(json3);
            
         log(JSON.stringify(jsonArr));
         
         setState(heizungDP,JSON.stringify(jsonArr),false);
      }
      
      M 1 Antwort Letzte Antwort
      0
      • hotspot_2H hotspot_2

        @mcu

        Dann vermute ich mal habe ich zu wild editiert nach deinem letzten Tipp

        Aber gerne, hier mal das Skript:

        let heizungDP = '[{"Heizung"}:{"Heute"}:{"Gestern"}:{"Vorgestern"]]';
        let aktDP = true;
        let schedDP = 5;
        
        let arrDP =''; // ArrayDP für PV
        let schedulePattern = '*/1 * * * *'; // alle x Minuten aktualisieren
         
         
        var schedule1;
        if (getState(schedDP).val){
           // Direkt neue Pattern wirken lassen, aber nur wenn aktiviert
           (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
           schedule1 = schedule(schedulePattern, async function () {
               tableJSONSet();
           });
        }
         
        on({id: schedDP, change: "any"}, function (obj) {
           let value = obj.state.val;
           if (value){
               (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
               schedule1 = schedule(schedulePattern, async function () {
                   tableJSONSet();
               });
               
           }else{
               (function () {if (schedule1) {clearSchedule(schedule1); schedule1 = null;}})();
           }
        });
         
        on({id: aktDP, change: "any"}, function (obj) {
           let value = obj.state.val;
           if (value){
               tableJSONSet();
               setTimeout(function(){
                   setStateDelayed(aktDP,false,3000,false);
               },2000);
               
           }
        });
         
        function tableJSONSet(){
           let jsonArr=[];
           // 1.Reihe
           let json1= {};
           json1.Title ="Brenner gelaufen";
           json1.Aktuell = getState('0_userdata.0.heizung.brenner_gelaufen_heute').val;
           json1.Tag = getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val;
           json1.Woche = getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val;
           jsonArr.push(json1);
           
           let json2 = {};
           json2.Title ="Wie oft?";
           json2.Aktuell = getState('0_userdata.0.testwert').val;
           json2.Tag = "";
           json2.Woche = "";
           jsonArr.push(json2);
           
           let json3 = {};
           json3.Title ="Laden";
           json3.Aktuell = getState('0_userdata.0.testwert').val;
           json3.Tag = "";
           json3.Woche = "";
           jsonArr.push(json3);
              
           log(JSON.stringify(jsonArr));
           
           setState(heizungDP,JSON.stringify(jsonArr),false);
        }
        
        M Online
        M Online
        MCU
        schrieb am zuletzt editiert von
        #3136

        @hotspot_2 Es muss ein ioBroker-DP angelegt werden. Warum hast du die createState rausgenommen?
        Der heizungDP muss ein ioBroker-DP sein -> '0_userdata.0.jarvis.heizungDP';
        Und den dann auch anlegen:

        Lass das mal laufen. Ergebnis einmal reinstellen. Also Inhalt vom DP heizungsDP

        let heizungDP =  '0_userdata.0.jarvis.heizungDP';
        createState(heizungDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
        
        let arrDP =''; 
        setTimeout(function(){
           tableJSONSet();
        },3000);
        
        /* In der Funktion kann man die Objekt-Key-Werte auch ändern */
        function tableJSONSet(){
           let jsonArr=[];
           // 1.Reihe
           let json1= {};
           json1.Title ="Brenner gelaufen";
           json1.Heute= getState('0_userdata.0.heizung.brenner_gelaufen_heute').val;
           json1.Gestern = getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val;
           json1.Vorgestern = getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val;
           jsonArr.push(json1);
           let json2 = {};
           json2.Title ="Wie oft?";
           json2.Heute= getState('0_userdata.0.heizung.brenner_einschaltungen_heute').val;
           json2.Gestern = getState('0_userdata.0.heizung.brenner_einschaltungen_gestern').val;
           json2.Vorgestern = getState('0_userdata.0.heizung.brenner_einschaltungen_vorgestern').val;
           jsonArr.push(json2);
           
           let json3 = {};
           json3.Title ="Laden";
           json3.Heute = getState('0_userdata.0.heizung.brenner_laufzeit_heute').val;
           json3.Gestern = getState('0_userdata.0.heizung.brenner_laufzeit_gestern').val;
           json3.Vorgestern = getState('0_userdata.0.heizung.brenner_laufzeit_vorgestern').val;
           jsonArr.push(json3);
              
           //log(JSON.stringify(jsonArr));
           
           setState(heizungDP,JSON.stringify(jsonArr),false);
        }
        

        NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
        Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

        hotspot_2H U 2 Antworten Letzte Antwort
        0
        • M MCU

          @hotspot_2 Es muss ein ioBroker-DP angelegt werden. Warum hast du die createState rausgenommen?
          Der heizungDP muss ein ioBroker-DP sein -> '0_userdata.0.jarvis.heizungDP';
          Und den dann auch anlegen:

          Lass das mal laufen. Ergebnis einmal reinstellen. Also Inhalt vom DP heizungsDP

          let heizungDP =  '0_userdata.0.jarvis.heizungDP';
          createState(heizungDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
          
          let arrDP =''; 
          setTimeout(function(){
             tableJSONSet();
          },3000);
          
          /* In der Funktion kann man die Objekt-Key-Werte auch ändern */
          function tableJSONSet(){
             let jsonArr=[];
             // 1.Reihe
             let json1= {};
             json1.Title ="Brenner gelaufen";
             json1.Heute= getState('0_userdata.0.heizung.brenner_gelaufen_heute').val;
             json1.Gestern = getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val;
             json1.Vorgestern = getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val;
             jsonArr.push(json1);
             let json2 = {};
             json2.Title ="Wie oft?";
             json2.Heute= getState('0_userdata.0.heizung.brenner_einschaltungen_heute').val;
             json2.Gestern = getState('0_userdata.0.heizung.brenner_einschaltungen_gestern').val;
             json2.Vorgestern = getState('0_userdata.0.heizung.brenner_einschaltungen_vorgestern').val;
             jsonArr.push(json2);
             
             let json3 = {};
             json3.Title ="Laden";
             json3.Heute = getState('0_userdata.0.heizung.brenner_laufzeit_heute').val;
             json3.Gestern = getState('0_userdata.0.heizung.brenner_laufzeit_gestern').val;
             json3.Vorgestern = getState('0_userdata.0.heizung.brenner_laufzeit_vorgestern').val;
             jsonArr.push(json3);
                
             //log(JSON.stringify(jsonArr));
             
             setState(heizungDP,JSON.stringify(jsonArr),false);
          }
          
          hotspot_2H Online
          hotspot_2H Online
          hotspot_2
          schrieb am zuletzt editiert von
          #3137

          @mcu Alles klar. Passt. Jetzt habe ich glaub das Prinzip auch verstanden. Das laufende Javascript schreibt im JSON-Format in den DP in ioBroker-DP und der wird dann vom JSON-Widget angezeigt.

          [{"Title":"Brenner gelaufen","Heute":true,"Gestern":true,"Vorgestern":false},{"Title":"Wie oft?","Heute":6,"Gestern":2,"Vorgestern":0},{"Title":"Laden","Heute":0,"Gestern":0,"Vorgestern":0}]
          
          M 1 Antwort Letzte Antwort
          0
          • hotspot_2H hotspot_2

            @mcu Alles klar. Passt. Jetzt habe ich glaub das Prinzip auch verstanden. Das laufende Javascript schreibt im JSON-Format in den DP in ioBroker-DP und der wird dann vom JSON-Widget angezeigt.

            [{"Title":"Brenner gelaufen","Heute":true,"Gestern":true,"Vorgestern":false},{"Title":"Wie oft?","Heute":6,"Gestern":2,"Vorgestern":0},{"Title":"Laden","Heute":0,"Gestern":0,"Vorgestern":0}]
            
            M Online
            M Online
            MCU
            schrieb am zuletzt editiert von MCU
            #3138

            @hotspot_2 Sieht gut aus.
            Jetzt in jarvis ganz normal ein Gerät anlegen mit dem GeräteDP -> heizungDP und dann ein Widget JSONTable anlegen.

            Wie oft soll das aktualisiert werden? Im SCript ergänzen.

            /*
            unter setTimeout
            },3000);
            */
            schedule('*/30 * * * *', () => { // wird alle 30 Minuten aktualisiert
                tableJSONSet();
            });
            

            Zeig auch bitte das ergebnis als JSONTable, damit andere es sehen können. Danke.

            NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
            Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

            hotspot_2H 1 Antwort Letzte Antwort
            0
            • M MCU

              @hotspot_2 Sieht gut aus.
              Jetzt in jarvis ganz normal ein Gerät anlegen mit dem GeräteDP -> heizungDP und dann ein Widget JSONTable anlegen.

              Wie oft soll das aktualisiert werden? Im SCript ergänzen.

              /*
              unter setTimeout
              },3000);
              */
              schedule('*/30 * * * *', () => { // wird alle 30 Minuten aktualisiert
                  tableJSONSet();
              });
              

              Zeig auch bitte das ergebnis als JSONTable, damit andere es sehen können. Danke.

              hotspot_2H Online
              hotspot_2H Online
              hotspot_2
              schrieb am zuletzt editiert von
              #3139

              @mcu So, passt. Gerne hier für Alle das Ergebnis:

              1f29752f-99a0-416b-af95-926d1aeda63f-image.png

              Kleine Frage dazu noch: Kann ich das unten "Zeilen pro Seite..." usw. auch noch verstecken?

              Anbei nochmal das Skript:

              let heizungDP =  '0_userdata.0.jarvis.heizungdp';
              createState(heizungDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
               
              let arrDP =''; 
              
              setTimeout(function(){
                 tableJSONSet();
              },3000);
              
              schedule('*/10 * * * *', () => { // wird alle 10 Minuten aktualisiert
                  tableJSONSet();
              });
              
              function tableJSONSet(){
              
                 let jsonArr=[];
                 // 1.Reihe
                 let json1= {};
                 json1.Title ="Brenner gelaufen";
                 if (getState('0_userdata.0.heizung.brenner_gelaufen_heute').val == true) {
                     json1.Heute = "Ja";
                 } else {
                     json1.Heute = "Nein";
                 };
                 if (getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val == true) {
                     json1.Gestern = "Ja";
                 } else {
                     json1.Gestern = "Nein";
                 };
                 if (getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val == true) {
                     json1.Vorgestern = "Ja";
                 } else {
                     json1.Vorgestern = "Nein";
                 };
                 jsonArr.push(json1);
                 
                 //2. Reihe
                 let json2 = {};
                 json2.Title ="Wie oft?";
                 json2.Heute= getState('0_userdata.0.heizung.brenner_einschaltungen_heute').val;
                 json2.Gestern = getState('0_userdata.0.heizung.brenner_einschaltungen_gestern').val;
                 json2.Vorgestern = getState('0_userdata.0.heizung.brenner_einschaltungen_vorgestern').val;
                 jsonArr.push(json2);
                 
                 // 3. Reihe
                 let json3 = {};
                 json3.Title ="Laufzeit";
                 json3.Heute = getState('0_userdata.0.heizung.brenner_laufzeit_heute').val;
                 json3.Gestern = getState('0_userdata.0.heizung.brenner_laufzeit_gestern').val;
                 json3.Vorgestern = getState('0_userdata.0.heizung.brenner_laufzeit_vorgestern').val;
                 jsonArr.push(json3);
                       
                 setState(heizungDP,JSON.stringify(jsonArr),false);
              }
              
              
              M 1 Antwort Letzte Antwort
              0
              • hotspot_2H hotspot_2

                @mcu So, passt. Gerne hier für Alle das Ergebnis:

                1f29752f-99a0-416b-af95-926d1aeda63f-image.png

                Kleine Frage dazu noch: Kann ich das unten "Zeilen pro Seite..." usw. auch noch verstecken?

                Anbei nochmal das Skript:

                let heizungDP =  '0_userdata.0.jarvis.heizungdp';
                createState(heizungDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
                 
                let arrDP =''; 
                
                setTimeout(function(){
                   tableJSONSet();
                },3000);
                
                schedule('*/10 * * * *', () => { // wird alle 10 Minuten aktualisiert
                    tableJSONSet();
                });
                
                function tableJSONSet(){
                
                   let jsonArr=[];
                   // 1.Reihe
                   let json1= {};
                   json1.Title ="Brenner gelaufen";
                   if (getState('0_userdata.0.heizung.brenner_gelaufen_heute').val == true) {
                       json1.Heute = "Ja";
                   } else {
                       json1.Heute = "Nein";
                   };
                   if (getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val == true) {
                       json1.Gestern = "Ja";
                   } else {
                       json1.Gestern = "Nein";
                   };
                   if (getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val == true) {
                       json1.Vorgestern = "Ja";
                   } else {
                       json1.Vorgestern = "Nein";
                   };
                   jsonArr.push(json1);
                   
                   //2. Reihe
                   let json2 = {};
                   json2.Title ="Wie oft?";
                   json2.Heute= getState('0_userdata.0.heizung.brenner_einschaltungen_heute').val;
                   json2.Gestern = getState('0_userdata.0.heizung.brenner_einschaltungen_gestern').val;
                   json2.Vorgestern = getState('0_userdata.0.heizung.brenner_einschaltungen_vorgestern').val;
                   jsonArr.push(json2);
                   
                   // 3. Reihe
                   let json3 = {};
                   json3.Title ="Laufzeit";
                   json3.Heute = getState('0_userdata.0.heizung.brenner_laufzeit_heute').val;
                   json3.Gestern = getState('0_userdata.0.heizung.brenner_laufzeit_gestern').val;
                   json3.Vorgestern = getState('0_userdata.0.heizung.brenner_laufzeit_vorgestern').val;
                   jsonArr.push(json3);
                         
                   setState(heizungDP,JSON.stringify(jsonArr),false);
                }
                
                
                M Online
                M Online
                MCU
                schrieb am zuletzt editiert von
                #3140

                @hotspot_2
                https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/styles/.jarvis-module-jsontable#zeilen-pro-seite-info-ausblenden

                NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
                Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

                hotspot_2H 1 Antwort Letzte Antwort
                0
                • M MCU

                  @hotspot_2
                  https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/styles/.jarvis-module-jsontable#zeilen-pro-seite-info-ausblenden

                  hotspot_2H Online
                  hotspot_2H Online
                  hotspot_2
                  schrieb am zuletzt editiert von
                  #3141

                  @mcu Ich hätte noch eine Frage: Wie kann ich den in der Titelzeile oben eine Bezeichnung mit Leerzeichnen eingeben? Also anstatt Gestern z.B. "4 Tage"?

                  M 1 Antwort Letzte Antwort
                  0
                  • hotspot_2H hotspot_2

                    @mcu Ich hätte noch eine Frage: Wie kann ich den in der Titelzeile oben eine Bezeichnung mit Leerzeichnen eingeben? Also anstatt Gestern z.B. "4 Tage"?

                    M Online
                    M Online
                    MCU
                    schrieb am zuletzt editiert von MCU
                    #3142

                    @hotspot_2

                    /* statt .Titel */
                    json1["4 Tage"] = ....
                    

                    NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
                    Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

                    1 Antwort Letzte Antwort
                    0
                    • U Offline
                      U Offline
                      UncleB
                      schrieb am zuletzt editiert von
                      #3143

                      Gibts eigentlich ne Anleitung wie man eCharts einbindet mit dem HistoryGraph?
                      Weiß nicht wie ich vorgehen muss, und die Suche ist bei dieser Forensoftware eine Katastrophe finde ich..

                      M 1 Antwort Letzte Antwort
                      0
                      • U UncleB

                        Gibts eigentlich ne Anleitung wie man eCharts einbindet mit dem HistoryGraph?
                        Weiß nicht wie ich vorgehen muss, und die Suche ist bei dieser Forensoftware eine Katastrophe finde ich..

                        M Online
                        M Online
                        MCU
                        schrieb am zuletzt editiert von MCU
                        #3144

                        @uncleb
                        https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/module/iframe-v3/echart-einbinden

                        https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/module/historygraph

                        NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
                        Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

                        1 Antwort Letzte Antwort
                        0
                        • K Offline
                          K Offline
                          Kev 0
                          schrieb am zuletzt editiert von
                          #3145

                          Könnt ihr mich beim Formatieren von Werten via Formeln unterstützen. Im Endeffekt muss ich eigentlich nur einen Wert (Zahl) die im Datenpunkt (Anzeige) reinkommt mit einer festen Zahl vergleichen und dementsprechend true/false ausgeben.
                          Ich habe das Beispiel "value": "val => Math.round(parseInt(val)/3600)" gefunden aber verstehe es leider nicht. Ich denke hier wird dem value (verarbeiteter Wert) ein neuer Wert zugewiesen aber was macht z.B. val => und wieso ist der hintere Term in Anführungszeichen? Ich hätte etwas erwartet wie "value": Math.round(parseInt(val)/3600).
                          Bzw. in meinem Fall "value": val = 5

                          M 1 Antwort Letzte Antwort
                          0
                          • K Kev 0

                            Könnt ihr mich beim Formatieren von Werten via Formeln unterstützen. Im Endeffekt muss ich eigentlich nur einen Wert (Zahl) die im Datenpunkt (Anzeige) reinkommt mit einer festen Zahl vergleichen und dementsprechend true/false ausgeben.
                            Ich habe das Beispiel "value": "val => Math.round(parseInt(val)/3600)" gefunden aber verstehe es leider nicht. Ich denke hier wird dem value (verarbeiteter Wert) ein neuer Wert zugewiesen aber was macht z.B. val => und wieso ist der hintere Term in Anführungszeichen? Ich hätte etwas erwartet wie "value": Math.round(parseInt(val)/3600).
                            Bzw. in meinem Fall "value": val = 5

                            M Online
                            M Online
                            MCU
                            schrieb am zuletzt editiert von MCU
                            #3146

                            @kev-0
                            Hier ist es beschrieben:
                            https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/module/jsontable/v3.x.x/parameter-format#beispiel-wert-in-spalte-ersetzen

                            wieso ist der hintere Term in Anführungszeichen

                            Der ganze Ausdruck ist ein JSON-Format: normalerweise sieht es so aus {"key":"value"}

                            Für Deine Anforderung:
                            https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/geraet/datenpunkt-eigenschaft/wert-pruefen

                            NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
                            Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

                            K 1 Antwort Letzte Antwort
                            1
                            • M MCU

                              @kev-0
                              Hier ist es beschrieben:
                              https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/module/jsontable/v3.x.x/parameter-format#beispiel-wert-in-spalte-ersetzen

                              wieso ist der hintere Term in Anführungszeichen

                              Der ganze Ausdruck ist ein JSON-Format: normalerweise sieht es so aus {"key":"value"}

                              Für Deine Anforderung:
                              https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/geraet/datenpunkt-eigenschaft/wert-pruefen

                              K Offline
                              K Offline
                              Kev 0
                              schrieb am zuletzt editiert von
                              #3147

                              @mcu
                              Danke hat funktioniert.
                              Für meine Anforderungen lässt es sich aber noch ein wenig abkürzen da val == 1000 ein boolscher Ausdruck ist
                              {
                              "value": "val => val == 1000"
                              }

                              1 Antwort Letzte Antwort
                              0
                              • M MCU

                                @hotspot_2 Es muss ein ioBroker-DP angelegt werden. Warum hast du die createState rausgenommen?
                                Der heizungDP muss ein ioBroker-DP sein -> '0_userdata.0.jarvis.heizungDP';
                                Und den dann auch anlegen:

                                Lass das mal laufen. Ergebnis einmal reinstellen. Also Inhalt vom DP heizungsDP

                                let heizungDP =  '0_userdata.0.jarvis.heizungDP';
                                createState(heizungDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
                                
                                let arrDP =''; 
                                setTimeout(function(){
                                   tableJSONSet();
                                },3000);
                                
                                /* In der Funktion kann man die Objekt-Key-Werte auch ändern */
                                function tableJSONSet(){
                                   let jsonArr=[];
                                   // 1.Reihe
                                   let json1= {};
                                   json1.Title ="Brenner gelaufen";
                                   json1.Heute= getState('0_userdata.0.heizung.brenner_gelaufen_heute').val;
                                   json1.Gestern = getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val;
                                   json1.Vorgestern = getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val;
                                   jsonArr.push(json1);
                                   let json2 = {};
                                   json2.Title ="Wie oft?";
                                   json2.Heute= getState('0_userdata.0.heizung.brenner_einschaltungen_heute').val;
                                   json2.Gestern = getState('0_userdata.0.heizung.brenner_einschaltungen_gestern').val;
                                   json2.Vorgestern = getState('0_userdata.0.heizung.brenner_einschaltungen_vorgestern').val;
                                   jsonArr.push(json2);
                                   
                                   let json3 = {};
                                   json3.Title ="Laden";
                                   json3.Heute = getState('0_userdata.0.heizung.brenner_laufzeit_heute').val;
                                   json3.Gestern = getState('0_userdata.0.heizung.brenner_laufzeit_gestern').val;
                                   json3.Vorgestern = getState('0_userdata.0.heizung.brenner_laufzeit_vorgestern').val;
                                   jsonArr.push(json3);
                                      
                                   //log(JSON.stringify(jsonArr));
                                   
                                   setState(heizungDP,JSON.stringify(jsonArr),false);
                                }
                                
                                U Offline
                                U Offline
                                UncleB
                                schrieb am zuletzt editiert von
                                #3148

                                @mcu said in jarvis v3.0.0 - just another remarkable vis:

                                @hotspot_2 Es muss ein ioBroker-DP angelegt werden. Warum hast du die createState rausgenommen?
                                Der heizungDP muss ein ioBroker-DP sein -> '0_userdata.0.jarvis.heizungDP';
                                Und den dann auch anlegen:

                                Lass das mal laufen. Ergebnis einmal reinstellen. Also Inhalt vom DP heizungsDP

                                let heizungDP =  '0_userdata.0.jarvis.heizungDP';
                                createState(heizungDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
                                
                                let arrDP =''; 
                                setTimeout(function(){
                                   tableJSONSet();
                                },3000);
                                
                                /* In der Funktion kann man die Objekt-Key-Werte auch ändern */
                                function tableJSONSet(){
                                   let jsonArr=[];
                                   // 1.Reihe
                                   let json1= {};
                                   json1.Title ="Brenner gelaufen";
                                   json1.Heute= getState('0_userdata.0.heizung.brenner_gelaufen_heute').val;
                                   json1.Gestern = getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val;
                                   json1.Vorgestern = getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val;
                                   jsonArr.push(json1);
                                   let json2 = {};
                                   json2.Title ="Wie oft?";
                                   json2.Heute= getState('0_userdata.0.heizung.brenner_einschaltungen_heute').val;
                                   json2.Gestern = getState('0_userdata.0.heizung.brenner_einschaltungen_gestern').val;
                                   json2.Vorgestern = getState('0_userdata.0.heizung.brenner_einschaltungen_vorgestern').val;
                                   jsonArr.push(json2);
                                   
                                   let json3 = {};
                                   json3.Title ="Laden";
                                   json3.Heute = getState('0_userdata.0.heizung.brenner_laufzeit_heute').val;
                                   json3.Gestern = getState('0_userdata.0.heizung.brenner_laufzeit_gestern').val;
                                   json3.Vorgestern = getState('0_userdata.0.heizung.brenner_laufzeit_vorgestern').val;
                                   jsonArr.push(json3);
                                      
                                   //log(JSON.stringify(jsonArr));
                                   
                                   setState(heizungDP,JSON.stringify(jsonArr),false);
                                }
                                

                                @MCU
                                Ich hab gerade ähnliches vor, unter meinen verbrauch Chart will ich ne Tabelle mit den aktuellen verbrauch und den Stromkosten ausgeben,
                                Ich hab mir einfach mal dieses Script gschnappt und auf meine Bedürfnisse angepasst, wie die Darstellung aussieht ist erstmal egal..
                                Aber versteh ich das richtig, ich muss manuell einen DP anlegen in meinem Beispiel: 0_userdata.0.jarvis.verbrauchDP
                                Dann nur das Script ausführen und State wird ja dann gleich in der 2ten Zeile gesetzt?..
                                Ich bekomm allerdings immer den Fehler:

                                11:11:53.420	error	javascript.0 (460) script.js.common.Jarvis.Stromverbrauch-Darstellung: ReferenceError: verbrauchDP is not defined
                                11:11:53.420	error	javascript.0 (460) at script.js.common.Jarvis.Stromverbrauch-Darstellung:2:13
                                11:11:53.421	error	javascript.0 (460) at script.js.common.Jarvis.Stromverbrauch-Darstellung:32:3
                                

                                Mein Script sieht so aus:

                                let heizungDP =  '0_userdata.0.jarvis.verbrauchDP';
                                createState(verbrauchDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
                                 
                                let arrDP =''; 
                                setTimeout(function(){
                                   tableJSONSet();
                                },3000);
                                 
                                /* In der Funktion kann man die Objekt-Key-Werte auch ändern */
                                function tableJSONSet(){
                                   let jsonArr=[];
                                   // 1.Reihe
                                   let json1= {};
                                   json1.Title ="Verbrauch";
                                   json1.Heute= getState('sonoff.0.stecker_3ddruck.ENERGY_Today').val;
                                   json1.Gestern = getState('sonoff.0.stecker_3ddruck.ENERGY_Yesterday').val;
                                   json1.Gesamt = getState('sonoff.0.stecker_3ddruck.ENERGY_Total').val;
                                   jsonArr.push(json1);
                                   let json2 = {};
                                   json2.Title ="Kosten";
                                   json2.Heute= getState('sourceanalytix.0.sonoff__0__stecker_3ddruck__ENERGY_Total.currentYear.costs.01_currentDay').val;
                                   json2.Gesamt = getState('sourceanalytix.0.sonoff__0__stecker_3ddruck__ENERGY_Total.currentYear.costs.05_currentYear').val;
                                   jsonArr.push(json2);
                                   
                                   
                                   //log(JSON.stringify(jsonArr));
                                   
                                   setState(verbrauchDP,JSON.stringify(jsonArr),false);
                                }
                                
                                
                                
                                M 1 Antwort Letzte Antwort
                                0
                                • U UncleB

                                  @mcu said in jarvis v3.0.0 - just another remarkable vis:

                                  @hotspot_2 Es muss ein ioBroker-DP angelegt werden. Warum hast du die createState rausgenommen?
                                  Der heizungDP muss ein ioBroker-DP sein -> '0_userdata.0.jarvis.heizungDP';
                                  Und den dann auch anlegen:

                                  Lass das mal laufen. Ergebnis einmal reinstellen. Also Inhalt vom DP heizungsDP

                                  let heizungDP =  '0_userdata.0.jarvis.heizungDP';
                                  createState(heizungDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
                                  
                                  let arrDP =''; 
                                  setTimeout(function(){
                                     tableJSONSet();
                                  },3000);
                                  
                                  /* In der Funktion kann man die Objekt-Key-Werte auch ändern */
                                  function tableJSONSet(){
                                     let jsonArr=[];
                                     // 1.Reihe
                                     let json1= {};
                                     json1.Title ="Brenner gelaufen";
                                     json1.Heute= getState('0_userdata.0.heizung.brenner_gelaufen_heute').val;
                                     json1.Gestern = getState('0_userdata.0.heizung.brenner_gelaufen_gestern').val;
                                     json1.Vorgestern = getState('0_userdata.0.heizung.brenner_gelaufen_vorgestern').val;
                                     jsonArr.push(json1);
                                     let json2 = {};
                                     json2.Title ="Wie oft?";
                                     json2.Heute= getState('0_userdata.0.heizung.brenner_einschaltungen_heute').val;
                                     json2.Gestern = getState('0_userdata.0.heizung.brenner_einschaltungen_gestern').val;
                                     json2.Vorgestern = getState('0_userdata.0.heizung.brenner_einschaltungen_vorgestern').val;
                                     jsonArr.push(json2);
                                     
                                     let json3 = {};
                                     json3.Title ="Laden";
                                     json3.Heute = getState('0_userdata.0.heizung.brenner_laufzeit_heute').val;
                                     json3.Gestern = getState('0_userdata.0.heizung.brenner_laufzeit_gestern').val;
                                     json3.Vorgestern = getState('0_userdata.0.heizung.brenner_laufzeit_vorgestern').val;
                                     jsonArr.push(json3);
                                        
                                     //log(JSON.stringify(jsonArr));
                                     
                                     setState(heizungDP,JSON.stringify(jsonArr),false);
                                  }
                                  

                                  @MCU
                                  Ich hab gerade ähnliches vor, unter meinen verbrauch Chart will ich ne Tabelle mit den aktuellen verbrauch und den Stromkosten ausgeben,
                                  Ich hab mir einfach mal dieses Script gschnappt und auf meine Bedürfnisse angepasst, wie die Darstellung aussieht ist erstmal egal..
                                  Aber versteh ich das richtig, ich muss manuell einen DP anlegen in meinem Beispiel: 0_userdata.0.jarvis.verbrauchDP
                                  Dann nur das Script ausführen und State wird ja dann gleich in der 2ten Zeile gesetzt?..
                                  Ich bekomm allerdings immer den Fehler:

                                  11:11:53.420	error	javascript.0 (460) script.js.common.Jarvis.Stromverbrauch-Darstellung: ReferenceError: verbrauchDP is not defined
                                  11:11:53.420	error	javascript.0 (460) at script.js.common.Jarvis.Stromverbrauch-Darstellung:2:13
                                  11:11:53.421	error	javascript.0 (460) at script.js.common.Jarvis.Stromverbrauch-Darstellung:32:3
                                  

                                  Mein Script sieht so aus:

                                  let heizungDP =  '0_userdata.0.jarvis.verbrauchDP';
                                  createState(verbrauchDP, {read: true, write: true, name: "Heizung Daten", type: "string", role: "text", def: "" });
                                   
                                  let arrDP =''; 
                                  setTimeout(function(){
                                     tableJSONSet();
                                  },3000);
                                   
                                  /* In der Funktion kann man die Objekt-Key-Werte auch ändern */
                                  function tableJSONSet(){
                                     let jsonArr=[];
                                     // 1.Reihe
                                     let json1= {};
                                     json1.Title ="Verbrauch";
                                     json1.Heute= getState('sonoff.0.stecker_3ddruck.ENERGY_Today').val;
                                     json1.Gestern = getState('sonoff.0.stecker_3ddruck.ENERGY_Yesterday').val;
                                     json1.Gesamt = getState('sonoff.0.stecker_3ddruck.ENERGY_Total').val;
                                     jsonArr.push(json1);
                                     let json2 = {};
                                     json2.Title ="Kosten";
                                     json2.Heute= getState('sourceanalytix.0.sonoff__0__stecker_3ddruck__ENERGY_Total.currentYear.costs.01_currentDay').val;
                                     json2.Gesamt = getState('sourceanalytix.0.sonoff__0__stecker_3ddruck__ENERGY_Total.currentYear.costs.05_currentYear').val;
                                     jsonArr.push(json2);
                                     
                                     
                                     //log(JSON.stringify(jsonArr));
                                     
                                     setState(verbrauchDP,JSON.stringify(jsonArr),false);
                                  }
                                  
                                  
                                  
                                  M Online
                                  M Online
                                  MCU
                                  schrieb am zuletzt editiert von
                                  #3149

                                  @uncleb Du musst dann auch den Verbrauch DP benennen.
                                  Du hast noch let heizungDP.

                                  NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
                                  Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

                                  U 1 Antwort Letzte Antwort
                                  0
                                  • M MCU

                                    @uncleb Du musst dann auch den Verbrauch DP benennen.
                                    Du hast noch let heizungDP.

                                    U Offline
                                    U Offline
                                    UncleB
                                    schrieb am zuletzt editiert von UncleB
                                    #3150

                                    @mcu said in jarvis v3.0.0 - just another remarkable vis:

                                    @uncleb Du musst dann auch den Verbrauch DP benennen.
                                    Du hast noch let heizungDP.

                                    Oh man.. Haha der Geburtstag gestern dauerte zu lange haha.. Sorry

                                    Edit:
                                    Kann ich auch noch die Einheiten hinter den Wert schreiben also "€" bzw "kWh"
                                    Die Zeilen pro Seite bräuchte ich auch nicht, lassen sich aber wohl nicht ausblenden?

                                    M 1 Antwort Letzte Antwort
                                    0
                                    • U UncleB

                                      @mcu said in jarvis v3.0.0 - just another remarkable vis:

                                      @uncleb Du musst dann auch den Verbrauch DP benennen.
                                      Du hast noch let heizungDP.

                                      Oh man.. Haha der Geburtstag gestern dauerte zu lange haha.. Sorry

                                      Edit:
                                      Kann ich auch noch die Einheiten hinter den Wert schreiben also "€" bzw "kWh"
                                      Die Zeilen pro Seite bräuchte ich auch nicht, lassen sich aber wohl nicht ausblenden?

                                      M Online
                                      M Online
                                      MCU
                                      schrieb am zuletzt editiert von MCU
                                      #3151

                                      @uncleb
                                      Entweder direkt dahinter schreiben:

                                      json1.Gesamt = getState('sonoff.0.stecker_3ddruck.ENERGY_Total').val+' KWh';
                                      

                                      oder aus dem DP selbst holen, je nachdem, ob vorhanden?

                                      json1.Gesamt = getState('sonoff.0.stecker_3ddruck.ENERGY_Total').val+' ' +getObject('sonoff.0.stecker_3ddruck.ENERGY_Total').common.unit;
                                      

                                      Zeilen pro Seite ausblenden:
                                      https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/styles/.jarvis-module-jsontable#zeilen-pro-seite-info-ausblenden

                                      NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
                                      Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

                                      1 Antwort Letzte Antwort
                                      0
                                      • K Offline
                                        K Offline
                                        Kev 0
                                        schrieb am zuletzt editiert von
                                        #3152

                                        Besteht die Möglichkeit die Schriftgröße in den Popups so anzupassen, das es keinen Scrollbalken gibt? Ich habe aktuell 9 Werte in der Jalousie und beim Tablet im Querformat leider einen Scrollbalken.

                                        M 1 Antwort Letzte Antwort
                                        0
                                        • K Kev 0

                                          Besteht die Möglichkeit die Schriftgröße in den Popups so anzupassen, das es keinen Scrollbalken gibt? Ich habe aktuell 9 Werte in der Jalousie und beim Tablet im Querformat leider einen Scrollbalken.

                                          M Online
                                          M Online
                                          MCU
                                          schrieb am zuletzt editiert von
                                          #3153

                                          @kev-0
                                          Schriftgröße:
                                          https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/styles/popup#popup-schriftgroesse-label-aendern

                                          Vermute aber du möchtest es komprimierter darstellen:
                                          https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/styles/popup#popup-komprimierter

                                          NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
                                          Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

                                          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

                                          817

                                          Online

                                          32.4k

                                          Benutzer

                                          81.6k

                                          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