Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Tester
    4. jarvis v2.2.0 - just another remarkable vis

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    jarvis v2.2.0 - just another remarkable vis

    This topic has been deleted. Only users with topic management privileges can see it.
    • Slowman
      Slowman @uwe72 last edited by

      @uwe72

      stellst du den Script zur Verfügung 🙄

      U 1 Reply Last reply Reply Quote 0
      • Zefau
        Zefau @dabbeljuh last edited by

        @dabbeljuh sagte in jarvis v2.1.0 - just another remarkable vis:

        Mir ist eben ein kleines Problem mit dem Kalender-Widget aufgefallen. Wenn ich es im Popup-Modus betreibe, lässt sich eben jenes Popup nicht mehr schließen und nur mittels Reload der Seite beheben.

        Jo, stimmt. Fixe ich sofort.

        M 1 Reply Last reply Reply Quote 1
        • U
          uwe72 @Slowman last edited by uwe72

          @Slowman

          f4a64377-2d71-4a22-84a7-1298dcfb3bfa-image.png

          Voraussetzung:

          • Abfallkalender Adapter.
          • Die 4 Bilder habe ich auf meinem Webserver abgelegt. Ggf. kannst Du die "Original-Bilder" nehmen vom Abfallkalender. Ich weiß aber nicht wo diese liegen und wie man an diese kommt.

          Ergebnis:

          • Das HTML wird jede Minute aktualisiert und im Datenpunkt "0_userdata.0.clement.html.abfallkalender" abgespeichert
          // Variablen:
          var widthHTML = "314px";
          var typenUndTermine;
          
          // Datenpunkt:
          var htmlState = "0_userdata.0.clement.html.abfallkalender";
          createState(htmlState, "", {
              name: htmlState,
              desc: htmlState,
              type: 'string', 
              read: true,
              write: true
          });
          
          // Update
          createHTML(htmlState)
          setInterval(function() { 
              createHTML(htmlState);
          }, 1000*60*1);   
          
          
          function _getColumnName(columnIndex) {
              var rowObject = typenUndTermine[columnIndex];
              return rowObject[2];
          }
          
          function _initData() {
              var restmuell = getState("trashschedule.0.type.Restmülltonne.daysLeft").val;
              var papier = getState("trashschedule.0.type.Papiertonne.daysLeft").val;
              var bio = getState("trashschedule.0.type.Biotonne.daysLeft").val;
              var gelb = getState("trashschedule.0.type.Gelbe Tonne.daysLeft").val;
          
              typenUndTermine = [
                  [restmuell, "trashschedule.0.type.Restmülltonne", "Restmüll", "http://192.168.178.110:888/garbage_can_darkgrey.png"],
                  [papier, "trashschedule.0.type.Papiertonne", "Papier", "http://192.168.178.110:888/garbage_can_blue.png"],
                  [bio, "trashschedule.0.type.Biotonne", "Biotonne", "http://192.168.178.110:888/garbage_can_lightgrey.png"],
                  [gelb, "trashschedule.0.type.Gelbe Tonne", "Plastik", "http://192.168.178.110:888/garbage_can_yellow.png"],
                  ];
                  
              typenUndTermine.sort(function(a, b){
                  return a[0] - b[0];
              });
          }
          
          function _isCellValueHighlighted(rowIndex, columnIndex, cellValue) {
              if (columnIndex == 1) { // Spalte "Tage"
                  if (cellValue < 2 || cellValue == 'Heute' || cellValue == 'Morgen') {
                      return true;
                  }
              }
              return false;
          }
          
          function _getValueAt(rowIndex, columnIndex) {
              var rowObject = typenUndTermine[columnIndex];
              if (rowIndex == 0 ){
                  var val = "<img src=\"" + rowObject[3] + "\" width=35px>";
                  return val;
              } else {
                  var  val =  rowObject[0] + " Tage";
                  let weekday = getState(rowObject[1] + ".nextWeekday").val;
                  let weekdayAsString;
                  if (weekday == 1) {
                      weekdayAsString = "Mo, ";
                  } else if (weekday == 2) {
                      weekdayAsString = "Di, ";
                  } else if (weekday == 3) {
                      weekdayAsString = "Mi, ";
                  } else if (weekday == 4) {
                      weekdayAsString = "Do, ";
                  } else if (weekday == 5) {
                      weekdayAsString = "Fr, ";
                  } else if (weekday == 6) {
                      weekdayAsString = "Sa, ";
                  } else if (weekday == 7) {
                      weekdayAsString = "So, ";
                  }
                  val = val + "<br><font size=2  color=\"#999999\">"+ weekdayAsString + getState(rowObject[1] + ".nextDateFormat").val + "</font>";  
                  val = val.substring(0, val.lastIndexOf('.')+1);
                  return val;
              }
          }
          
          function createHTML(htmlState) {
              var html = "";
          
              html += "<html>                                             \n";
              html += "   <head>                                          \n";
              html += "       <style>                                     \n";
              html += "           table, th, td {                         \n";
              html += "               border: 1px solid #595959;          \n";
              html += "               border-collapse: collapse;          \n";
              html += "               vertical-align: middle;             \n";
              html += "           }                                       \n";
              html += "           td,th {                                 \n";
              html += "               padding: 4px;                       \n";
              html += "           }                                       \n";
              html += "       </style>                                    \n";
              html += "   </head>                                         \n";
              html += "   <body>                                          \n";
          
              html += "       <table width=" + widthHTML + ">                         \n";
          
              _initData();
          
              var alignemt = "center";
          
              // Header:
              html += "           <tr>                                    \n";
              for (var c = 0; c < 4; c++) {
                  html += "           <th colspan=\"" + 1 + "\" style=\"text-align:" + alignemt + "\"><font size=2px\">" + _getColumnName(c) + "</th></font>	\n";
              }
              html += "           </tr>                                   \n";
          
              // Body:
              for (var r = 0; r < 2; r++) {
                  html += "       <tr>                                    \n";
          
                      for (var c = 0; c < 4; c++) {
                          var cellValue = _getValueAt(r, c);
                          var highlighted = _isCellValueHighlighted(r,c,cellValue);
          
                          if (new Boolean(highlighted) == true) {
                              html += "           <td style=\" text-align:" + alignemt + "\"><font color=\"#3379D0\">" + cellValue + "</font></td>";    
                          } else {
                              html += "           <td style=\" text-align:" + alignemt + "\">" + cellValue + "</td>";    
                          }
                      }
                      
                  html += "       </tr>                                    \n";        
              }
          
              html +=          "</table>\n";
              html +=      "</body>\n";
              html +=  "</html>\n";
              setState(htmlState, html);
          }
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          
          1 Reply Last reply Reply Quote 1
          • Slowman
            Slowman last edited by

            Vielen Dank!

            1 Reply Last reply Reply Quote 1
            • B
              banza @dabbeljuh last edited by

              @stephan1827
              Hi, danke für die Beispiele, kurze Frage zu den Farben. Die Farben werden nur übernommen, wenn der Datenpunkt der primäre ist? Sobald der Datenpunkt ein sekundärer ist bleibt die Standardfarbe.


              Screenshot 2020-12-30 215312.jpg

              @dabbeljuh
              bei mir wird das Blinken nicht genommen "falsches json-format".

              stephan1827 dabbeljuh 2 Replies Last reply Reply Quote 0
              • stephan1827
                stephan1827 @banza last edited by

                @banza Ja das stimmt, es gibt dafür schon einen Feature Request. Click mal auf den Daumen hoch dann steigt das in der Priotität

                https://github.com/Zefau/ioBroker.jarvis/issues/456

                Loi83 created this issue in Zefau/ioBroker.jarvis

                closed Farbliche Sekundäre Datenpunkte #456

                1 Reply Last reply Reply Quote 0
                • stephan1827
                  stephan1827 last edited by

                  @Zefau Kann man die Kopfzeile über die Theme Einstellungen schmaler machen?Bildschirmfoto 2020-12-31 um 08.35.21.png
                  Ich würde den Abstand nach oben gerne etwas schmaler machen.

                  Das gleiche würde ich gerne bei den Widgets machen, d.h. ich würde die Zeilen gerne etwas näher zusammenrücken
                  Bildschirmfoto 2020-12-31 um 08.35.28.png

                  U dabbeljuh 2 Replies Last reply Reply Quote 0
                  • U
                    uwe72 @stephan1827 last edited by uwe72

                    @stephan1827 Erster Teil, siehe meinen Post ein bisschen höher, alternativ hier bitte voten 😉 (wenn es dir wirklich um die Höhe der Kopfzeile geht?!)
                    https://github.com/Zefau/ioBroker.jarvis/issues/124

                    Zefau created this issue in Zefau/ioBroker.jarvis

                    closed add option to hide TopBar #124

                    1 Reply Last reply Reply Quote 0
                    • dabbeljuh
                      dabbeljuh @banza last edited by dabbeljuh

                      Hallo @banza, hast du beide Schnipsel denn an die jeweils richtige Stelle kopiert? Wie gesagt, die Definition für "blink" muss in den Bereich "Styles" in den Einstellungen.

                      1e8f76ae-f671-43ac-8013-78563199a033-grafik.png

                      Und so sieht das JSON im Icon aus:
                      a41af848-2c98-45d8-8b60-a6e898de1a64-grafik.png

                      stephan1827 B 2 Replies Last reply Reply Quote 1
                      • dabbeljuh
                        dabbeljuh @stephan1827 last edited by

                        @stephan1827 für den Übergang könntest du es hiermit versuchen, gehört in den Bereich "Styles". Damit wird die Kopfzeile etwas weniger hoch und die Icons rücken näher zusammen.

                        .MuiToolbar-regular {
                        min-height: 0 !important;
                        }

                        .MuiToolbar-regular button {
                        padding: 4px 12px 0 12px;
                        }

                        .MuiTab-root {
                        min-width: 120px;
                        min-height: 0 !important;
                        }

                        stephan1827 1 Reply Last reply Reply Quote 1
                        • M
                          MCU @Zefau last edited by MCU

                          @Zefau Vielleicht eine Kleinigkeit noch zu den sekundären Datenpunkten:

                          667d2c7a-dfa4-43a3-a72d-8d5edb6b2196-image.png
                          6b0a01ba-f25a-48d8-bd70-74d8e6668006-image.png
                          Ist es möglich, die Kommas, die die Werte trennen wegzulassen, falls der jeweilige folgende Wert leer ist, oder auch der Wert vor dem Komma?
                          3b7a0b14-0cbe-4294-9dd1-34cde75501f2-image.png

                          Zefau 1 Reply Last reply Reply Quote 0
                          • Zefau
                            Zefau @MCU last edited by

                            @MCU sagte in jarvis v2.1.0 - just another remarkable vis:

                            Ist es möglich, die Kommas, die die Werte trennen wegzulassen, falls der jeweilige folgende Wert leer ist, oder auch der Wert vor dem Komma?

                            Ja, das ergibt Sinn. Kann ich gemeinsam mit https://github.com/Zefau/ioBroker.jarvis/issues/456 umsetzen.

                            Loi83 created this issue in Zefau/ioBroker.jarvis

                            closed Farbliche Sekundäre Datenpunkte #456

                            DNC74 1 Reply Last reply Reply Quote 1
                            • stephan1827
                              stephan1827 @dabbeljuh last edited by

                              @dabbeljuh besten Dank, das ist schon etwas besser

                              1 Reply Last reply Reply Quote 0
                              • DNC74
                                DNC74 @Zefau last edited by

                                @Zefau Hi Zefau, wenn Du schon dabei bist, noch was "kleinliches" 😉 : die Farbe des Kommas sollte der Farbe der sekundären Datenpunkte entsprechen. Momentan sind die zu dunkel

                                1 Reply Last reply Reply Quote 0
                                • stephan1827
                                  stephan1827 @dabbeljuh last edited by

                                  @dabbeljuh habe ich gerade mal probiert, das pulsieren sieht echt super aus

                                  dabbeljuh Zefau 2 Replies Last reply Reply Quote 0
                                  • dabbeljuh
                                    dabbeljuh @stephan1827 last edited by

                                    @stephan1827 freut mich, dass ich helfen konnte. 🙂 Ich empfinde es als praktisch, gleich auf den ersten Blick zu sehen, ob es etwas zu beachten gibt (Temperatur, Luftfeuchtigkeit, neue Post im Briefkasten, Mülltonne muss raus ...)

                                    1 Reply Last reply Reply Quote 0
                                    • O
                                      OlliP81 last edited by

                                      Guten Tag zusammen,

                                      besteht aktuell eg. die Möglichkeit die Geräte unter der Struktur "linkeddevices.0" automatisch zu importieren?

                                      Falls nein, würde ich das sehr praktisch finden für zukünftige Versionen 😉

                                      Vielen Dank und viele Grüße

                                      Olli

                                      Zefau 1 Reply Last reply Reply Quote 0
                                      • Zefau
                                        Zefau @OlliP81 last edited by

                                        @OlliP81 sagte in jarvis v2.1.0 - just another remarkable vis:

                                        besteht aktuell eg. die Möglichkeit die Geräte unter der Struktur "linkeddevices.0" automatisch zu importieren?

                                        ist für v2.2 geplant (https://github.com/Zefau/ioBroker.jarvis/issues/467)

                                        Zefau created this issue in Zefau/ioBroker.jarvis

                                        closed Support import of devices from ioBroker.linkeddevices #467

                                        O 1 Reply Last reply Reply Quote 0
                                        • Zefau
                                          Zefau @stephan1827 last edited by

                                          @stephan1827 sagte in jarvis v2.1.0 - just another remarkable vis:

                                          habe ich gerade mal probiert, das pulsieren sieht echt super aus

                                          zeig mal 🙂

                                          1 Reply Last reply Reply Quote 0
                                          • O
                                            OlliP81 @Zefau last edited by

                                            @Zefau Supi, vielen Dank!

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            829
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            jarvis material material ui materialdesign vis visualisierung visualization
                                            316
                                            6126
                                            3411462
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo