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. Visualisierung
  4. Jarvis - Tabelle

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.1k

Jarvis - Tabelle

Geplant Angeheftet Gesperrt Verschoben Visualisierung
41 Beiträge 3 Kommentatoren 3.3k Aufrufe 2 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.
  • L LE-R.Kelly

    @mcu genauso

    9ca569fc-56a0-48de-b0f0-d3e0bf189203-image.png

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

    @le-r-kelly War schon auf der alpha, gehe jetzt mal au die v3.0.11. Dauert ein wenig.

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

    M 1 Antwort Letzte Antwort
    0
    • M MCU

      @le-r-kelly War schon auf der alpha, gehe jetzt mal au die v3.0.11. Dauert ein wenig.

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

      @mcu Setzt das mal in die Styles:

      p {
          margin: 0px !important;
      }
      

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

      L 1 Antwort Letzte Antwort
      0
      • M MCU

        @mcu Setzt das mal in die Styles:

        p {
            margin: 0px !important;
        }
        
        L Offline
        L Offline
        LE-R.Kelly
        schrieb am zuletzt editiert von
        #31

        @mcu SUPER

        28e23a07-049e-4749-91d6-e3455828417c-image.png

        Mal noch eine Verständnisfrage: Ich habe im Widget noch das "align": "center" eingefügt. Warum zentriert er Überschrift und Zeilen unterschiedlich?

        M 1 Antwort Letzte Antwort
        0
        • L LE-R.Kelly

          @mcu SUPER

          28e23a07-049e-4749-91d6-e3455828417c-image.png

          Mal noch eine Verständnisfrage: Ich habe im Widget noch das "align": "center" eingefügt. Warum zentriert er Überschrift und Zeilen unterschiedlich?

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

          @le-r-kelly Keine Ahnung.
          Bitte einmal Dein verändertes Script einstellen. 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.

          L 1 Antwort Letzte Antwort
          0
          • M MCU

            @le-r-kelly Keine Ahnung.
            Bitte einmal Dein verändertes Script einstellen. Danke.

            L Offline
            L Offline
            LE-R.Kelly
            schrieb am zuletzt editiert von
            #33

            @mcu
            Ich hab nur die Werterundungen eingefügt. Du bist so schnell mit Helfen, da konnte ich mich noch gar nicht richtig in das Skript reindenken.

            Auf den ersten Blick dachte ich, dass eine Änderung der Zeile 45 etwas bewirkt, war aber nicht so.

            // **********************************************
            // jsonTable mit nbsp für Bereiche mit Tür offen?
            // **********************************************
            let dpJSONTable      = '0_userdata.0.jarvis.jsonTable';
            let dpJSONTableValue = dpJSONTable + '.jsonTable';
            let dpSetJsonItems   = dpJSONTable + '.setJsonItems';
            let dpListDPs        = dpJSONTable + '.listDPs';
            createState(dpJSONTableValue, {read: true, write: true, name: "jsonTable Daten", type: "string", role: "text", def: "[]" });
            createState(dpSetJsonItems, {read: true, write: true, name: "Konfiguration JsonItems", type: "string", role: "text", def: "[]" });
            createState(dpListDPs, {read: true, write: true, name: "Liste der verwendeten DPs", type: "string", role: "text", def: "[]" });
            
            if (existsState(dpListDPs)){
                let iDDPs = JSON.parse(getState(dpListDPs).val);
                log(iDDPs);
                on({id:iDDPs, change:"ne"}, function (obj){
                    jsonTable_erstellen();
                });
            
            }
            
            on({id: dpSetJsonItems, change: "ne"}, function (obj) {
                let value = obj.state.val;
                log('Script '+ scriptName +' wird automatisch neugestartet!','warn');
                getObjectsFromItems()
                jsonTable_erstellen();
                runScript(scriptName);
            
            });
            
            // jsonTable_erstellen();
            
            function jsonTable_erstellen(){
                let jsonItems = JSON.parse(getState(dpSetJsonItems).val);
                // Länge Name bestimmen
                let nameLen = 0;
                for (let i=0;i<jsonItems.length;i++){
                    let statusArr = jsonItems[i].status;
                    for (let j=0;j<statusArr.length;j++){
                        if (statusArr[j].name.length> nameLen){
                            nameLen = statusArr[j].name.length;
                        }
                    }
                }
                // nameLen Abstand ergönzen
                nameLen = nameLen + 5;
                let jsonArr = [];
                for (let i =0;i<jsonItems.length;i++){
                    let jsonObj = {};
                    jsonObj.Bereich = jsonItems[i].bereich;
                    jsonObj.Temperatur =(getState(jsonItems[i].temperatur).val).toFixed(1) +' °C';
                    jsonObj.Luftfeuchte =(getState(jsonItems[i].luftfeuchte).val).toFixed(1) + ' %';
                    let statusArr = jsonItems[i].status;
                    let statusAll = '';
                    for (let j=0;j<statusArr.length;j++){
                        let status = '';
                        let nbspaceLen = nameLen - statusArr[j].name.length;
                        let spaceStr = '';
                        for (let k=0;k<nbspaceLen;k++){
                            spaceStr = spaceStr + '&nbsp';
                        }
                        if (existsState(statusArr[j].open)){
                            if (getState(statusArr[j].open).val){ //true offen
                                status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:orange;">offen</span></div></p></code>';
                            }else{
                                status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:green;">geschlossen</span></div></p></code>';
                            }
                        }else{
                            status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:red;">existiert nicht</span></div></p></code>';
                        }    
                        statusAll = statusAll + status;
                    }
                    jsonObj.Status = statusAll;
                    jsonArr.push(jsonObj);
                }
                
                // log(JSON.stringify(jsonArr));
                setState(dpJSONTableValue,JSON.stringify(jsonArr),false);
            }
            
            
            function getObjectsFromItems(){
                let jsonItems = JSON.parse(getState(dpSetJsonItems).val);
                let objectArr = [];
                for (let i=0;i<jsonItems.length;i++){
                    if (existsObject(jsonItems[i].temperatur)){
                        objectArr.push(jsonItems[i].temperatur);
                    }else{
                        log('Object: '+ jsonItems[i].temperatur + ' gibt es in ioBroker nicht!','warn');
                    }
                    if (existsObject(jsonItems[i].luftfeuchte)){
                        objectArr.push(jsonItems[i].luftfeuchte);
                    }else{
                        log('Object: '+ jsonItems[i].luftfeuchte + ' gibt es in ioBroker nicht!','warn');
                    }
                    for (let y=0;y<jsonItems[i].status.length;y++){
                        if (existsObject(jsonItems[i].status[y].open)){
                            objectArr.push(jsonItems[i].status[y].open);
                        }else{
                            // Object gibt es nicht
                            log('Object: '+ jsonItems[i].status[y].open + ' gibt es in ioBroker nicht!','warn');
                        }
                    }
                }
                //log(JSON.stringify(objectArr));
                const uniqueList = [...new Set(objectArr)]
                //return uniqueList;
                setState(dpListDPs,JSON.stringify(uniqueList),false);
            }
            
            M 1 Antwort Letzte Antwort
            0
            • L LE-R.Kelly

              @mcu
              Ich hab nur die Werterundungen eingefügt. Du bist so schnell mit Helfen, da konnte ich mich noch gar nicht richtig in das Skript reindenken.

              Auf den ersten Blick dachte ich, dass eine Änderung der Zeile 45 etwas bewirkt, war aber nicht so.

              // **********************************************
              // jsonTable mit nbsp für Bereiche mit Tür offen?
              // **********************************************
              let dpJSONTable      = '0_userdata.0.jarvis.jsonTable';
              let dpJSONTableValue = dpJSONTable + '.jsonTable';
              let dpSetJsonItems   = dpJSONTable + '.setJsonItems';
              let dpListDPs        = dpJSONTable + '.listDPs';
              createState(dpJSONTableValue, {read: true, write: true, name: "jsonTable Daten", type: "string", role: "text", def: "[]" });
              createState(dpSetJsonItems, {read: true, write: true, name: "Konfiguration JsonItems", type: "string", role: "text", def: "[]" });
              createState(dpListDPs, {read: true, write: true, name: "Liste der verwendeten DPs", type: "string", role: "text", def: "[]" });
              
              if (existsState(dpListDPs)){
                  let iDDPs = JSON.parse(getState(dpListDPs).val);
                  log(iDDPs);
                  on({id:iDDPs, change:"ne"}, function (obj){
                      jsonTable_erstellen();
                  });
              
              }
              
              on({id: dpSetJsonItems, change: "ne"}, function (obj) {
                  let value = obj.state.val;
                  log('Script '+ scriptName +' wird automatisch neugestartet!','warn');
                  getObjectsFromItems()
                  jsonTable_erstellen();
                  runScript(scriptName);
              
              });
              
              // jsonTable_erstellen();
              
              function jsonTable_erstellen(){
                  let jsonItems = JSON.parse(getState(dpSetJsonItems).val);
                  // Länge Name bestimmen
                  let nameLen = 0;
                  for (let i=0;i<jsonItems.length;i++){
                      let statusArr = jsonItems[i].status;
                      for (let j=0;j<statusArr.length;j++){
                          if (statusArr[j].name.length> nameLen){
                              nameLen = statusArr[j].name.length;
                          }
                      }
                  }
                  // nameLen Abstand ergönzen
                  nameLen = nameLen + 5;
                  let jsonArr = [];
                  for (let i =0;i<jsonItems.length;i++){
                      let jsonObj = {};
                      jsonObj.Bereich = jsonItems[i].bereich;
                      jsonObj.Temperatur =(getState(jsonItems[i].temperatur).val).toFixed(1) +' °C';
                      jsonObj.Luftfeuchte =(getState(jsonItems[i].luftfeuchte).val).toFixed(1) + ' %';
                      let statusArr = jsonItems[i].status;
                      let statusAll = '';
                      for (let j=0;j<statusArr.length;j++){
                          let status = '';
                          let nbspaceLen = nameLen - statusArr[j].name.length;
                          let spaceStr = '';
                          for (let k=0;k<nbspaceLen;k++){
                              spaceStr = spaceStr + '&nbsp';
                          }
                          if (existsState(statusArr[j].open)){
                              if (getState(statusArr[j].open).val){ //true offen
                                  status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:orange;">offen</span></div></p></code>';
                              }else{
                                  status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:green;">geschlossen</span></div></p></code>';
                              }
                          }else{
                              status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:red;">existiert nicht</span></div></p></code>';
                          }    
                          statusAll = statusAll + status;
                      }
                      jsonObj.Status = statusAll;
                      jsonArr.push(jsonObj);
                  }
                  
                  // log(JSON.stringify(jsonArr));
                  setState(dpJSONTableValue,JSON.stringify(jsonArr),false);
              }
              
              
              function getObjectsFromItems(){
                  let jsonItems = JSON.parse(getState(dpSetJsonItems).val);
                  let objectArr = [];
                  for (let i=0;i<jsonItems.length;i++){
                      if (existsObject(jsonItems[i].temperatur)){
                          objectArr.push(jsonItems[i].temperatur);
                      }else{
                          log('Object: '+ jsonItems[i].temperatur + ' gibt es in ioBroker nicht!','warn');
                      }
                      if (existsObject(jsonItems[i].luftfeuchte)){
                          objectArr.push(jsonItems[i].luftfeuchte);
                      }else{
                          log('Object: '+ jsonItems[i].luftfeuchte + ' gibt es in ioBroker nicht!','warn');
                      }
                      for (let y=0;y<jsonItems[i].status.length;y++){
                          if (existsObject(jsonItems[i].status[y].open)){
                              objectArr.push(jsonItems[i].status[y].open);
                          }else{
                              // Object gibt es nicht
                              log('Object: '+ jsonItems[i].status[y].open + ' gibt es in ioBroker nicht!','warn');
                          }
                      }
                  }
                  //log(JSON.stringify(objectArr));
                  const uniqueList = [...new Set(objectArr)]
                  //return uniqueList;
                  setState(dpListDPs,JSON.stringify(uniqueList),false);
              }
              
              M Online
              M Online
              MCU
              schrieb am zuletzt editiert von MCU
              #34

              @le-r-kelly Zeile 45 ist für den Abstand verantwortlich:
              f6690843-f3f4-4f85-9255-be7184ba94c0-image.png

              Ich hatte ebenso noch hinterlegt, dass sich der Bereich oder der Status orange färben, wenn der Sensor nicht erreichbar ist. So weiß ich, wann die Batterie getauscht werden muss.

              Zeile 62-63 prüft ob die Tür offen ist, nicht, ob der Sensor erreichbar ist. Das müsste man noch einbauen.

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

              L 1 Antwort Letzte Antwort
              0
              • M MCU

                @le-r-kelly Zeile 45 ist für den Abstand verantwortlich:
                f6690843-f3f4-4f85-9255-be7184ba94c0-image.png

                Ich hatte ebenso noch hinterlegt, dass sich der Bereich oder der Status orange färben, wenn der Sensor nicht erreichbar ist. So weiß ich, wann die Batterie getauscht werden muss.

                Zeile 62-63 prüft ob die Tür offen ist, nicht, ob der Sensor erreichbar ist. Das müsste man noch einbauen.

                L Offline
                L Offline
                LE-R.Kelly
                schrieb am zuletzt editiert von
                #35

                Ich hatte ebenso noch hinterlegt, dass sich der Bereich oder der Status orange färben, wenn der Sensor nicht erreichbar ist. So weiß ich, wann die Batterie getauscht werden muss.

                Zeile 62-63 prüft ob die Tür offen ist, nicht, ob der Sensor erreichbar ist. Das müsste man noch einbauen.

                Hab ich gesehen. Ich denke mal, der Datenpunkt muss in den jsonitems mit aufgenommen werden, dann wird er ja (so wie ich das sehe) mit ins array aufgenommen, dann

                 if (existsState(statusArr[j].available)){
                                if (getState(statusArr[j].available).val){ 
                                    status = '<code><p><div><span style="color:white;">'+statusArr[j].name+spaceStr+'</span><span style="color:orange;">offen</span></div></p></code>';
                                }else{
                                    status = '<code><p><div><span style="color:orange;">'+statusArr[j].name+spaceStr+'</span><span style="color:green;">geschlossen</span></div></p></code>';
                                }
                            }else{
                                status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:red;">existiert nicht</span></div></p></code>';
                            }    
                

                Ich weiß noch nicht, wie ich in der if-Funktion statusArr[j].available und statusArr[j].open kombinieren kann, aber getrennt dürfte es ja auch gehen (hab es noch nicht getestet).

                L 1 Antwort Letzte Antwort
                0
                • L LE-R.Kelly

                  Ich hatte ebenso noch hinterlegt, dass sich der Bereich oder der Status orange färben, wenn der Sensor nicht erreichbar ist. So weiß ich, wann die Batterie getauscht werden muss.

                  Zeile 62-63 prüft ob die Tür offen ist, nicht, ob der Sensor erreichbar ist. Das müsste man noch einbauen.

                  Hab ich gesehen. Ich denke mal, der Datenpunkt muss in den jsonitems mit aufgenommen werden, dann wird er ja (so wie ich das sehe) mit ins array aufgenommen, dann

                   if (existsState(statusArr[j].available)){
                                  if (getState(statusArr[j].available).val){ 
                                      status = '<code><p><div><span style="color:white;">'+statusArr[j].name+spaceStr+'</span><span style="color:orange;">offen</span></div></p></code>';
                                  }else{
                                      status = '<code><p><div><span style="color:orange;">'+statusArr[j].name+spaceStr+'</span><span style="color:green;">geschlossen</span></div></p></code>';
                                  }
                              }else{
                                  status = '<code><p><div><span>'+statusArr[j].name+spaceStr+'</span><span style="color:red;">existiert nicht</span></div></p></code>';
                              }    
                  

                  Ich weiß noch nicht, wie ich in der if-Funktion statusArr[j].available und statusArr[j].open kombinieren kann, aber getrennt dürfte es ja auch gehen (hab es noch nicht getestet).

                  L Offline
                  L Offline
                  LE-R.Kelly
                  schrieb am zuletzt editiert von
                  #36

                  Wäre noch die Frage, warum unterschiedlich zentriert wird?

                  5f414ce6-622e-47ae-b405-bc36020c03ad-image.png

                  M 1 Antwort Letzte Antwort
                  0
                  • L LE-R.Kelly

                    Wäre noch die Frage, warum unterschiedlich zentriert wird?

                    5f414ce6-622e-47ae-b405-bc36020c03ad-image.png

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

                    @le-r-kelly
                    Bitte dazu ein bug-Request aufmachen:
                    https://github.com/Zefau/ioBroker.jarvis/issues

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

                    L 1 Antwort Letzte Antwort
                    0
                    • M MCU

                      @le-r-kelly
                      Bitte dazu ein bug-Request aufmachen:
                      https://github.com/Zefau/ioBroker.jarvis/issues

                      L Offline
                      L Offline
                      LE-R.Kelly
                      schrieb am zuletzt editiert von
                      #38

                      @mcu erledigt

                      L 1 Antwort Letzte Antwort
                      0
                      • L LE-R.Kelly

                        @mcu erledigt

                        L Offline
                        L Offline
                        LE-R.Kelly
                        schrieb am zuletzt editiert von
                        #39

                        Lässt sich der Bereich auch irgendwie ausblenden (weil für meine Zwecke unnötig)?

                        3cc2d52f-57ca-4938-b8fa-3b71bdad6b25-image.png

                        M 1 Antwort Letzte Antwort
                        0
                        • L LE-R.Kelly

                          Lässt sich der Bereich auch irgendwie ausblenden (weil für meine Zwecke unnötig)?

                          3cc2d52f-57ca-4938-b8fa-3b71bdad6b25-image.png

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

                          @le-r-kelly
                          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.

                          L 1 Antwort Letzte Antwort
                          0
                          • M MCU

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

                            L Offline
                            L Offline
                            LE-R.Kelly
                            schrieb am zuletzt editiert von LE-R.Kelly
                            #41

                            @mcu
                            Du bist echt unglaublich schnell !!! Sorry wenn ich nerve :face_with_rolling_eyes:

                            Achso: Danke

                            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

                            746

                            Online

                            32.6k

                            Benutzer

                            82.1k

                            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