-
Notifications
You must be signed in to change notification settings - Fork 779
Open
Labels
Description
Backgrounds
The current designed login process,
- In login screen, visit Github's login url with a callback schema by WebView and listen to
onNavigationStateChange- Before feat(auth): use WebView for authentication #323, use
Linkingin Android andreact-native-safari-viewin iOS, then listen on Linking in both platforms - Why still listening on Linking in Android? Because in Android, we have a
can't loginbutton
- Before feat(auth): use WebView for authentication #323, use
- If succeed to login, it will,
- jump to the schema,
gitpoint://welcome, which means the welcome screen - trigger onNavigationStateChange to get the auth, and navigate to
Main
- jump to the schema,
I guess the stack navigator guarantees the main screen will always on the top of the welcome screen.
Problem
I tested different versions of codes and found that starting from #883, with RN 0.59,
- In iOS, onNavigationStateChange is not triggered for the schema
- In Android, every onNavigationStateChange is triggered but Main can't cover Welcome
Users will be blocked by the welcome screen after login in. The workaround is killing the app and open again. It has logged in so will navigate to the main screen at the second time.
Related
- No tag for v1.6.0, according to translation texts, it should be > 1716618 and < ecb61fa
- The most likely commit is 67a17ae
- Used try to make
Welcomebe able to navigate toMain(35e4a08)- Works well in iOS, it will only try to auth in the welcome screen
- But in Android, it will try to auth twice (both in login and welcome screen)
Future direction should be replacing the WebView login with native implementations.