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
    876

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

                      767

                      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