From c7a26548fdd2409e18d5fb417828645b068f415b Mon Sep 17 00:00:00 2001 From: Codel1417 Date: Sun, 1 Dec 2024 16:51:53 -0500 Subject: [PATCH] disable con mode toggle when gear disconnected --- lib/Frontend/Widgets/manage_gear.dart | 37 +++++++++++++++------------ 1 file changed, 21 insertions(+), 16 deletions(-) diff --git a/lib/Frontend/Widgets/manage_gear.dart b/lib/Frontend/Widgets/manage_gear.dart index 40eef78b..711f59fe 100644 --- a/lib/Frontend/Widgets/manage_gear.dart +++ b/lib/Frontend/Widgets/manage_gear.dart @@ -266,22 +266,27 @@ class ManageGearConventionMode extends ConsumerWidget { ListTile( title: Text(manageGearConModeToggleTitle()), subtitle: Text("Upon enabling 'Convention Mode' your gear will be rebooted and you will be prompted to enter the pincode. Please view and memorize the pincode before enabling"), - trailing: Switch( - value: device.baseStoredDevice.conModeEnabled, - onChanged: (value) { - //reject if gear disconnected - if (value) { - BluetoothMessage bluetoothMessage = BluetoothMessage(message: "SETPUSSKEY ${device.baseStoredDevice.conModePin}", device: device, timestamp: DateTime.timestamp()); - device.commandQueue.addCommand(bluetoothMessage); - device.baseStoredDevice.conModeEnabled = true; - ref.read(knownDevicesProvider.notifier).store(); - } else { - BluetoothMessage bluetoothMessage = BluetoothMessage(message: "STOPPUSSKEY", device: device, timestamp: DateTime.timestamp()); - device.commandQueue.addCommand(bluetoothMessage); - device.baseStoredDevice.conModeEnabled = false; - ref.read(knownDevicesProvider.notifier).store(); - } - }), + trailing: ValueListenableBuilder( + valueListenable: device.deviceConnectionState, + builder: (context, connectivityState, child) => Switch( + value: device.baseStoredDevice.conModeEnabled, + onChanged: connectivityState == ConnectivityState.connected + ? (value) { + //reject if gear disconnected + if (value) { + BluetoothMessage bluetoothMessage = BluetoothMessage(message: "SETPUSSKEY ${device.baseStoredDevice.conModePin}", device: device, timestamp: DateTime.timestamp()); + device.commandQueue.addCommand(bluetoothMessage); + device.baseStoredDevice.conModeEnabled = true; + ref.read(knownDevicesProvider.notifier).store(); + } else { + BluetoothMessage bluetoothMessage = BluetoothMessage(message: "STOPPUSSKEY", device: device, timestamp: DateTime.timestamp()); + device.commandQueue.addCommand(bluetoothMessage); + device.baseStoredDevice.conModeEnabled = false; + ref.read(knownDevicesProvider.notifier).store(); + } + } + : null), + ), ), OverflowBar( children: [FilledButton(onPressed: () => PinCodeRoute(pin: device.baseStoredDevice.conModePin).push(context), child: Text(manageGearConModePincodeTitle()))],