Заставить провайдера перестроить - PullRequest
0 голосов
/ 05 ноября 2019

Привет всем!)

Я студент-разработчик, и я застрял уже 3 месяца ... Я копаюсь везде и не нашел решения для моей задачи.

МойЗадача:

Я использую StreamProvider в своем приложении, всякий раз, когда я выхожу из учетной записи A, и вхожу в другой раз с учетной записью B. Все еще отображается учетная запись A. Иногда это показывает, что я нулевой. И если я хочу показать данные зарегистрированной учетной записи, мне нужно «запустить приложение» (с зеленой кнопкой запуска, с точкой, указывающей, что она запущена).

Что я думаю о проблеме, так это о том, что она не перестраивает основной поток, в котором находятся StreamProviders.

Я перепробовал так много вещей, что не знаю на этом этапе, если я пропустил одну идею, которая, возможно, была той, и я не знал, как ее использовать.

Спасиботы за свое время. Я действительно ценю.

Мой main.dart


// build of the MyApp() (stateful widget)

@override
  Widget build(BuildContext context) {
    return MultiProvider(
      providers: [
        StreamProvider<FirebaseUser>.value(value: FirebaseAuth.instance.onAuthStateChanged), // user
        StreamProvider<Users>.value(value: dbUsers.streamUser(user != null ? user.uid : "nothing")), // userFromDatabase
        StreamProvider<Homes>.value(value: dbHomes.streamHome(userFromDatabase != null ? userFromDatabase.idHome : "nothing")), // home from user
      ],
      child: MaterialApp(
          // routes of the dynamics links
          routes: <String, WidgetBuilder>{
            '/invite': (context) => RootPage(auth: Auth(), invite: true, idHome: ModalRoute.of(context).settings.arguments,),
            '/message': (context) => RootPage(auth: Auth(), isMessage: true),
          },
          // ____________________________
          home: RootPage(auth: Auth())
      ),
    );
  }

Мой RootPage.dart

enum AuthStatus {
  notSignedIn,
  signedIn
}

class _RootPageState extends State<RootPage> {

  AuthStatus _authStatus = AuthStatus.notSignedIn;

  @override
  void initState() {
    super.initState();
    // verify if the user is signed in
    widget.auth.currentUser().then((userId) {
      setState(() {
        _authStatus = userId == null ? AuthStatus.notSignedIn : AuthStatus.signedIn;
      });
    });

  }

  // ** CALLBACKS **
  void _signedIn(){
    setState(() {
      _authStatus = AuthStatus.signedIn;
    });
  }

  void _signedOut(){
    setState(() {
      _authStatus = AuthStatus.notSignedIn;
    });
  }
  // ________________

  @override
  Widget build(BuildContext context) {
    switch(_authStatus){
      case AuthStatus.notSignedIn:
        if(widget.invite != null){
          return RegisterFromInvitePage(
            auth: widget.auth,
            onSignedIn: _signedIn,
            idHome: widget.idHome,
          );
        } else {
          return LoginPage(
            auth: widget.auth,
            onSignedIn: _signedIn,
          );
        }
        break;
      case AuthStatus.signedIn:
        if(widget.isMessage != null){
          return MessagePage(
              auth: widget.auth,
          );
        } else {
          return HomePage(
              auth: widget.auth,
              onSignedOut: _signedOut,
          );
        }
    }

  }

Страница выхода (настройки)

class _SettingsPageState extends State<SettingsPage> {

  void _signOut() async {
    try {
        await widget.auth.signOut();
        widget.onSignedOut();
    } catch (error) {
        print("Sign out error :");
        print(error);
    }
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: ReusableWidgets().getAppBar(S.of(context).drawer_settings),
      drawer: DrawerBuild(),
      body: Column(
        children: <Widget>[
          RaisedButton(
            child: Text(S.of(context).sign_out),
            onPressed: (){
              setState(() {
                _signOut();
              });
            },
          )
        ],
      ),
    );
  }
...