NEWS
Javascript und Vis
-
Hallo,
ich baue grade meine eigene Wetter Vis mit Daten von DasWetter. Habe auch alles soweit hinbekommen, stehe nun aber vor dem großen Problem mit dem Datum von morgen, übermorgen usw.In DasWetter wird das Datum als String angezeigt. Also heute = 21042023 Morgen =220423
Da dieses Format sehr unschön ist ich gerne einen Punkt zwischen den einzelnen Werte hätte komme ich da nicht weiter.
Meine Idee ist nun ein eigenes kleines JAvascript zu schreiben und z.b. Das Datum von Morgen auszugeben.
Dazu habe ich das scriptunter Scripte ein javascript geschrieben mit dem Titel actual Dates. Das sieht grade so aus:
var heute = new Date(); heute = new Date(heute.getFullYear(),heute.getMonth(),heute.getDate(),0,0,0) var morgen = new Date(heute); morgen.setDate(morgen.getDate()+1); console.log(morgen);
wenn ich nun in die Vis gehen und string text nehme und als ObjectID mein javascript bekomme ich nur true angzeigt.
Hat jemand eine Idee wie ich das Datum von morgen, übermorgen in meine Vis einbetten kann?
Danke für eure Hilfe
-
var date = new Date(); date.setDate(date.getDate() + 1); var Tag = date.getDate(); // System Tag var Monat = date.getMonth()+1; // System Monat var Jahr = date.getFullYear(); // System Jahr log (Tag + "." + Monat + "." + Jahr);
-
@bahnuhr
Danke für das Script, allerdings löst es nicht mein Problem, in der VIS selber. Es wird mir immer nur true angezeigt.Wie kann ich in der VIS ein Script einbinden, dass nicht true zeigt?
-
@jones1975
Wie man das Javascript direkt in VIS einbettet kann ich Dir nicht sagen. Aber Du kannst den Wochentag doch einfach in einen Datenpunkt schreiben lassen von dem Skript. Und diesen Datenpunkt lässt Du dann in VIS anzeigen.
So mache ich das jedenfalls immer. -
var heute = new Date(); heute = new Date(heute.getFullYear(),heute.getMonth(),heute.getDate(),0,0,0) var morgen = new Date(heute); morgen.setDate(morgen.getDate()+1); console.log(morgen); setState("0_userdata.0.CONTROL-OWN.AAATEST.TestString7",morgen.toString())
vis mit string -widget:
-
@jones1975 sagte in Javascript und Vis:
@bahnuhr
Danke für das Script, allerdings löst es nicht mein Problem, in der VIS selber. Es wird mir immer nur true angezeigt.Wie kann ich in der VIS ein Script einbinden, dass nicht true zeigt?
mit welchem skript wird dir wo true angezeigt?
wo hast du das skript eingetragen (im javascript reiter in vis)? -
@jones1975 sagte: gerne einen Punkt zwischen den einzelnen Werte
Füge die Punkte ein. Prinzip:
date = date.slice(0, 2) + '.' + date.slice(2, 4) + '.' + date.slice(4);
Vom Vis-Binding habe ich keine Ahnung.
-
@paul53: Danke das werde ich probieren
Datenpunkt anlegen....
Also ich habe einen Datenpunkt unter 0_userdata angelegt und mit dem Namen Date versehen
als Objektdaten sehe ich nun{ "common": { "name": "Date", "desc": "Manuell erzeugt", "role": "date", "type": "object", "read": true, "write": true }, "type": "state", "native": {}, "_id": "0_userdata.0.Date.Date", "from": "system.adapter.admin.0", "user": "system.user.admin", "ts": 1682060316223 }
Aber wie binde ich jetzt da mein javascript ein?
-
@jones1975 mir ist immer noch nicht klar, was du wo einbinden willst
- ein javascript im vis-editor, das auf datenpunkte zugreift (läuft letztlich als script im browser)
- oder ein javascript im javascript-adapter (läuft auf dem iob-server)
-
@liv-in-sky ok da gibt es anscheinend auch unterschiede.... ich kann Programmieren (ok ein wenig
) aber mir sind die ganzen Verbindungen die ich selber anlegen möchte noch total schleierhaft..
Als Ziel: In einer Visualisierung das Datum von Morgen anzeigen lassen.
Folgende Möglichkeiten:
-
in dem Adapter das Wetter gibt es als Object day_value. Dieses wird als String ohne Punkte angezeigt. Beispiel: 20230426
Dieses Value möchte ich gerne im folgenden Format in meiner VIS angezeigt bekommen 26.04.2023 -
Mithilfe eines Javascripts.
Dazu habe ich ein Javascript erstellt, bzw nehme das von Bahnuhr weiter oben. Log zeigt das richtige Ergebnis.
Datenpunkt erstellt, aber weiß nicht wie ich nun den Datenpunkt mit dem Javascript verknüpfe.
Ich google seit Tagen und es gibt zig Anleitungen wie erstelle ich einen Datenpunkt, wie baue ich ein javascript aber ich habe noch keine Anleitung gefunden die einem Anfänger zeigt, wie ein Datenpunkt mit einem Javascript verknüpft wird.
Das kann doch nicht so schwer sein, aber vermutlich stelle ich mich einfach nur total .... an -
-
@jones1975 sagte in Javascript und Vis:
Dazu habe ich ein Javascript erstellt, bzw nehme das von Bahnuhr weiter oben. Log zeigt das richtige Ergebnis.
Datenpunkt erstellt, aber weiß nicht wie ich nun den Datenpunkt mit dem Javascript verknüpfe.- erstelle einen manuellen DP unter javascript oder unter userdata
- In dem Script ein setState hinzufügen, dass dann den Wert in diesen DP schreibt
- Im Vis Editor dann ein Widget (String) nehmen und dieses positionieren.
- im Widget als DP deinen selbst erstellten auswählen.
- Im runtime wird dann das widget korrekt angezeigt.
-
da gibt es einige möglichkeiten
du machst ein script - im js-adapter - so wie mein beispiel - und schreibst das ganze in einen dp
- dann ein string-widget im vis editor und die object-id deines dp angeben
- oder ein html widget und über ein sog. binding
oder etwas umständlich
du machst das script im vis-editor (welches in einem html widget ist) und schreibst das ergebnis gleich in den html code - würde man aber bei diesem beispiel nicht machen)script im adapter - fehlt noch der trigger einmalig am anfang des tages
var heute = new Date(); heute = new Date(heute.getFullYear(),heute.getMonth(),heute.getDate(),0,0,0) var morgen = new Date(heute); morgen.setDate(morgen.getDate()+1); console.log(formatDate(getDateObject(morgen), "DD.MM.YYYY")); setState("0_userdata.0.CONTROL-OWN.AAATEST.TestString7",formatDate(getDateObject(morgen), "DD.MM.YYYY").toString())
widgets:
string:html-widget mit binding
-
mit einer reinen vis-lösung geht auch folgendes.
Alternative1
Da du jetzt nicht wirklich geschrieben hast, wie die Daten genau vorliegen, habe ich es mal an einem Beispiel aus einem Datenpunkt aufgeschriebenSchritt1: den folgenden Code im Skripte-Tab in vis irgendwo am Ende kopieren (falls schon was drinsteht)
function calcDate(datum) { return datum.substr(0,2)+"."+datum.substr(2,2)+"."+datum.substr(4); }
Schritt2: Lege ein neues Html-Widget an
und trage in das Html-Feld das folgende ein{datum:0_userdata.0.test.test1;calcDate(datum)}
0_userdata.0.test.test1 gegen deinen Datenpunkt tauschen
Alternative2
Falls der Wert nicht in einem Datenpunkt vorliegt, geht auch noch folgendes, ebenfalls mit einem html-widget<div id="meinDatum"></div>
in deinem Code kannst du dann folgendes verwenden. In Variable datum muss der String in in Form 25042023 vorliegen.
$("#meinDatum").html(calcDate(datum));
Du musst allerdings aufpassen, das zum Zeitpunkt deiner Skriptausführung das widget bereits existiert. Prüfen kannst du das mit der Funktion waitForElementaus dem folgenden thread
https://forum.iobroker.net/topic/48663/howto-skripte-im-vis-editor-mit-jquery?_=1682415616257