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

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

Merge "Manually marking widgets recycler as non-scrollable of frozen" into ub-launcher3-rvc-dev

parents c7303048 31fa653e
Loading
Loading
Loading
Loading
+28 −0
Original line number Diff line number Diff line
@@ -16,17 +16,21 @@

package com.android.launcher3;

import static android.view.accessibility.AccessibilityEvent.TYPE_WINDOW_CONTENT_CHANGED;

import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.accessibility.AccessibilityNodeInfo;

import androidx.recyclerview.widget.RecyclerView;

import com.android.launcher3.compat.AccessibilityManagerCompat;
import com.android.launcher3.testing.TestProtocol;
import com.android.launcher3.views.ActivityContext;
import com.android.launcher3.views.RecyclerViewFastScroller;


@@ -187,4 +191,28 @@ public abstract class BaseRecyclerView extends RecyclerView {
            AccessibilityManagerCompat.sendScrollFinishedEventToTest(getContext());
        }
    }

    @Override
    public void onInitializeAccessibilityNodeInfo(AccessibilityNodeInfo info) {
        super.onInitializeAccessibilityNodeInfo(info);
        if (isLayoutSuppressed()) info.setScrollable(false);
        if (Utilities.IS_RUNNING_IN_TEST_HARNESS) {
            Log.d(TestProtocol.NO_SCROLL_END_WIDGETS,
                    "onInitializeAccessibilityNodeInfo, scrollable: " + info.isScrollable());
        }
    }

    @Override
    public void setLayoutFrozen(boolean frozen) {
        final boolean changing = frozen != isLayoutSuppressed();
        super.setLayoutFrozen(frozen);
        if (changing) {
            if (Utilities.IS_RUNNING_IN_TEST_HARNESS) {
                Log.d(TestProtocol.NO_SCROLL_END_WIDGETS, "setLayoutFrozen " + frozen
                        + " @ " + Log.getStackTraceString(new Throwable()));
                ActivityContext.lookupContext(getContext()).getDragLayer()
                        .sendAccessibilityEvent(TYPE_WINDOW_CONTENT_CHANGED);
            }
        }
    }
}
 No newline at end of file
+0 −21
Original line number Diff line number Diff line
@@ -22,7 +22,6 @@ import android.util.AttributeSet;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.accessibility.AccessibilityNodeInfo;

import com.android.launcher3.BaseRecyclerView;
import com.android.launcher3.R;
@@ -210,24 +209,4 @@ public class WidgetsRecyclerView extends BaseRecyclerView implements OnItemTouch
        }
        super.stopNestedScroll();
    }

    @Override
    public void setLayoutFrozen(boolean frozen) {
        if (frozen != isLayoutSuppressed()) {
            if (Utilities.IS_RUNNING_IN_TEST_HARNESS) {
                Log.d(TestProtocol.NO_SCROLL_END_WIDGETS, "setLayoutFrozen " + frozen
                        + " @ " + android.util.Log.getStackTraceString(new Throwable()));
            }
        }
        super.setLayoutFrozen(frozen);
    }

    @Override
    public void onInitializeAccessibilityNodeInfo(AccessibilityNodeInfo info) {
        super.onInitializeAccessibilityNodeInfo(info);
        if (Utilities.IS_RUNNING_IN_TEST_HARNESS) {
            Log.d(TestProtocol.NO_SCROLL_END_WIDGETS,
                    "onInitializeAccessibilityNodeInfo, scrollable: " + info.isScrollable());
        }
    }
}
 No newline at end of file