Flutter Firebase 将两个集合数据合并到一个数组中并在小部件中显示数据

时间:2021-04-15 16:28:21

标签: firebase flutter google-cloud-firestore

我想在一个数组中加入两个集合数据并将结果显示在 listView.builder

用户(UID、姓名、电子邮件、电话、经度、纬度),

和行程(用户 ID、日期、时间、价格、从、到)。

PS:这两个集合之间的关系是用户ID,

所以我想为每个元素显示一张卡片,其中包含以下详细信息:

姓名、电子邮件、电话、日期、时间、从、到。

如何实现?

    import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_auth/firebase_auth.dart';

class VoyagerModel {
  var firestore = FirebaseFirestore.instance;
  String de, vers, adress;
  DateTime dateTime;
  double price;
  User user;
  String time;
  createVoyage() async {
    await firestore.collection('voyages').add({
      'userId': this.user.uid,
      'de': this.de,
      'vers': this.vers,
      'date': this.dateTime,
      'time': this.time,
      'adress': this.adress,
      'prix': this.price
    });
  }
}

和用户模型

import 'package:cloud_firestore/cloud_firestore.dart';

class ClientModel {
  String ref = 'clients';

  createUser(
      {id,
      int number,
      String name,
      String email,
      double long,
      double lat}) async {
    await FirebaseFirestore.instance.collection('users').doc(id).set({
      'userId': id,
      'name': name,
      'email': email,
      'phone': number,
      'longitude': long,
      'latitude': lat
    }).catchError((err) => {print(err.toString())});
  }
}

1 个答案:

答案 0 :(得分:1)

这就是您要找的?

List<VoyagerModel> voyagers = [];
List<User> users = [];

@override
void initState() {
  // Fill voyagers and users
  super.initState();
}

@override
  Widget build(BuildContext context) {
    return Container(
      child: ListView.builder(
        itemCount: users.length,
        itemBuilder: (context, index) {
          final user = users[index];
          final userVoyagers =
              voyagers
               .where((voyager) => voyager.user.id == user.id)
               .toList();

          return Column(
            children: userVoyagers.map((userVoyager) {
              return Card(
                child: Column(
                  mainAxisSize: MainAxisSize.min,
                  children: [
                    Text(user.name),
                    Text(user.email),
                    Text('${user.number}'),
                    Text(userVoyager.dateTime.toString()),
                    Text(userVoyager.de),
                    Text(userVoyager.vers),
                  ],
                ),
              );
            }).toList(),
          );
        },
      ),
    );
  }
}