From 7887ab9999b384e567cb8c19d38c13057d127573 Mon Sep 17 00:00:00 2001
From: uvok
Date: Thu, 31 Jul 2025 18:14:54 +0200
Subject: ValueNotifier, remove manual back button
---
lib/model/connection/device_connection.dart | 4 ++-
.../flutter_blue_plus_device_connection.dart | 11 +++++---
lib/model/connection/mock_device_connection.dart | 11 +++++---
lib/model/connection/universal_ble_connection.dart | 13 ++++++----
lib/widgets/device_details.dart | 29 +++++++---------------
5 files changed, 34 insertions(+), 34 deletions(-)
diff --git a/lib/model/connection/device_connection.dart b/lib/model/connection/device_connection.dart
index 5c810f0..baeaa9f 100644
--- a/lib/model/connection/device_connection.dart
+++ b/lib/model/connection/device_connection.dart
@@ -13,12 +13,14 @@
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
+import 'package:flutter/foundation.dart';
+
enum ConnectionStatus { disconnected, connected, error }
abstract class DeviceConnection {
Future connect();
Future disconnect();
- ConnectionStatus get status;
+ ValueNotifier get status;
// Future read(String endpoint);
// Future write(String endpoint, Uint8List data);
diff --git a/lib/model/connection/flutter_blue_plus_device_connection.dart b/lib/model/connection/flutter_blue_plus_device_connection.dart
index 3f860a6..9cc73d1 100644
--- a/lib/model/connection/flutter_blue_plus_device_connection.dart
+++ b/lib/model/connection/flutter_blue_plus_device_connection.dart
@@ -15,6 +15,7 @@
import 'dart:async';
+import 'package:flutter/foundation.dart';
import 'package:flutter_blue_plus/flutter_blue_plus.dart';
import 'package:logger/logger.dart';
import 'package:uvok_epaper_badge/first_where_ext.dart';
@@ -24,7 +25,9 @@ import 'package:uvok_epaper_badge/model/device/flutter_blue_plus_device.dart';
var logger = Logger();
class FlutterBluePlusDeviceConnection implements DeviceConnection {
- ConnectionStatus _status = ConnectionStatus.disconnected;
+ final ValueNotifier _status = ValueNotifier(
+ ConnectionStatus.disconnected,
+ );
// Just to have a resonable default subscription?
StreamSubscription subs =
Stream.empty().listen((e) => ());
@@ -58,7 +61,7 @@ class FlutterBluePlusDeviceConnection implements DeviceConnection {
findCharac(svcs);
- _status = ConnectionStatus.connected;
+ _status.value = ConnectionStatus.connected;
await Future.delayed(Duration(seconds: 5));
logger.i("Try re-discover");
@@ -68,11 +71,11 @@ class FlutterBluePlusDeviceConnection implements DeviceConnection {
@override
Future disconnect() async {
subs.cancel().ignore();
- _status = ConnectionStatus.disconnected;
+ _status.value = ConnectionStatus.disconnected;
}
@override
- ConnectionStatus get status => _status;
+ ValueNotifier get status => _status;
void _onConnStateChange(BluetoothConnectionState event) {
logger.i("New conn state: ${event.toString()}");
diff --git a/lib/model/connection/mock_device_connection.dart b/lib/model/connection/mock_device_connection.dart
index 8b8750a..9dc3726 100644
--- a/lib/model/connection/mock_device_connection.dart
+++ b/lib/model/connection/mock_device_connection.dart
@@ -13,21 +13,24 @@
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
+import 'package:flutter/foundation.dart';
import 'package:uvok_epaper_badge/model/connection/device_connection.dart';
class MockDeviceConnection implements DeviceConnection {
- ConnectionStatus _status = ConnectionStatus.disconnected;
+ final ValueNotifier _status = ValueNotifier(
+ ConnectionStatus.disconnected,
+ );
@override
Future connect() async {
- _status = ConnectionStatus.connected;
+ _status.value = ConnectionStatus.connected;
}
@override
Future disconnect() async {
- _status = ConnectionStatus.disconnected;
+ _status.value = ConnectionStatus.disconnected;
}
@override
- ConnectionStatus get status => _status;
+ ValueNotifier get status => _status;
}
diff --git a/lib/model/connection/universal_ble_connection.dart b/lib/model/connection/universal_ble_connection.dart
index b86bf2b..fa986a0 100644
--- a/lib/model/connection/universal_ble_connection.dart
+++ b/lib/model/connection/universal_ble_connection.dart
@@ -13,13 +13,16 @@
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
+import 'package:flutter/foundation.dart';
import 'package:universal_ble/universal_ble.dart';
import 'package:uvok_epaper_badge/model/connection/device_connection.dart';
import 'package:uvok_epaper_badge/model/device/universal_ble_device.dart';
class UniversalBleConnection implements DeviceConnection {
final UniversalBleDevice _device;
- ConnectionStatus _status = ConnectionStatus.disconnected;
+ final ValueNotifier _status = ValueNotifier(
+ ConnectionStatus.disconnected,
+ );
UniversalBleConnection(this._device);
@@ -27,11 +30,11 @@ class UniversalBleConnection implements DeviceConnection {
Future connect() async {
await _device.device.connect();
- _status = await _device.device.isConnected
+ _status.value = await _device.device.isConnected
? ConnectionStatus.connected
: ConnectionStatus.disconnected;
- if (_status == ConnectionStatus.connected) {
+ if (_status.value == ConnectionStatus.connected) {
/* Ignore return value for now */
await _device.device.discoverServices();
}
@@ -40,9 +43,9 @@ class UniversalBleConnection implements DeviceConnection {
@override
Future disconnect() async {
await _device.device.disconnect();
- _status = ConnectionStatus.disconnected;
+ _status.value = ConnectionStatus.disconnected;
}
@override
- ConnectionStatus get status => _status;
+ ValueNotifier get status => _status;
}
diff --git a/lib/widgets/device_details.dart b/lib/widgets/device_details.dart
index e481303..0081d3c 100644
--- a/lib/widgets/device_details.dart
+++ b/lib/widgets/device_details.dart
@@ -13,6 +13,7 @@
// You should have received a copy of the GNU General Public License
// along with this program. If not, see .
+import 'dart:io';
import 'dart:ui';
import 'package:uvok_epaper_badge/model/device/device.dart';
@@ -39,7 +40,6 @@ class DeviceDetailsScreen extends StatefulWidget {
}
class DeviceDetailsState extends State {
- String connectStatus = "";
late final AppLifecycleListener appLL;
/// Whether the back button should be active.
@@ -63,15 +63,14 @@ class DeviceDetailsState extends State {
title: Text("Device details"),
),
body: Center(
- child: Column(
- spacing: 20,
- children: [
- Text(connectStatus),
- ElevatedButton(
- onPressed: backActive ? backClick : null,
- child: Text("Back"),
- ),
- ],
+ child: ValueListenableBuilder(
+ valueListenable: widget.deviceConnection.status,
+ builder: (connCtx, ConnectionStatus value, child) {
+ return Column(
+ spacing: 20,
+ children: [Text("Connection state: ${value.toString()}")],
+ );
+ },
),
),
);
@@ -83,10 +82,6 @@ class DeviceDetailsState extends State {
_doConnect();
}
- void backClick() {
- Navigator.pop(context);
- }
-
@override
void deactivate() {
logger.i("(widget deactivate)");
@@ -102,20 +97,14 @@ class DeviceDetailsState extends State {
}
void _doConnect() async {
- final dev = widget.device;
-
try {
logger.i("Try to connect...");
await widget.deviceConnection.connect();
} catch (e) {
logger.e(e);
await widget.deviceConnection.disconnect();
- connectStatus = e.toString();
} finally {
backActive = true;
- if (mounted) {
- setState(() {});
- }
}
}
}
--
cgit v1.2.3