问题描述
我在我的应用中使用 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());
如果用户第一次登录应用程序,我想向他们显示一个入职屏幕。但我不知道如何实现它,因为我无法在 async
中使用 auth.when()
方法。我该怎么做?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)