Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. Tester
  4. Test Adapter PoolControl

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    459

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    10
    1
    380

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    972

Test Adapter PoolControl

Geplant Angeheftet Gesperrt Verschoben Tester
testerpoolpoolcontrolsolar
397 Beiträge 14 Kommentatoren 23.8k Aufrufe 14 Beobachtet
  • Ä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.
  • DasBo1975D Offline
    DasBo1975D Offline
    DasBo1975
    Developer
    schrieb am zuletzt editiert von
    #379

    Hi zusammen,

    ich habe heute noch eine neue Version nachgeschoben: v1.3.6

    Sorry dafür, dass schon wieder so schnell ein Update kommt, aber mir ist ein unschönes Verhalten im Frostschutz aufgefallen, das ich nicht so stehen lassen wollte.

    Solche Dinge zeigen sich leider oft erst im echten Alltag im Produktivsystem und nicht im Testsystem – genau so war es auch hier.

    🔧 Fix in 1.3.6

    Der frostHelper konnte in bestimmten Situationen die Pumpe fälschlicherweise ausschalten, obwohl sie gerade von einem anderen Helper (z. B. PV) bewusst eingeschaltet wurde.

    Das ist jetzt behoben.

    👉 Der Frostschutz arbeitet nun sauber nach folgendem Prinzip:

    • Bei Frost: Pumpe wird wie gewohnt erzwungen eingeschaltet
    • Wenn kein Frost mehr vorliegt:
      → die Pumpe wird nur dann wieder ausgeschaltet, wenn der frostHelper sie zuvor selbst aktiviert hat
      → andere Helper (z. B. photovoltaicHelper) bleiben unangetastet

    Zusätzlich:

    • interne Logik zur Zustandszuordnung verbessert
    • Sprach-Status für Frostschutz korrigiert
    • Timer im frostHelper auf ioBroker-konforme Variante umgestellt (stabiler)

    Wie immer gilt:
    Wenn euch noch etwas auffällt oder ihr Feedback habt – gerne her damit 🙂

    Viele Grüße
    Dirk

    • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

    • Einfach macht aus einem Problem keine Lösung

    • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

    1 Antwort Letzte Antwort
    0
    • D Online
      D Online
      DennisMenger
      schrieb am zuletzt editiert von DennisMenger
      #380

      Moin. Ab wann sollte sich der Datenpunkt current-entry und die anderen Datenpunkte im Ordner logbook ändern? Mein Solar lief heute, aber keine Änderung im Datenpunkt. Oder habe ich was übersehen einzustellen?

      DasBo1975D 1 Antwort Letzte Antwort
      0
      • D DennisMenger

        Moin. Ab wann sollte sich der Datenpunkt current-entry und die anderen Datenpunkte im Ordner logbook ändern? Mein Solar lief heute, aber keine Änderung im Datenpunkt. Oder habe ich was übersehen einzustellen?

        DasBo1975D Offline
        DasBo1975D Offline
        DasBo1975
        Developer
        schrieb am zuletzt editiert von
        #381

        @DennisMenger sagte:

        Moin. Ab wann sollte sich der Datenpunkt current-entry und die anderen Datenpunkte im Ordner logbook ändern? Mein Solar lief heute, aber keine Änderung im Datenpunkt. Oder habe ich was übersehen einzustellen?

        Moin 🙂

        der current_entry im Logbook ist kein Live-Wert, der sich sofort ändert, sobald Solar läuft.
        Der Eintrag wird nur dann neu geschrieben, wenn sich der erzeugte Text wirklich ändert.

        Heißt konkret:
        Nur weil Solar heute gelaufen ist, muss sich der Wert nicht automatisch ändern – z. B. wenn die Bewertung am Ende gleich bleibt („kein nennenswerter Ertrag“ etc.).

        Was wir aber einmal prüfen sollten:

        Schau bitte kurz auf diese States:

        • solar.active
        • solar.extended.active
        • analytics.insights.solar.results.solar_ran_today

        Wenn Solar bei dir wirklich lief, müsste solar_ran_today irgendwann auf true gehen.
        Wenn das nicht passiert, dann schauen wir uns das nochmal genauer an – dann könnte da tatsächlich noch was nicht sauber greifen 👍

        Wenn du magst, kannst du mir die Werte mal schicken, dann gehe ich da tiefer rein

        • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

        • Einfach macht aus einem Problem keine Lösung

        • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

        D 1 Antwort Letzte Antwort
        0
        • DasBo1975D DasBo1975

          @DennisMenger sagte:

          Moin. Ab wann sollte sich der Datenpunkt current-entry und die anderen Datenpunkte im Ordner logbook ändern? Mein Solar lief heute, aber keine Änderung im Datenpunkt. Oder habe ich was übersehen einzustellen?

          Moin 🙂

          der current_entry im Logbook ist kein Live-Wert, der sich sofort ändert, sobald Solar läuft.
          Der Eintrag wird nur dann neu geschrieben, wenn sich der erzeugte Text wirklich ändert.

          Heißt konkret:
          Nur weil Solar heute gelaufen ist, muss sich der Wert nicht automatisch ändern – z. B. wenn die Bewertung am Ende gleich bleibt („kein nennenswerter Ertrag“ etc.).

          Was wir aber einmal prüfen sollten:

          Schau bitte kurz auf diese States:

          • solar.active
          • solar.extended.active
          • analytics.insights.solar.results.solar_ran_today

          Wenn Solar bei dir wirklich lief, müsste solar_ran_today irgendwann auf true gehen.
          Wenn das nicht passiert, dann schauen wir uns das nochmal genauer an – dann könnte da tatsächlich noch was nicht sauber greifen 👍

          Wenn du magst, kannst du mir die Werte mal schicken, dann gehe ich da tiefer rein

          D Online
          D Online
          DennisMenger
          schrieb am zuletzt editiert von DennisMenger
          #382
          • solar.active
          • solar.extended.active
          • analytics.insights.solar.results.solar_ran_today

          solar.active = habe ich nicht (oder meintest du solar-control-active, der ist true
          solar.extended.active = jetzt false (seit 17:05 Uhr) war heute definitiv auch auf true
          analytics.insights.solar.results.solar_ran_today = false

          Solar wurde auch definitiv in den letzten beiden Tagen jeweils eingeschaltet durch den Adapter.

          DasBo1975D 1 Antwort Letzte Antwort
          0
          • D DennisMenger
            • solar.active
            • solar.extended.active
            • analytics.insights.solar.results.solar_ran_today

            solar.active = habe ich nicht (oder meintest du solar-control-active, der ist true
            solar.extended.active = jetzt false (seit 17:05 Uhr) war heute definitiv auch auf true
            analytics.insights.solar.results.solar_ran_today = false

            Solar wurde auch definitiv in den letzten beiden Tagen jeweils eingeschaltet durch den Adapter.

            DasBo1975D Offline
            DasBo1975D Offline
            DasBo1975
            Developer
            schrieb am zuletzt editiert von
            #383

            @DennisMenger sagte:

            • solar.active
            • solar.extended.active
            • analytics.insights.solar.results.solar_ran_today

            solar.active = habe ich nicht (oder meintest du solar-control-active, der ist true
            solar.extended.active = jetzt false (seit 17:05 Uhr) war heute definitiv auch auf true
            analytics.insights.solar.results.solar_ran_today = false

            Solar wurde auch definitiv in den letzten beiden Tagen jeweils eingeschaltet durch den Adapter.

            entschuldige, ich meinte sorar.request_active

            aber ich bin dran, das gerade zu überprüfen

            • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

            • Einfach macht aus einem Problem keine Lösung

            • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

            1 Antwort Letzte Antwort
            0
            • DasBo1975D Offline
              DasBo1975D Offline
              DasBo1975
              Developer
              schrieb am zuletzt editiert von
              #384

              Moin zusammen 🙂

              ich habe heute die Version 1.3.7 nachgeschoben, nachdem mich ein Hinweis von Dennis auf einen Fehler in den Solar Insights aufmerksam gemacht hat.

              Bei der Auswertung wurde für Standard-Solar ein falscher Datenpunkt verwendet, wodurch es in bestimmten Konstellationen passieren konnte, dass „Solar lief heute“ nicht korrekt erkannt wurde.

              Das habe ich jetzt korrigiert, so dass sowohl normales Solar als auch Solar Extended sauber berücksichtigt werden.

              Zusätzlich habe ich noch eine kleine Verbesserung im photovoltaicHelper mit reingenommen (Rundung im Status-Text + Timer-Umstellung).

              Sorry für die erneute Version in kurzer Zeit, aber das wollte ich sauber geradeziehen 👍

              • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

              • Einfach macht aus einem Problem keine Lösung

              • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

              1 Antwort Letzte Antwort
              0
              • D Online
                D Online
                DennisMenger
                schrieb am zuletzt editiert von
                #385

                Super, vielen Dank für die schnelle Reaktion. Ich werde berichten.

                1 Antwort Letzte Antwort
                1
                • H Offline
                  H Offline
                  homecineplexx
                  schrieb am zuletzt editiert von
                  #386

                  Nachdem ich nächstes Wochenende auch erstmals unseren Pool in Betrieb nehmen werde, werd ich diesen Adapter ausprobieren. Mal schauen wie der mit meinen Geräten zusammenspielen kann/wird.

                  DasBo1975D 1 Antwort Letzte Antwort
                  0
                  • H homecineplexx

                    Nachdem ich nächstes Wochenende auch erstmals unseren Pool in Betrieb nehmen werde, werd ich diesen Adapter ausprobieren. Mal schauen wie der mit meinen Geräten zusammenspielen kann/wird.

                    DasBo1975D Offline
                    DasBo1975D Offline
                    DasBo1975
                    Developer
                    schrieb am zuletzt editiert von
                    #387

                    @homecineplexx sagte:

                    Nachdem ich nächstes Wochenende auch erstmals unseren Pool in Betrieb nehmen werde, werd ich diesen Adapter ausprobieren. Mal schauen wie der mit meinen Geräten zusammenspielen kann/wird.

                    Freut mich zu hören, dass du den Adapter testen möchtest 🙂
                    Wenn dir etwas auffällt oder du Fragen hast, immer gerne her damit.

                    Gib gerne auch kurz Rückmeldung, wie gut er mit deinen Geräten zusammenspielt – das hilft mir enorm bei der Weiterentwicklung.

                    • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

                    • Einfach macht aus einem Problem keine Lösung

                    • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

                    1 Antwort Letzte Antwort
                    1
                    • D Online
                      D Online
                      DennisMenger
                      schrieb am zuletzt editiert von
                      #388

                      Habe heute morgen gleich die neue Version installiert. Solar ist heute auch wieder definitiv gelaufen. Datenpunkt solar-ran-today steht auf true, Datenpunkt active-minutes-today steht aber weiter auf 0. Letzter Zeitstempel vom 20.04.2026.

                      DasBo1975D 1 Antwort Letzte Antwort
                      0
                      • D DennisMenger

                        Habe heute morgen gleich die neue Version installiert. Solar ist heute auch wieder definitiv gelaufen. Datenpunkt solar-ran-today steht auf true, Datenpunkt active-minutes-today steht aber weiter auf 0. Letzter Zeitstempel vom 20.04.2026.

                        DasBo1975D Offline
                        DasBo1975D Offline
                        DasBo1975
                        Developer
                        schrieb am zuletzt editiert von
                        #389

                        @DennisMenger sagte:

                        Habe heute morgen gleich die neue Version installiert. Solar ist heute auch wieder definitiv gelaufen. Datenpunkt solar-ran-today steht auf true, Datenpunkt active-minutes-today steht aber weiter auf 0. Letzter Zeitstempel vom 20.04.2026.

                        Moin. Ich danke dir für die Info. Ich kann das bei mir leider nicht nachvollziehen. Bei mir wird der Datenpunkt gefüllt. Ich werde das morgen spätestens am Wochenende noch mal genauer unter die Lupe nehmen. Vielleicht kannst du mir einmal Screenshots von allen Daten punkten schicken aus dem Solar Inside Bereich.

                        • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

                        • Einfach macht aus einem Problem keine Lösung

                        • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

                        1 Antwort Letzte Antwort
                        0
                        • D Online
                          D Online
                          DennisMenger
                          schrieb am zuletzt editiert von
                          #390

                          Guten Morgen. Na klar schicke ich mal die Screenshots.

                          Results results.png
                          Logbooklogbook.png
                          Inputs inputs.png
                          Calculation calculation.png
                          Debug debug.png

                          DasBo1975D 1 Antwort Letzte Antwort
                          0
                          • D DennisMenger

                            Guten Morgen. Na klar schicke ich mal die Screenshots.

                            Results results.png
                            Logbooklogbook.png
                            Inputs inputs.png
                            Calculation calculation.png
                            Debug debug.png

                            DasBo1975D Offline
                            DasBo1975D Offline
                            DasBo1975
                            Developer
                            schrieb am zuletzt editiert von
                            #391

                            @DennisMenger sagte:

                            Guten Morgen. Na klar schicke ich mal die Screenshots.

                            Hallo Dennis,

                            vielen Dank nochmal für deine Hinweise und dein genaues Hinschauen – das hilft mir wirklich enorm weiter 👍

                            Ich habe mir das Ganze inzwischen nochmal genauer angesehen und dabei aktuell zwei Fehler identifiziert. Die werde ich heute Abend bzw. spätestens morgen sauber beheben und dann mit einer neuen Version veröffentlichen.

                            Bis dahin bitte ich noch um ein wenig Geduld.

                            Danke dir nochmal für deine Unterstützung und dein Feedback!

                            Viele Grüße
                            Dirk

                            • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

                            • Einfach macht aus einem Problem keine Lösung

                            • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

                            1 Antwort Letzte Antwort
                            0
                            • DasBo1975D Offline
                              DasBo1975D Offline
                              DasBo1975
                              Developer
                              schrieb am zuletzt editiert von
                              #392

                              ich habe heute die Version 1.3.9 nachgeschoben.

                              Dabei habe ich mehrere Fehler im Solar-Logbook und im Solar-Insights-Bereich behoben. Unter anderem wurden teilweise Logeinträge gar nicht erstellt bzw. doppelt geschrieben, außerdem gab es Probleme bei Zeitstempeln und der Tagesauswertung (z. B. solar_ran_today und active_minutes_today). Diese Punkte sollten jetzt wieder sauber und nachvollziehbar funktionieren.

                              Zusätzlich habe ich die Stabilität des Loggings verbessert und die Verarbeitung der Wettertexte optimiert.

                              Vielen Dank an Dennis für die hilfreichen Hinweise und das genaue Mitprüfen 👍

                              • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

                              • Einfach macht aus einem Problem keine Lösung

                              • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

                              1 Antwort Letzte Antwort
                              0
                              • DasBo1975D Offline
                                DasBo1975D Offline
                                DasBo1975
                                Developer
                                schrieb am zuletzt editiert von
                                #393

                                Moin ihr alle,

                                ich habe mir heute mal die Zeit genommen, ein bisschen mit den Daten aus den Datenpunkten der Solarauswertung zu spielen und habe mir daraus eine kleine Solar-COP-Auswertung in VIS mit einem HTML-Widget gebastelt.

                                Ich wollte euch einfach mal daran teilhaben lassen, wie sowas aussehen kann 🙂

                                Die Daten kommen komplett aus den vorhandenen States (z. B. Laufzeit, geschätzter Solarertrag, Leistung, Temperaturen usw.), daraus habe ich mir eine kompakte Übersicht gebaut mit:

                                • Tagesstatus (ob Solar überhaupt aktiv war)
                                • Laufzeit in Minuten
                                • Solarertrag und Spitzenleistung
                                • COP-/Effizienz-Bewertung als kleines Sternesystem
                                • und einem Logbuch mit den Tagesereignissen

                                Das Ganze läuft rein über ein HTML-Widget und wertet die JSON- bzw. Text-Datenpunkte aus, die der Adapter sowieso schon liefert.

                                Die Kombination aus:

                                • kompakter Zusammenfassung oben
                                • farblicher Bewertung
                                • und Logbuch darunter

                                macht es für mich deutlich übersichtlicher als einzelne States durchzuklicken.

                                Aktuell ist bei mir noch nicht viel zu sehen, weil:

                                • es mitten in der Nacht ist 😄
                                • und die Solarerträge momentan wegen dem Wetter eh ziemlich mau sind

                                Falls jemand Interesse an dem HTML-Code für das Widget hat, einfach kurz Bescheid sagen – ich kann das gerne teilen.

                                Feedback oder Ideen sind natürlich auch willkommen!

                                Solar COP.png

                                • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

                                • Einfach macht aus einem Problem keine Lösung

                                • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

                                1 Antwort Letzte Antwort
                                0
                                • D Online
                                  D Online
                                  DennisMenger
                                  schrieb am zuletzt editiert von
                                  #394

                                  Ich hätte da grundsätzlich Interesse dran. Das wäre klasse, wenn du das teilen würdest.

                                  PS: Solarauswertung scheint jetzt auch bei mir zu funktionieren.

                                  DasBo1975D 1 Antwort Letzte Antwort
                                  0
                                  • D DennisMenger

                                    Ich hätte da grundsätzlich Interesse dran. Das wäre klasse, wenn du das teilen würdest.

                                    PS: Solarauswertung scheint jetzt auch bei mir zu funktionieren.

                                    DasBo1975D Offline
                                    DasBo1975D Offline
                                    DasBo1975
                                    Developer
                                    schrieb am zuletzt editiert von
                                    #395

                                    @DennisMenger

                                    Freut mich zu hören, dass die Solarauswertung bei dir jetzt funktioniert. Den HTML Code für das Widget schicke ich in den nächsten Tagen.

                                    • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

                                    • Einfach macht aus einem Problem keine Lösung

                                    • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

                                    1 Antwort Letzte Antwort
                                    0
                                    • DasBo1975D Offline
                                      DasBo1975D Offline
                                      DasBo1975
                                      Developer
                                      schrieb am zuletzt editiert von
                                      #396

                                      @dennismenger

                                      Hier mal der html Code für das html widget.

                                      <div style="width:100%;height:100%;box-sizing:border-box;font-family:Arial,sans-serif;color:white;overflow:hidden;">
                                      
                                        <div id="solarCopHeaderV5" style="
                                          width:100%;
                                          box-sizing:border-box;
                                          padding:7px 10px;
                                          margin-bottom:7px;
                                          background:rgba(5,20,32,.94);
                                          border:1px solid rgba(0,216,255,.45);
                                          border-radius:8px;
                                          color:#00d8ff;
                                          font-weight:bold;
                                          font-size:15px;
                                          letter-spacing:.3px;
                                        ">
                                          Solar COP Auswertung
                                          <div id="solarCopStatsV5" style="
                                            margin-top:5px;
                                            color:#ffffff;
                                            font-weight:normal;
                                            font-size:10px;
                                            line-height:1.35;
                                          ">lade Tageswerte...</div>
                                        </div>
                                      
                                        <div id="solarLogbookV5" style="
                                          width:100%;
                                          height:calc(100% - 76px);
                                          overflow-y:auto;
                                          padding:0 4px 8px 4px;
                                          box-sizing:border-box;
                                        ">
                                          lade...
                                        </div>
                                      
                                      </div>
                                      
                                      <script>
                                      (function () {
                                        var baseLog = "poolcontrol.0.analytics.insights.solar.logbook";
                                        var dpText = baseLog + ".day_log_text";
                                        var baseResults = "poolcontrol.0.analytics.insights.solar.results";
                                      
                                        var targetId = "solarLogbookV5";
                                        var statsId = "solarCopStatsV5";
                                      
                                        function esc(t) {
                                          t = String(t || "");
                                          t = t.replace(/&/g, "&amp;");
                                          t = t.replace(/</g, "&lt;");
                                          t = t.replace(/>/g, "&gt;");
                                          return t;
                                        }
                                      
                                        function val(states, id, fallback) {
                                          if (states && states[id] && states[id].val !== undefined && states[id].val !== null && states[id].val !== "") {
                                            return states[id].val;
                                          }
                                          return fallback;
                                        }
                                      
                                        function cleanNumber(v, fallback) {
                                          if (v === null || v === undefined) return fallback;
                                      
                                          v = String(v).trim();
                                      
                                          if (v === "" || v === "(null)" || v === "null" || v === "undefined" || v === "$null") {
                                            return fallback;
                                          }
                                      
                                          v = v.replace(",", ".").replace(/[^\d.-]/g, "");
                                          var n = parseFloat(v);
                                      
                                          if (isNaN(n)) return fallback;
                                          return n;
                                        }
                                      
                                        function formatNumber(n, d) {
                                          n = cleanNumber(n, 0);
                                          return n.toFixed(d).replace(".", ",");
                                        }
                                      
                                        function getDeltaColor(delta) {
                                          if (delta === null) return "#9fb3c8";
                                          if (delta < 0) return "#ff5c5c";
                                          if (delta <= 1.5) return "#ffb13b";
                                          return "#00ff88";
                                        }
                                      
                                        function getColor(text) {
                                          if (text.indexOf("nicht gelaufen") !== -1 || text.indexOf("kein sinnvoller") !== -1) return "#ffb13b";
                                          if (text.indexOf("Fehler") !== -1 || text.indexOf("Warnung") !== -1) return "#ff5c5c";
                                          if (text.indexOf("OK") !== -1 || text.indexOf("gut") !== -1 || text.indexOf("gelaufen") !== -1) return "#00ff88";
                                          return "#00d8ff";
                                        }
                                      
                                        function calcCopScore(min, cop) {
                                          if (min <= 0 || cop === null || cop <= 0) return 0;
                                          if (cop < 2) return 1;
                                          if (cop < 4) return 2;
                                          if (cop < 6) return 3;
                                          if (cop < 8) return 4;
                                          return 5;
                                        }
                                      
                                        function stars(score) {
                                          var s = "";
                                          var i;
                                          var activeColor = score >= 4 ? "#00ff88" : "#ffb13b";
                                      
                                          for (i = 1; i <= 5; i++) {
                                            if (i <= score) {
                                              s += "<span style='color:" + activeColor + ";'>★</span>";
                                            } else {
                                              s += "<span style='color:#555;'>☆</span>";
                                            }
                                          }
                                      
                                          return s;
                                        }
                                      
                                        function renderStats(states) {
                                          var el = document.getElementById(statsId);
                                          if (!el) return;
                                      
                                          var min = cleanNumber(val(states, baseResults + ".active_minutes_today", 0), 0);
                                          var kwh = cleanNumber(val(states, baseResults + ".estimated_gain_today_kwh", 0), 0);
                                          var peak = cleanNumber(val(states, baseResults + ".peak_power_today_w", 0), 0);
                                          var copRaw = cleanNumber(val(states, baseResults + ".estimated_efficiency_ratio", null), null);
                                      
                                          var ran = val(states, baseResults + ".solar_ran_today", false);
                                          var effective = val(states, baseResults + ".solar_effective_now", false);
                                          var state = val(states, baseResults + ".solar_gain_state", "no_data");
                                      
                                          var collector = cleanNumber(val(states, baseResults + ".collector_temp_used", "-"), null);
                                          var delta = cleanNumber(val(states, baseResults + ".delta_t_used", "-"), null);
                                          var deltaColor = getDeltaColor(delta);
                                      
                                          var cop = null;
                                          var copText = "-";
                                          var copColor = "#9fb3c8";
                                      
                                          if (min > 0 && copRaw !== null && copRaw > 0) {
                                            cop = copRaw;
                                            copText = formatNumber(cop, 2);
                                            copColor = cop >= 6 ? "#00ff88" : (cop >= 2 ? "#ffb13b" : "#ff5c5c");
                                          }
                                      
                                          var statusText = "Heute: keine Aktivität";
                                          var statusColor = "#ffb13b";
                                      
                                          if (ran === true || ran === "true" || min > 0) {
                                            statusText = "Heute: Solar war aktiv";
                                            statusColor = "#00ff88";
                                          }
                                      
                                          if (effective === true || effective === "true") {
                                            statusText = "Solar aktuell wirksam";
                                            statusColor = "#00ff88";
                                          }
                                      
                                          var kwhColor = kwh > 0 ? "#00ff88" : "#ffb13b";
                                          var score = calcCopScore(min, cop);
                                          var scoreColor = score >= 4 ? "#00ff88" : (score >= 2 ? "#ffb13b" : "#9fb3c8");
                                      
                                          el.innerHTML =
                                            "<span style='color:" + statusColor + ";font-weight:bold;'>" + esc(statusText) + "</span>"
                                            + " &nbsp; | &nbsp; COP: <b style='color:" + copColor + ";'>" + esc(copText) + "</b>"
                                            + " &nbsp; | &nbsp; COP-Score: <b style='color:" + scoreColor + ";letter-spacing:1px;'>"
                                            + stars(score) + " (" + score + "/5)</b>"
                                            + " &nbsp; | &nbsp; Laufzeit: <b>" + esc(formatNumber(min, 0)) + " min</b>"
                                            + " &nbsp; | &nbsp; Solarertrag: <b style='color:" + kwhColor + ";'>" + esc(formatNumber(kwh, 2)) + " kWh</b>"
                                            + " &nbsp; | &nbsp; Solarspitze: <b>" + esc(formatNumber(peak, 0)) + " W</b>"
                                            + "<br>"
                                            + "Status: <b>" + esc(state) + "</b>"
                                            + " &nbsp; | &nbsp; Kollektor: <b>" + esc(collector === null ? "-" : formatNumber(collector, 1)) + " °C</b>"
                                            + " &nbsp; | &nbsp; ΔT: <b style='color:" + deltaColor + ";'>" + esc(delta === null ? "-" : formatNumber(delta, 1)) + " K</b>";
                                        }
                                      
                                        function renderLog(raw) {
                                          var box = document.getElementById(targetId);
                                          if (!box) return;
                                      
                                          if (!raw || raw === "undefined" || raw === "null" || raw === "$null") {
                                            box.innerHTML = "<div style='color:#ffb13b;padding:10px;font-size:10px;'>Keine Logbuchdaten vorhanden.</div>";
                                            return;
                                          }
                                      
                                          var lines = String(raw).split(/\r?\n/).reverse();
                                          var html = "";
                                          var i;
                                      
                                          for (i = 0; i < lines.length; i++) {
                                            var line = lines[i].trim();
                                            if (!line) continue;
                                      
                                            var m = line.match(/^([0-9]{2}:[0-9]{2})\s*-\s*(.*)$/);
                                            var time = "";
                                            var text = line;
                                      
                                            if (m) {
                                              time = m[1];
                                              text = m[2];
                                            }
                                      
                                            var firstSentence = text.split(". ")[0] || text;
                                            if (firstSentence.length > 120) {
                                              firstSentence = firstSentence.substring(0, 120) + "...";
                                            }
                                      
                                            var color = getColor(text);
                                            var bg = "rgba(0,30,50,.65)";
                                            var border = "rgba(0,170,255,.35)";
                                      
                                            if (i < 3) {
                                              bg = "rgba(0,50,80,.82)";
                                              border = color;
                                            }
                                      
                                            html += ""
                                              + "<div style='display:grid;grid-template-columns:54px 1fr;gap:8px;border:1px solid " + border + ";border-radius:8px;padding:6px 8px;margin-bottom:7px;background:" + bg + ";box-shadow:0 0 8px rgba(0,0,0,.35);'>"
                                              +   "<div style='color:" + color + ";font-weight:bold;font-size:10px;white-space:nowrap;'>" + esc(time) + "</div>"
                                              +   "<div style='color:#ffffff;font-size:10px;line-height:1.28;'>"
                                              +     "<div style='font-weight:bold;color:#ffffff;margin-bottom:2px;'>" + esc(firstSentence) + "</div>"
                                              +     "<div style='opacity:.72;'>" + esc(text) + "</div>"
                                              +   "</div>"
                                              + "</div>";
                                          }
                                      
                                          box.innerHTML = html;
                                        }
                                      
                                        function refresh() {
                                          vis.conn.getStates(baseLog + ".*", function (errLog, logStates) {
                                            var raw = "";
                                      
                                            if (!errLog && logStates && logStates[dpText]) {
                                              raw = logStates[dpText].val;
                                            }
                                      
                                            renderLog(raw);
                                          });
                                      
                                          vis.conn.getStates(baseResults + ".*", function (errRes, resultStates) {
                                            renderStats(resultStates || {});
                                          });
                                        }
                                      
                                        function startWhenReady() {
                                          if (typeof vis !== "undefined" && vis.conn && vis.conn.getStates) {
                                            refresh();
                                            setInterval(refresh, 60000);
                                          } else {
                                            setTimeout(startWhenReady, 500);
                                          }
                                        }
                                      
                                        startWhenReady();
                                      })();
                                      </script>
                                      
                                      • Entwickler des Adapters PoolControl / BertinSoft-Sprachassistent

                                      • Einfach macht aus einem Problem keine Lösung

                                      • universelle Gerätedatenstruktur mit kontextueller Funktionszuordnung. Oder einfach gesagt: Jedes Gerät spricht dieselbe Sprache - nur nicht jedes sagt alles!

                                      1 Antwort Letzte Antwort
                                      0
                                      • D Online
                                        D Online
                                        DennisMenger
                                        schrieb am zuletzt editiert von
                                        #397

                                        Vielen Dank, werde ich testen

                                        1 Antwort Letzte Antwort
                                        0

                                        Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

                                        Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

                                        Mit deinem Input könnte dieser Beitrag noch besser werden 💗

                                        Registrieren Anmelden
                                        Antworten
                                        • In einem neuen Thema antworten
                                        Anmelden zum Antworten
                                        • Älteste zuerst
                                        • Neuste zuerst
                                        • Meiste Stimmen


                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        516

                                        Online

                                        32.8k

                                        Benutzer

                                        82.8k

                                        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