NEWS
Jarvis - Tabelle
-
@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).
-
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).
Wäre noch die Frage, warum unterschiedlich zentriert wird?

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

@le-r-kelly
Bitte dazu ein bug-Request aufmachen:
https://github.com/Zefau/ioBroker.jarvis/issues -
@le-r-kelly
Bitte dazu ein bug-Request aufmachen:
https://github.com/Zefau/ioBroker.jarvis/issues@mcu erledigt
-
@mcu erledigt
Lässt sich der Bereich auch irgendwie ausblenden (weil für meine Zwecke unnötig)?

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

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