Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 35e20d5a authored by jasonwshsu's avatar jasonwshsu
Browse files

Fix not on the top when entering device detail page

Root Cause: Added SpacePreference in xml let the page renders order
incorrectly.

Solution: That SpacePreference should only be visible when the device is
hearing aid.

Bug: 245681095
Test: make RunSettingsRoboTests ROBOTEST_FILTER=BluetoothDetailsPairOtherControllerTest
Merged-In: Ic0be940c8466b5e1e301255868c29d06bd4428bd
Merged-In: I442445a861898258a73f37ad8f85bcee387fbf58
Change-Id: Icca48d9c2643507638b2b581d052530521cce5df
parent e43bf3cd
Loading
Loading
Loading
Loading
+1 −0
Original line number Original line Diff line number Diff line
@@ -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
+14 −1
Original line number Original line Diff line number Diff line
@@ -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) {
+27 −1
Original line number Original line Diff line number Diff line
@@ -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();
    }
}
}