Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Tester
  4. jarvis v3.2.x - just another remarkable vis

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.6k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    996

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.3k

jarvis v3.2.x - just another remarkable vis

Scheduled Pinned Locked Moved Tester
947 Posts 46 Posters 271.0k Views 44 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • D Offline
    D Offline
    der-eine
    wrote on last edited by der-eine
    #722

    @MCU ich habe ein Skript, dass mit einen jsonTable zusammenstellt und ich würde gerne die Hintergrund Farbe von Fenster und Tür ändern anhand des Wertes. (rot grün)
    Ich probier schon eine längere Zeit mit Deiner Anleitung rum aber bekomme es nicht hin. Wie sollte ich rangehen? Das Style Attribute gleich im Skript einbauen (wie?) oder im Gerät bei Jarvis?

    Bildschirmfoto 2025-02-10 um 00.54.26.png

    M 1 Reply Last reply
    0
    • D der-eine

      @MCU ich habe ein Skript, dass mit einen jsonTable zusammenstellt und ich würde gerne die Hintergrund Farbe von Fenster und Tür ändern anhand des Wertes. (rot grün)
      Ich probier schon eine längere Zeit mit Deiner Anleitung rum aber bekomme es nicht hin. Wie sollte ich rangehen? Das Style Attribute gleich im Skript einbauen (wie?) oder im Gerät bei Jarvis?

      Bildschirmfoto 2025-02-10 um 00.54.26.png

      M Online
      M Online
      MCU
      wrote on last edited by MCU
      #723

      @der-eine Stell mal das Script rein.
      Diese
      2d41a4be-4808-4e13-a938-e6b9a605ac3f-image.png

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

      D 1 Reply Last reply
      0
      • M MCU

        @der-eine Stell mal das Script rein.
        Diese
        2d41a4be-4808-4e13-a938-e6b9a605ac3f-image.png

        D Offline
        D Offline
        der-eine
        wrote on last edited by
        #724

        @mcu

        const LOGGING_ENABLED = false;
        
        const rooms = [
            {
                name: "Wohnzimmer",
                sollDP: "heatingcontrol.0.Rooms.Wohnzimmer.CurrentTimePeriodTemperature",
                statusDP: "heatingcontrol.0.Rooms.Wohnzimmer.State",
                istDP: "alias.0.Aqara.EG.Wohnzimmer.Temperature",
                ventilDP: "shelly.0.SHTRV-01#60A423D91058#1.tmp.valvePosition",
                fensterDPs: ["zigbee.0.00158d000aca7c1a.opened"],
                tuerDPs: ["zigbee.0.00158d000aca7c3a.opened"]
            }
        ];
        
        async function updateTable() {
            try {
                const table = await Promise.all(rooms.map(async (room) => {
                    const [soll, ist, ventil, status, ...fensterTueren] = await Promise.all([
                        getStateAsync(room.sollDP),
                        getStateAsync(room.istDP),
                        getStateAsync(room.ventilDP),
                        getStateAsync(room.statusDP),
                        ...room.fensterDPs.map(dp => getStateAsync(dp)),
                        ...room.tuerDPs.map(dp => getStateAsync(dp))
                    ]);
        
                    const fensterStatus = {
                        "Fenster 1": room.fensterDPs.length > 0 ? (fensterTueren[0]?.val ? "Offen" : "Geschlossen") : "-",
                        "Fenster 2": room.fensterDPs.length > 1 ? (fensterTueren[1]?.val ? "Offen" : "Geschlossen") : "-"
                    };
        
                    const tuerStatus = room.tuerDPs.length ? { "Tür": fensterTueren[room.fensterDPs.length]?.val ? "Offen" : "Geschlossen" } : { "Tür": "-" };
        
                    return {
                        Raum: room.name,
                        Soll: `${soll?.val ?? "N/A"} °C`,
                        Ist: `${ist?.val ?? "N/A"} °C`,
                        Ventil: `${ventil?.val ?? "N/A"} %`,
                        Status: status?.val ?? "N/A",
                        ...fensterStatus,
                        ...tuerStatus
                    };
                }));
        
                if (LOGGING_ENABLED) console.log(JSON.stringify(table, null, 2));
        
                setState("0_userdata.0.Variablen.Jarvis.Heizung.testTable", JSON.stringify(table), true);
            } catch (error) {
                console.error("Fehler beim Abrufen der Daten:", error);
            }
        }
        
        schedule("* * * * * *", updateTable);
        updateTable();
        
        
        M 1 Reply Last reply
        0
        • D der-eine

          @mcu

          const LOGGING_ENABLED = false;
          
          const rooms = [
              {
                  name: "Wohnzimmer",
                  sollDP: "heatingcontrol.0.Rooms.Wohnzimmer.CurrentTimePeriodTemperature",
                  statusDP: "heatingcontrol.0.Rooms.Wohnzimmer.State",
                  istDP: "alias.0.Aqara.EG.Wohnzimmer.Temperature",
                  ventilDP: "shelly.0.SHTRV-01#60A423D91058#1.tmp.valvePosition",
                  fensterDPs: ["zigbee.0.00158d000aca7c1a.opened"],
                  tuerDPs: ["zigbee.0.00158d000aca7c3a.opened"]
              }
          ];
          
          async function updateTable() {
              try {
                  const table = await Promise.all(rooms.map(async (room) => {
                      const [soll, ist, ventil, status, ...fensterTueren] = await Promise.all([
                          getStateAsync(room.sollDP),
                          getStateAsync(room.istDP),
                          getStateAsync(room.ventilDP),
                          getStateAsync(room.statusDP),
                          ...room.fensterDPs.map(dp => getStateAsync(dp)),
                          ...room.tuerDPs.map(dp => getStateAsync(dp))
                      ]);
          
                      const fensterStatus = {
                          "Fenster 1": room.fensterDPs.length > 0 ? (fensterTueren[0]?.val ? "Offen" : "Geschlossen") : "-",
                          "Fenster 2": room.fensterDPs.length > 1 ? (fensterTueren[1]?.val ? "Offen" : "Geschlossen") : "-"
                      };
          
                      const tuerStatus = room.tuerDPs.length ? { "Tür": fensterTueren[room.fensterDPs.length]?.val ? "Offen" : "Geschlossen" } : { "Tür": "-" };
          
                      return {
                          Raum: room.name,
                          Soll: `${soll?.val ?? "N/A"} °C`,
                          Ist: `${ist?.val ?? "N/A"} °C`,
                          Ventil: `${ventil?.val ?? "N/A"} %`,
                          Status: status?.val ?? "N/A",
                          ...fensterStatus,
                          ...tuerStatus
                      };
                  }));
          
                  if (LOGGING_ENABLED) console.log(JSON.stringify(table, null, 2));
          
                  setState("0_userdata.0.Variablen.Jarvis.Heizung.testTable", JSON.stringify(table), true);
              } catch (error) {
                  console.error("Fehler beim Abrufen der Daten:", error);
              }
          }
          
          schedule("* * * * * *", updateTable);
          updateTable();
          
          
          M Online
          M Online
          MCU
          wrote on last edited by
          #725

          @der-eine Du meinst die Überschriften?

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

          D 1 Reply Last reply
          0
          • M MCU

            @der-eine Du meinst die Überschriften?

            D Offline
            D Offline
            der-eine
            wrote on last edited by der-eine
            #726

            @mcu nein, offen geschlossen bei den Values

            So wie hier in der Anleitung:

            Bildschirmfoto 2025-02-10 um 00.56.49.png

            M 1 Reply Last reply
            0
            • D der-eine

              @mcu nein, offen geschlossen bei den Values

              So wie hier in der Anleitung:

              Bildschirmfoto 2025-02-10 um 00.56.49.png

              M Online
              M Online
              MCU
              wrote on last edited by MCU
              #727

              @der-eine

              const fensterStatus = {
                              "Fenster 1": room.fensterDPs.length > 0 ? (fensterTueren[0]?.val ? "<div style=\"color:red;\">Offen</div>" : "<div style=\"color:green;\">Geschlossen</div>") : "-",
                              "Fenster 2": room.fensterDPs.length > 1 ? (fensterTueren[1]?.val ? "<div style=\"color:red;\">Offen</div>" : "<div style=\"color:green;\">Geschlossen</div>") : "-"
                          };
              

              wenn der Hintergrund geändert werden soll dann background-color nutzen

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

              D 1 Reply Last reply
              1
              • M MCU

                @der-eine

                const fensterStatus = {
                                "Fenster 1": room.fensterDPs.length > 0 ? (fensterTueren[0]?.val ? "<div style=\"color:red;\">Offen</div>" : "<div style=\"color:green;\">Geschlossen</div>") : "-",
                                "Fenster 2": room.fensterDPs.length > 1 ? (fensterTueren[1]?.val ? "<div style=\"color:red;\">Offen</div>" : "<div style=\"color:green;\">Geschlossen</div>") : "-"
                            };
                

                wenn der Hintergrund geändert werden soll dann background-color nutzen

                D Offline
                D Offline
                der-eine
                wrote on last edited by
                #728

                @mcu top funktioniert. Danke. :+1:

                M 1 Reply Last reply
                0
                • D der-eine

                  @mcu top funktioniert. Danke. :+1:

                  M Online
                  M Online
                  MCU
                  wrote on last edited by
                  #729

                  @der-eine Wenn du das mit styles innerhalb der jsonTable machen wolltest

                  "style": "(rowindex, row, props) => (row.Tür == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                  

                  MIt Fenster 1 und Fenster 2 würde es nicht gehen da dort ein Leerzeichen ist
                  Müsste man evtl so machen

                  "style": "(rowindex, row, props) => (row['Fenster 1'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                  

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

                  D 1 Reply Last reply
                  0
                  • M MCU

                    @der-eine Wenn du das mit styles innerhalb der jsonTable machen wolltest

                    "style": "(rowindex, row, props) => (row.Tür == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                    

                    MIt Fenster 1 und Fenster 2 würde es nicht gehen da dort ein Leerzeichen ist
                    Müsste man evtl so machen

                    "style": "(rowindex, row, props) => (row['Fenster 1'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                    
                    D Offline
                    D Offline
                    der-eine
                    wrote on last edited by der-eine
                    #730

                    @mcu das wäre der Ansatz gewesen aber ich habe nicht herausgefunden wo der Style Tag stehen muss. Hatte immer ne Spalte mit Style und den Background Werten.

                    M 1 Reply Last reply
                    0
                    • D der-eine

                      @mcu das wäre der Ansatz gewesen aber ich habe nicht herausgefunden wo der Style Tag stehen muss. Hatte immer ne Spalte mit Style und den Background Werten.

                      M Online
                      M Online
                      MCU
                      wrote on last edited by MCU
                      #731

                      @der-eine
                      39f05d3e-c69d-4441-9236-dea25c0e7924-image.png

                      9f3045a3-cf35-4649-ad85-d1caa6077ea0-image.png

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

                      D 1 Reply Last reply
                      1
                      • M MCU

                        @der-eine
                        39f05d3e-c69d-4441-9236-dea25c0e7924-image.png

                        9f3045a3-cf35-4649-ad85-d1caa6077ea0-image.png

                        D Offline
                        D Offline
                        der-eine
                        wrote on last edited by
                        #732

                        @mcu hätte das schon versucht:

                        Bildschirmfoto 2025-02-10 um 01.16.33.png

                        M 1 Reply Last reply
                        0
                        • D der-eine

                          @mcu hätte das schon versucht:

                          Bildschirmfoto 2025-02-10 um 01.16.33.png

                          M Online
                          M Online
                          MCU
                          wrote on last edited by MCU
                          #733

                          @der-eine Nein.
                          row["Fenster 1"] ==

                          Und das muss ein Array sein, so wie ich es oben gezeigt habe

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

                          D 1 Reply Last reply
                          1
                          • M MCU

                            @der-eine Nein.
                            row["Fenster 1"] ==

                            Und das muss ein Array sein, so wie ich es oben gezeigt habe

                            D Offline
                            D Offline
                            der-eine
                            wrote on last edited by
                            #734

                            @mcu das davor war nur die "Erklärung"

                            Bildschirmfoto 2025-02-10 um 01.18.43.png

                            M 1 Reply Last reply
                            0
                            • D der-eine

                              @mcu das davor war nur die "Erklärung"

                              Bildschirmfoto 2025-02-10 um 01.18.43.png

                              M Online
                              M Online
                              MCU
                              wrote on last edited by MCU
                              #735

                              @der-eine
                              Dort muss ein Array drin stehen

                              [
                              {
                              "field":"Raum",
                              "label":"Raum",
                              },
                              {
                              "field":"Soll",
                              "label":"Soll",
                              },
                              {
                              "field":"Ist",
                              "label":"Ist",
                              },
                              {
                              "field":"Ventil",
                              "label":"Ventil",
                              },
                              {
                              "field":"Status",
                              "label":"Status",
                              },
                              {
                              "field":"Fenster 1",
                              "label":"Fenster 1",
                              "style": "(rowindex, row, props) => (row['Fenster 1'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                              },
                              {
                              "field":"Fenster 2",
                              "label":"Fenster 2",
                              "style": "(rowindex, row, props) => (row['Fenster 2'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                              },
                              {
                              "field":"Tür",
                              "label":"Tür",
                              "style": "(rowindex, row, props) => (row['Tür'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                              }
                              ]
                              
                              
                              
                              
                              
                              
                              

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

                              D 1 Reply Last reply
                              1
                              • M MCU

                                @der-eine
                                Dort muss ein Array drin stehen

                                [
                                {
                                "field":"Raum",
                                "label":"Raum",
                                },
                                {
                                "field":"Soll",
                                "label":"Soll",
                                },
                                {
                                "field":"Ist",
                                "label":"Ist",
                                },
                                {
                                "field":"Ventil",
                                "label":"Ventil",
                                },
                                {
                                "field":"Status",
                                "label":"Status",
                                },
                                {
                                "field":"Fenster 1",
                                "label":"Fenster 1",
                                "style": "(rowindex, row, props) => (row['Fenster 1'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                                },
                                {
                                "field":"Fenster 2",
                                "label":"Fenster 2",
                                "style": "(rowindex, row, props) => (row['Fenster 2'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                                },
                                {
                                "field":"Tür",
                                "label":"Tür",
                                "style": "(rowindex, row, props) => (row['Tür'] == 'Offen' ? 'background-color: #00FF00' : 'background-color: #FF0000')"
                                }
                                ]
                                
                                
                                
                                
                                
                                
                                
                                D Offline
                                D Offline
                                der-eine
                                wrote on last edited by
                                #736

                                @mcu passt. Danke für die Erklärung. :+1:

                                M 1 Reply Last reply
                                0
                                • D der-eine

                                  @mcu passt. Danke für die Erklärung. :+1:

                                  M Online
                                  M Online
                                  MCU
                                  wrote on last edited by
                                  #737

                                  @der-eine Fenster 2 war noch falsch, korrigiert

                                  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 Reply Last reply
                                  1
                                  • B Offline
                                    B Offline
                                    bastian-m
                                    wrote on last edited by
                                    #738

                                    Ist beim Entwicklerteam eigentlich soweit alles in Ordnung? Mir ist gerade aufgefallen, dass es zumindest im Github-Repo seit November keinen Commit mehr gab.

                                    Natürlich will Gut Ding Weile haben und jeder macht mal Pause und hat wichtigeres zu tun, noch dazu bei einem Freizeitprojekt. Ich hoffe, @Zefau geht's gut.

                                    Gruß,
                                    Bastian

                                    M 1 Reply Last reply
                                    1
                                    • B bastian-m

                                      Ist beim Entwicklerteam eigentlich soweit alles in Ordnung? Mir ist gerade aufgefallen, dass es zumindest im Github-Repo seit November keinen Commit mehr gab.

                                      Natürlich will Gut Ding Weile haben und jeder macht mal Pause und hat wichtigeres zu tun, noch dazu bei einem Freizeitprojekt. Ich hoffe, @Zefau geht's gut.

                                      Gruß,
                                      Bastian

                                      M Online
                                      M Online
                                      MCU
                                      wrote on last edited by MCU
                                      #739

                                      @bastian-m Er entwickelt auf jedenfall weiter. Mal mehr mal weniger. Ist in github zu sehen, wenn man auf den Namen klickt.

                                      https://github.com/Zefau

                                      bd1fd0b5-b4ea-4e1b-9e15-3c5fdb5ab872-image.png

                                      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 Reply Last reply
                                      0
                                      • M MCU

                                        @bastian-m Er entwickelt auf jedenfall weiter. Mal mehr mal weniger. Ist in github zu sehen, wenn man auf den Namen klickt.

                                        https://github.com/Zefau

                                        bd1fd0b5-b4ea-4e1b-9e15-3c5fdb5ab872-image.png

                                        U Offline
                                        U Offline
                                        uwe72
                                        wrote on last edited by uwe72
                                        #740

                                        @mcu möchte Dich nicht zu dem Thema nerven:
                                        https://github.com/Zefau/ioBroker.jarvis/issues/2878

                                        Wenn Du sagst Du hast "keine Idee" dazu ist dies absolut in Ordnung.

                                        Habe nun bei einer anderen Umgebung (anderes iobroker/jarvis) auch auf die neueste Version (jarvis.0, v3.2.0-rc.12) umgestellt und habe das gleiche Verhalten. Mich wunderte es nur, da du ja sagtest, dass "mein HTML" bei dir korrekt dargestellt wird. Hast Du vielleicht doch noch eine Idee an was es liegen kann? Das mit dem hinzufügen von height=100% hatte nichts gebracht gehabt.

                                        Gibts eine Chance, dass bei der finalen v3.2 das Problem gefixt wird?

                                        U 1 Reply Last reply
                                        0
                                        • U uwe72

                                          @mcu möchte Dich nicht zu dem Thema nerven:
                                          https://github.com/Zefau/ioBroker.jarvis/issues/2878

                                          Wenn Du sagst Du hast "keine Idee" dazu ist dies absolut in Ordnung.

                                          Habe nun bei einer anderen Umgebung (anderes iobroker/jarvis) auch auf die neueste Version (jarvis.0, v3.2.0-rc.12) umgestellt und habe das gleiche Verhalten. Mich wunderte es nur, da du ja sagtest, dass "mein HTML" bei dir korrekt dargestellt wird. Hast Du vielleicht doch noch eine Idee an was es liegen kann? Das mit dem hinzufügen von height=100% hatte nichts gebracht gehabt.

                                          Gibts eine Chance, dass bei der finalen v3.2 das Problem gefixt wird?

                                          U Offline
                                          U Offline
                                          uwe72
                                          wrote on last edited by
                                          #741

                                          @mcu

                                          Ich habe zum Test mal einen neuen Reiter gemacht und ein simples HTML erstellt. Eigentlich sieht man, dass es gar nichts mit dem HTML zu tun hat, sondern eher mit dem "Panel" dahinter, welches einfach nicht "gefüllt" ist.

                                          1fb5195c-6206-46c3-b6f8-67982f2e5013-image.png

                                          U 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          679

                                          Online

                                          32.6k

                                          Users

                                          82.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe