phoenix_html icon indicating copy to clipboard operation
phoenix_html copied to clipboard

Javascript data-confirm fires multiple times

Open tomciopp opened this issue 5 years ago • 4 comments

If you're using something like turbolinks, phoenix_html may get loaded multiple times. This leads to a situation where users will have to click the confirm dialog over and over to get the dialog to disappear.

Looking at the code and the docs for addEventListener, I believe there should be a simple fix to this problem.

If multiple identical EventListeners are registered on the same EventTarget with the same parameters, the duplicate instances are discarded. They do not cause the EventListener to be called twice, and they do not need to be removed manually with the removeEventListener() method.

Note, however that when using an anonymous function as the handler, such listeners will NOT be identical, because anonymous functions are not identical even if defined using the SAME unchanging source-code simply called repeatedly, even if in a loop.

It looks like the root of the problem is the fact that we are using anonymous functions when adding the event listener. If we can ensure that the functions are static when the code runs again the additional event listener will be ignored since it is identical. Since this is based off behavior from rails I think it would be good to borrow/steal their implementation since it should handle these problems out of the box.

https://github.com/rails/rails/tree/master/actionview/app/assets/javascripts

tomciopp avatar Jan 28 '20 08:01 tomciopp

Makes sense. Can you please send a PR that moves to a named function? Thank you!

josevalim avatar Jan 28 '20 08:01 josevalim

@josevalim Sure, I will take a look at implementing a solution tomorrow.

tomciopp avatar Jan 28 '20 09:01 tomciopp

Hi @tomciopp, so I asked around to know if the global is necessary and I was told that Turbolinks do not make it a requirement as long as you load scripts on the head, as advised by Turbolinks. Are you loading Phoenix HTML and friends on the <head> and the problem still persists?

josevalim avatar Jan 29 '20 15:01 josevalim

Yes, everything is loaded in the <head> and the problem persists.

tomciopp avatar Feb 03 '20 15:02 tomciopp