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.
  • 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

                        740

                        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