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

Commit de08e6e9 authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Android (Google) Code Review
Browse files

Merge "Fix janky in App info screen"

parents 4bd94b90 7fb266f3
Loading
Loading
Loading
Loading
+2 −1
Original line number Diff line number Diff line
@@ -18,7 +18,8 @@
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">
    android:layout_height="wrap_content"
    android:background="@android:color/transparent">

    <com.android.settingslib.widget.settingsspinner.SettingsSpinner
        android:id="@+id/filter_spinner"
+31 −38
Original line number Diff line number Diff line
@@ -21,17 +21,11 @@
    android:layout_height="match_parent"
    android:orientation="vertical">

    <androidx.core.widget.NestedScrollView
    <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fillViewport="true"
        settings:layout_behavior="com.android.settings.widget.FloatingAppBarScrollingViewBehavior">

        <FrameLayout
            android:id="@+id/content_container"
            android:layout_width="match_parent"
            android:layout_height="match_parent">

        <LinearLayout
            android:id="@+id/list_container"
            android:layout_width="match_parent"
@@ -47,6 +41,7 @@
                    android:id="@+id/apps_list"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:clipToPadding="false"
                    settings:fastScrollEnabled="true"
                    settings:fastScrollHorizontalThumbDrawable="@drawable/thumb_drawable"
                    settings:fastScrollHorizontalTrackDrawable="@drawable/line_drawable"
@@ -71,8 +66,6 @@

    </FrameLayout>

    </androidx.core.widget.NestedScrollView>

    <com.google.android.material.appbar.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
+3 −5
Original line number Diff line number Diff line
@@ -186,7 +186,6 @@ public class ManageApplications extends InstrumentedFragment

    private View mLoadingContainer;
    private View mListContainer;
    private RecyclerView mRecyclerView;
    private SearchView mSearchView;

    // Size resource used for packages whose size computation failed for some reason
@@ -220,7 +219,7 @@ public class ManageApplications extends InstrumentedFragment
    @VisibleForTesting
    FilterSpinnerAdapter mFilterAdapter;
    @VisibleForTesting
    View mContentContainer;
    RecyclerView mRecyclerView;

    private View mRootView;
    private Spinner mFilterSpinner;
@@ -330,7 +329,6 @@ public class ManageApplications extends InstrumentedFragment
            Bundle savedInstanceState) {
        mRootView = inflater.inflate(R.layout.manage_applications_apps, null);
        mLoadingContainer = mRootView.findViewById(R.id.loading_container);
        mContentContainer = mRootView.findViewById(R.id.content_container);
        mListContainer = mRootView.findViewById(R.id.list_container);
        if (mListContainer != null) {
            // Create adapter and list view here
@@ -861,14 +859,14 @@ public class ManageApplications extends InstrumentedFragment
            // overlapped by floating filter.
            if (hasFilter) {
                mManageApplications.mSpinnerHeader.setVisibility(View.VISIBLE);
                mManageApplications.mContentContainer.setPadding(0 /* left */,
                mManageApplications.mRecyclerView.setPadding(0 /* left */,
                        mContext.getResources().getDimensionPixelSize(
                                R.dimen.app_bar_height) /* top */,
                        0 /* right */,
                        0 /* bottom */);
            } else {
                mManageApplications.mSpinnerHeader.setVisibility(View.GONE);
                mManageApplications.mContentContainer.setPadding(0 /* left */, 0 /* top */,
                mManageApplications.mRecyclerView.setPadding(0 /* left */, 0 /* top */,
                        0 /* right */,
                        0 /* bottom */);
            }
+4 −4
Original line number Diff line number Diff line
@@ -466,27 +466,27 @@ public class ManageApplicationsTest {

    @Test
    public void updateFilterView_hasFilterSet_shouldShowFilterAndHavePaddingTop() {
        mFragment.mContentContainer = new View(mContext);
        mFragment.mRecyclerView = new RecyclerView(mContext);
        mFragment.mSpinnerHeader = new View(mContext);
        mFragment.mFilterAdapter = new ManageApplications.FilterSpinnerAdapter(mFragment);

        mFragment.mFilterAdapter.updateFilterView(true);

        assertThat(mFragment.mSpinnerHeader.getVisibility()).isEqualTo(View.VISIBLE);
        assertThat(mFragment.mContentContainer.getPaddingTop()).isEqualTo(
        assertThat(mFragment.mRecyclerView.getPaddingTop()).isEqualTo(
                mContext.getResources().getDimensionPixelSize(R.dimen.app_bar_height));
    }

    @Test
    public void updateFilterView_noFilterSet_shouldHideFilterAndNoPaddingTop() {
        mFragment.mContentContainer = new View(mContext);
        mFragment.mRecyclerView = new RecyclerView(mContext);
        mFragment.mSpinnerHeader = new View(mContext);
        mFragment.mFilterAdapter = new ManageApplications.FilterSpinnerAdapter(mFragment);

        mFragment.mFilterAdapter.updateFilterView(false);

        assertThat(mFragment.mSpinnerHeader.getVisibility()).isEqualTo(View.GONE);
        assertThat(mFragment.mContentContainer.getPaddingTop()).isEqualTo(0);
        assertThat(mFragment.mRecyclerView.getPaddingTop()).isEqualTo(0);
    }

    private void setUpOptionMenus() {