diff --git a/lib/esense_connect_dialog.dart b/lib/esense_connect_dialog.dart new file mode 100644 index 0000000..b598174 --- /dev/null +++ b/lib/esense_connect_dialog.dart @@ -0,0 +1,52 @@ +import 'package:flutter/material.dart'; + +class ESenseConnectDialog extends StatefulWidget { + final void Function(String) connect; + final ValueNotifier deviceStatus; + const ESenseConnectDialog( + {super.key, required this.deviceStatus, required this.connect}); + + @override + State createState() => _ESenseConnectDialogState(); +} + +class _ESenseConnectDialogState extends State { + String eSenseDeviceName = ''; + + @override + Widget build(BuildContext context) { + return AlertDialog( + title: const Text('Connect to ESense'), + content: Column(mainAxisSize: MainAxisSize.min, children: [ + TextField( + onChanged: (input) { + setState(() { + eSenseDeviceName = input; + }); + }, + decoration: InputDecoration( + border: OutlineInputBorder(), + hintText: 'eSense-xxxx', + labelText: 'Device name', + ), + ), + // Text(eSenseDeviceName), + ValueListenableBuilder( + valueListenable: widget.deviceStatus, + builder: (BuildContext context, String value, Widget? child) { + return Text(value); + }), + ]), + actions: [ + TextButton( + onPressed: () => Navigator.pop(context, 'Cancel'), + child: const Text('Discard'), + ), + TextButton( + onPressed: () => widget.connect(eSenseDeviceName), + child: const Text('Connect'), + ), + ], + ); + } +} diff --git a/lib/level_selection.dart b/lib/level_selection.dart index 5ba7a21..e902304 100644 --- a/lib/level_selection.dart +++ b/lib/level_selection.dart @@ -4,6 +4,7 @@ import 'package:esense_flutter/esense.dart'; import 'package:file_picker/file_picker.dart'; import 'package:flutter/material.dart'; import 'package:permission_handler/permission_handler.dart'; +import 'package:sense_the_rhythm/esense_connect_dialog.dart'; import 'package:shared_preferences/shared_preferences.dart'; import 'level.dart'; @@ -19,15 +20,17 @@ class _LevelSelectionState extends State { String? stepmaniaCoursesPath; List stepmaniaCoursesFolders = []; - ESenseManager? eSenseManager; - String _deviceStatus = ''; String eSenseDeviceName = ''; + ESenseManager? eSenseManager; + ValueNotifier _deviceStatus = ValueNotifier(''); + // String _deviceStatus = ''; bool connected = false; bool sampling = false; @override void initState() { super.initState(); + _listenToESense(); loadFolderPath(); } @@ -61,40 +64,42 @@ class _LevelSelectionState extends State { connected = false; switch (event.type) { case ConnectionType.connected: - _deviceStatus = 'connected'; + _deviceStatus.value = 'connected'; connected = true; break; case ConnectionType.unknown: - _deviceStatus = 'unknown'; + _deviceStatus.value = 'unknown'; break; case ConnectionType.disconnected: - _deviceStatus = 'disconnected'; + _deviceStatus.value = 'disconnected'; sampling = false; break; case ConnectionType.device_found: - _deviceStatus = 'device_found'; + _deviceStatus.value = 'device_found'; break; case ConnectionType.device_not_found: - _deviceStatus = 'device_not_found'; + _deviceStatus.value = 'device_not_found'; break; } }); }); } - Future _connectToESense() async { + Future _connectToESense(String deviceName) async { if (!connected) { await _askForPermissions(); print('Trying to connect to eSense device...'); + setState(() { + eSenseDeviceName = deviceName; + }); print(eSenseDeviceName); eSenseManager = ESenseManager(eSenseDeviceName); connected = await eSenseManager!.connect(); print('success!'); setState(() { - _deviceStatus = connected ? 'connecting...' : 'connection failed'; + _deviceStatus.value = connected ? 'connecting...' : 'connection failed'; }); - _listenToESense(); } } @@ -147,43 +152,14 @@ class _LevelSelectionState extends State { title: const Text('Sense the Rhythm'), actions: [ IconButton( - onPressed: () => showDialog( + onPressed: () => showDialog( context: context, builder: (BuildContext context) { - return AlertDialog( - title: const Text('Connect to ESense'), - content: StatefulBuilder(builder: - (BuildContext context, StateSetter setState) { - return Column( - mainAxisSize: MainAxisSize.min, - children: [ - TextField( - onChanged: (input) { - setState(() { - eSenseDeviceName = input; - }); - }, - decoration: InputDecoration( - border: OutlineInputBorder(), - hintText: 'eSense-xxxx', - labelText: 'Device name', - ), - ), - Text(eSenseDeviceName), - Text(_deviceStatus) - ]); - }), - actions: [ - TextButton( - onPressed: () => Navigator.pop(context, 'Cancel'), - child: const Text('Discard'), - ), - TextButton( - onPressed: () => _connectToESense(), - child: const Text('Connect'), - ), - ], - ); + return ESenseConnectDialog( + deviceStatus: _deviceStatus, + connect: (String name) { + _connectToESense(name); + }); }, ), icon: const Icon(Icons.bluetooth))