Remove duplicated metered & privacy spinner
From Wi-Fi dialog when there are already same settings in the Wi-Fi detail page. This makes simpler for the user and help fix the inconsistent issue. Fix: 297036035 Test: manual - open Wi-Fi dialog from Wi-Fi detail page Test: robo test Change-Id: Ic02658d91938db78b91e867a923260aa2610ae49
This commit is contained in:
@@ -64,6 +64,7 @@ import android.widget.ImageButton;
|
||||
import android.widget.Spinner;
|
||||
import android.widget.TextView;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
|
||||
import com.android.net.module.util.NetUtils;
|
||||
@@ -200,8 +201,10 @@ public class WifiConfigController2 implements TextWatcher,
|
||||
private TextView mDns2View;
|
||||
|
||||
private Spinner mProxySettingsSpinner;
|
||||
@Nullable
|
||||
private Spinner mMeteredSettingsSpinner;
|
||||
private Spinner mHiddenSettingsSpinner;
|
||||
@Nullable
|
||||
private Spinner mPrivacySettingsSpinner;
|
||||
private TextView mHiddenWarningView;
|
||||
private TextView mProxyHostView;
|
||||
@@ -216,48 +219,51 @@ public class WifiConfigController2 implements TextWatcher,
|
||||
private StaticIpConfiguration mStaticIpConfiguration = null;
|
||||
|
||||
private String[] mLevels;
|
||||
private int mMode;
|
||||
private final int mMode;
|
||||
private final boolean mHideMeteredAndPrivacy;
|
||||
private final WifiManager mWifiManager;
|
||||
private final AndroidKeystoreAliasLoader mAndroidKeystoreAliasLoader;
|
||||
private TextView mSsidView;
|
||||
|
||||
private Context mContext;
|
||||
private final Context mContext;
|
||||
|
||||
@VisibleForTesting
|
||||
Integer[] mSecurityInPosition;
|
||||
|
||||
private final WifiManager mWifiManager;
|
||||
private boolean mIsTrustOnFirstUseSupported;
|
||||
|
||||
private final ArrayMap<Integer, SubscriptionInfo> mActiveSubscriptionInfos = new ArrayMap<>();
|
||||
|
||||
public WifiConfigController2(WifiConfigUiBase2 parent, View view, WifiEntry wifiEntry,
|
||||
int mode) {
|
||||
mConfigUi = parent;
|
||||
mView = view;
|
||||
mWifiEntry = wifiEntry;
|
||||
mContext = mConfigUi.getContext();
|
||||
this(parent, view, wifiEntry, mode, false);
|
||||
}
|
||||
|
||||
// Init Wi-Fi manager
|
||||
mWifiManager = (WifiManager) mContext.getSystemService(Context.WIFI_SERVICE);
|
||||
initWifiConfigController2(wifiEntry, mode);
|
||||
public WifiConfigController2(WifiConfigUiBase2 parent, View view, WifiEntry wifiEntry,
|
||||
int mode, boolean hideMeteredAndPrivacy) {
|
||||
this(parent, view, wifiEntry, mode, hideMeteredAndPrivacy,
|
||||
parent.getContext().getSystemService(WifiManager.class),
|
||||
new AndroidKeystoreAliasLoader(KeyProperties.NAMESPACE_WIFI));
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
public WifiConfigController2(WifiConfigUiBase2 parent, View view, WifiEntry wifiEntry,
|
||||
int mode, WifiManager wifiManager) {
|
||||
int mode, boolean hideMeteredAndPrivacy, WifiManager wifiManager,
|
||||
AndroidKeystoreAliasLoader androidKeystoreAliasLoader) {
|
||||
mConfigUi = parent;
|
||||
|
||||
mView = view;
|
||||
mWifiEntry = wifiEntry;
|
||||
mMode = mode;
|
||||
mHideMeteredAndPrivacy = hideMeteredAndPrivacy;
|
||||
mContext = mConfigUi.getContext();
|
||||
mWifiManager = wifiManager;
|
||||
initWifiConfigController2(wifiEntry, mode);
|
||||
mAndroidKeystoreAliasLoader = androidKeystoreAliasLoader;
|
||||
initWifiConfigController2(wifiEntry);
|
||||
}
|
||||
|
||||
private void initWifiConfigController2(WifiEntry wifiEntry, int mode) {
|
||||
|
||||
private void initWifiConfigController2(WifiEntry wifiEntry) {
|
||||
mWifiEntrySecurity = (wifiEntry == null) ? WifiEntry.SECURITY_NONE :
|
||||
wifiEntry.getSecurity();
|
||||
mMode = mode;
|
||||
mIsTrustOnFirstUseSupported = mWifiManager.isTrustOnFirstUseSupported();
|
||||
|
||||
final Resources res = mContext.getResources();
|
||||
@@ -287,12 +293,14 @@ public class WifiConfigController2 implements TextWatcher,
|
||||
mProxySettingsSpinner = (Spinner) mView.findViewById(R.id.proxy_settings);
|
||||
mProxySettingsSpinner.setOnItemSelectedListener(this);
|
||||
mSharedCheckBox = (CheckBox) mView.findViewById(R.id.shared);
|
||||
mMeteredSettingsSpinner = mView.findViewById(R.id.metered_settings);
|
||||
if (!mHideMeteredAndPrivacy) {
|
||||
mMeteredSettingsSpinner = mView.findViewById(R.id.metered_settings);
|
||||
mView.findViewById(R.id.metered_settings_fields).setVisibility(View.VISIBLE);
|
||||
}
|
||||
mHiddenSettingsSpinner = mView.findViewById(R.id.hidden_settings);
|
||||
mPrivacySettingsSpinner = mView.findViewById(R.id.privacy_settings);
|
||||
if (mWifiManager.isConnectedMacRandomizationSupported()) {
|
||||
View privacySettingsLayout = mView.findViewById(R.id.privacy_settings_fields);
|
||||
privacySettingsLayout.setVisibility(View.VISIBLE);
|
||||
if (!mHideMeteredAndPrivacy && mWifiManager.isConnectedMacRandomizationSupported()) {
|
||||
mPrivacySettingsSpinner = mView.findViewById(R.id.privacy_settings);
|
||||
mView.findViewById(R.id.privacy_settings_fields).setVisibility(View.VISIBLE);
|
||||
}
|
||||
mHiddenSettingsSpinner.setOnItemSelectedListener(this);
|
||||
mHiddenWarningView = mView.findViewById(R.id.hidden_settings_warning);
|
||||
@@ -313,14 +321,18 @@ public class WifiConfigController2 implements TextWatcher,
|
||||
boolean showAdvancedFields = false;
|
||||
if (mWifiEntry.isSaved()) {
|
||||
WifiConfiguration config = mWifiEntry.getWifiConfiguration();
|
||||
mMeteredSettingsSpinner.setSelection(config.meteredOverride);
|
||||
if (mMeteredSettingsSpinner != null) {
|
||||
mMeteredSettingsSpinner.setSelection(config.meteredOverride);
|
||||
}
|
||||
mHiddenSettingsSpinner.setSelection(config.hiddenSSID
|
||||
? HIDDEN_NETWORK
|
||||
: NOT_HIDDEN_NETWORK);
|
||||
|
||||
final int prefMacValue = WifiPrivacyPreferenceController2
|
||||
.translateMacRandomizedValueToPrefValue(config.macRandomizationSetting);
|
||||
mPrivacySettingsSpinner.setSelection(prefMacValue);
|
||||
if (mPrivacySettingsSpinner != null) {
|
||||
final int prefMacValue = WifiPrivacyPreferenceController2
|
||||
.translateMacRandomizedValueToPrefValue(config.macRandomizationSetting);
|
||||
mPrivacySettingsSpinner.setSelection(prefMacValue);
|
||||
}
|
||||
|
||||
if (config.getIpConfiguration().getIpAssignment() == IpAssignment.STATIC) {
|
||||
mIpSettingsSpinner.setSelection(STATIC_IP);
|
||||
@@ -1063,17 +1075,15 @@ public class WifiConfigController2 implements TextWatcher,
|
||||
if (refreshCertificates) {
|
||||
loadSims();
|
||||
|
||||
final AndroidKeystoreAliasLoader androidKeystoreAliasLoader =
|
||||
getAndroidKeystoreAliasLoader();
|
||||
loadCertificates(
|
||||
mEapCaCertSpinner,
|
||||
androidKeystoreAliasLoader.getCaCertAliases(),
|
||||
mAndroidKeystoreAliasLoader.getCaCertAliases(),
|
||||
null /* noCertificateString */,
|
||||
false /* showMultipleCerts */,
|
||||
true /* showUsePreinstalledCertOption */);
|
||||
loadCertificates(
|
||||
mEapUserCertSpinner,
|
||||
androidKeystoreAliasLoader.getKeyCertAliases(),
|
||||
mAndroidKeystoreAliasLoader.getKeyCertAliases(),
|
||||
mDoNotProvideEapUserCertString,
|
||||
false /* showMultipleCerts */,
|
||||
false /* showUsePreinstalledCertOption */);
|
||||
@@ -1158,11 +1168,9 @@ public class WifiConfigController2 implements TextWatcher,
|
||||
setSelection(mEapCaCertSpinner, caCerts[0]);
|
||||
} else {
|
||||
// Reload the cert spinner with an extra "multiple certificates added" item.
|
||||
final AndroidKeystoreAliasLoader androidKeystoreAliasLoader =
|
||||
getAndroidKeystoreAliasLoader();
|
||||
loadCertificates(
|
||||
mEapCaCertSpinner,
|
||||
androidKeystoreAliasLoader.getCaCertAliases(),
|
||||
mAndroidKeystoreAliasLoader.getCaCertAliases(),
|
||||
null /* noCertificateString */,
|
||||
true /* showMultipleCerts */,
|
||||
true /* showUsePreinstalledCertOption */);
|
||||
@@ -1501,11 +1509,6 @@ public class WifiConfigController2 implements TextWatcher,
|
||||
}
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
AndroidKeystoreAliasLoader getAndroidKeystoreAliasLoader() {
|
||||
return new AndroidKeystoreAliasLoader(KeyProperties.NAMESPACE_WIFI);
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
void loadSims() {
|
||||
List<SubscriptionInfo> activeSubscriptionInfos = mContext
|
||||
|
@@ -41,6 +41,7 @@ class WifiDialog2 @JvmOverloads constructor(
|
||||
private val mode: Int,
|
||||
@StyleRes style: Int = 0,
|
||||
private val hideSubmitButton: Boolean = mode == WifiConfigUiBase2.MODE_VIEW,
|
||||
private val hideMeteredAndPrivacy: Boolean = false,
|
||||
) : AlertDialog(context, style), WifiConfigUiBase2, DialogInterface.OnClickListener {
|
||||
/**
|
||||
* Host UI component of WifiDialog2 can receive callbacks by this interface.
|
||||
@@ -71,7 +72,7 @@ class WifiDialog2 @JvmOverloads constructor(
|
||||
setWindowsOverlay()
|
||||
view = layoutInflater.inflate(R.layout.wifi_dialog, null)
|
||||
setView(view)
|
||||
controller = WifiConfigController2(this, view, wifiEntry, mode)
|
||||
controller = WifiConfigController2(this, view, wifiEntry, mode, hideMeteredAndPrivacy)
|
||||
super.onCreate(savedInstanceState)
|
||||
if (hideSubmitButton) {
|
||||
controller.hideSubmitButton()
|
||||
|
@@ -42,6 +42,7 @@ import android.view.Menu;
|
||||
import android.view.MenuInflater;
|
||||
import android.view.MenuItem;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
@@ -180,8 +181,14 @@ public class WifiNetworkDetailsFragment extends RestrictedDashboardFragment impl
|
||||
}
|
||||
|
||||
final WifiEntry wifiEntry = mNetworkDetailsTracker.getWifiEntry();
|
||||
return new WifiDialog2(getActivity(), this, wifiEntry,
|
||||
WifiConfigUiBase2.MODE_MODIFY);
|
||||
return new WifiDialog2(
|
||||
getActivity(),
|
||||
this,
|
||||
wifiEntry,
|
||||
WifiConfigUiBase2.MODE_MODIFY,
|
||||
0,
|
||||
false,
|
||||
true);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -276,14 +283,12 @@ public class WifiNetworkDetailsFragment extends RestrictedDashboardFragment impl
|
||||
|
||||
// Sets callback listener for wifi dialog.
|
||||
mWifiDialogListeners.add(mWifiDetailPreferenceController2);
|
||||
mWifiDialogListeners.add(privacyController2);
|
||||
mWifiDialogListeners.add(meteredPreferenceController2);
|
||||
|
||||
return mControllers;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSubmit(WifiDialog2 dialog) {
|
||||
public void onSubmit(@NonNull WifiDialog2 dialog) {
|
||||
for (WifiDialog2.WifiDialog2Listener listener : mWifiDialogListeners) {
|
||||
listener.onSubmit(dialog);
|
||||
}
|
||||
|
@@ -18,26 +18,23 @@ package com.android.settings.wifi.details2;
|
||||
|
||||
import android.app.backup.BackupManager;
|
||||
import android.content.Context;
|
||||
import android.net.wifi.WifiConfiguration;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.preference.ListPreference;
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.wifi.WifiDialog2;
|
||||
import com.android.wifitrackerlib.WifiEntry;
|
||||
|
||||
/**
|
||||
* A controller that controls whether the Wi-Fi network is metered or not.
|
||||
*/
|
||||
public class WifiMeteredPreferenceController2 extends BasePreferenceController implements
|
||||
Preference.OnPreferenceChangeListener, WifiDialog2.WifiDialog2Listener {
|
||||
Preference.OnPreferenceChangeListener {
|
||||
|
||||
private static final String KEY_WIFI_METERED = "metered";
|
||||
private final WifiEntry mWifiEntry;
|
||||
private Preference mPreference;
|
||||
|
||||
public WifiMeteredPreferenceController2(Context context, WifiEntry wifiEntry) {
|
||||
super(context, KEY_WIFI_METERED);
|
||||
@@ -59,7 +56,7 @@ public class WifiMeteredPreferenceController2 extends BasePreferenceController i
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||
public boolean onPreferenceChange(@NonNull Preference preference, Object newValue) {
|
||||
if (mWifiEntry.isSaved() || mWifiEntry.isSubscription()) {
|
||||
mWifiEntry.setMeteredChoice(Integer.parseInt((String) newValue));
|
||||
}
|
||||
@@ -82,36 +79,4 @@ public class WifiMeteredPreferenceController2 extends BasePreferenceController i
|
||||
private void updateSummary(ListPreference preference, int meteredOverride) {
|
||||
preference.setSummary(preference.getEntries()[meteredOverride]);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void displayPreference(PreferenceScreen screen) {
|
||||
super.displayPreference(screen);
|
||||
mPreference = screen.findPreference(getPreferenceKey());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSubmit(WifiDialog2 dialog) {
|
||||
if (dialog.getController() != null && mWifiEntry.canSetMeteredChoice()) {
|
||||
final WifiConfiguration newConfig = dialog.getController().getConfig();
|
||||
if (newConfig == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (getWifiEntryMeteredChoice(newConfig) != mWifiEntry.getMeteredChoice()) {
|
||||
mWifiEntry.setMeteredChoice(getWifiEntryMeteredChoice(newConfig));
|
||||
onPreferenceChange(mPreference, String.valueOf(newConfig.meteredOverride));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private int getWifiEntryMeteredChoice(WifiConfiguration wifiConfiguration) {
|
||||
switch (wifiConfiguration.meteredOverride) {
|
||||
case WifiConfiguration.METERED_OVERRIDE_METERED:
|
||||
return WifiEntry.METERED_CHOICE_METERED;
|
||||
case WifiConfiguration.METERED_OVERRIDE_NOT_METERED:
|
||||
return WifiEntry.METERED_CHOICE_UNMETERED;
|
||||
default:
|
||||
return WifiEntry.METERED_CHOICE_AUTO;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -17,29 +17,26 @@
|
||||
package com.android.settings.wifi.details2;
|
||||
|
||||
import android.content.Context;
|
||||
import android.net.wifi.WifiConfiguration;
|
||||
import android.net.wifi.WifiManager;
|
||||
|
||||
import androidx.annotation.NonNull;
|
||||
import androidx.annotation.VisibleForTesting;
|
||||
import androidx.preference.ListPreference;
|
||||
import androidx.preference.Preference;
|
||||
import androidx.preference.PreferenceScreen;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settings.wifi.WifiDialog2;
|
||||
import com.android.wifitrackerlib.WifiEntry;
|
||||
|
||||
/**
|
||||
* A controller that controls whether the Wi-Fi network is mac randomized or not.
|
||||
*/
|
||||
public class WifiPrivacyPreferenceController2 extends BasePreferenceController implements
|
||||
Preference.OnPreferenceChangeListener, WifiDialog2.WifiDialog2Listener {
|
||||
Preference.OnPreferenceChangeListener {
|
||||
|
||||
private static final String KEY_WIFI_PRIVACY = "privacy";
|
||||
private final WifiManager mWifiManager;
|
||||
private WifiEntry mWifiEntry;
|
||||
private Preference mPreference;
|
||||
|
||||
public WifiPrivacyPreferenceController2(Context context) {
|
||||
super(context, KEY_WIFI_PRIVACY);
|
||||
@@ -57,12 +54,6 @@ public class WifiPrivacyPreferenceController2 extends BasePreferenceController i
|
||||
? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void displayPreference(PreferenceScreen screen) {
|
||||
super.displayPreference(screen);
|
||||
mPreference = screen.findPreference(getPreferenceKey());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(Preference preference) {
|
||||
final ListPreference listPreference = (ListPreference) preference;
|
||||
@@ -79,7 +70,7 @@ public class WifiPrivacyPreferenceController2 extends BasePreferenceController i
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||
public boolean onPreferenceChange(@NonNull Preference preference, Object newValue) {
|
||||
final int privacy = Integer.parseInt((String) newValue);
|
||||
mWifiEntry.setPrivacy(privacy);
|
||||
|
||||
@@ -128,30 +119,4 @@ public class WifiPrivacyPreferenceController2 extends BasePreferenceController i
|
||||
final int prefMacRandomized = translateMacRandomizedValueToPrefValue(macRandomized);
|
||||
preference.setSummary(preference.getEntries()[prefMacRandomized]);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onSubmit(WifiDialog2 dialog) {
|
||||
if (dialog.getController() != null) {
|
||||
final WifiConfiguration newConfig = dialog.getController().getConfig();
|
||||
if (newConfig == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (getWifiEntryPrivacy(newConfig) != mWifiEntry.getPrivacy()) {
|
||||
mWifiEntry.setPrivacy(getWifiEntryPrivacy(newConfig));
|
||||
onPreferenceChange(mPreference, String.valueOf(newConfig.macRandomizationSetting));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private int getWifiEntryPrivacy(WifiConfiguration wifiConfiguration) {
|
||||
switch (wifiConfiguration.macRandomizationSetting) {
|
||||
case WifiConfiguration.RANDOMIZATION_NONE:
|
||||
return WifiEntry.PRIVACY_DEVICE_MAC;
|
||||
case WifiConfiguration.RANDOMIZATION_PERSISTENT:
|
||||
return WifiEntry.PRIVACY_RANDOMIZED_MAC;
|
||||
default:
|
||||
return WifiEntry.PRIVACY_UNKNOWN;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user