Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. jarvis v3.0.0 - just another remarkable vis

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    jarvis v3.0.0 - just another remarkable vis

    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      MCU @vlink last edited by

      @vlink Und genau das kann man über die Breakpoints einstellen.

      1 Reply Last reply Reply Quote 0
      • S
        SlipKoRn_DH88 last edited by

        Hallo zusammen,

        ich habe mittlerweile mehrere Schaltbare Geräte (Steckdosen, Nuki...), welche mit 0 und 1schalten, aber nicht mit false und true. Hat Jarvis eine Möglichkeit die Werte 0, 1 zu schalten? Ich habe in der Doku und im Forum bisher nichts finden können. Möglicherweise waren meine Suchwörter auch nicht die korrekten.

        Besten Dank

        M 1 Reply Last reply Reply Quote 0
        • M
          MCU @SlipKoRn_DH88 last edited by

          @slipkorn_dh88 Steht in der Doku. Schau mal unter Datenpunkt-Eigenschaften On und off Attribute.

          1 Reply Last reply Reply Quote 1
          • S
            SlipKoRn_DH88 last edited by

            @mcu Perfekt, danke dir! So funktioniert es.

            H 1 Reply Last reply Reply Quote 0
            • H
              hotspot_2 @SlipKoRn_DH88 last edited by

              Hallo zusammen,

              ich würde gerne in Jarvis eine Tabelle einbinden. Angezeigt werden sollen Beschriftungen und Werte aus den Objekten. Konkret geht es darum darzustellen wie oft der Ölbrenner die letzen drei Tage gelaufen ist, wie lange er an war und wie hoch der Ölverbrauch war. Ich habe diese Werte alle in den Objekten stehen.

              HTMLTable habe ich probiert, das war aber bisher nicht so erfolgreich.

              Danke schon mal für etwas Hilfestellung.

              1 Reply Last reply Reply Quote 0
              • M
                MCU last edited by MCU

                @hotspot_2
                Wo sind die Daten? Zeig mal bitte die Objekte.
                Woher kommen die drei Tage? history, influxdb?

                H 1 Reply Last reply Reply Quote 0
                • H
                  hotspot_2 @MCU last edited by

                  @mcu Sind 9 ganz normale Objekte in userdata, die ich angelegt habe und dementsprechenden mit Blockly Skripten beschreibe. Es sind Boolean und Number Objekte.

                  M 1 Reply Last reply Reply Quote 0
                  • M
                    MCU @hotspot_2 last edited by

                    @hotspot_2 Die drei Tage haben also für jeden Tag und DP einen eigenen DP?

                    H 1 Reply Last reply Reply Quote 0
                    • H
                      hotspot_2 @MCU last edited by

                      @mcu So ist es.

                      M 1 Reply Last reply Reply Quote 0
                      • M
                        MCU @hotspot_2 last edited by MCU

                        @hotspot_2 Und dann gibt es noch je einen extra-DP für die Zeit, wie lange der Ölbrenner an war, auch für 3 Tage?

                        Vielleicht findest du da was?
                        https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/module/jsontable/jsontable-erstellen

                        H 2 Replies Last reply Reply Quote 0
                        • H
                          hotspot_2 @MCU last edited by

                          @mcu

                          Mal anders:
                          dcafd01f-3a87-4792-8c26-35d5d88d1e72-image.png

                          Möchte damit einfach in Jarvis einen kurzen Überblick über die letzten drei Tage geben. Das war die Intension. Alles andere erfolgt über influx / Grafana.

                          1 Reply Last reply Reply Quote 0
                          • H
                            hotspot_2 @MCU last edited by

                            @mcu Habe mir mal das Javascript angepasst. Könnte passen ;-).

                            Wo muss ich das jetzt einfügen? Im Widget JSONTable?

                            M 1 Reply Last reply Reply Quote 0
                            • M
                              MCU @hotspot_2 last edited by MCU

                              @hotspot_2 Ja. Also vorher Geräte-DP anlegen.

                              H 1 Reply Last reply Reply Quote 0
                              • H
                                hotspot_2 @MCU last edited by

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

                                M 1 Reply Last reply Reply Quote 0
                                • M
                                  MCU @hotspot_2 last edited by 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.

                                  H 1 Reply Last reply Reply Quote 0
                                  • H
                                    hotspot_2 @MCU last edited by

                                    @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 Reply Last reply Reply Quote 0
                                    • M
                                      MCU @hotspot_2 last edited by

                                      @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);
                                      }
                                      
                                      H U 2 Replies Last reply Reply Quote 0
                                      • H
                                        hotspot_2 @MCU last edited by

                                        @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 Reply Last reply Reply Quote 0
                                        • M
                                          MCU @hotspot_2 last edited by 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.

                                          H 1 Reply Last reply Reply Quote 0
                                          • H
                                            hotspot_2 @MCU last edited by

                                            @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 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            808
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            jarvis material material ui materialdesign vis visualisierung visualization
                                            252
                                            4481
                                            1955198
                                            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