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

Commit 2454e2ac authored by Treehugger Robot's avatar Treehugger Robot Committed by Automerger Merge Worker
Browse files

Merge "Fix padding in QSContainerImpl after re-inflation" into udc-dev am:...

Merge "Fix padding in QSContainerImpl after re-inflation" into udc-dev am: 3ae3ca1a am: fb63f207 am: f41f026b

Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/23600827



Change-Id: I20adf13643a6315620ea9680273208449a823e42
Signed-off-by: default avatarAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
parents 6145d326 f41f026b
Loading
Loading
Loading
Loading
+6 −0
Original line number Original line Diff line number Diff line
@@ -55,6 +55,7 @@ public class NotificationsQuickSettingsContainer extends ConstraintLayout
    private Consumer<QS> mQSFragmentAttachedListener = qs -> {};
    private Consumer<QS> mQSFragmentAttachedListener = qs -> {};
    private QS mQs;
    private QS mQs;
    private View mQSContainer;
    private View mQSContainer;
    private int mLastQSPaddingBottom;


    /**
    /**
     *  These are used to compute the bounding box containing the shade and the notification scrim,
     *  These are used to compute the bounding box containing the shade and the notification scrim,
@@ -83,6 +84,10 @@ public class NotificationsQuickSettingsContainer extends ConstraintLayout
        mQs = (QS) fragment;
        mQs = (QS) fragment;
        mQSFragmentAttachedListener.accept(mQs);
        mQSFragmentAttachedListener.accept(mQs);
        mQSContainer = mQs.getView().findViewById(R.id.quick_settings_container);
        mQSContainer = mQs.getView().findViewById(R.id.quick_settings_container);
        // We need to restore the bottom padding as the fragment may have been recreated due to
        // some special Configuration change, so we apply the last known padding (this will be
        // correct even if it has changed while the fragment was destroyed and re-created).
        setQSContainerPaddingBottom(mLastQSPaddingBottom);
    }
    }


    @Override
    @Override
@@ -109,6 +114,7 @@ public class NotificationsQuickSettingsContainer extends ConstraintLayout
    }
    }


    public void setQSContainerPaddingBottom(int paddingBottom) {
    public void setQSContainerPaddingBottom(int paddingBottom) {
        mLastQSPaddingBottom = paddingBottom;
        if (mQSContainer != null) {
        if (mQSContainer != null) {
            mQSContainer.setPadding(
            mQSContainer.setPadding(
                    mQSContainer.getPaddingLeft(),
                    mQSContainer.getPaddingLeft(),
+97 −0
Original line number Original line Diff line number Diff line
/*
 * Copyright (C) 2023 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.systemui.shade

import android.testing.AndroidTestingRunner
import android.view.View
import android.view.ViewGroup
import android.widget.FrameLayout
import androidx.constraintlayout.widget.ConstraintLayout
import androidx.test.filters.SmallTest
import com.android.systemui.R
import com.android.systemui.SysuiTestCase
import com.android.systemui.qs.QSFragment
import com.android.systemui.util.mockito.whenever
import com.google.common.truth.Truth.assertThat
import org.junit.Before
import org.junit.Test
import org.junit.runner.RunWith
import org.mockito.Mock
import org.mockito.MockitoAnnotations

@SmallTest
@RunWith(AndroidTestingRunner::class)
class NotificationsQuickSettingsContainerTest : SysuiTestCase() {

    @Mock private lateinit var qsFrame: View
    @Mock private lateinit var stackScroller: View
    @Mock private lateinit var keyguardStatusBar: View
    @Mock private lateinit var qsFragment: QSFragment

    private lateinit var qsView: ViewGroup
    private lateinit var qsContainer: View

    private lateinit var underTest: NotificationsQuickSettingsContainer

    @Before
    fun setUp() {
        MockitoAnnotations.initMocks(this)

        underTest = NotificationsQuickSettingsContainer(context, null)

        setUpViews()
        underTest.onFinishInflate()
        underTest.onFragmentViewCreated("QS", qsFragment)
    }

    @Test
    fun qsContainerPaddingSetAgainAfterQsRecreated() {
        val padding = 100
        underTest.setQSContainerPaddingBottom(padding)

        assertThat(qsContainer.paddingBottom).isEqualTo(padding)

        // We reset the padding before "creating" a new QSFragment
        qsContainer.setPadding(0, 0, 0, 0)
        underTest.onFragmentViewCreated("QS", qsFragment)

        assertThat(qsContainer.paddingBottom).isEqualTo(padding)
    }

    private fun setUpViews() {
        qsView = FrameLayout(context)
        qsContainer = View(context)
        qsContainer.id = R.id.quick_settings_container
        qsView.addView(qsContainer)

        whenever(qsFrame.findViewById<View>(R.id.qs_frame)).thenReturn(qsFrame)
        whenever(stackScroller.findViewById<View>(R.id.notification_stack_scroller))
            .thenReturn(stackScroller)
        whenever(keyguardStatusBar.findViewById<View>(R.id.keyguard_header))
            .thenReturn(keyguardStatusBar)
        whenever(qsFragment.view).thenReturn(qsView)

        val layoutParams = ConstraintLayout.LayoutParams(0, 0)
        whenever(qsFrame.layoutParams).thenReturn(layoutParams)
        whenever(stackScroller.layoutParams).thenReturn(layoutParams)
        whenever(keyguardStatusBar.layoutParams).thenReturn(layoutParams)

        underTest.addView(qsFrame)
        underTest.addView(stackScroller)
        underTest.addView(keyguardStatusBar)
    }
}