aboutsummaryrefslogtreecommitdiff
path: root/lib/screens/new_chat_screen.dart
blob: 7b7721feeef92120f6a42788434fc6fe6933ae13 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
import 'package:flutter/material.dart';
import 'package:linkchat/firebase/database.dart';
import 'package:linkchat/models/group.dart';

import '../firebase/auth.dart';
import '../models/user.dart';

class NewChatScreen extends StatefulWidget {
  const NewChatScreen({super.key});

  @override
  State<NewChatScreen> createState() => _NewChatScreenState();
}

class _NewChatScreenState extends State<NewChatScreen> {
  final Auth _auth = Auth();
  final Database _db = Database();
  final TextEditingController _controller = TextEditingController();
  List<FsUser> users = [];
  List<FsUser> filteredUsers = [];

  @override
  void initState() {
    super.initState();
    _db.getAllUsers().first.then((u) {
      setState(() {
        users = u;
        filteredUsers = u;
      });
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Nuevo chat'),
        leading: IconButton(
          icon: const Icon(Icons.arrow_back),
          onPressed: () {
            Navigator.of(context).pop();
          },
        ),
      ),
      body: Column(
        children: [
          TextField(
            controller: _controller,
            decoration: const InputDecoration(
              border: OutlineInputBorder(),
              labelText: 'Nombre del contacto',
            ),
            onChanged: (value) {
              setState(() {
                if (value.isNotEmpty) {
                  filteredUsers = users
                      .where((user) => user.displayName.contains(value))
                      .toList();
                } else {
                  filteredUsers = users;
                }
              });
            },
          ),
          ListView.builder(
            shrinkWrap: true,
            itemCount: filteredUsers.length,
            itemBuilder: (context, index) {
              FsUser user = filteredUsers[index];
              return ListTile(
                leading: CircleAvatar(
                  backgroundImage: NetworkImage(user.photoUrl),
                ),
                title: Text(user.displayName),
                trailing: IconButton(
                  icon: const Icon(Icons.send),
                  onPressed: () {
                    _db
                        .saveGroup(Group(
                      createdBy: _auth.currentUser!.uid,
                      createdAt: DateTime.now(),
                      members: [
                        _auth.currentUser!.uid,
                        user.uid,
                      ],
                    ))
                        .whenComplete(() {
                      Navigator.of(context).pop();
                    });
                  },
                ),
              );
            },
          ),
        ],
      ),
    );
  }
}