NEWS
[Gelöst] Unifi Voucher
-
@liv-in-sky Wegen Chat...Komme ich gerne darauf zurück, bin nur die ganze Zeit sehr sporadisch vor dem Bildschirm.
Ich bin jetzt auf jeden Fall einen Schritt weiter.
Aber... Lasse ich ein einfaches Debug Log laufen sehe ich in dem Logs wunderbar das die Voucherdaten geliefert werden.
Wobei ich mich frage sollte dann eigentlich dann nicht mehr die "0" geliefert werden solange ein Voucher existiert?Wenn ich jetzt aber diesen Wert mit diesen Blockly weiterverarbeiten will:
wird in den „Rohdaten“ Datenpunkt immer nur die "0" geschrieben (sollte es tatsächlich die 0 sein, schreibt es wie gewünscht "NULL" -
@draexler weiß nicht, ob ich das alles richtig verstehe
entweder stimmt die falls abfrage nicht und es kommt immer "0" zurück
falls wert von UNIFI.Voucherueberwachung = 0 kannste mal auf = "0" - also einen string vergleichen, nicht eine zahl - evtl ist da was falsch
-
@liv-in-sky sorry wenn es kompliziert ist.
Also ich will das in den „Rohdaten“ Datenpunkt der Return Wert deines „Abfrage“
scripts eingetragen wird.
Aber mein Blockly trägt immer „0“ ein. Außer der Return Wert deines „Abfrage“
Scripts ist „0“ dann schreibt er „NULL“ gemäß des Blocklys.Ich hoffe das war verständlicher
-
@draexler ich glaube, das habe ich soweit verstanden - daher die falls abfrage ändern. die function gibt immer einen string zurück, du fragst aber eine zahl in der 2ten if abfrage ab- daher meine idee, dass mal zu ändern
-
@liv-in-sky Sicher das immer ein String zurückgeliefert wird?
Ich habe den Datenpunkt mal auf Zahl geändert und habe nun das im Log:State value to set for "0_userdata.0.VIS_Datenpunkte.UNIFI.Voucherueberwachung" has to be type "string" but received type "number"
-
@draexler ok - das sollte dann schon stimmen - habe ich mich geirrt
-
@liv-in-sky Habe jetzt mal wieder ein bisschen getestet. Aber keine Chance. Er schreibt mir immer wieder nur die "0" als Return Wert.
Ich habe jetzt mal unter dem Blockly ein Debug Output eingebaut:
Man sieht also das das wenn der Return Wert der "Abfrage" ungleich "0" er die korrekte if Abfrage nimmt. Er schreibt aber trotzdem nur eine "0" ins Log.
Lasse ich wie schon mal geschrieben vollkommen losgelöst einen Debug Output Trigger lassen schreibt er den gewünschten Wert
Ich bin ratlos....
Hier nochmal das Abfrage Skript:
const dpPrefix = "0_userdata.0.VIS_Datenpunkte."; let arrTrigger=[]; let count=0 let alterWert=getState(dpPrefix+"UNIFI.Voucherueberwachung").val $('unifi.0.default.vouchers.*.create_time').each(function(id, i) { if(!id.includes("voucher_.create")){ count++ let erstellt=getState(id).val arrTrigger.push([new Date(erstellt).getTime(),id,getState(id.replace("create_time","code")).val]) } }); setState(dpPrefix+"UNIFI.Voucherueberwachung",count) arrTrigger.sort(function (alpha, beta) { return beta[0]- alpha[0]; }); if (alterWert<count) {return arrTrigger[0][1]+","+arrTrigger[0][2]; } else { return "0";} alterWert=count
Vielleicht ist hier ja doch ein Fehler drin
-
@draexler
du rufst die function öfter mal in einem if block auf - versuche mal eine neue variable zu erstellen und rufe dort die function auf - im if-block nutzt du dann die neue variable, anstatt immer wieder die function aufzurufen.die function setzt bei einmaligen durchlaufen einen wert und merkt sich den für den nächstan aufruf - das könnte evtl das seltsame verhalten zeigen
hier ein beispiel:
-
@liv-in-sky Das war es! Super Danke dir
Jetzt bastel ich mal weiter.
-
@draexler dann noch viel spaß beim "coden"