bartbutenaers / node-red-contrib-ui-svg

A Node-RED widget node to show interactive SVG (vector graphics) in the dashboard
Apache License 2.0
94 stars 27 forks source link

"JS" tab sheet and Javascript events via msg not available #76

Closed krikkoo closed 3 years ago

krikkoo commented 4 years ago

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

bartbutenaers commented 4 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

krikkoo commented 4 years ago

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

bartbutenaers commented 4 years ago

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?

krikkoo commented 4 years ago

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.

bartbutenaers commented 3 years ago

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 ...

krikkoo commented 3 years ago

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.

bartbutenaers commented 3 years ago

@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.

Updated example flow

Here is a better example flow (which I will update on the readme page):

image

[{"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:

macos_safari_click

And on MacOs in Chrome I also get a 'single' alert popup:

macos_chrome

Replace a previous event handler

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':

image

Syntax errors in injected Javascript code

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):

image

Show browser events on the server

And to make troubleshooting a bit easier in the future, I have added a extra checkbox:

image

When that checkbox is checked, a entry will appear in the Debug sidebar for every event that will be triggered:

image

Can you let me know if this works also works on your Mac?

Animation type dropdown

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:

safari_animate_dropdown

Your new question

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...

krikkoo commented 3 years ago

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

Schermata 2020-11-10 alle 00 14 55

and I would like to trigger it from JS tab

Schermata 2020-11-10 alle 19 15 29

I have tried lot of command without success. This error appear.

Schermata 2020-11-10 alle 19 28 41

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

bartbutenaers commented 3 years ago

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}]
  1. 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>
  2. I have an animation with id my_animation, that changes the my_circle's color from blue to red:

    image

  3. my_animation should be started as soon as the circle is clicked:

    image

  4. And it indeed works like that:

    svg_js_animation

No idea why your example doesn't work, when looking at the screenshots....

krikkoo commented 3 years ago

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

bartbutenaers commented 3 years ago

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:

  1. Create a very simple flow that contains only the part that fails, and let me know which 'simple' steps I need to perform to reproduce the problem. So - like in my simplified flow above - throw out everything that isn't relevant for this issue, because that is very time consuming for us to figure out for everybody how their flow works ...
  2. Or if you want to extend your technical skills, you can try to debug it yourself. Because once you know it, it will be a massive help to you for troubleshooting other issues in the future...

If you want to try the second option, here is how you can do it:

  1. 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
  2. Add a debugger statement before the line where your Javascript code is evaluated:

    image

  3. Restart Node-RED to detect this updated code.

  4. Open the developer tools for your browser. For example for Chrome like this:

    image

  5. Do you stuff in the SVG, and once your event is triggered the browser's debugger will pause at your debugger statement.

  6. Now you can show variables, and execute pieces of your Javascript event handler one by one (to figure out where stuff goes wrong:

    chrome_debug_js

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)....

bartbutenaers commented 3 years ago

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:

  1. Enable JS debugging in the "Settings" tabsheet:

    image

  2. Open the developer tools for your browser. For example for Chrome like this:

    image

  3. Do you stuff in the SVG in the dashboard, and once your event is triggered the browser's debugger will pause here automatically:

    image

  4. 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).

krikkoo commented 3 years ago

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

Schermata 2020-11-12 alle 20 28 41

Thank you your support. Regards

bartbutenaers commented 3 years ago

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:

image

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??

krikkoo commented 3 years ago

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

bartbutenaers commented 3 years ago

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...

krikkoo commented 3 years ago

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

bartbutenaers commented 3 years ago

Do I understand this correctly:

  1. When you add that function to the text element in the "SVG"-tabsheet, then it works fine.
  2. When you add that function via a Javascript code snippet in the "JS"-tabsheet, then it doesn't work.

Correct? Can you please post be me - for both tabsheets wjat you have entered? And please only the part relevant for this specific question.

krikkoo commented 3 years ago

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.

Schermata 2020-11-18 alle 18 20 03

Thank you for your support.

Regards

bartbutenaers commented 3 years ago

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.

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.

bartbutenaers commented 3 years ago

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...

krikkoo commented 3 years ago

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

bartbutenaers commented 3 years ago

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

bartbutenaers commented 3 years ago

Version 2.1.0 is now published on NPM.

bartbutenaers commented 3 years ago

@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!!!