Skip to content

Menu automatically dismisses on web when outside the bounds of the window #3854

@CodingItWrong

Description

@CodingItWrong

Current behaviour

On web on desktop browsers (at least on macOS), when a Menu attempts to display and it partially falls outside the bounds of the browser window, it auto-dismisses.

Expected behaviour

Ideally, the Menu would position itself so that it would not attempt to display outside the bounds of the browser window, so that no scrolling is needed. But if it does attempt to display outside the bounds of the browser window, it would not auto-dismiss, so that at least the user can access it by scrolling.

How to reproduce?

https://github.com/CodingItWrong/paper-sandbox/tree/menu-auto-dismiss-web

  • Open the app in any desktop web browser (tested in Chrome, Safari, and Firefox for Mac)
  • Click each menu button
  • Expected: the menu displays for all buttons
  • Actual: on any web browser for Mac, the left and right menus display, but the right button flashes and is automatically dismissed

Note: the bug does not occur on iOS or Android native, on iOS Safari, or on Android Chrome.

Preview

menu-web-auto-dismiss.mov

What have you tried so far?

Tried adjusting anchorPosition so the Menu displays within the window. But since it is displaying off to the right, anchorPosition's top and bottom don't help. It might be a workaround if we could anchor to left and right, similar to MUI: https://mui.com/material-ui/react-popover/#anchor-playground

Tried adding margin to the right of the button so that the menu fully fits within the browser window. This prevents triggering the issue, but will be challenging for my use case on small screens.

Your Environment

software version
ios 16.2
android n/a
react-native 0.71.7
react-native-paper 5.7.0
node 18.15.0
npm or yarn yarn 1.22.19
expo sdk 48.0.15

Metadata

Metadata

Assignees

No one assigned

    Labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions