Как заказать документы по содержимому поля в firestore flutter

# #firebase #flutter #dart #google-cloud-firestore

Вопрос:

У меня есть коллекция номеров для отеля. Когда я добавляю новый или показываю список комнат, они не отображаются от 1 до 5. Есть ли способ заказать номера по их номеру?

изображение списка комнат

Документы в коллекции номеров автоматически генерируют свой идентификатор, и в каждой комнате есть поле под названием номер комнаты (например : 1,2,3 ..).

 final rooms = Provider.of<List<Room>>(context) ?? [];

return  StreamProvider<List<Room>>.value(
  initialData: [],
  value: DatabaseService().singleRoom,
  child: Scaffold(
    appBar: AppBar(
      title: Text("Liste des chambre single"),
      backgroundColor: Colors.blue,
      elevation: 2.0,
      leading: IconButton(icon: Icon(Icons.chevron_left),onPressed: ()=> Navigator.pushReplacementNamed(context, '/room_type_screen'),),
      actions: [
        ElevatedButton.icon(
          icon: Icon(Icons.home),
          label: Text(""),
          onPressed: ()=> Navigator.pushReplacementNamed(context, '/admin_home'),
        ),
        ElevatedButton.icon(
          icon: Icon(Icons.add),
          label: Text(""),
          onPressed: ()=> Navigator.pushNamed(context, '/add_room'),
        ),

      ],
    ),
    body: ListView.builder(
      itemCount: rooms.length,
      itemBuilder: (context,index){
        return RoomTile(room : rooms[index]);
      },
    ),
  ),
 
 Widget build(BuildContext context) {
void deleteRoomFromDatabase(String id){
  final CollectionReference singleRoomCollection = FirebaseFirestore.instance.collection("rooms/single/room");
  singleRoomCollection.doc(id).delete();
}
  return Padding(
    padding: EdgeInsets.only(top: 10.0),
    child: Card(
      margin: EdgeInsets.fromLTRB(20, 6, 20, 0),
      child: GridTileBar(
        backgroundColor: Color(0xFFBDBDBD),
        leading: CircleAvatar(
          radius: 30.0,
          backgroundColor: Colors.orange,
          // backgroundImage: AssetImage('assets/6074.jpg'),
          child: Text("${room.numChambre.toString().substring(1)}",
            style: TextStyle(
              color: Colors.white,
              fontSize: 25.0,
              fontWeight: FontWeight.bold
            ),
          ),
        ),
        title: room.reserver?Text("Chambre réservé"):Text('Chambre disponible',style: TextStyle(fontSize: 20),),
        subtitle: Text("Prix : " room.prix.toString()),
        trailing: IconButton(
          icon: Icon(Icons.delete),
          onPressed: (){
            deleteRoomFromDatabase(room.roomId);
          },
        ),
      ),
    ),
  );
}
 

Комментарии:

1. Можете ли вы поделиться скриншотом структуры вашей базы данных?

Ответ №1:

если вы хотите заказать свой результат у:

 FirebaseFirestore.instance.collection("rooms/single/room")
 

используйте функцию .OrderBy ().

 FirebaseFirestore.instance.collection("rooms/single/room").orderBy("FieldInFirestoreToOrderBy", descending: true/false)
 

Если вы хотите отфильтровать результат, вы также можете использовать функцию .where

Комментарии:

1. Хороший ответ. Насколько я могу судить, прочитав вопрос, поле для заказа есть numChambre .