Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

  1. ioBroker Community Home
  2. Deutsch
  3. Visualisierung
  4. [Vorlage] Variable Zeitsteuerung mit VIS Editor

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.2k

[Vorlage] Variable Zeitsteuerung mit VIS Editor

Geplant Angeheftet Gesperrt Verschoben Visualisierung
vistemplate
919 Beiträge 47 Kommentatoren 279.2k Aufrufe 75 Watching
  • Ä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.
  • H Offline
    H Offline
    HelmutS
    schrieb am zuletzt editiert von
    #448

    Guten Morgen zusammen.
    Ich lasse mir beim editieren der Timer den Zustand der Bedingungen anzeigen.
    Eventuell findet das der eine oder andere nützlich.
    Hier die Änderungen:
    im Script ab ca. Zeile 700, jeweils die letzte Zeile:

        // Trigger zum Erstellen der Bedingungen als String für späteres eval() (3x)
        on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Value'), change: "any", ack: false}, function (obj) {
            var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
            var Cond1State = getState("javascript.0.Timer." + path + ".Editor.Cond1State").val
            var Cond1Comp = getState("javascript.0.Timer." + path + ".Editor.Cond1Comp").val
            var Cond1Value = getState("javascript.0.Timer." + path + ".Editor.Cond1Value").val
            var strCond1 = "getState(\"" + ConditionJSON[Cond1State] + "\").val " + Cond1Comp + " " + Cond1Value
            setState("javascript.0.Timer." + path + ".Editor.Condition1", strCond1);
            setState("javascript.0.Timer." + path + ".Editor.Cond1Result", eval(strCond1));
        });
    
        on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Value'), change: "any", ack: false}, function (obj) {
            var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
            var Cond2State = getState("javascript.0.Timer." + path + ".Editor.Cond2State").val
            var Cond2Comp = getState("javascript.0.Timer." + path + ".Editor.Cond2Comp").val
            var Cond2Value = getState("javascript.0.Timer." + path + ".Editor.Cond2Value").val
            var strCond2 = "getState(\"" + ConditionJSON[Cond2State] + "\").val " + Cond2Comp + " " + Cond2Value
            setState("javascript.0.Timer." + path + ".Editor.Condition2", strCond2);
            setState("javascript.0.Timer." + path + ".Editor.Cond2Result", eval(strCond2));
        });
    
        on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Value'), change: "any", ack: false}, function (obj) {
            var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
            var Cond3State = getState("javascript.0.Timer." + path + ".Editor.Cond3State").val
            var Cond3Comp = getState("javascript.0.Timer." + path + ".Editor.Cond3Comp").val
            var Cond3Value = getState("javascript.0.Timer." + path + ".Editor.Cond3Value").val
            var strCond3 = "getState(\"" + ConditionJSON[Cond3State] + "\").val " + Cond3Comp + " " + Cond3Value
            setState("javascript.0.Timer." + path + ".Editor.Condition3", strCond3);
            setState("javascript.0.Timer." + path + ".Editor.Cond3Result", eval(strCond3));
        });
    

    und ab Zeile ca 1000:

    createState("Timer.ActiveTable");
    createState("Timer." + path + ".NextDevice");
    createState("Timer." + path + ".FilterDevice");
    createState("Timer." + path + ".NextDevices");
    createState("Timer." + path + ".clickTarget");
    createState("Timer." + path + ".dblClickTarget");
    createState("Timer." + path + ".AstroJSON");
    createState("Timer." + path + ".DropDownDevice");
    createState("Timer." + path + ".DropDownGruppe");
    createState("Timer." + path + ".Editor.DropDownMinutes");
    createState("Timer." + path + ".Editor.Gruppe");
    createState("Timer." + path + ".Editor.Del");
    createState("Timer." + path + ".Editor.OK");
    createState("Timer." + path + ".Editor.CopyAll");
    createState("Timer." + path + ".Editor.CopyCond");
    createState("Timer." + path + ".Editor.DropDownAstro");
    createState("Timer." + path + ".Editor.DropDownAstroWerte");
    createState("Timer." + path + ".Editor.DropDownAstroTexte");
    createState("Timer." + path + ".Editor.Device");
    createState("Timer." + path + ".Editor.Nummer");
    createState("Timer." + path + ".TimerJSON");
    createState("Timer." + path + ".Editor.Aktiv");
    createState("Timer." + path + ".Editor.Zeit");
    createState("Timer." + path + ".Editor.Cron");
    createState("Timer." + path + ".Editor.TageVIS");
    createState("Timer." + path + ".Editor.CronTage");
    createState("Timer." + path + ".Editor.WTagMo");
    createState("Timer." + path + ".Editor.WTagDi");
    createState("Timer." + path + ".Editor.WTagMi");
    createState("Timer." + path + ".Editor.WTagDo");
    createState("Timer." + path + ".Editor.WTagFr");
    createState("Timer." + path + ".Editor.WTagSa");
    createState("Timer." + path + ".Editor.WTagSo");
    createState("Timer." + path + ".Editor.Std");
    createState("Timer." + path + ".Editor.Min");
    createState("Timer." + path + ".Editor.Sollwert");
    createState("Timer." + path + ".Editor.SollwertDropDown");
    createState("Timer." + path + ".Editor.Random");
    createState("Timer." + path + ".Editor.RandPM");
    createState("Timer." + path + ".Editor.Offset");
    createState("Timer." + path + ".Editor.OffsetPM");
    createState("Timer." + path + ".Editor.RememberTimer");
    createState("Timer." + path + ".Editor.ConditionKeyDropDown");
    createState("Timer." + path + ".Editor.Condition");
    createState("Timer." + path + ".Editor.ConditionsNr");
    createState("Timer." + path + ".Editor.Condition1");
    createState("Timer." + path + ".Editor.Cond1State");
    createState("Timer." + path + ".Editor.Cond1Comp");
    createState("Timer." + path + ".Editor.Cond1Value");
    createState("Timer." + path + ".Editor.Cond1Result");
    createState("Timer." + path + ".Editor.Condition2");
    createState("Timer." + path + ".Editor.Cond2State");
    createState("Timer." + path + ".Editor.Cond2Comp");
    createState("Timer." + path + ".Editor.Cond2Value");
    createState("Timer." + path + ".Editor.Cond2Result");
    createState("Timer." + path + ".Editor.Condition3");
    createState("Timer." + path + ".Editor.Cond3State");
    createState("Timer." + path + ".Editor.Cond3Comp");
    createState("Timer." + path + ".Editor.Cond3Value");
    createState("Timer." + path + ".Editor.Cond3Result");
    

    Jeweils die Zeile mit "Result"

    Im Edit-View bei den Bedingungen als Hintergrundfarbe dann

    {w:javascript.0.Timer.Devices.Editor.Cond1Result; w == "true" ? "#00AA00" : "#AA0000"} 
    

    eintragen ("Cond1Result" entsprechend ändern)

    G 1 Antwort Letzte Antwort
    0
    • H HelmutS

      Guten Morgen zusammen.
      Ich lasse mir beim editieren der Timer den Zustand der Bedingungen anzeigen.
      Eventuell findet das der eine oder andere nützlich.
      Hier die Änderungen:
      im Script ab ca. Zeile 700, jeweils die letzte Zeile:

          // Trigger zum Erstellen der Bedingungen als String für späteres eval() (3x)
          on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Value'), change: "any", ack: false}, function (obj) {
              var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
              var Cond1State = getState("javascript.0.Timer." + path + ".Editor.Cond1State").val
              var Cond1Comp = getState("javascript.0.Timer." + path + ".Editor.Cond1Comp").val
              var Cond1Value = getState("javascript.0.Timer." + path + ".Editor.Cond1Value").val
              var strCond1 = "getState(\"" + ConditionJSON[Cond1State] + "\").val " + Cond1Comp + " " + Cond1Value
              setState("javascript.0.Timer." + path + ".Editor.Condition1", strCond1);
              setState("javascript.0.Timer." + path + ".Editor.Cond1Result", eval(strCond1));
          });
      
          on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Value'), change: "any", ack: false}, function (obj) {
              var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
              var Cond2State = getState("javascript.0.Timer." + path + ".Editor.Cond2State").val
              var Cond2Comp = getState("javascript.0.Timer." + path + ".Editor.Cond2Comp").val
              var Cond2Value = getState("javascript.0.Timer." + path + ".Editor.Cond2Value").val
              var strCond2 = "getState(\"" + ConditionJSON[Cond2State] + "\").val " + Cond2Comp + " " + Cond2Value
              setState("javascript.0.Timer." + path + ".Editor.Condition2", strCond2);
              setState("javascript.0.Timer." + path + ".Editor.Cond2Result", eval(strCond2));
          });
      
          on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Value'), change: "any", ack: false}, function (obj) {
              var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
              var Cond3State = getState("javascript.0.Timer." + path + ".Editor.Cond3State").val
              var Cond3Comp = getState("javascript.0.Timer." + path + ".Editor.Cond3Comp").val
              var Cond3Value = getState("javascript.0.Timer." + path + ".Editor.Cond3Value").val
              var strCond3 = "getState(\"" + ConditionJSON[Cond3State] + "\").val " + Cond3Comp + " " + Cond3Value
              setState("javascript.0.Timer." + path + ".Editor.Condition3", strCond3);
              setState("javascript.0.Timer." + path + ".Editor.Cond3Result", eval(strCond3));
          });
      

      und ab Zeile ca 1000:

      createState("Timer.ActiveTable");
      createState("Timer." + path + ".NextDevice");
      createState("Timer." + path + ".FilterDevice");
      createState("Timer." + path + ".NextDevices");
      createState("Timer." + path + ".clickTarget");
      createState("Timer." + path + ".dblClickTarget");
      createState("Timer." + path + ".AstroJSON");
      createState("Timer." + path + ".DropDownDevice");
      createState("Timer." + path + ".DropDownGruppe");
      createState("Timer." + path + ".Editor.DropDownMinutes");
      createState("Timer." + path + ".Editor.Gruppe");
      createState("Timer." + path + ".Editor.Del");
      createState("Timer." + path + ".Editor.OK");
      createState("Timer." + path + ".Editor.CopyAll");
      createState("Timer." + path + ".Editor.CopyCond");
      createState("Timer." + path + ".Editor.DropDownAstro");
      createState("Timer." + path + ".Editor.DropDownAstroWerte");
      createState("Timer." + path + ".Editor.DropDownAstroTexte");
      createState("Timer." + path + ".Editor.Device");
      createState("Timer." + path + ".Editor.Nummer");
      createState("Timer." + path + ".TimerJSON");
      createState("Timer." + path + ".Editor.Aktiv");
      createState("Timer." + path + ".Editor.Zeit");
      createState("Timer." + path + ".Editor.Cron");
      createState("Timer." + path + ".Editor.TageVIS");
      createState("Timer." + path + ".Editor.CronTage");
      createState("Timer." + path + ".Editor.WTagMo");
      createState("Timer." + path + ".Editor.WTagDi");
      createState("Timer." + path + ".Editor.WTagMi");
      createState("Timer." + path + ".Editor.WTagDo");
      createState("Timer." + path + ".Editor.WTagFr");
      createState("Timer." + path + ".Editor.WTagSa");
      createState("Timer." + path + ".Editor.WTagSo");
      createState("Timer." + path + ".Editor.Std");
      createState("Timer." + path + ".Editor.Min");
      createState("Timer." + path + ".Editor.Sollwert");
      createState("Timer." + path + ".Editor.SollwertDropDown");
      createState("Timer." + path + ".Editor.Random");
      createState("Timer." + path + ".Editor.RandPM");
      createState("Timer." + path + ".Editor.Offset");
      createState("Timer." + path + ".Editor.OffsetPM");
      createState("Timer." + path + ".Editor.RememberTimer");
      createState("Timer." + path + ".Editor.ConditionKeyDropDown");
      createState("Timer." + path + ".Editor.Condition");
      createState("Timer." + path + ".Editor.ConditionsNr");
      createState("Timer." + path + ".Editor.Condition1");
      createState("Timer." + path + ".Editor.Cond1State");
      createState("Timer." + path + ".Editor.Cond1Comp");
      createState("Timer." + path + ".Editor.Cond1Value");
      createState("Timer." + path + ".Editor.Cond1Result");
      createState("Timer." + path + ".Editor.Condition2");
      createState("Timer." + path + ".Editor.Cond2State");
      createState("Timer." + path + ".Editor.Cond2Comp");
      createState("Timer." + path + ".Editor.Cond2Value");
      createState("Timer." + path + ".Editor.Cond2Result");
      createState("Timer." + path + ".Editor.Condition3");
      createState("Timer." + path + ".Editor.Cond3State");
      createState("Timer." + path + ".Editor.Cond3Comp");
      createState("Timer." + path + ".Editor.Cond3Value");
      createState("Timer." + path + ".Editor.Cond3Result");
      

      Jeweils die Zeile mit "Result"

      Im Edit-View bei den Bedingungen als Hintergrundfarbe dann

      {w:javascript.0.Timer.Devices.Editor.Cond1Result; w == "true" ? "#00AA00" : "#AA0000"} 
      

      eintragen ("Cond1Result" entsprechend ändern)

      G Offline
      G Offline
      GiuseppeS
      schrieb am zuletzt editiert von
      #449

      @HelmutS
      Hi, die Idee finde ich richtig gut. Bei der Umsetzung müsste man evtl. noch etwas beachten:

      Was passiert, wenn du gerade eine Bedingung "neu eingibst? D.h. Zeile der Bedingungen ist leer und tippst von links nach rechts deine Werte ein. Gut möglich, dass aktuell Error angezeigt werden, bis die Zeile vollständig ist, oder? Kannst Du das bitte testen?
      Ansonsten würde ich die Zeilen direkt übernehmen.

      H 1 Antwort Letzte Antwort
      0
      • H Offline
        H Offline
        HelmutS
        schrieb am zuletzt editiert von
        #450

        Nachtrag
        Im Script ab ca. Zeile 820 noch folgende Änderung:

                setState("javascript.0.Timer." + path + ".Editor.Aktiv", TimerJSON[device][nr].Aktiv, true);
                setState("javascript.0.Timer." + path + ".Editor.Zeit", TimerJSON[device][nr].Zeit, true);
                setState("javascript.0.Timer." + path + ".Editor.Cron", TimerJSON[device][nr].Cron, true);
                setState("javascript.0.Timer." + path + ".Editor.TageVIS", TimerJSON[device][nr].TageVIS, true);
                setState("javascript.0.Timer." + path + ".Editor.CronTage", TimerJSON[device][nr].CronTage, true);
                setState("javascript.0.Timer." + path + ".Editor.WTagMo", TimerJSON[device][nr].Mo, true);
                setState("javascript.0.Timer." + path + ".Editor.WTagDi", TimerJSON[device][nr].Di, true);
                setState("javascript.0.Timer." + path + ".Editor.WTagMi", TimerJSON[device][nr].Mi, true);
                setState("javascript.0.Timer." + path + ".Editor.WTagDo", TimerJSON[device][nr].Do, true);
                setState("javascript.0.Timer." + path + ".Editor.WTagFr", TimerJSON[device][nr].Fr, true);
                setState("javascript.0.Timer." + path + ".Editor.WTagSa", TimerJSON[device][nr].Sa, true);
                setState("javascript.0.Timer." + path + ".Editor.WTagSo", TimerJSON[device][nr].So, true);
                setState("javascript.0.Timer." + path + ".Editor.Std", TimerJSON[device][nr].Std, true);
                setState("javascript.0.Timer." + path + ".Editor.Min", TimerJSON[device][nr].Min, true);
                setState("javascript.0.Timer." + path + ".Editor.Sollwert", TimerJSON[device][nr].Sollwert, true);
                setState("javascript.0.Timer." + path + ".Editor.DropDownAstro", TimerJSON[device][nr].Astro, true);
                setState("javascript.0.Timer." + path + ".Editor.Random", TimerJSON[device][nr].Random, true);
                setState("javascript.0.Timer." + path + ".Editor.RandPM", TimerJSON[device][nr].RandPM, true);
                setState("javascript.0.Timer." + path + ".Editor.Offset", TimerJSON[device][nr].Offset, true);
                setState("javascript.0.Timer." + path + ".Editor.OffsetPM", TimerJSON[device][nr].OffsetPM, true);
                setState("javascript.0.Timer." + path + ".Editor.RememberTimer", TimerJSON[device][nr].RememberTimer, true);
                setState("javascript.0.Timer." + path + ".Editor.ConditionsNr", TimerJSON[device][nr].ConditionsNr, true);
                setState("javascript.0.Timer." + path + ".Editor.Condition1", TimerJSON[device][nr].Conditions[1].ConditionStr, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond1State", TimerJSON[device][nr].Conditions[1].CondState, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond1Comp", TimerJSON[device][nr].Conditions[1].CondComp, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond1Value", TimerJSON[device][nr].Conditions[1].CondValue, true);
                setState("javascript.0.Timer." + path + ".Editor.Condition2", TimerJSON[device][nr].Conditions[2].ConditionStr, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond2State", TimerJSON[device][nr].Conditions[2].CondState, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond2Comp", TimerJSON[device][nr].Conditions[2].CondComp, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond2Value", TimerJSON[device][nr].Conditions[2].CondValue, true);
                setState("javascript.0.Timer." + path + ".Editor.Condition3", TimerJSON[device][nr].Conditions[3].ConditionStr, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond3State", TimerJSON[device][nr].Conditions[3].CondState, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond3Comp", TimerJSON[device][nr].Conditions[3].CondComp, true);
                setState("javascript.0.Timer." + path + ".Editor.Cond3Value", TimerJSON[device][nr].Conditions[3].CondValue, true);
                setState("javascript.0.Timer." + path + ".Editor.Gruppe", TimerJSON[device][nr].Gruppe, true);
        
                if (TimerJSON[device][nr].Conditions[1].ConditionStr != ""){
                    setState("javascript.0.Timer." + path + ".Editor.Cond1Result", eval(TimerJSON[device][nr].Conditions[1].ConditionStr));
                }
                if (TimerJSON[device][nr].Conditions[2].ConditionStr != ""){
                    setState("javascript.0.Timer." + path + ".Editor.Cond2Result", eval(TimerJSON[device][nr].Conditions[2].ConditionStr));
                }
                if (TimerJSON[device][nr].Conditions[3].ConditionStr != ""){
                    setState("javascript.0.Timer." + path + ".Editor.Cond3Result", eval(TimerJSON[device][nr].Conditions[3].ConditionStr));
                }
        
        
        1 Antwort Letzte Antwort
        0
        • G GiuseppeS

          @HelmutS
          Hi, die Idee finde ich richtig gut. Bei der Umsetzung müsste man evtl. noch etwas beachten:

          Was passiert, wenn du gerade eine Bedingung "neu eingibst? D.h. Zeile der Bedingungen ist leer und tippst von links nach rechts deine Werte ein. Gut möglich, dass aktuell Error angezeigt werden, bis die Zeile vollständig ist, oder? Kannst Du das bitte testen?
          Ansonsten würde ich die Zeilen direkt übernehmen.

          H Offline
          H Offline
          HelmutS
          schrieb am zuletzt editiert von
          #451

          @GiuseppeS
          Stimmt, beim ersten Aufruf kommt ein Fehler.
          Ich habe es jetzt so gelöst:

              // Trigger zum Erstellen der Bedingungen als String für späteres eval() (3x)
              on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Value'), change: "any", ack: false}, function (obj) {
                  var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                  var Cond1State = getState("javascript.0.Timer." + path + ".Editor.Cond1State").val
                  var Cond1Comp = getState("javascript.0.Timer." + path + ".Editor.Cond1Comp").val
                  var Cond1Value = getState("javascript.0.Timer." + path + ".Editor.Cond1Value").val
                  var strCond1 = "getState(\"" + ConditionJSON[Cond1State] + "\").val " + Cond1Comp + " " + Cond1Value
                  setState("javascript.0.Timer." + path + ".Editor.Condition1", strCond1);
                  if (Cond1State != "" && Cond1Comp != "" && Cond1Value != "")
                  {
                      setState("javascript.0.Timer." + path + ".Editor.Cond1Result", eval(strCond1));
                  }
              });
          
              on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Value'), change: "any", ack: false}, function (obj) {
                  var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                  var Cond2State = getState("javascript.0.Timer." + path + ".Editor.Cond2State").val
                  var Cond2Comp = getState("javascript.0.Timer." + path + ".Editor.Cond2Comp").val
                  var Cond2Value = getState("javascript.0.Timer." + path + ".Editor.Cond2Value").val
                  var strCond2 = "getState(\"" + ConditionJSON[Cond2State] + "\").val " + Cond2Comp + " " + Cond2Value
                  setState("javascript.0.Timer." + path + ".Editor.Condition2", strCond2);
                  if (Cond2State != "" && Cond2Comp != "" && Cond2Value != "")
                  {
                      setState("javascript.0.Timer." + path + ".Editor.Cond2Result", eval(strCond2));
                  }
              });
          
              on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Value'), change: "any", ack: false}, function (obj) {
                  var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                  var Cond3State = getState("javascript.0.Timer." + path + ".Editor.Cond3State").val
                  var Cond3Comp = getState("javascript.0.Timer." + path + ".Editor.Cond3Comp").val
                  var Cond3Value = getState("javascript.0.Timer." + path + ".Editor.Cond3Value").val
                  var strCond3 = "getState(\"" + ConditionJSON[Cond3State] + "\").val " + Cond3Comp + " " + Cond3Value
                  setState("javascript.0.Timer." + path + ".Editor.Condition3", strCond3);
                  if (Cond3State != "" && Cond3Comp != "" && Cond3Value != "")
                  {
                      setState("javascript.0.Timer." + path + ".Editor.Cond3Result", eval(strCond3));
                  }
              });
          

          Oder fällt dir eine bessere Lösung ein? Du kennst den Script besser

          G 2 Antworten Letzte Antwort
          0
          • H HelmutS

            @GiuseppeS
            Stimmt, beim ersten Aufruf kommt ein Fehler.
            Ich habe es jetzt so gelöst:

                // Trigger zum Erstellen der Bedingungen als String für späteres eval() (3x)
                on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Value'), change: "any", ack: false}, function (obj) {
                    var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                    var Cond1State = getState("javascript.0.Timer." + path + ".Editor.Cond1State").val
                    var Cond1Comp = getState("javascript.0.Timer." + path + ".Editor.Cond1Comp").val
                    var Cond1Value = getState("javascript.0.Timer." + path + ".Editor.Cond1Value").val
                    var strCond1 = "getState(\"" + ConditionJSON[Cond1State] + "\").val " + Cond1Comp + " " + Cond1Value
                    setState("javascript.0.Timer." + path + ".Editor.Condition1", strCond1);
                    if (Cond1State != "" && Cond1Comp != "" && Cond1Value != "")
                    {
                        setState("javascript.0.Timer." + path + ".Editor.Cond1Result", eval(strCond1));
                    }
                });
            
                on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Value'), change: "any", ack: false}, function (obj) {
                    var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                    var Cond2State = getState("javascript.0.Timer." + path + ".Editor.Cond2State").val
                    var Cond2Comp = getState("javascript.0.Timer." + path + ".Editor.Cond2Comp").val
                    var Cond2Value = getState("javascript.0.Timer." + path + ".Editor.Cond2Value").val
                    var strCond2 = "getState(\"" + ConditionJSON[Cond2State] + "\").val " + Cond2Comp + " " + Cond2Value
                    setState("javascript.0.Timer." + path + ".Editor.Condition2", strCond2);
                    if (Cond2State != "" && Cond2Comp != "" && Cond2Value != "")
                    {
                        setState("javascript.0.Timer." + path + ".Editor.Cond2Result", eval(strCond2));
                    }
                });
            
                on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Value'), change: "any", ack: false}, function (obj) {
                    var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                    var Cond3State = getState("javascript.0.Timer." + path + ".Editor.Cond3State").val
                    var Cond3Comp = getState("javascript.0.Timer." + path + ".Editor.Cond3Comp").val
                    var Cond3Value = getState("javascript.0.Timer." + path + ".Editor.Cond3Value").val
                    var strCond3 = "getState(\"" + ConditionJSON[Cond3State] + "\").val " + Cond3Comp + " " + Cond3Value
                    setState("javascript.0.Timer." + path + ".Editor.Condition3", strCond3);
                    if (Cond3State != "" && Cond3Comp != "" && Cond3Value != "")
                    {
                        setState("javascript.0.Timer." + path + ".Editor.Cond3Result", eval(strCond3));
                    }
                });
            

            Oder fällt dir eine bessere Lösung ein? Du kennst den Script besser

            G Offline
            G Offline
            GiuseppeS
            schrieb am zuletzt editiert von
            #452

            @HelmutS

            Ich überlege auch schon, wie man das am effektivsten anpasst. Ich denke, den Fehler einfach mit try/catch abzufangen, wird die einfachste Lösung sein, ohne zuviel komplexen Code zu nutzen.

            Werde deinen Code daher weitestgehend übernehmen und innerhalb des if-Statements ein try/catch einbauen. Muss aber ehrlich gesagt testen, ob es mit eval() überhaupt funktioniert. Habe es noch nie getestet...

            1 Antwort Letzte Antwort
            0
            • H HelmutS

              @GiuseppeS
              Stimmt, beim ersten Aufruf kommt ein Fehler.
              Ich habe es jetzt so gelöst:

                  // Trigger zum Erstellen der Bedingungen als String für späteres eval() (3x)
                  on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond1Value'), change: "any", ack: false}, function (obj) {
                      var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                      var Cond1State = getState("javascript.0.Timer." + path + ".Editor.Cond1State").val
                      var Cond1Comp = getState("javascript.0.Timer." + path + ".Editor.Cond1Comp").val
                      var Cond1Value = getState("javascript.0.Timer." + path + ".Editor.Cond1Value").val
                      var strCond1 = "getState(\"" + ConditionJSON[Cond1State] + "\").val " + Cond1Comp + " " + Cond1Value
                      setState("javascript.0.Timer." + path + ".Editor.Condition1", strCond1);
                      if (Cond1State != "" && Cond1Comp != "" && Cond1Value != "")
                      {
                          setState("javascript.0.Timer." + path + ".Editor.Cond1Result", eval(strCond1));
                      }
                  });
              
                  on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond2Value'), change: "any", ack: false}, function (obj) {
                      var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                      var Cond2State = getState("javascript.0.Timer." + path + ".Editor.Cond2State").val
                      var Cond2Comp = getState("javascript.0.Timer." + path + ".Editor.Cond2Comp").val
                      var Cond2Value = getState("javascript.0.Timer." + path + ".Editor.Cond2Value").val
                      var strCond2 = "getState(\"" + ConditionJSON[Cond2State] + "\").val " + Cond2Comp + " " + Cond2Value
                      setState("javascript.0.Timer." + path + ".Editor.Condition2", strCond2);
                      if (Cond2State != "" && Cond2Comp != "" && Cond2Value != "")
                      {
                          setState("javascript.0.Timer." + path + ".Editor.Cond2Result", eval(strCond2));
                      }
                  });
              
                  on({id: new RegExp('javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Comp' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3State' + "|" + 'javascript\\.0\\.Timer\\.' + path + '\\.Editor\\.Cond3Value'), change: "any", ack: false}, function (obj) {
                      var ConditionJSON = JSON.parse(getState("javascript.0.Timer." + path + ".ConditionJSON").val);
                      var Cond3State = getState("javascript.0.Timer." + path + ".Editor.Cond3State").val
                      var Cond3Comp = getState("javascript.0.Timer." + path + ".Editor.Cond3Comp").val
                      var Cond3Value = getState("javascript.0.Timer." + path + ".Editor.Cond3Value").val
                      var strCond3 = "getState(\"" + ConditionJSON[Cond3State] + "\").val " + Cond3Comp + " " + Cond3Value
                      setState("javascript.0.Timer." + path + ".Editor.Condition3", strCond3);
                      if (Cond3State != "" && Cond3Comp != "" && Cond3Value != "")
                      {
                          setState("javascript.0.Timer." + path + ".Editor.Cond3Result", eval(strCond3));
                      }
                  });
              

              Oder fällt dir eine bessere Lösung ein? Du kennst den Script besser

              G Offline
              G Offline
              GiuseppeS
              schrieb am zuletzt editiert von GiuseppeS
              #453

              @HelmutS

              Habe den Code von dir nun 1:1 übernommen. Try/Catch habe ich mal weggelassen. Wenn jemand seinen Boolean-State mit einem Zahlenwert vergleichen würde, würde dieser Fehler auch abgefangen werden, was nicht für die Fehlersuche im Nachgang nicht sinnvoll wäre.

              Meine einzige Anpassung war nur folgende. Statt

                      if (TimerJSON[device][nr].Conditions[1].ConditionStr != ""){
                          setState("javascript.0.Timer." + path + ".Editor.Cond1Result", eval(TimerJSON[device][nr].Conditions[1].ConditionStr));
                      }
                      if (TimerJSON[device][nr].Conditions[2].ConditionStr != ""){
                          setState("javascript.0.Timer." + path + ".Editor.Cond2Result", eval(TimerJSON[device][nr].Conditions[2].ConditionStr));
                      }
                      if (TimerJSON[device][nr].Conditions[3].ConditionStr != ""){
                          setState("javascript.0.Timer." + path + ".Editor.Cond3Result", eval(TimerJSON[device][nr].Conditions[3].ConditionStr));
                      }
              

              habe ich folgendes eingesetzt:

                      for (let i = 1; i <= 3; i++){
                          setState("javascript.0.Timer." + path + ".Editor.Cond" + i + "Result", eval(TimerJSON[device][nr].Conditions[i].ConditionStr));
                      // weitere States werden gesetzt.... weiter oben entfernt
                      }
              

              Werde jetzt allgemein nur eine Kleinigkeit ergänzen: Wenn die Anzahl der Bedingungen verringert wird, möchte ich die nicht mehr genutzten States leeren. Aktuell stehen weiterhin Werte in den States bzw. im Main-JSON, was mich schon länger stört.

              1 Antwort Letzte Antwort
              0
              • G Offline
                G Offline
                GiuseppeS
                schrieb am zuletzt editiert von
                #454

                So Update ist hochgeladen. Für ein manuelles Update einfach das Skript unterhalb des Variablen-Bereichs übernehmen (Falls vom letzten Update kommend). Zusätzlich könnt ihr das PopUp View neu importieren. Alternativ können auch die Farbeinstellungen der 9 Bedingungs-Widgets übernommen werden.


                Changelog 26.04.2020

                • Minütliches Flackern der nächsten Timer abgestellt. Nur noch bei Änderungen gibts ein Flackern
                • Bedingungen werden während der Eingabe ausgewertet und farblich im Editor hervorgehoben (Danke an HelmutS)
                • Wenn Bedingungen leer oder fehlerhaft sind, wird das PopUp-Fenster nicht geschlossen. Log wird ausgegeben.

                Wenn Bedingungen fehlerhaft sind, wird das PopUp beim Schließen über Button "Übernehmen" nicht geschlossen. Im iobroker Log wird auch entsprechend eine Ausgabe erzeugt. Hatte jetzt bestimmt eine Stunde versucht, diese Ausgabe dynamisch im PopUp direkt anzeigen zu lassen, aber erfolglos. Wollte das Error-Textfeld über html-Widget und dynamischer Sichtbarkeit realisieren, aber leider werden dahinterliegende Widgets überdeckt (Steuerung nicht möglich) trotz "Unsichtbarkeit" des zusätzlichen Widgets.

                Danke @HelmutS

                H 1 Antwort Letzte Antwort
                0
                • G GiuseppeS

                  So Update ist hochgeladen. Für ein manuelles Update einfach das Skript unterhalb des Variablen-Bereichs übernehmen (Falls vom letzten Update kommend). Zusätzlich könnt ihr das PopUp View neu importieren. Alternativ können auch die Farbeinstellungen der 9 Bedingungs-Widgets übernommen werden.


                  Changelog 26.04.2020

                  • Minütliches Flackern der nächsten Timer abgestellt. Nur noch bei Änderungen gibts ein Flackern
                  • Bedingungen werden während der Eingabe ausgewertet und farblich im Editor hervorgehoben (Danke an HelmutS)
                  • Wenn Bedingungen leer oder fehlerhaft sind, wird das PopUp-Fenster nicht geschlossen. Log wird ausgegeben.

                  Wenn Bedingungen fehlerhaft sind, wird das PopUp beim Schließen über Button "Übernehmen" nicht geschlossen. Im iobroker Log wird auch entsprechend eine Ausgabe erzeugt. Hatte jetzt bestimmt eine Stunde versucht, diese Ausgabe dynamisch im PopUp direkt anzeigen zu lassen, aber erfolglos. Wollte das Error-Textfeld über html-Widget und dynamischer Sichtbarkeit realisieren, aber leider werden dahinterliegende Widgets überdeckt (Steuerung nicht möglich) trotz "Unsichtbarkeit" des zusätzlichen Widgets.

                  Danke @HelmutS

                  H Offline
                  H Offline
                  HelmutS
                  schrieb am zuletzt editiert von
                  #455

                  @GiuseppeS
                  Ich danke dir für die viele Arbeit

                  1 Antwort Letzte Antwort
                  0
                  • L Offline
                    L Offline
                    Lachi
                    schrieb am zuletzt editiert von
                    #456

                    Super Arbeit vielen Dank,
                    du benutzt den Timer doch auch fürs Handy oder?
                    Welche app benutzt du den dafür?
                    Ich habe die io-app und da wird es nicht richtig dargestellt, widget Eigenschaften nicht übernommen, view zu groß dargestellt.
                    Mache ich was falsch?

                    G 1 Antwort Letzte Antwort
                    0
                    • L Lachi

                      Super Arbeit vielen Dank,
                      du benutzt den Timer doch auch fürs Handy oder?
                      Welche app benutzt du den dafür?
                      Ich habe die io-app und da wird es nicht richtig dargestellt, widget Eigenschaften nicht übernommen, view zu groß dargestellt.
                      Mache ich was falsch?

                      G Offline
                      G Offline
                      GiuseppeS
                      schrieb am zuletzt editiert von GiuseppeS
                      #457

                      @Lachi
                      Ich verwende ein Android Handy und darin rufe ich mit Google Chrome die VIS Seite im Browser auf. Auf dem Android Handy nutze ich nicht die App da ich schon unabhängig von dem Timer Probleme mit der Darstellung hatte.
                      Meine bessere Hälfte nutzt die offizielle ios ioBroker App. Darin wird sich alles korrekt angezeigt.

                      1 Antwort Letzte Antwort
                      0
                      • M Offline
                        M Offline
                        manu96
                        schrieb am zuletzt editiert von
                        #458

                        @GiuseppeS
                        Bin gerade auf deine Zeitsteuerung mithilfe von VIS gestoßesen. Mich würde nur einmal interessieren wie du die verschiedenen Geräte ansteuerst? Bei mir sind alle Jalousien und Markisen über fhem angeschlossen und müssten daher dort geschaltet werden. Ist das innerhalb deines Skriptes irgendwo einstellbar?

                        Trotzdem erstmal vielen Dank für deine Arbeit und das bereitstellen.
                        LG, Manuel

                        G 1 Antwort Letzte Antwort
                        0
                        • M manu96

                          @GiuseppeS
                          Bin gerade auf deine Zeitsteuerung mithilfe von VIS gestoßesen. Mich würde nur einmal interessieren wie du die verschiedenen Geräte ansteuerst? Bei mir sind alle Jalousien und Markisen über fhem angeschlossen und müssten daher dort geschaltet werden. Ist das innerhalb deines Skriptes irgendwo einstellbar?

                          Trotzdem erstmal vielen Dank für deine Arbeit und das bereitstellen.
                          LG, Manuel

                          G Offline
                          G Offline
                          GiuseppeS
                          schrieb am zuletzt editiert von GiuseppeS
                          #459

                          @manu96
                          Sind deine Geräte von ioBroker aus erreichbar?
                          Grundsätzlich funktioniert das Einbinden im Skript über eine ioBroker Aufzählung.
                          Wenn Du deine fhem Geräte in ioBroker siehst, müsstest Du einfach diese Geräte in eine Aufzählung setzen und diese wiederum im Skript ganz oben eingeben.

                          Es müssten mit dem Skript alle Arten von Geräten steuerbar sein, insofern diese nur ein State zum Steuern benötigen. In die Aufzählung dürfen nur States, keine übergeordnete Ordner (Channels bzw. Devices genannt).

                          M 1 Antwort Letzte Antwort
                          1
                          • G GiuseppeS

                            @manu96
                            Sind deine Geräte von ioBroker aus erreichbar?
                            Grundsätzlich funktioniert das Einbinden im Skript über eine ioBroker Aufzählung.
                            Wenn Du deine fhem Geräte in ioBroker siehst, müsstest Du einfach diese Geräte in eine Aufzählung setzen und diese wiederum im Skript ganz oben eingeben.

                            Es müssten mit dem Skript alle Arten von Geräten steuerbar sein, insofern diese nur ein State zum Steuern benötigen. In die Aufzählung dürfen nur States, keine übergeordnete Ordner (Channels bzw. Devices genannt).

                            M Offline
                            M Offline
                            manu96
                            schrieb am zuletzt editiert von
                            #460

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

                            @manu96
                            Sind deine Geräte von ioBroker aus erreichbar?
                            Grundsätzlich funktioniert das Einbinden im Skript über eine ioBroker Aufzählung.
                            Wenn Du deine fhem Geräte in ioBroker siehst, müsstest Du einfach diese Geräte in eine Aufzählung setzen und diese wiederum im Skript ganz oben eingeben.

                            Es müssten mit dem Skript alle Arten von Geräten steuerbar sein, insofern diese nur ein State zum Steuern benötigen. In die Aufzählung dürfen nur States, keine übergeordnete Ordner (Channels bzw. Devices genannt).

                            Ok vielen Dank für die Info. Dann teste ich mal.

                            1 Antwort Letzte Antwort
                            1
                            • E Offline
                              E Offline
                              echicor
                              schrieb am zuletzt editiert von
                              #461

                              Hi Zusammen,

                              ich hatte das Script und die View bereits mit Stand aus Septemper 2019 am laufen. Jetzt habe ich heute die aktuellsten Versionen des Scripts und des Views bei mir eingespielt und bin auf ein Problem gestoßen. Ich kann keine Einträge mehr editieren :confused:

                              Im Editor sieht meine View aktuell so aus:
                              2a245e59-f278-41ba-aca6-0216d5b41038-image.png
                              Wie man sieht, habe ich das "EDIT"-View nach links unten verschoben, dieses hat bei mir die ID "w00657".

                              Im Script selbst habe ich dies natürlich auch angepasst:
                              36bd9465-a40b-4be9-913b-ae0d4540cad8-image.png

                              Wenn ich nun jedoch am Tablet oder wie hier am Rechner im Browser einen Eintrag editieren möchte bekomme ich die Fehlermeldung, das der View nicht existieren würde (error: view not found.error: view not found.error: view not found.error: view not found.):
                              2f70a0d0-a0dc-48a9-a676-c4461d9b68c1-image.png

                              Was ich schon probiert habe, ist, dass ich mal ein neues View angelegt habe und dort alles importiert habe. Danach habe ich das Skript mit dem Widget entsprechend angepasst. Leider funktionierte das aber auch nicht.

                              Vielleich hat jemand einen Tipp wie ich die Einträge wieder editieren kann? Wäre echt dankbar dafür.

                              H 1 Antwort Letzte Antwort
                              0
                              • E echicor

                                Hi Zusammen,

                                ich hatte das Script und die View bereits mit Stand aus Septemper 2019 am laufen. Jetzt habe ich heute die aktuellsten Versionen des Scripts und des Views bei mir eingespielt und bin auf ein Problem gestoßen. Ich kann keine Einträge mehr editieren :confused:

                                Im Editor sieht meine View aktuell so aus:
                                2a245e59-f278-41ba-aca6-0216d5b41038-image.png
                                Wie man sieht, habe ich das "EDIT"-View nach links unten verschoben, dieses hat bei mir die ID "w00657".

                                Im Script selbst habe ich dies natürlich auch angepasst:
                                36bd9465-a40b-4be9-913b-ae0d4540cad8-image.png

                                Wenn ich nun jedoch am Tablet oder wie hier am Rechner im Browser einen Eintrag editieren möchte bekomme ich die Fehlermeldung, das der View nicht existieren würde (error: view not found.error: view not found.error: view not found.error: view not found.):
                                2f70a0d0-a0dc-48a9-a676-c4461d9b68c1-image.png

                                Was ich schon probiert habe, ist, dass ich mal ein neues View angelegt habe und dort alles importiert habe. Danach habe ich das Skript mit dem Widget entsprechend angepasst. Leider funktionierte das aber auch nicht.

                                Vielleich hat jemand einen Tipp wie ich die Einträge wieder editieren kann? Wäre echt dankbar dafür.

                                H Offline
                                H Offline
                                HelmutS
                                schrieb am zuletzt editiert von
                                #462

                                @echicor
                                Was ist beim EDIT-Button unter Dialog eingestellt?

                                E 1 Antwort Letzte Antwort
                                0
                                • H HelmutS

                                  @echicor
                                  Was ist beim EDIT-Button unter Dialog eingestellt?

                                  E Offline
                                  E Offline
                                  echicor
                                  schrieb am zuletzt editiert von
                                  #463

                                  @HelmutS
                                  Das wars...da stand noch der View-Titel vom Erfinder drin :face_with_rolling_eyes:
                                  Ich habe es jetzt mit meinem View angepasst und nun erscheint auch wieder der Dialog zum Editieren. Danke dir für den Wink mit dem Zaunpfahl ;-)

                                  7172683f-0f4c-4883-9c7d-72831755425a-image.png

                                  d3755c51-9b87-4d76-aa3c-64e9d21c67c2-image.png

                                  1 Antwort Letzte Antwort
                                  0
                                  • G Offline
                                    G Offline
                                    GiuseppeS
                                    schrieb am zuletzt editiert von GiuseppeS
                                    #464

                                    Hallo Leute, habe mir speziell für die Rollladen Steuerung ein Skript erstellt.
                                    Screenshot_20200525_134410.jpg

                                    Es ist möglich über eine einzige Sollwert Vorgabe mehrere Geräte zu steuern.
                                    Wie immer ist das Skript generisch gestaltet. D.h. über die Angabe einer Aufzählung im oberen Skript Bereich wird die html Tabelle erstellt. Es können somit auch andere Geräte oder Eigenschaften, wie z.B. Dimmer-Werte mehrerer Lampen angegeben werden.

                                    Es kann statt eine Aufzählung auch eine Liste von Objekt-IDs (als Array) angegeben werden. Könnte das auch in den Standard Timer einbringen falls gewünscht.
                                    Aktivieren bzw Deaktivieren der einzelnen Einträge in Tabelle über einen Klick/Touch auf die Zeile. Istwerte werden rein informativ dargestellt.

                                    In VIS wird ein html Widget für die Tabelle verwendet. Für die Sollwert Vorgabe kann nach eigenem Geschmack ein Widget genutzt werden. Sollwert Vorgabe sollte in das neue State "SetValue" geschrieben werden.
                                    Ist das State "DeviceList" kann die Reihenfolge innerhalb der Tabelle manipuliert werden. Hier einfach Geräte untereinander tauschen, wenn gewünscht.

                                    Viel Spaß

                                    ControlAll.zip

                                    GlasfaserG 1 Antwort Letzte Antwort
                                    1
                                    • G GiuseppeS

                                      Hallo Leute, habe mir speziell für die Rollladen Steuerung ein Skript erstellt.
                                      Screenshot_20200525_134410.jpg

                                      Es ist möglich über eine einzige Sollwert Vorgabe mehrere Geräte zu steuern.
                                      Wie immer ist das Skript generisch gestaltet. D.h. über die Angabe einer Aufzählung im oberen Skript Bereich wird die html Tabelle erstellt. Es können somit auch andere Geräte oder Eigenschaften, wie z.B. Dimmer-Werte mehrerer Lampen angegeben werden.

                                      Es kann statt eine Aufzählung auch eine Liste von Objekt-IDs (als Array) angegeben werden. Könnte das auch in den Standard Timer einbringen falls gewünscht.
                                      Aktivieren bzw Deaktivieren der einzelnen Einträge in Tabelle über einen Klick/Touch auf die Zeile. Istwerte werden rein informativ dargestellt.

                                      In VIS wird ein html Widget für die Tabelle verwendet. Für die Sollwert Vorgabe kann nach eigenem Geschmack ein Widget genutzt werden. Sollwert Vorgabe sollte in das neue State "SetValue" geschrieben werden.
                                      Ist das State "DeviceList" kann die Reihenfolge innerhalb der Tabelle manipuliert werden. Hier einfach Geräte untereinander tauschen, wenn gewünscht.

                                      Viel Spaß

                                      ControlAll.zip

                                      GlasfaserG Offline
                                      GlasfaserG Offline
                                      Glasfaser
                                      schrieb am zuletzt editiert von
                                      #465

                                      @GiuseppeS

                                      Nur zur Info :
                                      Schöne Idee , aber ..... da würde z.B. bei vielen gleichzeitigen Befehlen die CCU Homematic (Raspberrymatic ) der DutyCycle explodieren . bzw. die Befehle sich im Sendeprotokoll überschneiden .

                                      Synology 918+ 16GB - ioBroker in Docker v9 , VISO auf Trekstor Primebook C13 13,3" , Hikvision Domkameras mit Surveillance Station .. CCU RaspberryMatic in Synology VM .. Zigbee CC2538+CC2592 .. Sonoff .. KNX .. Modbus ..

                                      G 1 Antwort Letzte Antwort
                                      0
                                      • GlasfaserG Glasfaser

                                        @GiuseppeS

                                        Nur zur Info :
                                        Schöne Idee , aber ..... da würde z.B. bei vielen gleichzeitigen Befehlen die CCU Homematic (Raspberrymatic ) der DutyCycle explodieren . bzw. die Befehle sich im Sendeprotokoll überschneiden .

                                        G Offline
                                        G Offline
                                        GiuseppeS
                                        schrieb am zuletzt editiert von GiuseppeS
                                        #466

                                        @Glasfaser
                                        Okay, da hast du recht. Bei 7 Rollläden über WLAN habe ich keine Probleme. Aber andere Protokolle sind anfälliger. Allerdings, wenn der Bedarf der allgemeinen Nutzung besteht:
                                        Die Sollwerte der einzelnen Geräte werden ja innerhalb einer Schleife im Skript abgearbeitet; eine einstellbare Zeitverzögerung würde das Problem beheben. So wie es beim Scene Adapter auch möglich ist.

                                        Das gute ist: hier ist sehr viel Recycling von der Zeitsteuerung drin. War in 2/3 Stündchen erledigt 😁

                                        1 Antwort Letzte Antwort
                                        0
                                        • M Offline
                                          M Offline
                                          micklafisch
                                          schrieb am zuletzt editiert von
                                          #467

                                          Hallo, ich bin gerade dabei das ganze von der Version 15.09.2019 auf die aktuelle Version umzustellen (im Grunde aufgrund der unzähligen Anpassungen und Änderungen einmal das alte bisherige umbenennen und einmal komplett neuer Import aller Anhänge und Anpassung der Variablen und meiner VIS).

                                          Was ich nun aufgrund der "oneclick" bzw. "doubleclick"-Aktion nicht mehr schaffe ist, dass mein Edit-Popup ein anders ist. Die Variable "DlgWidget" hab ich geändert (Widget ist materialdesign - dialog view). Ich habe das Widget permanent angezeigt. Bei der Auswahl eines Timers kann ich damit auch die View korrekt öffnen, aber bei einem doppelklick öffnet er weiterhin das alte Widget "jqui container button".

                                          Woran kann das noch hängen?

                                          GlasfaserG 3 Antworten Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          278

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          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