mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-22 22:39:01 -04:00 
			
		
		
		
	fix(mobile): pause background video play (#17032)
* fix(mobile): prevent background video playback * fix: logic for tracking app state * chore: move lifecycle handler in separate file * chore: replace useState with useRef * chore: useOnAppLifecycleStateChange * fix: removed print statement
This commit is contained in:
		
							parent
							
								
									c8331f111f
								
							
						
					
					
						commit
						d2bcf5d716
					
				| @ -44,6 +44,10 @@ class NativeVideoViewerPage extends HookConsumerWidget { | ||||
|     final lastVideoPosition = useRef(-1); | ||||
|     final isBuffering = useRef(false); | ||||
| 
 | ||||
|     // Used to track whether the video should play when the app | ||||
|     // is brought back to the foreground | ||||
|     final shouldPlayOnForeground = useRef(true); | ||||
| 
 | ||||
|     // When a video is opened through the timeline, `isCurrent` will immediately be true. | ||||
|     // When swiping from video A to video B, `isCurrent` will initially be true for video A and false for video B. | ||||
|     // If the swipe is completed, `isCurrent` will be true for video B after a delay. | ||||
| @ -368,6 +372,20 @@ class NativeVideoViewerPage extends HookConsumerWidget { | ||||
|       const [], | ||||
|     ); | ||||
| 
 | ||||
|     useOnAppLifecycleStateChange((_, state) async { | ||||
|       if (state == AppLifecycleState.resumed && shouldPlayOnForeground.value) { | ||||
|         controller.value?.play(); | ||||
|       } else if (state == AppLifecycleState.paused) { | ||||
|         final videoPlaying = await controller.value?.isPlaying(); | ||||
|         if (videoPlaying ?? true) { | ||||
|           shouldPlayOnForeground.value = true; | ||||
|           controller.value?.pause(); | ||||
|         } else { | ||||
|           shouldPlayOnForeground.value = false; | ||||
|         } | ||||
|       } | ||||
|     }); | ||||
| 
 | ||||
|     return Stack( | ||||
|       children: [ | ||||
|         // This remains under the video to avoid flickering | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user