summaryrefslogtreecommitdiff
path: root/lib/ui.dart
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2026-01-16 21:49:22 +0100
committerxengineering <me@xengineering.eu>2026-01-17 20:56:45 +0100
commit1dc47d1991910d95b4472ed3e415adb0d46a6617 (patch)
treef7dba1ec72756d8460a770d3fe655872d32599dd /lib/ui.dart
parente2a1b271e2cf417cd3104e6e0679cb54993e6d8f (diff)
downloadsia-app-1dc47d1991910d95b4472ed3e415adb0d46a6617.tar
sia-app-1dc47d1991910d95b4472ed3e415adb0d46a6617.tar.zst
sia-app-1dc47d1991910d95b4472ed3e415adb0d46a6617.zip
Display MQTT connection status
The user otherwise cannot trust the state of the contacts because the app could just be disconnected from the broker.
Diffstat (limited to 'lib/ui.dart')
-rw-r--r--lib/ui.dart30
1 files changed, 29 insertions, 1 deletions
diff --git a/lib/ui.dart b/lib/ui.dart
index ff8c3a8..38ace9a 100644
--- a/lib/ui.dart
+++ b/lib/ui.dart
@@ -11,7 +11,12 @@ class UI extends StatelessWidget {
return MaterialApp(
home: Scaffold(
appBar: AppBar(title: const Text("Contacts")),
- body: const ContactList(),
+ body: const Column(
+ children: <Widget>[
+ Expanded(child: ContactList()),
+ ],
+ ),
+ bottomNavigationBar: const ConnectionStatus(),
),
);
}
@@ -43,3 +48,26 @@ class ContactList extends StatelessWidget {
);
}
}
+
+class ConnectionStatus extends StatelessWidget {
+ const ConnectionStatus({super.key});
+
+ @override
+ Widget build(BuildContext context) {
+ return Consumer<AppState>(
+ builder: (BuildContext context, AppState state, Widget? child) {
+ Icon icon;
+ Text text;
+ if (state.brokerConnected) {
+ icon = const Icon(Icons.cloud, color: Colors.green);
+ text = const Text('Connected');
+ } else {
+ icon = const Icon(Icons.cloud_off, color: Colors.red);
+ text = const Text('Disconnected');
+ }
+
+ return ListTile(leading: icon, title: text);
+ },
+ );
+ }
+}