Я пытаюсь прочитать список из БД и использовать его в listview.builder (), но прежде чем я смогу это сделать, мне нужно иметь данные. Но дело в том, что у меня есть данные. Я пробовал это с String и Int, и это работает отлично.
Я читаю и настраиваю данные пользователей в виде списка в БД. Вы заметите, что у меня дома есть список под названием userDo c, ну, мне нужен был способ вставить информацию о клиенте в виде списка, поэтому я подумал сделать это так (если есть лучший способ, пожалуйста, поделитесь ), но дело в том, что он сохраняет его в БД, но всякий раз, когда я обновляю sh приложение, весь контент уходит за пределы экрана, но все равно сохраняется в БД, и когда я фактически вводю новые данные после обновления sh он удаляет все старые данные и заменяет их новым списком в БД, а это не то, что мне нужно (предполагается добавить в список уже существующие данные).
Кстати, я пытаюсь создать простой список дел. Короче говоря, у меня возникают проблемы с чтением и записью списка в базу данных, и по какой-то причине он возвращает ноль, когда у меня действительно есть данные в базе данных. Пожалуйста, скажите мне, если вам нужна более точная информация. Спасибо.
Главная
import "package:flutter/material.dart";
import "package:innovative_world/services/auth_service.dart";
import "package:innovative_world/models/list_model.dart";
import 'package:innovative_world/services/database_service.dart';
import "package:innovative_world/shared/decoration.dart";
import 'package:innovative_world/shared/loading.dart';
import 'package:provider/provider.dart';
import "package:innovative_world/models/user_model.dart";
import "package:innovative_world/models/list_model.dart";
class Home extends StatefulWidget {
@override
_HomeState createState() => _HomeState();
}
class _HomeState extends State<Home> {
String _text;
final _formKey = GlobalKey<FormState>();
List<String> userDoc = [];
@override
Widget build(BuildContext context) {
final user = Provider.of<UserId>(context);
return StreamBuilder<UserList>(
stream: DatabaseService(uid: user.uid).userListStream,
builder: (context, snapshot) {
if (snapshot.hasData) {
UserList userList = snapshot.data;
return Scaffold(
// App Bar
body: // I cut off some irrelevant code
RaisedButton( // Submit button
onPressed: () async {
if (_formKey.currentState.validate()) {
userDoc.add(_text);
_formKey.currentState.reset();
await DatabaseService(uid: user.uid)
.setUserData(userDoc);
}
},
ListView.builder(
shrinkWrap: true,
itemCount: userDoc.length, // snapshot.data.list.length will give Error null
itemBuilder: (context, index) {
return Card(
child: ListTile(
title: Text(userDoc[index]),
),
);
},
),
],
),
),
);
} else {
return Loading();
}
});
}
}
Служба базы данных
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_auth/firebase_auth.dart';
import "package:innovative_world/models/list_model.dart";
class DatabaseService {
// Collection Reference
CollectionReference listCollection = Firestore.instance.collection("list");
// Get current users id
final String uid;
DatabaseService({this.uid});
// Set data to firestore db
Future setUserData(List<String> list) async {
return await listCollection.document(uid).setData({
"list": list
});
}
// UserList snapshot
UserList _userListFromSnapshot(DocumentSnapshot snapshot) {
return UserList(
uid: uid,
list: snapshot.data["list"]
);
}
// Stream for user's to do list
Stream<UserList> get userListStream {
return listCollection.document(uid).snapshots()
.map(_userListFromSnapshot);
}
}
Служба аутентификации
// Register with email and password
Future registerWithEmailAndPassword(String email, String password) async {
try {
AuthResult result = await _auth.createUserWithEmailAndPassword(email: email, password: password);
FirebaseUser user = result.user;
await DatabaseService(uid: user.uid).setUserData(["Test"]); // Set initial Data as snapshot
return _userFromFirebaseUser(user);
}
catch(e) {
print(e.toString());
return null;
}
}
список моделей
class UserList {
final List<String> list;
final String uid;
UserList({ this.list, this.uid });
}