Snap for 12860712 from 3b6a8f9ba4 to 25Q2-release
Change-Id: I4a8b92c108ddd0782d6afc35e292e81788dd405f
This commit is contained in:
@@ -446,6 +446,9 @@
|
|||||||
<!-- Category for the locale picker. [CHAR LIMIT=50]-->
|
<!-- Category for the locale picker. [CHAR LIMIT=50]-->
|
||||||
<string name="all_supported_locales_title">All languages</string>
|
<string name="all_supported_locales_title">All languages</string>
|
||||||
|
|
||||||
|
<!-- Category for the app locale picker. [CHAR LIMIT=50]-->
|
||||||
|
<string name="more_supported_locales_title">More languages</string>
|
||||||
|
|
||||||
<!-- Category for the locale region picker. [CHAR LIMIT=50]-->
|
<!-- Category for the locale region picker. [CHAR LIMIT=50]-->
|
||||||
<string name="all_supported_locales_regions_title">All regions</string>
|
<string name="all_supported_locales_regions_title">All regions</string>
|
||||||
|
|
||||||
@@ -508,12 +511,20 @@
|
|||||||
|
|
||||||
<!-- Menu item in the locale menu [CHAR LIMIT=30] -->
|
<!-- Menu item in the locale menu [CHAR LIMIT=30] -->
|
||||||
<string name="locale_search_menu">Search</string>
|
<string name="locale_search_menu">Search</string>
|
||||||
|
<!-- Title for the language and region selection screen [CHAR LIMIT=25] -->
|
||||||
|
<string name="language_and_region_title">Language & region</string>
|
||||||
<!-- Title for the language selection screen [CHAR LIMIT=25] -->
|
<!-- Title for the language selection screen [CHAR LIMIT=25] -->
|
||||||
<string name="language_selection_title">Add a language</string>
|
<string name="language_selection_title">Add a language</string>
|
||||||
|
<!-- Title for the region picker [CHAR LIMIT=25] -->
|
||||||
|
<string name="region_selection_title">Choose a region</string>
|
||||||
<!-- Title for the region selection screen [CHAR LIMIT=25] -->
|
<!-- Title for the region selection screen [CHAR LIMIT=25] -->
|
||||||
<string name="country_selection_title">Region preference</string>
|
<string name="country_selection_title">Region preference</string>
|
||||||
<!-- Hint text in a search edit box (used to filter long language / country lists) [CHAR LIMIT=25] -->
|
<!-- Hint text in a search edit box (used to filter long language / country lists) [CHAR LIMIT=25] -->
|
||||||
<string name="search_language_hint">Type language name</string>
|
<string name="search_language_hint">Search languages</string>
|
||||||
|
<!-- Hint text in a search edit box (used to filter long region) [CHAR LIMIT=25] -->
|
||||||
|
<string name="search_region_hint">Search regions</string>
|
||||||
|
<!-- The title for Choose a region page -->
|
||||||
|
<string name="top_intro_region_title">The region you choose affects how your phone displays time, dates, temperature, and more</string>
|
||||||
<!-- Category for more language settings. [CHAR LIMIT=NONE]-->
|
<!-- Category for more language settings. [CHAR LIMIT=NONE]-->
|
||||||
<string name="more_language_settings_category">More language settings</string>
|
<string name="more_language_settings_category">More language settings</string>
|
||||||
|
|
||||||
|
|||||||
@@ -16,9 +16,15 @@
|
|||||||
|
|
||||||
<PreferenceScreen
|
<PreferenceScreen
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:settings="http://schemas.android.com/apk/res-auto"
|
||||||
android:title="@string/language_selection_title"
|
android:title="@string/language_selection_title"
|
||||||
android:key="key_system_language_picker_page">
|
android:key="key_system_language_picker_page">
|
||||||
|
|
||||||
|
<com.android.settingslib.widget.TopIntroPreference
|
||||||
|
android:key="top_intro_region"
|
||||||
|
android:title="@string/top_intro_region_title"
|
||||||
|
settings:isPreferenceVisible="false"/>
|
||||||
|
|
||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:key="system_language_suggested_category"
|
android:key="system_language_suggested_category"
|
||||||
android:title="@string/suggested_locales_title"/>
|
android:title="@string/suggested_locales_title"/>
|
||||||
|
|||||||
@@ -48,9 +48,13 @@ class VibrationMainSwitchPreference :
|
|||||||
override fun storage(context: Context): KeyValueStore =
|
override fun storage(context: Context): KeyValueStore =
|
||||||
VibrationMainSwitchToggleStorage(SettingsSystemStore.get(context))
|
VibrationMainSwitchToggleStorage(SettingsSystemStore.get(context))
|
||||||
|
|
||||||
|
override fun getReadPermissions(context: Context) = SettingsSystemStore.getReadPermissions()
|
||||||
|
|
||||||
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
||||||
ReadWritePermit.ALLOW
|
ReadWritePermit.ALLOW
|
||||||
|
|
||||||
|
override fun getWritePermissions(context: Context) = SettingsSystemStore.getWritePermissions()
|
||||||
|
|
||||||
override fun getWritePermit(
|
override fun getWritePermit(
|
||||||
context: Context,
|
context: Context,
|
||||||
value: Boolean?,
|
value: Boolean?,
|
||||||
|
|||||||
@@ -42,19 +42,22 @@ import com.android.settingslib.datastore.SettingsSystemStore
|
|||||||
import com.android.settingslib.display.BrightnessUtils.GAMMA_SPACE_MAX
|
import com.android.settingslib.display.BrightnessUtils.GAMMA_SPACE_MAX
|
||||||
import com.android.settingslib.display.BrightnessUtils.GAMMA_SPACE_MIN
|
import com.android.settingslib.display.BrightnessUtils.GAMMA_SPACE_MIN
|
||||||
import com.android.settingslib.display.BrightnessUtils.convertLinearToGammaFloat
|
import com.android.settingslib.display.BrightnessUtils.convertLinearToGammaFloat
|
||||||
import com.android.settingslib.metadata.FloatPersistentPreference
|
import com.android.settingslib.metadata.PersistentPreference
|
||||||
import com.android.settingslib.metadata.PreferenceMetadata
|
import com.android.settingslib.metadata.PreferenceMetadata
|
||||||
import com.android.settingslib.metadata.PreferenceSummaryProvider
|
import com.android.settingslib.metadata.PreferenceSummaryProvider
|
||||||
|
import com.android.settingslib.metadata.RangeValue
|
||||||
import com.android.settingslib.metadata.ReadWritePermit
|
import com.android.settingslib.metadata.ReadWritePermit
|
||||||
import com.android.settingslib.metadata.SensitivityLevel
|
import com.android.settingslib.metadata.SensitivityLevel
|
||||||
import com.android.settingslib.preference.PreferenceBinding
|
import com.android.settingslib.preference.PreferenceBinding
|
||||||
import com.android.settingslib.transition.SettingsTransitionHelper
|
import com.android.settingslib.transition.SettingsTransitionHelper
|
||||||
|
import java.math.BigDecimal
|
||||||
import java.text.NumberFormat
|
import java.text.NumberFormat
|
||||||
|
|
||||||
// LINT.IfChange
|
// LINT.IfChange
|
||||||
class BrightnessLevelPreference :
|
class BrightnessLevelPreference :
|
||||||
PreferenceMetadata,
|
PreferenceMetadata,
|
||||||
FloatPersistentPreference,
|
PersistentPreference<Int>,
|
||||||
|
RangeValue,
|
||||||
PreferenceBinding,
|
PreferenceBinding,
|
||||||
PreferenceRestrictionMixin,
|
PreferenceRestrictionMixin,
|
||||||
PreferenceSummaryProvider,
|
PreferenceSummaryProvider,
|
||||||
@@ -70,7 +73,7 @@ class BrightnessLevelPreference :
|
|||||||
get() = R.string.keywords_display_brightness_level
|
get() = R.string.keywords_display_brightness_level
|
||||||
|
|
||||||
override fun getSummary(context: Context): CharSequence? =
|
override fun getSummary(context: Context): CharSequence? =
|
||||||
NumberFormat.getPercentInstance().format(context.brightness)
|
NumberFormat.getPercentInstance().format(context.brightnessPercent)
|
||||||
|
|
||||||
override fun isEnabled(context: Context) = super<PreferenceRestrictionMixin>.isEnabled(context)
|
override fun isEnabled(context: Context) = super<PreferenceRestrictionMixin>.isEnabled(context)
|
||||||
|
|
||||||
@@ -105,7 +108,7 @@ class BrightnessLevelPreference :
|
|||||||
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
override fun getReadPermit(context: Context, callingPid: Int, callingUid: Int) =
|
||||||
ReadWritePermit.ALLOW
|
ReadWritePermit.ALLOW
|
||||||
|
|
||||||
override fun getWritePermit(context: Context, value: Float?, callingPid: Int, callingUid: Int) =
|
override fun getWritePermit(context: Context, value: Int?, callingPid: Int, callingUid: Int) =
|
||||||
ReadWritePermit.DISALLOW
|
ReadWritePermit.DISALLOW
|
||||||
|
|
||||||
override val sensitivityLevel
|
override val sensitivityLevel
|
||||||
@@ -113,6 +116,10 @@ class BrightnessLevelPreference :
|
|||||||
|
|
||||||
override fun storage(context: Context): KeyValueStore = BrightnessStorage(context)
|
override fun storage(context: Context): KeyValueStore = BrightnessStorage(context)
|
||||||
|
|
||||||
|
override fun getMinValue(context: Context) = 0
|
||||||
|
|
||||||
|
override fun getMaxValue(context: Context) = 100
|
||||||
|
|
||||||
private class BrightnessStorage(private val context: Context) :
|
private class BrightnessStorage(private val context: Context) :
|
||||||
AbstractKeyedDataObservable<String>(),
|
AbstractKeyedDataObservable<String>(),
|
||||||
KeyValueStore,
|
KeyValueStore,
|
||||||
@@ -123,7 +130,9 @@ class BrightnessLevelPreference :
|
|||||||
|
|
||||||
@Suppress("UNCHECKED_CAST")
|
@Suppress("UNCHECKED_CAST")
|
||||||
override fun <T : Any> getValue(key: String, valueType: Class<T>) =
|
override fun <T : Any> getValue(key: String, valueType: Class<T>) =
|
||||||
context.brightness.toFloat() as T
|
BigDecimal(context.brightnessPercent * 100)
|
||||||
|
.setScale(0, NumberFormat.getPercentInstance().roundingMode)
|
||||||
|
.toInt() as T
|
||||||
|
|
||||||
override fun <T : Any> setValue(key: String, valueType: Class<T>, value: T?) {}
|
override fun <T : Any> setValue(key: String, valueType: Class<T>, value: T?) {}
|
||||||
|
|
||||||
@@ -134,7 +143,7 @@ class BrightnessLevelPreference :
|
|||||||
context.displayManager.registerDisplayListener(
|
context.displayManager.registerDisplayListener(
|
||||||
this,
|
this,
|
||||||
HandlerExecutor.main,
|
HandlerExecutor.main,
|
||||||
/* eventFlags= */ 0,
|
/* eventFilter= */ 0,
|
||||||
DisplayManager.PRIVATE_EVENT_TYPE_DISPLAY_BRIGHTNESS,
|
DisplayManager.PRIVATE_EVENT_TYPE_DISPLAY_BRIGHTNESS,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
@@ -176,21 +185,20 @@ class BrightnessLevelPreference :
|
|||||||
private val Context.displayManager: DisplayManager
|
private val Context.displayManager: DisplayManager
|
||||||
get() = getSystemService(DisplayManager::class.java)!!
|
get() = getSystemService(DisplayManager::class.java)!!
|
||||||
|
|
||||||
private val Context.brightness: Double
|
private val Context.brightnessPercent: Double
|
||||||
get() {
|
get() {
|
||||||
val info: BrightnessInfo? = display.brightnessInfo
|
val info: BrightnessInfo = display.brightnessInfo ?: return 0.0
|
||||||
val value =
|
return info.brightnessInGammaSpace.toPercentage()
|
||||||
info?.run {
|
|
||||||
convertLinearToGammaFloat(brightness, brightnessMinimum, brightnessMaximum)
|
|
||||||
}
|
|
||||||
return getPercentage(value?.toDouble() ?: 0.0)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getPercentage(value: Double): Double =
|
private val BrightnessInfo.brightnessInGammaSpace: Int
|
||||||
|
get() = convertLinearToGammaFloat(brightness, brightnessMinimum, brightnessMaximum)
|
||||||
|
|
||||||
|
private fun Int.toPercentage(): Double =
|
||||||
when {
|
when {
|
||||||
value > GAMMA_SPACE_MAX -> 1.0
|
this > GAMMA_SPACE_MAX -> 1.0
|
||||||
value < GAMMA_SPACE_MIN -> 0.0
|
this < GAMMA_SPACE_MIN -> 0.0
|
||||||
else -> (value - GAMMA_SPACE_MIN) / (GAMMA_SPACE_MAX - GAMMA_SPACE_MIN)
|
else -> (this - GAMMA_SPACE_MIN).toDouble() / (GAMMA_SPACE_MAX - GAMMA_SPACE_MIN)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,6 +16,7 @@
|
|||||||
package com.android.settings.localepicker;
|
package com.android.settings.localepicker;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
|
||||||
import com.android.internal.app.LocaleStore;
|
import com.android.internal.app.LocaleStore;
|
||||||
|
|
||||||
@@ -25,5 +26,6 @@ import java.util.List;
|
|||||||
public interface LocaleListSearchCallback {
|
public interface LocaleListSearchCallback {
|
||||||
|
|
||||||
/** Callback method for searching changes. */
|
/** Callback method for searching changes. */
|
||||||
void onSearchListChanged(@NonNull List<LocaleStore.LocaleInfo> localeInfoList);
|
void onSearchListChanged(@NonNull List<LocaleStore.LocaleInfo> localeInfoList,
|
||||||
|
@Nullable CharSequence prefix);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -60,7 +60,9 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
private Map<String, Preference> mPreferences;
|
private Map<String, Preference> mPreferences;
|
||||||
private String mPackageName;
|
private String mPackageName;
|
||||||
private boolean mIsCountryMode;
|
private boolean mIsCountryMode;
|
||||||
@Nullable private LocaleStore.LocaleInfo mParentLocale;
|
@Nullable
|
||||||
|
private LocaleStore.LocaleInfo mParentLocale;
|
||||||
|
private boolean mIsSuggestedCategory;
|
||||||
|
|
||||||
public LocalePickerBaseListPreferenceController(@NonNull Context context,
|
public LocalePickerBaseListPreferenceController(@NonNull Context context,
|
||||||
@NonNull String preferenceKey) {
|
@NonNull String preferenceKey) {
|
||||||
@@ -75,6 +77,7 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
public void displayPreference(@NonNull PreferenceScreen screen) {
|
public void displayPreference(@NonNull PreferenceScreen screen) {
|
||||||
super.displayPreference(screen);
|
super.displayPreference(screen);
|
||||||
mPreferenceCategory = screen.findPreference(getPreferenceCategoryKey());
|
mPreferenceCategory = screen.findPreference(getPreferenceCategoryKey());
|
||||||
|
mIsSuggestedCategory = getPreferenceCategoryKey().contains(KEY_SUGGESTED);
|
||||||
updatePreferences();
|
updatePreferences();
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -88,17 +91,13 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
mParentLocale = getParentLocale();
|
mParentLocale = getParentLocale();
|
||||||
if (mParentLocale != null) {
|
if (mParentLocale != null) {
|
||||||
mIsCountryMode = true;
|
mIsCountryMode = true;
|
||||||
mLocaleList = getLocaleCollectorController(mContext).getSupportedLocaleList(
|
if (!mIsSuggestedCategory) {
|
||||||
mParentLocale, false, mIsCountryMode);
|
|
||||||
mLocaleOptions = new ArrayList<>(mLocaleList.size());
|
|
||||||
if (!getPreferenceCategoryKey().contains(KEY_SUGGESTED)) {
|
|
||||||
mPreferenceCategory.setTitle(
|
mPreferenceCategory.setTitle(
|
||||||
mContext.getString(R.string.all_supported_locales_regions_title));
|
mContext.getString(R.string.all_supported_locales_regions_title));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
result = getSortedLocaleList(
|
result = getSortedLocaleList(mIsSuggestedCategory
|
||||||
getPreferenceCategoryKey().contains(KEY_SUGGESTED)
|
|
||||||
? getSuggestedLocaleList()
|
? getSuggestedLocaleList()
|
||||||
: getSupportedLocaleList());
|
: getSupportedLocaleList());
|
||||||
|
|
||||||
@@ -112,13 +111,17 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSearchListChanged(@NonNull List<LocaleStore.LocaleInfo> newList) {
|
public void onSearchListChanged(@NonNull List<LocaleStore.LocaleInfo> newList,
|
||||||
|
@Nullable CharSequence prefix) {
|
||||||
mPreferenceCategory.removeAll();
|
mPreferenceCategory.removeAll();
|
||||||
mPreferences.clear();
|
mPreferences.clear();
|
||||||
final Map<String, Preference> existingPreferences = mPreferences;
|
final Map<String, Preference> existingPreferences = mPreferences;
|
||||||
if (getPreferenceCategoryKey().contains(KEY_SUGGESTED)) {
|
|
||||||
newList = getSortedSuggestedLocaleFromSearchList(
|
List<LocaleStore.LocaleInfo> sortedList =
|
||||||
newList, getSuggestedLocaleList());
|
mIsSuggestedCategory ? getSuggestedLocaleList() : getSupportedLocaleList();
|
||||||
|
newList = getSortedSuggestedLocaleFromSearchList(newList, sortedList);
|
||||||
|
if (mIsSuggestedCategory && getParentLocale() != null) {
|
||||||
|
newList = getSortedSuggestedRegionFromSearchList(prefix, newList, sortedList);
|
||||||
}
|
}
|
||||||
setupPreference(newList, existingPreferences);
|
setupPreference(newList, existingPreferences);
|
||||||
}
|
}
|
||||||
@@ -138,6 +141,23 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
return searchItem;
|
return searchItem;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private List<LocaleStore.LocaleInfo> getSortedSuggestedRegionFromSearchList(
|
||||||
|
@Nullable CharSequence prefix,
|
||||||
|
List<LocaleStore.LocaleInfo> listOptions,
|
||||||
|
List<LocaleStore.LocaleInfo> listSuggested) {
|
||||||
|
List<LocaleStore.LocaleInfo> searchItem = new ArrayList<>();
|
||||||
|
if (prefix == null || prefix.isEmpty()) {
|
||||||
|
return getSortedLocaleList(listSuggested);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (LocaleStore.LocaleInfo option : listOptions) {
|
||||||
|
if (listSuggested.contains(option)) {
|
||||||
|
searchItem.add(option);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return getSortedLocaleList(searchItem);
|
||||||
|
}
|
||||||
|
|
||||||
private void setupPreference(List<LocaleStore.LocaleInfo> localeInfoList,
|
private void setupPreference(List<LocaleStore.LocaleInfo> localeInfoList,
|
||||||
Map<String, Preference> existingPreferences) {
|
Map<String, Preference> existingPreferences) {
|
||||||
Log.d(TAG, "setupPreference: isNumberingMode = " + isNumberingMode());
|
Log.d(TAG, "setupPreference: isNumberingMode = " + isNumberingMode());
|
||||||
@@ -175,18 +195,20 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
|
|
||||||
protected abstract LocaleCollectorBase getLocaleCollectorController(Context context);
|
protected abstract LocaleCollectorBase getLocaleCollectorController(Context context);
|
||||||
|
|
||||||
@Nullable protected abstract LocaleStore.LocaleInfo getParentLocale();
|
@Nullable
|
||||||
|
protected abstract LocaleStore.LocaleInfo getParentLocale();
|
||||||
|
|
||||||
protected abstract boolean isNumberingMode();
|
protected abstract boolean isNumberingMode();
|
||||||
|
|
||||||
@Nullable protected abstract LocaleList getExplicitLocaleList();
|
@Nullable
|
||||||
|
protected abstract LocaleList getExplicitLocaleList();
|
||||||
|
|
||||||
protected String getPackageName() {
|
protected String getPackageName() {
|
||||||
return mPackageName;
|
return mPackageName;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected List<LocaleStore.LocaleInfo> getSuggestedLocaleList() {
|
protected List<LocaleStore.LocaleInfo> getSuggestedLocaleList() {
|
||||||
mLocaleOptions.clear();
|
setupLocaleList();
|
||||||
if (mLocaleList != null && !mLocaleList.isEmpty()) {
|
if (mLocaleList != null && !mLocaleList.isEmpty()) {
|
||||||
mLocaleOptions.addAll(mLocaleList.stream()
|
mLocaleOptions.addAll(mLocaleList.stream()
|
||||||
.filter(localeInfo -> localeInfo.isSuggested())
|
.filter(localeInfo -> localeInfo.isSuggested())
|
||||||
@@ -199,6 +221,7 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected List<LocaleStore.LocaleInfo> getSupportedLocaleList() {
|
protected List<LocaleStore.LocaleInfo> getSupportedLocaleList() {
|
||||||
|
setupLocaleList();
|
||||||
if (mLocaleList != null && !mLocaleList.isEmpty()) {
|
if (mLocaleList != null && !mLocaleList.isEmpty()) {
|
||||||
mLocaleOptions.addAll(mLocaleList.stream()
|
mLocaleOptions.addAll(mLocaleList.stream()
|
||||||
.filter(localeInfo -> !localeInfo.isSuggested())
|
.filter(localeInfo -> !localeInfo.isSuggested())
|
||||||
@@ -206,10 +229,15 @@ public abstract class LocalePickerBaseListPreferenceController extends
|
|||||||
} else {
|
} else {
|
||||||
Log.d(TAG, "Can not get supported locales because the locale list is null or empty.");
|
Log.d(TAG, "Can not get supported locales because the locale list is null or empty.");
|
||||||
}
|
}
|
||||||
|
|
||||||
return mLocaleOptions;
|
return mLocaleOptions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void setupLocaleList() {
|
||||||
|
mLocaleList = getLocaleCollectorController(mContext).getSupportedLocaleList(
|
||||||
|
mParentLocale, false, mIsCountryMode);
|
||||||
|
mLocaleOptions.clear();
|
||||||
|
}
|
||||||
|
|
||||||
private List<LocaleStore.LocaleInfo> getSortedLocaleList(
|
private List<LocaleStore.LocaleInfo> getSortedLocaleList(
|
||||||
List<LocaleStore.LocaleInfo> localeInfos) {
|
List<LocaleStore.LocaleInfo> localeInfos) {
|
||||||
final Locale sortingLocale = Locale.getDefault();
|
final Locale sortingLocale = Locale.getDefault();
|
||||||
|
|||||||
@@ -19,33 +19,39 @@ package com.android.settings.localepicker;
|
|||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.Menu;
|
||||||
|
import android.view.MenuInflater;
|
||||||
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.Filter;
|
||||||
|
import android.widget.SearchView;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.core.view.ViewCompat;
|
||||||
import androidx.preference.PreferenceCategory;
|
import androidx.preference.PreferenceCategory;
|
||||||
import androidx.recyclerview.widget.RecyclerView;
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
|
||||||
import com.android.internal.app.LocaleHelper;
|
import com.android.internal.app.LocaleHelper;
|
||||||
import com.android.internal.app.LocaleStore;
|
import com.android.internal.app.LocaleStore;
|
||||||
import com.android.internal.app.SystemLocaleCollector;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.search.BaseSearchIndexProvider;
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
import com.android.settings.widget.PreferenceCategoryController;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
import com.android.settingslib.widget.TopIntroPreference;
|
||||||
|
|
||||||
import com.google.android.material.appbar.AppBarLayout;
|
import com.google.android.material.appbar.AppBarLayout;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Set;
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A locale picker fragment to show region country and numbering system.
|
* A locale picker fragment to show region country and numbering system.
|
||||||
@@ -54,7 +60,8 @@ import java.util.Set;
|
|||||||
* Allows the user to search for locales using both their native name and their name in the
|
* Allows the user to search for locales using both their native name and their name in the
|
||||||
* default locale.</p>
|
* default locale.</p>
|
||||||
*/
|
*/
|
||||||
public class RegionAndNumberingSystemPickerFragment extends DashboardFragment {
|
public class RegionAndNumberingSystemPickerFragment extends DashboardFragment implements
|
||||||
|
SearchView.OnQueryTextListener, MenuItem.OnActionExpandListener {
|
||||||
|
|
||||||
public static final String EXTRA_TARGET_LOCALE = "extra_target_locale";
|
public static final String EXTRA_TARGET_LOCALE = "extra_target_locale";
|
||||||
public static final String EXTRA_IS_NUMBERING_SYSTEM = "extra_is_numbering_system";
|
public static final String EXTRA_IS_NUMBERING_SYSTEM = "extra_is_numbering_system";
|
||||||
@@ -63,17 +70,30 @@ public class RegionAndNumberingSystemPickerFragment extends DashboardFragment {
|
|||||||
private static final String KEY_PREFERENCE_SYSTEM_LOCALE_LIST = "system_locale_list";
|
private static final String KEY_PREFERENCE_SYSTEM_LOCALE_LIST = "system_locale_list";
|
||||||
private static final String KEY_PREFERENCE_SYSTEM_LOCALE_SUGGESTED_LIST =
|
private static final String KEY_PREFERENCE_SYSTEM_LOCALE_SUGGESTED_LIST =
|
||||||
"system_locale_suggested_list";
|
"system_locale_suggested_list";
|
||||||
|
private static final String KEY_TOP_INTRO_PREFERENCE = "top_intro_region";
|
||||||
|
private static final String EXTRA_EXPAND_SEARCH_VIEW = "expand_search_view";
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private SystemLocaleAllListPreferenceController mSystemLocaleAllListPreferenceController;
|
private SearchView mSearchView = null;
|
||||||
@Nullable
|
@Nullable
|
||||||
|
private SearchFilter mSearchFilter = null;
|
||||||
|
@SuppressWarnings("NullAway")
|
||||||
|
private SystemLocaleAllListPreferenceController mSystemLocaleAllListPreferenceController;
|
||||||
|
@SuppressWarnings("NullAway")
|
||||||
private SystemLocaleSuggestedListPreferenceController mSuggestedListPreferenceController;
|
private SystemLocaleSuggestedListPreferenceController mSuggestedListPreferenceController;
|
||||||
@Nullable
|
@Nullable
|
||||||
private LocaleStore.LocaleInfo mLocaleInfo;
|
private LocaleStore.LocaleInfo mLocaleInfo;
|
||||||
private RecyclerView mRecyclerView;
|
@Nullable
|
||||||
|
private List<LocaleStore.LocaleInfo> mLocaleOptions;
|
||||||
|
@SuppressWarnings("NullAway")
|
||||||
|
private List<LocaleStore.LocaleInfo> mOriginalLocaleInfos;
|
||||||
private AppBarLayout mAppBarLayout;
|
private AppBarLayout mAppBarLayout;
|
||||||
|
private RecyclerView mRecyclerView;
|
||||||
private Activity mActivity;
|
private Activity mActivity;
|
||||||
|
private boolean mExpandSearch;
|
||||||
private boolean mIsNumberingMode;
|
private boolean mIsNumberingMode;
|
||||||
|
@Nullable
|
||||||
|
private CharSequence mPrefix;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(@NonNull Bundle icicle) {
|
public void onCreate(@NonNull Bundle icicle) {
|
||||||
@@ -83,13 +103,27 @@ public class RegionAndNumberingSystemPickerFragment extends DashboardFragment {
|
|||||||
Log.d(TAG, "onCreate, no activity or activity is finishing");
|
Log.d(TAG, "onCreate, no activity or activity is finishing");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
setHasOptionsMenu(true);
|
||||||
|
|
||||||
if (mLocaleInfo == null) {
|
mExpandSearch = mActivity.getIntent().getBooleanExtra(EXTRA_EXPAND_SEARCH_VIEW, false);
|
||||||
Log.d(TAG, "onCreate, can not get localeInfo");
|
if (icicle != null) {
|
||||||
return;
|
mExpandSearch = icicle.getBoolean(EXTRA_EXPAND_SEARCH_VIEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
mActivity.setTitle(mLocaleInfo.getFullNameNative());
|
Log.d(TAG, "onCreate, mIsNumberingMode = " + mIsNumberingMode);
|
||||||
|
if (!mIsNumberingMode) {
|
||||||
|
mActivity.setTitle(R.string.region_selection_title);
|
||||||
|
}
|
||||||
|
|
||||||
|
TopIntroPreference topIntroPreference = findPreference(KEY_TOP_INTRO_PREFERENCE);
|
||||||
|
if (topIntroPreference != null) {
|
||||||
|
topIntroPreference.setVisible(!mIsNumberingMode);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mSystemLocaleAllListPreferenceController != null) {
|
||||||
|
mOriginalLocaleInfos =
|
||||||
|
mSystemLocaleAllListPreferenceController.getSupportedLocaleList();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -106,6 +140,151 @@ public class RegionAndNumberingSystemPickerFragment extends DashboardFragment {
|
|||||||
mRecyclerView = view.findViewById(R.id.recycler_view);
|
mRecyclerView = view.findViewById(R.id.recycler_view);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSaveInstanceState(@NonNull Bundle outState) {
|
||||||
|
super.onSaveInstanceState(outState);
|
||||||
|
if (mSearchView != null) {
|
||||||
|
outState.putBoolean(EXTRA_EXPAND_SEARCH_VIEW, !mSearchView.isIconified());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreateOptionsMenu(@NonNull Menu menu, @NonNull MenuInflater inflater) {
|
||||||
|
super.onCreateOptionsMenu(menu, inflater);
|
||||||
|
inflater.inflate(R.menu.language_selection_list, menu);
|
||||||
|
final MenuItem searchMenuItem = menu.findItem(R.id.locale_search_menu);
|
||||||
|
if (searchMenuItem != null) {
|
||||||
|
searchMenuItem.setOnActionExpandListener(this);
|
||||||
|
mSearchView = (SearchView) searchMenuItem.getActionView();
|
||||||
|
mSearchView.setQueryHint(
|
||||||
|
getContext().getResources().getText(R.string.search_region_hint));
|
||||||
|
mSearchView.setOnQueryTextListener(this);
|
||||||
|
mSearchView.setMaxWidth(Integer.MAX_VALUE);
|
||||||
|
if (mExpandSearch) {
|
||||||
|
searchMenuItem.expandActionView();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void filterSearch(@Nullable String query) {
|
||||||
|
if (mSearchFilter == null) {
|
||||||
|
mSearchFilter = new SearchFilter();
|
||||||
|
}
|
||||||
|
|
||||||
|
// If we haven't load apps list completely, don't filter anything.
|
||||||
|
if (mOriginalLocaleInfos == null) {
|
||||||
|
Log.w(TAG, "Locales haven't loaded completely yet, so nothing can be filtered");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mSearchFilter.filter(query);
|
||||||
|
}
|
||||||
|
|
||||||
|
private class SearchFilter extends Filter {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected FilterResults performFiltering(CharSequence prefix) {
|
||||||
|
FilterResults results = new FilterResults();
|
||||||
|
mPrefix = prefix;
|
||||||
|
if (TextUtils.isEmpty(prefix)) {
|
||||||
|
results.values = mOriginalLocaleInfos;
|
||||||
|
results.count = mOriginalLocaleInfos.size();
|
||||||
|
} else {
|
||||||
|
// TODO: decide if we should use the string's locale
|
||||||
|
List<LocaleStore.LocaleInfo> newList = new ArrayList<>(mOriginalLocaleInfos);
|
||||||
|
newList.addAll(mSystemLocaleAllListPreferenceController.getSuggestedLocaleList());
|
||||||
|
Locale locale = Locale.getDefault();
|
||||||
|
String prefixString = LocaleHelper.normalizeForSearch(prefix.toString(), locale);
|
||||||
|
final int count = newList.size();
|
||||||
|
final ArrayList<LocaleStore.LocaleInfo> newValues = new ArrayList<>();
|
||||||
|
for (int i = 0; i < count; i++) {
|
||||||
|
final LocaleStore.LocaleInfo value = newList.get(i);
|
||||||
|
final String nameToCheck = LocaleHelper.normalizeForSearch(
|
||||||
|
value.getFullNameInUiLanguage(), locale);
|
||||||
|
final String nativeNameToCheck = LocaleHelper.normalizeForSearch(
|
||||||
|
value.getFullNameNative(), locale);
|
||||||
|
if ((wordMatches(nativeNameToCheck, prefixString)
|
||||||
|
|| wordMatches(nameToCheck, prefixString)) && !newValues.contains(
|
||||||
|
value)) {
|
||||||
|
newValues.add(value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
results.values = newValues;
|
||||||
|
results.count = newValues.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
return results;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void publishResults(CharSequence constraint, FilterResults results) {
|
||||||
|
if (mSystemLocaleAllListPreferenceController == null
|
||||||
|
|| mSuggestedListPreferenceController == null) {
|
||||||
|
Log.d(TAG, "publishResults(), can not get preference.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mLocaleOptions = (ArrayList<LocaleStore.LocaleInfo>) results.values;
|
||||||
|
// TODO: Need to scroll to first preference when searching.
|
||||||
|
if (mRecyclerView != null) {
|
||||||
|
mRecyclerView.post(() -> mRecyclerView.scrollToPosition(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
mSystemLocaleAllListPreferenceController.onSearchListChanged(mLocaleOptions, mPrefix);
|
||||||
|
mSuggestedListPreferenceController.onSearchListChanged(mLocaleOptions, mPrefix);
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: decide if this is enough, or we want to use a BreakIterator...
|
||||||
|
private boolean wordMatches(String valueText, String prefixString) {
|
||||||
|
if (valueText == null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// First match against the whole, non-split value
|
||||||
|
if (valueText.startsWith(prefixString)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// For example: English (Australia), Arabic (Egypt)
|
||||||
|
Pattern pattern = Pattern.compile("^.*?\\((.*)");
|
||||||
|
Matcher matcher = pattern.matcher(valueText);
|
||||||
|
if (matcher.find()) {
|
||||||
|
String region = matcher.group(1);
|
||||||
|
return region.startsWith(prefixString);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onMenuItemActionExpand(@NonNull MenuItem item) {
|
||||||
|
// To prevent a large space on tool bar.
|
||||||
|
mAppBarLayout.setExpanded(false /*expanded*/, false /*animate*/);
|
||||||
|
// To prevent user can expand the collapsing tool bar view.
|
||||||
|
ViewCompat.setNestedScrollingEnabled(mRecyclerView, false);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onMenuItemActionCollapse(@NonNull MenuItem item) {
|
||||||
|
// We keep the collapsed status after user cancel the search function.
|
||||||
|
mAppBarLayout.setExpanded(false /*expanded*/, false /*animate*/);
|
||||||
|
ViewCompat.setNestedScrollingEnabled(mRecyclerView, true);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onQueryTextSubmit(@Nullable String query) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onQueryTextChange(@Nullable String newText) {
|
||||||
|
filterSearch(newText);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected String getLogTag() {
|
protected String getLogTag() {
|
||||||
return TAG;
|
return TAG;
|
||||||
|
|||||||
@@ -222,8 +222,9 @@ public class SystemLocalePickerFragment extends DashboardFragment implements
|
|||||||
if (mRecyclerView != null) {
|
if (mRecyclerView != null) {
|
||||||
mRecyclerView.post(() -> mRecyclerView.scrollToPosition(0));
|
mRecyclerView.post(() -> mRecyclerView.scrollToPosition(0));
|
||||||
}
|
}
|
||||||
mSystemLocaleAllListPreferenceController.onSearchListChanged(mLocaleOptions);
|
|
||||||
mSuggestedListPreferenceController.onSearchListChanged(mLocaleOptions);
|
mSystemLocaleAllListPreferenceController.onSearchListChanged(mLocaleOptions, null);
|
||||||
|
mSuggestedListPreferenceController.onSearchListChanged(mLocaleOptions, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: decide if this is enough, or we want to use a BreakIterator...
|
// TODO: decide if this is enough, or we want to use a BreakIterator...
|
||||||
|
|||||||
@@ -17,6 +17,7 @@
|
|||||||
package com.android.settings.network
|
package com.android.settings.network
|
||||||
|
|
||||||
import android.app.Activity
|
import android.app.Activity
|
||||||
|
import android.app.settings.SettingsEnums.ACTION_AIRPLANE_TOGGLE
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.content.pm.PackageManager
|
import android.content.pm.PackageManager
|
||||||
@@ -33,6 +34,7 @@ import com.android.settings.PreferenceRestrictionMixin
|
|||||||
import com.android.settings.R
|
import com.android.settings.R
|
||||||
import com.android.settings.Utils
|
import com.android.settings.Utils
|
||||||
import com.android.settings.network.SatelliteRepository.Companion.isSatelliteOn
|
import com.android.settings.network.SatelliteRepository.Companion.isSatelliteOn
|
||||||
|
import com.android.settings.overlay.FeatureFactory.Companion.featureFactory
|
||||||
import com.android.settingslib.RestrictedSwitchPreference
|
import com.android.settingslib.RestrictedSwitchPreference
|
||||||
import com.android.settingslib.datastore.AbstractKeyedDataObservable
|
import com.android.settingslib.datastore.AbstractKeyedDataObservable
|
||||||
import com.android.settingslib.datastore.DataChangeReason
|
import com.android.settingslib.datastore.DataChangeReason
|
||||||
@@ -113,6 +115,9 @@ class AirplaneModePreference :
|
|||||||
val intent = Intent(Intent.ACTION_AIRPLANE_MODE_CHANGED)
|
val intent = Intent(Intent.ACTION_AIRPLANE_MODE_CHANGED)
|
||||||
intent.putExtra("state", value)
|
intent.putExtra("state", value)
|
||||||
context.sendBroadcastAsUser(intent, UserHandle.ALL)
|
context.sendBroadcastAsUser(intent, UserHandle.ALL)
|
||||||
|
|
||||||
|
val metricsFeature = featureFactory.metricsFeatureProvider
|
||||||
|
metricsFeature.action(context, ACTION_AIRPLANE_TOGGLE, value)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -58,9 +58,11 @@ import com.android.settings.Utils;
|
|||||||
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.network.ims.WifiCallingQueryImsState;
|
import com.android.settings.network.ims.WifiCallingQueryImsState;
|
||||||
|
import com.android.settings.network.telephony.AbstractSubscriptionPreferenceController;
|
||||||
import com.android.settings.network.telephony.wificalling.IWifiCallingRepository;
|
import com.android.settings.network.telephony.wificalling.IWifiCallingRepository;
|
||||||
import com.android.settings.network.telephony.wificalling.WifiCallingRepository;
|
import com.android.settings.network.telephony.wificalling.WifiCallingRepository;
|
||||||
import com.android.settings.widget.SettingsMainSwitchPreference;
|
import com.android.settings.widget.SettingsMainSwitchPreference;
|
||||||
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
import kotlin.Unit;
|
import kotlin.Unit;
|
||||||
|
|
||||||
@@ -293,6 +295,11 @@ public class WifiCallingSettingsForSub extends DashboardFragment
|
|||||||
|
|
||||||
updateDescriptionForOptions(
|
updateDescriptionForOptions(
|
||||||
List.of(mButtonWfcMode, mButtonWfcRoamingMode, mUpdateAddress));
|
List.of(mButtonWfcMode, mButtonWfcRoamingMode, mUpdateAddress));
|
||||||
|
|
||||||
|
List<AbstractPreferenceController> subscriptionPreferenceControllers =
|
||||||
|
useGroup(AbstractSubscriptionPreferenceController.class);
|
||||||
|
subscriptionPreferenceControllers.forEach(
|
||||||
|
controller -> ((AbstractSubscriptionPreferenceController) controller).init(mSubId));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
package com.android.settings.network
|
package com.android.settings.network
|
||||||
|
|
||||||
|
import android.app.settings.SettingsEnums.ACTION_AIRPLANE_TOGGLE
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.content.ContextWrapper
|
import android.content.ContextWrapper
|
||||||
import android.content.pm.PackageManager
|
import android.content.pm.PackageManager
|
||||||
@@ -26,12 +27,14 @@ import android.telephony.TelephonyManager
|
|||||||
import androidx.preference.SwitchPreferenceCompat
|
import androidx.preference.SwitchPreferenceCompat
|
||||||
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.settings.testutils.FakeFeatureFactory
|
||||||
import com.android.settingslib.datastore.SettingsGlobalStore
|
import com.android.settingslib.datastore.SettingsGlobalStore
|
||||||
import com.android.settingslib.preference.createAndBindWidget
|
import com.android.settingslib.preference.createAndBindWidget
|
||||||
import com.google.common.truth.Truth.assertThat
|
import com.google.common.truth.Truth.assertThat
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
import org.junit.runner.RunWith
|
import org.junit.runner.RunWith
|
||||||
import org.mockito.ArgumentMatchers.anyInt
|
import org.mockito.ArgumentMatchers.anyInt
|
||||||
|
import org.mockito.Mockito.verify
|
||||||
import org.mockito.kotlin.doReturn
|
import org.mockito.kotlin.doReturn
|
||||||
import org.mockito.kotlin.mock
|
import org.mockito.kotlin.mock
|
||||||
import org.mockito.kotlin.stub
|
import org.mockito.kotlin.stub
|
||||||
@@ -103,6 +106,24 @@ class AirplaneModePreferenceTest {
|
|||||||
assertThat(getValue).isFalse()
|
assertThat(getValue).isFalse()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun setValue_valueTrue_metricsActionAirplaneToggleTrue() {
|
||||||
|
val metricsFeatureProvider = FakeFeatureFactory.setupForTest().metricsFeatureProvider
|
||||||
|
|
||||||
|
airplaneModePreference.storage(context).setBoolean(AirplaneModePreference.KEY, true)
|
||||||
|
|
||||||
|
verify(metricsFeatureProvider).action(context, ACTION_AIRPLANE_TOGGLE, true)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun setValue_valueFalse_metricsActionAirplaneToggleFalse() {
|
||||||
|
val metricsFeatureProvider = FakeFeatureFactory.setupForTest().metricsFeatureProvider
|
||||||
|
|
||||||
|
airplaneModePreference.storage(context).setBoolean(AirplaneModePreference.KEY, false)
|
||||||
|
|
||||||
|
verify(metricsFeatureProvider).action(context, ACTION_AIRPLANE_TOGGLE, false)
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
fun performClick_defaultOn_checkedIsFalse() {
|
fun performClick_defaultOn_checkedIsFalse() {
|
||||||
SettingsGlobalStore.get(context).setInt(Settings.Global.AIRPLANE_MODE_ON, 1)
|
SettingsGlobalStore.get(context).setInt(Settings.Global.AIRPLANE_MODE_ON, 1)
|
||||||
|
|||||||
Reference in New Issue
Block a user