Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. mein aktuelles VISv7

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    mein aktuelles VISv7

    This topic has been deleted. Only users with topic management privileges can see it.
    • H
      hofmannha @Glasfaser last edited by

      @Glasfaser
      Richtig, der fehlt. Aber ich habe nur das Projekt importiert und die Datenpunkte angelegt.

      Glasfaser 1 Reply Last reply Reply Quote 0
      • Glasfaser
        Glasfaser @hofmannha last edited by Glasfaser

        @hofmannha sagte in mein aktuelles VISv7:

        @Glasfaser
        Richtig, der fehlt.

        Startest du mit dieser Seite

        a_menue in den Runtime !???

        H 1 Reply Last reply Reply Quote 0
        • H
          hofmannha @Glasfaser last edited by

          @Glasfaser
          Nein, mit a_start

          Glasfaser 1 Reply Last reply Reply Quote 0
          • Glasfaser
            Glasfaser @hofmannha last edited by

            @hofmannha

            Nein das ist falsch ,
            sonst bekommst du kein Viewwechsel mit dem Menue, wie du es haben willst !!

            die Startseite ist a_menue dann inkl. Viewwechsel !!

            H 1 Reply Last reply Reply Quote 0
            • H
              hofmannha @Glasfaser last edited by

              @Glasfaser
              Suuuper! Das war’s. Aber dann ist der Name auch etwas unglücklich gewählt. Danke für deine Mühe und noch einen schönen Sonntag

              Glasfaser 1 Reply Last reply Reply Quote 0
              • Glasfaser
                Glasfaser @hofmannha last edited by Glasfaser

                @hofmannha sagte in mein aktuelles VISv7:

                @Glasfaser
                Ich arbeite schon etwas länger mit ioBroker,

                ist genau das selbe wie bei Kuddel Projekt aufgebaut .. Viewwechsel .. was du hast 😉

                hier im Projekt:

                Widget : view in Widget 8 im View a_menue

                1.JPG

                H 1 Reply Last reply Reply Quote 0
                • H
                  hofmannha @Glasfaser last edited by

                  @Glasfaser
                  Ja stimmt. Manchmal macht man eben zu viel. Dann ist es besser, wenn man mal eine Pause einlegt damit der Kopf wieder frei wird.

                  D 1 Reply Last reply Reply Quote 0
                  • D
                    dos1973 @hofmannha last edited by

                    @Glasfaser

                    Danke für die Auflösung...
                    Ist so gewachsen und dann denkst du selbst nicht mehr nach und startetst den richtigen view für die Runtime.

                    1 Reply Last reply Reply Quote 1
                    • Negalein
                      Negalein Global Moderator last edited by

                      @dos1973

                      Du verwendest einige Javascripts, wie zB javascript.0.darksky.currently.icon, oder javascript.0.BatterieUeberwachung.NextExpectedLowBatt.
                      Kannst du deine Scripts exportieren (event. einzeln)?

                      Im Menü 0-6 hast du andere Icons.
                      Kannst du die bitte hier uploaden?

                      Danke dir

                      D 1 Reply Last reply Reply Quote 0
                      • D
                        dos1973 @Negalein last edited by

                        @Negalein

                        Icons:
                        habe das Menü auch noch nicht fertiggestellt. Habe bei mir selbst auch keine Icons sichtbar 1-6 nur (2) ist da und dass passt nichtmal

                        das ist das Dark Sky Script.
                        Du musst dich aber bei bei Dark Sky anmelden und einen API Key erzeugen. Ich nutze das Script aktuell nur noch für das aktuelle Wetter ICON, und auch nur weil Darksky "Nacht" Symbole anbietet.
                        https://forum.iobroker.net/topic/20992/skript-für-darksky-wetterdaten

                        Batterie kommt von hier:
                        https://forum.iobroker.net/topic/31676/vorlage-generische-batteriestandsüberwachung-vis-ausgabe
                        Ich habe es allerdings etwas angepasst, dass es in mein Design passt. Ich habe meine Änderungen gekennzeichnet
                        Ich meine die aktuellste Version unterstützt sogar schon Anpassungen am Design.

                        // Batterieüberwachungsskript Version 1.5.5 Stand 28.04.2020
                        //Überwacht Batteriespannungen beliebig vieler Geräte 
                        
                        //WICHTIG!!!
                        //Vorraussetzungen: Den Gerätechannels müssen Räume, sowie die Funktion "BatterieSpannung_xx" für jeden entsprechenden Batteriespannungs Datenpunkt zugewiesen sein.
                        
                        //Grund Einstellungen
                        const praefix = "javascript.0.BatterieUeberwachung."; //Grundpfad für Script DPs
                        const logging = true; //Logging aktivieren?
                        const FunktionBaseName = "BatterieSpannung_"; //Name der Funktion welche für die Batterieüberwachung genutzt wird
                        const UseTelegram = false; // Sollen Nachrichten via Telegram gesendet werden?
                        const UseMail = false; // Sollen Nachrichten via Mail gesendet werden?
                        const UseAlexa = false; // Sollen Nachrichten via Alexa ausgegeben werden?
                        const AlexaId = ""; // Die Alexa Seriennummer
                        const UseSay = false; // Sollen Nachrichten via Say ausgegeben werden? Funktion des Authors, sollte bei Anwendern auf false gesetzt werden.
                        const UseEventLog = false; // Sollen Nachrichten ins Eventlog geschreiben werden? Funktion des Authors, sollte bei Anwendern auf false gesetzt werden.
                        const UsePopUp = false // Soll PopUp angezeigt werden? Funktion des Authors, sollte bei Anwendern auf false gesetzt werden.
                        const ProzMeansLive = true; //Zeigen Prozentwerte des Gerätedatenpunktes Batteriekapazität oder restliche Lebensdauer?
                        
                        //Tabellen Einstellungen
                        const TblOkBgColor = "#fff"; //Hintergrundfarbe für Batteriestatus Ok
                        const TblInfoBgColor = "#ffc107"; //Hintergrundfarbe für Batteriestatus Info, also die leerste Batterie welche noch nicht das Limit unterschreitet
                        const TblWarnBgColor = "#4caf50"; //Hintergrundfarbe für Batteriestatus Warnung, also jene Batterie welche unter das Limit kam.
                        const HeadBgColor = "#fff"; //Hintergrundfarbe des Tabellenkopfes
                        const FontColor = "#4F729A"; //Textfarbe für Tabelleninhalt
                        const HeadFontColor = "#4F729A"; //Textfarbe für Tabellenkopf
                        const TblShowLfdCol = true; //Tabellenspalte mit laufender Nummer anzeigen?
                        const TblShowDeviceIDCol = false; //Tabellenspalte mit Geräte ID anzeigen?
                        const TblShowDeviceNameCol = true; //Tabellenspalte mit Gerätenamen anzeigen?
                        const TblShowRoomCol = false; //Tabellenspalte mit Raum anzeigen?
                        const TblShowUmaxCol = true; //Tabellenspalte mit Batterie Nennspannung anzeigen? 
                        const TblShowUistCol = true; //Tabellenspalte mit aktueller Batteriespannung anzeigen?
                        const TblShowUlimitCol = true; //Tabellenspalte mit unterer Batterielimit Spannung anzeigen?
                        const TblShowProzbatCol = true; //Tabellenspalte mit Batteriestand in Prozent anzeigen?
                        const TblShowProzliveCol = true; //Tabellenspalte mit Restlebensdauer unter Berücksichtigung der Limitspannung in Prozent anzeigen? Beispiel: Batterie hat 3V Nennspannung, Limit ist bei 2V, aktueller Batteriestand ist 2.5V, dann wäre die Restlebensdauer 50%
                        const TblShowStatusCol = true; //Tabellenspalte mit Status ausgeben?
                        
                        //Ab hier nix mehr ändern
                        
                        let DpCount = 0; //Zähler für anzulegende Datenpunkte
                        const States = []; //States Array initialisieren
                        const Sensor = [] //Sensoren Array initialisieren
                        const SensorVal = []; //SensorDatenpunkte Werte Array initialisieren
                        const SensorUmax = []; //Sensoren Array Batteriespannungswerte Werte initialisieren
                        const SensorUProz = []; //Sensoren Array Spannung in Prozent initialisieren
                        const SensorLiveProz = []; //Sensoren Array verbleibende Lebendauer unter Berücksichtigung des min Limits, nicht zu verwechseln mit Batteriekapazität in %
                        const SensorState = []; //Statusarray, mögliche Werte ok,info,warn
                        const BatteryMinLimit = []; // Das eingestellte Batterie min. limit
                        const BatteryMinLimitDp = []; //Array mit den generierten MinLimit Einstellungsdatenpunkten
                        const WelcheFunktionVerwenden = []; // Array mit allen Einträgen aus Funktionen welche den FunktionBaseName beinhalten
                        let AllBatterysOk = true;
                        let LastMessage = "";
                        let LastMessageSeparator = "<br>";
                        let NextExpectedLowBatt = "";
                        
                        //function CreateStates() {
                        //Datenpunkte anlegen in javascript.0.BatterieUeberwachung.
                        States[DpCount] = { id: praefix + "AllBatterysOk", initial: true, forceCreation: false, common: { read: true, write: false, name: "Alle Batterien Ok?", type: "boolean", role: "state", def: false } }; //
                        DpCount++;
                        States[DpCount] = { id: praefix + "LastMessage", initial: "", forceCreation: false, common: { read: true, write: false, name: "Letzte Warnmeldung", type: "string", role: "state", def: "" } }; //
                        DpCount++;
                        FillWelcheFunktionVerwenden(); //Vorab Funktionen mit Umax Spannungen einlesen da diese für ID und Namen der MinLimit States benötigt werden
                        
                        for (let x = 0; x < WelcheFunktionVerwenden.length; x++) {
                            let dummy = WelcheFunktionVerwenden[x].slice(FunktionBaseName.length) //Letzten Zeichen aus Funktionsnamen extrahieren
                            let VoltInitial = CreateUmaxValueFromString(x) //Extrahierte Zeichen zu Kommazahl wandeln 
                            VoltInitial = VoltInitial / 100 * 80; //Initialwert für Limit berechnen
                            if (logging) log("InitialSpannung " + x + " gesetzt auf 80%= " + VoltInitial);
                            States[DpCount] = { id: praefix + "BatteryMinLimit_" + dummy, initial: VoltInitial, forceCreation: false, common: { read: true, write: true, name: "Unteres Limit für Warnmeldung bei " + toFloat(dummy.substr(0, 1) + "." + dummy.substr(1, 1)) + "V Geräten", type: "number", role: "value", unit: "V", def: 2.6 } }; //
                            BatteryMinLimitDp[x] = "BatteryMinLimit_" + dummy;
                            DpCount++;
                        };
                        States[DpCount] = { id: praefix + "NextExpectedLowBatt", initial: "", forceCreation: false, common: { read: true, write: false, name: "Vorraussichtlich nächste zu wechselnde Batterie", type: "string", role: "state", def: "" } }; //
                        DpCount++;
                        States[DpCount] = { id: praefix + "OverviewTable", initial: "", forceCreation: false, common: { read: true, write: false, name: "Einfache HTML Übersichtstabelle", type: "string", role: "state", def: "" } }; //
                        
                        //Alle States anlegen, Main aufrufen wenn fertig
                        let numStates = States.length;
                        States.forEach(function (state) {
                            createState(state.id, state.initial, state.forceCreation, state.common, function () {
                                numStates--;
                                if (numStates === 0) {
                                    if (logging) log("CreateStates fertig!");
                                    main();
                                };
                            });
                        });
                        
                        function CreateUmaxValueFromString(x) {
                            let dummy = WelcheFunktionVerwenden[x].slice(FunktionBaseName.length) //Aus der Funktionsbezeichnung die letzten beiden Zeichen extrahieren= z.B. 33
                            return toFloat(dummy.slice(0, dummy.length - 1) + "." + dummy.slice(-1)) //Die extrahierten Zeichen zu einer Kommazahl wandeln= z.B. 3.3
                        }
                        
                        function Init() {
                            if (logging) log("Reaching init()");
                            let counter = 0; //Zähler für Devices
                            let TempVal // Temporärer Sensorwert um nicht mehrere GetStates zu benötigen
                            let TempUnit //Einheit für Unterscheidung ob % vorliegen
                            let Funktionen = getEnums('functions'); //Alle Funktionen der Aufzählung in Array Funktionen übertragen
                            for (let x in Funktionen) {        // loop ueber alle Funktionen
                                let Funktion = Funktionen[x].name; // Einzelne Funktion aus dem Array
                                if (typeof Funktion == 'object') Funktion = Funktion.de; //Wenn Rückgabewert ein Objekt ist, ist die Funktion mehrsprachig und es wird die deutsche Bezeichnug verwendet
                                let members = Funktionen[x].members; //Array mit allen Mitgliedern der Funktion erzeugen
                                for (let z = 0; z < WelcheFunktionVerwenden.length; z++) { //Loop über alle Funktions welche zu WelcheFunktionVerwenden passen
                                    if (Funktion == WelcheFunktionVerwenden[z]) { //Wenn Function ist WelcheFunktionVerwenden (BatterieSpannung)
                                        let Umax = CreateUmaxValueFromString(z) //Batteriesollspannung aus der Funktionsbezeichnung extrahieren
                                        let BattMinLimitTemp = getState(praefix + "BatteryMinLimit_" + WelcheFunktionVerwenden[z].slice(FunktionBaseName.length)).val //Temporäres (für den jeweiligen Schleifendurchlauf) MinLimit einlesen
                                        for (let y in members) { // Loop über alle WelcheFunktionVerwenden Members
                                            Sensor[counter] = members[y]; //Treffer in SenorIDarray einlesen
                                            TempVal = getState(Sensor[counter]).val;//Wert vom Sensor in Tempval einlesen um wiederholte Getstates zu vermeiden
                                            //if (typeof (TempVal) == undefined || typeof (TempVal) == null || TempVal == "") TempVal = 0; //Bei leeren Feldern 0 setzen um Fehler zu vermeiden
                                            TempUnit = GetUnit(counter);
                                            if (logging) log("Tempval=" + TempVal + " TempUnit=" + TempUnit + " TypeOf=" + typeof (TempVal))
                                            switch (typeof (TempVal)) { //Wenn der Sensorwert bool ist (wenn nur LowBatt mit true/false vom Sensor gemeldet wird)
                                                case "boolean": //Sensorval ist Bool
                                                    if (TempVal) { //Bei Lowbat=true
                                                        SensorVal[counter] = 0; //Batt wird als leer definiert und auf 0 gesetzt
                                                        SensorUProz[counter] = 0; //Prozentwerte aus Umax und Sensorwert errechnen
                                                        SensorLiveProz[counter] = 0; //Lebensprozent auf 0%
                                                    }
                                                    else {
                                                        SensorVal[counter] = Umax; //Batt wird als voll definiert und auf Umax gesetzt
                                                        SensorUProz[counter] = 100; //Prozentwerte aus Umax und Sensorwert errechnen
                                                        SensorLiveProz[counter] = 100; //Lebensprozent auf 100%
                                                    };
                                                    break;
                                                case "number": //Sensorval ist Zahl
                                                    switch (TempUnit) { //Bei Zahlen nach Einheit unterscheiden um % Angaben mit zu verarbeiten
                                                        case "%": //Bei Datenpunkt Unit = %
                                                            //if (logging) log("unit= " + TempUnit + " should be %");
                                                            if (ProzMeansLive) { // Wenn die Prozentangabe bereits Lebensdauer zeigt (Einstellungsoption)
                                                                SensorLiveProz[counter] = TempVal; //Direkt zuweisen aus Sensorwert
                                                                SensorUProz[counter] = (Umax - ((Umax - BattMinLimitTemp) / 100 * SensorLiveProz[counter])) / Umax * 100 //Errechne Batteriekapazität
                                                                SensorVal[counter] = Umax / 100 * SensorUProz[counter];  //Errechne Spannung
                                                            }
                                                            else { //Wenn die Prozentangabe Batteriekapazität darstellt  (Einstellungsoption)
                                                                SensorUProz[counter] = TempVal; //Batteriekapazität in % bestimmen
                                                                SensorVal[counter] = Umax / 100 * SensorUProz[counter]; //Sensorwert aus Umax und Prozentwert bestimmen
                                                                SensorLiveProz[counter] = (SensorVal[counter] - BattMinLimitTemp) / (Umax - BattMinLimitTemp) * 100; //Restlebensdauer in % ermitteln
                                                            };
                        
                                                            break;
                                                        default: // In allen anderen Fällen
                                                            SensorVal[counter] = TempVal; //Spannung ist Wert vom DP
                                                            SensorUProz[counter] = SensorVal[counter] / Umax * 100; //Prozentwerte aus Umax und Sensorwert errechnen
                                                            SensorLiveProz[counter] = (SensorVal[counter] - BattMinLimitTemp) / (Umax - BattMinLimitTemp) * 100; //Restlebensdauer in % ermitteln
                                                    };
                                                    break;
                                                case "string": //Sensorval ist Text
                                                    if (TempVal == "ok") {
                                                        SensorVal[counter] = Umax; //Batt wird als voll definiert und auf Umax gesetzt
                                                        SensorUProz[counter] = 100; //Prozentwerte aus Umax und Sensorwert errechnen
                                                        SensorLiveProz[counter] = 100; //Lebensprozent auf 100%
                                                    }
                                                    else if (TempVal != "ok") { //Bei BatteryState != ok
                                                        SensorVal[counter] = 0; //Batt wird als leer definiert und 0.1 unter MinLimit gesetzt
                                                        SensorUProz[counter] = 0; //Prozentwerte aus Umax und Sensorwert errechnen
                                                        SensorLiveProz[counter] = 0; //Lebensprozent auf 0%
                                                    };
                                                    break;
                                                default:
                                            };
                                            if (SensorLiveProz[counter] > 100) SensorLiveProz[counter] = 100; //Um bei übervollen Batterien mehr als 100% live zu vermeiden
                                            SensorUmax[counter] = Umax; //Synchrones UmaxArray füllen
                                            BatteryMinLimit[counter] = BattMinLimitTemp; //Limitarray füllen
                                            if (logging) log(counter + " " + Funktion + ' found at ' + members[y] + " Umax= " + SensorUmax[counter] + " BattMinLimit=" + BattMinLimitTemp + " Val= " + SensorVal[counter] + " SensorProzent= " + SensorUProz[counter]);
                                            counter++
                                        };
                                    };
                                };
                            };
                        }
                        
                        function FillWelcheFunktionVerwenden() {
                            if (logging) log("Reaching FillWelcheFunktionVerwenden");
                            let z = 0;
                            let Funktionen = getEnums('functions'); //Alle Funktionen der Aufzählung in Array Funktionen übertragen
                            //let NumFunktionen = Funktionen.length
                            for (let x in Funktionen) {        // loop ueber alle Funktionen
                                let Funktion = Funktionen[x].name; // Einzelne Funktion aus dem Array
                                if (typeof Funktion == 'object') Funktion = Funktion.de; //Wenn Rückgabewert ein Objekt ist, ist die Funktion mehrsprachig und es wird die deutsche Bezeichnung verwendet
                                let members = Funktionen[x].members; //Array mit allen Mitgliedern der Funktion erzeugen
                                if (Funktion.includes(FunktionBaseName)) {
                                    WelcheFunktionVerwenden[z] = Funktion;
                                    if (logging) log("Found Function " + WelcheFunktionVerwenden[z])
                                    z++
                                };
                            };
                        }
                        
                        function main() {
                            if (logging) log("Reaching main()");
                            Init(); //Alle Werte einlesen, Arrays füllen, fehlende Werte errechnen
                            CreateTrigger(); // Trigger erzeugen
                            CheckAllBatterys(); // Alle Batteriestände prüfen
                            CheckNextLowBatt(); // Batterie mit niedrigster Spannung finden
                            MakeTable(); //HTML Tabelle erzeugen
                        }
                        
                        function Meldung(msg) {
                            if (UseSay) Say(msg);
                            if (UseTelegram) {
                                sendTo("telegram.0", "send", {
                                    text: msg
                                });
                            };
                            if (UseMail) {
                                sendTo("email", msg);
                            };
                            if (UseAlexa) {
                                if (AlexaId != "") setState("alexa2.0.Echo-Devices." + AlexaId + ".Commands.announcement"/*announcement*/, msg);
                            };
                            if (logging) log(msg);
                            if (UseEventLog) WriteEventLog(msg);
                            if (UsePopUp) ShowPopUp(true, msg, "Batterys", "red");
                            setState(praefix + "LastMessage", LastMessage); //Meldung in Datenpunkt LastMessage schreiben
                        
                        }
                        
                        function CheckNextLowBatt() { //Ermittelt die Batterie mit der geringsten Spannung, ignoriert Batterien welche das Limit bereits unterschritten haben da diese bereits in der LastMessage gemeldet werden
                            let LowestBattProz = 100; //Mit 100% initialisieren
                            let LowestBattIndex = 0;
                            for (let x = 0; x < Sensor.length; x++) { //Alle Sensoren durchlaufen
                                if (SensorState[x] != "warn") SensorState[x] = "ok";
                                if (SensorVal[x] > BatteryMinLimit[x]) { // Nur Sensoren berücksichtigen die das min Limit noch nicht unterschritten haben
                                    if (SensorUProz[x] < LowestBattProz) { //Wenn Sensorwert kleiner LowestBattProz, LowestBattVal auf neuen Wert setzen um das Gerät mit den wenigsten Prozent zu ermitteln
                                        LowestBattProz = SensorUProz[x];
                                        LowestBattIndex = x;
                                    };
                                };
                            };
                        
                            NextExpectedLowBatt = "Aktuell niedrigster Batteriestand (" + SensorVal[LowestBattIndex].toFixed(2) + "V): " + GetRoom(LowestBattIndex) + " bei Gerät " + getObject(GetParentId(Sensor[LowestBattIndex]), "common").common.name;
                            setState(praefix + "NextExpectedLowBatt", NextExpectedLowBatt);
                            SensorState[LowestBattIndex] = "info";
                            if (logging) log(NextExpectedLowBatt);
                        }
                        
                        function CheckAllBatterysOk() {
                            if (logging) log("Reaching CheckAllBatterysOk - Lastmessage=" + LastMessage);
                            AllBatterysOk = true;
                            for (let x = 0; x < Sensor.length; x++) { //Alle Sensoren durchlaufen
                                if (SensorVal[x] < BatteryMinLimit[x]) { // Nur Sensoren berücksichtigen die das min Limit noch nicht unterschritten haben
                                    AllBatterysOk = false;
                                };
                            };
                            setState(praefix + "AllBatterysOk", AllBatterysOk);
                            if (AllBatterysOk == true) {
                                LastMessage = ""; //Lastmessage löschen
                                setState(praefix + "LastMessage", LastMessage); //Meldung in Datenpunkt LastMessage löschen
                                if (logging) log("Alle Batterien ok, Lastmessage gelöscht");
                            };
                        }
                        
                        function CheckBatterys(x) { // Prüfung eines einzelnen Batteriestandes wenn getriggert
                            if (logging) log("Reaching CheckBatterys(" + x + ") Val=" + SensorVal[x] + " Limit=" + BatteryMinLimit[x]);
                            if (SensorVal[x] < BatteryMinLimit[x]) { //Wenn Min. Wert unterschritten
                                LastMessage = "Batteriestand unter Limit im " + GetRoom(x) + " bei Gerät " + getObject(Sensor[x].substring(0, Sensor[x].lastIndexOf("."))).common.name;
                                Meldung(LastMessage);
                                SensorState[x] = "warn";
                            }
                            else {
                                SensorState[x] = "ok";
                            };
                            CheckAllBatterysOk();
                            CheckNextLowBatt();
                            MakeTable();
                        }
                        
                        function CheckAllBatterys() { // Prüfung aller Batteriestände bei Skriptstart
                            if (logging) log("Reaching CheckAllBatterys() found " + (Sensor.length) + " Devices");
                            //LastMessage = "";
                            for (let x = 0; x < Sensor.length; x++) { //Alle Sensoren durchlaufen
                                if (SensorVal[x] < BatteryMinLimit[x]) { //Wenn Min. Wert unterschritten
                                    if (logging) log("SensorVal[" + x + "] = " + SensorVal[x] + "V, unterschreitet MinLimit von " + BatteryMinLimit[x] + " V");
                                    LastMessage = LastMessage + "Batteriestand unter Limit im " + GetRoom(x) + " bei Gerät " + getObject(Sensor[x].substring(0, Sensor[x].lastIndexOf("."))).common.name + LastMessageSeparator;
                                    SensorState[x] = "warn";
                                }
                                else {
                                    if (SensorState[x] != "info") SensorState[x] = "ok";
                                };
                            };
                            CheckAllBatterysOk()
                            LastMessage = LastMessage.substr(0, LastMessage.length - LastMessageSeparator.length); //letzten <br> Umbruch wieder entfernen
                            if (LastMessage != "") Meldung(LastMessage); // Wenn Lastmessage nicht leer, Nachricht ausgeben
                        }
                        
                        function GetRoom(x) {  // Raum eines Gerätes ermitteln
                            let room = getObject(Sensor[x], 'rooms').enumNames[0];
                            if (typeof room == 'object') room = room.de;
                            room = room.replace(/_/g, " "); //Unterstriche durch Leerzeichen ersetzen
                            return room;
                        }
                        
                        function GetUnit(x) {
                            let unit = getObject(Sensor[x], 'common').common.unit
                            return unit;
                        }
                        
                        function GetParentId(Id) {
                            let parentDevicelId;
                        
                            if (Id.indexOf("hm-rpc.0") == -1) { //Wenn kein HM Adapter, eine Ebene zurück
                                parentDevicelId = Id.split(".").slice(0, -1).join(".");// Id an den Punkten in Array schreiben (split), das letzte Element von hinten entfernen (slice) und den Rest wieder zu String zusammensetzen
                            }
                            else { //Wenn HM dann zwei Ebenen zurück
                                parentDevicelId = Id.split(".").slice(0, -2).join(".");// Id an den Punkten in Array schreiben (split), die 2 letzten Element von hinten entfernen (slice) und den Rest wieder zu String zusammensetzen
                            };
                        
                            //if (logging) log("Id= " + Id + " ParentDeviceId= " + parentDevicelId)
                            return parentDevicelId
                        }
                        
                        function HmNameCorrection() {
                        
                        }
                        
                        function MakeTable() {
                            if (logging) log("Reaching Mytable");
                            let BgColor = "";
                        
                            // original
                            //let style0 = "style='border: 1px solid black; padding-left: 5px; padding-right: 5px; font-size:0.8em; font-weight: normal; text-align: left; color:" + FontColor + "; background-color:"
                            //let style1 = "style='width: 40px; border: 1px solid black; padding-left: 5px; padding-right: 5px; font-size:0.8em; font-weight: normal; text-align: right; color:" + FontColor + "; background-color:"
                            //let headstyle0 = "style='border: 1px solid black; padding-left: 5px; padding-right: 5px; height: 30px; font-size:1.0em; font-weight: bold; text-align: left; color:" + HeadFontColor + "; background-color:"
                            //let headstyle1 = "style='width: 40px; border: 1px solid black; padding-left: 5px; padding-right: 5px; height: 30px; font-size:1.0em; font-weight: bold; text-align: center; color:" + HeadFontColor + "; background-color:"
                        
                            /////////////// modifiziert DOS
                            
                            let style0 = "style='border: 0px solid black; padding-top: 10px; padding-left: 5px; padding-right: 5px; font-size:0.8em; font-weight: normal; text-align: left; color:" + FontColor + "; background-color:"
                            let style1 = "style='width: 40px; border: 0px solid black; padding-top: 10px; padding-left: 5px; padding-right: 5px; font-size:0.8em; font-weight: normal; text-align: right; color:" + FontColor + "; background-color:"
                            let headstyle0 = "style='border: 0px solid black; padding-left: 5px; padding-right: 5px; height: 30px; font-size:1.0em; font-weight: bold; text-align: left; color:" + HeadFontColor + "; background-color:"
                            let headstyle1 = "style='width: 40px; border: 0px solid black; padding-left: 5px; padding-right: 5px; height: 30px; font-size:1.0em; font-weight: bold; text-align: center; color:" + HeadFontColor + "; background-color:"
                            
                            // modifiziert ende DOS
                        
                        
                        
                            let MyTableHead = "<table style='width:100%; border: 0px solid black; border-collapse: collapse;'><tr>";
                            let MyTable;
                        
                            if (TblShowLfdCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle0 + HeadBgColor + "'>lfd</th>";
                            };
                            if (TblShowDeviceIDCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle0 + HeadBgColor + "'>Sensor ID</th>";
                            };
                            if (TblShowDeviceNameCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle0 + HeadBgColor + "'>Sensor Name</th>";
                            };
                            if (TblShowRoomCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle0 + HeadBgColor + "'>Raum</th>";
                            };
                            if (TblShowUmaxCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle1 + HeadBgColor + "'>U<br>Nenn</th>";
                            };
                            if (TblShowUistCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle1 + HeadBgColor + "'>U<br>Ist</th>";
                            };
                            if (TblShowUlimitCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle1 + HeadBgColor + "'>U<br>Limit</th>";
                            };
                            if (TblShowProzbatCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle1 + HeadBgColor + "'>%bat</th>";
                            };
                            if (TblShowProzliveCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle1 + HeadBgColor + "'>%live</th>";
                            };
                            if (TblShowStatusCol) {
                                MyTableHead = MyTableHead + "<th " + headstyle1 + HeadBgColor + "'>Status</th>";
                            };
                        
                            MyTableHead = MyTableHead + "</tr>";
                            MyTable = MyTableHead + "<tr>";
                        
                            for (let x = 0; x < Sensor.length; x++) { //Alle Sensoren durchlaufen 
                                switch (SensorState[x]) {
                                    case "ok":
                                        BgColor = TblOkBgColor;
                                        break;
                                    case "info":
                                        BgColor = TblInfoBgColor;
                                        break;
                                    case "warn":
                                        BgColor = TblWarnBgColor;
                                        break;
                                    default:
                                };
                        
                                MyTable = MyTable + "<tr>"
                                if (TblShowLfdCol) {
                                    MyTable = MyTable + "<td " + style0 + BgColor + "'>" + (x + 1) + "</td>";
                                };
                                if (TblShowDeviceIDCol) {
                                    MyTable = MyTable + "<td " + style0 + BgColor + "'>" + GetParentId(Sensor[x]) + "</td>";
                                };
                                if (TblShowDeviceNameCol) {
                                    MyTable = MyTable + "<td " + style0 + BgColor + "'>" + getObject(GetParentId(Sensor[x]), "common").common.name + "</td>";
                                };
                                if (TblShowRoomCol) {
                                    MyTable = MyTable + "<td " + style0 + BgColor + "'>" + GetRoom(x) + "</td>";
                                };
                                if (TblShowUmaxCol) {
                                    MyTable = MyTable + "<td " + style1 + BgColor + "'>" + SensorUmax[x].toFixed(1) + "V</td>";
                                };
                                if (TblShowUistCol) {
                                    MyTable = MyTable + "<td " + style1 + BgColor + "'>" + SensorVal[x].toFixed(2) + "V</td>";
                                };
                                if (TblShowUlimitCol) {
                                    MyTable = MyTable + "<td " + style1 + BgColor + "'>" + BatteryMinLimit[x].toFixed(2) + "V</td>";
                                };
                                if (TblShowProzbatCol) {
                                    if (typeof (SensorUProz[x]) == "number") {
                                        MyTable = MyTable + "<td " + style1 + BgColor + "'>" + SensorUProz[x].toFixed(1) + "%</td>";
                                    }
                                    else {
                                        MyTable = MyTable + "<td " + style1 + BgColor + "'>" + SensorUProz[x] + "</td>";
                                    };
                                };
                                if (TblShowProzliveCol) {
                                    if (typeof (SensorLiveProz[x]) == "number") {
                                        MyTable = MyTable + "<td " + style1 + BgColor + "'>" + SensorLiveProz[x].toFixed(1) + "%</td>";
                                    }
                                    else {
                                        MyTable = MyTable + "<td " + style1 + BgColor + "'>" + SensorLiveProz[x] + "</td>";
                                    };
                                };
                                if (TblShowStatusCol) {
                                    MyTable = MyTable + "<td " + style1 + BgColor + "'>" + SensorState[x] + "</td>";
                                };
                        
                                MyTable = MyTable + "</tr>";
                            };
                        
                            MyTable = MyTable + "</table>";
                            setState(praefix + "OverviewTable", MyTable);
                            //if (logging) log(MyTable);
                        }
                        
                        
                        //Trigger für Sensoren erzeugen
                        function CreateTrigger() {
                            for (let x = 0; x < Sensor.length; x++) { //Alle Sensoren durchlaufen
                                on(Sensor[x], function (dp) { //Trigger in Schleife erstellen
                                    let TempVal = dp.state.val;
                                    let TempUnit = GetUnit(x);
                                    switch (typeof (TempVal)) { //Wenn der Sensorwert bool ist (wenn nur LowBatt mit true/false vom Sensor gemeldet wird)
                                        case "boolean": //Sensorval ist Bool
                                            if (TempVal) { //Bei Lowbat=true
                                                SensorVal[x] = 0; //Batt wird als leer definiert und 0.1 unter MinLimit gesetzt
                                                SensorUProz[x] = 0; //Prozentwerte aus Umax und Sensorwert errechnen;
                                                SensorLiveProz[x] = 0; //Lebensprozent auf 0%
                                            }
                                            else {
                                                SensorVal[x] = SensorUmax[x]; //Batt wird als voll definiert und auf Umax gesetzt
                                                SensorUProz[x] = 100; //Prozentwerte aus Umax und Sensorwert errechnen
                                                SensorLiveProz[x] = 100; //Lebensprozent auf 100%
                                            };
                                            break;
                                        case "number": //Sensorval ist Zahl
                                            switch (TempUnit) { //Bei Zahlen nach Einheit unterscheiden um % Angaben mit zu verarbeiten
                                                case "%": //Bei Datenpunkt Unit = %
                                                    //if (logging) log("unit= " + TempUnit + " should be %");
                                                    if (ProzMeansLive) { // Wenn die Prozentangabe bereits Lebensdauer zeigt (Einstellungsoption)
                                                        SensorLiveProz[x] = TempVal; //Direkt zuweisen aus Sensorwert
                                                        SensorUProz[x] = (SensorUmax[x] - ((SensorUmax[x] - BatteryMinLimit[x]) / 100 * SensorLiveProz[x])) / SensorUmax[x] * 100 //Errechne Batteriekapazität
                                                        SensorVal[x] = SensorUmax[x] / 100 * SensorUProz[x];  //Errechne Spannung
                                                    }
                                                    else { //Wenn die Prozentangabe Batteriekapazität darstellt  (Einstellungsoption)
                                                        SensorUProz[x] = TempVal; //Batteriekapazität in % bestimmen
                                                        SensorVal[x] = SensorUmax[x] / 100 * SensorUProz[x]; //Sensorwert aus Umax und Prozentwert bestimmen
                                                        SensorLiveProz[x] = (SensorVal[x] - BatteryMinLimit[x]) / (SensorUmax[x] - BatteryMinLimit[x]) * 100; //Restlebensdauer in % ermitteln
                                                    };
                        
                                                    break;
                        
                                                default: // In allen anderen Fällen
                                                    SensorVal[x] = TempVal; //Spannung ist Wert vom DP
                                                    SensorUProz[x] = SensorVal[x] / SensorUmax[x] * 100; //Prozentwerte aus Umax und Sensorwert errechnen
                                            };
                                            break;
                                        case "string": //Sensorval ist Text
                                            if (TempVal == "ok") {
                                                SensorVal[x] = SensorUmax[x]; //Batt wird als voll definiert und auf Umax gesetzt
                                                SensorUProz[x] = 100; //Prozentwerte aus Umax und Sensorwert errechnen
                                                SensorLiveProz[x] = 100; //Lebensprozent auf 100%
                                            }
                                            else if (TempVal != "ok") { //Bei BatteryState != ok
                                                SensorVal[x] = 0; //Batt wird als leer definiert und 0.1 unter MinLimit gesetzt
                                                SensorUProz[x] = 0; //Prozentwerte aus Umax und Sensorwert errechnen
                                                SensorLiveProz[x] = 0; //Lebensprozent auf 0%
                                            };
                                            break;
                        
                                        default:
                                    };
                                    CheckBatterys(x); //Prüfen
                                });
                            };
                        
                            for (let x = 0; x < WelcheFunktionVerwenden.length; x++) { //Alle Batteriefunktionen durchlaufen
                                on(praefix + BatteryMinLimitDp[x], function (dp) { //Trigger erstellen und auslösen wenn min Limit geändert wurde. Dann erneute Komplettprüfung aller Batteriestände
                                    if (logging) log("Reaching Trigger for :" + praefix + BatteryMinLimitDp[x])
                                    main(); //Neuzuweisung des geänderten Limits an alle Geräte
                                });
                            };
                        }
                        
                        
                        Negalein L 2 Replies Last reply Reply Quote 0
                        • Negalein
                          Negalein Global Moderator @dos1973 last edited by

                          @dos1973 sagte in mein aktuelles VISv7:

                          Batterie kommt von hier:

                          Danke, das hab ich sogar schon im Einsatz.
                          Da werde ich gleich mal deine Änderungen versuchen.

                          Habe bei mir selbst auch keine Icons sichtbar

                          Ah ok. Da werd ich mal im großen weiten Netz auf Suche gehen.

                          1 Reply Last reply Reply Quote 0
                          • L
                            Lanki1302 @dos1973 last edited by Lanki1302

                            @dos1973
                            Hi. Erstmal: Die VIS ist dir wirklich gut gelungen....Echt Mega.

                            Ich versuche gerade die Batterieüberwachung bei mir einzufügen.
                            Leider kommt nach dem Starten des Skriptes im Log folgender Fehler:
                            Unbenannt.PNG
                            Was kann das sein?! Wenn ich die VIS aufmache erscheint nichts. Er schein irgendwie ein Problem mit der Tabellendarstellung zu haben....

                            Hier noch das Log aus dem Skript:

                            28.10.2020, 22:27:38.360 [warn ]: javascript.0 (4182) at Init (script.js.common.BattUeberwachung:110:31)
                            28.10.2020, 22:27:38.361 [warn ]: javascript.0 (4182) at main (script.js.common.BattUeberwachung:193:5)
                            28.10.2020, 22:27:38.362 [warn ]: javascript.0 (4182) at Object.<anonymous> (script.js.common.BattUeberwachung:84:13)
                            28.10.2020, 22:27:38.392 [error]: javascript.0 (4182) at MakeTable (script.js.common.BattUeberwachung:407:81)
                            28.10.2020, 22:27:38.393 [error]: javascript.0 (4182) at main (script.js.common.BattUeberwachung:197:5)
                            28.10.2020, 22:27:38.394 [error]: javascript.0 (4182) at Object.<anonymous> (script.js.common.BattUeberwachung:84:13)

                            Gruß

                            D 1 Reply Last reply Reply Quote 0
                            • D
                              dos1973 @Lanki1302 last edited by

                              @Lanki1302
                              Hats du die Anweisungen zum Script umgesetzt? Aufzählung erstellt?
                              https://github.com/Pittini/iobroker-Batterienauswertung

                              Das script alleine reicht nicht aus.

                              L 1 Reply Last reply Reply Quote 0
                              • L
                                Lanki1302 @dos1973 last edited by Lanki1302

                                @dos1973
                                Ja, die Aufzählungen habe ich angelegt und verknüpft.
                                Ich habe auch schonmal alles wieder gelöscht und nochmal eingegeben. Ergebnis war dann eine Tabelle in der VIS bei der die Schrift nicht richtig in den Tabellenspalten abgebildet wurde....also versetzt.

                                Anweisungen zum Script habe ich dabei durchgearbeitet

                                D 1 Reply Last reply Reply Quote 0
                                • D
                                  dos1973 @Lanki1302 last edited by

                                  @Lanki1302

                                  ohje, ob ich da helfen kann.
                                  Du wirst erst die Grundfunktionalität des Scriptes herstellen müssen.
                                  Du könntest nochmals den Teil den ich "modifiziert" habe testweise rausnehmen und den Original Teil wieder einkommentieren und schauen ob es dann geht.
                                  Am besten du postest dein Fehler in dem dazugehörigen Thread.
                                  Ich selbst habe ja für mich nur die "Optik" etwas angepasst.

                                  Die eigentliche Logik im Script ist dort entstanden.

                                  L 1 Reply Last reply Reply Quote 0
                                  • htrecksler
                                    htrecksler Forum Testing @dos1973 last edited by

                                    @dos1973 Ich suche schon eine ganze Weile Icon Sets durch. Kannst Du mir eventuell sagen woher z. B. dieses Thermometer Icon kommt?
                                    Thermometer.jpg

                                    Übrigens, aber das wurde ja bereits gesagt, die (wie ich finde) gelungenste Visualisierung.
                                    Das ist zwar sicher Geschmacksache, und mir gefällt auch nicht alles, aber die Grundidee und die Anordnung der Informationen finde ich extrem gelungen.

                                    D 1 Reply Last reply Reply Quote 0
                                    • D
                                      dos1973 @htrecksler last edited by dos1973

                                      @htrecksler
                                      das icon stammen wahrscheinlich von flaticon.com, aber kann es nicht 100% versichern. ich habe mal angehängt. Btw mir gefällt auch nicht alles 😉

                                      *** weisses icon auf weißem Hintergrund

                                      thermometer (1).png

                                      *** weisses icon auf weißem Hintergrund

                                      D 1 Reply Last reply Reply Quote 1
                                      • D
                                        dos1973 @dos1973 last edited by dos1973

                                        @hofmannha
                                        Ich habe pro harmony activity 2 Seiten erstellt. Linker block ist immer steuerung und rechter block immer inhalt/ content.

                                        Das ganz steuert sich immer über den DP der „current Activity“ und zeigt dann die linke und rechte Seite entsprechend der ausgewählten activity an.

                                        Beispiel tv.
                                        Links die commandos für mein receiver und ton
                                        Rechts aktuelles programm

                                        Bei kodi
                                        Links die stwuerung für kodi
                                        Rechts inhalte, filmbeschreibung, cover etc

                                        EDIT:
                                        du brauchst noch das Script, dass die harmony Seiten aktualisiert, sorry hatte ich vergessen. ich hänge es oben an den Startpost

                                        D H 2 Replies Last reply Reply Quote 0
                                        • D
                                          dos1973 @dos1973 last edited by

                                          @hofmannha
                                          das hat dir noch gefehlt.
                                          Bildschirmfoto 2020-10-31 um 12.43.26.png

                                          export im Startpost

                                          1 Reply Last reply Reply Quote 0
                                          • H
                                            hofmannha @dos1973 last edited by

                                            Hallo @dos1973,
                                            vielen vielen Dank für die Unterstützung.
                                            Eine Frage noch. Ich habe auch ein Amazon Fire TV Stick. Auf diesem Stick läuft Kodi. Ich habe ehrlich gesagt Null Ahnung wie ich auf den Stick mit Kodi zugreifen kann.
                                            Könntest Du mich da mal einen Tip geben?
                                            Gruß

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            946
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            vis
                                            30
                                            142
                                            20861
                                            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