NEWS
Blockly
-
moin,
ich spiele die ganze Zeit mit Blockly rum,
dabei habe ich dieses Script erstellt.
filename="2016-08-18 13_04_38-ioBroker.admin.png" index="0">~~der erste Zweif (falls mache) funktioniert soweit das ich die Logausgabe sehe und die Variable Ausschaltzeit wird mit false gefüllt. Aber warum mit false erwartet habe ich eigentlich 22:00.
Die Variable habe ich per Hand mit Typ gemischt angelegt.
Einen Vorschlag
für Blockly eine neue Rubrik im Forum oder unterrubrik bei Scripte.
Danke für die Hilfe!
mfg
Armin `
Wenn du dein Skript hier posten würdest, dann kann man auch diesen Skript nach editieren und zeigen, wie es aussehen muss.Ich weiß genau, wo der Fehler liegt, aber es ist schwer zu beschreiben.
Ich überlege gerade, ob man die Tagen nicht von 1 bis 7 machen sollte. Aktuell kommen die 0 für Sonntag bis 6 für Samstag. Du wolltest aber sicher Wochentage erwischen.
-
Mit "Blocker" und "Block-Logik" war das gleiche gemeint von ScriptGUI … damit kannst Du quasi ein Limit bei Triggern einbauen. Das sind Dinge wie:
-
nur jeder 10 'te Trigger geht durch (rest wird geblockt)
-
nur einer je 5 Minuten (rest wird geblockt)
In der "Nicht-Web-version" von ScriptGUI kam das dazu.
Und man kann es immer über nen extra eingang immer resetten ... Nutze ich an ein paar Stellen genauso wie das Delay.
zu Pushover: dann war ich zu blind ... oder brauchts da ein update? `
ein update von git. -
-
die Wochentage funktionieren soweit. Für heute eine 4 .Es wird nur nicht die Uhrzeit in die Variable Ausschaltzeit geschrieben. In der Variable steht nur false und nicht 22:00.
Hier das script
sehe schon das true das gehört da nicht hin
schedule("* * * * *", function () { console.log('Wochtag als Zahl augegeben'); TagAlsZahl = (new Date().getDay()); console.log(TagAlsZahl); if (TagAlsZahl <= 5) { [b]setState("javascript.0.Ausschaltzeit"/*Ausschaltzeit*/, (Ausschaltzeit == formatDate(new Date(), "hh:mm")), true); console.log('Die Ausschaltzeit ist 22:00 Uhr');[/b] } else { setState("javascript.0.Ausschaltzeit"/*Ausschaltzeit*/, (Ausschaltzeit == formatDate(new Date(), "hh:mm")), true); console.log('Die Ausschaltzeit ist 23:00 Uhr'); } });
-
DU musst die Zuweisung zu "Ausschaltzeit weg machen oder zuerst zuweisen und dann den State updaten
-
DU musst die Zuweisung zu "Ausschaltzeit weg machen oder zuerst zuweisen und dann den State updaten `
Hm als Nichtprogrammierer bin ich ein wenig überfordert mit deiner Aussage! könntest du mir das in Blockly zeigen was du meinst?
Danke für Deine Hilfe!!
mfg
Arminhh
-
heiute abend daheim vllt. Aber noch ein versuch:
jetzt hast du
aktualisiere <state>mit … Ausschaltzeit= <uhrzeitwert>zweites ist eine Logikvergleich. Damit schaust Du was in Ausschaltzeit steht und vergleichst es mit der Uhrzeit. Das ist immer "falsch"
versuche mal:
aktualisiere <state>mit ... zu String ... <uhrzeitwert>oder brauchst Du die Variable noch für andere Dinge?</uhrzeitwert></state></uhrzeitwert></state>
-
Hallo
Ich habe eine Warnung im Script von Blockly.
Hat ja vielleicht nichts zu sagen.
Und so sieht es in Blockly aus.
Grüße
-
die Wochentage funktionieren soweit. Für heute eine 4 .Es wird nur nicht die Uhrzeit in die Variable Ausschaltzeit geschrieben. In der Variable steht nur false und nicht 22:00.
Hier das script
sehe schon das true das gehört da nicht hin
schedule("* * * * *", function () { console.log('Wochtag als Zahl augegeben'); TagAlsZahl = (new Date().getDay()); console.log(TagAlsZahl); if (TagAlsZahl <= 5) { [b]setState("javascript.0.Ausschaltzeit"/*Ausschaltzeit*/, (Ausschaltzeit == formatDate(new Date(), "hh:mm")), true); console.log('Die Ausschaltzeit ist 22:00 Uhr');[/b] } else { setState("javascript.0.Ausschaltzeit"/*Ausschaltzeit*/, (Ausschaltzeit == formatDate(new Date(), "hh:mm")), true); console.log('Die Ausschaltzeit ist 23:00 Uhr'); } }); ```` `
Auch letzte Zeile ist wichtig. Da wo //…. steht
-
Es gibt mal wider ein riesen Update für javascript auf github.
Bitte melden was fehlt.
-
Hallo
Ich habe da ein Problem.
Mein erstes Blockly-Progrämmchen startet mit Fehler.
Javascript v2.3.2
Im Editor habe ich eine neue Gruppe "Test" angelegt.
Darin habe ich mein Programm erstellt.
Also weder in "common" noch "global".
Blockly sieht so aus.
Im ersten Block "hm-rega.0.14256" ist eine nummerische HM-Systemvariable, die zyklisch geändert wird.
Sobald die Sys-Var geändert wird gibt es folgende Fehlermeldung.
! javascript-0 2016-08-18 22:00:07.229 info Stop script script.js.Test.RollosMorgensVorne
! ReferenceError: 2016-08-18 21:58:54.312 error at Socket.onpacket (C:\ioBroker\node_modules\iobroker.js-controller\node_modules\socket.io-client\lib\socket.js:221:12)
! ReferenceError: 2016-08-18 21:58:54.312 error at Socket.onevent (C:\ioBroker\node_modules\iobroker.js-controller\node_modules\socket.io-client\lib\socket.js:263:10)
! ReferenceError: 2016-08-18 21:58:54.312 error at Socket.Emitter.emit (C:\ioBroker\node_modules\iobroker.js-controller\node_modules\socket.io-client\node_modules\component-emitter\index.js:131:20)
! ReferenceError: 2016-08-18 21:58:54.312 error at Socket. (C:\ioBroker\node_modules\iobroker.js-controller\lib\states\statesInMemClient.js:45:30)
! ReferenceError: 2016-08-18 21:58:54.312 error at Object.that.states.States.change (C:\ioBroker\node_modules\iobroker.js-controller\lib\adapter.js:2113:37)
! ReferenceError: 2016-08-18 21:58:54.312 error at Object.utils.adapter.stateChange (C:\ioBroker\node_modules\iobroker.javascript\javascript.js:222:17)
! ReferenceError: 2016-08-18 21:58:54.312 error at checkPatterns (C:\ioBroker\node_modules\iobroker.javascript\javascript.js:544:17)
! ReferenceError: 2016-08-18 21:58:54.312 error at getObjectEnums (C:\ioBroker\node_modules\iobroker.javascript\javascript.js:2812:17)
! ReferenceError: 2016-08-18 21:58:54.312 error at C:\ioBroker\node_modules\iobroker.javascript\javascript.js:548:48
! ReferenceError: 2016-08-18 21:58:54.312 error at Object.subs.callback (C:\ioBroker\node_modules\iobroker.javascript\javascript.js:1228:48)
! ReferenceError: 2016-08-18 21:58:54.312 error at Object. (script.js.Test.RollosMorgensVorne:3:7)
! ReferenceError: 2016-08-18 21:58:54.312 error getValue is not defined
! message 2016-08-18 21:58:54.297
! error hm-rega.0.14256 [object Object] getValue is not defined
! javascript-0 2016-08-18 21:57:10.322 info script.js.Test.RollosMorgensVorne: registered 1 subscription and 0 schedules
! javascript-0 2016-08-18 21:57:10.322 info Start javascript script.js.Test.RollosMorgensVorneDas
hm-rega.0.14256 [object Object] getValue is not defined
verstehe ich nicht.
Kann jemand einem blinden Huhn ein Korn geben?
Grüße
-
heiute abend daheim vllt. Aber noch ein versuch:
jetzt hast du
aktualisiere <state>mit … Ausschaltzeit= <uhrzeitwert>zweites ist eine Logikvergleich. Damit schaust Du was in Ausschaltzeit steht und vergleichst es mit der Uhrzeit. Das ist immer "falsch"
versuche mal:
aktualisiere <state>mit ... zu String ... <uhrzeitwert>oder brauchst Du die Variable noch für andere Dinge?</uhrzeitwert></state></uhrzeitwert></state> `
Danke für Deine Mühe,
ich glaube ich habe es verstanden. Laut lock funktioniert es
schedule("* * * * *", function () { console.log('Wochtag als Zahl augegeben'); TagAlsZahl = (new Date().getDay()); console.log(TagAlsZahl); if (TagAlsZahl <= 5) { console.log('Die Ausschaltzeit ist 22:00 Uhr'); Ausschaltzeit = ('' + '22:00'); console.log(Ausschaltzeit); } else { console.log('Die Ausschaltzeit ist 23:00 Uhr'); Ausschaltzeit = ('' + '23:00'); console.log(Ausschaltzeit); } });
mfg
Arminhhh
-
Es gibt mal wider ein riesen Update für javascript auf github.
Bitte melden was fehlt. `
moin Bluefox
ich habe das Update von Github installiert. Angezeigt wird mir unter Adapter Javascript v 2.3.2 javascript mehrmals neu gestartet.
Browser Cache geleert.
Ich kann keine Änderungen feststellen!
mfg
Arminhh
-
Also bei mir sind bei Blockly neue Blocks aufgetaucht …
@Bluefiox: Für die Kommunikationsdinge ist super das jetzt auch Pushover drin ist.
Wäre es noch sinnvoll einen "sendTo"-Blockly zu haben woman einem beliebigen Adapter eine Message senden kann?
-
Ist das "Debug" und "Hilfe-Ausgabe" neu?
-
Also bei mir sind bei Blockly neue Blocks aufgetaucht …
@Bluefiox: Für die Kommunikationsdinge ist super das jetzt auch OPushover drin ist.
Wäre es noch sinnvoll einen "sendTo"-Blockly zu haben woman einem beliebigen Adapter eine Message senden kann? `
Ich habe schon an sendTo Block gedacht.Alles muss seine Zeit haben.
Momentan kann man sendTo mit Custom function implementieren.
48_2016-08-19_09_09_53-iobroker.admin.png -
Ist das "Debug" und "Hilfe-Ausgabe" neu? `
ja. -
Hallo Zusammen
Ich kriege mein Blockly-Script nicht ans laufen. (s.o.)
Für einen Tipp wäre ich dankbar.
Grüße
-
Hallo Zusammen
Ich kriege mein Blockly-Script nicht ans laufen. (s.o.)
Für einen Tipp wäre ich dankbar.
Grüße `
Bitte hier ganzen Skript posten!Screenshot ist nicht gleich Skript.
ich kann dann den Skript importieren und ausprobieren. Und ab nächste Version jeder kann importieren und ausprobieren
-
hm-rega.0.14256 [object Object] getValue is not defined `
In dem http://forum.iobroker.net/viewtopic.php?f=36&t=3412&start=40#p32773 taucht mehrmals getValue(id).val auf. Woher kommt die Funktion ?Der JS-Adapter kennt diese Funktion nicht, sondern nur getState(id).val. So wie ich es verstanden habe, erzeugt Blockly aus den Bildern Javascript-Code für den JS-Adapter ?
-
Hi, Danke für Eure Unterstützung.
Hier das von Blockly erzeugte Script.
// Rollos Morgens Vorne on({id: "hm-rega.0.14256"/*Minuten_vor_SU*/, change: "ne"}, function (obj) { var value = obj.state.val; if (getValue("hm-rega.0.14370").val >= getValue("hm-rega.0.14255").val) { // Prüfen Rollos vorne unten // (RolloVorneUnter=True) if (getValue("hm-rega.0.5335").val == true) { if (formatDate(new Date(), "hh:mm") >= getValue("hm-rega.0.13863").val) { console.log('Rollos vorne hoch'); } } } else { console.log('Rollos Morgens noch nicht so weit'); } }); //JTNDeG1sJTIweG1sbnMlM0QlMjJodHRwJTNBJTJGJTJGd3d3LnczLm9yZyUyRjE5OTklMkZ4aHRtbCUyMiUzRSUzQ2Jsb2NrJTIwdHlwZSUzRCUyMm9uJTIyJTIwaWQlM0QlMjJTZSU1RS5fVnVSJTJCdiUyNXJjJTVFXy0pdjllJTIyJTIweCUzRCUyMi0xMTYyJTIyJTIweSUzRCUyMi0zODclMjIlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJPSUQlMjIlM0VobS1yZWdhLjAuMTQyNTYlM0MlMkZmaWVsZCUzRSUzQ2ZpZWxkJTIwbmFtZSUzRCUyMkNPTkRJVElPTiUyMiUzRW5lJTNDJTJGZmllbGQlM0UlM0Njb21tZW50JTIwcGlubmVkJTNEJTIydHJ1ZSUyMiUyMGglM0QlMjI1MyUyMiUyMHclM0QlMjIxMzElMjIlM0VSb2xsb3MlMjBNb3JnZW5zJTIwVm9ybmUlM0MlMkZjb21tZW50JTNFJTNDc3RhdGVtZW50JTIwbmFtZSUzRCUyMlNUQVRFTUVOVCUyMiUzRSUzQ2Jsb2NrJTIwdHlwZSUzRCUyMmNvbnRyb2xzX2lmJTIyJTIwaWQlM0QlMjJLKVlCQjBhJTVCLiUyNW5BZCo0eTNIJTNGbiUyMiUzRSUzQ211dGF0aW9uJTIwZWxzZSUzRCUyMjElMjIlM0UlM0MlMkZtdXRhdGlvbiUzRSUzQ3ZhbHVlJTIwbmFtZSUzRCUyMklGMCUyMiUzRSUzQ2Jsb2NrJTIwdHlwZSUzRCUyMmxvZ2ljX2NvbXBhcmUlMjIlMjBpZCUzRCUyMjZrTTFmWXFyUiU3RF9RZy5jZXBvR0slMjIlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJPUCUyMiUzRUdURSUzQyUyRmZpZWxkJTNFJTNDdmFsdWUlMjBuYW1lJTNEJTIyQSUyMiUzRSUzQ2Jsb2NrJTIwdHlwZSUzRCUyMmdldF92YWx1ZSUyMiUyMGlkJTNEJTIyYndxRnpPVEMuUVVtUXMhJTVETy5PKSUyMiUzRSUzQ2ZpZWxkJTIwbmFtZSUzRCUyMkFUVFIlMjIlM0V2YWwlM0MlMkZmaWVsZCUzRSUzQ2ZpZWxkJTIwbmFtZSUzRCUyMk9JRCUyMiUzRWhtLXJlZ2EuMC4xNDM3MCUzQyUyRmZpZWxkJTNFJTNDJTJGYmxvY2slM0UlM0MlMkZ2YWx1ZSUzRSUzQ3ZhbHVlJTIwbmFtZSUzRCUyMkIlMjIlM0UlM0NibG9jayUyMHR5cGUlM0QlMjJnZXRfdmFsdWUlMjIlMjBpZCUzRCUyMkhxSCU1RDh1JTVFQkhSWEtILnglMkNMKCU1RCglMjIlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJBVFRSJTIyJTNFdmFsJTNDJTJGZmllbGQlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJPSUQlMjIlM0VobS1yZWdhLjAuMTQyNTUlM0MlMkZmaWVsZCUzRSUzQyUyRmJsb2NrJTNFJTNDJTJGdmFsdWUlM0UlM0MlMkZibG9jayUzRSUzQyUyRnZhbHVlJTNFJTNDc3RhdGVtZW50JTIwbmFtZSUzRCUyMkRPMCUyMiUzRSUzQ2Jsb2NrJTIwdHlwZSUzRCUyMmNvbnRyb2xzX2lmJTIyJTIwaWQlM0QlMjJEaEhiT3kqSFZzJTdEU34lMkJ2JTNEblolNjApJTIyJTNFJTNDY29tbWVudCUyMHBpbm5lZCUzRCUyMnRydWUlMjIlMjBoJTNEJTIyNzclMjIlMjB3JTNEJTIyMTU2JTIyJTNFUHIlQzMlQkNmZW4lMjBSb2xsb3MlMjB2b3JuZSUyMHVudGVuJTBBKFJvbGxvVm9ybmVVbnRlciUzRFRydWUpJTNDJTJGY29tbWVudCUzRSUzQ3ZhbHVlJTIwbmFtZSUzRCUyMklGMCUyMiUzRSUzQ2Jsb2NrJTIwdHlwZSUzRCUyMmxvZ2ljX2NvbXBhcmUlMjIlMjBpZCUzRCUyMjl3RnUlMkIqJTNCQiU0MFdtKmlIJTNCSWhtLkIlMjIlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJPUCUyMiUzRUVRJTNDJTJGZmllbGQlM0UlM0N2YWx1ZSUyMG5hbWUlM0QlMjJBJTIyJTNFJTNDYmxvY2slMjB0eXBlJTNEJTIyZ2V0X3ZhbHVlJTIyJTIwaWQlM0QlMjJmWCU1RUdTJTJCUi5XeUhDMVp6NG1ZNm4lMjIlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJBVFRSJTIyJTNFdmFsJTNDJTJGZmllbGQlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJPSUQlMjIlM0VobS1yZWdhLjAuNTMzNSUzQyUyRmZpZWxkJTNFJTNDJTJGYmxvY2slM0UlM0MlMkZ2YWx1ZSUzRSUzQ3ZhbHVlJTIwbmFtZSUzRCUyMkIlMjIlM0UlM0NibG9jayUyMHR5cGUlM0QlMjJsb2dpY19ib29sZWFuJTIyJTIwaWQlM0QlMjJ+LVFVJTVEUSU1RSlVU0RsbSUyQm0yQUIhMiUyMiUzRSUzQ2ZpZWxkJTIwbmFtZSUzRCUyMkJPT0wlMjIlM0VUUlVFJTNDJTJGZmllbGQlM0UlM0MlMkZibG9jayUzRSUzQyUyRnZhbHVlJTNFJTNDJTJGYmxvY2slM0UlM0MlMkZ2YWx1ZSUzRSUzQ3N0YXRlbWVudCUyMG5hbWUlM0QlMjJETzAlMjIlM0UlM0NibG9jayUyMHR5cGUlM0QlMjJjb250cm9sc19pZiUyMiUyMGlkJTNEJTIyeU4lM0FLa0RnRiUzRnEwS1R4QmtiaXd0JTIyJTNFJTNDdmFsdWUlMjBuYW1lJTNEJTIySUYwJTIyJTNFJTNDYmxvY2slMjB0eXBlJTNEJTIybG9naWNfY29tcGFyZSUyMiUyMGlkJTNEJTIyX3V5WnUlMkYlNDAlNDBUJTJCMnEoZGZmfmpCeSUyMiUzRSUzQ2ZpZWxkJTIwbmFtZSUzRCUyMk9QJTIyJTNFR1RFJTNDJTJGZmllbGQlM0UlM0N2YWx1ZSUyMG5hbWUlM0QlMjJBJTIyJTNFJTNDYmxvY2slMjB0eXBlJTNEJTIydGltZV9nZXQlMjIlMjBpZCUzRCUyMmQwMFByY1YydEcoR0RQayU1RTdtNXQlMjIlM0UlM0NtdXRhdGlvbiUyMGZvcm1hdCUzRCUyMmZhbHNlJTIyJTIwbGFuZ3VhZ2UlM0QlMjJmYWxzZSUyMiUzRSUzQyUyRm11dGF0aW9uJTNFJTNDZmllbGQlMjBuYW1lJTNEJTIyT1BUSU9OJTIyJTNFaGglM0FtbSUzQyUyRmZpZWxkJTNFJTNDJTJGYmxvY2slM0UlM0MlMkZ2YWx1ZSUzRSUzQ3ZhbHVlJTIwbmFtZSUzRCUyMkIlMjIlM0UlM0NibG9jayUyMHR5cGUlM0QlMjJnZXRfdmFsdWUlMjIlMjBpZCUzRCUyMnJ2RkZtN3QhcCphTyUyNVYuNiUyNVYlNUJCJTIyJTNFJTNDZmllbGQlMjBuYW1lJTNEJTIyQVRUUiUyMiUzRXZhbCUzQyUyRmZpZWxkJTNFJTNDZmllbGQlMjBuYW1lJTNEJTIyT0lEJTIyJTNFaG0tcmVnYS4wLjEzODYzJTNDJTJGZmllbGQlM0UlM0MlMkZibG9jayUzRSUzQyUyRnZhbHVlJTNFJTNDJTJGYmxvY2slM0UlM0MlMkZ2YWx1ZSUzRSUzQ3N0YXRlbWVudCUyMG5hbWUlM0QlMjJETzAlMjIlM0UlM0NibG9jayUyMHR5cGUlM0QlMjJkZWJ1ZyUyMiUyMGlkJTNEJTIySDZlVkspMCU1QjUlNUQlN0MlMjNjJTVCbUolMkJLQ3QlMjIlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJTZXZlcml0eSUyMiUzRWxvZyUzQyUyRmZpZWxkJTNFJTNDdmFsdWUlMjBuYW1lJTNEJTIyVEVYVCUyMiUzRSUzQ2Jsb2NrJTIwdHlwZSUzRCUyMnRleHQlMjIlMjBpZCUzRCUyMkdSS34uWGIlMjNXem8lNDAlNUQ4ZiU1REZ5Z3QlMjIlM0UlM0NmaWVsZCUyMG5hbWUlM0QlMjJURVhUJTIyJTNFUm9sbG9zJTIwdm9ybmUlMjBob2NoJTNDJTJGZmllbGQlM0UlM0MlMkZibG9jayUzRSUzQyUyRnZhbHVlJTNFJTNDJTJGYmxvY2slM0UlM0MlMkZzdGF0ZW1lbnQlM0UlM0MlMkZibG9jayUzRSUzQyUyRnN0YXRlbWVudCUzRSUzQyUyRmJsb2NrJTNFJTNDJTJGc3RhdGVtZW50JTNFJTNDc3RhdGVtZW50JTIwbmFtZSUzRCUyMkVMU0UlMjIlM0UlM0NibG9jayUyMHR5cGUlM0QlMjJkZWJ1ZyUyMiUyMGlkJTNEJTIyeFNQQWZIMjQ1cmxUJTJGUkZ2NjVQZCUyMiUzRSUzQ2ZpZWxkJTIwbmFtZSUzRCUyMlNldmVyaXR5JTIyJTNFbG9nJTNDJTJGZmllbGQlM0UlM0N2YWx1ZSUyMG5hbWUlM0QlMjJURVhUJTIyJTNFJTNDc2hhZG93JTIwdHlwZSUzRCUyMnRleHQlMjIlMjBpZCUzRCUyMiU3Qnk3UGNqbmhBZGVFLXd5JTNEWXMlNUVJJTIyJTNFJTNDZmllbGQlMjBuYW1lJTNEJTIyVEVYVCUyMiUzRVJvbGxvcyUyME1vcmdlbnMlMjBub2NoJTIwbmljaHQlMjBzbyUyMHdlaXQlM0MlMkZmaWVsZCUzRSUzQyUyRnNoYWRvdyUzRSUzQyUyRnZhbHVlJTNFJTNDJTJGYmxvY2slM0UlM0MlMkZzdGF0ZW1lbnQlM0UlM0MlMkZibG9jayUzRSUzQyUyRnN0YXRlbWVudCUzRSUzQyUyRmJsb2NrJTNFJTNDJTJGeG1sJTNF
Grüße