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

Bottom sheet modal overflows and content is missing on iOS 18.0.0 simulator. #1026

Open
shonie2xx opened this issue Sep 18, 2024 · 34 comments
Open

Comments

@shonie2xx
Copy link

shonie2xx commented Sep 18, 2024

Issue

It seems the authorize method uses a modal, as the login page slides up from the bottom of the screen. On iOS 18.0.0, this modal is not displaying the content of the page and is not fitting within the screen. Below is a screenshot from the simulator:

simulator_screenshot_ABCB2A82-9ABC-4E83-A904-45FC72F0D22E

Environment

Simulator iOS: 18.0.0
Simulator Device: iPhone 15 Pro, iPhone 16 Pro
Xcode: 16.0
macOS: Sequila 15.0
react-native: ^0.72.5
react-native-app-auth: 7.2.0 (also occurs on 8.0.0)

@sasha-maliauka
Copy link

We're having the same issue. Works fine on iOS 17.x.x/Xcode 15.x.x, not working on iOS 18/Xcode 16.

@brampono
Copy link

I can also reproduce this issue:
Xcode: 16.0
Simulator: iPhone 16 Pro | iOS 18
react-native: 0.74.5
react-native-app-auth: 8.0.0

I can fix the issue by running simulator: iPhone 15 Pro | iOS 17.5

Seems like it could be an issue with iOS 18.0

@ashosipyan
Copy link

ashosipyan commented Sep 19, 2024

Have the same issue with Xcode16 and iOS18 simulator, the interesting thing is that it works in production build on real device.

Update: also tested dev build on real device and it's working as well

@roshanShendre13
Copy link

roshanShendre13 commented Sep 25, 2024

Yes I am also facing the same issue on Xcode16 and iOS18 simulator

@KhadeevRV
Copy link

Same issue

@Anaezsh
Copy link

Anaezsh commented Oct 1, 2024

Same

@m0hamad
Copy link
Contributor

m0hamad commented Oct 1, 2024

Hi @shonie2xx, I've been looking into this and have not been able to replicate it yet with iOS 18.0 & Xcode 16. Would you be able to provide a reproducible example that I could take a look at? Thank you.

@ashosipyan
Copy link

Hi @shonie2xx, I've been looking into this and have not been able to replicate it yet with iOS 18.0 & Xcode 16. Would you be able to provide a reproducible example that I could take a look at? Thank you.

hi @m0hamad, the main problem is with ios18 simulator, did you test on real device?

@shonie2xx
Copy link
Author

Hi @m0hamad, the issue is happening only on simulator and not physical device. iOS 18.0 Simulator & XCode 16. How can I further help you?

@m0hamad
Copy link
Contributor

m0hamad commented Oct 2, 2024

@ashosipyan @shonie2xx Apologies for not being more specific. I tested on an iOS 18.0 simulator (16/16 Plus/16 Pro/16 Pro Max) with various react-native versions combined with different versions of react-native-app-auth and haven't had any luck replicating the issue yet. Are you also using Expo?

@bogrees
Copy link

bogrees commented Oct 2, 2024

I can reproduce the issue with:

  • Xcode 16.0
  • Simulator running iPhone 16 Pro with iOS 18.0
  • react-native-app-auth 7.2.0

@ashosipyan
Copy link

ashosipyan commented Oct 3, 2024

@m0hamad hi, thank you for clarification,

we are using:

  • react-native 0.72.14
  • Xcode 16
  • iOS 18 simulator iPhone 16 pro
  • we are not using expo
  • latest version of react-native-app-auth

if I try on simulator with iOS 17.5 and Xcode16 everything works fine, so for me the only issue is iOS18 simulator

@m0hamad
Copy link
Contributor

m0hamad commented Oct 4, 2024

@m0hamad hi, thank you for clarification,

we are using:

  • react-native 0.72.14
  • Xcode 16
  • iOS 18 simulator iPhone 16 pro
  • we are not using expo
  • latest version of react-native-app-auth

if I try on simulator with iOS 17.5 and Xcode16 everything works fine, so for me the only issue is iOS18 simulator

Hi @ashosipyan,

I am still trying to replicate the issue. I noticed that there was a MacOS Sequoia re-release today and an update to the iOS 18 simulator along with the dev tools. Can you try updating and seeing if the issue persists afterwards? Thank you.

@shonie2xx
Copy link
Author

@m0hamad hi, thank you for clarification,
we are using:

  • react-native 0.72.14
  • Xcode 16
  • iOS 18 simulator iPhone 16 pro
  • we are not using expo
  • latest version of react-native-app-auth

if I try on simulator with iOS 17.5 and Xcode16 everything works fine, so for me the only issue is iOS18 simulator

Hi @ashosipyan,

I am still trying to replicate the issue. I noticed that there was a MacOS Sequoia re-release today and an update to the iOS 18 simulator along with the dev tools. Can you try updating and seeing if the issue persists afterwards? Thank you.

I tried it out this morning doesn't fix the issue. Could it be something from the cocoapods version? We're running COCOAPODS: 1.15.2

@m0hamad
Copy link
Contributor

m0hamad commented Oct 8, 2024

@m0hamad hi, thank you for clarification,
we are using:

  • react-native 0.72.14
  • Xcode 16
  • iOS 18 simulator iPhone 16 pro
  • we are not using expo
  • latest version of react-native-app-auth

if I try on simulator with iOS 17.5 and Xcode16 everything works fine, so for me the only issue is iOS18 simulator

Hi @ashosipyan,
I am still trying to replicate the issue. I noticed that there was a MacOS Sequoia re-release today and an update to the iOS 18 simulator along with the dev tools. Can you try updating and seeing if the issue persists afterwards? Thank you.

I tried it out this morning doesn't fix the issue. Could it be something from the cocoapods version? We're running COCOAPODS: 1.15.2

@shonie2xx I also have the same COCOAPODS version (can see the version in the Podfile.lock file). I believe the best way to move forward would be for you to submit a reproducible example, I have not had any luck yet with reproducing this issue. Thank you.

@veselignome
Copy link

I'm also experiencing this issue after several years of successful usage with this IDP, only simulator issue as described.
Tested locally so dangerouslyAllowInsecureHttpRequests is used.

  • XCode 16
  • iPhone simulator (15/16) with iOS 18
  • "react-native": "0.74.3"
  • "react-native-app-auth": "7.2.0"
  • no expo
  • COCOAPODS: 1.14.3

usage:
authorize({ issuer:"http://192.168.1.1:9000/auth/realms/authprovider/", clientId:"XXX_myClientId_XXX", redirectUrl:"myapp://callback", scopes:[ "MyAuthProviderAuthorization", "directory", "openid", "profile", "email", "offline_access", "id" ], additionalParameters:{ prompt:"login" }, dangerouslyAllowInsecureHttpRequests:true })

Reproduction steps:

  • Click button that calls authorize function with the above described object
  • PopUp dialog shows up: MyApp wants to use 192.168.1.1 to Sign In
  • Click on Continue button
  • redirection to browser occurs that should offer login page with username/password fields

Expected result:

  • login page should be loaded

Actual result:

  • no login page content is shown, modal overflows. Identical to screenshot attached in this ticket by @shonie2xx

Thanks.

@DanushkaPerusinghe
Copy link

DanushkaPerusinghe commented Oct 11, 2024

Same issue in iOS simulator. Any update on this.

  • XCode 16
  • iPhone simulator 16 with iOS 18

Works fine in real device with iOS 18

Simulator Screenshot - iPhone 16 Pro - 2024-10-09 at 14 04 34

@carbonrobot
Copy link
Contributor

carbonrobot commented Oct 11, 2024

We are doing a little research around this issue, but it's going to be an upstream issue in either AppAuth-IOS or Xcode itself. This library only passes the data to AppAuth-IOS and has very little to do with the actual UI that is presented. So any fixes will likely need to be done in those codebases, not this one.

@carbonrobot
Copy link
Contributor

@robwalkerco
Copy link
Member

I've partially replicated this issue using Xcode 16.1 Beta 3 and iOS 18.1 Simulator.

Interestingly - hitting the release icon at the top-right allows the content to load correctly.

I can't replicate the layout issue from the original report, but the content fails to load.

Once openid/AppAuth-iOS#871 is merged and released, I can check that using the latest version of AppAuth-iOS in react-native-app-auth resolves this issue.

@carbonrobot
Copy link
Contributor

We have now released 8.0.1 which includes an upstream API fix. Please retest.

@bogrees
Copy link

bogrees commented Nov 26, 2024

Unfortunately, still not fixed using iPhone 16 Pro simulator with iOS 18.

@intellitour
Copy link

Seems like iOS 18 problem: https://forums.developer.apple.com/forums/thread/764468

@veselignome
Copy link

I can confirm this issue is still happening after installing version 8.0.1.

Following https://forums.developer.apple.com/forums/thread/764468 I've noticed it indeed works if simulator is NOT rosetta. I do not use excluded architectures field so cannot comment on it.

@ashosipyan
Copy link

Yes still the same with iOS 18.1 simulator :(

@batuhanbag
Copy link

still same with new version (8.0.1) and ios 18 simulators

@billnbell3
Copy link

+1

@billnbell3
Copy link

OK I got my version working using M1 Silicon chip (arm64). It seems that when running in Simulation under Xcode with Xcode 16.2 and IOS 18/18.1 or 18.2 the auth popup Safari browser plugin has an issue. This happens in Rosetta emulation or when using RN incorrectly. Everyone put in their Podfile the following when all packages did not support arm64. This was a quick fix, but is not longer needed. Everyone most likely already upgraded their packages to support arm64, and you can stop moving Simulator to x86_64....

config.build_settings['EXCLUDED_ARCHS[sdk=iphonesimulator*]'] = "arm64"

Just remove that - compile with Xcode and see if you get any errors, if you do, upgrade the package that is erroring. The only one I had to upgrade was react-native-maps - and it all started working.

There you go.

@shonie2xx
Copy link
Author

OK I got my version working using M1 Silicon chip (arm64). It seems that when running in Simulation under Xcode with Xcode 16.2 and IOS 18/18.1 or 18.2 the auth popup Safari browser plugin has an issue. This happens in Rosetta emulation or when using RN incorrectly. Everyone put in their Podfile the following when all packages did not support arm64. This was a quick fix, but is not longer needed. Everyone most likely already upgraded their packages to support arm64, and you can stop moving Simulator to x86_64....

config.build_settings['EXCLUDED_ARCHS[sdk=iphonesimulator*]'] = "arm64"

Just remove that - compile with Xcode and see if you get any errors, if you do, upgrade the package that is erroring. The only one I had to upgrade was react-native-maps - and it all started working.

There you go.

It's a nice clean up, but it doesn't work

@shonie2xx
Copy link
Author

@carbonrobot sorry for my late reply. I've installed the latest version 8.0.1, but the issue remains
simulator_screenshot_75545477-C6DC-4C3C-999D-BD2238611E44

A react-native update is planned, hopefully that will fix it.

@dirkpostma
Copy link

dirkpostma commented Dec 19, 2024

@shonie2xx this will not be solved by React Native upgrade. It can only be solved by apple.

Workaround is to test using simulator with iOS 17.
Or, when you want to test iOS 18, use a physical device.

see https://forums.developer.apple.com/forums/thread/764468

@shonie2xx
Copy link
Author

shonie2xx commented Dec 19, 2024

@dirkpostma thanks for follow up link. Indeed we are still using ios 17 for debugging, but that can't be forever. Let's see if apple solves it then

@billnbell3
Copy link

billnbell3 commented Dec 19, 2024

OK I got my version working using M1 Silicon chip (arm64). It seems that when running in Simulation under Xcode with Xcode 16.2 and IOS 18/18.1 or 18.2 the auth popup Safari browser plugin has an issue. This happens in Rosetta emulation or when using RN incorrectly. Everyone put in their Podfile the following when all packages did not support arm64. This was a quick fix, but is not longer needed. Everyone most likely already upgraded their packages to support arm64, and you can stop moving Simulator to x86_64....

config.build_settings['EXCLUDED_ARCHS[sdk=iphonesimulator*]'] = "arm64"

Just remove that - compile with Xcode and see if you get any errors, if you do, upgrade the package that is erroring. The only one I had to upgrade was react-native-maps - and it all started working.
There you go.

It's a nice clean up, but it doesn't work

Check "brew config" and make sure on Silicon you are not using Rosetta. Also right click XCODE and make sure you are not using Rosetta and have native Silicon.

Also "cd ios && pod deintegrate && pod install" after you remove that.

I added a package.json - pod nuke command.

"nuke": "rm -rf ios/build/generated && rm -rf ~/Library/Developer/Xcode/DerivedData && rm -f node_modules/react-native-config/ios/ReactNativeConfig/GeneratedDotEnv.m && rm -f yarn.lock && rm -rf node_modules; rm -rf ios/build; rm -rf ios/Pods; rm -rf ios/Podfile.lock; cd ios && pod deintegrate && cd .. && yarn install && yarn pod-install; cd android && ./gradlew clean && cd ..;",

This works for me 100%.

@billnbell3
Copy link

@carbonrobot sorry for my late reply. I've installed the latest version 8.0.1, but the issue remains simulator_screenshot_75545477-C6DC-4C3C-999D-BD2238611E44

A react-native update is planned, hopefully that will fix it.

That does not work for sure. But removing arm64 when you are running on Silicon (arm64) is not the right solution.

The XCODE for silicon (arm64) is working for us here. I am happy to share my whole Podfile. Make sure you remove the Podfile.lock file (run my yarn nuke above).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests