NEWS
Jarvis - Tabelle
-
Verrückt, will irgendwie nicht :-(

jsonTable Daten:
[ { "Bereich": "Außen", "Temperatur": "29.14 °C", "Luftfeuchte": "49.48 %", "Status": "<code><p><div><span>Eingansgtür           </span><span style=\"color:green;\">geschlossen</span></div></p></code>" }, { "Bereich": "Wohnzimmer", "Temperatur": "24.33 °C", "Luftfeuchte": "66.56 %", "Status": "<code><p><div><span>Küchenfenster         </span><span style=\"color:green;\">geschlossen</span></div></p></code><code><p><div><span>Wohnzimmer links      </span><span style=\"color:green;\">geschlossen</span></div></p></code><code><p><div><span>Wohnzimmer rechts     </span><span style=\"color:red;\">existiert nicht</span></div></p></code>" } ]Liste der verwendeten DPs:
[ "zigbee.0.00158d0002ca0acc.temperature", "zigbee.0.00158d0002ca0acc.humidity", "zigbee.0.00158d0002e6b55d.opened", "zigbee.0.00158d0002c8f457.temperature", "zigbee.0.00158d0002c8f457.humidity", "zigbee.0.00158d0003138382.opened", "zigbee.0.00158d0002f921f5.opened", "zigbee.0.00158d0002fa9531" ]Konfiguration JsonItems
[ { "bereich": "Außen", "temperatur": "zigbee.0.00158d0002ca0acc.temperature", "luftfeuchte": "zigbee.0.00158d0002ca0acc.humidity", "status": [ { "name": "Eingansgtür", "open": "zigbee.0.00158d0002e6b55d.opened" } ] }, { "bereich": "Wohnzimmer", "temperatur": "zigbee.0.00158d0002c8f457.temperature", "luftfeuchte": "zigbee.0.00158d0002c8f457.humidity", "status": [ { "name": "Küchenfenster", "open": "zigbee.0.00158d0003138382.opened" }, { "name": "Wohnzimmer links", "open": "zigbee.0.00158d0002f921f5.opened" }, { "name": "Wohnzimmer rechts", "open": "zigbee.0.00158d0002fa9531" } ] } ]Hast Du in der Widget-Konfig noch etwas Besonderes stehen? Da hab ich noch nix eingetragen.

-
Verrückt, will irgendwie nicht :-(

jsonTable Daten:
[ { "Bereich": "Außen", "Temperatur": "29.14 °C", "Luftfeuchte": "49.48 %", "Status": "<code><p><div><span>Eingansgtür           </span><span style=\"color:green;\">geschlossen</span></div></p></code>" }, { "Bereich": "Wohnzimmer", "Temperatur": "24.33 °C", "Luftfeuchte": "66.56 %", "Status": "<code><p><div><span>Küchenfenster         </span><span style=\"color:green;\">geschlossen</span></div></p></code><code><p><div><span>Wohnzimmer links      </span><span style=\"color:green;\">geschlossen</span></div></p></code><code><p><div><span>Wohnzimmer rechts     </span><span style=\"color:red;\">existiert nicht</span></div></p></code>" } ]Liste der verwendeten DPs:
[ "zigbee.0.00158d0002ca0acc.temperature", "zigbee.0.00158d0002ca0acc.humidity", "zigbee.0.00158d0002e6b55d.opened", "zigbee.0.00158d0002c8f457.temperature", "zigbee.0.00158d0002c8f457.humidity", "zigbee.0.00158d0003138382.opened", "zigbee.0.00158d0002f921f5.opened", "zigbee.0.00158d0002fa9531" ]Konfiguration JsonItems
[ { "bereich": "Außen", "temperatur": "zigbee.0.00158d0002ca0acc.temperature", "luftfeuchte": "zigbee.0.00158d0002ca0acc.humidity", "status": [ { "name": "Eingansgtür", "open": "zigbee.0.00158d0002e6b55d.opened" } ] }, { "bereich": "Wohnzimmer", "temperatur": "zigbee.0.00158d0002c8f457.temperature", "luftfeuchte": "zigbee.0.00158d0002c8f457.humidity", "status": [ { "name": "Küchenfenster", "open": "zigbee.0.00158d0003138382.opened" }, { "name": "Wohnzimmer links", "open": "zigbee.0.00158d0002f921f5.opened" }, { "name": "Wohnzimmer rechts", "open": "zigbee.0.00158d0002fa9531" } ] } ]Hast Du in der Widget-Konfig noch etwas Besonderes stehen? Da hab ich noch nix eingetragen.

-
Ok.
Hab jetzt das Forum zur Pro durchforstet, aber nix Konkretes zum Abschluss gefunden.Kannst Du hier nochmal den Link reinstellen? Danke
-
Ok.
Hab jetzt das Forum zur Pro durchforstet, aber nix Konkretes zum Abschluss gefunden.Kannst Du hier nochmal den Link reinstellen? Danke
-
@mcu
Funktioniert jetzt :-)

Danke für Deine Hilfe :+1: :+1: :+1:
Zwei Bitten/Fragen hätte ich noch:
- Würdest Du mal noch die Konfiguration der Spalten aus der Widget-Konfiguration posten?
- Mir gefällt Dein Theme, kann man das irgendwo beziehen?
VG
Ronny -
@mcu
Funktioniert jetzt :-)

Danke für Deine Hilfe :+1: :+1: :+1:
Zwei Bitten/Fragen hätte ich noch:
- Würdest Du mal noch die Konfiguration der Spalten aus der Widget-Konfiguration posten?
- Mir gefällt Dein Theme, kann man das irgendwo beziehen?
VG
Ronny@le-r-kelly Die zieht aber nicht ist noch ein bug.
[{"field":"Bereich","label":"Bereich"},{"field":"Temperatur","label":"Temperatur","style":"width:20%"},{"field":"Luftfeuchte","label":"Luffeuchte","style":"width:20%"},{"field":"Status","label":"Status","style":"width:50%"}]Theme:
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/besonderheiten-v3/styles/transparentes-designWohnzimmer rechts scheint einen Fehler zu haben? Kein Objekt in ioBroker definiert.
-
@mcu
Dankeschön!Den Fehler mit dem Wohnzimmer hab ich gefunden und nunmehr alle Sensoren übertragen.
Ich versuche gerade durch Dein Skript zu steigen, weil ich die Tabelle stauchen möchte, also alle Zwischenzeilen raus. Hintergrund ist, dass man sonst auf dem Flur-Tablet scrollen müsste, was nicht praktikabel ist. -
@mcu
Dankeschön!Den Fehler mit dem Wohnzimmer hab ich gefunden und nunmehr alle Sensoren übertragen.
Ich versuche gerade durch Dein Skript zu steigen, weil ich die Tabelle stauchen möchte, also alle Zwischenzeilen raus. Hintergrund ist, dass man sonst auf dem Flur-Tablet scrollen müsste, was nicht praktikabel ist. -
@le-r-kelly Die Zwischenzeilen, das macht das jsonTable-Modul automatisch. Man kann evtl. die Schriftgröße ändern.
Du kannst noch die Kompakte Ansicht einschalten:
Das Ändern der Kompaktansicht hat keinen Effekt, ich kriege die Zwischenzeilen nicht weg :-(
Perspektivisch will ich wieder da hin:

Auch alles zentriert, weil ich das optisch ansehnlicher finde. 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.
Deine Leistung ist großartig und ich bin meilenweit von Deinen Fähigkeiten entfernt. Ich tue mich nur gerade schwer mit dem Umstieg und kann mich nicht so recht von meinen optischen Gewohnheiten lösen.
-
Das Ändern der Kompaktansicht hat keinen Effekt, ich kriege die Zwischenzeilen nicht weg :-(
Perspektivisch will ich wieder da hin:

Auch alles zentriert, weil ich das optisch ansehnlicher finde. 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.
Deine Leistung ist großartig und ich bin meilenweit von Deinen Fähigkeiten entfernt. Ich tue mich nur gerade schwer mit dem Umstieg und kann mich nicht so recht von meinen optischen Gewohnheiten lösen.
-
@mcu Versteh ich nicht:


-
@mcu Versteh ich nicht:


-
@le-r-kelly Wenn du auf dem Tablet den Vollbilld-Button klickst/drückst?

Wie sieht es dann aus?@mcu genauso

-
@mcu genauso

-
@mcu SUPER

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

Mal noch eine Verständnisfrage: Ich habe im Widget noch das "align": "center" eingefügt. Warum zentriert er Überschrift und Zeilen unterschiedlich?
-
@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 + ' '; } 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); } -
@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 + ' '; } 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); }@le-r-kelly Zeile 45 ist für den Abstand verantwortlich:

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.
-
@le-r-kelly Zeile 45 ist für den Abstand verantwortlich:

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


