Add AppOpenByDefaultPreference for Spa
The "Open by Default" in App Info page. Bug: 236346018 Test: Manual with App Info page Test: Settings Unit tests Change-Id: I20f827241ff46bca28440b56fd32a0712ee439f9
This commit is contained in:
@@ -92,7 +92,12 @@ private fun AppInfoSettings(packageInfoPresenter: PackageInfoPresenter) {
|
||||
|
||||
AppPermissionPreference(app)
|
||||
AppStoragePreference(app)
|
||||
// TODO: instant_app_launch_supported_domain_urls
|
||||
// TODO: data_settings
|
||||
AppTimeSpentPreference(app)
|
||||
// TODO: battery
|
||||
// TODO: app_language_setting
|
||||
AppOpenByDefaultPreference(app)
|
||||
|
||||
Category(title = stringResource(R.string.advanced_apps)) {
|
||||
DisplayOverOtherAppsAppListProvider.InfoPageEntryItem(app)
|
||||
|
@@ -33,7 +33,7 @@ class AppInstallButton(private val packageInfoPresenter: PackageInfoPresenter) {
|
||||
val app = packageInfo.applicationInfo
|
||||
if (!app.isInstantApp) return null
|
||||
|
||||
return AppStoreUtil.getAppStoreLink(packageInfoPresenter.contextAsUser, app.packageName)
|
||||
return AppStoreUtil.getAppStoreLink(packageInfoPresenter.userContext, app.packageName)
|
||||
?.let { intent -> installButton(intent, app) }
|
||||
}
|
||||
|
||||
|
@@ -0,0 +1,92 @@
|
||||
/*
|
||||
* Copyright (C) 2022 The Android Open Source Project
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
package com.android.settings.spa.app.appinfo
|
||||
|
||||
import android.app.settings.SettingsEnums
|
||||
import android.content.Context
|
||||
import android.content.pm.ApplicationInfo
|
||||
import androidx.compose.runtime.Composable
|
||||
import androidx.compose.runtime.livedata.observeAsState
|
||||
import androidx.compose.runtime.remember
|
||||
import androidx.compose.ui.platform.LocalContext
|
||||
import androidx.compose.ui.res.stringResource
|
||||
import androidx.lifecycle.liveData
|
||||
import com.android.settings.R
|
||||
import com.android.settings.applications.appinfo.AppInfoDashboardFragment
|
||||
import com.android.settings.applications.intentpicker.AppLaunchSettings
|
||||
import com.android.settings.applications.intentpicker.IntentPickerUtils
|
||||
import com.android.settingslib.applications.AppUtils
|
||||
import com.android.settingslib.spa.framework.compose.stateOf
|
||||
import com.android.settingslib.spa.widget.preference.Preference
|
||||
import com.android.settingslib.spa.widget.preference.PreferenceModel
|
||||
import com.android.settingslib.spaprivileged.framework.common.asUser
|
||||
import com.android.settingslib.spaprivileged.framework.common.domainVerificationManager
|
||||
import com.android.settingslib.spaprivileged.model.app.hasFlag
|
||||
import com.android.settingslib.spaprivileged.model.app.userHandle
|
||||
import com.android.settingslib.spaprivileged.model.app.userId
|
||||
import kotlinx.coroutines.Dispatchers
|
||||
|
||||
@Composable
|
||||
fun AppOpenByDefaultPreference(app: ApplicationInfo) {
|
||||
val context = LocalContext.current
|
||||
val presenter = remember { AppOpenByDefaultPresenter(context, app) }
|
||||
if (!presenter.isAvailable()) return
|
||||
|
||||
Preference(object : PreferenceModel {
|
||||
override val title = stringResource(R.string.launch_by_default)
|
||||
override val summary = presenter.summaryLiveData.observeAsState(
|
||||
initial = stringResource(R.string.summary_placeholder),
|
||||
)
|
||||
override val enabled = stateOf(presenter.isEnabled())
|
||||
override val onClick = presenter::startActivity
|
||||
})
|
||||
}
|
||||
|
||||
private class AppOpenByDefaultPresenter(
|
||||
private val context: Context,
|
||||
private val app: ApplicationInfo,
|
||||
) {
|
||||
private val domainVerificationManager = context.asUser(app.userHandle).domainVerificationManager
|
||||
|
||||
fun isAvailable() =
|
||||
!app.isInstantApp && !AppUtils.isBrowserApp(context, app.packageName, app.userId)
|
||||
|
||||
fun isEnabled() = app.hasFlag(ApplicationInfo.FLAG_INSTALLED) && app.enabled
|
||||
|
||||
val summaryLiveData = liveData(Dispatchers.IO) {
|
||||
emit(context.getString(when {
|
||||
isLinkHandlingAllowed() -> R.string.app_link_open_always
|
||||
else -> R.string.app_link_open_never
|
||||
}))
|
||||
}
|
||||
|
||||
fun isLinkHandlingAllowed(): Boolean {
|
||||
val userState = IntentPickerUtils.getDomainVerificationUserState(
|
||||
domainVerificationManager, app.packageName
|
||||
)
|
||||
return userState?.isLinkHandlingAllowed ?: false
|
||||
}
|
||||
|
||||
fun startActivity() {
|
||||
AppInfoDashboardFragment.startAppInfoFragment(
|
||||
AppLaunchSettings::class.java,
|
||||
app,
|
||||
context,
|
||||
SettingsEnums.APPLICATIONS_INSTALLED_APP_DETAILS,
|
||||
)
|
||||
}
|
||||
}
|
@@ -24,6 +24,7 @@ import androidx.lifecycle.LiveData
|
||||
import com.android.settings.R
|
||||
import com.android.settingslib.applications.PermissionsSummaryHelper
|
||||
import com.android.settingslib.applications.PermissionsSummaryHelper.PermissionsResultCallback
|
||||
import com.android.settingslib.spaprivileged.framework.common.asUser
|
||||
import com.android.settingslib.spaprivileged.model.app.userHandle
|
||||
|
||||
data class AppPermissionSummaryState(
|
||||
@@ -35,8 +36,8 @@ class AppPermissionSummaryLiveData(
|
||||
private val context: Context,
|
||||
private val app: ApplicationInfo,
|
||||
) : LiveData<AppPermissionSummaryState>() {
|
||||
private val contextAsUser = context.createContextAsUser(app.userHandle, 0)
|
||||
private val packageManager = contextAsUser.packageManager
|
||||
private val userContext = context.asUser(app.userHandle)
|
||||
private val packageManager = userContext.packageManager
|
||||
|
||||
private val onPermissionsChangedListener = OnPermissionsChangedListener { uid ->
|
||||
if (uid == app.uid) update()
|
||||
@@ -53,7 +54,7 @@ class AppPermissionSummaryLiveData(
|
||||
|
||||
private fun update() {
|
||||
PermissionsSummaryHelper.getPermissionSummary(
|
||||
contextAsUser, app.packageName, permissionsCallback
|
||||
userContext, app.packageName, permissionsCallback
|
||||
)
|
||||
}
|
||||
|
||||
|
@@ -29,6 +29,7 @@ import android.util.Log
|
||||
import androidx.compose.runtime.Composable
|
||||
import com.android.settings.overlay.FeatureFactory
|
||||
import com.android.settingslib.spa.framework.compose.LocalNavController
|
||||
import com.android.settingslib.spaprivileged.framework.common.asUser
|
||||
import com.android.settingslib.spaprivileged.framework.compose.DisposableBroadcastReceiverAsUser
|
||||
import com.android.settingslib.spaprivileged.model.app.PackageManagers
|
||||
import kotlinx.coroutines.CoroutineScope
|
||||
@@ -49,8 +50,8 @@ class PackageInfoPresenter(
|
||||
private val coroutineScope: CoroutineScope,
|
||||
) {
|
||||
private val metricsFeatureProvider = FeatureFactory.getFactory(context).metricsFeatureProvider
|
||||
val contextAsUser by lazy { context.createContextAsUser(UserHandle.of(userId), 0) }
|
||||
val packageManagerAsUser: PackageManager by lazy { contextAsUser.packageManager }
|
||||
val userContext by lazy { context.asUser(UserHandle.of(userId)) }
|
||||
val packageManagerAsUser: PackageManager by lazy { userContext.packageManager }
|
||||
private val _flow: MutableStateFlow<PackageInfo?> = MutableStateFlow(null)
|
||||
|
||||
val flow: StateFlow<PackageInfo?> = _flow
|
||||
|
Reference in New Issue
Block a user