feat: add ConnectionStatusButton to show status on LevelSelection
This commit is contained in:
		
							parent
							
								
									fc951a4df5
								
							
						
					
					
						commit
						d9403d9e98
					
				|  | @ -3,6 +3,7 @@ import 'dart:io'; | ||||||
| import 'package:file_picker/file_picker.dart'; | import 'package:file_picker/file_picker.dart'; | ||||||
| import 'package:flutter/material.dart'; | import 'package:flutter/material.dart'; | ||||||
| import 'package:permission_handler/permission_handler.dart'; | import 'package:permission_handler/permission_handler.dart'; | ||||||
|  | import 'package:sense_the_rhythm/widgets/connection_status_button.dart'; | ||||||
| import 'package:shared_preferences/shared_preferences.dart'; | import 'package:shared_preferences/shared_preferences.dart'; | ||||||
| import 'package:sense_the_rhythm/utils/esense_input.dart'; | import 'package:sense_the_rhythm/utils/esense_input.dart'; | ||||||
| import 'package:sense_the_rhythm/utils/simfile.dart'; | import 'package:sense_the_rhythm/utils/simfile.dart'; | ||||||
|  | @ -94,18 +95,16 @@ class _LevelSelectionState extends State<LevelSelection> { | ||||||
|       appBar: AppBar( |       appBar: AppBar( | ||||||
|         title: const Text('Sense the Rhythm'), |         title: const Text('Sense the Rhythm'), | ||||||
|         actions: [ |         actions: [ | ||||||
|           IconButton( |           Padding( | ||||||
|               onPressed: () => showDialog( |             padding: const EdgeInsets.symmetric(horizontal: 8.0), | ||||||
|                     context: context, |             child: ValueListenableBuilder( | ||||||
|                     builder: (BuildContext context) { |               valueListenable: ESenseInput.instance.deviceStatus, | ||||||
|                       return ESenseConnectDialog( |               builder: | ||||||
|                           deviceStatus: ESenseInput.instance.deviceStatus, |                   (BuildContext context, String deviceStatus, Widget? child) { | ||||||
|                           connect: (String name) { |                 return ConnectionStatusButton(deviceStatus); | ||||||
|                             ESenseInput.instance.connectToESense(name); |               }, | ||||||
|                           }); |             ), | ||||||
|                     }, |           ) | ||||||
|                   ), |  | ||||||
|               icon: const Icon(Icons.bluetooth)) |  | ||||||
|         ], |         ], | ||||||
|       ), |       ), | ||||||
|       body: Builder(builder: (context) { |       body: Builder(builder: (context) { | ||||||
|  |  | ||||||
							
								
								
									
										36
									
								
								lib/widgets/connection_status_button.dart
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								lib/widgets/connection_status_button.dart
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,36 @@ | ||||||
|  | import 'package:flutter/material.dart'; | ||||||
|  | import 'package:sense_the_rhythm/utils/esense_input.dart'; | ||||||
|  | import 'package:sense_the_rhythm/widgets/esense_connect_dialog.dart'; | ||||||
|  | 
 | ||||||
|  | class ConnectionStatusButton extends StatelessWidget { | ||||||
|  |   final String deviceStatus; | ||||||
|  |   const ConnectionStatusButton( | ||||||
|  |     this.deviceStatus, { | ||||||
|  |     super.key, | ||||||
|  |   }); | ||||||
|  | 
 | ||||||
|  |   @override | ||||||
|  |   Widget build(BuildContext context) { | ||||||
|  |     return FilledButton.icon( | ||||||
|  |         style: ButtonStyle( | ||||||
|  |             backgroundColor: WidgetStateProperty.all( | ||||||
|  |                 ESenseInput.instance.connected ? Colors.green : Colors.grey), | ||||||
|  |             padding: | ||||||
|  |                 WidgetStateProperty.all(EdgeInsets.symmetric(horizontal: 8.0))), | ||||||
|  |         onPressed: () => showDialog( | ||||||
|  |               context: context, | ||||||
|  |               builder: (BuildContext context) { | ||||||
|  |                 return ESenseConnectDialog( | ||||||
|  |                     deviceStatus: ESenseInput.instance.deviceStatus, | ||||||
|  |                     connect: (String name) { | ||||||
|  |                       ESenseInput.instance.connectToESense(name); | ||||||
|  |                     }); | ||||||
|  |               }, | ||||||
|  |             ), | ||||||
|  |         label: Text(deviceStatus), | ||||||
|  |         iconAlignment: IconAlignment.end, | ||||||
|  |         icon: Icon(ESenseInput.instance.connected | ||||||
|  |             ? Icons.bluetooth_connected | ||||||
|  |             : Icons.bluetooth)); | ||||||
|  |   } | ||||||
|  | } | ||||||
		Loading…
	
		Reference in a new issue