Closed krikkoo closed 3 years ago
Hi @krikkoo, As you can see on the Node-RED forum, I have announced the JS functionality 6 days ago as 2.1.0 beta version. I hope that both requestors of the 2 large new features will do some tests before I publish it on NPM. If nobody has responded next week, I will publish it anyway ... Bart
Hi @bartbutenaers, Thank you for your clarification. I have installed your beta to have same test. Please note that my knowledge on JS is very low, I have copied your example about circle and I would you report the following, maybe will be useful for you: On Safari double click injection it seems not work On chrome it work the injection but the browser enter in a loop and continues to show the alert after the first double click even if I click OK in the pop-up.
Thank you for your great job Regards Record screen.mov.zip
Hey @krikkoo, Thanks for testing!
On Safari double click injection it seems not work
Are there any errors in the browser console logs?
On chrome it work the injection but the browser enter in a loop
I cannog explain that. I do all my developments in Chrome on Winows 10. On which OS are you running?
Hi, In the console no error is raising, so I suppose there is no issue in the development, probably compatibility problems. My OS is Catalina 10.15.7, Safari version is 14.0 and Chrome version is 86.0.4240.183 Maybe you can do some test in a virtual box machine. I can tell you another thing that not work in Safari but work in Chrome; In the Animate tab the "animation type" dropdown not appearing even if attribute name is "transform", but this deviate from this topic.
Any way thanks for your support and job.
Maybe you can do some test in a virtual box machine.
Ok thanks. Then this new version will have to wait some time, because I have not enough free time at the moment to setup such an environment where I can start debugging. Damn ...
Thanks to you for your devotion. I would you ask you another thinks that I did not found in any example, how it is possible to trigger an automation inside the JS tab with script. I tried a lot but my JS is limited. Thank you again.
@krikkoo, I have installed MacOS via VirtualBox on my Windows 10 portable. At the end I have nothing fixed in my code, because I 'think' that it works correctly... Instead I assume it was caused due to some issues in my example flow.
Here is a better example flow (which I will update on the readme page):
[{"id":"89244415.be9278","type":"ui_svg_graphics","z":"a03bd3cf.177578","group":"5ae1b679.de89c8","order":4,"width":"0","height":"0","svgString":"<svg x=\"0\" y=\"0\" height=\"350\" viewBox=\"-0.04032258064515237 0 250.0806451612903 350\" width=\"250\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" preserveAspectRatio=\"xMidYMid meet\">\n<circle id=\"my_circle\" cx=\"30\" cy=\"30\" r=\"25\" style=\"stroke: none; fill: #0000ff;\">\n</circle>\n</svg>","clickableShapes":[],"javascriptHandlers":[{"selector":"#my_circle","action":"click","sourceCode":"var letters = '0123456789ABCDEF';\n var color = '#';\n for (var i = 0; i < 6; i++) {\n color += letters[Math.floor(Math.random() * 16)];\n }\n\n$(\"#my_circle\")[0].style.fill = color;\n \n$scope.send({payload: color, topic: 'circle_color'})"}],"smilAnimations":[{"id":"","targetId":"","classValue":"","attributeName":"transform","transformType":"rotate","fromValue":"","toValue":"","trigger":"msg","duration":"1","durationUnit":"s","repeatCount":"0","end":"restore","delay":"1","delayUnit":"s","custom":""}],"bindings":[],"showCoordinates":false,"autoFormatAfterEdit":true,"showBrowserErrors":true,"showBrowserEvents":true,"outputField":"payload","editorUrl":"http://drawsvg.org/drawsvg.html","directory":"","panning":"disabled","zooming":"disabled","panOnlyWhenZoomed":false,"doubleClickZoomEnabled":false,"mouseWheelZoomEnabled":false,"name":"SVG with Javascript","x":540,"y":180,"wires":[["e06da0e0.2c837"]]},{"id":"d9df6292.785bc","type":"inject","z":"a03bd3cf.177578","name":"Show alert at click","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"{\"command\":\"add_js_event\",\"event\":\"click\",\"selector\":\"#my_circle\",\"script\":\"alert('Click event handled on the client ...')\"}","payloadType":"json","x":230,"y":140,"wires":[["89244415.be9278"]]},{"id":"5074f893.d378d8","type":"inject","z":"a03bd3cf.177578","name":"Remove clicked event","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"{\"command\":\"remove_js_event\",\"event\":\"click\",\"selector\":\"#my_circle\"}","payloadType":"json","x":240,"y":180,"wires":[["89244415.be9278"]]},{"id":"e06da0e0.2c837","type":"debug","z":"a03bd3cf.177578","name":"","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":750,"y":180,"wires":[]},{"id":"8572fad7.dd39b8","type":"inject","z":"a03bd3cf.177578","name":"change color at click","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"{\"command\":\"add_js_event\",\"event\":\"click\",\"selector\":\"#my_circle\",\"script\":\"var letters = '0123456789ABCDEF'; var color = '#'; for (var i = 0; i < 6; i++) { color += letters[Math.floor(Math.random() * 16)]; } $('#my_circle')[0].style.fill = color; $scope.send({payload: color, topic: 'circle_color'})\"}","payloadType":"json","x":230,"y":280,"wires":[["89244415.be9278"]]},{"id":"f678a359.157b4","type":"comment","z":"a03bd3cf.177578","name":"Multiline program ...","info":"","x":220,"y":240,"wires":[]},{"id":"5ae1b679.de89c8","type":"ui_group","name":"Press Demo","tab":"3667e211.c08f0e","order":1,"disp":true,"width":"5","collapse":false},{"id":"3667e211.c08f0e","type":"ui_tab","name":"Home","icon":"dashboard","order":1,"disabled":false,"hidden":false}]
This works for me on MacOs in Safari:
And on MacOs in Chrome I also get a 'single' alert popup:
Note that you need to remove the previous event handler (via the center inject node), before you add a new event handler. Otherwise you will see this error (when you have activated the setting 'show browser errors on server side':
Note that errors in the injected Javascript code will also be displayed, when that setting is activated. For example we inject javascript code where a ;
is forgotten between the two statements:
"var x=1 var y=2;"
Then this error will be displayed, as soon as you trigger the event in the dashboard (i.e. as soon as the javascript code is executed):
And to make troubleshooting a bit easier in the future, I have added a extra checkbox:
When that checkbox is checked, a entry will appear in the Debug sidebar for every event that will be triggered:
Can you let me know if this works also works on your Mac?
For me the dropdown appears both in Chrome and Safari. Of course it will only appear for attribute name "transform" and after you press the TAB button. For example for Safari:
how it is possible to trigger an automation inside the JS tab with script. I tried a lot but my JS is limited.
What do you mean with "automation". And please share what you have tried already! And please ask javascript related questions next time on the Node-RED forum, because I cannot solve all kind of javascript related questions here on my own...
Hi Bart, Thank you for your complete report, you are the best one. I have fixed the example like yours and now it work like a charm. I don't know why the animation dropdown did not appear, after the latest update it works.
Coming back to my query, I have this animation
and I would like to trigger it from JS tab
I have tried lot of command without success. This error appear.
I know it could be possible to create a message payload to do the same thing, but from JS should be easier and faster.
Thank you again for your support and sorry if I bothered you. You can close the issue. Regards
I have tried lot of command without success.
That is indeed weird... Should really expect that your flow should work. Can you please export this part of your flow and share it here!
I have created quickly a test flow:
[{"id":"b209d867.8fb108","type":"ui_svg_graphics","z":"6e219eb.05dce6","group":"5ae1b679.de89c8","order":4,"width":"0","height":"0","svgString":"<svg x=\"0\" y=\"0\" height=\"350\" viewBox=\"-0.04032258064515237 0 250.0806451612903 350\" width=\"250\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" preserveAspectRatio=\"xMidYMid meet\">\n<circle id=\"my_circle\" cx=\"30\" cy=\"30\" r=\"25\" style=\"stroke: none; fill: #0000ff;\">\n</circle>\n</svg>","clickableShapes":[],"javascriptHandlers":[{"selector":"#my_circle","action":"click","sourceCode":"$(\"#my_animation\")[0].beginElement()"}],"smilAnimations":[{"id":"my_animation","targetId":"my_circle","classValue":"","attributeName":"fill","transformType":"rotate","fromValue":"blue","toValue":"red","trigger":"msg","duration":"3","durationUnit":"s","repeatCount":"0","end":"restore","delay":"1","delayUnit":"s","custom":""}],"bindings":[],"showCoordinates":false,"autoFormatAfterEdit":true,"showBrowserErrors":true,"showBrowserEvents":true,"outputField":"payload","editorUrl":"http://drawsvg.org/drawsvg.html","directory":"","panning":"disabled","zooming":"disabled","panOnlyWhenZoomed":false,"doubleClickZoomEnabled":false,"mouseWheelZoomEnabled":false,"name":"SVG with Javascript","x":680,"y":320,"wires":[["e3544234.437"]]},{"id":"5ae1b679.de89c8","type":"ui_group","name":"Press Demo","tab":"3667e211.c08f0e","order":1,"disp":true,"width":"5","collapse":false},{"id":"3667e211.c08f0e","type":"ui_tab","name":"Home","icon":"dashboard","order":1,"disabled":false,"hidden":false}]
The SVG contains a simple circly with id my_circle
:
<svg x="0" y="0" height="350" viewBox="-0.04032258064515237 0 250.0806451612903 350" width="250" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" preserveAspectRatio="xMidYMid meet">
<circle id="my_circle" cx="30" cy="30" r="25" style="stroke: none; fill: #0000ff;">
</circle>
</svg>
I have an animation with id my_animation
, that changes the my_circle's color from blue to red:
my_animation should be started as soon as the circle is clicked:
And it indeed works like that:
No idea why your example doesn't work, when looking at the screenshots....
I have added your flow and it works as expected, great..
Can you please export this part of your flow and share it here!
Here below my test, it is a work in progress and some things could be improved.
[{"id":"9d2ddf5e.b72f08","type":"tab","label":"Flow 2","disabled":false,"info":""},{"id":"cbaacb83.0da518","type":"ui_svg_graphics","z":"9d2ddf5e.b72f08","group":"4ffb8df1.2bd194","order":1,"width":"0","height":"0","svgString":"<svg x=\"0\" y=\"0\" height=\"204\" width=\"264\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" preserveAspectRatio=\"xMidYMid meet\">\n\n <g id=\"background\">\n <rect id=\"background_rect\" x=\"2\" y=\"2\" rx=\"10\" ry=\"10\" height=\"170\" width=\"260\" fill=\"var(--nr-dashboard-widgetTextColor)\" style=\"stroke:black;stroke-width:1px;\"/>\n <image id=\"away_set_img\" x=\"70\" y=\"139\" width=\"36\" height=\"24\" style=\"cursor:pointer;\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\"/>\n <image id=\"frozen_set_img\" x=\"20\" y=\"139\" width=\"36\" height=\"24\" style=\"cursor:pointer;\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\"/>\n <text id=\"room_text\" x=\"180\" y=\"31\" style=\"fill: black; font-family: Arial; font-size: 25px; text-anchor: middle; font-variant-caps: small-caps;font-weight:lighter;\" lengthAdjust=\"spacing\">Salone</text>\n <text id=\"battery\" x=\"220\" y=\"163\" font-family=\"FontAwesome\" fill=\"black\" font-size=\"20px\" display=\"inline\"></text>\n <image id=\"wifi4_img\" x=\"160\" y=\"144\" width=\"40\" height=\"18\" display=\"none\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\"/>\n <image id=\"wifi3_img\" x=\"160\" y=\"144\" width=\"40\" height=\"18\" display=\"none\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\"/>\n <image id=\"wifi2_img\" x=\"160\" y=\"144\" width=\"40\" height=\"18\" display=\"none\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\"/>\n <image id=\"wifi1_img\" x=\"160\" y=\"144\" width=\"40\" height=\"18\" display=\"none\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\"/>\n <image id=\"wifierr_img\" x=\"160\" y=\"144\" width=\"40\" height=\"18\" display=\"inline\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\"/>\n </g>\n <g id=\"temp_get_group\">\n <rect id=\"temp_get_rect\" x=\"20\" y=\"42\" width=\"90\" height=\"85\" rx=\"10\" ry=\"10\" style=\"fill:white;stroke:silver;stroke-width:1px;\"/>\n <text id=\"temp_get_text\" x=\"40\" y=\"90\" style=\"fill:black;font-family:Arial;font-size:40px;\">22</text>\n <text id=\"temp_get_decimal_text\" x=\"82\" y=\"75\" style=\"fill:black;font-family:Arial;font-size:20px;\">0</text>\n <image id=\"boiler_on_img\" x=\"38\" y=\"87\" width=\"38\" height=\"40\" display=\"inline\" preserveAspectRatio=\"xMidYMid meet\" xlink:href=\"\" transform=\"matrix(0.585428 0 0 0.585428 33.7423 44.5555)\"/>\n </g>\n <g id=\"temp_set_group\">\n <rect id=\"temp_set_rect\" x=\"40\" y=\"12\" width=\"50\" height=\"40\" rx=\"5\" ry=\"5\" style=\"fill:black;stroke:black;stroke-width:1px;\"/>\n <text id=\"temp_set_text\" x=\"45\" y=\"44\" style=\"fill: white; font-family: Arial; font-size:30px;\">16</text>\n <text id=\"temp_set_decimal_text\" x=\"79\" y=\"34\" style=\"fill:white;font-family:Arial;font-size:15px;\">0</text>\n </g>\n <g id=\"temp_down_group\" style=\"cursor:pointer;\">\n <circle id=\"temp_down_circle\" cx=\"160\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <text id=\"temp_down_text\" x=\"153\" y=\"94\" style=\"fill:silver;font-family:Arial;font-size:40px;cursor:pointer;\">-</text>\n </g>\n <g id=\"temp_up_group\" style=\"cursor:pointer;\">\n <circle id=\"temp_up_circle\" cx=\"230\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <text id=\"temp_up_text\" x=\"218\" y=\"97\" style=\"fill:silver;font-family:Arial;font-size:40px;cursor:pointer;\">+</text>\n </g>\n\n</svg>\n","clickableShapes":[{"targetId":"#temp_down_group","action":"dblclick","payload":"","payloadType":"str","topic":"Netatmo/temp/set/down"},{"targetId":"#temp_up_group","action":"click","payload":"","payloadType":"str","topic":"Netatmo/temp/set/up"},{"targetId":"#away_set_img","action":"click","payload":"","payloadType":"str","topic":"Netatmo/temp/set/away"},{"targetId":"#frozen_set_img","action":"click","payload":"","payloadType":"str","topic":"Netatmo/temp/set/frozen"}],"javascriptHandlers":[{"selector":"#temp_down_group","action":"click","sourceCode":"var setpoint_decimal = $(\"#temp_set_decimal_text\")[0]. textContent;\nvar setpoint = $(\"#temp_set_text\")[0]. textContent;\n\nif (setpoint==\"MAX\") {\n $(\"#temp_set_decimal_text\")[0]. textContent='5';\n $(\"#temp_set_text\")[0]. textContent= '29';\n}else if (setpoint==\"0\") {\n $(\"#temp_set_text\")[0]. textContent= 'OFF';\n $(\"#temp_set_decimal_text\")[0]. textContent='';\n}else {\n\n if (setpoint_decimal==\"5\") {\n $(\"#temp_set_decimal_text\")[0]. textContent='0';\n }else if (setpoint_decimal==\"0\") {\n $(\"#temp_set_decimal_text\")[0]. textContent='5';\n $(\"#temp_set_text\")[0]. textContent= setpoint-1;\n }\n}\n\nif ($(\"#temp_set_text\")[0]. textContent.length<2) {\n $(\"#at_boiler_on_onload\")[0]. beginElement();\n $(\"#temp_set_text_1dig_on\")[0]. beginElement();\n $(\"#temp_set_decimal_text_1dig_on\")[0]. beginElement();\n }else {\n\n $(\"#temp_set_text_on\")[0]. beginElement();\n $(\"#temp_set_decimal_text_1dig_off\")[0]. beginElement();\n}\n"},{"selector":"#temp_up_group","action":"click","sourceCode":"$(\"#temp_set_text_1dig_on\")[0]. beginElement();\n $(\"#temp_set_decimal_text_1dig_on\")[0]. beginElement();\n"}],"smilAnimations":[{"id":"at_boiler_on_online","targetId":"background_rect","classValue":"","attributeName":"fill","transformType":"rotate","fromValue":"snow","toValue":"orange","trigger":"msg","duration":"2","durationUnit":"s","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"at_boiler_off_online","targetId":"background_rect","classValue":"","attributeName":"fill","transformType":"rotate","fromValue":"orange","toValue":"snow","trigger":"msg","duration":"2","durationUnit":"s","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"at_boiler_on_onload","targetId":"background_rect","classValue":"","attributeName":"fill","transformType":"rotate","fromValue":"orange","toValue":"orange","trigger":"msg","duration":"1","durationUnit":"s","repeatCount":"0","end":"restore","delay":"1","delayUnit":"s","custom":""},{"id":"at_boiler_off_onload","targetId":"background_rect","classValue":"","attributeName":"fill","transformType":"rotate","fromValue":"snow","toValue":"snow","trigger":"msg","duration":"1","durationUnit":"s","repeatCount":"0","end":"restore","delay":"1","delayUnit":"s","custom":""},{"id":"at_battery_low","targetId":"battery","classValue":"","attributeName":"display","transformType":"rotate","fromValue":"none","toValue":"inline","trigger":"msg","duration":"1","durationUnit":"s","repeatCount":"0","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"at_battery_normal","targetId":"battery","classValue":"","attributeName":"display","transformType":"rotate","fromValue":"inline","toValue":"inline","trigger":"msg","duration":"1","durationUnit":"s","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"temp_set_text_off","targetId":"temp_set_text","classValue":"","attributeName":"transform","transformType":"scale","fromValue":"1 1","toValue":"0.84 1","trigger":"msg","duration":"100","durationUnit":"ms","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"temp_set_text_on","targetId":"temp_set_text","classValue":"","attributeName":"transform","transformType":"scale","fromValue":"1 1","toValue":"1 1","trigger":"msg","duration":"100","durationUnit":"ms","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"temp_set_text_1dig_on","targetId":"temp_set_text","classValue":"","attributeName":"transform","transformType":"translate","fromValue":"0 0","toValue":"8 0","trigger":"msg","duration":"100","durationUnit":"ms","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"temp_set_decimal_text_1dig_on","targetId":"temp_set_decimal_text","classValue":"","attributeName":"transform","transformType":"translate","fromValue":"0 0","toValue":"-8 0","trigger":"msg","duration":"100","durationUnit":"ms","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""},{"id":"temp_set_decimal_text_1dig_off","targetId":"temp_set_decimal_text","classValue":"","attributeName":"transform","transformType":"scale","fromValue":"1 1","toValue":"1 1","trigger":"msg","duration":"100","durationUnit":"ms","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""}],"bindings":[],"showCoordinates":false,"autoFormatAfterEdit":false,"showBrowserErrors":true,"outputField":"","editorUrl":"//drawsvg.org/drawsvg.html","directory":"","panning":"disabled","zooming":"disabled","panOnlyWhenZoomed":false,"doubleClickZoomEnabled":false,"mouseWheelZoomEnabled":false,"name":"Netatmo","x":859,"y":300,"wires":[[]]},{"id":"b4b0be91.e10328","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"boiler_state_online","payload":"false","payloadType":"bool","x":191,"y":441,"wires":[["907a344b.c038c8"]]},{"id":"f6707f2e.71bce8","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"boiler_state_online","payload":"true","payloadType":"bool","x":191,"y":481,"wires":[["907a344b.c038c8"]]},{"id":"aac87487.960cd","type":"comment","z":"9d2ddf5e.b72f08","name":"Animation_online","info":"","x":160,"y":400,"wires":[]},{"id":"ec33c02f.e21968","type":"comment","z":"9d2ddf5e.b72f08","name":"Animation_onload","info":"","x":206,"y":222,"wires":[]},{"id":"7cb925b5.e38044","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":true,"onceDelay":"0.1","topic":"boiler_state_onload","payload":"false","payloadType":"bool","x":197,"y":309,"wires":[["907a344b.c038c8"]]},{"id":"a781c008.0401b","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"boiler_state_onload","payload":"true","payloadType":"bool","x":197,"y":349,"wires":[["907a344b.c038c8"]]},{"id":"f48d9fcd.edcb58","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"target_temperature","payload":"9.5","payloadType":"str","x":698.0000305175781,"y":593.0000228881836,"wires":[["907a344b.c038c8"]]},{"id":"a2a3e5da.306fb8","type":"comment","z":"9d2ddf5e.b72f08","name":"Animation_all","info":"","x":149,"y":520,"wires":[]},{"id":"918e9277.5a009","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"ambient_temperature","payload":"21.6","payloadType":"str","x":174,"y":722,"wires":[["907a344b.c038c8"]]},{"id":"2476a6d.5cd22da","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"battery_thermostat","payload":"full","payloadType":"str","x":175,"y":757,"wires":[["907a344b.c038c8"]]},{"id":"85b68dd5.665ab8","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"battery_thermostat","payload":"high","payloadType":"str","x":175,"y":796,"wires":[["907a344b.c038c8"]]},{"id":"38acad4f.7db9ba","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"battery_thermostat","payload":"medium","payloadType":"str","x":158,"y":836,"wires":[["907a344b.c038c8"]]},{"id":"ccd85218.7e226","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"battery_thermostat","payload":"low","payloadType":"str","x":175,"y":875,"wires":[["907a344b.c038c8"]]},{"id":"ad01f8cd.99598","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"battery_thermostat","payload":"empty","payloadType":"str","x":163,"y":916,"wires":[["907a344b.c038c8"]]},{"id":"ca947f13.e9d528","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"battery_thermostat","payload":"error","payloadType":"str","x":167,"y":960,"wires":[["907a344b.c038c8"]]},{"id":"3116ff10.7f108","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"rf_thermostat","payload":"100","payloadType":"num","x":184,"y":1001,"wires":[["907a344b.c038c8"]]},{"id":"d7c835e4.3fcb88","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"rf_thermostat","payload":"75","payloadType":"num","x":194,"y":1040,"wires":[["907a344b.c038c8"]]},{"id":"2f0eb803.c3c568","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"rf_thermostat","payload":"50","payloadType":"num","x":193,"y":1080,"wires":[["907a344b.c038c8"]]},{"id":"9af4279.1201bd8","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"rf_thermostat","payload":"25","payloadType":"num","x":192,"y":1118,"wires":[["907a344b.c038c8"]]},{"id":"5e8a3b73.0dabbc","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"rf_thermostat","payload":"0","payloadType":"num","x":192,"y":1155,"wires":[["907a344b.c038c8"]]},{"id":"ec5c88b5.7d38f8","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"room_thermostat","payload":"Cucina","payloadType":"str","x":222,"y":1202,"wires":[["907a344b.c038c8"]]},{"id":"d769e76a.5b5f28","type":"function","z":"9d2ddf5e.b72f08","name":"Thermostat Status","func":"var outputMsgs = [];\n\n\nlet station = [\"room_thermostat\",\n \"boiler_state_onload\",\n \"battery_thermostat\",\n \"rf_thermostat\",\n \"target_temperature\",\n \"ambient_temperature\"\n ];\n \nlet state = [global.get(\"Saloneroom_thermostat\")|| \"ND\",\n global.get(\"Saloneboiler_state\")|| false,\n global.get(\"Salonebattery_thermostat\")|| \"err\",\n global.get(\"Salonerf_strength\")|| 0,\n parseFloat(global.get(\"Salonesetpoint_temperature\")|| 0.0).toFixed(1),\n parseFloat(global.get(\"Salonemeasured_temperature\")|| 0.0).toFixed(1)\n ];\n\nvar index;\n\nfor (index = 0; index < station.length; ++index) {\n outputMsgs.push({topic:station[index] ,payload:state[index]}) \n}\n\n\nreturn [outputMsgs];","outputs":1,"noerr":0,"initialize":"","finalize":"","x":213,"y":255.000244140625,"wires":[["907a344b.c038c8"]]},{"id":"44e65b29.000bac","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"target_temperature","payload":"21.5","payloadType":"str","x":174,"y":604.000244140625,"wires":[["907a344b.c038c8"]]},{"id":"2feb3bf7.42f484","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"target_temperature","payload":"0","payloadType":"str","x":178,"y":680.000244140625,"wires":[["907a344b.c038c8"]]},{"id":"96a9ba92.a988e","type":"inject","z":"9d2ddf5e.b72f08","name":"","props":[{"p":"payload"},{"p":"topic","vt":"str"}],"repeat":"","crontab":"","once":false,"onceDelay":"","topic":"target_temperature","payload":"30.0","payloadType":"str","x":174,"y":564.000244140625,"wires":[["907a344b.c038c8"]]},{"id":"907a344b.c038c8","type":"function","z":"9d2ddf5e.b72f08","name":"","func":"//var x = global.get(\"Netatmo_boiler_state\") || false;\nlet topic = msg.topic;\nvar newmsg = {};\n\nif (topic.includes(\"boiler_state\")){\n \n let x = msg.payload;\n \n if (topic.includes(\"online\")) {\n \n switch (x) {\n \n case true :\n \n newmsg.payload = [\n {command:\"trigger_animation\",selector:\"#at_boiler_on_online\",action:\"start\"},\n {command:\"set_attribute\",selector:\"#boiler_on_img\",attributeName:\"display\",attributeValue:\"inline\"}\n ];\n break;\n \n case false : \n \n newmsg.payload = [\n {command:\"trigger_animation\",selector:\"#at_boiler_off_online\",action:\"start\"},\n {command:\"set_attribute\",selector:\"#boiler_on_img\",attributeName:\"display\",attributeValue:\"none\"}\n ];\n break;\n }\n }\n if (topic.includes(\"onload\")) {\n \n switch (x) {\n \n case true :\n \n newmsg.payload = [\n //{command:\"set_attribute\",selector:\"#background_rect\",attributeName:\"fill\",attributeValue:\"orange\"},\n {command:\"trigger_animation\",selector:\"#at_boiler_on_onload\",action:\"start\"},\n {command:\"set_attribute\",selector:\"#boiler_on_img\",attributeName:\"display\",attributeValue:\"inline\"}\n ];\n break;\n \n case false : \n \n newmsg.payload = [\n //{command:\"set_attribute\",selector:\"#background_rect\",attributeName:\"fill\",attributeValue:\"ghostwhite\"},\n {command:\"trigger_animation\",selector:\"#at_boiler_off_onload\",action:\"start\"},\n {command:\"set_attribute\",selector:\"#boiler_on_img\",attributeName:\"display\",attributeValue:\"none\"}\n ];\n break;\n }\n }\n \n}else if (topic.includes(\"temperature\")){\n var str = msg.payload;\n var temp = \"\";\n var tempDecimal = \"\";\n var var1d = false;\n var strString = false;\n if (str == \"0.0\" || str == \"0\"){\n temp = \"OFF\"\n strString = true;\n var1d =false;\n } else if (parseFloat(str).toFixed(1) >= 30.0){\n temp = \"MAX\"\n strString = true;\n var1d =false;\n } else if (str.indexOf('.') !== -1){ //verifico se è decimale\n //var temp = str.substring(0, 2);\n temp = str.substring(0, str.indexOf('.'));\n tempDecimal = str.substring(str.indexOf('.')+1, 4);\n strString = false;\n \n if (temp.length >1){\n var1d =false;\n }else{\n var1d =true;\n }\n } else if (str.indexOf('.') == -1 && str.length >1){ //true\n //var temp = str.substring(0, 2);\n temp = str;\n tempDecimal = \"0\";\n strString = false;\n var1d =false;\n } else if (str.indexOf('.') == -1 && str.length <2){ //true\n //var temp = str.substring(0, 2);\n temp = str;\n tempDecimal = \"0\";\n strString = false;\n var1d =true;\n } \n \n if (topic.includes(\"target\")) {\n \n newmsg.payload = [\n {command:\"update_text\",selector:\"#temp_set_text\",textContent:temp},\n {command:\"update_text\",selector:\"#temp_set_decimal_text\",textContent:tempDecimal},\n {command: \"trigger_animation\", selector: \"#temp_set_text_off\", action:(strString ==true ? \"start\" : \"stop\")},\n {command: \"trigger_animation\", selector: \"#temp_set_text_on\", action:(strString !=true ? \"start\" : \"stop\")},\n {command: \"trigger_animation\", selector: \"#temp_set_text_1dig_on\", action:(var1d == true ? \"start\" : \"stop\")},\n {command: \"trigger_animation\", selector: \"#temp_set_decimal_text_1dig_on\", action:(var1d == true ? \"start\" : \"stop\")},\n {command: \"trigger_animation\", selector: \"#temp_set_decimal_text_1dig_off\", action:(var1d != true ? \"start\" : \"stop\")}\n ];\n }\n if (topic.includes(\"ambient\")){\n \n newmsg.payload = [\n {command:\"update_text\",selector:\"#temp_get_text\",textContent:temp},\n {command:\"update_text\",selector:\"#temp_get_decimal_text\",textContent:tempDecimal}\n ];\n }\n}else if (topic.includes(\"thermostat\")){\n let state = msg.payload;\n var w1show, w2show, w3show, w4show = false;\n var animation = false;\n var values = [0,25,50,75,100];\n \n if (topic.includes(\"battery\")){\n \n switch (state){\n case \"full\":\n text = \"\";\n animation = false;\n break;\n case \"high\":\n text = \"\";\n animation = false;\n break;\n case \"medium\":\n text = \"\";\n animation = false;\n break;\n case \"low\":\n text = \"\";\n animation = true;\n break;\n case \"empty\":\n text = \"\";\n animation = true;\n break;\n default:\n text = \"err\"; \n \n }\n \n newmsg.payload = [\n {command:\"trigger_animation\",selector:\"#at_battery_low\",action:(animation ==true ? \"start\" : \"stop\")},\n {command:\"trigger_animation\",selector:\"#at_battery_normal\",action:(animation ==false ? \"start\" : \"stop\")},\n //{command:\"set_attribute\",selector:\"#battery\",attributeName:\"display\",attributeValue:\"inline\"},\n {command:\"update_text\",selector:\"#battery\",textContent:text},\n {command:\"set_attribute\",selector:\"#battery\",attributeName: \"fill\",attributeValue:(animation ==true ? \"red\" : \"black\")}\n ];\n \n }else if (topic.includes(\"rf\")){\n \n if (state >= values[1] && state < values[2]){\n w1show = true;\n w2show = false;\n w3show = false;\n w4show = false;\n weshow = false;\n }else if (state >= values[2] && state < values[3]){\n w1show = false;\n w2show = true;\n w3show = false;\n w4show = false;\n weshow = false;\n }else if (state >= values[3] && state < values[4]){\n w1show = false;\n w2show = false;\n w3show = true;\n w4show = false;\n weshow = false;\n }else if (state >= values[4]){\n w1show = false;\n w2show = false;\n w3show = false;\n w4show = true;\n weshow = false;\n }else{\n w1show = false;\n w2show = false;\n w3show = false;\n w4show = false;\n weshow = true;\n } \n\n newmsg.payload = [\n {command:\"set_attribute\",selector:\"#wifi1_img\",attributeName:\"display\",attributeValue:(w1show ==true ? \"inline\" : \"none\")},\n {command:\"set_attribute\",selector:\"#wifi2_img\",attributeName:\"display\",attributeValue:(w2show ==true ? \"inline\" : \"none\")},\n {command:\"set_attribute\",selector:\"#wifi3_img\",attributeName:\"display\",attributeValue:(w3show ==true ? \"inline\" : \"none\")},\n {command:\"set_attribute\",selector:\"#wifi4_img\",attributeName:\"display\",attributeValue:(w4show ==true ? \"inline\" : \"none\")},\n {command:\"set_attribute\",selector:\"#wifierr_img\",attributeName:\"display\",attributeValue:(weshow ==true ? \"inline\" : \"none\")}\n ];\n }else if (topic.includes(\"room\")){\n \n newmsg.payload = [{command:\"update_text\",selector:\"#room_text\",textContent:state}];\n }\n \n \n}\n \n \n \n//msg.topic = \"trigger_animation\";\nreturn newmsg;\n\n","outputs":1,"noerr":0,"initialize":"","finalize":"","x":638.0001220703125,"y":277,"wires":[["cbaacb83.0da518"]]},{"id":"4ffb8df1.2bd194","type":"ui_group","name":"svg","tab":"48fa7ffc.1df2a","order":1,"disp":true,"width":"6","collapse":false},{"id":"48fa7ffc.1df2a","type":"ui_tab","name":"tests","icon":"dashboard","order":13,"disabled":false,"hidden":false}]
I made some other test and it work, probably I have done some mistake in the JS flow.
Thank you for your patient Regards
Morning, I have taken the liberty to update your post: if you add 3 backticks (in the lines above and below your flow), it will be displayed on a single line.
I have not been able to identify your problem, because I have not enough time to figure out how your entire flow works. I have tried to simplify your flow, but then I don't get that error:
[{"id":"cbaacb83.0da518","type":"ui_svg_graphics","z":"9d2ddf5e.b72f08","group":"4ffb8df1.2bd194","order":1,"width":"0","height":"0","svgString":"<svg x=\"0\" y=\"0\" height=\"204\" width=\"264\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:svg=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" preserveAspectRatio=\"xMidYMid meet\">\n <g id=\"temp_set_group\">\n <text id=\"temp_set_decimal_text\" x=\"79\" y=\"34\" style=\"fill:white;font-family:Arial;font-size:15px;\">9999</text>\n </g>\n <g id=\"temp_down_group\" style=\"cursor:pointer;\">\n <circle id=\"temp_down_circle\" cx=\"40\" cy=\"40\" r=\"30\" style=\"fill:blue;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <text id=\"temp_down_text\" x=\"100\" y=\"94\" style=\"fill:silver;font-family:Arial;font-size:40px;cursor:pointer;\">temp down text</text>\n </g>\n</svg>\n","clickableShapes":[],"javascriptHandlers":[{"selector":"#temp_down_group","action":"click","sourceCode":"$(\"#temp_set_decimal_text_1dig_off\")[0].beginElement();"}],"smilAnimations":[{"id":"temp_set_decimal_text_1dig_off","targetId":"temp_set_decimal_text","classValue":"","attributeName":"transform","transformType":"scale","fromValue":"1 1","toValue":"1 1","trigger":"msg","duration":"100","durationUnit":"ms","repeatCount":"1","end":"freeze","delay":"1","delayUnit":"s","custom":""}],"bindings":[],"showCoordinates":false,"autoFormatAfterEdit":false,"showBrowserErrors":true,"showBrowserEvents":true,"outputField":"","editorUrl":"//drawsvg.org/drawsvg.html","directory":"","panning":"disabled","zooming":"disabled","panOnlyWhenZoomed":false,"doubleClickZoomEnabled":false,"mouseWheelZoomEnabled":false,"name":"Netatmo","x":859,"y":300,"wires":[[]]},{"id":"4ffb8df1.2bd194","type":"ui_group","name":"svg","tab":"48fa7ffc.1df2a","order":1,"disp":true,"width":"6","collapse":false},{"id":"48fa7ffc.1df2a","type":"ui_tab","name":"tests","icon":"dashboard","order":13,"disabled":false,"hidden":false}]
There are two things you can do:
If you want to try the second option, here is how you can do it:
Search for the folder where this SVG node is installed. You need to search that inside your .node red folder:
<somewhere on your machine\.node-red\node_modules\node-red-contrib-ui-svg
Add a debugger
statement before the line where your Javascript code is evaluated:
Restart Node-RED to detect this updated code.
Open the developer tools for your browser. For example for Chrome like this:
Do you stuff in the SVG, and once your event is triggered the browser's debugger will pause at your debugger
statement.
Now you can show variables, and execute pieces of your Javascript event handler one by one (to figure out where stuff goes wrong:
I think that once you start writing your own JS handler, you need to be able to debug your JS code. Otherwise you will depend heavily on other people that might not always be able to help you. I will add that to the readme page, because of course when you start writing Javascript event handlers you should be able to debug your code...
P.S. in the above animation you will see that I get a reference to your animation element (instead of an undefined like in your screenshots)....
Hi,
I have quickly added a newe feature to avoid that you have to add the debugger
statement manually.
The procedure is now a bit easier:
Enable JS debugging in the "Settings" tabsheet:
Open the developer tools for your browser. For example for Chrome like this:
Do you stuff in the SVG in the dashboard, and once your event is triggered the browser's debugger will pause here automatically:
Now you can show variables, and execute pieces of your Javascript code (which is inside the userData.sourceCode
variable) one by one (to figure out where stuff goes wrong).
Hi Bart, Thank you for your help, I really appreciate it. I started to do some test with browser debug. I still not able to understand why this issue appears. I have understood where is the issue but I can't understand why it is not works. Here below is the piece of code that create the issue, if I remove it all the animations work fine.
if (setpoint_decimal=="5") {
$("#temp_set_decimal_text")[0]. textContent='0';
}else if (setpoint_decimal=="0") {
$("#temp_set_decimal_text")[0]. textContent='5';
$("#temp_set_text")[0]. textContent= setpoint-1;
}
I will investigate probably the issue could be related to the variable type. I have tried to convert the text in Int and changed the above if with a switch, but the result is the same. The code works because the text in the SVG is decreased, but this corrupt the animation
If I check the code in the console and some backslash are coming
Thank you your support. Regards
BTW you should remove the space 3 time before textContent
...
Not sure why the double quotes are being escaped via \
.
When I put your code snippet into my JS event handler, the there is no escaping:
As an experiment, you could try to replace the double quotes by single quotes. Then we we know at least whether that is the root cause of your troubles ...
Even when I debug on Chrome on virtualBox MacOS, the double quotes are not escaped. Note that I only run a browser on virtualbox, but Node-RED itself is running on Windows. Perhaps you are running Node-RED on MacOS also, and there somehow the escaping is applied??
Hi Bart,
Thank you for your help, you opened a world to me with debug, and the idea to enable JS debugging in the "Settings" tabsheet it has been amazing.
I have followed your advice, I have replaced the double quotes by single quotes and the backslashes are disappeared, great.
I have also removed the spaces before textContent
but this it seems the same, the code works well also whit the spaces.
I didn't resolve the issue about the AnimateTransform but I have changed my approach, as my AnimateTransform it was a work around to translate and scale the text, I'm now using the property .style.transform
of the text element to translate and scale the text directly in JS tabsheet, and it is more fluid and faster.
In the meantime I'm continuing to develop and I will inform you in case I will resolve my issue about AnimateTransform, in the mean time my knowledge is growing and maybe I will found the issue on that code.
Only for your information my Node-Red instance is hosted on a Raspberry pi 3.
I really thank you for your kindly support. Regards @krikkoo
Glad that you find it useful! I'm always suprised how people are able to write code without usung a debugger. I always experiment with code snippets (in the console tab) while I am debugging. That way I'm 100% sure that this code snippets will work correctly, before I add those snippets to my node program...
Only for your information my Node-Red instance is hosted on a Raspberry pi 3.
Will need to test that this week, to be able to determine where the double quotes are being applied...
Hi Bart,
Sorry if I disturb you, I was playing with text in SVG and I found, surfing on web at this link, that there are some Event Attributes that could be useful to add in the JS tab, for example onchange
for text could be very useful.
I really don't know if it is possible, here below what I have done.
I tried to use in a text element to call the function that translate the text according to it content. It is the same function that I call from JS sheet in mouse events and it works.
<text id="temp_set_text1" onchange="Transform()" x="44" y="44" style="fill: white; font-family: Arial; font-size:30px;">1</text>
I'm trying to use direct in the element but it not works, instead onclick
works well.
Can you tell me if I'm doing somethings that is not allowed, I enabled JS debug but no error coming out.
Thank you for your time.. Regards
Do I understand this correctly:
Correct? Can you please post be me - for both tabsheets wjat you have entered? And please only the part relevant for this specific question.
Hi Burt, Here below there are the three cases that I have done.
[{"id":"64885236.dd5efc","type":"tab","label":"Flow 2","disabled":false,"info":""},{"id":"42c9098.3bc25f8","type":"inject","z":"64885236.dd5efc","name":"Show alert at double click","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"{\"command\":\"add_js_event\",\"event\":\"onchange\",\"selector\":\"#temp_set_text3\",\"script\":\"function Transform3(){var setpoint = $('#temp_set_text')[0].textContent;if (setpoint.length == 1 ){$('#temp_set_text_group')[0].style.transform='translateX(8px)';$('#temp_set_decimal_text_group')[0].style.transform='translateX(-8px)';}else if (setpoint.length == 2){$('#temp_set_text_group')[0].style.transform='scale(1)';$('#temp_set_decimal_text_group')[0].style.transform='scale(1)';}else if (setpoint.length == 3){$('#temp_set_text_group')[0].style.transform='translateX(3px) scale(0.82, 1)';}}\"}","payloadType":"json","x":354,"y":334,"wires":[["83e37230.c051c8"]]},{"id":"c4242bdd.ebe57","type":"ui_svg_graphics","z":"64885236.dd5efc","group":"8f59fa7c.29e13","order":1,"width":"0","height":"0","svgString":"<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0\" y=\"0\" height=\"204\" width=\"264\" preserveAspectRatio=\"xMidYMid meet\" viewBox=\"39.98632049560547 12 210.02735900878906 93\"><rect id=\"svgEditorBackground\" x=\"40\" y=\"12\" width=\"210\" height=\"93\" style=\"fill: none; stroke: none;\"/>\n \n <script>//<![CDATA[\n //document.getElementById(\"temp_set_text1\").addEventListener(\"onchange\", Transform);\n \n function Transform1(){\n console.log('MyTransform')\n setpoint = $('#temp_set_text1')[0].textContent;\n if (setpoint.length == 1 ){\n $('#temp_set_text_group1')[0].style.transform='translateX(8px)';\n $('#temp_set_decimal_group1')[0].style.transform='translateX(-8px)';\n }else if (setpoint.length == 2){\n $('#temp_set_text_group1')[0].style.transform='scale(1)';\n $('#temp_set_decimal_group1')[0].style.transform='scale(1)';\n }else if (setpoint.length == 3){\n $('#temp_set_text_group1')[0].style.transform='translateX(3px) scale(0.82, 1)';\n }\n }\n //]]>\n </script>\n \n <g id=\"temp_set_group1\">\n <rect id=\"temp_set_rect1\" x=\"40\" y=\"12\" width=\"50\" height=\"40\" rx=\"5\" ry=\"5\" style=\"fill:black;stroke:black;stroke-width:1px;\"/>\n <g id=\"temp_set_text_group1\">\n <text id=\"temp_set_text1\" x=\"44\" y=\"44\" style=\"fill: white; font-family: Arial; font-size:30px;\">1</text>\n </g>\n <g id=\"temp_set_decimal_group1\">\n <text id=\"temp_set_decimal_text1\" x=\"78\" y=\"34\" style=\"fill:white;font-family:Arial;font-size:15px;\">5</text>\n </g>\n </g>\n <g id=\"temp_down_group1\" style=\"cursor:pointer;\">\n <circle id=\"temp_down_circle1\" cx=\"160\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <rect x=\"151\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\" />\n </g>\n <g id=\"temp_up_group1\" style=\"cursor:pointer;\">\n <circle id=\"temp_up_circle1\" cx=\"230\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <rect x=\"221\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\"/>\n <rect x=\"221\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\" transform=\"rotate(90 230 83)\"/>\n </g>\n\n</svg>","clickableShapes":[],"javascriptHandlers":[{"selector":"#temp_down_group1","action":"mousedown","sourceCode":"var setpoint_decimal;\nvar setpoint;\nvar i;\n\ntimer = setInterval( function () {\n\n setpoint_decimal = parseInt($('#temp_set_decimal_text1')[0].textContent);\n setpoint = parseInt($('#temp_set_text1')[0].textContent) ;\n\n if (setpoint_decimal == 0 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text1')[0].textContent='5';\n setpoint -= 1;\n $('#temp_set_text1')[0].textContent=setpoint;\n }else if (setpoint_decimal == 5 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text1')[0].textContent='0';\n }\n\n setpoint = $('#temp_set_text1')[0].textContent;\n setpoint_decimal = parseInt($('#temp_set_decimal_text1')[0].textContent);\n \n if (setpoint == \"MAX\"){\n $('#temp_set_decimal_text1')[0].textContent='5';\n $('#temp_set_text1')[0].textContent= '29';\n\n }else if (setpoint == \"0\" && setpoint_decimal == \"0\"){\n $('#temp_set_text1')[0].textContent= 'OFF';\n $('#temp_set_decimal_text1')[0].textContent='';\n }else if (setpoint == \"OFF\"){\n clearInterval(timer);\n return;\n }\n\n Transform1()\n}, 300)\n"},{"selector":"#temp_down_group1","action":"mouseup","sourceCode":"clearInterval(timer);\n"},{"selector":"#temp_up_group1","action":"mousedown","sourceCode":"var setpoint_decimal;\nvar setpoint;\nvar stringsetpoint =\"\";\nvar i;\n\nconsole.log(setpoint);\n\ntimer = setInterval( function () {\n\n setpoint_decimal = parseInt($('#temp_set_decimal_text1')[0].textContent);\n setpoint = parseInt($('#temp_set_text1')[0].textContent) ;\n\n if (setpoint_decimal == 0 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text1')[0].textContent='5';\n }else if (setpoint_decimal == 5 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text1')[0].textContent='0';\n setpoint +=1;\n $('#temp_set_text1')[0].textContent=setpoint;\n }\n\n stringsetpoint = $('#temp_set_text1')[0].textContent;\n setpoint_decimal = parseInt($('#temp_set_decimal_text1')[0].textContent);\n console.log(stringsetpoint);\n if (stringsetpoint == \"OFF\"){\n $('#temp_set_decimal_text1')[0].textContent='5';\n $('#temp_set_text1')[0].textContent= '0';\n }else if (stringsetpoint == \"30\"){\n $('#temp_set_text1')[0].textContent= 'MAX';\n $('#temp_set_decimal_text1')[0].textContent='';\n }else if (stringsetpoint == \"MAX\"){\n clearInterval(timer);\n return;\n }\n\n Transform1()\n}, 300)\n"},{"selector":"#temp_up_group1","action":"mouseup","sourceCode":"clearInterval(timer);"}],"smilAnimations":[],"bindings":[],"showCoordinates":false,"autoFormatAfterEdit":false,"showBrowserErrors":true,"showBrowserEvents":false,"enableJsDebugging":true,"outputField":"","editorUrl":"//drawsvg.org/drawsvg.html","directory":"","panning":"disabled","zooming":"disabled","panOnlyWhenZoomed":false,"doubleClickZoomEnabled":false,"mouseWheelZoomEnabled":false,"name":"Netatmo Test 1","x":620,"y":260,"wires":[[]]},{"id":"deb021fa.d6542","type":"ui_svg_graphics","z":"64885236.dd5efc","group":"585e81d.29298","order":1,"width":"0","height":"0","svgString":"<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0\" y=\"0\" height=\"204\" width=\"264\" preserveAspectRatio=\"xMidYMid meet\" viewBox=\"39.98632049560547 12 210.02735900878906 93\"><rect id=\"svgEditorBackground\" x=\"40\" y=\"12\" width=\"210\" height=\"93\" style=\"fill: none; stroke: none;\"/>\n \n <script>//<![CDATA[\n //document.getElementById(\"temp_set_text2\").addEventListener(\"onchange\", Transform);\n \n function Transform2(){\n console.log('MyTransform')\n setpoint = $('#temp_set_text2')[0].textContent;\n if (setpoint.length == 1 ){\n $('#temp_set_text_group2')[0].style.transform='translateX(8px)';\n $('#temp_set_decimal_group2')[0].style.transform='translateX(-8px)';\n }else if (setpoint.length == 2){\n $('#temp_set_text_group2')[0].style.transform='scale(1)';\n $('#temp_set_decimal_group2')[0].style.transform='scale(1)';\n }else if (setpoint.length == 3){\n $('#temp_set_text_group2')[0].style.transform='translateX(3px) scale(0.82, 1)';\n }\n }\n //]]>\n </script>\n \n <g id=\"temp_set_group2\">\n <rect id=\"temp_set_rect2\" x=\"40\" y=\"12\" width=\"50\" height=\"40\" rx=\"5\" ry=\"5\" style=\"fill:black;stroke:black;stroke-width:1px;\"/>\n <g id=\"temp_set_text_group2\">\n <text id=\"temp_set_text2\" onchange=\"Transform()\" x=\"44\" y=\"44\" style=\"fill: white; font-family: Arial; font-size:30px;\">1</text>\n </g>\n <g id=\"temp_set_decimal_group2\">\n <text id=\"temp_set_decimal_text2\" x=\"78\" y=\"34\" style=\"fill:white;font-family:Arial;font-size:15px;\">5</text>\n </g>\n </g>\n <g id=\"temp_down_group2\" style=\"cursor:pointer;\">\n <circle id=\"temp_down_circle2\" cx=\"160\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <rect x=\"151\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\" />\n </g>\n <g id=\"temp_up_group2\" style=\"cursor:pointer;\">\n <circle id=\"temp_up_circle2\" cx=\"230\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <rect x=\"221\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\"/>\n <rect x=\"221\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\" transform=\"rotate(90 230 83)\"/>\n </g>\n\n</svg>","clickableShapes":[],"javascriptHandlers":[{"selector":"#temp_down_group2","action":"mousedown","sourceCode":"var setpoint_decimal;\nvar setpoint;\nvar i;\n\ntimer = setInterval( function () {\n\n setpoint_decimal = parseInt($('#temp_set_decimal_text2')[0].textContent);\n setpoint = parseInt($('#temp_set_text2')[0].textContent) ;\n\n if (setpoint_decimal == 0 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text2')[0].textContent='5';\n setpoint -= 1;\n $('#temp_set_text2')[0].textContent=setpoint;\n }else if (setpoint_decimal == 5 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text2')[0].textContent='0';\n }\n\n setpoint = $('#temp_set_text2')[0].textContent;\n setpoint_decimal = parseInt($('#temp_set_decimal_text2')[0].textContent);\n \n if (setpoint == \"MAX\"){\n $('#temp_set_decimal_text2')[0].textContent='5';\n $('#temp_set_text2')[0].textContent= '29';\n\n }else if (setpoint == \"0\" && setpoint_decimal == \"0\"){\n $('#temp_set_text2')[0].textContent= 'OFF';\n $('#temp_set_decimal_text2')[0].textContent='';\n }else if (setpoint == \"OFF\"){\n clearInterval(timer);\n return;\n }\n\n //Transform2()\n}, 300)\n"},{"selector":"#temp_down_group2","action":"mouseup","sourceCode":"clearInterval(timer);\n"},{"selector":"#temp_up_group2","action":"mousedown","sourceCode":"var setpoint_decimal;\nvar setpoint;\nvar stringsetpoint =\"\";\nvar i;\n\nconsole.log(setpoint);\n\ntimer = setInterval( function () {\n\n setpoint_decimal = parseInt($('#temp_set_decimal_text2')[0].textContent);\n setpoint = parseInt($('#temp_set_text2')[0].textContent) ;\n\n if (setpoint_decimal == 0 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text2')[0].textContent='5';\n }else if (setpoint_decimal == 5 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text2')[0].textContent='0';\n setpoint +=1;\n $('#temp_set_text2')[0].textContent=setpoint;\n }\n\n stringsetpoint = $('#temp_set_text2')[0].textContent;\n setpoint_decimal = parseInt($('#temp_set_decimal_text2')[0].textContent);\n console.log(stringsetpoint);\n if (stringsetpoint == \"OFF\"){\n $('#temp_set_decimal_text2')[0].textContent='5';\n $('#temp_set_text1')[0].textContent= '0';\n }else if (stringsetpoint == \"30\"){\n $('#temp_set_text2')[0].textContent= 'MAX';\n $('#temp_set_decimal_text2')[0].textContent='';\n }else if (stringsetpoint == \"MAX\"){\n clearInterval(timer);\n return;\n }\n\n //Transform2()\n}, 300)\n"},{"selector":"#temp_up_group2","action":"mouseup","sourceCode":"clearInterval(timer);"}],"smilAnimations":[],"bindings":[],"showCoordinates":false,"autoFormatAfterEdit":false,"showBrowserErrors":true,"showBrowserEvents":false,"enableJsDebugging":true,"outputField":"","editorUrl":"//drawsvg.org/drawsvg.html","directory":"","panning":"disabled","zooming":"disabled","panOnlyWhenZoomed":false,"doubleClickZoomEnabled":false,"mouseWheelZoomEnabled":false,"name":"Netatmo Test 2","x":619,"y":296,"wires":[[]]},{"id":"83e37230.c051c8","type":"ui_svg_graphics","z":"64885236.dd5efc","group":"d60d6dc3.d626c8","order":1,"width":"0","height":"0","svgString":"<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" x=\"0\" y=\"0\" height=\"204\" width=\"264\" preserveAspectRatio=\"xMidYMid meet\" viewBox=\"39.98632049560547 12 210.02735900878906 93\"><rect id=\"svgEditorBackground\" x=\"40\" y=\"12\" width=\"210\" height=\"93\" style=\"fill: none; stroke: none;\"/>\n \n <script>//<![CDATA[\n //document.getElementById(\"temp_set_text1\").addEventListener(\"onchange\", Transform);\n \n \n //]]>\n </script>\n \n <g id=\"temp_set_group3\">\n <rect id=\"temp_set_rect3\" x=\"40\" y=\"12\" width=\"50\" height=\"40\" rx=\"5\" ry=\"5\" style=\"fill:black;stroke:black;stroke-width:1px;\"/>\n <g id=\"temp_set_text_group3\">\n <text id=\"temp_set_text3\" x=\"44\" y=\"44\" style=\"fill: white; font-family: Arial; font-size:30px;\">1</text>\n </g>\n <g id=\"temp_set_decimal_group3\">\n <text id=\"temp_set_decimal_text3\" x=\"78\" y=\"34\" style=\"fill:white;font-family:Arial;font-size:15px;\">5</text>\n </g>\n </g>\n <g id=\"temp_down_group3\" style=\"cursor:pointer;\">\n <circle id=\"temp_down_circle3\" cx=\"160\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <rect x=\"151\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\" />\n </g>\n <g id=\"temp_up_group3\" style=\"cursor:pointer;\">\n <circle id=\"temp_up_circle3\" cx=\"230\" cy=\"83\" r=\"20\" style=\"fill:white;stroke-width:0.5px;stroke-opacity:1;stroke:silver;cursor:pointer;\"/>\n <rect x=\"221\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\"/>\n <rect x=\"221\" y=\"81.25\" width=\"18\" height=\"3.5\" rx=\"1\" ry=\"1\" style=\"fill:silver;stroke:none;stroke-width:1px;cursor:pointer;\" transform=\"rotate(90 230 83)\"/>\n </g>\n\n</svg>","clickableShapes":[],"javascriptHandlers":[{"selector":"#temp_down_group3","action":"mousedown","sourceCode":"var setpoint_decimal;\nvar setpoint;\nvar i;\n\ntimer = setInterval( function () {\n\n setpoint_decimal = parseInt($('#temp_set_decimal_text3')[0].textContent);\n setpoint = parseInt($('#temp_set_text3')[0].textContent) ;\n\n if (setpoint_decimal == 0 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text3')[0].textContent='5';\n setpoint -= 1;\n $('#temp_set_text3')[0].textContent=setpoint;\n }else if (setpoint_decimal == 5 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text3')[0].textContent='0';\n }\n\n setpoint = $('#temp_set_text3')[0].textContent;\n setpoint_decimal = parseInt($('#temp_set_decimal_text3')[0].textContent);\n \n if (setpoint == \"MAX\"){\n $('#temp_set_decimal_text3')[0].textContent='5';\n $('#temp_set_text3')[0].textContent= '29';\n\n }else if (setpoint == \"0\" && setpoint_decimal == \"0\"){\n $('#temp_set_text3')[0].textContent= 'OFF';\n $('#temp_set_decimal_text3')[0].textContent='';\n }else if (setpoint == \"OFF\"){\n clearInterval(timer);\n return;\n }\n\n //Transform()\n}, 300)\n"},{"selector":"#temp_down_group3","action":"mouseup","sourceCode":"clearInterval(timer);\n"},{"selector":"#temp_up_group3","action":"mousedown","sourceCode":"var setpoint_decimal;\nvar setpoint;\nvar stringsetpoint =\"\";\nvar i;\n\nconsole.log(setpoint);\n\ntimer = setInterval( function () {\n\n setpoint_decimal = parseInt($('#temp_set_decimal_text3')[0].textContent);\n setpoint = parseInt($('#temp_set_text3')[0].textContent) ;\n\n if (setpoint_decimal == 0 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text3')[0].textContent='5';\n }else if (setpoint_decimal == 5 && !isNaN(setpoint)) {\n $('#temp_set_decimal_text3')[0].textContent='0';\n setpoint +=1;\n $('#temp_set_text3')[0].textContent=setpoint;\n }\n\n stringsetpoint = $('#temp_set_text3')[0].textContent;\n setpoint_decimal = parseInt($('#temp_set_decimal_text3')[0].textContent);\n console.log(stringsetpoint);\n if (stringsetpoint == \"OFF\"){\n $('#temp_set_decimal_text3')[0].textContent='5';\n $('#temp_set_text3')[0].textContent= '0';\n }else if (stringsetpoint == \"30\"){\n $('#temp_set_text3')[0].textContent= 'MAX';\n $('#temp_set_decimal_text3')[0].textContent='';\n }else if (stringsetpoint == \"MAX\"){\n clearInterval(timer);\n return;\n }\n\n //Transform()\n}, 300)\n"},{"selector":"#temp_up_group3","action":"mouseup","sourceCode":"clearInterval(timer);"}],"smilAnimations":[],"bindings":[],"showCoordinates":false,"autoFormatAfterEdit":false,"showBrowserErrors":true,"showBrowserEvents":false,"enableJsDebugging":true,"outputField":"","editorUrl":"//drawsvg.org/drawsvg.html","directory":"","panning":"disabled","zooming":"disabled","panOnlyWhenZoomed":false,"doubleClickZoomEnabled":false,"mouseWheelZoomEnabled":false,"name":"Netatmo Test 3","x":618,"y":333,"wires":[[]]},{"id":"8f59fa7c.29e13","type":"ui_group","name":"Function in SVG Tabsheet and called from elements in JS Tabsheet","tab":"527c4ef0.7eaa3","order":1,"disp":true,"width":"6","collapse":false},{"id":"585e81d.29298","type":"ui_group","name":"Function in SGV TabSheet called from onchange event in SVG TabSheet","tab":"527c4ef0.7eaa3","order":2,"disp":true,"width":"6","collapse":false},{"id":"d60d6dc3.d626c8","type":"ui_group","name":"Function injected with 'onchange' Action","tab":"527c4ef0.7eaa3","order":3,"disp":true,"width":"6","collapse":false},{"id":"527c4ef0.7eaa3","type":"ui_tab","name":"test1","icon":"dashboard","order":13,"disabled":false,"hidden":false}]
The first one is working well, the others two no.
For the last case when I try to inject the JS event I received an error as follow.
Thank you for your support.
Regards
Only for your information my Node-Red instance is hosted on a Raspberry pi 3.
I have installed my node on a Raspberry pi 3 and used double quotes (in the "SVG" tabsheet). Then I have opened the dashboard both on Windows and IOs (virtualbox), but it works fine: never are the double quotes escaped ...
The first one is working well, the others two no.
And in the third test there are a number of problems:
In the input msg.payload.event you pass "onchange" as value. But you can see on the readme page that I currently only support following events (which is why you get the 'unsupported' errror):
In the input msg.payload.script you should add the code that needs to be executed when the event occurs. For example:
"script": "alert('change');"
But you write
function Transform3(){ ... }
So suppose I would support the change-event: when your code would be executed then your function definition would be created, but your function would never be called. So you should do instead:
function Transform3(){ ... };
Transform3();
And even if I would support the "change" event to my node, then: the input msg.payload.event would have to be "change" and not "onchange"...
But I have you already asked before to keep your test flows very simple. I only need a flow like <svg ...><text ... ></svg>
which demonstrates your issue. I have VERY few free time, so I cannot figure out all the flows that everybody keeps sending to me. Please rewrite the 3 flows to the "absolute" minimum that I need to reproduce the problem. And explain shortly for each of the 3 test flows where I need to do what (click ...) to reproduce the problem.
I have installed my node on a Raspberry pi 3 and used double quotes (in the "SVG" tabsheet). Then I have opened the dashboard both on Windows and IOs (virtualbox), but it works fine: never are the double quotes escaped .. Hi @krikkoo, Did you enter the code snippet in the "JS" tabsheet, or did you inject it via an input message? Or are there any other tips you can give me to reproduce the problem on my Raspberry pi 3? This is the last 'known' issue, which I would like to solve before I publish version 2.1.0 to NPM.
Please rewrite the 3 flows to the "absolute" minimum that I need to reproduce the problem.
If you would have some time to simplify your flow, I can try to reproduce it. And if I get your flow working, I can try to add some extra events (like e.g. change). But so few spare time lately...
Hi @bartbutenaers, Unfortunately this period I don't have match spare time to work on my flow.
Probably the problems that I incurred are due my low knowledge of JS.
You are in the right way, if you added the event change
in the JS sheet that trigger when a text field change its value (for example sending an update_text
injection) this will be wonderful.
In my opinion You can officially release this version of SVG. it is very stable and works like a charm. You can also close this issue of course.
Thank you very match for your time. Regards
Hi @krikkoo, thanks for the feedback. Yes me als not much free time lately :-( I think you have achieved quite a bit already with JS... I have no idea why the double quotes are escaped. Perhaps if I have published this version, I will have some extra use cases which perhaps might enlighten me about this issue... I will close this issue and when you have other questions/requests afterwards, you can open a new one. That is easier for me to track what has been solved. Have fun with it! Bart
Version 2.1.0 is now published on NPM.
@krikkoo, Can you please create a new Github issue about the missing events (like e.g. the 'change' event). And copy all relevant info to it. Otherwise I have to read through this whole discussion again afterwards, to see what is still not working for you and what not. That allows me to implement it quicker, as soon as I have some free time again. Thanks!!!
Hi, first of all thank you for your great job. I would ask you if there is some issue in my node red installation, it is installed on Rasberry pi 3. As per readme file it should be available a JS tab and also the possibility to inject javascript code trough msg.payload, but in my SVG config screen it not present JS tab and if I try to send JS in payload I received the following message "The msg.payload contains an object that has an unsupported command property 'add_js_event'". I have tried on chrome and safari browser with the same result.
Can you kindly help me please to understand what is wrong in my setup.
Thanks in advance. Best Regards