Navigation

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

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    jarvis v3.2.x - just another remarkable vis

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

      @meisterq-0 Das wurde für das automatische Auslesen der Objektdaten common.states für die Anzeigevariante schon mal gefordert. Wurde nicht umgesetzt.

      Problem ist das der DP mehrfach in unterschiedlichen Geräte-DPs genutzt werden kann, man aber nicht in allen eine automatische Änderung haben möchte. Also man muss schon die Geräte-Id und stateKey angeben und dann hat man noch die unterschiedlichen Möglichkeiten mit dem Objektwerten und Statewerten usw.

      Ändern sich dann mehrere States gleichzeitig würde der deviceDP von 2 Seiten gleichzeitig geändert werden. Evlt klappt evlt nicht und nur der letzte gewinnt.

      Ist etwas komplizierter.

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

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

          D 1 Reply Last reply Reply Quote 0
          • D
            der-eine @MCU last edited by

            @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 Reply Quote 0
            • M
              MCU @der-eine last edited by

              @der-eine Du meinst die Überschriften?

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

                    @mcu top funktioniert. Danke. 👍

                    M 1 Reply Last reply Reply Quote 0
                    • M
                      MCU @der-eine last edited by

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

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

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

                          D 1 Reply Last reply Reply Quote 1
                          • D
                            der-eine @MCU last edited by

                            @mcu hätte das schon versucht:

                            Bildschirmfoto 2025-02-10 um 01.16.33.png

                            M 1 Reply Last reply Reply Quote 0
                            • M
                              MCU @der-eine last edited by MCU

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

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

                              D 1 Reply Last reply Reply Quote 1
                              • D
                                der-eine @MCU last edited by

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

                                Bildschirmfoto 2025-02-10 um 01.18.43.png

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

                                    @mcu passt. Danke für die Erklärung. 👍

                                    M 1 Reply Last reply Reply Quote 0
                                    • M
                                      MCU @der-eine last edited by

                                      @der-eine Fenster 2 war noch falsch, korrigiert

                                      1 Reply Last reply Reply Quote 1
                                      • B
                                        bastian-m last edited by

                                        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 Reply Quote 1
                                        • M
                                          MCU @bastian-m last edited by 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 1 Reply Last reply Reply Quote 0
                                          • U
                                            uwe72 @MCU last edited by 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?

                                            uwe72 created this issue in Zefau/ioBroker.jarvis

                                            closed Viele Layoutfehler / Reiter in Vollbild füllt sich nicht mehr in vertikaler Richtung #2878

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            880
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            43
                                            882
                                            186452
                                            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