Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. [gelöst] - VIS Intance Id - automatisiert ermitteln

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] - VIS Intance Id - automatisiert ermitteln

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

      @bananajoe
      na, dass werde ich nachher gleich mal testen.
      Danke.

      Melde mich dann.

      1 Reply Last reply Reply Quote 0
      • bahnuhr
        bahnuhr Forum Testing Most Active @BananaJoe last edited by

        @bananajoe sagte in VIS Intance Id - automatisiert ermitteln:

        zweites Merkmal wie IP-Adresse

        Das müssten wir noch hinbekommen.
        Vielleicht meldet sich noch jemand der dies weiß.

        BananaJoe 1 Reply Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @BananaJoe last edited by

          @bananajoe sagte in VIS Intance Id - automatisiert ermitteln:

          Hartnäckigkeit - wenn das mit dem Timeout nicht klappt (und vis.intance noch null ist) im begrenzten Umfang wiederholen.

          das macht der link, den ich gepostet habe - dort wird auf etwas gewartet und immer wieder versucht , den wert zu bekommen - diese funktionen sind sozusagen um das vis.instance gelegt

          die instance id ist zum unterscheiden da - jeder browser bekommt seine eigene id - egal ob selber rechner oder ein anderer - du musst ihn nur einmal in der vis bekannt machen und kannst dann unterscheiden - ip oder hostnamen sind etwas komplizierter rauszubekommen - daher verstehe ich eigentlich deine frage nicht - mit der instance id weiß man, wer wer oder was da gerade die vis anzeigen will

          1 Reply Last reply Reply Quote 0
          • BananaJoe
            BananaJoe Most Active @bahnuhr last edited by BananaJoe

            @bahnuhr google ist mein Freund:

            alert(location.hostname);
            

            ergibt ein Popup mit der IP-Adresse bzw. den DNS Hostnamen (je nachdem was er liefern kann), könnte man auch so wegschreiben.
            Oder besser, im Namen des Datenpunktes zum wegschreiben nutzen, dann hätte ich passend zur IP immer die ID

            ist quatsch, lieger die IP des ioBroker-Servers

            liv-in-sky bahnuhr 2 Replies Last reply Reply Quote 0
            • Jey Cee
              Jey Cee Developer @BananaJoe last edited by Jey Cee

              @bananajoe schau dir mal das Skript an. Das muss im Browser ausgeführt werden, in unserem Fall in VIS eingebetet werden, dann liefert es dir die Adresse vom Gerät.

              liv-in-sky 1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @Jey Cee last edited by liv-in-sky

                @jey-cee sag ich doch - voll kompliziert 🙂 - die instance id reicht völlig aus, um die unterschiedlichen clients herauszufinden

                1 Reply Last reply Reply Quote 0
                • liv-in-sky
                  liv-in-sky @BananaJoe last edited by

                  @bananajoe

                  zum warten auf ein objet, bevor man vis.instance aufrufen kann meinte ich diesen link - hatte das in einem anderen thread gepostet

                  https://forum.iobroker.net/topic/48663/howto-skripte-im-vis-editor-mit-jquery

                  1 Reply Last reply Reply Quote 0
                  • bahnuhr
                    bahnuhr Forum Testing Most Active @BananaJoe last edited by

                    @bananajoe

                    Bist du weiter gekommen mit den Hinweisen und Scripten von @liv-in-sky und @Jey-Cee .

                    Ich habs probiert mit dem Script von @Jey-Cee und auch andere aus dem Netz.
                    Hat aber irgendwie nicht geklappt.

                    BananaJoe 1 Reply Last reply Reply Quote 0
                    • BananaJoe
                      BananaJoe Most Active @bahnuhr last edited by

                      @bahnuhr bei mir auch nicht. Das mit dem Warten auf das Widget hat bei mir auch nicht funktioniert.

                      Habe aber noch nicht viel rumprobiert.

                      1 Reply Last reply Reply Quote 0
                      • liv-in-sky
                        liv-in-sky last edited by liv-in-sky

                        in beispiel:

                        zum testen habe ich ein neues project gemacht, damit man nicht den ganzen durcheinander darin hat

                        2 html widgets
                        das obere wird mit der instance id geschrieben, wenn das widget da ist
                        das untere wartet bis die instance id vorhanden ist und schreibt dann den text in das widgets
                        am anfang (im vis-editor) sind die widgets ohne text !!

                        AApossis (161).gif

                        script im vis editor

                         function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
                        
                                if (counter < 100) {
                        
                         
                        
                                    setTimeout(function () {
                        
                                        if (parent.find(elementPath).length > 0) {
                        
                                            if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
                        
                                            callBack();
                        
                                        } else {
                        
                                            if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
                        
                                            counter++
                        
                                            waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
                        
                                        }
                        
                                    }, 1);
                        
                                } else {
                        
                                   if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
                        
                                    callBack();
                        
                                }
                        
                            }
                        
                        
                        
                        
                        
                        waitForElement($('body'),'#w00001', 'dummy', 'dummy', function () {
                        
                                // Widget ist vollständig geladen, wir können irgendwas damit machen
                           console.log(vis.instance)
                            $( "#w00001" ).text( 'Test mit warten auf Widget Instance ID: '+vis.instance);
                         
                        
                            }, 0, true);
                            
                            
                        waitForElement($('body'),'vis.instance', 'dummy', 'dummy', function () {
                        
                                // Widget ist vollständig geladen, wir können irgendwas damit machen
                           console.log(vis.instance)
                            $( "#w00002" ).text( 'Warten auf VIS-Instance Instance ID: '+vis.instance);
                         
                        
                            }, 0, true);
                        

                        [{"tpl":"tplHtml","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0},"style":{"left":"718px","top":"655px","color":"#d8df2a","background-color":"#3b0c0c"},"widgetSet":"basic"},{"tpl":"tplHtml","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":true,"g_css_background":true,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0},"style":{"left":"719px","top":"856px","color":"#d8df2a","background-color":"#3b0c0c"},"widgetSet":"basic"}]
                        

                        damit weiß man dann, welcher browser bzw welches gerät gerade browsen wil

                        bahnuhr 1 Reply Last reply Reply Quote 0
                        • bahnuhr
                          bahnuhr Forum Testing Most Active @liv-in-sky last edited by

                          @liv-in-sky

                          Habs ausprobiert.
                          Wenn du einen Browser im kiosk Mode nimmst, dann wartet er immer noch auf den Klick.

                          function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
                                  if (counter < 100) {
                                      setTimeout(function () {
                                          if (parent.find(elementPath).length > 0) {
                                              if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
                                              callBack();
                                          } else {
                                              if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
                                              counter++
                                              waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
                                          }
                                      }, 1);
                                  } else {
                                     if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
                                      callBack();
                                  }
                              }
                           
                          waitForElement($('body'),'#w02705', 'dummy', 'dummy', function () {
                                  // Widget ist vollständig geladen, wir können irgendwas damit machen
                             console.log(vis.instance)
                              setTimeout( () => { 
                                  $('#w02705>div>span>span').trigger('click'); 
                              }, 2000);
                              setTimeout( () => { 
                          	$( "#w02256" ).text( 'Test mit warten auf Widget Instance ID: '+vis.instance);
                              }, 3000);
                              }, 0, true);
                              
                          waitForElement($('body'),'vis.instance', 'dummy', 'dummy', function () {
                                  // Widget ist vollständig geladen, wir können irgendwas damit machen
                             console.log(vis.instance)
                              $( "#w02259" ).text( 'Warten auf VIS-Instance Instance ID: '+vis.instance);
                              }, 0, true);
                          

                          Habe mal einen timeout eingebaut. Klappt aber nur manchmal.

                          Wäre schön wenn wir dies mit der IP auch noch hinbekommen könnten.

                          mfg
                          Dieter

                          liv-in-sky 2 Replies Last reply Reply Quote 0
                          • liv-in-sky
                            liv-in-sky @bahnuhr last edited by

                            @bahnuhr

                            fully browser oder chromium

                            bahnuhr 1 Reply Last reply Reply Quote 0
                            • bahnuhr
                              bahnuhr Forum Testing Most Active @liv-in-sky last edited by

                              @liv-in-sky sagte in VIS Intance Id - automatisiert ermitteln:

                              @bahnuhr

                              fully browser oder chromium

                              win tablet mit MS edge

                              1 Reply Last reply Reply Quote 0
                              • liv-in-sky
                                liv-in-sky @bahnuhr last edited by liv-in-sky

                                @bahnuhr sagte in VIS Intance Id - automatisiert ermitteln:

                                Wenn du einen Browser im kiosk Mode nimmst, dann wartet er immer noch auf den Klick.

                                • welchen klick - über was redest du - bei meinem beispiel gibt es keinen klick
                                • edge kann ich nur am pc testen - funktioniert auch

                                @bahnuhr sagte in VIS Intance Id - automatisiert ermitteln:

                                Habe mal einen timeout eingebaut. Klappt aber nur manchmal.

                                ???? wo ?

                                @bahnuhr sagte in VIS Intance Id - automatisiert ermitteln:

                                Wäre schön wenn wir dies mit der IP auch noch hinbekommen könnten.

                                hatte ich schon vor langer zeit probiert und bin gescheitert - aufwand ist mir zu groß - da muss jmd anderer helfen

                                bahnuhr 1 Reply Last reply Reply Quote 0
                                • bahnuhr
                                  bahnuhr Forum Testing Most Active @liv-in-sky last edited by

                                  @liv-in-sky sagte in VIS Intance Id - automatisiert ermitteln:

                                  welchen klick - über was redest du - bei meinem beispiel gibt es keinen klick
                                  edge kann ich nur am pc testen - funktioniert auch

                                  ok, dann hab ich dein Script nicht verstanden.

                                  5be9d249-4011-49d6-a899-14d5f8127a23-image.png
                                  Welche widget Nr. müssen hier rein?
                                  oben hatte ich das widget Instanz, und unten das obere widget von dir.

                                  de1ed69f-09e2-45e7-b1ee-59cc8c18d6f6-image.png
                                  Und hier hatte ich dein unteres widget.

                                  Ist dies nicht korrekt ?

                                  @liv-in-sky sagte in VIS Intance Id - automatisiert ermitteln:

                                  ???? wo ?

                                  dies:

                                      setTimeout( () => { 
                                          $('#w02705>div>span>span').trigger('click'); 
                                      }, 2000);
                                      setTimeout( () => { 
                                  	$( "#w02256" ).text( 'Test mit warten auf Widget Instance ID: '+vis.instance);
                                      }, 3000);
                                  
                                  liv-in-sky 2 Replies Last reply Reply Quote 0
                                  • liv-in-sky
                                    liv-in-sky @bahnuhr last edited by

                                    @bahnuhr

                                    das sind 2 widgets - die haben bei mir die id's #00001 und #00002 - bei dir musst du nachsehen, welche id's erzeugt worden sind

                                    einmal wird auf #00001 gwartet und dann in das wisget #00001 geschrieben /geändert

                                    im 2ten widget wird auf vis.instance gewartet - bis das object von der vis erstellt wurde und dann wird der text in #00002 geschrieben

                                    beide widgets am anfang leer - kein tet enthalten

                                    bahnuhr BananaJoe 2 Replies Last reply Reply Quote 0
                                    • liv-in-sky
                                      liv-in-sky @bahnuhr last edited by liv-in-sky

                                      @bahnuhr sagte in VIS Intance Id - automatisiert ermitteln:

                                      setTimeout( () => {

                                      warum wartest du hier ? du kannst das ganze auch direkt in das script schreiben - du musst halt auf deine widget id's achten

                                      dieses waitForElement benötigt man, da man nicht genau weiß, was schon alles geladen und bekannt ist. man wartet also, bis lles da ist und dann schreibt man oder ändert man die widgets.

                                      waitForElement($('body'),'#w02705', 'dummy', 'dummy', function () {
                                      
                                              // Widget ist vollständig geladen, wir können irgendwas damit machen
                                         console.log(vis.instance)
                                          $( "#w02705" ).text( 'Test mit warten auf Widget Instance ID: '+vis.instance);
                                       
                                      
                                          }, 0, true);
                                      
                                      
                                      1 Reply Last reply Reply Quote 0
                                      • bahnuhr
                                        bahnuhr Forum Testing Most Active @liv-in-sky last edited by

                                        @liv-in-sky

                                        so, nochmal.
                                        5715ff6c-99fa-462d-b499-99d15e9b505a-image.png

                                        Ich habe beide widget eingefügt.
                                        Das obere hat die Nr. 2256 und das untere die Nr. 2259

                                        function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
                                                if (counter < 100) {
                                                    setTimeout(function () {
                                                        if (parent.find(elementPath).length > 0) {
                                                            if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
                                                            callBack();
                                                        } else {
                                                            if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
                                                            counter++
                                                            waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
                                                        }
                                                    }, 1);
                                                } else {
                                                   if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
                                                    callBack();
                                                }
                                            }
                                         
                                        waitForElement($('body'),'#w02256', 'dummy', 'dummy', function () {
                                                // Widget ist vollständig geladen, wir können irgendwas damit machen
                                           console.log(vis.instance)
                                        	$( "#w02256" ).text( 'Test mit warten auf Widget Instance ID: '+vis.instance);
                                            }, 0, true);
                                            
                                        waitForElement($('body'),'vis.instance', 'dummy', 'dummy', function () {
                                                // Widget ist vollständig geladen, wir können irgendwas damit machen
                                           console.log(vis.instance)
                                            $( "#w02259" ).text( 'Warten auf VIS-Instance Instance ID: '+vis.instance);
                                            }, 0, true);
                                        

                                        dein Script eingefügt und die Nr. eingetragen.

                                        In runtime kommt dann absolut nix.

                                        Kein Text, keine Instanz.
                                        f0441fd1-aba7-4c6d-b241-c9af6782f7da-image.png

                                        liv-in-sky 1 Reply Last reply Reply Quote 0
                                        • liv-in-sky
                                          liv-in-sky @bahnuhr last edited by

                                          @bahnuhr

                                          das schaut eigentlich richtig aus - kommt eine fehlermeldung in der entwicklungsumgebung ?

                                          1 Reply Last reply Reply Quote 0
                                          • BananaJoe
                                            BananaJoe Most Active @liv-in-sky last edited by

                                            @liv-in-sky @bahnuhr

                                            So, ich habe es noch mal angepasst, so läuft es bei mir:

                                            • Widget #00001 ist das (basic -Screen Resolution) Widget
                                            • Datenpunkt vom Typ String in welches die ID geschrieben wird: 0_userdata.0.Visualisierung.Instanzen.DC.Test-Instanzen
                                            • folgendes Skript im Reiter Skripte:
                                            // Funktion die auf ein Widget wartet,
                                            // Stammt von: https://forum.iobroker.net/topic/48663/howto-skripte-im-vis-editor-mit-jquery
                                            // Modifiziert: 30 Durchläufe maximal, 1 Sekunde Pause dazwischen
                                            function waitForElement(parent, elementPath, wid, widgetName, callBack, counter = 0, debug = false) {
                                                     if (counter < 30) {
                                                         setTimeout(function () {
                                                             if (parent.find(elementPath).length > 0) {
                                                                 if (debug) console.log(`[${widgetName} ${wid}] it took ${counter}ms to wait for the element '${elementPath}'`);
                                                                 callBack();
                                                             } else {
                                                                 if (debug) console.log(`[${widgetName} ${wid}] wait for element '${elementPath}'`);
                                                                 counter++
                                                                 waitForElement(parent, elementPath, wid, widgetName, callBack, counter, debug);
                                                             }
                                                         }, 1000);
                                                     } else {
                                                        if (debug) console.warn(`[${widgetName} ${wid}] stop waiting after ${counter} retries`);
                                                         callBack();
                                                    }
                                                }
                                             
                                            
                                            // Warten auf das (basic - Scren Resolution) Widget, ID ggf. anpassen
                                            waitForElement($('body'),'#w00001', 'dummy', 'dummy', function () {
                                               // Widget ist geladen, auf das Widget klicken, w00001 ist die ID von meinem basic - Screen Resolution Widget
                                                setTimeout( () => { 
                                                    $('#w00001>div>span>span').trigger('click'); 
                                                }, 1000);
                                                // und in einen Datenpunkt schreiben
                                                setTimeout( () => { 
                                                    vis.setValue('0_userdata.0.Visualisierung.Instanzen.DC.Test-Instanzen', vis.instance);
                                                }, 3000);
                                            }, 0, true);
                                            

                                            Die waitForElement wartet, wenn einfach so rauskopiert, nämlich nur 100 Durchläufe mit je 1ms pause. Das ist meine ich eindeutig zu wenig. Ich habe die Pausen auf 1 Sekunde und die Durchläufe auf 30 gesetzt.
                                            Dann wird mit 1 Sekunden Verzögerung auf das Widget geklickt und noch mal 2 Sekunden später der Datenpunkt gesetzt.
                                            Perfekt wäre jetzt noch eine Schleife die wartet das vis.instance einen Wert hat/gesetzt ist statt der Pause

                                            Wegen der IP: Ich meine mich erinnern zu können das es so - mit Absicht - nicht möglich ist. Aber man könnte seine "externe" IP herausbekommen. Das geht im Prinzip immer dadurch das einen externe Seite aufgerufen wird und einem zurückmeldet mit welcher IP man sich meldet. Wenn man das intern macht kommt natürlich auch die interne IP.

                                            liv-in-sky 1 Reply Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            899
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            13
                                            126
                                            11130
                                            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