NEWS
Typescript setObejct kompelier fehler
-
Hi,
ich komme an einer stelle mit meinem Typescipt Skript nicht weiter.
Ich möchte gerne "states" erstellen bei dem es im "Wert" eine Auswahl gibt.
Für die Auswahl habe ich ein Emun erstellt.enum LightMode{ MANUALL, PRESSEND, ASTRO, TIME, TIME_PRESSEND, ASTRO_PRESSEND }
aus diesem Enum baue ich dann ein Object
{ "0": "MANUALL", "1": "PRESSEND", "2": "ASTRO", "3": "TIME", "4": "TIME_PRESSEND", "5": "ASTRO_PRESSEND", }
das ich beim erstellen des States mitgebe
createStateAsync(testPath,{name: "test1", type: 'number', states:{"0":"MANUALL", .....}}
Bis hierhin geht auch alles. Jetzt möchte ich noch die Möglichkeit haben das, wenn sich das enum mal ändert (z.b. ein weiterer Eintrag) dieses auch im Object angepasst wird.
MitextendObject(testPath, {common:{states:{"0":"MANUALL", .....}}})
ist es möglich, dies zu ändern, wenn ein neuer Eintrag hinzukommt jedoch nicht, wenn ich einen Eintrag entferne.
Ich habe es dann noch mitconst obj= getObject(testPath) obj.common.states = {"0":"MANUALL", .....} setObject(testPath, obj, (err) => { if (err) log('Cannot write object: ' + err); });
versucht was leider zu fehlern beim Kompilierne führte.
Bei der Suche hier im Forum haben die diesen Eintrag gefunden
https://forum.iobroker.net/topic/57264/gelöst-typescript-kompilierfehler-setobject/17
darauf hin haben ich das auch versucht.const obj= getObject(testPath) as iobJS.StateObject; obj.common.states = {"0":"MANUALL", .....} setObject(testPath, obj, (err) => { if (err) log('Cannot write object: ' + err); }); }
leider war es auch nicht erfolgreich.
Kann mir jemand sagen wo mein Fehler ist oder einen Tipp geben über welchen weg ich das hinbekomme ?
Ach ja mein Test state ist
{ "common": { "name": "test1", "type": "number", "states": { "0": "MANUALL", "1": "PRESSEND", "2": "ASTRO", "3": "TIME", "4": "TIME_PRESSEND", "5": "ASTRO_PRESSEND", "6": "MAX", "7": "__LENGTH" }, "role": "state" }, "native": {}, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1709191401013, "_id": "0_userdata.0.dev.intTest" }
Und natürlich ist "setObject" im JS adapter erlaubt.
gruß
-
hier stand Quatsch
-
Bei mir funktioniert das in 7.8.0 ohne Fehler:
const obj= getObject('0_userdata.0.test') as iobJS.StateObject; obj.common.states = {'0': 'MANUALL'}; setObject('0_userdata.0.test', obj, (err) => { if (err) log('Cannot write object: ' + err); });
-
@haus-automatisierung
Danke mit den Hinweis habe ich meinen Fehler gefunden.Ich hatte über eine Funktion aus dem Enum die das zusammen gebaut.
function lightModeStates(){ let ret = "" for (var enumMember in LightMode) { if (typeof(LightMode[enumMember]) === 'number'){ ret += ",\"" + LightMode[enumMember] + "\":\"" + enumMember + "\"" } } return JSON.parse("{" + ret.substring(1) + "}") // remove "," }
Und mein Fehler war das ich gedacht habe das dort ein Object auskommt somit hatte ich als Rückgabe Obejct eingetragen.
Nachdem ich das entfernt habe geht alles. Manchmal sind es die kleinen Dinge. -
@ignis-draco sagte in Typescript setObejct kompelier fehler:
Ich hatte über eine Funktion aus dem Enum die das zusammen gebaut.
Die Funktion ist ja ultra umständlich. Erst manuell JSON zusammenbauen, um es dann wieder zu parsen?! Nur damit es Strings werden, oder wie?
const result = {}; Object.keys(LightMode).forEach((key) => { result[key] = typeof LightMode[key] !== 'string' ? String(LightMode[key]) : LightMode[key]; }); return result;
-
Da hast du natürlich recht. Wobei ich den Quellcode von dir korrigieren muss.
Ein Enum in Typstript ist immer doppelt (hin und Rückrichtung). Mit deinem Code wären alle Eintrag doppelt da.const result = {}; Object.keys(LightMode).forEach((key) => { if (!isNaN(parseInt(key))){ result[key] = String(LightMode[key]) } }); return result;
Damit Passt es jetzt.
-
@ignis-draco sagte in Typescript setObejct kompelier fehler:
Mit deinem Code wären alle Eintrag doppelt da.
Wie soll das gehen? Schlüssel sind eindeutig
-
@haus-automatisierung sagte in Typescript setObejct kompelier fehler:
Wie soll das gehen? Schlüssel sind eindeutig
Das hat mich auch sehr verwundert.
Wenn man den Code ausführt bekommt man:{ '0': 'MANUALL', '1': 'PRESSEND', '2': 'ASTRO', '3': 'TIME', '4': 'TIME_PRESSEND', '5': 'ASTRO_PRESSEND', MANUALL: '0', PRESSEND: '1', ASTRO: '2', TIME: '3', TIME_PRESSEND: '4', ASTRO_PRESSEND: '5' }
Halt ein mal Hin und einmal Rück.
-
@ignis-draco sagte in Typescript setObejct kompelier fehler:
Halt ein mal Hin und einmal Rück.
Dafür ist dann aber nicht der Code verantwortlich, sondern das muss dann schon in
LightMode
genauso stehen. -
Klar habe ja auch gesagt das es an der Enum Implementation von Typscript liegt.
@ignis-draco sagte in Typescript setObejct kompelier fehler:
Ein Enum in Typstript ist immer doppelt (hin und Rückrichtung). Mit deinem Code wären alle Eintrag doppelt da.
-
@ignis-draco sagte in Typescript setObejct kompelier fehler:
Ein Enum in Typstript ist immer doppelt (hin und Rückrichtung). Mit deinem Code wären alle Eintrag doppelt da.
Das ist am Ende ja ein ein normales Objekt. Da gibt es keinen "Hin- und Rückweg" welcher automatisch erstellt wird.
EDIT: Ach krass, gerade wirklich etwas neues gelernt (ich nutze Enum eigentlich nie, daher ist mir das bisher nicht aufgefallen)! Danke:
enum UserResponse { No = 0, Yes = 1, }; console.log(JSON.stringify(UserResponse)); // {"0":"No","1":"Yes","No":0,"Yes":1}
-
Das Zauberwort lautet Reverse mappings.
Willkommen im Club habe das auch erst heute gelernt. -
Ich muss das Thema leider noch mal hochholen.
Meine Test Version funktioniert ja.
const testPath = "0_userdata.0.dev.color_mode" const obj= getObject(testPath) as iobJS.StateObject;
Als ich das ganze aber dynamisch machen wollte z.b.
async function updateEnum(path:string, states, statesLength){ const obj= getObject(path) as iobJS.StateObject;
hatte ich wieder den Fehler.
Wenn ich aus dem const ein var machen geht es auch nicht mehr
var testPath = "0_userdata.0.dev.color_mode" const obj= getObject(testPath) as iobJS.StateObject;
und es reicht nicht aus den string in ein const zu packen
async function updateEnum(path:string, states, statesLength){ const testPath = path const obj= getObject(testPath) as iobJS.StateObject;
immer bekommen ich
script.js.common.dev: TypeScript compilation failed: const obj = getObject(path) as iobJS.StateObject; ^ERROR: Conversion of type '{ type: "meta" | "config" | "user" | "state" | "instance" | "adapter" | "channel" | "folder" | "device" | "script" | "enum" | "group" | "host" | "chart"; ts: number; from: string; common: { ...; }; ... 8 more ...; encryptedNative: string[]; }' to type 'StateObject' may be a mistake because neither type sufficiently overlaps with the other. If this was intentional, convert the expression to 'unknown' first. Types of property 'common' are incompatible. Type '{ [x: string]: any; [x: number]: any; }' is missing the following properties from type 'StateCommon': read, write, role, name
Leider fehlt mir da echt tiefergehendes Javascript/typescript wissen um das zu verstehen.
Würde mir noch mal jemand auf die Sprünge helfen?