summaryrefslogtreecommitdiff
path: root/lib/ui.dart
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2026-04-08 14:16:28 +0200
committerxengineering <me@xengineering.eu>2026-04-08 14:16:28 +0200
commit18cbbf877b171fc23950e64dac5fa6abda6fb02b (patch)
treeb3270dccc583da68c0a8b38c5123e5747191292d /lib/ui.dart
parent5171ef6557c3f38a32e68313e51c4ca1e866835a (diff)
downloadsia-app-18cbbf877b171fc23950e64dac5fa6abda6fb02b.tar
sia-app-18cbbf877b171fc23950e64dac5fa6abda6fb02b.tar.zst
sia-app-18cbbf877b171fc23950e64dac5fa6abda6fb02b.zip
Add plug control
This allows the user to turn Wi-Fi plugs on and off.
Diffstat (limited to 'lib/ui.dart')
-rw-r--r--lib/ui.dart60
1 files changed, 60 insertions, 0 deletions
diff --git a/lib/ui.dart b/lib/ui.dart
index 67a830f..2c964ed 100644
--- a/lib/ui.dart
+++ b/lib/ui.dart
@@ -107,6 +107,11 @@ class DevicesPage extends StatelessWidget {
child: Text("Covers", style: TextStyle(fontSize: 22)),
),
CoverList(),
+ Padding(
+ padding: EdgeInsets.all(15.0),
+ child: Text("Plugs", style: TextStyle(fontSize: 22)),
+ ),
+ PlugList(),
],
),
),
@@ -211,6 +216,61 @@ class CoverList extends StatelessWidget {
}
}
+class PlugList extends StatelessWidget {
+ const PlugList({super.key});
+
+ @override
+ Widget build(BuildContext context) {
+ return Consumer<AppState>(
+ builder: (BuildContext context, AppState state, Widget? child) {
+ return ListView.builder(
+ shrinkWrap: true,
+ physics: const NeverScrollableScrollPhysics(),
+ itemCount: state.plugs.length,
+ itemBuilder: (BuildContext context, int index) {
+ String plug = state.plugs.elementAt(index);
+ return Column(
+ children: <Widget>[
+ ListTile(
+ leading: const Icon(Icons.outlet),
+ title: Text(plug),
+ trailing: Row(
+ mainAxisSize: MainAxisSize.min,
+ children: <Widget>[
+ IconButton(
+ icon: const Icon(Icons.flash_on),
+ constraints: const BoxConstraints(),
+ onPressed: () {
+ state.publish(
+ 'plug/$plug/action',
+ 'on',
+ MqttQos.exactlyOnce
+ );
+ },
+ ),
+ IconButton(
+ icon: const Icon(Icons.flash_off),
+ constraints: const BoxConstraints(),
+ onPressed: () {
+ state.publish(
+ 'plug/$plug/action',
+ 'off',
+ MqttQos.exactlyOnce
+ );
+ },
+ ),
+ ],
+ ),
+ ),
+ ],
+ );
+ },
+ );
+ },
+ );
+ }
+}
+
class ConnectionStatus extends StatelessWidget {
const ConnectionStatus({super.key});