Skip to content
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

[BUG] - Dropdown Item not usable on Android #1349

Closed
stgogm opened this issue Aug 10, 2023 · 58 comments · Fixed by #1565
Closed

[BUG] - Dropdown Item not usable on Android #1349

stgogm opened this issue Aug 10, 2023 · 58 comments · Fixed by #1565
Labels
🐛 Type: Bug Something isn't working

Comments

@stgogm
Copy link

stgogm commented Aug 10, 2023

Describe the bug

This does nothing when trying to activate a dropdown item on an Android device. I've tested with 2 different devices. Using the Chrome remote debugger I can activate the item if I click on it on my computer, but tapping on the device does nothing.

Tapping on the tabs does nothing either.

Your Example Website or App

https://nextui.org/docs/components/dropdown#usage

Steps to Reproduce the Bug or Issue

  1. Using Chrome on an Android device, go to https://nextui.org/docs/components/dropdown#usage
  2. Tap the dropdown trigger
  3. Tap an item
  4. Nothing happens

Expected behavior

When an item is tapped, it should close the dropdown and trigger the actions.

Screenshots or Videos

No response

Operating System Version

Android

Browser

Chrome

@stgogm stgogm added the 🐛 Type: Bug Something isn't working label Aug 10, 2023
@jguddas
Copy link
Contributor

jguddas commented Aug 10, 2023

Work's on my machine.

Chrome 115.0.5790.139
Android 13

@jrgarciadev
Copy link
Member

Hey @stgogm are you using a real device, or are you using the one provided by Chrome Dev Tools?

@stgogm
Copy link
Author

stgogm commented Aug 11, 2023

Thanks for revising this.

I tried with two real devices, and one definitively doesn't work. There are no error logs or anything:

screenrecorder-2023-08-11-10-57-10-405_iyyV1RAU.mp4

I've tried other libraries (MUI, Prime), and they work well, so I'm trying to figure out what's happening.

Not working device:

  • Redmi Note 10 Pro
  • Android 13 TKQ1.221013.002
  • MIUI Global 14.0.2.0
  • Chrome 115.0.5790.166

@jguddas
Copy link
Contributor

jguddas commented Aug 11, 2023

@dmythro
Copy link

dmythro commented Aug 11, 2023

I had issues with Dropdown button wrapped in a Tooltip. Also, Dropdown or Popover doesn't work for me in Chrome's responsive tool (but it works fine on actual devices as I checked, works fine in Safari and it's responsive design tool, works in iOS 16), Chrome is v115 latest. Example: my webpage (there are sources as well, link in footer), plan to replace with something else as it may not work in some edge cases, noticed after it was already there.

@dmythro
Copy link

dmythro commented Aug 11, 2023

Yeah, also doesn't work on my test Android 13 (Pixel 4a). Only Navbar toggle works from this kind of controls (visible only on small screens via link above).

Update: there is a Dropdown on User block, and there's a Popover when you click on "Built with" in footer.

Hope it helps to reproduce.

@jrgarciadev
Copy link
Member

I had issues with Dropdown wrapped in a Tooltip. Also, Dropdown or Popover doesn't work for me in Chrome's responsive tool (but it works fine on actual devices as I checked, works fine in Safari and it's responsive design tool, works in iOS 16), Chrome is v115 latest. Example: my webpage (there are sources as well, link in footer), plan to replace with something else as it may not work in some edge cases, noticed after it was already there.

For issues regarding Tooltip wrapping other overlays components please check this #1265

@dmythro
Copy link

dmythro commented Aug 11, 2023

For issues regarding Tooltip wrapping other overlays components please check this #1265

Thanks! Yes, I had figured out that kind of a workaround, but then decided to rework layout a bit :)

@devongovett
Copy link

Could you please go to this page on your device, tap the button, and paste the output you get? Also please include as much info as possible about your device, including hardware, Android version, Chrome version, etc. https://codepen.io/devongovett/pen/XWyLEvy

@emmanuelxd
Copy link

emmanuelxd commented Aug 11, 2023

Could you please go to this page on your device, tap the button, and paste the output you get? Also please include as much info as possible about your device, including hardware, Android version, Chrome version, etc. https://codepen.io/devongovett/pen/XWyLEvy

{
"isTrusted": true,
"pointerId": 2,
"width": 0,
"height": 0,
"pressure": 1,
"tiltX": 0,
"tiltY": 0,
"azimuthAngle": 0,
"altitudeAngle": 1.5707963267948966,
"tangentialPressure": 0,
"twist": 0,
"pointerType": "touch",
"isPrimary": true,
"screenX": 63.6363639831543,
"screenY": 498.18182373046875,
"clientX": 63.6363639831543,
"clientY": 18.636363983154297,
"ctrlKey": false,
"shiftKey": false,
"altKey": false,
"metaKey": false,
"button": 0,
"buttons": 1,
"pageX": 63.6363639831543,
"pageY": 18.636363983154297,
"x": 63.6363639831543,
"y": 18.636363983154297,
"offsetX": 53.81818389892578,
"offsetY": 8.818181991577148,
"movementX": 0,
"movementY": 0,
"layerX": 63,
"layerY": 18,
"detail": 0,
"which": 1,
"type": "pointerdown",
"eventPhase": 2,
"bubbles": true,
"cancelable": true,
"defaultPrevented": false,
"composed": true,
"timeStamp": 3435.5,
"returnValue": true,
"cancelBubble": false,
"NONE": 0,
"CAPTURING_PHASE": 1,
"AT_TARGET": 2,
"BUBBLING_PHASE": 3
}

Android 12 SKQ1.211006.001
Chrome versión 115.0.5790.166
MIUI 13.0.3

@stgogm
Copy link
Author

stgogm commented Aug 11, 2023

@devongovett this is on the non working device:

{
  "isTrusted": true,
  "pointerId": 7,
  "width": 0,
  "height": 0,
  "pressure": 1,
  "tiltX": 0,
  "tiltY": 0,
  "azimuthAngle": 0,
  "altitudeAngle": 1.5707963267948966,
  "tangentialPressure": 0,
  "twist": 0,
  "pointerType": "touch",
  "isPrimary": true,
  "screenX": 21.090909957885742,
  "screenY": 492,
  "clientX": 22.936052322387695,
  "clientY": 24.672319412231445,
  "ctrlKey": false,
  "shiftKey": false,
  "altKey": false,
  "metaKey": false,
  "button": 0,
  "buttons": 1,
  "pageX": 22.936052322387695,
  "pageY": 24.672319412231445,
  "x": 22.936052322387695,
  "y": 24.672319412231445,
  "offsetX": 12.96331787109375,
  "offsetY": 14.6995849609375,
  "movementX": 0,
  "movementY": 0,
  "layerX": 22,
  "layerY": 24,
  "detail": 0,
  "which": 1,
  "type": "pointerdown",
  "eventPhase": 2,
  "bubbles": true,
  "cancelable": true,
  "defaultPrevented": false,
  "composed": true,
  "timeStamp": 9183.899999976158,
  "returnValue": true,
  "cancelBubble": false,
  "NONE": 0,
  "CAPTURING_PHASE": 1,
  "AT_TARGET": 2,
  "BUBBLING_PHASE": 3
}

@jguddas
Copy link
Contributor

jguddas commented Aug 13, 2023

This is from a working device, as you can see height and width are not 0.

{ "isTrusted": true, "pointerId": 19, "width": 2.6666667461395264, "height": 2.6666667461395264, "pressure": 1, "tiltX": 0, "tiltY": 0, "azimuthAngle": 0, "altitudeAngle": 1.5707963267948966, "tangentialPressure": 0, "twist": 0, "pointerType": "touch", "isPrimary": true, "screenX": 41.29166793823242, "screenY": 455.41668701171875, "clientX": 41.29166793823242, "clientY": 20.08333396911621, "ctrlKey": false, "shiftKey": false, "altKey": false, "metaKey": false, "button": 0, "buttons": 1, "pageX": 41.29166793823242, "pageY": 20.08333396911621, "x": 41.29166793823242, "y": 20.08333396911621, "offsetX": 31.291667938232422, "offsetY": 10.083333969116211, "movementX": 0, "movementY": 0, "layerX": 41, "layerY": 20, "detail": 0, "which": 1, "type": "pointerdown", "eventPhase": 2, "bubbles": true, "cancelable": true, "defaultPrevented": false, "composed": true, "timeStamp": 12066.699999809265, "returnValue": true, "cancelBubble": false, "NONE": 0, "CAPTURING_PHASE": 1, "AT_TARGET": 2, "BUBBLING_PHASE": 3 }

@dmythro
Copy link

dmythro commented Aug 13, 2023

So, for now as a workaround I've noticed that drop-downs without backdrop work for me on all devices, so removed it.
Looks way cooler with a blurred backdrop, but it's much more important to have it working for now :)

@devongovett
Copy link

@emmanuelxd @stgogm thanks! could you repeat the same thing except click the button using Android's TalkBack screen reader? That's what we're trying to detect here. See here for how to turn TalkBack on and off (usually you press and hold both volume buttons). Once it is on, move the virtual cursor to the button and double tap to click.

@emmanuelxd
Copy link

@devongovett sure!

Results with TalkBack On

{
  "isTrusted": true,
  "pointerId": 1,
  "width": 1,
  "height": 1,
  "pressure": 0,
  "tiltX": 0,
  "tiltY": 0,
  "azimuthAngle": 0,
  "altitudeAngle": 1.5707963267948966,
  "tangentialPressure": 0,
  "twist": 0,
  "pointerType": "mouse",
  "isPrimary": true,
  "screenX": 15,
  "screenY": 148,
  "clientX": 41,
  "clientY": 18,
  "ctrlKey": false,
  "shiftKey": false,
  "altKey": false,
  "metaKey": false,
  "button": 0,
  "buttons": 1,
  "pageX": 41,
  "pageY": 18,
  "x": 41,
  "y": 18,
  "offsetX": 0,
  "offsetY": 0,
  "movementX": 0,
  "movementY": 0,
  "layerX": 41,
  "layerY": 18,
  "detail": 0,
  "which": 1,
  "type": "pointerdown",
  "eventPhase": 2,
  "bubbles": true,
  "cancelable": true,
  "defaultPrevented": false,
  "composed": true,
  "timeStamp": 11230,
  "returnValue": true,
  "cancelBubble": false,
  "NONE": 0,
  "CAPTURING_PHASE": 1,
  "AT_TARGET": 2,
  "BUBBLING_PHASE": 3
}

@devongovett
Copy link

Great thanks. We will make some updates on the React Aria side and post a link here for you to test once we have a potential fix. And sorry again, these device specific bugs are hard! 😄

@yihuiliao
Copy link

yihuiliao commented Aug 18, 2023

Hey everyone! We have a potential fix on the React Aria side so if you were having issues previously, could you please go to this page on the docs, scroll to the button that says "Press me!", and report what it says? Also please include as much info as possible about your device, including hardware, Android version, Chrome version, etc. Unfortunately, our team doesn't have the devices which are causing this issue so your help would be much appreciated!

@LFDanLu
Copy link

LFDanLu commented Aug 19, 2023

Just wanted to chime in with the following bug filed against Chrome: https://bugs.chromium.org/p/chromium/issues/detail?id=1271444. The check we use in React Aria relies on several attributes of the click event, but is still quite brittle especially since Talkback sometimes issues events with pointerType: touch and height/width: 0. Ideally, attributes like isPrimary would be false for a TalkBack click.

@stgogm
Copy link
Author

stgogm commented Aug 19, 2023

@yihuiliao this is what i get:

- press start with touch
- press end with touch
- press with touch

Thanks!

@Maadhav
Copy link

Maadhav commented Aug 19, 2023

Is there anyway to fix this issue temporarily? A lot of our users are mobile based and hence a lot of them are getting this issue.

@emmanuelxd
Copy link

@yihuiliao

- press start with touch
- press end with touch
- press with touch

Android 12 SKQ1.211006.001 Chrome versión 115.0.5790.166 MIUI 13.0.3

@LucasTrombim
Copy link

Is there anyway to fix this issue temporarily? A lot of users are having this issue.

@jguddas
Copy link
Contributor

jguddas commented Aug 29, 2023

Has anyone tried to see if the changes that are not yet released but are in main in react-aria fix all of this?

@LucasTrombim
Copy link

I don't understand, what do you mean? Do I install the react-aria package on the main branch?

@devongovett
Copy link

You could try using the nightly version of @react-aria/interactions by using npm overrides/yarn resolutions.

{
  "overrides": {
    "@react-aria/interactions": "nightly"
  }
}

@LucasTrombim
Copy link

LucasTrombim commented Aug 30, 2023

didn't solve the problem, any other alternative?

@LFDanLu
Copy link

LFDanLu commented Aug 30, 2023

what does npm list @react-aria/interactions return for you? Perhaps you are running into npm/cli#5850 with the override?

@LucasTrombim
Copy link

├─┬ @nextui-org/[email protected]
│ ├─┬ @nextui-org/[email protected]
│ │ ├─┬ @react-aria/[email protected]
│ │ │ ├── @react-aria/[email protected] deduped
│ │ │ └─┬ @react-aria/[email protected]
│ │ │   └── @react-aria/[email protected] deduped
│ │ ├─┬ @react-aria/[email protected]
│ │ │ └── @react-aria/[email protected] deduped
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├─┬ @nextui-org/[email protected]
│ │ │ └── @react-aria/[email protected] deduped
│ │ ├─┬ @react-aria/[email protected]
│ │ │ └── @react-aria/[email protected] deduped
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├─┬ @react-aria/[email protected]
│ │ │ └─┬ @react-aria/[email protected]
│ │ │   └── @react-aria/[email protected] deduped
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├── @react-aria/[email protected] deduped
│ │ └─┬ @react-aria/[email protected]
│ │   └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├─┬ @react-aria/[email protected]
│ │ │ └── @react-aria/[email protected] deduped
│ │ └─┬ @react-types/[email protected]
│ │   └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├── @react-aria/[email protected] deduped
│ │ └─┬ @react-aria/[email protected]
│ │   └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├── @react-aria/[email protected] deduped
│ │ └─┬ @react-aria/[email protected]
│ │   └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├── @react-aria/[email protected] deduped
│ │ └─┬ @react-aria/[email protected]
│ │   ├─┬ @react-aria/[email protected]
│ │   │ └── @react-aria/[email protected] deduped
│ │   └── @react-aria/[email protected] deduped
│ ├─┬ @nextui-org/[email protected]
│ │ ├── @react-aria/[email protected] deduped
│ │ └─┬ @react-aria/[email protected]
│ │   └── @react-aria/[email protected] deduped
│ └─┬ @nextui-org/[email protected]
│   ├── @react-aria/[email protected] deduped
│   └─┬ @react-aria/[email protected]
│     └── @react-aria/[email protected] deduped
├── @react-aria/[email protected]
└─┬ @react-aria/[email protected]
  └── @react-aria/[email protected] deduped

@LFDanLu
Copy link

LFDanLu commented Aug 30, 2023

Can you try pulling and running this locally: https://github.com/LFDanLu/android-test? It has the @react-aria/interactions override and works on my Android device (but I never was able to reproduce the original issue). Just try tapping on the "Open Menu" button.

here is a codesandbox link for the above repo: https://codesandbox.io/p/sandbox/github/LFDanLu/android-test/tree/main

@LucasTrombim
Copy link

It worked! I'll check package by package to see what the problem might be.

@emmanuelxd
Copy link

It worked for me too, thanks

@LucasTrombim
Copy link

LucasTrombim commented Aug 31, 2023

When I tried to fork it, and download it to run locally. It's not working anymore, what version of node are you using? Can you tell me the problem?

@LFDanLu
Copy link

LFDanLu commented Aug 31, 2023

I'm on node 16.20 but just tried 18.12.1 locally and the react-aria/interactions override still worked with a complete clean install (aka deleted lockfile + node modules). Just to be clear, you forked https://github.com/LFDanLu/android-test and ran that repo locally but the override wasn't applied?

@LucasTrombim
Copy link

I did a local test and realized that the problem was the installation of the packages with yarn. Even with yarn up to date and working, the component still has the problem. After running the same configurations with npm, it works perfectly. Can you tell me how to solve it?

@LucasTrombim
Copy link

LucasTrombim commented Aug 31, 2023

I found the solution, it was my package.json config.... i was using "overrides" with yarn instead of "resolutions".

Now it works at all! Thanks for all the support @LFDanLu @devongovett @jguddas

@MisterHims
Copy link
Contributor

MisterHims commented Sep 1, 2023

Hi there! For me, using the "backdrop" prop prevents the component from working on mobile: when I tap, no reaction. The phenomenon also occurs with the Popover component when the "backdrop" prop is used.

OS: Android 13 - Pixel 6a
Browser: Chrome 116.0.5845.163

@LFDanLu
Copy link

LFDanLu commented Sep 1, 2023

@MisterHims does it still break if you apply the "backdrop" prop in https://github.com/LFDanLu/android-test/blob/661f4e9e27d9e40361e47f0cdcaf33c6b075498c/app/page.tsx#L13? Curious if this is a separate issue from the erroneous virtual click detection problem.

@jrgarciadev
Copy link
Member

@MisterHims @LFDanLu are you testing in real devices or are you using the chrome dev tools?

@LFDanLu
Copy link

LFDanLu commented Sep 2, 2023

@jrgarciadev I'm using a Samsung Galaxy S22+, Android 13, Chrome 116.0.5845.163.

@MisterHims
Copy link
Contributor

@MisterHims does it still break if you apply the "backdrop" prop in https://github.com/LFDanLu/android-test/blob/661f4e9e27d9e40361e47f0cdcaf33c6b075498c/app/page.tsx#L13? Curious if this is a separate issue from the erroneous virtual click detection problem.

Yes, still break with using backdrop="blur" in this case. I also tried with the Microsoft Edge 116.0.1938.64 browser.

@LFDanLu
Copy link

LFDanLu commented Sep 5, 2023

Curious, what prints out for you when you tap on button in the example here?

@OtabekVaxobov
Copy link

Can you try pulling and running this locally: https://github.com/LFDanLu/android-test? It has the @react-aria/interactions override and works on my Android device (but I never was able to reproduce the original issue). Just try tapping on the "Open Menu" button.

here is a codesandbox link for the above repo: https://codesandbox.io/p/sandbox/github/LFDanLu/android-test/tree/main

thank U, its work

@MisterHims
Copy link
Contributor

Curious, what prints out for you when you tap on button in the example here?

Screenshot_20230906-165818.png

@LFDanLu
Copy link

LFDanLu commented Sep 6, 2023

That looks to be the proper result and would indicate to me that it is more likely that the break with backdrop="blur" has to do with something other than the press event detection that we've fixed in react-aria. I'm not familiar with the implementation of the Dropdown component here though, so I can't say for sure.

@realdocweird
Copy link

realdocweird commented Sep 7, 2023

in my case on xiaomi phones tabs and accordion are not working "@nextui-org/react": "^2.1.7"
then npm list @react-aria/interactions returns @react-aria/[email protected] , i tried overriding with the 3.0.0-nightly.2405 tabs were fixed but accordion was not.
On galaxy s23 and iphones >13 everything fine

@devongovett
Copy link

devongovett commented Sep 8, 2023

FYI the fix was released in the latest version of react-aria! https://react-spectrum.adobe.com/releases/2023-09-07.html

@KhalidHassan218
Copy link

KhalidHassan218 commented Aug 26, 2024

this issue still exist in the latest verison of nextui , using yarn , on native screens it closes once it opens

"@nextui-org/framer-utils": "^2.0.21", "@nextui-org/react": "^2.4.6", "@nextui-org/use-infinite-scroll": "^2.1.5", "@react-aria/interactions": "^3.22.2", "@react-aria/ssr": "^3.9.5", "@react-aria/visually-hidden": "^3.8.15",

@siyasangab
Copy link

issue still exists

@LFDanLu
Copy link

LFDanLu commented Dec 18, 2024

@siyasangab @KhalidHassan218 do you have a reproduction I can try? I just tried the NextUI dropdown on my Android phone (Chrome 131, Android 14) and it seems to work fine.

@KhalidHassan218
Copy link

I already got fired , does not matter for me anymore , but for others ....

I remember that I have fixed using a workaround using use disclosure and worked fine

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🐛 Type: Bug Something isn't working
Projects
None yet
Development

Successfully merging a pull request may close this issue.