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
|
import 'package:flutter/material.dart';
void main() {
runApp(const MainApp());
}
class MainApp extends StatelessWidget {
const MainApp({super.key});
@override
Widget build(BuildContext context) {
return const MaterialApp(
home: ContactList(),
);
}
}
class Contact {
final String address;
final bool isOpen;
const Contact({required this.address, required this.isOpen});
}
class ContactList extends StatelessWidget {
const ContactList({super.key});
final List<Contact> contacts = const <Contact>[
Contact(address: "Living Room Window", isOpen: false),
Contact(address: "Front Door", isOpen: true),
Contact(address: "Back Door", isOpen: false),
Contact(address: "Garage Window", isOpen: true),
];
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text("Contacts")),
body: ListView.builder(
itemCount: contacts.length,
itemBuilder: (BuildContext context, int index) {
final Contact contact = contacts[index];
return ContactTile(contact: contact);
},
),
);
}
}
class ContactTile extends StatelessWidget {
final Contact contact;
const ContactTile({super.key, required this.contact});
@override
Widget build(BuildContext context) {
return ListTile(
leading: Icon(
contact.isOpen ? Icons.meeting_room : Icons.door_front_door,
color: contact.isOpen ? Colors.red : Colors.green,
),
title: Text(contact.address),
);
}
}
|