NEWS
DP mit custom Element anlegen
-
@david-g sagte:
,":"aber"
Was soll das sein?
Es fehlt die abschließende geschweifte Klammer für "states" vor dem Komma.
JSON (Objekte) per Blockly zu erstellen, ist immer ein Krampf.
Mittels JS-Funktion ist es erheblich einfacher:
const states = {}; for(let i = 0; i < 7; i++) { states[i] = formatDate(Date.now() + i * 86400000, 'W DD.MM.'); } return JSON.stringify(states);
Ergebnis:
{"type":"number","role":"value","states":{"0":"Mi 13.03.","1":"Do 14.03.","2":"Fr 15.03.","3":"Sa 16.03.","4":"So 17.03.","5":"Mo 18.03.","6":"Di 19.03."},"custom":{"lovelace.0":{"enabled":true,"entity":"input_select","name":"aber"}}}
-
@paul53 sagte in DP mit custom Element anlegen:
Was soll das sein?
Da fehlt in der Tat was vor.....
@paul53 sagte in DP mit custom Element anlegen:
JSON (Objekte) per Blockly zu erstellen, ist immer ein Krampf.
Das stimmt wohl....
Werde deinen Vorschlag heute Abend einmal nachbauen.
Auf das "heute, morgen und übermorgen" bei den States kann ich verzichten.
-
@paul53 sagte in DP mit custom Element anlegen:
JSON (Objekte) per Blockly zu erstellen, ist immer ein Krampf.
Jetzt zum Glück nicht mehr:
https://forum.iobroker.net/topic/73439/javascript-7-9-0-neue-objekt-und-http-bausteine
-
@haus-automatisierung sagte: Jetzt zum Glück nicht mehr:
Endlich! Habe gerade getestet
-
Das sieht gut aus.
Dann versuche ich es mit den neuen Bausteinen, auch wenn sich in meinem Fall die Schleife natürlich anbietet.Ich mag es aber, Dinge für einen anderen Zweck modifizieren zu können.
-
@david-g sagte in DP mit custom Element anlegen:
Dann versuche ich es mit den neuen Bausteinen
Ich glaube im "Datenpunkt erzeugen"-Baustein steht fix ein
JSON.parse()
im generierten JS-Code. Es könnte also sein, dass man dort nicht direkt ein Objekt fürcommon
übergeben kann. Da müsste ich den Block dann nochmal anpassen damit beide Fälle abgedeckt werden. -
@david-g sagte: auch wenn sich in meinem Fall die Schleife natürlich anbietet.
Ja, aber mit einer kleinen Änderung:
const states = {}; for(let i = 0; i < 7; i++) { states[i] = formatDate(Date.now() + i * 86400000, 'W DD.MM.'); } return states;
Blockly:
-
@paul53 Ah tricky, ist halt etwas unschön dass man dann ein
JSON.parse(JSON.stringify(...))
generiert. -
@haus-automatisierung sagte: Da müsste ich den Block dann nochmal anpassen damit beide Fälle abgedeckt werden.
Du meinst den Block "Datenpunkt erzeugen"? Dort wäre es sinnvoll. Dann bitte auch gleich so, dass man eine Text-Variable als ID übergeben kann (für konstruierte IDs).
-
Habe es nachgebaut.
Klappt auf Anhieb. Dank dir.In dem Fall macht man die States ja schön mit der Funktion.
Könnte man es auch mit den neuen Blöcken machen? Falls man mal was hat, was man nicht sdquenziell abarbeiten kann.
-
@david-g sagte: Könnte man es auch mit den neuen Blöcken machen?
Nein, man kann für das in der Schleife zu setzende Attribut keine Variable übergeben.
states[i] = // ist nicht möglich
-
Okay.
So klappt es jedenfalls auch, falls man Werte hat die man nicht mit einer Schleife berechnen kann.
Hab zum testen einfach mal den selben Fall genommen.Wenn man irgendwann mit den Objekten direkt im Datenpunkt erzeugen arbeiten könnte, macht es natürlich weniger Fehleranfallig.
Super Baustein @haus-automatisierung