Ripple effect not working in Firefox
mehrdad-shokri opened this issue · 14 comments
Have you tested ripple effect on firefox.
I have Firefox 48, ripple effect works on chrome but not on Firefox.
I'm seeing the same issue.
Can confirm, this package does not work on firefox
Hmm. Gross. I'll put in some time tomorrow morning to figure out what's going on.
Anything to report? Do we know what Firefox does/doesn't have that's causing this?
From what I've observed, the root cause is Firefox's handling of the canvas element (or something) inside a button
. If I put the ripple component inside a div, it works fine in Firefox.
The reason I say "or something", is because the ripple effect from the Material UI library also doesn't work in Firefox, and that one is implemented with a TransitionGroup
component and divs. (Side note — any benchmarks comparing the performance of the two approaches?)
So it's not a deficiency of this library, but rather a bug in Firefox. I've been trying to find a report in Mozilla's tracker of something like this happening in other cases, but nothing yet.
Hey @lourd, thanks for the update! I went down a bit of a rabbit hole on this too.
As far as I can tell, using canvas is significantly faster, but I don't have any hard benchmarks. However I originally did this with SVG and found the paint times were generally way faster in canvas. I performance profiled the current implementation using the timeline tab in Chrome, and through manual testing on devices.
I wish I had a better answer here. My stance on it so far has been that this component is a total enhancement, but I'd really love to sort out what's going on in Firefox.
Here's the corresponding issue from Material UI. Doesn't indicate a fix for this component, they simply workaround it by not putting the ripple in a button.
It seems that it works on Firefox but on extra conditions. I just realized that it works at least with 'href' or 'containerElement' attributes. However, it should not have an impact...
Let's see on official page on the label named 'Complex examples' and buttons named 'Choose an image' and 'Github link'.
However, despite it somehow works, it is bugged when screen is scrolled little down. Just like the ripple effect were attached to the point of the page... it is weird.
Anyone still having this issue, should reset dom.w3c_touch_events.enabled
and dom.w3c_touch_events.expose
values in about:config
to default values. It looks like it was set to wrong default in past FF versions.
That would only fix the problem for you, not your users.
Regardless, in Firefox 59.0.1, I'm not seeing dom.w3c_touch_events.expose
as an option in about:config
, and setting dom.w3c_touch_events.enabled
to 1
didn't change anything
I was investigate and this is not MUI's issue, but Firefox's.
dom.w3c_touch_events.enabled
default value is 2
. If you have issue and this value different from 2 just reset to default, it is last option in right click menu or change to 2 manually.
This issues is fixed by Firefox, but if you used multiple versions and upgrade from one to other in past couple years, as default value changes over time you may have old default value set as custom config (after upgrade). You can check https://developer.mozilla.org/en-US/docs/Web/API/Touch_events for history.
Also setting this value to 0
must work, as it disables touch events. 2
is autodetect and it can detect wrong that you have touchscreen monitor.
You users can be affected by this issue if they are old Firefox users.