Fix issue where the wrong system was opened when dealing with other permissions than Manifest.permission.POST_NOTIFICATIONS

This commit is contained in:
Benoit Marty
2025-12-10 10:32:37 +01:00
parent 618171be05
commit b34f2cddef
5 changed files with 13 additions and 8 deletions

View File

@@ -113,7 +113,7 @@ class DefaultPermissionsPresenter(
}
}
PermissionsEvents.OpenSystemSettingAndCloseDialog -> {
permissionActions.openSettings()
permissionActions.openSettings(permission)
showDialog.value = false
}
}

View File

@@ -8,9 +8,11 @@
package io.element.android.libraries.permissions.impl.action
import android.Manifest
import android.content.Context
import dev.zacsweers.metro.AppScope
import dev.zacsweers.metro.ContributesBinding
import io.element.android.libraries.androidutils.system.openAppSettingsPage
import io.element.android.libraries.androidutils.system.startNotificationSettingsIntent
import io.element.android.libraries.di.annotations.ApplicationContext
@@ -18,7 +20,10 @@ import io.element.android.libraries.di.annotations.ApplicationContext
class AndroidPermissionActions(
@ApplicationContext private val context: Context
) : PermissionActions {
override fun openSettings() {
context.startNotificationSettingsIntent()
override fun openSettings(permission: String) {
when (permission) {
Manifest.permission.POST_NOTIFICATIONS -> context.startNotificationSettingsIntent()
else -> context.openAppSettingsPage()
}
}
}

View File

@@ -9,5 +9,5 @@
package io.element.android.libraries.permissions.impl.action
interface PermissionActions {
fun openSettings()
fun openSettings(permission: String)
}

View File

@@ -61,6 +61,6 @@ class NotificationTroubleshootCheckPermissionTest(
navigator: NotificationTroubleshootNavigator,
) {
// Do not bother about asking the permission inline, just lead the user to the settings
permissionActions.openSettings()
permissionActions.openSettings(Manifest.permission.POST_NOTIFICATIONS)
}
}

View File

@@ -9,13 +9,13 @@
package io.element.android.libraries.permissions.impl.action
class FakePermissionActions(
val openSettingsAction: () -> Unit = {}
val openSettingsAction: (String) -> Unit = {}
) : PermissionActions {
var openSettingsCalled = false
private set
override fun openSettings() {
openSettingsAction()
override fun openSettings(permission: String) {
openSettingsAction(permission)
openSettingsCalled = true
}
}