Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. [Vorlage] Variable Zeitsteuerung mit VIS Editor

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [Vorlage] Variable Zeitsteuerung mit VIS Editor

    This topic has been deleted. Only users with topic management privileges can see it.
    • sigi234
      sigi234 Forum Testing Most Active @GiuseppeS last edited by

      @GiuseppeS

      Irgendwas stimmt bei mir nicht?

      Screenshot (2597).png

      G 1 Reply Last reply Reply Quote 0
      • G
        GiuseppeS @sigi234 last edited by GiuseppeS

        @sigi234
        Lösche bitte als Test die Klasse "mdui-black-bg" aus dem Abbrechen-Button.
        Falls es das war, ändere es von black zu blue.

        EDIT:
        Habe gerade das Popup neu importiert und kann keine Fehler feststellen. Es kann tatsächlich an der genutzten Klasse mdui-black-bg liegen. Bin mir nicht mehr sicher, aber ich hatte in Uhulas Farbpalette etwas ergänzt/angepasst.

        sigi234 1 Reply Last reply Reply Quote 0
        • sigi234
          sigi234 Forum Testing Most Active @GiuseppeS last edited by sigi234

          @GiuseppeS sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:

          @sigi234
          Lösche bitte als Test die Klasse "mdui-black-bg" aus dem Abbrechen-Button.
          Falls es das war, ändere es von black zu blue.

          EDIT:
          Habe gerade das Popup neu importiert und kann keine Fehler feststellen. Es kann tatsächlich an der genutzten Klasse mdui-black-bg liegen. Bin mir nicht mehr sicher, aber ich hatte in Uhulas Farbpalette etwas ergänzt/angepasst.

          Geht nicht, habe diese Version:

          --release : 'MDCSS v2.5';
          --release-date : '30.04.2020';

          Editor:

          Screenshot (2601).png

          Runtime:

          Screenshot (2603).png

          Screenshot (2605).png

          G 1 Reply Last reply Reply Quote 0
          • G
            GiuseppeS @sigi234 last edited by

            @sigi234

            Achso, Du benutzt die neuen CSS-Klassen von Uhula. Dann musst Du in diesem Update von mir die verwendeten Klassen u.U. anpassen anpassen. Verwende noch die alte Bibliothek von Uhula. mdui-raisedbutton ist definitiv ein solcher Fall.

            Werde aber zeitnah, in den nächsten zwei Wochen, versuchen die neue Bibliothek anzuwenden.

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

              @sigi234

              Du meinst bestimmt den weißen Hintergrund !?

              und nicht wie @GiuseppeS den Button meint ..

              G sigi234 2 Replies Last reply Reply Quote 0
              • G
                GiuseppeS @Glasfaser last edited by GiuseppeS

                @Glasfaser
                Hatte den weißen Hintergrund schon bemerkt. Dachte, dass es vom letzten Update kam und mit der Button-Klasse zusammenhing.
                Aber anscheinend lag das letzte Update länger zurück, bzw. die Ursache ist eine ganz andere (MDCSS 2 statt 1 wie bei mir) und unabhängig vom letzten Release.

                Glasfaser 1 Reply Last reply Reply Quote 0
                • sigi234
                  sigi234 Forum Testing Most Active @Glasfaser last edited by sigi234

                  @Glasfaser sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:

                  Du meinst bestimmt den weißen Hintergrund !?

                  Ja

                  Im Editor wird ja alles Richtig angezeigt.

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

                    @sigi234

                    Das liegt am Widget DialogView , es wird durch das MDCSS verändert .
                    Deshalb bin ich noch auf MDCSS Version 1 .. reicht mir auch .
                    Das Widget MD hingegen funktioniert ...

                    Könntest du mal testweise das CSS rausnehmen !?

                    sigi234 1 Reply Last reply Reply Quote 0
                    • sigi234
                      sigi234 Forum Testing Most Active @Glasfaser last edited by

                      @Glasfaser sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:

                      Könntest du mal testweise das CSS rausnehmen !?

                      JA:
                      Screenshot (2608).png

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

                        @sigi234

                        Dann MDCSS v2.5 wieder rein und das einfügen .

                        /***Hintergrund Popup ändern *******/
                        .mdui-runtime .ui-dialog {
                            background: linear-gradient(0deg, #2c2a3f, #4f344c, #2c2a3f) !important;
                        }
                        
                        sigi234 1 Reply Last reply Reply Quote 1
                        • sigi234
                          sigi234 Forum Testing Most Active @Glasfaser last edited by

                          @Glasfaser sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:

                          Dann MDCSS v2.5 wieder rein und das einfügen .

                          👍

                          Screenshot (2610).png

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

                            @sigi234

                            Kannst ja deine Farben nehmen 🙂 😁

                            sigi234 1 Reply Last reply Reply Quote 0
                            • sigi234
                              sigi234 Forum Testing Most Active @Glasfaser last edited by sigi234

                              @Glasfaser sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:

                              @sigi234

                              Kannst ja deine Farben nehmen 🙂 😁

                              Ja, Danke Deine gefällt mir auch. 😀

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

                                @GiuseppeS

                                Wegen der NULL im Popup mußt du noch was machen , denn die Warnung wird angezeigt !

                                Sie verschwindet natürlich beim ersten befüllen / leeren .... aber einer Neustarter wundert sich

                                1 Reply Last reply Reply Quote 0
                                • G
                                  GiuseppeS last edited by GiuseppeS

                                  Ich glaube ich teste mal demnächst auch diesen Gradienten Style 👍

                                  @sigi234
                                  Wenn das Skript läuft, darf der gelbe Streifen im PopUp nicht mehr sichtbar sein. Der ist nur sichtbar, wenn bei den Bedingungen Fehler drin sind.

                                  Edit: Glasfaser war schneller 👍

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

                                    @GiuseppeS sagte in [Vorlage] Variable Zeitsteuerung mit VIS Editor:

                                    Wenn das Skript läuft, darf der gelbe Streifen im PopUp nicht mehr sichtbar sein.

                                    ist so beim neuanlegen !
                                    bei leerem Datenpunkt , wird es zum ersten mal angezeigt

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

                                      @Glasfaser
                                      Okay. War mir nicht aufgefallen. Werde beim Anlegen des States einen Wert mitgeben.

                                      Glasfaser 2 Replies Last reply Reply Quote 0
                                      • Glasfaser
                                        Glasfaser @GiuseppeS last edited by

                                        @GiuseppeS

                                        und den "scrollamount="50" langsamer auf 10 ... sonst ist kein Effekt ...
                                        bei mir Blitz die Schrift nach links 🙂

                                        1 Reply Last reply Reply Quote 1
                                        • Glasfaser
                                          Glasfaser @GiuseppeS last edited by Glasfaser

                                          @GiuseppeS

                                          Mal was anderes ....
                                          Ich arbeite viel mit dem Adapter - Logparser und habe im Script dazu etwas eingebaut , damit die Log Ausgabe dementsprechend auch Sinnvoll dargestellt wird .

                                          var logPraefix = '[Timer] ##{"severity":"", "from":"", "message":"'; // Wenn stdLog = true, kann hiermit die Ausgabe des ausgeführten Timers manipuliert werden
                                          var logPraefixend = '"}##'; // Logparser Ende
                                          
                                          

                                          .

                                          // Timer neu erstellen falls AKTIV == true
                                              if (aktiv){
                                                  // Verschiedene Mappings aus DropDown zu realen States erstellen
                                                  if(sollWertMapping.hasOwnProperty(sollwert)){
                                                      if(debugLog){console.log("Sollwert Mapping! Ist: " + sollwert);}
                                                      sollwert = sollWertMapping[sollwert]
                                                      if(debugLog){console.log("Sollwert Mapping! Real: " + sollwert);}
                                                  } else (sollwert = parseInt(sollwert));
                                          
                                                  if(stdLog){console.log("Schedule aktiviert: \"" + device + " #" + nr + "\": [" + scheduleNr + "] | " + cronString + " | " + objID + " | " + sollwert);}
                                          
                                                  if (rememberState){
                                                      // Array der CondIDs zusammenstellen für späteren Subscribe
                                                      var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                                                      condArr.push(objID); // Auch objID = Ziel-ID überwachen
                                                      for (let i = 1; i <= conditionsNr; i++){
                                                          condArr.push(ConditionJSON[TimerJSON[device][nr].Conditions[i].CondState]);
                                                      }
                                                  }
                                                  
                                                  cronArr[scheduleNr] = schedule(cronString, function(){
                                                      // Löschen der Subscription des selben Devices, falls vorhanden
                                                      if (subscribesList[device] > 0){
                                                          if(debugLog){console.log("Aktive Subscription für \"" + device + "\" gelöscht! Nächster Timer übernimmt!");}
                                                          unsubscribe(subscribesArr[subscribesList[device]]);
                                                          subscribesArr[subscribesList[device]] = null;
                                                          subscribesList[device] = 0;
                                                      }
                                                      if( condEval(TimerJSON[device][nr]) ){
                                                          if(stdLog){ console.log(logPraefix + device + " (" + tmpSollwert + ")" + logPraefixend);}
                                                          setState(objID, sollwert);
                                                          setTimeout(tableMain, 500); // aktualisieren der Tabelle
                                                      } else if (rememberState){
                                                          if(stdLog){ console.log(logPraefix + device + " (" + tmpSollwert + ") -> Timer gespeichert. Bedingung(en) noch nicht erfüllt!" + logPraefixend);}
                                                          subscribesList[device] = scheduleNr;
                                                          subscribesArr[scheduleNr] = on({id: condArr, change: "ne"}, function (obj) {
                                                              if (obj.id == objID){ // Falls getriggert durch objID, Subscription löschen
                                                                  if(debugLog){console.log("Schedule für \"" + device + " #" + nr + "\" [" + scheduleNr + "] -> Timer gelöscht! Istwert von Ziel-ID direkt verändert!");}
                                                                  unsubscribe(subscribesArr[scheduleNr]);
                                                                  subscribesArr[scheduleNr] = null;
                                                                  subscribesList[device] = 0;
                                                                  setTimeout(tableMain, 500); // aktualisieren der Tabelle
                                                              } else if( condEval(TimerJSON[device][nr]) ){
                                                                  if(stdLog){ console.log(logPraefix + device + " (" + tmpSollwert + ") -> Timer ausgeführt. Bedingung(en) nachträglich erfüllt!" + logPraefixend);}
                                                                  setState(objID, sollwert);
                                                                  unsubscribe(subscribesArr[scheduleNr]);
                                                                  subscribesArr[scheduleNr] = null;
                                                                  subscribesList[device] = 0;
                                                                  setState("javascript.0.Timer." + path + ".BackgroundTimersAfterwardsFulfilled", true);
                                                                  setStateDelayed("javascript.0.Timer." + path + ".BackgroundTimersAfterwardsFulfilled", false, 500, false);
                                                                  // aktualisieren der Tabelle erfolgt bereits über separatem Trigger der Bedingungen
                                                              }
                                                          });
                                                          setTimeout(tableMain, 500); // aktualisieren der Tabelle für Blinken
                                                      } else {
                                                          if(stdLog){ console.log(logPraefix + device + " (" + tmpSollwert + ") -> Nicht ausgeführt. Bedingung(en) nicht erfüllt!" + logPraefixend);}
                                                          setTimeout(tableMain, 500);
                                                      };
                                                  });
                                              } else {
                                                  // Falls Timer deaktiviert wird, während es gespeichert wurde... Subscription löschen!
                                                  if (subscribesArr[scheduleNr]){
                                                      if(debugLog){console.log("Schedule für \"" + device + " #" + nr + "\" [" + scheduleNr + "] -> Timer aus Speicher entfernt!");}
                                                      unsubscribe(subscribesArr[scheduleNr]);
                                                      subscribesArr[scheduleNr] = null;
                                                      subscribesList[device] = 0;
                                                  }
                                              }
                                          }
                                          
                                          
                                          

                                          Logparser :
                                          .
                                          1.JPG
                                          .
                                          1.JPG

                                          1 Reply Last reply Reply Quote 0
                                          • sigi234
                                            sigi234 Forum Testing Most Active @GiuseppeS last edited by

                                            @GiuseppeS

                                            Eine Anzeige ob der Timer ausgelöst hat wäre Super. Oder übersehe ich da was?

                                            Glasfaser G 2 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            831
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            template vis
                                            47
                                            919
                                            221101
                                            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