Merge "Add a preference in reset options to delete private space" into main
This commit is contained in:
committed by
Android (Google) Code Review
commit
4230ad4b07
@@ -0,0 +1,146 @@
|
||||
/*
|
||||
* Copyright (C) 2024 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.privatespace.delete;
|
||||
|
||||
import static com.android.settings.system.ResetDashboardFragment.PRIVATE_SPACE_DELETE_CREDENTIAL_REQUEST;
|
||||
|
||||
import android.app.Activity;
|
||||
import android.app.Dialog;
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
import android.content.DialogInterface;
|
||||
import android.content.Intent;
|
||||
import android.os.Bundle;
|
||||
import android.text.TextUtils;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.appcompat.app.AlertDialog;
|
||||
import androidx.fragment.app.FragmentManager;
|
||||
import androidx.preference.Preference;
|
||||
|
||||
import com.android.internal.annotations.Initializer;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.core.instrumentation.InstrumentedDialogFragment;
|
||||
import com.android.settings.password.ChooseLockSettingsHelper;
|
||||
import com.android.settings.privatespace.PrivateSpaceMaintainer;
|
||||
import com.android.settings.system.ResetDashboardFragment;
|
||||
|
||||
/** Controller to delete private space from Settings Reset options after authentication. */
|
||||
public class ResetOptionsDeletePrivateSpaceController extends BasePreferenceController {
|
||||
private static final String TAG = "PrivateSpaceResetCtrl";
|
||||
private ResetDashboardFragment mHostFragment;
|
||||
|
||||
public ResetOptionsDeletePrivateSpaceController(
|
||||
@NonNull Context context, @NonNull String preferenceKey) {
|
||||
super(context, preferenceKey);
|
||||
}
|
||||
|
||||
@Initializer
|
||||
public void setFragment(@NonNull ResetDashboardFragment hostFragment) {
|
||||
mHostFragment = hostFragment;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getAvailabilityStatus() {
|
||||
// TODO(b/330396315) : use canAddPrivateProfile() to check if private space is supported
|
||||
// on the device
|
||||
return android.multiuser.Flags.enablePrivateSpaceFeatures()
|
||||
&& android.multiuser.Flags.deletePrivateSpaceFromReset()
|
||||
? AVAILABLE
|
||||
: UNSUPPORTED_ON_DEVICE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean handlePreferenceTreeClick(@NonNull Preference preference) {
|
||||
if (!TextUtils.equals(preference.getKey(), getPreferenceKey())) {
|
||||
return false;
|
||||
}
|
||||
startAuthenticationForDelete();
|
||||
return true;
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
boolean startAuthenticationForDelete() {
|
||||
final ChooseLockSettingsHelper.Builder builder =
|
||||
new ChooseLockSettingsHelper.Builder(mHostFragment.getActivity(), mHostFragment);
|
||||
builder.setRequestCode(PRIVATE_SPACE_DELETE_CREDENTIAL_REQUEST).show();
|
||||
return true;
|
||||
}
|
||||
|
||||
/** Method to handle onActivityResult */
|
||||
public boolean handleActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
|
||||
if (requestCode == PRIVATE_SPACE_DELETE_CREDENTIAL_REQUEST
|
||||
&& resultCode == Activity.RESULT_OK
|
||||
&& data != null) {
|
||||
DeletePrivateSpaceDialogFragment dialogFragment = getDeleteDialogFragment();
|
||||
dialogFragment.show(
|
||||
getFragmentManager(), DeletePrivateSpaceDialogFragment.class.getName());
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
DeletePrivateSpaceDialogFragment getDeleteDialogFragment() {
|
||||
return new DeletePrivateSpaceDialogFragment();
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
FragmentManager getFragmentManager() {
|
||||
return mHostFragment.getFragmentManager();
|
||||
}
|
||||
|
||||
/* Dialog shown when deleting private space from Reset Options. */
|
||||
public static class DeletePrivateSpaceDialogFragment extends InstrumentedDialogFragment {
|
||||
private static final String TAG = "PrivateSpaceResetFrag";
|
||||
|
||||
@Override
|
||||
public int getMetricsCategory() {
|
||||
return SettingsEnums.RESET_DELETE_PRIVATE_SPACE_DIALOG;
|
||||
}
|
||||
|
||||
@NonNull
|
||||
@Override
|
||||
public Dialog onCreateDialog(@Nullable Bundle savedInstanceState) {
|
||||
Context context = getContext();
|
||||
return new AlertDialog.Builder(context)
|
||||
.setTitle(R.string.reset_private_space_delete_title)
|
||||
.setMessage(R.string.reset_private_space_delete_dialog)
|
||||
.setPositiveButton(
|
||||
R.string.private_space_delete_button_label,
|
||||
(DialogInterface dialog, int which) -> {
|
||||
mMetricsFeatureProvider.action(
|
||||
context, SettingsEnums.RESET_DELETE_PRIVATE_SPACE_CONFIRM);
|
||||
PrivateSpaceMaintainer privateSpaceMaintainer =
|
||||
PrivateSpaceMaintainer.getInstance(context);
|
||||
privateSpaceMaintainer.deletePrivateSpace();
|
||||
dialog.dismiss();
|
||||
})
|
||||
.setNegativeButton(
|
||||
R.string.private_space_cancel_label,
|
||||
(DialogInterface dialog, int which) -> {
|
||||
mMetricsFeatureProvider.action(
|
||||
context, SettingsEnums.RESET_DELETE_PRIVATE_SPACE_CANCEL);
|
||||
dialog.cancel();
|
||||
})
|
||||
.create();
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -18,6 +18,9 @@ package com.android.settings.system;
|
||||
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.applications.manageapplications.ResetAppPrefPreferenceController;
|
||||
@@ -25,6 +28,7 @@ import com.android.settings.dashboard.DashboardFragment;
|
||||
import com.android.settings.network.EraseEuiccDataController;
|
||||
import com.android.settings.network.NetworkResetPreferenceController;
|
||||
import com.android.settings.network.SubscriptionUtil;
|
||||
import com.android.settings.privatespace.delete.ResetOptionsDeletePrivateSpaceController;
|
||||
import com.android.settings.search.BaseSearchIndexProvider;
|
||||
import com.android.settingslib.core.AbstractPreferenceController;
|
||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||
@@ -38,6 +42,7 @@ import java.util.List;
|
||||
public class ResetDashboardFragment extends DashboardFragment {
|
||||
|
||||
private static final String TAG = "ResetDashboardFragment";
|
||||
public static final int PRIVATE_SPACE_DELETE_CREDENTIAL_REQUEST = 1;
|
||||
|
||||
@Override
|
||||
public int getMetricsCategory() {
|
||||
@@ -65,6 +70,14 @@ public class ResetDashboardFragment extends DashboardFragment {
|
||||
if (SubscriptionUtil.isSimHardwareVisible(context)) {
|
||||
use(EraseEuiccDataController.class).setFragment(this);
|
||||
}
|
||||
if (android.multiuser.Flags.enablePrivateSpaceFeatures()
|
||||
&& android.multiuser.Flags.deletePrivateSpaceFromReset()) {
|
||||
ResetOptionsDeletePrivateSpaceController resetOptionsDeletePrivateSpaceController =
|
||||
use(ResetOptionsDeletePrivateSpaceController.class);
|
||||
if (resetOptionsDeletePrivateSpaceController != null) {
|
||||
resetOptionsDeletePrivateSpaceController.setFragment(this);
|
||||
}
|
||||
}
|
||||
FactoryResetPreferenceController factoryResetPreferenceController =
|
||||
use(FactoryResetPreferenceController.class);
|
||||
if (factoryResetPreferenceController != null) {
|
||||
@@ -96,4 +109,13 @@ public class ResetDashboardFragment extends DashboardFragment {
|
||||
return buildPreferenceControllers(context, null /* lifecycle */);
|
||||
}
|
||||
};
|
||||
|
||||
@Override
|
||||
public void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
|
||||
if (use(ResetOptionsDeletePrivateSpaceController.class)
|
||||
.handleActivityResult(requestCode, resultCode, data)) {
|
||||
return;
|
||||
}
|
||||
super.onActivityResult(requestCode, resultCode, data);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user