0

我在我的应用程序中使用 Riverpod 进行状态管理。这是我的代码。

主要方法——

runApp(
      MaterialApp(
                debugShowCheckedModeBanner: false,
                theme: ThemeProvider.themeOf(themeContext).data,
                home: route.Route(),
              );
            
    ); 
class Route extends ConsumerWidget {
  @override
  Widget build(BuildContext context, ScopedReader watch) {
    AsyncValue<User> auth = watch(authStateChangesProvider);
    return auth.when(
      data: (user) {
        if (user != null && user.uid != null) {
       return HomePage();
        } else {
          return LoginPage();
        }
      }, 
      loading: () => CircularProgressIndicator(),
      error: (e, o) => Text('error'), 
    );
  }
}

AuthStateChanges-

final firebaseAuthProvider =
    Provider<FirebaseAuth>((ref) => FirebaseAuth.instance);

final StreamProvider<User> authStateChangesProvider = StreamProvider<User>(
    (ref) => ref.watch(firebaseAuthProvider).authStateChanges());

如果这是他们第一次登录应用程序,我想向用户显示一个入职屏幕。但我不知道如何实现它,因为我不能asyncauth.when(). 我怎么做?

4

0 回答 0