Ошибка При получении количества коллекций Firebase во Flutter? - PullRequest
0 голосов
/ 11 декабря 2019

Я разрабатываю приложение для администратора, в котором я хочу отобразить количество пользователей (Коллекция) из облачного пожарного хранилища. Когда я попытался это сделать, я могу вывести значение в моем терминале, но в моем приложении его значение равно 0. Может кто-нибудь, пожалуйста, помогите в этом, это мой код

class _AdminState extends State<Admin> {
  getUsersCount() {
    var length = 0;
    Firestore.instance.collection('users').getDocuments().then((myDocuments){
      print("${myDocuments.documents.length}");
      length = myDocuments.documents.length;
    });
    return length.toString();

  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Row(
            children: <Widget>[
              Expanded(
                  child: FlatButton.icon(
                      onPressed: () {
                        setState(() => _selectedPage = Page.dashboard);
                      },
                      icon: Icon(
                        Icons.dashboard,
                        color: _selectedPage == Page.dashboard
                            ? active
                            : notActive,
                      ),
                      label: Text('Dashboard'))),
              Expanded(
                  child: FlatButton.icon(
                      onPressed: () {
                        setState(() => _selectedPage = Page.manage);
                      },
                      icon: Icon(
                        Icons.sort,
                        color:
                        _selectedPage == Page.manage ? active : notActive,
                      ),
                      label: Text('Manage'))),
            ],
          ),
          elevation: 0.0,
          backgroundColor: Colors.white,
        ),
        body: _loadScreen());
  }

  Widget _loadScreen() {
    switch (_selectedPage) {
      case Page.dashboard:


        return Column(
          children: <Widget>[
            ListTile(
              subtitle: Text(
                'Admin View',
                textAlign: TextAlign.center,
                style: TextStyle(fontSize: 29.0, color: Colors.indigo,fontWeight: FontWeight.bold),
              ),
            ),
            Expanded(
              child: GridView(
                gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
                    crossAxisCount: 2,


                ),
                children: <Widget>[
                  Padding(

                    padding: const EdgeInsets.all(18.0),
                    child: Card(

                      child: ListTile(
                          title: FlatButton.icon(

                              onPressed: null,
                              icon: Icon(Icons.directions_boat,color: Colors.black,),
                              label: Text("Boats",style: TextStyle(fontSize: 9,color: Colors.indigo),)),
                          subtitle: Text(
                            '3',
                            textAlign: TextAlign.center,
                            style: TextStyle(color: active, fontSize: 50.0),
                          )),
                    ),
                  ),
                  Padding(
                    padding: const EdgeInsets.all(18.0),
                    child: Card(

                      child: ListTile(
                          title: FlatButton.icon(
                              onPressed: null,
                              icon: Icon(Icons.people,color: Colors.black,),
                              label: Text("Users",style: TextStyle(fontSize: 9,color: Colors.indigo),)),
                          subtitle: Text(
                            getUsersCount(),
                            textAlign: TextAlign.center,
                            style: TextStyle(color: active, fontSize: 50.0),
                          )),
                    ),
                  ),
                  Padding(
                    padding: const EdgeInsets.all(22.0),
                    child: Card(
                      child: ListTile(
                          title: FlatButton.icon(
                              onPressed: null,
                              icon: Icon(Icons.bookmark,color: Colors.black,),
                              label: Text("Bookings",style: TextStyle(fontSize: 8,color: Colors.indigo),)),
                          subtitle: Text(
                            '120',
                            textAlign: TextAlign.center,
                            style: TextStyle(color: active, fontSize: 50.0),
                          )),
                    ),
                  ),
                ],

              ),

            ),
          ],
        );
        break;

Мой терминал печатает точное значение, которое доступно в базе данных. Терминал выглядит так enter image description here

Мой скриншот приложения выглядит следующим образом enter image description here

Padding(
                    padding: const EdgeInsets.all(18.0),
                    child: Card(

                      child: ListTile(
                          title: FlatButton.icon(
                              onPressed: null,
                              icon: Icon(Icons.people,color: Colors.black,),
                              label: Text("Users",style: TextStyle(fontSize: 9,color: Colors.indigo),)),
                          subtitle: Text(
                            getUsersCount(),
                            textAlign: TextAlign.center,
                            style: TextStyle(color: active, fontSize: 50.0),
                          )),
                    ),
                  ),

enter image description here

enter image description here

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...