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

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    [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

      Ich muss gestehen, dass ich jetzt nicht so richtig verstanden habe, was du meinst.

      Aber die IP ist bei mir nicht das Problem. Ich habe überall statische IP vergeben.

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

        @bahnuhr Ich poste es wenn es fertig ist - aber Zusammengefasst:

        • JavaScript welches in der VIS hinterlegt wird und welches beim Start / Laden von VIS einmalig ausgeführt wird
        • Das Skript holt sich per http-Aufruf den externen Helfer "ip.php" welche auf einen Webserver im lokalen Netzwerk liegen muss (kann der ioBroker sein) die eigene IP-Adresse
        • Das Skript schreibt die IP-Adresse in einen Datenpunkt von ioBroker (z.B. per Simple-API)
        • Auf dem ioBroker läuft ein zweites Skript welches durch die Änderung der IP angetriggert wird, nimmt den IP-Wert und wartet das sich der vis.0.control.instance Wert ändert (Da schreibt das VIS was gerade geladen hat seine Id rein wenn es fertig ist)
        • Tata, wir haben etwas eindeutiges um unseren Client/Tablet/Browser zu erkennen + die Instance-Id
          Das kann man dann ja in einen weiteren Datenpunkt hinterlegen damit die anderen eigenen Skripte nachschlagen können welche Id gerade welches Gerät hat.

        Wäre sogar noch Ausbaufähig indem der Browser-UserAgent Wert auch noch übermittelt wird, dann könnte man sogar verschiedene Browser auf einem Gerät unterscheiden.
        Umständlich ist nur das man einen extra Webserver nur für das Abfragen der IP-Adresse benötigt - was an den sinnvollen Vorgaben für JavaScript in Webbrowser liegt möglichst wenig Informationen über den lokalen Client zu erfahren.

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

          @bananajoe

          Ich glaube das funktioniert so nicht.
          Grund:
          Wenn ich edge im Kiosk mode aufrufe ist noch keine Instance erzeugt.
          Im DP vis.0.control.instance kommt:
          notdefined

          Ist auch logisch, denn die Instance wurde noch nicht erzeugt.

          Folglich muss man es irgendwie hinbekommen, dass o.g. Script "erzeuge Instance" bei Start von vis läuft.

          BananaJoe Peoples 2 Replies Last reply Reply Quote 0
          • BananaJoe
            BananaJoe Most Active @bahnuhr last edited by

            @bahnuhr mhh und notdefined kann man nicht als Id nutzen 👎

            bahnuhr 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:

              @bahnuhr mhh und notdefined kann man nicht als Id nutzen 👎

              keine Ahnung.

              Mein Ziel ist ja, die ID irgendwie nach sayit zu bekommen.
              Wenn das geht, dann würde ich halt notdefined dort eintragen.

              1 Reply Last reply Reply Quote 0
              • Peoples
                Peoples @bahnuhr last edited by Peoples

                @bahnuhr sagte in VIS Intance Id - automatisiert ermitteln:

                Folglich muss man es irgendwie hinbekommen, dass o.g. Script "erzeuge Instance" bei Start von vis läuft.

                Habt ihr mal versucht über $(document).ready in Vis euer script zu starten?

                So bekommt man nach dem die Seite "ready" ist zumindest mal einen "Alert"

                $( document ).ready(function() {
                    alert( "ready!" );
                });
                

                Man könnte zum Beispiel folgendes machen:

                $( document ).ready(function() {
                    $.get("http://XXXX/set/javascript.0.test.teststring?value=gesetzt", function(data, status){
                        alert("Data: " + data + "\nStatus: " + status);
                    });
                });
                

                So könnte man wenn man irgendwie an die Instanz - Daten kommt diese mit dem SimpleApi-Adapter in eine Javascript Variable schreiben um sie dann weiter zu verwenden

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

                  @peoples sagte in VIS Intance Id - automatisiert ermitteln:

                  @bahnuhr sagte in VIS Intance Id - automatisiert ermitteln:

                  Folglich muss man es irgendwie hinbekommen, dass o.g. Script "erzeuge Instance" bei Start von vis läuft.

                  Habt ihr mal versucht über $(document).ready in Vis euer script zu starten?

                  So bekommt man nach dem die Seite "ready" ist zumindest mal einen "Alert"

                  $( document ).ready(function() {
                      alert( "ready!" );
                  });
                  

                  schon erheblich besser, weil später. Da ist VIS schon gestartet, die URL steht auch schon fest aber er hat noch nichts geladen.
                  Die VIS-Variablen gibt dann noch nicht.

                  $( document ).ready(function() {
                      var variables = ""
                      for (var mynames in this) {
                          variables += mynames + "\n";
                      }
                      alert(variables);
                      alert(this.gauges.constructor);
                  });
                  

                  Über this bekomme ich alle Variablen / Zweige (Namespace?),
                  die wiederum kann man näher betrachten wenn man this um den Namen ergänzt, z.B. this.body

                  Ich behaupte das ist immer noch zu früh. ich müsste mal anders testen ob bei laufender VIS überhaupt Zugriff auf die vis.xxx gibt

                  1 Reply Last reply Reply Quote -1
                  • bahnuhr
                    bahnuhr Forum Testing Most Active last edited by bahnuhr

                    generateInstance:   function () {
                            if (typeof storage !== 'undefined') {
                                this.instance = (Math.random() * 4294967296).toString(16);
                                this.instance = '0000000' + this.instance;
                                this.instance = this.instance.substring(this.instance.length - 8);
                                $('#vis_instance').val(this.instance);
                                storage.set(this.storageKeyInstance, this.instance);
                            }
                        },
                    

                    Nochmal die Frage an alle:

                    Wie kann man es erreichen, dass VIS beim Start diese Funktion automatisch ausführt ?

                    mfg
                    Dieter

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

                      @bahnuhr

                      Ich habe die Idee das man das ganze über ein eigenes Widget lösen könnte. Da arbeite ich mich aber gerade erst ein (Beiträge dazu gibt es ja genug).

                      Ich habe schon in vielen Sprachen programmiert und bin - so glaube ich - fälschlicherweise davon ausgegangen das man auf die Variablen andere JavaScript-Prozesse innerhalb von VIS zugreifen könnte. Ich vermute aber die laufen isoliert und somit geht das gar nicht. Ich habe z.B. schon Erweiterungen für MediaWiki geschrieben, das ist in PHP, und da habe ich in jeder Extension Zugriff auf alle Variablen des Grundprogrammes. Das funktioniert aber gänzlich anders als beim JavaScript hier.

                      Wie genau das in JavaScript geht - da hat es bei mir noch nicht ganz klick gemacht (wie auch ein paar andere Dinge wie async/await).

                      Theoretisch könnte man den Code einfach aus dem vis-master vis.js übernehmen und selber ausführen und die Id speichern lassen. Aber ich vermute das deswegen der VIS Hauptprozesse das deswegen noch lange nicht übernimmt weil man die Id nur für den Bereich berechnet hat in dem das eigene Programm läuft (der this Bereich)

                      Ich werde da in der nächsten Zeit noch weiter tiefer Einsteigen.

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

                        @bananajoe

                        Danke für deine Info.
                        Wenn du Hilfe brauchst, sag Bescheid.

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

                          In der Datei: ...widgets/basic.html ist folgender Scriptbaustein:

                          <script id="tplScreenResolution"
                                  type="text/ejs"
                                  class="vis-tpl"
                                  data-vis-prev='<img src="widgets/basic/img/Prev_ScreenResolution.png"></img>'
                                  data-vis-set="basic"
                                  data-vis-type="tools"
                                  data-vis-name="Screen Resolution"
                                  data-vis-attrs="">
                              <div class="vis-widget <%== this.data.attr('class') %>" style="width:170px; height:75px; border: 1px solid #888; font-size: 12px; opacity: 0.8" id="<%= this.data.attr('wid') %>">
                          		<div id="div_<%= this.data.attr('wid') %>" style="padding: 10px">
                          			Default view: <span class='vis-resolution-default-view'></span><br>
                          			Width: <span class='vis-resolution-width'></span><br>
                          			Height: <span class='vis-resolution-height'></span><br>
                          			Instance: <span><%== vis.instance ? vis.instance : vis.binds.basic.createScreenText() %></span>
                          		</div>
                          		<%= vis.binds.basic.detectScreen(this.data.attr('wid')) %>
                              </div>
                          </script>
                          
                          

                          Dort habe ich folgendes ersetzt:
                          alt:

                          Instance: <span><%== vis.instance ? vis.instance : vis.binds.basic.createScreenText() %></span>
                          

                          neu:

                                              	if (!vis.instance) {
                                                  	vis.generateInstance();
                          			}
                          		        setTimeout(function () {
                          				Instance: <span><%== vis.instance ? vis.instance : vis.binds.basic.createScreenText() %></span>
                          		        }, 1000);
                          
                          

                          Ziel ist es:
                          Ich möchte, dass die Instanz gleich bei Start von vis erzeugt wird. Nicht erst beim klicken.

                          Hat aber nicht geklappt.

                          @apollon77
                          @Jey-Cee
                          @Jan1
                          @Thomas-Braun

                          Ihr seid doch Script Spezialisten. Könnt ihr mir hier mal helfen?

                          mfg
                          Dieter

                          Thomas Braun Jey Cee 2 Replies Last reply Reply Quote 0
                          • Thomas Braun
                            Thomas Braun Most Active @bahnuhr last edited by

                            @bahnuhr
                            Hab ich keinen Schimmer von.

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

                              @thomas-braun sagte in VIS Intance Id - automatisiert ermitteln:

                              @bahnuhr
                              Hab ich keinen Schimmer von.

                              Schade, trotzdem Danke für die Antwort.

                              1 Reply Last reply Reply Quote 0
                              • Jey Cee
                                Jey Cee Developer @bahnuhr last edited by

                                @bahnuhr ohne jetzt tiefer ein zu steigen würde ich eine Quick and Dirty Lösung einbauen. Bau dir ein Skript in vis ein das einen Klick auf das Widget auslöst sobald vis geladen ist.

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

                                  @jey-cee sagte in VIS Intance Id - automatisiert ermitteln:

                                  Bau dir ein Skript in vis ein das einen Klick auf das Widget auslöst sobald vis geladen ist.

                                  Danke für die Info.
                                  Ja, das wäre eine Idee. Nur weiß ich nicht wie?

                                  Hättest du 2 Zeilen für mich?
                                  Könnte man das Ergebnis (Browser Instanz) dann auch in einen Datenpunkt schreiben lassen?

                                  Jey Cee 1 Reply Last reply Reply Quote 0
                                  • Jey Cee
                                    Jey Cee Developer @bahnuhr last edited by

                                    @bahnuhr öhm hier mal was ungetestetes so aus der Hüfte.

                                    let timeout = 50; //Zeit erhöhen wenn der Klick nicht angenommen wird
                                    $(document).ready( () => {
                                      setTimeout( () => {
                                        $('#widget-id').click();
                                      }, timeout)
                                       
                                    })
                                    

                                    Die widget-id sieht man im Editor bei Aktives widget oder im Eigenschaften Tab, sieht so aus: w00001

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

                                      @jey-cee sagte in VIS Intance Id - automatisiert ermitteln:

                                      let timeout = 50; //Zeit erhöhen wenn der Klick nicht angenommen wird $(document).ready( () => { setTimeout( () => { $('#widget-id').click(); }, timeout) })

                                      Hab folgendes eingefügt:

                                      let timeout = 500; //Zeit erhöhen wenn der Klick nicht angenommen wird
                                      $(document).ready( () => {
                                        setTimeout( () => {
                                          $('w02705').click();
                                        }, timeout);
                                      });
                                      

                                      Hat leider nicht geklappt. Es wird immer noch angezeigt "Klick"

                                      Jey Cee 1 Reply Last reply Reply Quote 0
                                      • Jey Cee
                                        Jey Cee Developer @bahnuhr last edited by

                                        @bahnuhr ich hab das jetzt mal gerade getestet. Der Klick muss einen bestimmten bereich des Widgets angewendet werden, außerdem hab ich es auf trigger('click') geändert das funktioniert sicher.

                                        Hier die geänderte Zeile:

                                         $('#w00003>div>span>span').trigger('click');
                                        

                                        PS: Die # sagt das es sich um eine id handelt, . wäre class, ohne bezieht es sich auf das HTML Element.

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

                                          @jey-cee
                                          habe das unter Scripte eingefügt:
                                          2dffdfe3-7769-4007-9425-0743c352e772-image.png

                                          Ist das richtig.
                                          Fazit:
                                          Klick wird nicht vorgenommen.
                                          Wenn ich edge im kiosk mode öffnen steht auf der view immer noch "klicken"
                                          dad804c6-c7cd-4e82-9202-88cf164190a4-image.png

                                          Jey Cee 1 Reply Last reply Reply Quote 0
                                          • Jey Cee
                                            Jey Cee Developer @bahnuhr last edited by

                                            @bahnuhr ok soweit richtig. Setz den Timeout mal auf 1000 oder noch höher, je nach größe der View kann der Wert sehr hoch sein.
                                            Ich hab es mit Chrome und Firefox getestet, hat bei beiden geklappt.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            832
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

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