diff --git a/app/src/main/java/org/linphone/ui/main/settings/viewmodel/SettingsViewModel.kt b/app/src/main/java/org/linphone/ui/main/settings/viewmodel/SettingsViewModel.kt index 5244f82ba..7658233bc 100644 --- a/app/src/main/java/org/linphone/ui/main/settings/viewmodel/SettingsViewModel.kt +++ b/app/src/main/java/org/linphone/ui/main/settings/viewmodel/SettingsViewModel.kt @@ -90,7 +90,7 @@ class SettingsViewModel val autoRecordCalls = MutableLiveData() - val goToIncomingCallNotificationChannelSettingsEvent = MutableLiveData>() + val goToIncomingCallNotificationChannelSettingsEvent = MutableLiveData>() // Conversations settings val showConversationsSettings = MutableLiveData() @@ -462,11 +462,18 @@ class SettingsViewModel @UiThread fun changeRingtone() { coreContext.postOnCoreThread { core -> - val defaultDeviceRingtone = RingtoneManager.getActualDefaultRingtoneUri(coreContext.context, RingtoneManager.TYPE_RINGTONE) - val coreRingtone = core.ring?.toUri() - Log.i("$TAG Currently set ringtone in Core is [$coreRingtone], device default ringtone is [$defaultDeviceRingtone]") - val currentRingtone = coreRingtone ?: defaultDeviceRingtone - goToIncomingCallNotificationChannelSettingsEvent.postValue(Event(currentRingtone)) + try { + val defaultDeviceRingtone = RingtoneManager.getActualDefaultRingtoneUri( + coreContext.context, + RingtoneManager.TYPE_RINGTONE + ) + val coreRingtone = core.ring?.toUri() + Log.i("$TAG Currently set ringtone in Core is [$coreRingtone], device default ringtone is [$defaultDeviceRingtone]") + val currentRingtone = coreRingtone ?: defaultDeviceRingtone + goToIncomingCallNotificationChannelSettingsEvent.postValue(Event(currentRingtone)) + } catch (e: Exception) { + Log.e("$TAG Failed to get current ringtone: $e") + } } }