NEWS
jarvis v3.0.0 - just another remarkable vis
-
@SWE_weidlix
Wie es aussieht, hast du die v2 im Einsatz. Dann gehört der Post eigentlich in den v2-Thread.
Da du aber auch mit v3 arbeiten möchtest, hier vielleicht erstmal was zu lesen:
https://mcuiobroker.gitbook.io/jarvis-infos/
Schau erstmal und wenn du dann dazu Fragen haben solltest,
v2 -> https://forum.iobroker.net/topic/30668/jarvis-v2-2-0-just-another-remarkable-visv3-> hier
WidgetHeader ausblenden
https://mcuiobroker.gitbook.io/jarvis-infos/jarvis/beispiele/styles/widgetheader-ausblendenEs muss v2.2.5 installiert sein!
P.S. Es gibt nur einen Entwickler @Zefau . -
@mcu
Zunächst einmal Danke.zu Punkt 1
Hab einen Issue aufgemachtzu Punkt 2 und 3
Die Größenänderung hat geklappt. Die Sache mit dem Trennstrich hat nicht den Effekt, den ich eigentlich wollte. Wenig Platz vorhanden -> Trennstrich führt zu einem Zeilenumbruch. Viel Platz vorhanden -> Trennstrich wird entfernt und das Wort zusammengeschrieben. Der Vorschlag mit white-space führt nur dazu, dass gar nicht mehr getrennt wird.zu Punkt 4
Muss ich noch ausprobieren, wie da der aktuelle Stand ist.zu Punkt 5
Hab einen feature request angelegtInzwischen ist noch eine weitere Frage aufgetaucht.
Punkt 6
Wenn ich ein Widget oder einen kompletten Tab kopiere, erhalte ich keine Kopien, sondern Duplikate (gleiche Id) d.h., wenn ich ein Widget verändere, ändert sich auch das Duplikat. Eigentlich will ich ja wirklich Kopien, die dann nach dem kopieren unabhängig voneinander sind. Ansonsten kann ich mit der Kopie ja nichts anfangen. -
@mcu
Zunächst einmal Danke.zu Punkt 1
Hab einen Issue aufgemachtzu Punkt 2 und 3
Die Größenänderung hat geklappt. Die Sache mit dem Trennstrich hat nicht den Effekt, den ich eigentlich wollte. Wenig Platz vorhanden -> Trennstrich führt zu einem Zeilenumbruch. Viel Platz vorhanden -> Trennstrich wird entfernt und das Wort zusammengeschrieben. Der Vorschlag mit white-space führt nur dazu, dass gar nicht mehr getrennt wird.zu Punkt 4
Muss ich noch ausprobieren, wie da der aktuelle Stand ist.zu Punkt 5
Hab einen feature request angelegtInzwischen ist noch eine weitere Frage aufgetaucht.
Punkt 6
Wenn ich ein Widget oder einen kompletten Tab kopiere, erhalte ich keine Kopien, sondern Duplikate (gleiche Id) d.h., wenn ich ein Widget verändere, ändert sich auch das Duplikat. Eigentlich will ich ja wirklich Kopien, die dann nach dem kopieren unabhängig voneinander sind. Ansonsten kann ich mit der Kopie ja nichts anfangen. -
@mcu
Zunächst einmal Danke.zu Punkt 1
Hab einen Issue aufgemachtzu Punkt 2 und 3
Die Größenänderung hat geklappt. Die Sache mit dem Trennstrich hat nicht den Effekt, den ich eigentlich wollte. Wenig Platz vorhanden -> Trennstrich führt zu einem Zeilenumbruch. Viel Platz vorhanden -> Trennstrich wird entfernt und das Wort zusammengeschrieben. Der Vorschlag mit white-space führt nur dazu, dass gar nicht mehr getrennt wird.zu Punkt 4
Muss ich noch ausprobieren, wie da der aktuelle Stand ist.zu Punkt 5
Hab einen feature request angelegtInzwischen ist noch eine weitere Frage aufgetaucht.
Punkt 6
Wenn ich ein Widget oder einen kompletten Tab kopiere, erhalte ich keine Kopien, sondern Duplikate (gleiche Id) d.h., wenn ich ein Widget verändere, ändert sich auch das Duplikat. Eigentlich will ich ja wirklich Kopien, die dann nach dem kopieren unabhängig voneinander sind. Ansonsten kann ich mit der Kopie ja nichts anfangen. -
@mcu sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
@sigi234 Hast du mal in den Datenpunkt-Eigenschaften
"min":"-20","max":"30"eingegeben?
Versuchs mal.

-
@sigi234 Zum Thema Bar Chart
Bin gerade nicht am PC. Ist nicht rechts bei dem ausgewählten DP ein extra Feld, wo man die Farbe wählen kann?@mcu sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
@sigi234 Zum Thema Bar Chart
Bin gerade nicht am PC. Ist nicht rechts bei dem ausgewählten DP ein extra Feld, wo man die Farbe wählen kann?Jupp, das geht. Es wird zwar auch die Legende geändert, ist aber Ok so. Danke
-
@rapunzel zu3 von oben
Ich hab es so verstanden, dass du keinen Umbruch mehr haben möchtest.
Bin etwas verwirrt. Was möchtest du genau erreichen?
Momentan ist es doch so, dass er automatisch den Umbruch macht?Darzustellender Text: Solltemperatur
Eingabe: Soll-temperatur
Wenig Platz auf dem Bildschirm:
Soll-
temperatur
Viel Platz auf dem Bildschirm:
SolltemperaturIm Moment macht er automatisch den Umbruch, d.h. für wenig Platz ist das richtig. Bei viel Platz auf dem Bildschirm stellt er den Text aber so dar: Soll-temperatur, was nicht so schön aussieht.
-
Darzustellender Text: Solltemperatur
Eingabe: Soll-temperatur
Wenig Platz auf dem Bildschirm:
Soll-
temperatur
Viel Platz auf dem Bildschirm:
SolltemperaturIm Moment macht er automatisch den Umbruch, d.h. für wenig Platz ist das richtig. Bei viel Platz auf dem Bildschirm stellt er den Text aber so dar: Soll-temperatur, was nicht so schön aussieht.
@rapunzel Wenn der Text Solltemperatur auch so dargestellt werden soll, muss er auch so eingegeben werden.
Für CSS gibt es dann nochword-wrap: break-word; oder hyphens: auto; hyphenate-limit-chars: auto 5; hyphenate-limit-lines: 2; für bestimmte Browser auch -webkit-hyphens: auto; -webkit-hyphenate-limit-chars: auto 3; -webkit-hyphenate-limit-lines: 4; -ms-hyphens: auto; -ms-hyphenate-limit-chars: auto 3; -ms-hyphenate-limit-lines: 4;Ich kenne keine CSS-Funktion, die aus Soll-temperatur dann in Abhängigkeit von der Breite die Wörter zusammensetzt:
-> Solltemperatur -
@j1s2e3 sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
LightColorBody schreibt #RGB als String wie vermutet.
LightColorBody erkennt das Input-Format und gibt das entsprechende Format auch wieder aus.
Mögliche Formate:- Hex-Wert (mit oder ohne vorangestellter #)
- Hex-Wert mit Alpha-Kanal (mit oder ohne vorangestellter #)
- Hue-Wert
- RGB
Einzelne Farb-Kanäle können nicht angesteuert werden. Hierfür ist ein Level-Slider zu nehmen, richtig.
Für die Farbgradienten kannst du gerne ein Feature Request aufmachen - ist eine gute Idee.
@zefau Danke. Ich nehme RGB (String: R,G,B). Laesst sich einfacher mit split/join und Arrays handhaben.
Bietet der LightColorBody auch einen normierten Wertebereich fuer R,G,B? So wie 0-1, oder 0-100%? Die Festlegung auf den Wertebereich eines Bytes ist ziemlich limitierend. Mein RGBW Controller z.B. bietet eine 10-Bit Genauigkeit (0-1023). Bei Dimmern nimmt man fuer den Level ja auch nicht 0-255, sondern 0-100%, und rechnet das dann auf die HW um.
Der LightColorBody supported kein W Channel, richtig? D.h. ich brauche einen extra Datenpunkt plus extra Levelslider.
Ist unpraktisch, wegen dem oben genannten split und join. Fuer W brauche ich dann extra Code.Feature Requests lege ich an.
-
@coalado sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
, ich bin PRO. Aber es geht leider nicht.
HTMLTable: Wenn htmlTags im Text sind, wird in der Zelle gar nichts angezeigt.
JSONTable: HTML Tags werden "escaped" und sind dann eben als TAGS sichtbar.Also unabhängig davon, dass du HTML Tags anzeigen willst:
- HTMLTable liest einen Datenpunkt, der eine Tabelle wie
<table> ... </table>beinhaltet und zeigt diese dann als jarvis Tabelle an (im selben Layout wie JSON-Table), z. B.mihome-vacuum.0.history.allTableHTML - JSONTable liest einen Datenpunkt mit einer JSON-Struktur und zeigt die Tabelle an (das ist ja bekannt), z. B.
mihome-vacuum.0.history.allTableHTML
Beide rendern auch HTML Inhalte. Habe es gerade ausprobiert und bei mir geht es.
Poste mal bitte deine JSON Struktur, dann probiere ich es daran aus.
@zefau said in jarvis v3.0.0 (beta) - just another remarkable vis:
Beide rendern auch HTML Inhalte. Habe es gerade ausprobiert und bei mir geht es.
Poste mal bitte deine JSON Struktur, dann probiere ich es daran aus."2f6267e8-f322-4a77-84d2-5a833ce14ed8": { "id": "2f6267e8-f322-4a77-84d2-5a833ce14ed8", "config": { "thead": "[{\"field\":\"c0\"},{\"field\":\"c1\"}]", "sortDirection": false, "rowsPerPage": 10, "max": 0, "dense": true, "hideTopBar": false }, "module": "JsonTable", "title": "JSONTable", "items": [ { "type": "device", "deviceId": "4ec10aee-b580-4e36-97d9-fd41c7f360db", "id": "6c6ec7dd-c451-4179-bbfe-7d2fc756b333", "primaryStateKey": "LogData", "bodyStateKey": "LogData", "bodyElement": "LastChangeBody" } ], "revision": "4814a" },"4ec10aee-b580-4e36-97d9-fd41c7f360db": { "id": "4ec10aee-b580-4e36-97d9-fd41c7f360db", "name": "Log", "icon": "", "label": "Log", "function": "_defaults", "states": { "LogData": { "stateKey": "LogData", "showState": true, "state": "vis.0.custom.helper.json.logs-table" } }, "options": {}, "attributes": {}, "revision": "7bf47" },
Kurze Offtopic Frage: was bedeutet das revision property?
- HTMLTable liest einen Datenpunkt, der eine Tabelle wie
-
jarvis - just another remarkable vis
Besonderes Dank an @MCU, @RkcCorian und die vielen Tester, die die alpha unermüdlich auf Bugs getestet haben.
Was ist jarvis?
jarvis ist eine Material Design Visualisierung, die - seit der Version 3.0 - auf Vue.js und dem Quasar Framework basiert. jarvis gibt eine Struktur und Module vor, die zur Visualisierung genutzt werden, aber sehr flexibel konfiguriert werden können.
jarvis ist responsive und passt sich der Größe des Screens an.
Das Layout ist flexibel konfigurierbar. Es können Seiten (seit v3) sowie Tabs verwendet werden. Jeder Tab kann entweder
fullscreensein oder beliebig viele Widgets haben. Die Widgets können (ab v3) eine beliebige Größe haben und flexibel angeordnet werden. Die Spaltenstruktur aus v2 gibt es nicht mehr.Warum jarvis?
jarvis ist weitaus weniger flexibel als ioBroker.vis, aber bietet dafür ein standardisiertes Design, um schnell eine Visualisierung zusammenzustellen. Wer besonders spezifische Anforderungen hat, sollte (weiterhin) ioBroker.vis verwendet.
v2 vs. v3: Was ist zu beachten?

Beim ersten Aufruf von v3 wird das alte Layout aus v2 in die neue v3-Struktur konvertiert. Eine Konvertierung von v3 auf v2 (Downgrade) existiert nicht! Daher unbedingt ein Backup anlegen, bevor v3 installiert wird!
Nach der Konvertierung ist es manuell notwendig, im Modul
Calendardie Passwörter neu zu setzen, damit die Kalendereinträge korrekt geladen werden.Das ModulStateListHorizontalwurde durchHomeKitTileersetzt.v2 vs. v3: Was ist neu?

Layout
- Add navigation drawer (#81)
- Flexible Layout: Allow Widgets to span accross columns (#129)
- add Jumper / Link functionality to quickly change view to a certain tab / widget (#143)
- Allow TopBar / TabBar to be placed on either top or bottom (#234)
- Dropdown Menü für Button in der TAB-Leiste (#638)
- Introduce tiles (#235)
- Add option to use icon as State indication (#264)
- Introduce different widget sizes (#277)
- Swipe to switch between tabs (#19)
- Automatischer Seitenwechsel nach x Minuten (#293)
Geräte / States
Modul Chart
- Anmerkung: Das Modul
Chart(aus v2) wurde in v3 inHistoryGraphumbenannt. Das neu eingeführte ModulChartin v3 erlaubt den Vergleich von verschiedenen Datenpunkt-Werten (keine historischen Werte mehr; hierfür ist nunHistoryGraphzu nutzen). - Vergleich von Datenpunkt-Werten mittels Bar-Chart, Pie-Chart oder Polar-Chart
- Migrate from Chart.js to Apache ECharts (#282)
- Rework / dense Chart layout (#446)
- Bar graph (#427)
- add secondary y-axis (#326)
Modul JsonTable / HtmlTable
- add new module HtmlTable (#676)
Anmerkung: Liest HTML Tabellen aus ioBroker (analog zu JSON-Strukturen beim ModulJsonTable) und stellt diese als Tabelle in jarvis dar - Improve module JsonTable (#679)
Anmerkung: Spalten umbenennen, Werte durch eigene Funktionen ändern, HTML nutzen, etc.
Modul AdapterStatus
- Allow to start / stop adapter instance
- Add Info Type from the Adapter Updates (#346)
Modul Calendar
- Custom colors for calendars (#660)
Modul iFrame
- Aktualisierung von iFrame oder Image nur wenn zugehöriger TAB aktiv ist (#458)
- Allow usage of settings parameter within URL of iFrame module (#335)
Status / Trigger
- ButtonAction als Taster (#450)
- ToogleMode for ButtonAction / IconButtonAction (#408)
- Allow icon as state status (#680)
- allow specific values for trigger action (#757)
- LevelBody: Einheit im Slider-Label berücksichtigen (#1188)
Einstellungen / Settings
- Keep jarvis open in different tab/window while editing config (#355)
- Save / apply configuration without reloading page (#311)
- add Autocompletion of state on typing in device configuration (#420)
- Settings Button im Menü ausblenden (#437)
- Security prompt when deleting an entry (#76)
- Funktiontasten (PC) zur Bearbeitung für Jarvis (#973)
Sonstiges
.
Und noch viel mehr Feature und vor allem viele, viele
Bug-Fixes!
Die vollständige Liste aller Features auf Github (bzw. inkl. Bug Fixes).@MCU hat überdies einen tabellarischen Vergleich im Wiki.
jarvis übersetzen / translate jarvis
Gibt es jemanden, der eine andere Sprache nativ als Muttersprache spricht und Lust hat, jarvis zu übersetzen?
Siehe https://github.com/Zefau/jarvis.i18n
__
Anyone who speaks another language fluently / mother tongue and likes to translate jarvis?
See https://github.com/Zefau/jarvis.i18n
v3: Unterstützung durch Pro-Account

Die v3 führt einen Pro-Account ein, mit der diverse Pro-Features genutzt werden können. Ab v3 ist jarvis damit Freemium, was bedeutet, dass jarvis grundsätzlich in vielen Belangen kostenlos ist (und bleibt), ihr aber das Projekt unterstützen könnt und dann einen gewissen erweiterten Umfang habt. Eine Auflistung von Pro-Features gibt es via Github-Issues. Außerdem gibt es eine Diskussion zum Thema Pro-Account inkl. Feature-Auflistung.
Das Abonnement kann in den jarvis Einstellungen via PayPal gekauft werden, ist jederzeit kündbar und läuft bei Kündigung bis zum bezahlten Ende fort (also mindestens 1 Jahr). Sofern es Schwierigkeiten gibt, meldet euch gerne bei mir via ioBroker.jarvis@mailbox.org.
Nach dem Kauf bitte die Lizenz in den Datenpunkt jarvis.0.info.prokopieren, sofern dies automatisch nicht geklappt haben sollte.Bitte versteht die eingeführte Möglichkeit des Abonnements nicht nur als reine Bezahlung, sondern auch als Unterstützung zur Weiterentwicklung des Adapters. Vielen Dank für euren Support!
Impressionen
Nachfolgend einige Impressionen / Beispiele:
Users
Siehe https://forum.iobroker.net/topic/37661/showcase-jarvis-just-another-remarkable-vis
YouTube
Siehe https://www.youtube.com/playlist?list=PLukgJ9IF0jR1tR2oy6VHjehCwRabnuYQS
Ausblick / Roadmap
Ihr habt Wünsche? Bitte legt ein Issue auf Github an.
Gestalte mit und stimme ab
Sofern euch Features fehlen, legt gerne ein Issue als Feature Request auf Github an.
Bitte stimmt für eure gewünschten Feature Requests ab: Nutzt dazu die Emoticon auf Github, um für eure favorisierten Feature Requests abzustimmen:

Jeder Emoticon zählt gleich. Bitte stimmt nicht für alle / zu viele Feature Requests ab, sonst gibt es am Ende keine großen Unterschiede mehr.
Die Reihenfolge nach abgegebenen Stimmen seht ihr hier: Übersicht der Feature Requests nach Stimmen
Edit
@MCUHallo, Fehler im Skript DateWeatherDWD:
17:33:18.898 info javascript.0 (10756) Stop script script.js.Jarvis.DateWeather 17:33:19.233 info javascript.0 (10756) Start javascript script.js.Jarvis.DateWeather 17:33:19.259 info javascript.0 (10756) script.js.Jarvis.DateWeather: registered 12 subscriptions and 1 schedule 17:33:23.261 info javascript.0 (10756) script.js.Jarvis.DateWeather: Warnung vorhanden 17:33:23.263 error javascript.0 (10756) at htmlSet (script.js.Jarvis.DateWeather:338:44) 17:33:23.264 error javascript.0 (10756) at Object.<anonymous> (script.js.Jarvis.DateWeather:42:9) 17:34:02.466 info javascript.0 (10756) script.js.Jarvis.DateWeather: Warnung vorhanden 17:34:02.467 error javascript.0 (10756) at htmlSet (script.js.Jarvis.DateWeather:338:44) 17:34:02.467 error javascript.0 (10756) at Object.<anonymous> (script.js.Jarvis.DateWeather:79:9) -
Edit
@MCUHallo, Fehler im Skript DateWeatherDWD:
17:33:18.898 info javascript.0 (10756) Stop script script.js.Jarvis.DateWeather 17:33:19.233 info javascript.0 (10756) Start javascript script.js.Jarvis.DateWeather 17:33:19.259 info javascript.0 (10756) script.js.Jarvis.DateWeather: registered 12 subscriptions and 1 schedule 17:33:23.261 info javascript.0 (10756) script.js.Jarvis.DateWeather: Warnung vorhanden 17:33:23.263 error javascript.0 (10756) at htmlSet (script.js.Jarvis.DateWeather:338:44) 17:33:23.264 error javascript.0 (10756) at Object.<anonymous> (script.js.Jarvis.DateWeather:42:9) 17:34:02.466 info javascript.0 (10756) script.js.Jarvis.DateWeather: Warnung vorhanden 17:34:02.467 error javascript.0 (10756) at htmlSet (script.js.Jarvis.DateWeather:338:44) 17:34:02.467 error javascript.0 (10756) at Object.<anonymous> (script.js.Jarvis.DateWeather:79:9) -
-
@sigi234 Gibt es in dem Object eine "start" und "end"-property?
Er scheint in einem "warningX"-object kein Objekt zu haben, da muss ich anscheinend doch prüfen.
Du kannst mal durchschauen, ob es dort ein object bei den warning0-10 gibt wo kein Inhalt drin ist, auch kein {}.
Er steigt dort mit einem error aus, da er es nicht parsen kann. -
@sigi234 Gibt es in dem Object eine "start" und "end"-property?
Er scheint in einem "warningX"-object kein Objekt zu haben, da muss ich anscheinend doch prüfen.
Du kannst mal durchschauen, ob es dort ein object bei den warning0-10 gibt wo kein Inhalt drin ist, auch kein {}.
Er steigt dort mit einem error aus, da er es nicht parsen kann.@mcu sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
@sigi234 Gibt es in dem Object eine "start" und "end"-property?
{"regionName":"Kreis und Stadt Passau","state":"Bayern","type":5,"level":2,"description":"Es tritt leichter Frost um -1 °C auf.","end":1639731600000,"start":1639688400000,"event":"FROST","headline":"Amtliche WARNUNG vor FROST","instruction":"","stateShort":"BY","altitudeStart":null,"altitudeEnd":null} -
@sigi234 Gibt es in dem Object eine "start" und "end"-property?
Er scheint in einem "warningX"-object kein Objekt zu haben, da muss ich anscheinend doch prüfen.
Du kannst mal durchschauen, ob es dort ein object bei den warning0-10 gibt wo kein Inhalt drin ist, auch kein {}.
Er steigt dort mit einem error aus, da er es nicht parsen kann.@mcu sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
Du kannst mal durchschauen, ob es dort ein object bei den warning0-10 gibt wo kein Inhalt drin ist, auch kein {}.

-
@mcu sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
Du kannst mal durchschauen, ob es dort ein object bei den warning0-10 gibt wo kein Inhalt drin ist, auch kein {}.

-
@sigi234 Wenn du das Script neu startest kommt der Fehler immer wieder?

Das HTML wird dann nach 4 Sekunden automatisch neu generiert.@mcu sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
sigi234 Wenn du das Script neu startest kommt der Fehler immer wieder?
Ja
-
@mcu sagte in jarvis v3.0.0 (beta) - just another remarkable vis:
sigi234 Wenn du das Script neu startest kommt der Fehler immer wieder?
Ja





