NEWS
[gelöst] - VIS Intance Id - automatisiert ermitteln
-
@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. -
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:
notdefinedIst 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.
-
@bahnuhr mhh und notdefined kann man nicht als Id nutzen
-
@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. -
@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
-
@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.bodyIch 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
-
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 -
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.
-
Danke für deine Info.
Wenn du Hilfe brauchst, sag Bescheid. -
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-BraunIhr seid doch Script Spezialisten. Könnt ihr mir hier mal helfen?
mfg
Dieter -
@bahnuhr
Hab ich keinen Schimmer von. -
@thomas-braun sagte in VIS Intance Id - automatisiert ermitteln:
@bahnuhr
Hab ich keinen Schimmer von.Schade, trotzdem Danke für die Antwort.
-
@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.
-
@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? -
@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
-
@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"
-
@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.
-
@jey-cee
habe das unter Scripte eingefügt:
Ist das richtig.
Fazit:
Klick wird nicht vorgenommen.
Wenn ich edge im kiosk mode öffnen steht auf der view immer noch "klicken"
-
@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. -
@jey-cee sagte in VIS Intance Id - automatisiert ermitteln:
@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.Habs jetzt mal auf 4000 gesetzt. Dann hat es mit edge kiosk geklappt.
Und nun noch ne letzte Frage.
Kann man diese erzeugte Instanz dann ebenfalls mit einem solchen kleinen Script in ein Objekt schreiben.