-
-
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
[Menu] Clicking outside a menu blocks click from bubbling up #11243
Comments
@simoami The current Menu behavior was designed on purpose. It's following the menu behavior on mobile, try Android for instance. I do think there is room for the two behaviors. It's a tradeoff. On mobile, the cost of wrongly interacting with an element is much higher. It might trigger a screen transition, it can slow users down. We have a related issue: #9893. I see two possible paths going forward. 1. Either we add some options to the Popover or 2. we build a new component on top of the Modal. It's prioritized for the post v1 roadmap. |
Thanks @oliviertassinari oh yes, I just noticed the scroll block too. While this solves for mobile, it is not a desired behavior for menus on desktop. Btw, I took a look at #9893 and I feel that the dropdown issue is only one instance of a side effect of the current menu behavior and that a fix shouldn't be limited to dropdown components. Another common scenario is a list with secondary actions with menus attached to them. In terms of what you're suggesting, I'm open to either option, as long as the default behavior is not altered. I'm thinking that a configurable option is the easiest one. Angular's material project has a
Fyi, Google's own cloud platform (which is material design) has the menus behave the right way: |
IMHO, it's wrong. It's not the behavior a native select has: https://jsfiddle.net/q1pmh7oo/. |
I see what you mean 👍 Like I said we can keep the default behavior intact and offer more customization. I think different use cases call for different behavior. I personally think one less click is better ux if it doesn't have a side effect. |
@oliviertassinari, you're right that the behavior on Android is for the menu to dismiss when tapping outside a menu. However, a key difference with the MUI implementation is that it closes Here's an illustration, just to be clear. Currently:
Desired (and how it behaves on native Android):
|
@simoami What do you think of moving the discussion to #9893? |
Related to #17353. |
@oliviertassinari Sorry, I missed your last comment. |
I would question how we use the Popover for Menu or Select in the first place currently. These are pretty disruptive since they mess with page layout (see scroll bars) and the clickaway listener prevents any other clicks. As outlined in this issue you usually don't want them to have the same status as a something like a dialog (don't hide rest of the UI and don't intercept clicks). Using the Popper and then closing the listboxes when it looses focus would be more like the platform handles these things. We only need to consider the edge case when we click the trigger again when the listbox is displayed. Native FocusEvent has relatedTarget but that is incorrectly polyfilled in react. |
@eps1lon I share your feeling, I think that the current menu and select behavior is too disruptive for desktop (I think that it's much better suited for mobile). There is a related comment you might appreciate in #17636 (comment). |
Understanding, this works by design for mobile platforms, but for desktops (browsers) there is still not friendly behaviour. The case: I checked menus in Windows. When I call context menus for different folders, I do not need to close menu before opening a new one. There are two issues I see here:
Maybe the item (1) is for discuss, but I guess item (2) should be fixed. At least by disabling browser context menu on right click. This behaviour can be changed adding |
Hey man, i've had the same issue. So i searched on the world wide web and found something which is similar to your problem. It solves the problem in a different way than the 'vanilla' way of MUI. So I tested it. And it worked fine for me. In my case i wanted just a hover menu, but here you can find some other usefull templates for dropdowns. Also as in your case a normal dropdown menu. In my case i created a react component:
I hope this helps you and others! |
Any update on this? |
Hi All, The problem was that in the project, when we opened a menu, we had to click once to close it before being able to open another menu. This double-click requirement was inconvenient. To fix this issue, I made changes to the code as below:
These changes did the trick! Now, when you click to close an opened menu, you can immediately open another menu without having to click twice. If anyone else is facing a similar problem, you can try implementing this solution. Let me know if it works for you too! |
Just in case if someone else faces the same issue, I was able to solve with the following:
When the user scroll down, it closes the menu (useful if you're building dynamic Menus on different cards for example). If you only have one Menu (on the top for example), then you can skip the I hope it helps. |
Hi @simoami , I encountered the same issue with menu dismissal while building a dropdown menu, where it required an extra click to dismiss one menu before opening another. This behavior disrupts the expected seamless interaction for users. To address this, I recommend using the Material-UI Popup State library. It simplifies managing popups and menus, allowing clicks on other elements to simultaneously dismiss the current menu and open a new one, aligning with good UX practices. |
Current Behavior
There a fundamental issue with the menu dismissal. When presented with multiple buttons or select fields that show a menu, it take 2 clicks to dismiss the existing menu and show the next one.
Steps to Reproduce
In the demo below, try opening the first menu by clicking on the first button, then the second menu by clicking on the second button. Notice that an extra click is needed to dismiss the first menu then another one to show the second menu.
https://codesandbox.io/s/9lp94v86zo
Expected Behavior
Good UX guidelines recommend to reduce the number of clicks needed to perform an action. As opposed to modals and dialogs, menus are not expected to hijack the click away events.
The issue is that the background click to dismiss a menu, has a
e.preventDefault()
which prevents it from bubbling up to the other element.In other frameworks, you can click on an other element, and it will have double effect: close up the first menu, and show the new one in one click action. For reference:
Bootstrap
http://getbootstrap.com/2.3.2/components.html#buttonDropdowns
Semantic-UI
Sencha ExtJS
http://examples.sencha.com/extjs/6.5.3/examples/kitchensink/?modern#buttons-split
UIKit
https://getuikit.com/v2/docs/button.html
Your Environment
The text was updated successfully, but these errors were encountered: