-
-
Notifications
You must be signed in to change notification settings - Fork 32.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
onTouchTap fires twice on Lists and other components #5070
Comments
How long we can not use react-tap-plugin-event? |
In case you didn't see the post in the other issue you linked: I found a solution so it may help you too. After the onTouchTap event another onClick event is fired after a delay (~300ms), whether the onTouchTap is handled or not. FIX: Example: Hope this helps. |
I'm using React 15.3.1, and while I'm not sure when it was introduced, it looks like TapEventPlugin is now included in React's libs by default, so I've given up using react-tap-plugin-event and have switched to using the following: require('react/lib/EventPluginHub').injection.injectEventPluginsByName({
'TapEventPlugin': require('react/lib/TapEventPlugin')
}); I haven't tested it extensively yet, but seems to work well in desktop Chrome and in Chrome for Android. Might be worth a shot to see if it fixes your issue, as the raw TapEventPlugin code is indeed different than react-tap-plugin-event's. |
Unfortunately, none of the solutions mentioned above work. @JamesAlias - when I implement your solution, touch tap on ListItem stops working. @jamespizzurro - I tried your solution, but the behavior is exactly the same with React's TapEventPlugin too. I have implemented the workaround for Ghost Clicks posted on react-tap-event-plugin's page and it does help prevent the ghost clicks, but I still get a ripple effect on the list items on the next page.
Is there a reason for MUI to have onTouchTap listener instead of onClick now that the 300ms delay has been removed from the browsers? |
any news about this ? |
I've finally followed @JamesAlias advice : |
Same here, this seems to happen sporadically. For example when expanding a Wat does seem to help sometimes, but this is on the user side, is to press and hold the CardHeader or Button or whatever element is receiving the But there are times where I load my page and this does not occur at all, so whether this is an issue with |
Okay this is called ghost click and documented here with solution. https://github.com/zilverline/react-tap-event-plugin Ignoring ghost clicks When a tap happens, the browser sends a touchstart and touchend, and then 300ms later, a click event. This plugin ignores the click event if it has been immediately preceeded by a touch event (within 750ms of the last touch event). Occasionally, there may be times when the 750ms threshold is exceeded due to slow rendering or garbage collection, and this causes the dreaded ghost click. The 750ms threshold is pretty good, but sometimes you might want to override that behaviour. You can do this by supplying your own shouldRejectClick function when you inject the plugin. The following example will simply reject all click events, which you might want to do if you are always using onTouchTap and only building for touch devices: var React = require('react'), |
what's the progress on this issue? I have a list on one page and touch on one of the items will transit to item's detail page, I can use e.preventDefault to prevent the ghost click when going back to the list page, but still seeing a ripple there. Is there a workaround or universal fixing to deal this issue? |
TouchTapping the "All" Chip in the browse menu previously resulted two touchtaps. Solved by this method: mui/material-ui#5070 (by adding an event.preventDefault())
After several attempts at fixing this problem I came to the conclusion that the only solution is to call It would be relatively easy to extend the Having nearly 300 onTouchTap handlers in my project it was not really an option to manually add In search of an automated solution and after a day of different attempts the only solution seems to be monkey-patching Ugly, I know, but it works... import React from 'react';
let orig = React.createElement;
React.createElement = function(type, props, ...children) {
// only wrap native elements (string-ish `type`) which have an onTouchTap prop
if (typeof type === "string" && props && props.onTouchTap) {
let orig = props.onTouchTap;
props = {
...props,
onTouchTap: function(e) {
e.preventDefault();
return orig.apply(this, arguments);
}
}
}
return orig.call(this, type, props, ...children);
}; Tested on...
|
We have removed the |
I have a List component. Click on an item in the list replaces the original list with another list. On mobile devices, when I tap on the first list, it fires a second tap on the new list when the new list comes up. This ends up clicking the item in the new list too and leads to unpredictable UI behavior. I found a similar issue reported on react-tap-plugin-event page. I'm wondering whether it's that plugin's issue or an MUI issue, and is there a way to resolve it?
Versions
The text was updated successfully, but these errors were encountered: