Skip to content

Commit

Permalink
fix: call dropped when turning camera on (WPB-9013) 🍒 (#2976)
Browse files Browse the repository at this point in the history
Co-authored-by: Oussama Hassine <[email protected]>
  • Loading branch information
github-actions[bot] and ohassine authored May 7, 2024
1 parent eb02dc3 commit 377f600
Showing 1 changed file with 13 additions and 27 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -169,39 +169,25 @@ fun OngoingCallScreen(
hideDialog = permissionPermanentlyDeniedDialogState::dismiss
)

handleVideoPreviewOnLifecycleChange(
isCameraOn = sharedCallingViewModel.callState.isCameraOn,
callStatus = sharedCallingViewModel.callState.callStatus,
startSendingVideoFeed = ongoingCallViewModel::startSendingVideoFeed,
pauseSendingVideoFeed = ongoingCallViewModel::pauseSendingVideoFeed,
onClearVideoPreview = sharedCallingViewModel::clearVideoPreview
)
}

/**
* This function is responsible for handling the lifecycle changes of the video preview.
* It will pause the video feed when the lifecycle is paused and resume it when the lifecycle is resumed.
*/
@Composable
private fun handleVideoPreviewOnLifecycleChange(
isCameraOn: Boolean,
callStatus: CallStatus,
startSendingVideoFeed: () -> Unit,
pauseSendingVideoFeed: () -> Unit,
onClearVideoPreview: () -> Unit
) {
// Pause the video feed when the lifecycle is paused and resume it when the lifecycle is resumed.
val lifecycleOwner: LifecycleOwner = LocalLifecycleOwner.current
DisposableEffect(lifecycleOwner, isCameraOn, callStatus) {
DisposableEffect(lifecycleOwner) {

val observer = LifecycleEventObserver { _, event ->
if (event == Lifecycle.Event.ON_PAUSE && callStatus == CallStatus.ESTABLISHED && isCameraOn) {
pauseSendingVideoFeed()
if (event == Lifecycle.Event.ON_PAUSE &&
sharedCallingViewModel.callState.callStatus == CallStatus.ESTABLISHED &&
sharedCallingViewModel.callState.isCameraOn
) {
ongoingCallViewModel.pauseSendingVideoFeed()
}
if (event == Lifecycle.Event.ON_RESUME && callStatus == CallStatus.ESTABLISHED && isCameraOn) {
startSendingVideoFeed()
if (event == Lifecycle.Event.ON_RESUME &&
sharedCallingViewModel.callState.callStatus == CallStatus.ESTABLISHED &&
sharedCallingViewModel.callState.isCameraOn
) {
ongoingCallViewModel.startSendingVideoFeed()
}
if (event == Lifecycle.Event.ON_DESTROY) {
onClearVideoPreview()
sharedCallingViewModel.clearVideoPreview()
}
}

Expand Down

0 comments on commit 377f600

Please sign in to comment.