mirror of
				https://github.com/johrpan/musicus_mobile.git
				synced 2025-10-26 10:47:25 +01:00 
			
		
		
		
	Move more code from mobile to common
This commit is contained in:
		
							parent
							
								
									2e4f69a178
								
							
						
					
					
						commit
						5312bad52d
					
				
					 28 changed files with 258 additions and 215 deletions
				
			
		
							
								
								
									
										59
									
								
								common/lib/src/widgets/play_pause_button.dart
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								common/lib/src/widgets/play_pause_button.dart
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,59 @@ | |||
| import 'dart:async'; | ||||
| 
 | ||||
| import 'package:flutter/material.dart'; | ||||
| 
 | ||||
| import '../backend.dart'; | ||||
| 
 | ||||
| class PlayPauseButton extends StatefulWidget { | ||||
|   @override | ||||
|   _PlayPauseButtonState createState() => _PlayPauseButtonState(); | ||||
| } | ||||
| 
 | ||||
| class _PlayPauseButtonState extends State<PlayPauseButton> | ||||
|     with SingleTickerProviderStateMixin { | ||||
|   AnimationController playPauseAnimation; | ||||
|   MusicusBackendState backend; | ||||
|   StreamSubscription<bool> playingSubscription; | ||||
| 
 | ||||
|   @override | ||||
|   void initState() { | ||||
|     super.initState(); | ||||
| 
 | ||||
|     playPauseAnimation = AnimationController( | ||||
|       vsync: this, | ||||
|       duration: Duration(milliseconds: 300), | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   void didChangeDependencies() { | ||||
|     super.didChangeDependencies(); | ||||
| 
 | ||||
|     backend = MusicusBackend.of(context); | ||||
|     playPauseAnimation.value = backend.playback.playing.value ? 1.0 : 0.0; | ||||
| 
 | ||||
|     if (playingSubscription != null) { | ||||
|       playingSubscription.cancel(); | ||||
|     } | ||||
| 
 | ||||
|     playingSubscription = backend.playback.playing.listen((playing) => | ||||
|         playing ? playPauseAnimation.forward() : playPauseAnimation.reverse()); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   Widget build(BuildContext context) { | ||||
|     return IconButton( | ||||
|       icon: AnimatedIcon( | ||||
|         icon: AnimatedIcons.play_pause, | ||||
|         progress: playPauseAnimation, | ||||
|       ), | ||||
|       onPressed: backend.playback.playPause, | ||||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   @override | ||||
|   void dispose() { | ||||
|     super.dispose(); | ||||
|     playingSubscription.cancel(); | ||||
|   } | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Elias Projahn
						Elias Projahn