Snap for 8867503 from 7ab7c1d6f8 to tm-qpr1-release
Change-Id: I675b4a4fc5d9b4e6dd5ab76c8a5d55ad222271b3
This commit is contained in:
1
res/raw/lottie_long_press_power_for_power_menu.json
Normal file
1
res/raw/lottie_long_press_power_for_power_menu.json
Normal file
File diff suppressed because one or more lines are too long
@@ -12743,7 +12743,7 @@
|
|||||||
<!-- Summary for prevent ringing setting -->
|
<!-- Summary for prevent ringing setting -->
|
||||||
<string name="prevent_ringing_option_mute_summary">Mute</string>
|
<string name="prevent_ringing_option_mute_summary">Mute</string>
|
||||||
<!-- Summary for prevent ringing setting when the option itself is unavailable. [CHAR LIMIT=NONE] -->
|
<!-- Summary for prevent ringing setting when the option itself is unavailable. [CHAR LIMIT=NONE] -->
|
||||||
<string name="prevent_ringing_option_unavailable_lpp_summary">To enable, first change \"Press and hold power button\" to the power menu.</string>
|
<string name="prevent_ringing_option_unavailable_lpp_summary">To enable, first change \"Press & hold power button\" to the power menu.</string>
|
||||||
|
|
||||||
<!-- Title for detail page of wifi network [CHAR LIMIT=30] -->
|
<!-- Title for detail page of wifi network [CHAR LIMIT=30] -->
|
||||||
<string name="pref_title_network_details">Network details</string>
|
<string name="pref_title_network_details">Network details</string>
|
||||||
@@ -13502,29 +13502,28 @@
|
|||||||
<!-- Cards and passes name lower case [CHAR LIMIT=40] -->
|
<!-- Cards and passes name lower case [CHAR LIMIT=40] -->
|
||||||
<string name="cards_passes_lower">cards & passes</string>
|
<string name="cards_passes_lower">cards & passes</string>
|
||||||
|
|
||||||
<!-- Power menu setting name [CHAR LIMIT=NONE] -->
|
<!-- Power menu setting name [CHAR LIMIT=60] -->
|
||||||
<string name="power_menu_setting_name">Press and hold power button</string>
|
<string name="power_menu_setting_name">Press & hold power button</string>
|
||||||
|
|
||||||
<!-- Power menu setting summary to describe press and hold power button for Assistant is enabled. [CHAR LIMIT=NONE] -->
|
<!-- Power menu setting section title for selecting the press and hold power button behavior. [CHAR LIMIT=60] -->
|
||||||
<string name="power_menu_summary_long_press_for_assist_enabled">Press and hold for the Assistant</string>
|
<string name="power_menu_long_press_category_title">Press & hold power button to access</string>
|
||||||
<!-- Power menu setting summary to describe press and hold power button for Assistant is disabled and power menu will appear. [CHAR LIMIT=NONE] -->
|
<!-- Power menu setting option to make press and hold power button to open Power Menu. [CHAR LIMIT=60] -->
|
||||||
<string name="power_menu_summary_long_press_for_assist_disabled_with_power_menu">Press and hold for the power menu</string>
|
<string name="power_menu_long_press_for_power_menu_title">Power menu</string>
|
||||||
<!-- Power menu setting summary to describe press and hold power button for Assistant is disabled and nothing will happen. [CHAR LIMIT=NONE] -->
|
<!-- Power menu setting option to make press and hold power button to open Assistant. [CHAR LIMIT=60] -->
|
||||||
<string name="power_menu_summary_long_press_for_assist_disabled_no_action">Press and hold disabled</string>
|
<string name="power_menu_long_press_for_assistant_title">Digital assistant</string>
|
||||||
|
|
||||||
|
<!-- Power menu setting summary to describe press and hold power button will open Assistant. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="power_menu_summary_long_press_for_assistant">Access digital assistant</string>
|
||||||
|
<!-- Power menu setting summary to describe press and hold power button will open Power Menu. [CHAR LIMIT=NONE] -->
|
||||||
|
<string name="power_menu_summary_long_press_for_power_menu">Access power menu</string>
|
||||||
|
|
||||||
<!-- Power menu setting privacy no secure screen lock set [CHAR_LIMIT=NONE] -->
|
<!-- Power menu setting privacy no secure screen lock set [CHAR_LIMIT=NONE] -->
|
||||||
<string name="lockscreen_privacy_not_secure">To use, first set a screen lock</string>
|
<string name="lockscreen_privacy_not_secure">To use, first set a screen lock</string>
|
||||||
|
|
||||||
<!-- Power menu setting use long press power to invoke assistant. [CHAR LIMIT=NONE] -->
|
<!-- Power menu explanation to press power and volume up to show power menu. [CHAR LIMIT=NONE] -->
|
||||||
<string name="power_menu_long_press_for_assist">Hold for Assistant</string>
|
<string name="power_menu_power_volume_up_hint">Power menu:\nPress the power button and the volume up button at the same time</string>
|
||||||
|
|
||||||
<!-- Power menu setting use log press power to invoke assistant summary. [CHAR LIMIT=NONE] -->
|
|
||||||
<string name="power_menu_long_press_for_assist_summary">Trigger the Assistant by holding the power button</string>
|
|
||||||
|
|
||||||
<!-- Power menu explanation to press power and volume up to show power and emergency menu. [CHAR LIMIT=NONE] -->
|
|
||||||
<string name="power_menu_power_volume_up_hint">Power & Emergency Menu:\nPress Power and Volume up at the same time.</string>
|
|
||||||
<!-- Power menu explanation where to find prevent ringing option. [CHAR LIMIT=NONE] -->
|
<!-- Power menu explanation where to find prevent ringing option. [CHAR LIMIT=NONE] -->
|
||||||
<string name="power_menu_power_prevent_ringing_hint">Prevent ringing:\nShortcut available in the volume menu.</string>
|
<string name="power_menu_power_prevent_ringing_hint">Prevent ringing:\nPress a volume button for the shortcut</string>
|
||||||
|
|
||||||
<!-- Power menu title of the seekbar setting controlling duration of how long the power button must be held to invoke assistant. [CHAR LIMIT=NONE]-->
|
<!-- Power menu title of the seekbar setting controlling duration of how long the power button must be held to invoke assistant. [CHAR LIMIT=NONE]-->
|
||||||
<string name="power_menu_long_press_for_assist_sensitivity_title">Press & hold duration</string>
|
<string name="power_menu_long_press_for_assist_sensitivity_title">Press & hold duration</string>
|
||||||
|
|||||||
@@ -23,19 +23,28 @@
|
|||||||
android:key="gesture_power_menu_video"
|
android:key="gesture_power_menu_video"
|
||||||
settings:searchable="false"
|
settings:searchable="false"
|
||||||
settings:lottie_imageAssetsFolder="power_menu"
|
settings:lottie_imageAssetsFolder="power_menu"
|
||||||
settings:lottie_rawRes="@raw/lottie_power_menu"/>
|
settings:lottie_rawRes="@raw/lottie_long_press_power_for_power_menu"
|
||||||
|
settings:controller="com.android.settings.gestures.LongPressPowerIllustrationPreferenceController"/>
|
||||||
|
|
||||||
<SwitchPreference
|
<PreferenceCategory
|
||||||
android:key="gesture_power_menu_long_press_for_assist"
|
android:key="gesture_power_menu_long_press_category"
|
||||||
android:title="@string/power_menu_long_press_for_assist"
|
android:title="@string/power_menu_long_press_category_title">
|
||||||
android:summary="@string/power_menu_long_press_for_assist_summary"
|
<com.android.settingslib.widget.SelectorWithWidgetPreference
|
||||||
settings:controller="com.android.settings.gestures.LongPressPowerButtonPreferenceController"
|
android:key="gesture_power_menu_long_press_for_power_menu"
|
||||||
/>
|
android:title="@string/power_menu_long_press_for_power_menu_title"
|
||||||
|
settings:controller="com.android.settings.gestures.LongPressPowerForPowerMenuPreferenceController"/>
|
||||||
|
|
||||||
|
<com.android.settingslib.widget.SelectorWithWidgetPreference
|
||||||
|
android:key="gesture_power_menu_long_press_for_assistant"
|
||||||
|
android:title="@string/power_menu_long_press_for_assistant_title"
|
||||||
|
settings:controller="com.android.settings.gestures.LongPressPowerForAssistantPreferenceController"/>
|
||||||
|
</PreferenceCategory>
|
||||||
|
|
||||||
<com.android.settings.widget.LabeledSeekBarPreference
|
<com.android.settings.widget.LabeledSeekBarPreference
|
||||||
android:key="gesture_power_menu_long_press_for_assist_sensitivity"
|
android:key="gesture_power_menu_long_press_for_assist_sensitivity"
|
||||||
android:title="@string/power_menu_long_press_for_assist_sensitivity_title"
|
android:title="@string/power_menu_long_press_for_assist_sensitivity_title"
|
||||||
android:summary="@string/power_menu_long_press_for_assist_sensitivity_summary"
|
android:summary="@string/power_menu_long_press_for_assist_sensitivity_summary"
|
||||||
|
settings:allowDividerAbove="true"
|
||||||
settings:textStart="@string/power_menu_long_press_for_assist_sensitivity_low_label"
|
settings:textStart="@string/power_menu_long_press_for_assist_sensitivity_low_label"
|
||||||
settings:textEnd="@string/power_menu_long_press_for_assist_sensitivity_high_label"
|
settings:textEnd="@string/power_menu_long_press_for_assist_sensitivity_high_label"
|
||||||
settings:controller="com.android.settings.gestures.LongPressPowerSensitivityPreferenceController"
|
settings:controller="com.android.settings.gestures.LongPressPowerSensitivityPreferenceController"
|
||||||
@@ -45,5 +54,6 @@
|
|||||||
android:key="power_menu_power_volume_up_hint"
|
android:key="power_menu_power_volume_up_hint"
|
||||||
android:title="@string/power_menu_power_volume_up_hint"
|
android:title="@string/power_menu_power_volume_up_hint"
|
||||||
android:selectable="false"
|
android:selectable="false"
|
||||||
settings:searchable="false"/>
|
settings:searchable="false"
|
||||||
|
settings:controller="com.android.settings.gestures.LongPressPowerFooterPreferenceController"/>
|
||||||
</PreferenceScreen>
|
</PreferenceScreen>
|
||||||
|
|||||||
@@ -49,8 +49,6 @@ public class ToggleScreenReaderPreferenceFragmentForSetupWizard
|
|||||||
if (mTopIntroPreference != null) {
|
if (mTopIntroPreference != null) {
|
||||||
mTopIntroPreference.setVisible(false);
|
mTopIntroPreference.setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
mToggleServiceSwitchPreference.applyPartnerCustomizationPaddingStyle();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -1,196 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2021 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.gestures;
|
|
||||||
|
|
||||||
import static com.android.settings.gestures.PowerMenuSettingsUtils.LONG_PRESS_POWER_ASSISTANT_VALUE;
|
|
||||||
import static com.android.settings.gestures.PowerMenuSettingsUtils.LONG_PRESS_POWER_GLOBAL_ACTIONS;
|
|
||||||
import static com.android.settings.gestures.PowerMenuSettingsUtils.POWER_BUTTON_LONG_PRESS_DEFAULT_VALUE_RESOURCE;
|
|
||||||
import static com.android.settings.gestures.PowerMenuSettingsUtils.POWER_BUTTON_LONG_PRESS_SETTING;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.provider.Settings;
|
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceScreen;
|
|
||||||
|
|
||||||
import com.android.internal.annotations.VisibleForTesting;
|
|
||||||
import com.android.settings.R;
|
|
||||||
import com.android.settings.core.TogglePreferenceController;
|
|
||||||
|
|
||||||
import org.checkerframework.checker.nullness.qual.MonotonicNonNull;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Configures the behaviour of long press power button action.
|
|
||||||
*/
|
|
||||||
public class LongPressPowerButtonPreferenceController extends TogglePreferenceController {
|
|
||||||
|
|
||||||
private static final String KEY_CHORD_POWER_VOLUME_UP_SETTING =
|
|
||||||
Settings.Global.KEY_CHORD_POWER_VOLUME_UP;
|
|
||||||
|
|
||||||
private static final String FOOTER_HINT_KEY = "power_menu_power_volume_up_hint";
|
|
||||||
private static final String ASSIST_SWITCH_KEY = "gesture_power_menu_long_press_for_assist";
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Values used for volume key chord behaviour when Assist setting is enabled.
|
|
||||||
*
|
|
||||||
* Values based on config_keyChordPowerVolumeUp in
|
|
||||||
* frameworks/base/core/res/res/values/config.xml
|
|
||||||
*/
|
|
||||||
@VisibleForTesting
|
|
||||||
static final int KEY_CHORD_POWER_VOLUME_UP_NO_ACTION = 0;
|
|
||||||
@VisibleForTesting
|
|
||||||
static final int KEY_CHORD_POWER_VOLUME_UP_MUTE_TOGGLE = 1;
|
|
||||||
@VisibleForTesting
|
|
||||||
static final int KEY_CHORD_POWER_VOLUME_UP_GLOBAL_ACTIONS = 2;
|
|
||||||
|
|
||||||
private static final int KEY_CHORD_POWER_VOLUME_UP_DEFAULT_VALUE_RESOURCE =
|
|
||||||
com.android.internal.R.integer.config_keyChordPowerVolumeUp;
|
|
||||||
|
|
||||||
@MonotonicNonNull
|
|
||||||
@VisibleForTesting
|
|
||||||
Preference mFooterHint;
|
|
||||||
|
|
||||||
@MonotonicNonNull
|
|
||||||
@VisibleForTesting
|
|
||||||
Preference mAssistSwitch;
|
|
||||||
|
|
||||||
public LongPressPowerButtonPreferenceController(Context context, String key) {
|
|
||||||
super(context, key);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void displayPreference(PreferenceScreen screen) {
|
|
||||||
super.displayPreference(screen);
|
|
||||||
mFooterHint = screen.findPreference(FOOTER_HINT_KEY);
|
|
||||||
mAssistSwitch = screen.findPreference(ASSIST_SWITCH_KEY);
|
|
||||||
refreshStateDisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public CharSequence getSummary() {
|
|
||||||
final int powerButtonValue = PowerMenuSettingsUtils.getPowerButtonSettingValue(mContext);
|
|
||||||
if (powerButtonValue == LONG_PRESS_POWER_ASSISTANT_VALUE) {
|
|
||||||
return mContext.getString(R.string.power_menu_summary_long_press_for_assist_enabled);
|
|
||||||
} else if (powerButtonValue == LONG_PRESS_POWER_GLOBAL_ACTIONS) {
|
|
||||||
return mContext.getString(
|
|
||||||
R.string.power_menu_summary_long_press_for_assist_disabled_with_power_menu);
|
|
||||||
} else {
|
|
||||||
return mContext.getString(
|
|
||||||
R.string.power_menu_summary_long_press_for_assist_disabled_no_action);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getAvailabilityStatus() {
|
|
||||||
final boolean enabled = mContext.getResources().getBoolean(
|
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable);
|
|
||||||
return enabled ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isChecked() {
|
|
||||||
return PowerMenuSettingsUtils.isLongPressPowerForAssistEnabled(mContext);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean setChecked(boolean isChecked) {
|
|
||||||
if (setPowerLongPressValue(isChecked)) {
|
|
||||||
// The key chord value is dependant on the long press setting and it always
|
|
||||||
// toggled in tandem. POWER_BUTTON_LONG_PRESS_SETTING is always the source
|
|
||||||
// of truth for both.
|
|
||||||
setPowerVolumeChordValue(isChecked);
|
|
||||||
refreshStateDisplay();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public int getSliceHighlightMenuRes() {
|
|
||||||
return R.string.menu_key_system;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void refreshStateDisplay() {
|
|
||||||
if (mAssistSwitch != null) {
|
|
||||||
mAssistSwitch.setSummary(getSummary());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mFooterHint != null) {
|
|
||||||
String footerHintText = mContext.getString(R.string.power_menu_power_volume_up_hint);
|
|
||||||
// If the device supports hush gesture, we need to notify the user where to find
|
|
||||||
// the setting.
|
|
||||||
if (mContext.getResources().getBoolean(
|
|
||||||
com.android.internal.R.bool.config_volumeHushGestureEnabled)) {
|
|
||||||
footerHintText = footerHintText + "\n\n" + mContext.getString(
|
|
||||||
R.string.power_menu_power_prevent_ringing_hint);
|
|
||||||
}
|
|
||||||
|
|
||||||
mFooterHint.setSummary(footerHintText);
|
|
||||||
mFooterHint.setVisible(isPowerMenuKeyChordEnabled(mContext));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static boolean isPowerMenuKeyChordEnabled(Context context) {
|
|
||||||
return Settings.Global.getInt(context.getContentResolver(),
|
|
||||||
KEY_CHORD_POWER_VOLUME_UP_SETTING,
|
|
||||||
context.getResources().getInteger(
|
|
||||||
com.android.internal.R.integer.config_keyChordPowerVolumeUp))
|
|
||||||
== KEY_CHORD_POWER_VOLUME_UP_GLOBAL_ACTIONS;
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean setPowerLongPressValue(boolean isChecked) {
|
|
||||||
if (isChecked) {
|
|
||||||
return Settings.Global.putInt(mContext.getContentResolver(),
|
|
||||||
POWER_BUTTON_LONG_PRESS_SETTING, LONG_PRESS_POWER_ASSISTANT_VALUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
// We need to determine the right disabled value based on the device default
|
|
||||||
// for long-press power.
|
|
||||||
|
|
||||||
// If the default is to start the assistant, then the fallback is GlobalActions.
|
|
||||||
final int defaultPowerButtonValue = mContext.getResources().getInteger(
|
|
||||||
POWER_BUTTON_LONG_PRESS_DEFAULT_VALUE_RESOURCE);
|
|
||||||
if (defaultPowerButtonValue == LONG_PRESS_POWER_ASSISTANT_VALUE) {
|
|
||||||
return Settings.Global.putInt(mContext.getContentResolver(),
|
|
||||||
POWER_BUTTON_LONG_PRESS_SETTING, LONG_PRESS_POWER_GLOBAL_ACTIONS);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the default is something different than Assist, we use that default.
|
|
||||||
return Settings.Global.putInt(mContext.getContentResolver(),
|
|
||||||
POWER_BUTTON_LONG_PRESS_SETTING, defaultPowerButtonValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Updates {@link Settings.Global.KEY_CHORD_POWER_VOLUME_UP} based on the changed value of
|
|
||||||
* {@link #POWER_BUTTON_LONG_PRESS_SETTING}. If power button is used for Assist, key chord
|
|
||||||
* should show the power menu.
|
|
||||||
*/
|
|
||||||
private boolean setPowerVolumeChordValue(boolean isPowerButtonLongPressChecked) {
|
|
||||||
if (isPowerButtonLongPressChecked) {
|
|
||||||
return Settings.Global.putInt(mContext.getContentResolver(),
|
|
||||||
KEY_CHORD_POWER_VOLUME_UP_SETTING, KEY_CHORD_POWER_VOLUME_UP_GLOBAL_ACTIONS);
|
|
||||||
}
|
|
||||||
|
|
||||||
// We restore key chord to the default value.
|
|
||||||
int keyChordDefaultValue = mContext.getResources().getInteger(
|
|
||||||
KEY_CHORD_POWER_VOLUME_UP_DEFAULT_VALUE_RESOURCE);
|
|
||||||
return Settings.Global.putInt(mContext.getContentResolver(),
|
|
||||||
KEY_CHORD_POWER_VOLUME_UP_SETTING, keyChordDefaultValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
@@ -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.gestures;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.net.Uri;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.lifecycle.OnLifecycleEvent;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
|
||||||
|
/** Configures the behaviour of long press power footer. */
|
||||||
|
public class LongPressPowerFooterPreferenceController extends BasePreferenceController
|
||||||
|
implements PowerMenuSettingsUtils.SettingsStateCallback, LifecycleObserver {
|
||||||
|
|
||||||
|
private Preference mPreference;
|
||||||
|
private final PowerMenuSettingsUtils mUtils;
|
||||||
|
|
||||||
|
public LongPressPowerFooterPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
|
mUtils = new PowerMenuSettingsUtils(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
super.updateState(preference);
|
||||||
|
|
||||||
|
CharSequence footerHintText = mContext.getString(R.string.power_menu_power_volume_up_hint);
|
||||||
|
// If the device supports hush gesture, we need to tell the user where to find the setting.
|
||||||
|
if (mContext.getResources()
|
||||||
|
.getBoolean(com.android.internal.R.bool.config_volumeHushGestureEnabled)) {
|
||||||
|
footerHintText =
|
||||||
|
TextUtils.concat(
|
||||||
|
footerHintText,
|
||||||
|
"\n\n",
|
||||||
|
mContext.getString(R.string.power_menu_power_prevent_ringing_hint));
|
||||||
|
}
|
||||||
|
|
||||||
|
preference.setSummary(footerHintText);
|
||||||
|
preference.setVisible(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChange(Uri uri) {
|
||||||
|
if (mPreference != null) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_START) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_START)
|
||||||
|
public void onStart() {
|
||||||
|
mUtils.registerObserver(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_STOP) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_STOP)
|
||||||
|
public void onStop() {
|
||||||
|
mUtils.unregisterObserver();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,100 @@
|
|||||||
|
/*
|
||||||
|
* 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.gestures;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.net.Uri;
|
||||||
|
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.lifecycle.OnLifecycleEvent;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configures the behaviour of the radio selector to configure long press power button to Assistant.
|
||||||
|
*/
|
||||||
|
public class LongPressPowerForAssistantPreferenceController extends BasePreferenceController
|
||||||
|
implements PowerMenuSettingsUtils.SettingsStateCallback,
|
||||||
|
SelectorWithWidgetPreference.OnClickListener,
|
||||||
|
LifecycleObserver {
|
||||||
|
|
||||||
|
private SelectorWithWidgetPreference mPreference;
|
||||||
|
private final PowerMenuSettingsUtils mUtils;
|
||||||
|
|
||||||
|
public LongPressPowerForAssistantPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
|
mUtils = new PowerMenuSettingsUtils(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
return PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)
|
||||||
|
? AVAILABLE
|
||||||
|
: UNSUPPORTED_ON_DEVICE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
if (mPreference != null) {
|
||||||
|
mPreference.setOnClickListener(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
super.updateState(preference);
|
||||||
|
if (preference instanceof SelectorWithWidgetPreference) {
|
||||||
|
((SelectorWithWidgetPreference) preference)
|
||||||
|
.setChecked(
|
||||||
|
PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onRadioButtonClicked(SelectorWithWidgetPreference preference) {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
if (mPreference != null) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChange(Uri uri) {
|
||||||
|
if (mPreference != null) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_START) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_START)
|
||||||
|
public void onStart() {
|
||||||
|
mUtils.registerObserver(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_STOP) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_STOP)
|
||||||
|
public void onStop() {
|
||||||
|
mUtils.unregisterObserver();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,101 @@
|
|||||||
|
/*
|
||||||
|
* 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.gestures;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.net.Uri;
|
||||||
|
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.lifecycle.OnLifecycleEvent;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configures the behaviour of the radio selector to configure long press power button to Power
|
||||||
|
* Menu.
|
||||||
|
*/
|
||||||
|
public class LongPressPowerForPowerMenuPreferenceController extends BasePreferenceController
|
||||||
|
implements PowerMenuSettingsUtils.SettingsStateCallback,
|
||||||
|
SelectorWithWidgetPreference.OnClickListener,
|
||||||
|
LifecycleObserver {
|
||||||
|
|
||||||
|
private SelectorWithWidgetPreference mPreference;
|
||||||
|
private final PowerMenuSettingsUtils mUtils;
|
||||||
|
|
||||||
|
public LongPressPowerForPowerMenuPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
|
mUtils = new PowerMenuSettingsUtils(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
return PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)
|
||||||
|
? AVAILABLE
|
||||||
|
: UNSUPPORTED_ON_DEVICE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
if (mPreference != null) {
|
||||||
|
mPreference.setOnClickListener(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
super.updateState(preference);
|
||||||
|
if (preference instanceof SelectorWithWidgetPreference) {
|
||||||
|
((SelectorWithWidgetPreference) preference)
|
||||||
|
.setChecked(
|
||||||
|
!PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onRadioButtonClicked(SelectorWithWidgetPreference preference) {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
if (mPreference != null) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChange(Uri uri) {
|
||||||
|
if (mPreference != null) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_START) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_START)
|
||||||
|
public void onStart() {
|
||||||
|
mUtils.registerObserver(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_STOP) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_STOP)
|
||||||
|
public void onStop() {
|
||||||
|
mUtils.unregisterObserver();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,84 @@
|
|||||||
|
/*
|
||||||
|
* 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.gestures;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.net.Uri;
|
||||||
|
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.lifecycle.OnLifecycleEvent;
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settingslib.widget.IllustrationPreference;
|
||||||
|
|
||||||
|
/** Configures the behaviour of long press power illustration. */
|
||||||
|
public class LongPressPowerIllustrationPreferenceController extends BasePreferenceController
|
||||||
|
implements PowerMenuSettingsUtils.SettingsStateCallback, LifecycleObserver {
|
||||||
|
|
||||||
|
private IllustrationPreference mIllustrationPreference;
|
||||||
|
private final PowerMenuSettingsUtils mUtils;
|
||||||
|
|
||||||
|
public LongPressPowerIllustrationPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
|
mUtils = new PowerMenuSettingsUtils(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getAvailabilityStatus() {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mIllustrationPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateState(Preference preference) {
|
||||||
|
super.updateState(preference);
|
||||||
|
|
||||||
|
((IllustrationPreference) preference)
|
||||||
|
.setLottieAnimationResId(
|
||||||
|
PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)
|
||||||
|
? R.raw.lottie_long_press_power_for_assistant
|
||||||
|
: R.raw.lottie_long_press_power_for_power_menu);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChange(Uri uri) {
|
||||||
|
if (mIllustrationPreference != null) {
|
||||||
|
updateState(mIllustrationPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_START) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_START)
|
||||||
|
public void onStart() {
|
||||||
|
mUtils.registerObserver(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_STOP) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_STOP)
|
||||||
|
public void onStop() {
|
||||||
|
mUtils.unregisterObserver();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -17,37 +17,28 @@
|
|||||||
package com.android.settings.gestures;
|
package com.android.settings.gestures;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.database.ContentObserver;
|
import android.net.Uri;
|
||||||
import android.os.Handler;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.lifecycle.Lifecycle;
|
||||||
|
import androidx.lifecycle.LifecycleObserver;
|
||||||
|
import androidx.lifecycle.OnLifecycleEvent;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.core.SliderPreferenceController;
|
import com.android.settings.core.SliderPreferenceController;
|
||||||
import com.android.settings.widget.LabeledSeekBarPreference;
|
import com.android.settings.widget.LabeledSeekBarPreference;
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
|
||||||
import com.android.settingslib.core.lifecycle.events.OnStart;
|
|
||||||
import com.android.settingslib.core.lifecycle.events.OnStop;
|
|
||||||
|
|
||||||
/** Handles changes to the long press power button sensitivity slider. */
|
/** Handles changes to the long press power button sensitivity slider. */
|
||||||
public class LongPressPowerSensitivityPreferenceController extends
|
public class LongPressPowerSensitivityPreferenceController extends SliderPreferenceController
|
||||||
SliderPreferenceController implements
|
implements PowerMenuSettingsUtils.SettingsStateCallback, LifecycleObserver {
|
||||||
LifecycleObserver, OnStart, OnStop {
|
|
||||||
|
|
||||||
private final ContentObserver mPowerButtonObserver = new ContentObserver(Handler.getMain()) {
|
|
||||||
@Override
|
|
||||||
public void onChange(boolean selfChange) {
|
|
||||||
if (mPreference != null) {
|
|
||||||
updateState(mPreference);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private final int[] mSensitivityValues;
|
private final int[] mSensitivityValues;
|
||||||
|
|
||||||
|
private final PowerMenuSettingsUtils mUtils;
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private LabeledSeekBarPreference mPreference;
|
private LabeledSeekBarPreference mPreference;
|
||||||
|
|
||||||
@@ -55,18 +46,19 @@ public class LongPressPowerSensitivityPreferenceController extends
|
|||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mSensitivityValues = context.getResources().getIntArray(
|
mSensitivityValues = context.getResources().getIntArray(
|
||||||
com.android.internal.R.array.config_longPressOnPowerDurationSettings);
|
com.android.internal.R.array.config_longPressOnPowerDurationSettings);
|
||||||
|
mUtils = new PowerMenuSettingsUtils(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_START) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_START)
|
||||||
public void onStart() {
|
public void onStart() {
|
||||||
mContext.getContentResolver().registerContentObserver(
|
mUtils.registerObserver(this);
|
||||||
Settings.Global.getUriFor(PowerMenuSettingsUtils.POWER_BUTTON_LONG_PRESS_SETTING),
|
|
||||||
false, mPowerButtonObserver);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
/** @OnLifecycleEvent(Lifecycle.Event.ON_STOP) */
|
||||||
|
@OnLifecycleEvent(Lifecycle.Event.ON_STOP)
|
||||||
public void onStop() {
|
public void onStop() {
|
||||||
mContext.getContentResolver().unregisterContentObserver(mPowerButtonObserver);
|
mUtils.unregisterObserver();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -86,21 +78,19 @@ public class LongPressPowerSensitivityPreferenceController extends
|
|||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
super.updateState(preference);
|
super.updateState(preference);
|
||||||
final LabeledSeekBarPreference pref = (LabeledSeekBarPreference) preference;
|
final LabeledSeekBarPreference pref = (LabeledSeekBarPreference) preference;
|
||||||
pref.setEnabled(
|
pref.setVisible(
|
||||||
isAvailable() && PowerMenuSettingsUtils.isLongPressPowerForAssistEnabled(mContext));
|
PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)
|
||||||
|
&& getAvailabilityStatus() == AVAILABLE);
|
||||||
pref.setProgress(getSliderPosition());
|
pref.setProgress(getSliderPosition());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
if (mSensitivityValues == null || mSensitivityValues.length < 2) {
|
if (mSensitivityValues == null
|
||||||
|
|| mSensitivityValues.length < 2
|
||||||
|
|| !PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)) {
|
||||||
return UNSUPPORTED_ON_DEVICE;
|
return UNSUPPORTED_ON_DEVICE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!PowerMenuSettingsUtils.isLongPressPowerForAssistEnabled(mContext)) {
|
|
||||||
return DISABLED_DEPENDENT_SETTING;
|
|
||||||
}
|
|
||||||
|
|
||||||
return AVAILABLE;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -120,6 +110,13 @@ public class LongPressPowerSensitivityPreferenceController extends
|
|||||||
mSensitivityValues[position]);
|
mSensitivityValues[position]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChange(Uri uri) {
|
||||||
|
if (mPreference != null) {
|
||||||
|
updateState(mPreference);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getMax() {
|
public int getMax() {
|
||||||
if (mSensitivityValues == null || mSensitivityValues.length == 0) {
|
if (mSensitivityValues == null || mSensitivityValues.length == 0) {
|
||||||
|
|||||||
@@ -16,9 +16,6 @@
|
|||||||
|
|
||||||
package com.android.settings.gestures;
|
package com.android.settings.gestures;
|
||||||
|
|
||||||
import static com.android.settings.gestures.PowerMenuSettingsUtils.LONG_PRESS_POWER_ASSISTANT_VALUE;
|
|
||||||
import static com.android.settings.gestures.PowerMenuSettingsUtils.LONG_PRESS_POWER_GLOBAL_ACTIONS;
|
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
@@ -32,25 +29,17 @@ public class PowerMenuPreferenceController extends BasePreferenceController {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharSequence getSummary() {
|
public CharSequence getSummary() {
|
||||||
final int powerButtonValue = PowerMenuSettingsUtils.getPowerButtonSettingValue(mContext);
|
if (PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)) {
|
||||||
if (powerButtonValue == LONG_PRESS_POWER_ASSISTANT_VALUE) {
|
return mContext.getText(R.string.power_menu_summary_long_press_for_assistant);
|
||||||
return mContext.getText(R.string.power_menu_summary_long_press_for_assist_enabled);
|
|
||||||
} else if (powerButtonValue == LONG_PRESS_POWER_GLOBAL_ACTIONS) {
|
|
||||||
return mContext.getText(
|
|
||||||
R.string.power_menu_summary_long_press_for_assist_disabled_with_power_menu);
|
|
||||||
} else {
|
} else {
|
||||||
return mContext.getText(
|
return mContext.getText(R.string.power_menu_summary_long_press_for_power_menu);
|
||||||
R.string.power_menu_summary_long_press_for_assist_disabled_no_action);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return isAssistInvocationAvailable() ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
|
return PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)
|
||||||
}
|
? AVAILABLE
|
||||||
|
: UNSUPPORTED_ON_DEVICE;
|
||||||
private boolean isAssistInvocationAvailable() {
|
|
||||||
return mContext.getResources().getBoolean(
|
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,53 +16,163 @@
|
|||||||
|
|
||||||
package com.android.settings.gestures;
|
package com.android.settings.gestures;
|
||||||
|
|
||||||
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.database.ContentObserver;
|
||||||
|
import android.net.Uri;
|
||||||
|
import android.os.Handler;
|
||||||
|
import android.os.Looper;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
/** Common code for long press power settings shared between controllers. */
|
/** Common code for long press power settings shared between controllers. */
|
||||||
final class PowerMenuSettingsUtils {
|
final class PowerMenuSettingsUtils {
|
||||||
|
|
||||||
/**
|
/** Setting storing the current behaviour of long press power. */
|
||||||
* Setting storing the current behaviour of long press power.
|
private static final String POWER_BUTTON_LONG_PRESS_SETTING =
|
||||||
*/
|
|
||||||
public static final String POWER_BUTTON_LONG_PRESS_SETTING =
|
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS;
|
Settings.Global.POWER_BUTTON_LONG_PRESS;
|
||||||
|
|
||||||
|
/** Setting storing the current behaviour of key chord power + volume up. */
|
||||||
|
private static final String KEY_CHORD_POWER_VOLUME_UP_SETTING =
|
||||||
|
Settings.Global.KEY_CHORD_POWER_VOLUME_UP;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Value used for long press power button behaviour when the Assist setting is disabled.
|
* Value used for long press power button behaviour when long press power for Assistant is
|
||||||
|
* disabled.
|
||||||
*
|
*
|
||||||
* If this value matches Assist setting, then it falls back to Global Actions panel or
|
* <p>If this value matches long press power for Assistant, then it falls back to Global Actions
|
||||||
* power menu, depending on their respective settings.
|
* panel (i.e., the Power Menu), depending on their respective settings.
|
||||||
*/
|
*/
|
||||||
public static final int POWER_BUTTON_LONG_PRESS_DEFAULT_VALUE_RESOURCE =
|
private static final int POWER_BUTTON_LONG_PRESS_DEFAULT_VALUE_RESOURCE =
|
||||||
com.android.internal.R.integer.config_longPressOnPowerBehavior;
|
com.android.internal.R.integer.config_longPressOnPowerBehavior;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Values used for long press power button behaviour when Assist setting is enabled.
|
* Value used for key chord power + volume up behaviour when long press power for Assistant is
|
||||||
*
|
* disabled.
|
||||||
* {@link com.android.server.policy.PhoneWindowManager#LONG_PRESS_POWER_GLOBAL_ACTIONS} for
|
|
||||||
* source of the value.
|
|
||||||
*/
|
*/
|
||||||
static final int LONG_PRESS_POWER_NO_ACTION = 0;
|
private static final int KEY_CHORD_POWER_VOLUME_UP_DEFAULT_VALUE_RESOURCE =
|
||||||
static final int LONG_PRESS_POWER_GLOBAL_ACTIONS = 1;
|
com.android.internal.R.integer.config_keyChordPowerVolumeUp;
|
||||||
static final int LONG_PRESS_POWER_ASSISTANT_VALUE = 5; // Settings.Secure.ASSISTANT
|
|
||||||
|
private static final int LONG_PRESS_POWER_GLOBAL_ACTIONS = 1; // a.k.a., Power Menu
|
||||||
|
private static final int LONG_PRESS_POWER_ASSISTANT_VALUE = 5; // Settings.Secure.ASSISTANT
|
||||||
|
|
||||||
|
private static final int KEY_CHORD_POWER_VOLUME_UP_GLOBAL_ACTIONS = 2;
|
||||||
|
|
||||||
|
private static final Uri POWER_BUTTON_LONG_PRESS_URI =
|
||||||
|
Settings.Global.getUriFor(POWER_BUTTON_LONG_PRESS_SETTING);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return current value of power button behaviour.
|
* @return true if long press power for assistant is currently enabled.
|
||||||
*/
|
*/
|
||||||
public static int getPowerButtonSettingValue(Context context) {
|
public static boolean isLongPressPowerForAssistantEnabled(Context context) {
|
||||||
return Settings.Global.getInt(context.getContentResolver(),
|
int longPressPowerSettingValue = Settings.Global.getInt(
|
||||||
|
context.getContentResolver(),
|
||||||
POWER_BUTTON_LONG_PRESS_SETTING,
|
POWER_BUTTON_LONG_PRESS_SETTING,
|
||||||
context.getResources().getInteger(POWER_BUTTON_LONG_PRESS_DEFAULT_VALUE_RESOURCE));
|
context.getResources().getInteger(POWER_BUTTON_LONG_PRESS_DEFAULT_VALUE_RESOURCE));
|
||||||
|
return longPressPowerSettingValue == LONG_PRESS_POWER_ASSISTANT_VALUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return true if long press power for assist is currently enabled.
|
* @return true if long press power for assistant setting is available on the device.
|
||||||
*/
|
*/
|
||||||
public static boolean isLongPressPowerForAssistEnabled(Context context) {
|
public static boolean isLongPressPowerSettingAvailable(Context context) {
|
||||||
return getPowerButtonSettingValue(context) == LONG_PRESS_POWER_ASSISTANT_VALUE;
|
if (!context.getResources().getBoolean(
|
||||||
|
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable)) {
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private PowerMenuSettingsUtils() {
|
int defaultLongPressPowerSettingValue =
|
||||||
|
context.getResources().getInteger(POWER_BUTTON_LONG_PRESS_DEFAULT_VALUE_RESOURCE);
|
||||||
|
switch (defaultLongPressPowerSettingValue) {
|
||||||
|
case LONG_PRESS_POWER_GLOBAL_ACTIONS:
|
||||||
|
case LONG_PRESS_POWER_ASSISTANT_VALUE:
|
||||||
|
// We support switching between Power Menu and Digital Assistant.
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
// All other combinations are not supported.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean setLongPressPowerForAssistant(Context context) {
|
||||||
|
if (Settings.Global.putInt(
|
||||||
|
context.getContentResolver(),
|
||||||
|
POWER_BUTTON_LONG_PRESS_SETTING,
|
||||||
|
LONG_PRESS_POWER_ASSISTANT_VALUE)) {
|
||||||
|
// Make power + volume up buttons to open the power menu
|
||||||
|
Settings.Global.putInt(
|
||||||
|
context.getContentResolver(),
|
||||||
|
KEY_CHORD_POWER_VOLUME_UP_SETTING,
|
||||||
|
KEY_CHORD_POWER_VOLUME_UP_GLOBAL_ACTIONS);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean setLongPressPowerForPowerMenu(Context context) {
|
||||||
|
if (Settings.Global.putInt(
|
||||||
|
context.getContentResolver(),
|
||||||
|
POWER_BUTTON_LONG_PRESS_SETTING,
|
||||||
|
LONG_PRESS_POWER_GLOBAL_ACTIONS)) {
|
||||||
|
// We restore power + volume up buttons to the default action.
|
||||||
|
int keyChordDefaultValue =
|
||||||
|
context.getResources()
|
||||||
|
.getInteger(KEY_CHORD_POWER_VOLUME_UP_DEFAULT_VALUE_RESOURCE);
|
||||||
|
Settings.Global.putInt(
|
||||||
|
context.getContentResolver(),
|
||||||
|
KEY_CHORD_POWER_VOLUME_UP_SETTING,
|
||||||
|
keyChordDefaultValue);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private final Context mContext;
|
||||||
|
private final SettingsObserver mSettingsObserver;
|
||||||
|
|
||||||
|
PowerMenuSettingsUtils(Context context) {
|
||||||
|
mContext = context;
|
||||||
|
mSettingsObserver = new SettingsObserver(new Handler(Looper.getMainLooper()));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers callback for observing SettingsProvider state.
|
||||||
|
*
|
||||||
|
* @param callback for state changes
|
||||||
|
*/
|
||||||
|
public void registerObserver(SettingsStateCallback callback) {
|
||||||
|
mSettingsObserver.setCallback(callback);
|
||||||
|
final ContentResolver resolver = mContext.getContentResolver();
|
||||||
|
resolver.registerContentObserver(POWER_BUTTON_LONG_PRESS_URI, true, mSettingsObserver);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Unregisters callback for observing SettingsProvider state. */
|
||||||
|
public void unregisterObserver() {
|
||||||
|
final ContentResolver resolver = mContext.getContentResolver();
|
||||||
|
resolver.unregisterContentObserver(mSettingsObserver);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** An interface for when SettingsProvider key state changes. */
|
||||||
|
public interface SettingsStateCallback {
|
||||||
|
/** Callback method for SettingsProvider key state changes. */
|
||||||
|
void onChange(Uri uri);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final class SettingsObserver extends ContentObserver {
|
||||||
|
private SettingsStateCallback mCallback;
|
||||||
|
|
||||||
|
SettingsObserver(Handler handler) {
|
||||||
|
super(handler);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setCallback(SettingsStateCallback callback) {
|
||||||
|
mCallback = callback;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onChange(boolean selfChange, Uri uri) {
|
||||||
|
if (mCallback != null) {
|
||||||
|
mCallback.onChange(uri);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -51,7 +51,7 @@ public class AppBubbleListPreferenceController extends AppConversationListPrefer
|
|||||||
private static final String KEY = "bubble_conversations";
|
private static final String KEY = "bubble_conversations";
|
||||||
|
|
||||||
public AppBubbleListPreferenceController(Context context, NotificationBackend backend) {
|
public AppBubbleListPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -80,25 +80,25 @@ public class AppBubbleListPreferenceController extends AppConversationListPrefer
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
// copy rather than inherit super's isAvailable because apps can link to this page
|
// copy rather than inherit super's isAvailable because apps can link to this page
|
||||||
// as part of onboarding, before they send a valid conversation notification
|
// as part of onboarding, before they send a valid conversation notification
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow.banned) {
|
if (mAppRow.banned) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel != null) {
|
if (mChannel != null) {
|
||||||
if (mBackend.onlyHasDefaultChannel(mAppRow.pkg, mAppRow.uid)
|
if (mBackend.onlyHasDefaultChannel(mAppRow.pkg, mAppRow.uid)
|
||||||
|| NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId())) {
|
|| NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId())) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (mAppRow.bubblePreference == BUBBLE_PREFERENCE_NONE) {
|
if (mAppRow.bubblePreference == BUBBLE_PREFERENCE_NONE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ public class AddToHomeScreenPreferenceController extends NotificationPreferenceC
|
|||||||
private static final String KEY = "add_to_home";
|
private static final String KEY = "add_to_home";
|
||||||
|
|
||||||
public AddToHomeScreenPreferenceController(Context context, NotificationBackend backend) {
|
public AddToHomeScreenPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -41,11 +41,11 @@ public class AddToHomeScreenPreferenceController extends NotificationPreferenceC
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mConversationInfo != null;
|
return mConversationInfo != null ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ public class AllowSoundPreferenceController extends NotificationPreferenceContro
|
|||||||
public AllowSoundPreferenceController(Context context,
|
public AllowSoundPreferenceController(Context context,
|
||||||
NotificationSettings.DependentFieldListener dependentFieldListener,
|
NotificationSettings.DependentFieldListener dependentFieldListener,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_IMPORTANCE);
|
||||||
mDependentFieldListener = dependentFieldListener;
|
mDependentFieldListener = dependentFieldListener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -50,11 +50,14 @@ public class AllowSoundPreferenceController extends NotificationPreferenceContro
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mChannel != null && NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId());
|
if (mChannel != null && NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId())) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -64,7 +64,7 @@ public class AppChannelsBypassingDndPreferenceController extends NotificationPre
|
|||||||
public AppChannelsBypassingDndPreferenceController(
|
public AppChannelsBypassingDndPreferenceController(
|
||||||
Context context,
|
Context context,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -110,8 +110,8 @@ public class AppChannelsBypassingDndPreferenceController extends NotificationPre
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
return mAppRow != null;
|
return mAppRow != null ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -49,7 +49,12 @@ public class AppConversationListPreferenceController extends NotificationPrefere
|
|||||||
protected PreferenceCategory mPreference;
|
protected PreferenceCategory mPreference;
|
||||||
|
|
||||||
public AppConversationListPreferenceController(Context context, NotificationBackend backend) {
|
public AppConversationListPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
this(context, backend, KEY);
|
||||||
|
}
|
||||||
|
|
||||||
|
public AppConversationListPreferenceController(Context context, NotificationBackend backend,
|
||||||
|
String key) {
|
||||||
|
super(context, backend, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -58,21 +63,24 @@ public class AppConversationListPreferenceController extends NotificationPrefere
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow.banned) {
|
if (mAppRow.banned) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel != null) {
|
if (mChannel != null) {
|
||||||
if (mBackend.onlyHasDefaultChannel(mAppRow.pkg, mAppRow.uid)
|
if (mBackend.onlyHasDefaultChannel(mAppRow.pkg, mAppRow.uid)
|
||||||
|| NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId())) {
|
|| NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId())) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return mBackend.hasSentValidMsg(mAppRow.pkg, mAppRow.uid) || mBackend.isInInvalidMsgState(
|
if (mBackend.hasSentValidMsg(mAppRow.pkg, mAppRow.uid) || mBackend.isInInvalidMsgState(
|
||||||
mAppRow.pkg, mAppRow.uid);
|
mAppRow.pkg, mAppRow.uid)) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -32,7 +32,7 @@ public class AppLinkPreferenceController extends NotificationPreferenceControlle
|
|||||||
private static final String KEY_APP_LINK = "app_link";
|
private static final String KEY_APP_LINK = "app_link";
|
||||||
|
|
||||||
public AppLinkPreferenceController(Context context) {
|
public AppLinkPreferenceController(Context context) {
|
||||||
super(context, null);
|
super(context, null, KEY_APP_LINK);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -41,11 +41,11 @@ public class AppLinkPreferenceController extends NotificationPreferenceControlle
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mAppRow.settingsIntent != null;
|
return mAppRow.settingsIntent != null ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ public class BadgePreferenceController extends NotificationPreferenceController
|
|||||||
|
|
||||||
public BadgePreferenceController(Context context,
|
public BadgePreferenceController(Context context,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_BADGE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -47,25 +47,29 @@ public class BadgePreferenceController extends NotificationPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow == null && mChannel == null) {
|
if (mAppRow == null && mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (Settings.Secure.getInt(mContext.getContentResolver(),
|
if (Settings.Secure.getInt(mContext.getContentResolver(),
|
||||||
NOTIFICATION_BADGING, SYSTEM_WIDE_ON) == SYSTEM_WIDE_OFF) {
|
NOTIFICATION_BADGING, SYSTEM_WIDE_ON) == SYSTEM_WIDE_OFF) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel != null) {
|
if (mChannel != null) {
|
||||||
if (isDefaultChannel()) {
|
if (isDefaultChannel()) {
|
||||||
return true;
|
return AVAILABLE;
|
||||||
} else {
|
} else {
|
||||||
return mAppRow == null ? false : mAppRow.showBadge;
|
return mAppRow == null
|
||||||
|
? CONDITIONALLY_UNAVAILABLE
|
||||||
|
: mAppRow.showBadge
|
||||||
|
? AVAILABLE
|
||||||
|
: CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -42,7 +42,7 @@ public class BlockPreferenceController extends NotificationPreferenceController
|
|||||||
public BlockPreferenceController(Context context,
|
public BlockPreferenceController(Context context,
|
||||||
NotificationSettings.DependentFieldListener dependentFieldListener,
|
NotificationSettings.DependentFieldListener dependentFieldListener,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_BLOCK);
|
||||||
mDependentFieldListener = dependentFieldListener;
|
mDependentFieldListener = dependentFieldListener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -52,14 +52,14 @@ public class BlockPreferenceController extends NotificationPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -32,15 +32,15 @@ public class BubbleCategoryPreferenceController extends NotificationPreferenceCo
|
|||||||
static final int ON = 1;
|
static final int ON = 1;
|
||||||
|
|
||||||
public BubbleCategoryPreferenceController(Context context) {
|
public BubbleCategoryPreferenceController(Context context) {
|
||||||
super(context, null);
|
super(context, null, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return areBubblesEnabled();
|
return areBubblesEnabled() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -32,15 +32,15 @@ public class BubbleLinkPreferenceController extends NotificationPreferenceContro
|
|||||||
static final int ON = 1;
|
static final int ON = 1;
|
||||||
|
|
||||||
public BubbleLinkPreferenceController(Context context) {
|
public BubbleLinkPreferenceController(Context context) {
|
||||||
super(context, null);
|
super(context, null, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return areBubblesEnabled();
|
return areBubblesEnabled() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -56,7 +56,7 @@ public class BubblePreferenceController extends NotificationPreferenceController
|
|||||||
public BubblePreferenceController(Context context, @Nullable FragmentManager fragmentManager,
|
public BubblePreferenceController(Context context, @Nullable FragmentManager fragmentManager,
|
||||||
NotificationBackend backend, boolean isAppPage,
|
NotificationBackend backend, boolean isAppPage,
|
||||||
@Nullable NotificationSettings.DependentFieldListener listener) {
|
@Nullable NotificationSettings.DependentFieldListener listener) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
mFragmentManager = fragmentManager;
|
mFragmentManager = fragmentManager;
|
||||||
mIsAppPage = isAppPage;
|
mIsAppPage = isAppPage;
|
||||||
mListener = listener;
|
mListener = listener;
|
||||||
@@ -68,21 +68,24 @@ public class BubblePreferenceController extends NotificationPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (!mIsAppPage && !isEnabled()) {
|
if (!mIsAppPage && !isEnabled()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel != null) {
|
if (mChannel != null) {
|
||||||
if (isDefaultChannel()) {
|
if (isDefaultChannel()) {
|
||||||
return true;
|
return AVAILABLE;
|
||||||
} else {
|
} else {
|
||||||
return mAppRow != null && mAppRow.bubblePreference != BUBBLE_PREFERENCE_NONE;
|
if (mAppRow != null && mAppRow.bubblePreference != BUBBLE_PREFERENCE_NONE) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -42,28 +42,31 @@ public class BubbleSummaryPreferenceController extends NotificationPreferenceCon
|
|||||||
static final int ON = 1;
|
static final int ON = 1;
|
||||||
|
|
||||||
public BubbleSummaryPreferenceController(Context context, NotificationBackend backend) {
|
public BubbleSummaryPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel != null) {
|
if (mChannel != null) {
|
||||||
if (!isGloballyEnabled()) {
|
if (!isGloballyEnabled()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (isDefaultChannel()) {
|
if (isDefaultChannel()) {
|
||||||
return true;
|
return AVAILABLE;
|
||||||
} else {
|
} else {
|
||||||
return mAppRow != null;
|
return mAppRow != null ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return isGloballyEnabled() && mBackend.hasSentValidBubble(mAppRow.pkg, mAppRow.uid);
|
if (isGloballyEnabled() && mBackend.hasSentValidBubble(mAppRow.pkg, mAppRow.uid)) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -28,6 +28,7 @@ import android.os.AsyncTask;
|
|||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
|
import android.util.Slog;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
@@ -39,16 +40,19 @@ import androidx.preference.SwitchPreference;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.Utils;
|
import com.android.settings.Utils;
|
||||||
import com.android.settings.applications.AppInfoBase;
|
import com.android.settings.applications.AppInfoBase;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.core.SubSettingLauncher;
|
import com.android.settings.core.SubSettingLauncher;
|
||||||
import com.android.settings.notification.NotificationBackend;
|
import com.android.settings.notification.NotificationBackend;
|
||||||
import com.android.settingslib.PrimarySwitchPreference;
|
import com.android.settingslib.PrimarySwitchPreference;
|
||||||
import com.android.settingslib.RestrictedSwitchPreference;
|
import com.android.settingslib.RestrictedSwitchPreference;
|
||||||
|
import com.android.settingslib.utils.ThreadUtils;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
public class ChannelListPreferenceController extends NotificationPreferenceController {
|
public class ChannelListPreferenceController extends NotificationPreferenceController
|
||||||
|
implements BasePreferenceController.UiBlocker {
|
||||||
|
|
||||||
private static final String KEY = "channels";
|
private static final String KEY = "channels";
|
||||||
private static final String KEY_GENERAL_CATEGORY = "categories";
|
private static final String KEY_GENERAL_CATEGORY = "categories";
|
||||||
@@ -59,7 +63,7 @@ public class ChannelListPreferenceController extends NotificationPreferenceContr
|
|||||||
private PreferenceCategory mPreference;
|
private PreferenceCategory mPreference;
|
||||||
|
|
||||||
public ChannelListPreferenceController(Context context, NotificationBackend backend) {
|
public ChannelListPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -68,20 +72,20 @@ public class ChannelListPreferenceController extends NotificationPreferenceContr
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow.banned) {
|
if (mAppRow.banned) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel != null) {
|
if (mChannel != null) {
|
||||||
if (mBackend.onlyHasDefaultChannel(mAppRow.pkg, mAppRow.uid)
|
if (mBackend.onlyHasDefaultChannel(mAppRow.pkg, mAppRow.uid)
|
||||||
|| NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId())) {
|
|| NotificationChannel.DEFAULT_CHANNEL_ID.equals(mChannel.getId())) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -93,22 +97,15 @@ public class ChannelListPreferenceController extends NotificationPreferenceContr
|
|||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
mPreference = (PreferenceCategory) preference;
|
mPreference = (PreferenceCategory) preference;
|
||||||
// Load channel settings
|
// Load channel settings
|
||||||
new AsyncTask<Void, Void, Void>() {
|
ThreadUtils.postOnBackgroundThread(() -> {
|
||||||
@Override
|
|
||||||
protected Void doInBackground(Void... unused) {
|
|
||||||
mChannelGroupList = mBackend.getGroups(mAppRow.pkg, mAppRow.uid).getList();
|
mChannelGroupList = mBackend.getGroups(mAppRow.pkg, mAppRow.uid).getList();
|
||||||
Collections.sort(mChannelGroupList, CHANNEL_GROUP_COMPARATOR);
|
Collections.sort(mChannelGroupList, CHANNEL_GROUP_COMPARATOR);
|
||||||
return null;
|
ThreadUtils.getUiThreadHandler().getLooper().prepare();
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void onPostExecute(Void unused) {
|
|
||||||
if (mContext == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
updateFullList(mPreference, mChannelGroupList);
|
updateFullList(mPreference, mChannelGroupList);
|
||||||
}
|
ThreadUtils.postOnMainThread(() -> {
|
||||||
}.execute();
|
showPreferences();
|
||||||
|
});
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -144,6 +141,12 @@ public class ChannelListPreferenceController extends NotificationPreferenceContr
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void showPreferences() {
|
||||||
|
if (mUiBlockListener != null) {
|
||||||
|
mUiBlockListener.onBlockerWorkFinished(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Looks for the category for the given group's key at the expected index, if that doesn't
|
* Looks for the category for the given group's key at the expected index, if that doesn't
|
||||||
* match, it checks all groups, and if it can't find that group anywhere, it creates it.
|
* match, it checks all groups, and if it can't find that group anywhere, it creates it.
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ public class ConversationDemotePreferenceController extends NotificationPreferen
|
|||||||
public ConversationDemotePreferenceController(Context context,
|
public ConversationDemotePreferenceController(Context context,
|
||||||
SettingsPreferenceFragment hostFragment,
|
SettingsPreferenceFragment hostFragment,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
mHostFragment = hostFragment;
|
mHostFragment = hostFragment;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -47,14 +47,17 @@ public class ConversationDemotePreferenceController extends NotificationPreferen
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow == null || mChannel == null) {
|
if (mAppRow == null || mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return !TextUtils.isEmpty(mChannel.getConversationId()) && !mChannel.isDemoted();
|
if (!TextUtils.isEmpty(mChannel.getConversationId()) && !mChannel.isDemoted()) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ public class ConversationHeaderPreferenceController extends NotificationPreferen
|
|||||||
private boolean mStarted = false;
|
private boolean mStarted = false;
|
||||||
|
|
||||||
public ConversationHeaderPreferenceController(Context context, DashboardFragment fragment) {
|
public ConversationHeaderPreferenceController(Context context, DashboardFragment fragment) {
|
||||||
super(context, null);
|
super(context, null, PREF_KEY_APP_HEADER);
|
||||||
mFragment = fragment;
|
mFragment = fragment;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -55,8 +55,8 @@ public class ConversationHeaderPreferenceController extends NotificationPreferen
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
return mAppRow != null;
|
return mAppRow != null ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ public class ConversationPriorityPreferenceController extends NotificationPrefer
|
|||||||
|
|
||||||
public ConversationPriorityPreferenceController(Context context,
|
public ConversationPriorityPreferenceController(Context context,
|
||||||
NotificationBackend backend, NotificationSettings.DependentFieldListener listener) {
|
NotificationBackend backend, NotificationSettings.DependentFieldListener listener) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
mDependentFieldListener = listener;
|
mDependentFieldListener = listener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -44,14 +44,14 @@ public class ConversationPriorityPreferenceController extends NotificationPrefer
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow == null || mChannel == null) {
|
if (mAppRow == null || mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ public class ConversationPromotePreferenceController extends NotificationPrefere
|
|||||||
public ConversationPromotePreferenceController(Context context,
|
public ConversationPromotePreferenceController(Context context,
|
||||||
SettingsPreferenceFragment hostFragment,
|
SettingsPreferenceFragment hostFragment,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
mHostFragment = hostFragment;
|
mHostFragment = hostFragment;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -47,14 +47,17 @@ public class ConversationPromotePreferenceController extends NotificationPrefere
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow == null || mChannel == null) {
|
if (mAppRow == null || mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return !TextUtils.isEmpty(mChannel.getConversationId()) && mChannel.isDemoted();
|
if (!TextUtils.isEmpty(mChannel.getConversationId()) && mChannel.isDemoted()) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ public class DeletedChannelsPreferenceController extends NotificationPreferenceC
|
|||||||
private static final String KEY_DELETED = "deleted";
|
private static final String KEY_DELETED = "deleted";
|
||||||
|
|
||||||
public DeletedChannelsPreferenceController(Context context, NotificationBackend backend) {
|
public DeletedChannelsPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_DELETED);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -39,16 +39,19 @@ public class DeletedChannelsPreferenceController extends NotificationPreferenceC
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
// only visible on app screen
|
// only visible on app screen
|
||||||
if (mChannel != null || hasValidGroup()) {
|
if (mChannel != null || hasValidGroup()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return mBackend.getDeletedChannelCount(mAppRow.pkg, mAppRow.uid) > 0;
|
if (mBackend.getDeletedChannelCount(mAppRow.pkg, mAppRow.uid) > 0) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ public class DescriptionPreferenceController extends NotificationPreferenceContr
|
|||||||
private static final String KEY_DESC = "desc";
|
private static final String KEY_DESC = "desc";
|
||||||
|
|
||||||
public DescriptionPreferenceController(Context context) {
|
public DescriptionPreferenceController(Context context) {
|
||||||
super(context, null);
|
super(context, null, KEY_DESC);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -38,20 +38,20 @@ public class DescriptionPreferenceController extends NotificationPreferenceContr
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel == null && !hasValidGroup()) {
|
if (mChannel == null && !hasValidGroup()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel != null && !TextUtils.isEmpty(mChannel.getDescription())) {
|
if (mChannel != null && !TextUtils.isEmpty(mChannel.getDescription())) {
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
if (hasValidGroup() && !TextUtils.isEmpty(mChannelGroup.getDescription())) {
|
if (hasValidGroup() && !TextUtils.isEmpty(mChannelGroup.getDescription())) {
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ public class DndPreferenceController extends NotificationPreferenceController
|
|||||||
private static final String KEY_BYPASS_DND = "bypass_dnd";
|
private static final String KEY_BYPASS_DND = "bypass_dnd";
|
||||||
|
|
||||||
public DndPreferenceController(Context context, NotificationBackend backend) {
|
public DndPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_BYPASS_DND);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -40,11 +40,11 @@ public class DndPreferenceController extends NotificationPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable() || mChannel == null) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE || mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return true;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ public class HeaderPreferenceController extends NotificationPreferenceController
|
|||||||
private boolean mStarted = false;
|
private boolean mStarted = false;
|
||||||
|
|
||||||
public HeaderPreferenceController(Context context, DashboardFragment fragment) {
|
public HeaderPreferenceController(Context context, DashboardFragment fragment) {
|
||||||
super(context, null);
|
super(context, null, PREF_KEY_APP_HEADER);
|
||||||
mFragment = fragment;
|
mFragment = fragment;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -55,8 +55,8 @@ public class HeaderPreferenceController extends NotificationPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
return mAppRow != null;
|
return mAppRow != null ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ public class HighImportancePreferenceController extends NotificationPreferenceCo
|
|||||||
public HighImportancePreferenceController(Context context,
|
public HighImportancePreferenceController(Context context,
|
||||||
NotificationSettings.DependentFieldListener dependentFieldListener,
|
NotificationSettings.DependentFieldListener dependentFieldListener,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_IMPORTANCE);
|
||||||
mDependentFieldListener = dependentFieldListener;
|
mDependentFieldListener = dependentFieldListener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -47,17 +47,19 @@ public class HighImportancePreferenceController extends NotificationPreferenceCo
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel == null) {
|
if (mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (isDefaultChannel()) {
|
if (isDefaultChannel()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mChannel.getImportance() >= IMPORTANCE_DEFAULT;
|
return mChannel.getImportance() >= IMPORTANCE_DEFAULT
|
||||||
|
? AVAILABLE
|
||||||
|
: CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ public class ImportancePreferenceController extends NotificationPreferenceContro
|
|||||||
public ImportancePreferenceController(Context context,
|
public ImportancePreferenceController(Context context,
|
||||||
NotificationSettings.DependentFieldListener dependentFieldListener,
|
NotificationSettings.DependentFieldListener dependentFieldListener,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_IMPORTANCE);
|
||||||
mDependentFieldListener = dependentFieldListener;
|
mDependentFieldListener = dependentFieldListener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -48,14 +48,14 @@ public class ImportancePreferenceController extends NotificationPreferenceContro
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel == null) {
|
if (mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return !isDefaultChannel();
|
return !isDefaultChannel() ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ public class InvalidConversationInfoPreferenceController extends NotificationPre
|
|||||||
|
|
||||||
public InvalidConversationInfoPreferenceController(Context context,
|
public InvalidConversationInfoPreferenceController(Context context,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -40,17 +40,19 @@ public class InvalidConversationInfoPreferenceController extends NotificationPre
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow.banned) {
|
if (mAppRow.banned) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mBackend.isInInvalidMsgState(mAppRow.pkg, mAppRow.uid);
|
return mBackend.isInInvalidMsgState(mAppRow.pkg, mAppRow.uid)
|
||||||
|
? AVAILABLE
|
||||||
|
: CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -31,7 +31,7 @@ public class InvalidConversationPreferenceController extends NotificationPrefere
|
|||||||
private static final String KEY = "invalid_conversation_switch";
|
private static final String KEY = "invalid_conversation_switch";
|
||||||
|
|
||||||
public InvalidConversationPreferenceController(Context context, NotificationBackend backend) {
|
public InvalidConversationPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -40,17 +40,19 @@ public class InvalidConversationPreferenceController extends NotificationPrefere
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow.banned) {
|
if (mAppRow.banned) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mBackend.isInInvalidMsgState(mAppRow.pkg, mAppRow.uid);
|
return mBackend.isInInvalidMsgState(mAppRow.pkg, mAppRow.uid)
|
||||||
|
? AVAILABLE
|
||||||
|
: CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -33,7 +33,7 @@ public class LightsPreferenceController extends NotificationPreferenceController
|
|||||||
private static final String KEY_LIGHTS = "lights";
|
private static final String KEY_LIGHTS = "lights";
|
||||||
|
|
||||||
public LightsPreferenceController(Context context, NotificationBackend backend) {
|
public LightsPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_LIGHTS);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -42,16 +42,18 @@ public class LightsPreferenceController extends NotificationPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel == null) {
|
if (mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return checkCanBeVisible(NotificationManager.IMPORTANCE_DEFAULT)
|
if (checkCanBeVisible(NotificationManager.IMPORTANCE_DEFAULT) && canPulseLight()
|
||||||
&& canPulseLight()
|
&& !isDefaultChannel()) {
|
||||||
&& !isDefaultChannel();
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -37,7 +37,7 @@ public class MinImportancePreferenceController extends NotificationPreferenceCon
|
|||||||
public MinImportancePreferenceController(Context context,
|
public MinImportancePreferenceController(Context context,
|
||||||
NotificationSettings.DependentFieldListener dependentFieldListener,
|
NotificationSettings.DependentFieldListener dependentFieldListener,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_IMPORTANCE);
|
||||||
mDependentFieldListener = dependentFieldListener;
|
mDependentFieldListener = dependentFieldListener;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -47,17 +47,17 @@ public class MinImportancePreferenceController extends NotificationPreferenceCon
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel == null) {
|
if (mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (isDefaultChannel()) {
|
if (isDefaultChannel()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mChannel.getImportance() <= IMPORTANCE_LOW;
|
return mChannel.getImportance() <= IMPORTANCE_LOW ? AVAILABLE : CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -17,26 +17,24 @@
|
|||||||
package com.android.settings.notification.app;
|
package com.android.settings.notification.app;
|
||||||
|
|
||||||
import static android.app.NotificationManager.IMPORTANCE_NONE;
|
import static android.app.NotificationManager.IMPORTANCE_NONE;
|
||||||
import static android.os.UserHandle.USER_SYSTEM;
|
|
||||||
|
|
||||||
import android.annotation.Nullable;
|
import android.annotation.Nullable;
|
||||||
import android.app.NotificationChannel;
|
import android.app.NotificationChannel;
|
||||||
import android.app.NotificationChannelGroup;
|
import android.app.NotificationChannelGroup;
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.pm.ApplicationInfo;
|
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.ShortcutInfo;
|
import android.content.pm.ShortcutInfo;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
import android.provider.Settings;
|
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
import android.util.Slog;
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.notification.NotificationBackend;
|
import com.android.settings.notification.NotificationBackend;
|
||||||
import com.android.settingslib.RestrictedLockUtils;
|
import com.android.settingslib.RestrictedLockUtils;
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
|
||||||
|
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -46,7 +44,7 @@ import java.util.Objects;
|
|||||||
* Parent class for preferences appearing on notification setting pages at the app,
|
* Parent class for preferences appearing on notification setting pages at the app,
|
||||||
* notification channel group, or notification channel level.
|
* notification channel group, or notification channel level.
|
||||||
*/
|
*/
|
||||||
public abstract class NotificationPreferenceController extends AbstractPreferenceController {
|
public abstract class NotificationPreferenceController extends BasePreferenceController {
|
||||||
private static final String TAG = "ChannelPrefContr";
|
private static final String TAG = "ChannelPrefContr";
|
||||||
@Nullable
|
@Nullable
|
||||||
protected NotificationChannel mChannel;
|
protected NotificationChannel mChannel;
|
||||||
@@ -71,8 +69,11 @@ public abstract class NotificationPreferenceController extends AbstractPreferenc
|
|||||||
boolean overrideCanBlockValue;
|
boolean overrideCanBlockValue;
|
||||||
boolean overrideCanConfigureValue;
|
boolean overrideCanConfigureValue;
|
||||||
|
|
||||||
public NotificationPreferenceController(Context context, NotificationBackend backend) {
|
boolean mLoadedChannelState;
|
||||||
super(context);
|
|
||||||
|
public NotificationPreferenceController(Context context, NotificationBackend backend,
|
||||||
|
String key) {
|
||||||
|
super(context, key);
|
||||||
mContext = context;
|
mContext = context;
|
||||||
mNm = (NotificationManager) mContext.getSystemService(Context.NOTIFICATION_SERVICE);
|
mNm = (NotificationManager) mContext.getSystemService(Context.NOTIFICATION_SERVICE);
|
||||||
mBackend = backend;
|
mBackend = backend;
|
||||||
@@ -81,28 +82,30 @@ public abstract class NotificationPreferenceController extends AbstractPreferenc
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns true if field's parent object is not blocked.
|
* Returns available if field's parent object is not blocked.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mAppRow.banned) {
|
if (mAppRow.banned) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannelGroup != null) {
|
if (mChannelGroup != null) {
|
||||||
if (mChannelGroup.isBlocked()) {
|
if (mChannelGroup.isBlocked()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (mChannel != null) {
|
if (mChannel != null) {
|
||||||
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return mChannel.getImportance() != IMPORTANCE_NONE;
|
if(mChannel.getImportance() == IMPORTANCE_NONE) {
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return true;
|
}
|
||||||
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void onResume(NotificationBackend.AppRow appRow,
|
protected void onResume(NotificationBackend.AppRow appRow,
|
||||||
|
|||||||
@@ -41,6 +41,7 @@ import android.os.UserHandle;
|
|||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
import android.util.Slog;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.view.ViewTreeObserver;
|
import android.view.ViewTreeObserver;
|
||||||
@@ -129,15 +130,52 @@ abstract public class NotificationSettings extends DashboardFragment {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mPkgInfo = findPackageInfo(mPkg, mUid);
|
|
||||||
|
|
||||||
if (mPkgInfo != null) {
|
|
||||||
mUserId = UserHandle.getUserId(mUid);
|
mUserId = UserHandle.getUserId(mUid);
|
||||||
|
mPkgInfo = findPackageInfo(mPkg, mUid);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
|
if (mIntent == null && mArgs == null) {
|
||||||
|
toastAndFinish("no intent");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (mUid < 0 || TextUtils.isEmpty(mPkg) || mPkgInfo == null) {
|
||||||
|
toastAndFinish("Missing package or uid or packageinfo");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
startListeningToPackageRemove();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDestroy() {
|
||||||
|
stopListeningToPackageRemove();
|
||||||
|
super.onDestroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onResume() {
|
||||||
|
super.onResume();
|
||||||
|
if (mUid < 0 || TextUtils.isEmpty(mPkg) || mPkgInfo == null) {
|
||||||
|
toastAndFinish("Missing package or uid or packageinfo");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mPkgInfo = findPackageInfo(mPkg, mUid);
|
||||||
|
if (mPkgInfo != null) {
|
||||||
mSuspendedAppsAdmin = RestrictedLockUtilsInternal.checkIfApplicationIsSuspended(
|
mSuspendedAppsAdmin = RestrictedLockUtilsInternal.checkIfApplicationIsSuspended(
|
||||||
mContext, mPkg, mUserId);
|
mContext, mPkg, mUserId);
|
||||||
|
|
||||||
loadChannel();
|
|
||||||
loadAppRow();
|
loadAppRow();
|
||||||
|
if (mAppRow == null) {
|
||||||
|
toastAndFinish("Can't load package");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
loadChannel();
|
||||||
|
loadConversation();
|
||||||
loadChannelGroup();
|
loadChannelGroup();
|
||||||
loadPreferencesFilter();
|
loadPreferencesFilter();
|
||||||
collectConfigActivities();
|
collectConfigActivities();
|
||||||
@@ -157,55 +195,6 @@ abstract public class NotificationSettings extends DashboardFragment {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
|
||||||
super.onCreate(savedInstanceState);
|
|
||||||
|
|
||||||
if (mIntent == null && mArgs == null) {
|
|
||||||
Log.w(TAG, "No intent");
|
|
||||||
toastAndFinish();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mUid < 0 || TextUtils.isEmpty(mPkg) || mPkgInfo == null) {
|
|
||||||
Log.w(TAG, "Missing package or uid or packageinfo");
|
|
||||||
toastAndFinish();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
startListeningToPackageRemove();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onDestroy() {
|
|
||||||
stopListeningToPackageRemove();
|
|
||||||
super.onDestroy();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onResume() {
|
|
||||||
super.onResume();
|
|
||||||
if (mUid < 0 || TextUtils.isEmpty(mPkg) || mPkgInfo == null || mAppRow == null) {
|
|
||||||
Log.w(TAG, "Missing package or uid or packageinfo");
|
|
||||||
finish();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// Reload app, channel, etc onResume in case they've changed. A little wasteful if we've
|
|
||||||
// just done onAttach but better than making every preference controller reload all
|
|
||||||
// the data
|
|
||||||
loadAppRow();
|
|
||||||
if (mAppRow == null) {
|
|
||||||
Log.w(TAG, "Can't load package");
|
|
||||||
finish();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
loadChannel();
|
|
||||||
loadConversation();
|
|
||||||
loadChannelGroup();
|
|
||||||
loadPreferencesFilter();
|
|
||||||
collectConfigActivities();
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void animatePanel() {
|
protected void animatePanel() {
|
||||||
if (mPreferenceFilter != null) {
|
if (mPreferenceFilter != null) {
|
||||||
mLayoutView = getActivity().findViewById(R.id.main_content);
|
mLayoutView = getActivity().findViewById(R.id.main_content);
|
||||||
@@ -307,7 +296,8 @@ abstract public class NotificationSettings extends DashboardFragment {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void toastAndFinish() {
|
protected void toastAndFinish(String msg) {
|
||||||
|
Log.w(TAG, msg);
|
||||||
Toast.makeText(mContext, R.string.app_not_found_dlg_text, Toast.LENGTH_SHORT).show();
|
Toast.makeText(mContext, R.string.app_not_found_dlg_text, Toast.LENGTH_SHORT).show();
|
||||||
getActivity().finish();
|
getActivity().finish();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ public class NotificationsOffPreferenceController extends NotificationPreference
|
|||||||
private static final String KEY_BLOCKED_DESC = "block_desc";
|
private static final String KEY_BLOCKED_DESC = "block_desc";
|
||||||
|
|
||||||
public NotificationsOffPreferenceController(Context context) {
|
public NotificationsOffPreferenceController(Context context) {
|
||||||
super(context, null);
|
super(context, null, KEY_BLOCKED_DESC);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -39,16 +39,20 @@ public class NotificationsOffPreferenceController extends NotificationPreference
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (mAppRow == null) {
|
if (mAppRow == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
if (mPreferenceFilter != null && !isIncludedInFilter()) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
// Available only when other controllers are unavailable - this UI replaces the UI that
|
// Available only when other controllers are unavailable - this UI replaces the UI that
|
||||||
// would give more detailed notification controls.
|
// would give more detailed notification controls.
|
||||||
return !super.isAvailable();
|
if (super.getAvailabilityStatus() == AVAILABLE) {
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
|
} else {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -47,7 +47,7 @@ public class SoundPreferenceController extends NotificationPreferenceController
|
|||||||
public SoundPreferenceController(Context context, SettingsPreferenceFragment hostFragment,
|
public SoundPreferenceController(Context context, SettingsPreferenceFragment hostFragment,
|
||||||
NotificationSettings.DependentFieldListener dependentFieldListener,
|
NotificationSettings.DependentFieldListener dependentFieldListener,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_SOUND);
|
||||||
mFragment = hostFragment;
|
mFragment = hostFragment;
|
||||||
mListener = dependentFieldListener;
|
mListener = dependentFieldListener;
|
||||||
}
|
}
|
||||||
@@ -58,14 +58,17 @@ public class SoundPreferenceController extends NotificationPreferenceController
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel == null) {
|
if (mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return checkCanBeVisible(NotificationManager.IMPORTANCE_DEFAULT) && !isDefaultChannel();
|
if (checkCanBeVisible(NotificationManager.IMPORTANCE_DEFAULT) && !isDefaultChannel()) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ public class VibrationPreferenceController extends NotificationPreferenceControl
|
|||||||
private final Vibrator mVibrator;
|
private final Vibrator mVibrator;
|
||||||
|
|
||||||
public VibrationPreferenceController(Context context, NotificationBackend backend) {
|
public VibrationPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_VIBRATE);
|
||||||
mVibrator = context.getSystemService(Vibrator.class);
|
mVibrator = context.getSystemService(Vibrator.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -44,14 +44,15 @@ public class VibrationPreferenceController extends NotificationPreferenceControl
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable() || mChannel == null) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE || mChannel == null) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return checkCanBeVisible(NotificationManager.IMPORTANCE_DEFAULT)
|
if (checkCanBeVisible(NotificationManager.IMPORTANCE_DEFAULT) && !isDefaultChannel()
|
||||||
&& !isDefaultChannel()
|
&& mVibrator != null && mVibrator.hasVibrator()) {
|
||||||
&& mVibrator != null
|
return AVAILABLE;
|
||||||
&& mVibrator.hasVibrator();
|
}
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -48,7 +48,7 @@ public class VisibilityPreferenceController extends NotificationPreferenceContro
|
|||||||
|
|
||||||
public VisibilityPreferenceController(Context context, LockPatternUtils utils,
|
public VisibilityPreferenceController(Context context, LockPatternUtils utils,
|
||||||
NotificationBackend backend) {
|
NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, KEY_VISIBILITY_OVERRIDE);
|
||||||
mLockPatternUtils = utils;
|
mLockPatternUtils = utils;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -58,14 +58,18 @@ public class VisibilityPreferenceController extends NotificationPreferenceContro
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public int getAvailabilityStatus() {
|
||||||
if (!super.isAvailable()) {
|
if (super.getAvailabilityStatus() == CONDITIONALLY_UNAVAILABLE) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
if (mChannel == null || mAppRow.banned) {
|
if (mChannel == null || mAppRow.banned) {
|
||||||
return false;
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
return checkCanBeVisible(NotificationManager.IMPORTANCE_LOW) && isLockScreenSecure();
|
if (checkCanBeVisible(NotificationManager.IMPORTANCE_LOW) && isLockScreenSecure()) {
|
||||||
|
return AVAILABLE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return CONDITIONALLY_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -50,16 +50,6 @@ public class ZenModeAutomationSettings extends ZenModeSettingsBase {
|
|||||||
private String[] mDeleteDialogRuleIds;
|
private String[] mDeleteDialogRuleIds;
|
||||||
private boolean[] mDeleteDialogChecked;
|
private boolean[] mDeleteDialogChecked;
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onAttach(Context context) {
|
|
||||||
super.onAttach(context);
|
|
||||||
Bundle bundle = getArguments();
|
|
||||||
if (bundle != null && bundle.containsKey(DELETE)) {
|
|
||||||
mBackend.removeZenRule(bundle.getString(DELETE));
|
|
||||||
bundle.remove(DELETE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
||||||
ZenServiceListing serviceListing = new ZenServiceListing(getContext(), CONFIG);
|
ZenServiceListing serviceListing = new ZenServiceListing(getContext(), CONFIG);
|
||||||
|
|||||||
@@ -103,8 +103,7 @@ public class ZenRuleButtonsPreferenceController extends AbstractZenModePreferenc
|
|||||||
new ZenDeleteRuleDialog.PositiveClickListener() {
|
new ZenDeleteRuleDialog.PositiveClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onOk(String id) {
|
public void onOk(String id) {
|
||||||
Bundle bundle = new Bundle();
|
mBackend.removeZenRule(id);
|
||||||
bundle.putString(ZenModeAutomationSettings.DELETE, id);
|
|
||||||
mMetricsFeatureProvider.action(mContext,
|
mMetricsFeatureProvider.action(mContext,
|
||||||
SettingsEnums.ACTION_ZEN_DELETE_RULE_OK);
|
SettingsEnums.ACTION_ZEN_DELETE_RULE_OK);
|
||||||
new SubSettingLauncher(mContext)
|
new SubSettingLauncher(mContext)
|
||||||
@@ -112,7 +111,6 @@ public class ZenRuleButtonsPreferenceController extends AbstractZenModePreferenc
|
|||||||
.setDestination(ZenModeAutomationSettings.class.getName())
|
.setDestination(ZenModeAutomationSettings.class.getName())
|
||||||
.setSourceMetricsCategory(MetricsProto.MetricsEvent
|
.setSourceMetricsCategory(MetricsProto.MetricsEvent
|
||||||
.NOTIFICATION_ZEN_MODE_AUTOMATION)
|
.NOTIFICATION_ZEN_MODE_AUTOMATION)
|
||||||
.setArguments(bundle)
|
|
||||||
.launch();
|
.launch();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -22,7 +22,6 @@ import android.content.Context;
|
|||||||
import android.content.res.TypedArray;
|
import android.content.res.TypedArray;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.ViewGroup;
|
|
||||||
import android.widget.Switch;
|
import android.widget.Switch;
|
||||||
|
|
||||||
import androidx.core.content.res.TypedArrayUtils;
|
import androidx.core.content.res.TypedArrayUtils;
|
||||||
@@ -35,8 +34,6 @@ import com.android.settingslib.RestrictedPreferenceHelper;
|
|||||||
import com.android.settingslib.core.instrumentation.SettingsJankMonitor;
|
import com.android.settingslib.core.instrumentation.SettingsJankMonitor;
|
||||||
import com.android.settingslib.widget.OnMainSwitchChangeListener;
|
import com.android.settingslib.widget.OnMainSwitchChangeListener;
|
||||||
|
|
||||||
import com.google.android.setupdesign.util.LayoutStyler;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@@ -52,7 +49,6 @@ public class SettingsMainSwitchPreference extends TwoStatePreference implements
|
|||||||
new ArrayList<>();
|
new ArrayList<>();
|
||||||
private final List<OnMainSwitchChangeListener> mSwitchChangeListeners = new ArrayList<>();
|
private final List<OnMainSwitchChangeListener> mSwitchChangeListeners = new ArrayList<>();
|
||||||
|
|
||||||
private boolean mApplyPartnerCustomizationPaddingStyle;
|
|
||||||
private SettingsMainSwitchBar mMainSwitchBar;
|
private SettingsMainSwitchBar mMainSwitchBar;
|
||||||
private CharSequence mTitle;
|
private CharSequence mTitle;
|
||||||
private EnforcedAdmin mEnforcedAdmin;
|
private EnforcedAdmin mEnforcedAdmin;
|
||||||
@@ -100,12 +96,6 @@ public class SettingsMainSwitchPreference extends TwoStatePreference implements
|
|||||||
} else {
|
} else {
|
||||||
mMainSwitchBar.hide();
|
mMainSwitchBar.hide();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mApplyPartnerCustomizationPaddingStyle) {
|
|
||||||
// TODO(b/232494666): Replace all margins of the root view with the padding
|
|
||||||
final ViewGroup parentView = (ViewGroup) mMainSwitchBar.getParent();
|
|
||||||
LayoutStyler.applyPartnerCustomizationLayoutPaddingStyle(parentView);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void init(Context context, AttributeSet attrs) {
|
private void init(Context context, AttributeSet attrs) {
|
||||||
@@ -253,14 +243,6 @@ public class SettingsMainSwitchPreference extends TwoStatePreference implements
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Apples the padding style of the partner's customization. It's used in the SetupWizard.
|
|
||||||
*/
|
|
||||||
public void applyPartnerCustomizationPaddingStyle() {
|
|
||||||
mApplyPartnerCustomizationPaddingStyle = true;
|
|
||||||
notifyChanged();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void initMainSwitchBar() {
|
private void initMainSwitchBar() {
|
||||||
if (mMainSwitchBar != null) {
|
if (mMainSwitchBar != null) {
|
||||||
mMainSwitchBar.setTitle(mTitle);
|
mMainSwitchBar.setTitle(mTitle);
|
||||||
|
|||||||
@@ -1,220 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2021 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.gestures;
|
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
|
||||||
|
|
||||||
import static org.mockito.ArgumentMatchers.anyInt;
|
|
||||||
import static org.mockito.Mockito.mock;
|
|
||||||
import static org.mockito.Mockito.spy;
|
|
||||||
import static org.mockito.Mockito.verify;
|
|
||||||
import static org.mockito.Mockito.when;
|
|
||||||
|
|
||||||
import android.app.Application;
|
|
||||||
import android.content.res.Resources;
|
|
||||||
import android.provider.Settings;
|
|
||||||
|
|
||||||
import androidx.annotation.StringRes;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
|
||||||
import org.junit.Test;
|
|
||||||
import org.junit.runner.RunWith;
|
|
||||||
import org.mockito.MockitoAnnotations;
|
|
||||||
import org.mockito.stubbing.Answer;
|
|
||||||
import org.robolectric.RobolectricTestRunner;
|
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
|
||||||
public class LongPressPowerButtonPreferenceControllerTest {
|
|
||||||
|
|
||||||
private static final String KEY_LONG_PRESS_POWER_BUTTON =
|
|
||||||
"gesture_power_menu_long_press_for_assist";
|
|
||||||
|
|
||||||
private Application mContext;
|
|
||||||
private Resources mResources;
|
|
||||||
private LongPressPowerButtonPreferenceController mController;
|
|
||||||
|
|
||||||
@Before
|
|
||||||
public void setUp() {
|
|
||||||
MockitoAnnotations.initMocks(this);
|
|
||||||
mContext = spy(ApplicationProvider.getApplicationContext());
|
|
||||||
mResources = mock(Resources.class);
|
|
||||||
when(mContext.getResources()).thenReturn(mResources);
|
|
||||||
when(mResources.getString(anyInt())).thenAnswer((Answer<String>) invocation -> {
|
|
||||||
int id = invocation.getArgument(0);
|
|
||||||
return getString(id);
|
|
||||||
});
|
|
||||||
when(mResources.getBoolean(
|
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable))
|
|
||||||
.thenReturn(true);
|
|
||||||
mController = new LongPressPowerButtonPreferenceController(mContext,
|
|
||||||
KEY_LONG_PRESS_POWER_BUTTON);
|
|
||||||
mController.mAssistSwitch = mock(Preference.class);
|
|
||||||
mController.mFooterHint = mock(Preference.class);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void isAvailable_configIsTrue_shouldReturnTrue() {
|
|
||||||
when(mResources.getBoolean(
|
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable))
|
|
||||||
.thenReturn(true);
|
|
||||||
|
|
||||||
assertThat(mController.isAvailable()).isTrue();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void isAvailable_configIsFalse_shouldReturnFalse() {
|
|
||||||
when(mResources.getBoolean(
|
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable))
|
|
||||||
.thenReturn(false);
|
|
||||||
|
|
||||||
assertThat(mController.isAvailable()).isFalse();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceChecked_powerMenuHintTextShown() {
|
|
||||||
mController.onPreferenceChange(null, true);
|
|
||||||
|
|
||||||
verify(mController.mFooterHint).setSummary(
|
|
||||||
getString(
|
|
||||||
R.string.power_menu_power_volume_up_hint));
|
|
||||||
verify(mController.mFooterHint).setVisible(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceUnchecked_keyChordEnabled_powerMenuHintTextShown() {
|
|
||||||
when(mResources.getInteger(
|
|
||||||
com.android.internal.R.integer.config_keyChordPowerVolumeUp))
|
|
||||||
.thenReturn(
|
|
||||||
LongPressPowerButtonPreferenceController.KEY_CHORD_POWER_VOLUME_UP_GLOBAL_ACTIONS);
|
|
||||||
|
|
||||||
mController.onPreferenceChange(null, false);
|
|
||||||
|
|
||||||
verify(mController.mFooterHint).setSummary(
|
|
||||||
getString(
|
|
||||||
R.string.power_menu_power_volume_up_hint));
|
|
||||||
verify(mController.mFooterHint).setVisible(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceChecked_hushGestureEnabled_powerMenuHintTextIncludesHushHint() {
|
|
||||||
when(mResources.getBoolean(
|
|
||||||
com.android.internal.R.bool.config_volumeHushGestureEnabled))
|
|
||||||
.thenReturn(true);
|
|
||||||
|
|
||||||
mController.onPreferenceChange(null, true);
|
|
||||||
|
|
||||||
verify(mController.mFooterHint).setSummary(
|
|
||||||
getString(
|
|
||||||
R.string.power_menu_power_volume_up_hint) + "\n\n"
|
|
||||||
+ getString(
|
|
||||||
R.string.power_menu_power_prevent_ringing_hint));
|
|
||||||
verify(mController.mFooterHint).setVisible(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceUnchecked_keyChordDisabled_powerMenuHintTextHidden() {
|
|
||||||
mController.onPreferenceChange(null, false);
|
|
||||||
when(mResources.getInteger(
|
|
||||||
com.android.internal.R.integer.config_keyChordPowerVolumeUp))
|
|
||||||
.thenReturn(
|
|
||||||
LongPressPowerButtonPreferenceController.KEY_CHORD_POWER_VOLUME_UP_NO_ACTION);
|
|
||||||
|
|
||||||
verify(mController.mFooterHint).setVisible(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceChecked_longPressPowerSettingSetToAssistant() {
|
|
||||||
mController.onPreferenceChange(null, true);
|
|
||||||
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS, -1)).isEqualTo(
|
|
||||||
PowerMenuSettingsUtils.LONG_PRESS_POWER_ASSISTANT_VALUE);
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.KEY_CHORD_POWER_VOLUME_UP, -1)).isEqualTo(
|
|
||||||
LongPressPowerButtonPreferenceController.KEY_CHORD_POWER_VOLUME_UP_GLOBAL_ACTIONS);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceUnchecked_longPressPowerSettingSetToDefaultValue() {
|
|
||||||
when(mResources.getInteger(
|
|
||||||
com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
|
||||||
.thenReturn(
|
|
||||||
PowerMenuSettingsUtils.LONG_PRESS_POWER_GLOBAL_ACTIONS);
|
|
||||||
|
|
||||||
mController.onPreferenceChange(null, false);
|
|
||||||
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS, -1)).isEqualTo(
|
|
||||||
PowerMenuSettingsUtils.LONG_PRESS_POWER_GLOBAL_ACTIONS);
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.KEY_CHORD_POWER_VOLUME_UP, -1)).isEqualTo(
|
|
||||||
LongPressPowerButtonPreferenceController.KEY_CHORD_POWER_VOLUME_UP_NO_ACTION);
|
|
||||||
verify(mController.mAssistSwitch).setSummary(
|
|
||||||
getString(
|
|
||||||
R.string.power_menu_summary_long_press_for_assist_disabled_with_power_menu));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceUnchecked_muteChordDefault_longPressPowerSettingSetToDefaultValue() {
|
|
||||||
// Value out of range chosen deliberately.
|
|
||||||
when(mResources.getInteger(
|
|
||||||
com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
|
||||||
.thenReturn(8);
|
|
||||||
when(mResources.getInteger(
|
|
||||||
com.android.internal.R.integer.config_keyChordPowerVolumeUp))
|
|
||||||
.thenReturn(
|
|
||||||
LongPressPowerButtonPreferenceController.KEY_CHORD_POWER_VOLUME_UP_MUTE_TOGGLE);
|
|
||||||
|
|
||||||
mController.onPreferenceChange(null, false);
|
|
||||||
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS, -1)).isEqualTo(8);
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.KEY_CHORD_POWER_VOLUME_UP, -1)).isEqualTo(
|
|
||||||
LongPressPowerButtonPreferenceController.KEY_CHORD_POWER_VOLUME_UP_MUTE_TOGGLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void preferenceUnchecked_assistDefault_setNoAction() {
|
|
||||||
// Ensure that the Assistant is the default behavior for LPP.
|
|
||||||
when(mResources.getInteger(
|
|
||||||
com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
|
||||||
.thenReturn(
|
|
||||||
PowerMenuSettingsUtils.LONG_PRESS_POWER_ASSISTANT_VALUE);
|
|
||||||
|
|
||||||
mController.onPreferenceChange(null, false);
|
|
||||||
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS, -1)).isEqualTo(
|
|
||||||
PowerMenuSettingsUtils.LONG_PRESS_POWER_GLOBAL_ACTIONS);
|
|
||||||
assertThat(Settings.Global.getInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.KEY_CHORD_POWER_VOLUME_UP, -1)).isEqualTo(
|
|
||||||
LongPressPowerButtonPreferenceController.KEY_CHORD_POWER_VOLUME_UP_NO_ACTION);
|
|
||||||
verify(mController.mAssistSwitch).setSummary(getString(
|
|
||||||
R.string.power_menu_summary_long_press_for_assist_disabled_with_power_menu));
|
|
||||||
}
|
|
||||||
|
|
||||||
private String getString(@StringRes int id) {
|
|
||||||
return ApplicationProvider.getApplicationContext().getString(id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -0,0 +1,115 @@
|
|||||||
|
/*
|
||||||
|
* 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.gestures;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.Application;
|
||||||
|
import android.content.res.Resources;
|
||||||
|
import android.text.TextUtils;
|
||||||
|
|
||||||
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settingslib.widget.FooterPreference;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class LongPressPowerFooterPreferenceControllerTest {
|
||||||
|
|
||||||
|
private Application mContext;
|
||||||
|
private Resources mResources;
|
||||||
|
private Preference mPreference;
|
||||||
|
private LongPressPowerFooterPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||||
|
mResources = spy(mContext.getResources());
|
||||||
|
when(mContext.getResources()).thenReturn(mResources);
|
||||||
|
mPreference = new FooterPreference(mContext);
|
||||||
|
mController = new LongPressPowerFooterPreferenceController(mContext, "test_key");
|
||||||
|
|
||||||
|
PreferenceScreen mScreen = mock(PreferenceScreen.class);
|
||||||
|
when(mScreen.findPreference("test_key")).thenReturn(mPreference);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_longPressPowerForPowerMenu_hidesPreference() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.isVisible()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_longPressPowerForAssistant_showsPreference() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.isVisible()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_notEligible_showsPreference() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.isVisible()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_hushGestureEnabled_includesPreventRingingHint() {
|
||||||
|
when(mResources.getBoolean(com.android.internal.R.bool.config_volumeHushGestureEnabled))
|
||||||
|
.thenReturn(true);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.getSummary().toString())
|
||||||
|
.isEqualTo(
|
||||||
|
TextUtils.concat(
|
||||||
|
mContext.getString(R.string.power_menu_power_volume_up_hint),
|
||||||
|
"\n\n",
|
||||||
|
mContext.getString(
|
||||||
|
R.string.power_menu_power_prevent_ringing_hint)));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_hushGestureDisabled_doesNotIncludePreventRingingHint() {
|
||||||
|
when(mResources.getBoolean(com.android.internal.R.bool.config_volumeHushGestureEnabled))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.getSummary().toString())
|
||||||
|
.isEqualTo(mContext.getString(R.string.power_menu_power_volume_up_hint));
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,116 @@
|
|||||||
|
/*
|
||||||
|
* 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.gestures;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.Application;
|
||||||
|
import android.content.res.Resources;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class LongPressPowerForAssistantPreferenceControllerTest {
|
||||||
|
|
||||||
|
private Application mContext;
|
||||||
|
private Resources mResources;
|
||||||
|
private SelectorWithWidgetPreference mPreference;
|
||||||
|
private LongPressPowerForAssistantPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||||
|
mResources = spy(mContext.getResources());
|
||||||
|
mPreference = new SelectorWithWidgetPreference(mContext);
|
||||||
|
mController = new LongPressPowerForAssistantPreferenceController(mContext, "test_key");
|
||||||
|
|
||||||
|
when(mContext.getResources()).thenReturn(mResources);
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(true);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(5); // Default to Assistant
|
||||||
|
|
||||||
|
PreferenceScreen mScreen = mock(PreferenceScreen.class);
|
||||||
|
when(mScreen.findPreference("test_key")).thenReturn(mPreference);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mController.onStart();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void initialState_longPressPowerForPowerMenu_preferenceNotChecked() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.isChecked()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void initialState_longPressPowerForAssistant_preferenceChecked() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.isChecked()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_longPressPowerSettingAvailable_returnsAvailable() {
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(BasePreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_longPressPowerSettingNotAvailable_returnsNotAvailable() {
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(BasePreferenceController.UNSUPPORTED_ON_DEVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onClick_updatesSettingsValue_checksPreference() {
|
||||||
|
// Initial state: preference not checked
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isFalse();
|
||||||
|
assertThat(mPreference.isChecked()).isFalse();
|
||||||
|
|
||||||
|
mPreference.performClick();
|
||||||
|
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isTrue();
|
||||||
|
assertThat(mPreference.isChecked()).isTrue();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,116 @@
|
|||||||
|
/*
|
||||||
|
* 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.gestures;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.Application;
|
||||||
|
import android.content.res.Resources;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
import com.android.settingslib.widget.SelectorWithWidgetPreference;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class LongPressPowerForPowerMenuPreferenceControllerTest {
|
||||||
|
|
||||||
|
private Application mContext;
|
||||||
|
private Resources mResources;
|
||||||
|
private SelectorWithWidgetPreference mPreference;
|
||||||
|
private LongPressPowerForPowerMenuPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||||
|
mResources = spy(mContext.getResources());
|
||||||
|
mPreference = new SelectorWithWidgetPreference(mContext);
|
||||||
|
mController = new LongPressPowerForPowerMenuPreferenceController(mContext, "test_key");
|
||||||
|
|
||||||
|
when(mContext.getResources()).thenReturn(mResources);
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(true);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(5); // Default to Assistant
|
||||||
|
|
||||||
|
PreferenceScreen mScreen = mock(PreferenceScreen.class);
|
||||||
|
when(mScreen.findPreference("test_key")).thenReturn(mPreference);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mController.onStart();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void initialState_longPressPowerForPowerMenu_preferenceChecked() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.isChecked()).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void initialState_longPressPowerForAssistant_preferenceNotChecked() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.isChecked()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_longPressPowerSettingAvailable_returnsAvailable() {
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(BasePreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_longPressPowerSettingNotAvailable_returnsNotAvailable() {
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(BasePreferenceController.UNSUPPORTED_ON_DEVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onClick_updatesSettingsValue_checksPreference() {
|
||||||
|
// Initial state: preference not checked
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isTrue();
|
||||||
|
assertThat(mPreference.isChecked()).isFalse();
|
||||||
|
|
||||||
|
mPreference.performClick();
|
||||||
|
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isFalse();
|
||||||
|
assertThat(mPreference.isChecked()).isTrue();
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,74 @@
|
|||||||
|
/*
|
||||||
|
* 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.gestures;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.Application;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
|
import com.android.settingslib.widget.IllustrationPreference;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
|
||||||
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
public class LongPressPowerIllustrationPreferenceControllerTest {
|
||||||
|
|
||||||
|
private Application mContext;
|
||||||
|
private IllustrationPreference mPreference;
|
||||||
|
private LongPressPowerIllustrationPreferenceController mController;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
mContext = ApplicationProvider.getApplicationContext();
|
||||||
|
mPreference = new IllustrationPreference(mContext);
|
||||||
|
mController = new LongPressPowerIllustrationPreferenceController(mContext, "test_key");
|
||||||
|
|
||||||
|
PreferenceScreen mScreen = mock(PreferenceScreen.class);
|
||||||
|
when(mScreen.findPreference("test_key")).thenReturn(mPreference);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_longPressPowerForPowerMenu_showsPowerMenuAnimation() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.getLottieAnimationResId())
|
||||||
|
.isEqualTo(R.raw.lottie_long_press_power_for_power_menu);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void updateState_longPressPowerForAssistant_showsAssistantAnimation() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mPreference.getLottieAnimationResId())
|
||||||
|
.isEqualTo(R.raw.lottie_long_press_power_for_assistant);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -26,14 +26,20 @@ import android.app.Application;
|
|||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.widget.LabeledSeekBarPreference;
|
||||||
|
import com.android.settingslib.testutils.shadow.ShadowInteractionJankMonitor;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
|
@Config(shadows = {ShadowInteractionJankMonitor.class})
|
||||||
public class LongPressPowerSensitivityPreferenceControllerTest {
|
public class LongPressPowerSensitivityPreferenceControllerTest {
|
||||||
|
|
||||||
private static final String KEY_LONG_PRESS_SENSITIVITY =
|
private static final String KEY_LONG_PRESS_SENSITIVITY =
|
||||||
@@ -43,7 +49,9 @@ public class LongPressPowerSensitivityPreferenceControllerTest {
|
|||||||
|
|
||||||
private Application mContext;
|
private Application mContext;
|
||||||
private Resources mResources;
|
private Resources mResources;
|
||||||
|
private LabeledSeekBarPreference mPreference;
|
||||||
private LongPressPowerSensitivityPreferenceController mController;
|
private LongPressPowerSensitivityPreferenceController mController;
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
@@ -54,9 +62,20 @@ public class LongPressPowerSensitivityPreferenceControllerTest {
|
|||||||
when(mResources.getIntArray(
|
when(mResources.getIntArray(
|
||||||
com.android.internal.R.array.config_longPressOnPowerDurationSettings))
|
com.android.internal.R.array.config_longPressOnPowerDurationSettings))
|
||||||
.thenReturn(SENSITIVITY_VALUES);
|
.thenReturn(SENSITIVITY_VALUES);
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(true);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(5); // Default to Assistant
|
||||||
|
|
||||||
|
mPreference = new LabeledSeekBarPreference(mContext, null);
|
||||||
mController = new LongPressPowerSensitivityPreferenceController(mContext,
|
mController = new LongPressPowerSensitivityPreferenceController(mContext,
|
||||||
KEY_LONG_PRESS_SENSITIVITY);
|
KEY_LONG_PRESS_SENSITIVITY);
|
||||||
|
|
||||||
|
mScreen = mock(PreferenceScreen.class);
|
||||||
|
when(mScreen.findPreference(KEY_LONG_PRESS_SENSITIVITY)).thenReturn(mPreference);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -98,46 +117,64 @@ public class LongPressPowerSensitivityPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void longPressForAssistEnabled_isAvailable() {
|
public void longPressForAssistant_isVisible() {
|
||||||
Settings.Global.putInt(mContext.getContentResolver(),
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS,
|
|
||||||
PowerMenuSettingsUtils.LONG_PRESS_POWER_ASSISTANT_VALUE);
|
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
mController.updateState(mPreference);
|
||||||
LongPressPowerSensitivityPreferenceController.AVAILABLE);
|
|
||||||
|
assertThat(mPreference.isVisible()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void longPressForAssistDisabled_isNotAvailableDueToDependentSetting() {
|
public void longPressForPowerMenu_isHidden() {
|
||||||
Settings.Global.putInt(mContext.getContentResolver(),
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS,
|
|
||||||
PowerMenuSettingsUtils.LONG_PRESS_POWER_NO_ACTION);
|
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
mController.updateState(mPreference);
|
||||||
LongPressPowerSensitivityPreferenceController.DISABLED_DEPENDENT_SETTING);
|
|
||||||
|
assertThat(mPreference.isVisible()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void sensitivityValuesAreNull_notAvailable() {
|
public void longPressPowerSettingNotAvailable_notAvailable_isHidden() {
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(false);
|
||||||
|
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(LongPressPowerSensitivityPreferenceController.UNSUPPORTED_ON_DEVICE);
|
||||||
|
assertThat(mPreference.isVisible()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void sensitivityValuesAreNull_notAvailable_isHidden() {
|
||||||
when(mResources.getIntArray(
|
when(mResources.getIntArray(
|
||||||
com.android.internal.R.array.config_longPressOnPowerDurationSettings))
|
com.android.internal.R.array.config_longPressOnPowerDurationSettings))
|
||||||
.thenReturn(null);
|
.thenReturn(null);
|
||||||
mController = new LongPressPowerSensitivityPreferenceController(mContext,
|
mController = new LongPressPowerSensitivityPreferenceController(mContext,
|
||||||
KEY_LONG_PRESS_SENSITIVITY);
|
KEY_LONG_PRESS_SENSITIVITY);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
||||||
LongPressPowerSensitivityPreferenceController.UNSUPPORTED_ON_DEVICE);
|
LongPressPowerSensitivityPreferenceController.UNSUPPORTED_ON_DEVICE);
|
||||||
|
assertThat(mPreference.isVisible()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void sensitivityValuesArrayTooShort_notAvailable() {
|
public void sensitivityValuesArrayTooShort_notAvailable_isHidden() {
|
||||||
when(mResources.getIntArray(
|
when(mResources.getIntArray(
|
||||||
com.android.internal.R.array.config_longPressOnPowerDurationSettings))
|
com.android.internal.R.array.config_longPressOnPowerDurationSettings))
|
||||||
.thenReturn(new int[]{200});
|
.thenReturn(new int[]{200});
|
||||||
mController = new LongPressPowerSensitivityPreferenceController(mContext,
|
mController = new LongPressPowerSensitivityPreferenceController(mContext,
|
||||||
KEY_LONG_PRESS_SENSITIVITY);
|
KEY_LONG_PRESS_SENSITIVITY);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
||||||
LongPressPowerSensitivityPreferenceController.UNSUPPORTED_ON_DEVICE);
|
LongPressPowerSensitivityPreferenceController.UNSUPPORTED_ON_DEVICE);
|
||||||
|
assertThat(mPreference.isVisible()).isFalse();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,20 +18,21 @@ package com.android.settings.gestures;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.mockito.Mockito.mock;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.res.Resources;
|
import android.content.res.Resources;
|
||||||
|
|
||||||
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
|
||||||
|
|
||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class PowerMenuPreferenceControllerTest {
|
public class PowerMenuPreferenceControllerTest {
|
||||||
@@ -41,35 +42,75 @@ public class PowerMenuPreferenceControllerTest {
|
|||||||
|
|
||||||
private static final String KEY_GESTURE_POWER_MENU = "gesture_power_menu";
|
private static final String KEY_GESTURE_POWER_MENU = "gesture_power_menu";
|
||||||
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mContext = spy(RuntimeEnvironment.application);
|
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||||
mResources = mock(Resources.class);
|
mResources = spy(mContext.getResources());
|
||||||
when(mResources.getBoolean(
|
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable))
|
|
||||||
.thenReturn(true);
|
|
||||||
when(mContext.getResources()).thenReturn(mResources);
|
|
||||||
mController = new PowerMenuPreferenceController(mContext, KEY_GESTURE_POWER_MENU);
|
mController = new PowerMenuPreferenceController(mContext, KEY_GESTURE_POWER_MENU);
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
when(mContext.getResources()).thenReturn(mResources);
|
||||||
public void getAvailabilityStatus_assistAvailable_available() {
|
|
||||||
when(mResources.getBoolean(
|
when(mResources.getBoolean(
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable))
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
.thenReturn(true);
|
.thenReturn(true);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
.thenReturn(1); // Default to power menu
|
||||||
BasePreferenceController.AVAILABLE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getAvailabilityStatus_assistUnavailable_unavailable() {
|
public void getAvailabilityStatus_settingsAvailable_returnsAvailable() {
|
||||||
when(mResources.getBoolean(
|
when(mResources.getBoolean(
|
||||||
com.android.internal.R.bool.config_longPressOnPowerForAssistantSettingAvailable))
|
com.android.internal.R.bool
|
||||||
.thenReturn(false);
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(true);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(1); // Default to power menu
|
||||||
|
|
||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(
|
assertThat(mController.getAvailabilityStatus())
|
||||||
BasePreferenceController.UNSUPPORTED_ON_DEVICE);
|
.isEqualTo(BasePreferenceController.AVAILABLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_settingsNotAvailable_returnsNotAvailable() {
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(false);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(1); // Default to power menu
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(BasePreferenceController.UNSUPPORTED_ON_DEVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getAvailabilityStatus_longPressPowerSettingNotAvailable_returnsNotAvailable() {
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(true);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(3); // Default to power off (unsupported setup)
|
||||||
|
|
||||||
|
assertThat(mController.getAvailabilityStatus())
|
||||||
|
.isEqualTo(BasePreferenceController.UNSUPPORTED_ON_DEVICE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getSummary_longPressPowerToAssistant_returnsNotAvailable() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
|
||||||
|
assertThat(mController.getSummary().toString())
|
||||||
|
.isEqualTo(
|
||||||
|
mContext.getString(R.string.power_menu_summary_long_press_for_assistant));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getSummary_longPressPowerToPowerMenu_returnsNotAvailable() {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
|
||||||
|
assertThat(mController.getSummary().toString())
|
||||||
|
.isEqualTo(
|
||||||
|
mContext.getString(R.string.power_menu_summary_long_press_for_power_menu));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -44,48 +44,123 @@ public class PowerMenuSettingsUtilsTest {
|
|||||||
mContext = spy(ApplicationProvider.getApplicationContext());
|
mContext = spy(ApplicationProvider.getApplicationContext());
|
||||||
mResources = mock(Resources.class);
|
mResources = mock(Resources.class);
|
||||||
when(mContext.getResources()).thenReturn(mResources);
|
when(mContext.getResources()).thenReturn(mResources);
|
||||||
|
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void longPressBehaviourValuePresent_returnsValue() {
|
public void isLongPressPowerForAssistantEnabled_valueSetToAssistant_returnsTrue() {
|
||||||
when(mResources.getInteger(
|
Settings.Global.putInt(
|
||||||
com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
mContext.getContentResolver(), Settings.Global.POWER_BUTTON_LONG_PRESS, 5);
|
||||||
.thenReturn(0);
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isTrue();
|
||||||
Settings.Global.putInt(mContext.getContentResolver(),
|
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS, 1);
|
|
||||||
|
|
||||||
assertThat(PowerMenuSettingsUtils.getPowerButtonSettingValue(mContext)).isEqualTo(1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void longPressBehaviourValueNotPresent_returnsDefault() {
|
public void isLongPressPowerForAssistantEnabled_valueNotSetToAssistant_returnsFalse() {
|
||||||
when(mResources.getInteger(
|
Settings.Global.putInt(
|
||||||
com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
mContext.getContentResolver(), Settings.Global.POWER_BUTTON_LONG_PRESS, 3);
|
||||||
.thenReturn(2);
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isFalse();
|
||||||
|
|
||||||
assertThat(PowerMenuSettingsUtils.getPowerButtonSettingValue(mContext)).isEqualTo(2);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void longPressBehaviourValueSetToAssistant_isAssistEnabledReturnsTrue() {
|
public void isLongPressPowerForAssistantEnabled_valueNotSet_defaultToAssistant_returnsTrue() {
|
||||||
Settings.Global.putInt(mContext.getContentResolver(),
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS, 5);
|
.thenReturn(5);
|
||||||
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistEnabled(mContext)).isTrue();
|
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void longPressBehaviourValueNotSetToAssistant_isAssistEnabledReturnsFalse() {
|
public void isLongPressPowerForAssistantEnabled_valueNotSet_defaultToPowerMenu_returnsFalse() {
|
||||||
Settings.Global.putInt(mContext.getContentResolver(),
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
Settings.Global.POWER_BUTTON_LONG_PRESS, 3);
|
.thenReturn(1);
|
||||||
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistEnabled(mContext)).isFalse();
|
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistantEnabled(mContext)).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void longPressBehaviourDefaultSetToAssistant_isAssistEnabledReturnsFalse() {
|
public void isLongPressPowerSettingAvailable_defaultToAssistant_returnsTrue() {
|
||||||
when(mResources.getInteger(
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
.thenReturn(5);
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void isLongPressPowerSettingAvailable_defaultToPowerMenu_returnsTrue() {
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(1);
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)).isTrue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void isLongPressPowerSettingAvailable_defaultToPowerOff_returnsFalse() {
|
||||||
|
// Power off is the unsupported option in long press power settings
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
.thenReturn(3);
|
.thenReturn(3);
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
assertThat(PowerMenuSettingsUtils.isLongPressPowerForAssistEnabled(mContext)).isFalse();
|
@Test
|
||||||
|
public void isLongPressPowerSettingAvailable_settingDisabled_returnsFalse() {
|
||||||
|
// Disable the setting
|
||||||
|
when(mResources.getBoolean(
|
||||||
|
com.android.internal.R.bool
|
||||||
|
.config_longPressOnPowerForAssistantSettingAvailable))
|
||||||
|
.thenReturn(false);
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_longPressOnPowerBehavior))
|
||||||
|
.thenReturn(1);
|
||||||
|
|
||||||
|
assertThat(PowerMenuSettingsUtils.isLongPressPowerSettingAvailable(mContext)).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void setLongPressPowerForAssistant_updatesValue() throws Exception {
|
||||||
|
boolean result = PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
|
||||||
|
assertThat(result).isTrue();
|
||||||
|
assertThat(
|
||||||
|
Settings.Global.getInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
Settings.Global.POWER_BUTTON_LONG_PRESS))
|
||||||
|
.isEqualTo(5);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void setLongPressPowerForAssistant_updatesKeyChordValueToPowerMenu() throws Exception {
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForAssistant(mContext);
|
||||||
|
assertThat(
|
||||||
|
Settings.Global.getInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
Settings.Global.KEY_CHORD_POWER_VOLUME_UP))
|
||||||
|
.isEqualTo(2);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void setLongPressPowerForPowerMenu_updatesValue() throws Exception {
|
||||||
|
boolean result = PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
|
||||||
|
assertThat(result).isTrue();
|
||||||
|
assertThat(
|
||||||
|
Settings.Global.getInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
Settings.Global.POWER_BUTTON_LONG_PRESS))
|
||||||
|
.isEqualTo(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void setLongPressPowerForPowerMenu_updatesKeyChordValueToDefault() throws Exception {
|
||||||
|
when(mResources.getInteger(com.android.internal.R.integer.config_keyChordPowerVolumeUp))
|
||||||
|
.thenReturn(1);
|
||||||
|
|
||||||
|
PowerMenuSettingsUtils.setLongPressPowerForPowerMenu(mContext);
|
||||||
|
|
||||||
|
assertThat(
|
||||||
|
Settings.Global.getInt(
|
||||||
|
mContext.getContentResolver(),
|
||||||
|
Settings.Global.KEY_CHORD_POWER_VOLUME_UP))
|
||||||
|
.isEqualTo(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -426,7 +426,7 @@ public class NotificationPreferenceControllerTest {
|
|||||||
private final class TestPreferenceController extends NotificationPreferenceController {
|
private final class TestPreferenceController extends NotificationPreferenceController {
|
||||||
|
|
||||||
private TestPreferenceController(Context context, NotificationBackend backend) {
|
private TestPreferenceController(Context context, NotificationBackend backend) {
|
||||||
super(context, backend);
|
super(context, backend, "key");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
Reference in New Issue
Block a user