Fix issue where the wrong system was opened when dealing with other permissions than Manifest.permission.POST_NOTIFICATIONS
This commit is contained in:
@@ -113,7 +113,7 @@ class DefaultPermissionsPresenter(
|
||||
}
|
||||
}
|
||||
PermissionsEvents.OpenSystemSettingAndCloseDialog -> {
|
||||
permissionActions.openSettings()
|
||||
permissionActions.openSettings(permission)
|
||||
showDialog.value = false
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -9,5 +9,5 @@
|
||||
package io.element.android.libraries.permissions.impl.action
|
||||
|
||||
interface PermissionActions {
|
||||
fun openSettings()
|
||||
fun openSettings(permission: String)
|
||||
}
|
||||
|
||||
@@ -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)
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user