Merge "Fix not on the top when entering device detail page" into tm-qpr-dev

This commit is contained in:
Jason Hsu
2022-09-22 07:37:28 +00:00
committed by Android (Google) Code Review
3 changed files with 42 additions and 2 deletions

View File

@@ -46,6 +46,7 @@
android:key="hearing_aid_pair_other_button" android:key="hearing_aid_pair_other_button"
android:gravity="center" /> android:gravity="center" />
<com.android.settings.applications.SpacePreference <com.android.settings.applications.SpacePreference
android:key="hearing_aid_space_layout"
android:layout_height="8dp" /> android:layout_height="8dp" />
<com.android.settingslib.widget.ActionButtonsPreference <com.android.settingslib.widget.ActionButtonsPreference

View File

@@ -22,19 +22,25 @@ import androidx.preference.PreferenceFragmentCompat;
import androidx.preference.PreferenceScreen; import androidx.preference.PreferenceScreen;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.applications.SpacePreference;
import com.android.settings.core.SubSettingLauncher; import com.android.settings.core.SubSettingLauncher;
import com.android.settingslib.bluetooth.CachedBluetoothDevice; import com.android.settingslib.bluetooth.CachedBluetoothDevice;
import com.android.settingslib.bluetooth.HearingAidProfile; import com.android.settingslib.bluetooth.HearingAidProfile;
import com.android.settingslib.core.lifecycle.Lifecycle; import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.widget.ButtonPreference; import com.android.settingslib.widget.ButtonPreference;
import com.google.common.annotations.VisibleForTesting;
/** /**
* This class handles button preference logic to display for hearing aid device. * This class handles button preference logic to display for hearing aid device.
*/ */
public class BluetoothDetailsPairOtherController extends BluetoothDetailsController { public class BluetoothDetailsPairOtherController extends BluetoothDetailsController {
private static final String KEY_PAIR_OTHER = "hearing_aid_pair_other_button"; private static final String KEY_PAIR_OTHER = "hearing_aid_pair_other_button";
@VisibleForTesting
static final String KEY_SPACE = "hearing_aid_space_layout";
private ButtonPreference mPreference; private ButtonPreference mPreference;
private SpacePreference mSpacePreference;
public BluetoothDetailsPairOtherController(Context context, public BluetoothDetailsPairOtherController(Context context,
PreferenceFragmentCompat fragment, PreferenceFragmentCompat fragment,
@@ -62,13 +68,20 @@ public class BluetoothDetailsPairOtherController extends BluetoothDetailsControl
: R.string.bluetooth_pair_left_ear_button; : R.string.bluetooth_pair_left_ear_button;
mPreference = screen.findPreference(getPreferenceKey()); mPreference = screen.findPreference(getPreferenceKey());
mSpacePreference = screen.findPreference(KEY_SPACE);
mPreference.setTitle(stringRes); mPreference.setTitle(stringRes);
setPreferencesVisibility(getButtonPreferenceVisibility(mCachedDevice));
mPreference.setOnClickListener(v -> launchPairingDetail()); mPreference.setOnClickListener(v -> launchPairingDetail());
} }
@Override @Override
protected void refresh() { protected void refresh() {
mPreference.setVisible(getButtonPreferenceVisibility(mCachedDevice)); setPreferencesVisibility(getButtonPreferenceVisibility(mCachedDevice));
}
private void setPreferencesVisibility(boolean visible) {
mPreference.setVisible(visible);
mSpacePreference.setVisible(visible);
} }
private boolean getButtonPreferenceVisibility(CachedBluetoothDevice cachedDevice) { private boolean getButtonPreferenceVisibility(CachedBluetoothDevice cachedDevice) {

View File

@@ -21,6 +21,7 @@ import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Mockito.when; import static org.mockito.Mockito.when;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.applications.SpacePreference;
import com.android.settingslib.bluetooth.CachedBluetoothDevice; import com.android.settingslib.bluetooth.CachedBluetoothDevice;
import com.android.settingslib.bluetooth.HearingAidProfile; import com.android.settingslib.bluetooth.HearingAidProfile;
import com.android.settingslib.widget.ButtonPreference; import com.android.settingslib.widget.ButtonPreference;
@@ -43,6 +44,7 @@ public class BluetoothDetailsPairOtherControllerTest extends BluetoothDetailsCon
private CachedBluetoothDevice mSubCachedDevice; private CachedBluetoothDevice mSubCachedDevice;
private BluetoothDetailsPairOtherController mController; private BluetoothDetailsPairOtherController mController;
private ButtonPreference mPreference; private ButtonPreference mPreference;
private SpacePreference mSpacePreference;
@Override @Override
public void setUp() { public void setUp() {
@@ -51,8 +53,11 @@ public class BluetoothDetailsPairOtherControllerTest extends BluetoothDetailsCon
mController = new BluetoothDetailsPairOtherController(mContext, mFragment, mCachedDevice, mController = new BluetoothDetailsPairOtherController(mContext, mFragment, mCachedDevice,
mLifecycle); mLifecycle);
mPreference = new ButtonPreference(mContext); mPreference = new ButtonPreference(mContext);
mSpacePreference = new SpacePreference(mContext, null);
mPreference.setKey(mController.getPreferenceKey()); mPreference.setKey(mController.getPreferenceKey());
mSpacePreference.setKey(BluetoothDetailsPairOtherController.KEY_SPACE);
mScreen.addPreference(mPreference); mScreen.addPreference(mPreference);
mScreen.addPreference(mSpacePreference);
} }
@Test @Test
@@ -76,7 +81,17 @@ public class BluetoothDetailsPairOtherControllerTest extends BluetoothDetailsCon
} }
@Test @Test
public void isAvailable_isConnectedHearingAidDevice_available() { public void init_isNotConnectedHearingAidDevice_notVisiblePreference() {
when(mCachedDevice.isConnectedHearingAidDevice()).thenReturn(false);
mController.init(mScreen);
assertThat(mPreference.isVisible()).isFalse();
assertThat(mSpacePreference.isVisible()).isFalse();
}
@Test
public void isAvailable_isNotConnectedHearingAidDevice_notAvailable() {
when(mCachedDevice.isConnectedHearingAidDevice()).thenReturn(false); when(mCachedDevice.isConnectedHearingAidDevice()).thenReturn(false);
assertThat(mController.isAvailable()).isFalse(); assertThat(mController.isAvailable()).isFalse();
@@ -118,4 +133,15 @@ public class BluetoothDetailsPairOtherControllerTest extends BluetoothDetailsCon
assertThat(mController.isAvailable()).isTrue(); assertThat(mController.isAvailable()).isTrue();
} }
@Test
public void refresh_isNotConnectedHearingAidDevice_notVisiblePreference() {
when(mCachedDevice.isConnectedHearingAidDevice()).thenReturn(false);
mController.init(mScreen);
mController.refresh();
assertThat(mPreference.isVisible()).isFalse();
assertThat(mSpacePreference.isVisible()).isFalse();
}
} }