Merge "Use radio button style for single selection" into main
This commit is contained in:
@@ -35,8 +35,8 @@ import com.android.settings.core.BasePreferenceController;
|
|||||||
import com.android.settings.core.SubSettingLauncher;
|
import com.android.settings.core.SubSettingLauncher;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
|
|
||||||
@@ -138,13 +138,13 @@ public class NumberingSystemItemController extends BasePreferenceController {
|
|||||||
for (String localeTag : locales) {
|
for (String localeTag : locales) {
|
||||||
Locale supportedLocale = Locale.forLanguageTag(localeTag);
|
Locale supportedLocale = Locale.forLanguageTag(localeTag);
|
||||||
if (isSameBaseLocale(targetLocale, supportedLocale)) {
|
if (isSameBaseLocale(targetLocale, supportedLocale)) {
|
||||||
TickButtonPreference pref = new TickButtonPreference(mContext);
|
SelectorWithWidgetPreference pref = new SelectorWithWidgetPreference(mContext);
|
||||||
String numberingName = getNumberingSystem(supportedLocale);
|
String numberingName = getNumberingSystem(supportedLocale);
|
||||||
pref.setTitle(numberingName);
|
pref.setTitle(numberingName);
|
||||||
String key = supportedLocale.getUnicodeLocaleType(
|
String key = supportedLocale.getUnicodeLocaleType(
|
||||||
ExtensionTypes.NUMBERING_SYSTEM);
|
ExtensionTypes.NUMBERING_SYSTEM);
|
||||||
pref.setKey(key == null ? RegionalPreferencesDataUtils.DEFAULT_VALUE : key);
|
pref.setKey(key == null ? RegionalPreferencesDataUtils.DEFAULT_VALUE : key);
|
||||||
pref.setSelected(isSameNumberingSystem(targetLocale, supportedLocale));
|
pref.setChecked(isSameNumberingSystem(targetLocale, supportedLocale));
|
||||||
screen.addPreference(pref);
|
screen.addPreference(pref);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -168,11 +168,12 @@ public class NumberingSystemItemController extends BasePreferenceController {
|
|||||||
|
|
||||||
private void handleNumberSystemSelect(Preference preference) {
|
private void handleNumberSystemSelect(Preference preference) {
|
||||||
for (int i = 0; i < mPreferenceScreen.getPreferenceCount(); i++) {
|
for (int i = 0; i < mPreferenceScreen.getPreferenceCount(); i++) {
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceScreen.getPreference(i);
|
SelectorWithWidgetPreference pref =
|
||||||
|
(SelectorWithWidgetPreference) mPreferenceScreen.getPreference(i);
|
||||||
Log.i(TAG, "[onPreferenceClick] key is " + pref.getKey());
|
Log.i(TAG, "[onPreferenceClick] key is " + pref.getKey());
|
||||||
if (pref.getKey().equals(preference.getKey())) {
|
if (pref.getKey().equals(preference.getKey())) {
|
||||||
String numberingSystem = pref.getKey();
|
String numberingSystem = pref.getKey();
|
||||||
pref.setSelected(true);
|
pref.setChecked(true);
|
||||||
Locale updatedLocale =
|
Locale updatedLocale =
|
||||||
saveNumberingSystemToLocale(Locale.forLanguageTag(mSelectedLanguage),
|
saveNumberingSystemToLocale(Locale.forLanguageTag(mSelectedLanguage),
|
||||||
numberingSystem);
|
numberingSystem);
|
||||||
@@ -188,7 +189,7 @@ public class NumberingSystemItemController extends BasePreferenceController {
|
|||||||
mParentFragment.setArguments(bundle);
|
mParentFragment.setArguments(bundle);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
pref.setSelected(false);
|
pref.setChecked(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -24,8 +24,8 @@ import androidx.preference.PreferenceScreen;
|
|||||||
|
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.overlay.FeatureFactory;
|
import com.android.settings.overlay.FeatureFactory;
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
/** A base controller for handling all regional preferences controllers. */
|
/** A base controller for handling all regional preferences controllers. */
|
||||||
public abstract class RegionalPreferenceListBasePreferenceController extends
|
public abstract class RegionalPreferenceListBasePreferenceController extends
|
||||||
@@ -54,15 +54,14 @@ public abstract class RegionalPreferenceListBasePreferenceController extends
|
|||||||
String[] unitValues = getUnitValues();
|
String[] unitValues = getUnitValues();
|
||||||
|
|
||||||
for (int i = 0; i < unitValues.length; i++) {
|
for (int i = 0; i < unitValues.length; i++) {
|
||||||
TickButtonPreference pref = new TickButtonPreference(mContext);
|
SelectorWithWidgetPreference pref = new SelectorWithWidgetPreference(mContext);
|
||||||
mPreferenceCategory.addPreference(pref);
|
mPreferenceCategory.addPreference(pref);
|
||||||
final String item = unitValues[i];
|
final String item = unitValues[i];
|
||||||
final String value = RegionalPreferencesDataUtils.getDefaultUnicodeExtensionData(
|
final String value = RegionalPreferencesDataUtils.getDefaultUnicodeExtensionData(
|
||||||
mContext, getExtensionTypes());
|
mContext, getExtensionTypes());
|
||||||
pref.setTitle(getPreferenceTitle(item));
|
pref.setTitle(getPreferenceTitle(item));
|
||||||
pref.setKey(item);
|
pref.setKey(item);
|
||||||
pref.setOnPreferenceClickListener(clickedPref -> {
|
pref.setOnClickListener(v -> {
|
||||||
setSelected(pref);
|
|
||||||
RegionalPreferencesDataUtils.savePreference(mContext, getExtensionTypes(),
|
RegionalPreferencesDataUtils.savePreference(mContext, getExtensionTypes(),
|
||||||
item.equals(RegionalPreferencesDataUtils.DEFAULT_VALUE)
|
item.equals(RegionalPreferencesDataUtils.DEFAULT_VALUE)
|
||||||
? null : item);
|
? null : item);
|
||||||
@@ -70,20 +69,8 @@ public abstract class RegionalPreferenceListBasePreferenceController extends
|
|||||||
getMetricsActionKey() == SettingsEnums.ACTION_SET_FIRST_DAY_OF_WEEK ? ""
|
getMetricsActionKey() == SettingsEnums.ACTION_SET_FIRST_DAY_OF_WEEK ? ""
|
||||||
: getPreferenceTitle(value) + " > " + getPreferenceTitle(item);
|
: getPreferenceTitle(value) + " > " + getPreferenceTitle(item);
|
||||||
mMetricsFeatureProvider.action(mContext, getMetricsActionKey(), metrics);
|
mMetricsFeatureProvider.action(mContext, getMetricsActionKey(), metrics);
|
||||||
return true;
|
|
||||||
});
|
});
|
||||||
pref.setSelected(!value.isEmpty() && item.equals(value));
|
pref.setChecked(!value.isEmpty() && item.equals(value));
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setSelected(TickButtonPreference preference) {
|
|
||||||
for (int i = 0; i < mPreferenceCategory.getPreferenceCount(); i++) {
|
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceCategory.getPreference(i);
|
|
||||||
if (pref.getKey().equals(preference.getKey())) {
|
|
||||||
pref.setSelected(true);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
pref.setSelected(false);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -25,16 +25,15 @@ import android.os.LocaleList;
|
|||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import com.android.internal.app.LocalePicker;
|
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceCategory;
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
|
import com.android.internal.app.LocalePicker;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -91,8 +90,9 @@ public class FirstDayOfWeekItemListControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_setSelectPreferredFirstDayOfWeekIsDefault() {
|
public void displayPreference_setSelectPreferredFirstDayOfWeekIsDefault() {
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceCategory.getPreference(0);
|
SelectorWithWidgetPreference pref =
|
||||||
pref.performClick();
|
(SelectorWithWidgetPreference) mPreferenceCategory.getPreference(0);
|
||||||
|
pref.onClick();
|
||||||
String record = Settings.System.getString(
|
String record = Settings.System.getString(
|
||||||
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
||||||
|
|
||||||
@@ -103,8 +103,9 @@ public class FirstDayOfWeekItemListControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_setSelectPreferredFirstDayOfWeekIsSunday() {
|
public void displayPreference_setSelectPreferredFirstDayOfWeekIsSunday() {
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceCategory.getPreference(1);
|
SelectorWithWidgetPreference pref =
|
||||||
pref.performClick();
|
(SelectorWithWidgetPreference) mPreferenceCategory.getPreference(1);
|
||||||
|
pref.onClick();
|
||||||
String record = Settings.System.getString(
|
String record = Settings.System.getString(
|
||||||
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
||||||
|
|
||||||
@@ -114,8 +115,9 @@ public class FirstDayOfWeekItemListControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_setSelectPreferredFirstDayOfWeekIsMonday() {
|
public void displayPreference_setSelectPreferredFirstDayOfWeekIsMonday() {
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceCategory.getPreference(2);
|
SelectorWithWidgetPreference pref =
|
||||||
pref.performClick();
|
(SelectorWithWidgetPreference) mPreferenceCategory.getPreference(2);
|
||||||
|
pref.onClick();
|
||||||
String record = Settings.System.getString(
|
String record = Settings.System.getString(
|
||||||
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
||||||
|
|
||||||
|
@@ -38,7 +38,7 @@ import androidx.test.core.app.ApplicationProvider;
|
|||||||
|
|
||||||
import com.android.internal.app.LocalePicker;
|
import com.android.internal.app.LocalePicker;
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
import com.android.settings.testutils.FakeFeatureFactory;
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -82,7 +82,8 @@ public class NumberingSystemItemControllerTest {
|
|||||||
NumberingSystemItemController.ARG_VALUE_LANGUAGE_SELECT);
|
NumberingSystemItemController.ARG_VALUE_LANGUAGE_SELECT);
|
||||||
bundle.putString(
|
bundle.putString(
|
||||||
NumberingSystemItemController.KEY_SELECTED_LANGUAGE, Locale.US.toLanguageTag());
|
NumberingSystemItemController.KEY_SELECTED_LANGUAGE, Locale.US.toLanguageTag());
|
||||||
TickButtonPreference preference = new TickButtonPreference(mApplicationContext);
|
SelectorWithWidgetPreference preference =
|
||||||
|
new SelectorWithWidgetPreference(mApplicationContext);
|
||||||
preference.setKey("I_am_the_key");
|
preference.setKey("I_am_the_key");
|
||||||
mPreferenceScreen.addPreference(preference);
|
mPreferenceScreen.addPreference(preference);
|
||||||
mController = new NumberingSystemItemController(mApplicationContext, bundle);
|
mController = new NumberingSystemItemController(mApplicationContext, bundle);
|
||||||
@@ -110,7 +111,8 @@ public class NumberingSystemItemControllerTest {
|
|||||||
NumberingSystemItemController.ARG_VALUE_NUMBERING_SYSTEM_SELECT);
|
NumberingSystemItemController.ARG_VALUE_NUMBERING_SYSTEM_SELECT);
|
||||||
bundle.putString(
|
bundle.putString(
|
||||||
NumberingSystemItemController.KEY_SELECTED_LANGUAGE, Locale.US.toLanguageTag());
|
NumberingSystemItemController.KEY_SELECTED_LANGUAGE, Locale.US.toLanguageTag());
|
||||||
TickButtonPreference preference = new TickButtonPreference(mApplicationContext);
|
SelectorWithWidgetPreference preference =
|
||||||
|
new SelectorWithWidgetPreference(mApplicationContext);
|
||||||
preference.setKey("test_key");
|
preference.setKey("test_key");
|
||||||
mPreferenceScreen.addPreference(preference);
|
mPreferenceScreen.addPreference(preference);
|
||||||
mController = new NumberingSystemItemController(mApplicationContext, bundle);
|
mController = new NumberingSystemItemController(mApplicationContext, bundle);
|
||||||
@@ -133,8 +135,10 @@ public class NumberingSystemItemControllerTest {
|
|||||||
NumberingSystemItemController.ARG_VALUE_NUMBERING_SYSTEM_SELECT);
|
NumberingSystemItemController.ARG_VALUE_NUMBERING_SYSTEM_SELECT);
|
||||||
bundle.putString(
|
bundle.putString(
|
||||||
NumberingSystemItemController.KEY_SELECTED_LANGUAGE, "ar-BH");
|
NumberingSystemItemController.KEY_SELECTED_LANGUAGE, "ar-BH");
|
||||||
TickButtonPreference defaultPreference = new TickButtonPreference(mApplicationContext);
|
SelectorWithWidgetPreference defaultPreference =
|
||||||
TickButtonPreference numberPreference = new TickButtonPreference(mApplicationContext);
|
new SelectorWithWidgetPreference(mApplicationContext);
|
||||||
|
SelectorWithWidgetPreference numberPreference =
|
||||||
|
new SelectorWithWidgetPreference(mApplicationContext);
|
||||||
defaultPreference.setKey("default");
|
defaultPreference.setKey("default");
|
||||||
numberPreference.setKey("latn");
|
numberPreference.setKey("latn");
|
||||||
mPreferenceScreen.addPreference(defaultPreference);
|
mPreferenceScreen.addPreference(defaultPreference);
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
package com.android.settings.regionalpreferences;
|
package com.android.settings.regionalpreferences;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -24,16 +25,15 @@ import android.os.LocaleList;
|
|||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import com.android.internal.app.LocalePicker;
|
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceCategory;
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
|
import com.android.internal.app.LocalePicker;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -88,8 +88,9 @@ public class TemperatureUnitListControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_setSelectPreferredTemperatureUnitIsDefault() {
|
public void displayPreference_setSelectPreferredTemperatureUnitIsDefault() {
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceCategory.getPreference(0);
|
SelectorWithWidgetPreference pref =
|
||||||
pref.performClick();
|
(SelectorWithWidgetPreference) mPreferenceCategory.getPreference(0);
|
||||||
|
pref.onClick();
|
||||||
String record = Settings.System.getString(
|
String record = Settings.System.getString(
|
||||||
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
||||||
|
|
||||||
@@ -101,8 +102,9 @@ public class TemperatureUnitListControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_setSelectPreferredTemperatureUnitIsCelsius() {
|
public void displayPreference_setSelectPreferredTemperatureUnitIsCelsius() {
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceCategory.getPreference(1);
|
SelectorWithWidgetPreference pref =
|
||||||
pref.performClick();
|
(SelectorWithWidgetPreference) mPreferenceCategory.getPreference(1);
|
||||||
|
pref.onClick();
|
||||||
String record = Settings.System.getString(
|
String record = Settings.System.getString(
|
||||||
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
||||||
|
|
||||||
@@ -112,8 +114,9 @@ public class TemperatureUnitListControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_setSelectPreferredTemperatureUnitIsFahrenhe() {
|
public void displayPreference_setSelectPreferredTemperatureUnitIsFahrenhe() {
|
||||||
TickButtonPreference pref = (TickButtonPreference) mPreferenceCategory.getPreference(2);
|
SelectorWithWidgetPreference pref =
|
||||||
pref.performClick();
|
(SelectorWithWidgetPreference) mPreferenceCategory.getPreference(2);
|
||||||
|
pref.onClick();
|
||||||
String record = Settings.System.getString(
|
String record = Settings.System.getString(
|
||||||
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
mContext.getContentResolver(), Settings.System.LOCALE_PREFERENCES);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user