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

Commit 3e952e03 authored by Mady Mellor's avatar Mady Mellor Committed by Android (Google) Code Review
Browse files

Merge "Unify calls to sysuiProxy#showBubble into one method" into udc-qpr-dev

parents 1a50287c 4e0ec1e4
Loading
Loading
Loading
Loading
+29 −5
Original line number Diff line number Diff line
@@ -118,6 +118,7 @@ public class BubbleBarController extends IBubblesListener.Stub {
    private final Executor mMainExecutor;
    private final LauncherApps mLauncherApps;
    private final BubbleIconFactory mIconFactory;
    private final SystemUiProxy mSystemUiProxy;

    private BubbleBarItem mSelectedBubble;
    private BubbleBarOverflow mOverflowBubble;
@@ -159,8 +160,10 @@ public class BubbleBarController extends IBubblesListener.Stub {
        mContext = context;
        mBarView = bubbleView; // Need the view for inflating bubble views.

        mSystemUiProxy = SystemUiProxy.INSTANCE.get(context);

        if (BUBBLE_BAR_ENABLED) {
            SystemUiProxy.INSTANCE.get(context).setBubblesListener(this);
            mSystemUiProxy.setBubblesListener(this);
        }
        mMainExecutor = MAIN_EXECUTOR;
        mLauncherApps = context.getSystemService(LauncherApps.class);
@@ -173,7 +176,7 @@ public class BubbleBarController extends IBubblesListener.Stub {
    }

    public void onDestroy() {
        SystemUiProxy.INSTANCE.get(mContext).setBubblesListener(null);
        mSystemUiProxy.setBubblesListener(null);
    }

    public void init(TaskbarControllers controllers, BubbleControllers bubbleControllers) {
@@ -354,12 +357,33 @@ public class BubbleBarController extends IBubblesListener.Stub {
        }
    }

    /** Tells WMShell to show the currently selected bubble. */
    public void showSelectedBubble() {
        if (getSelectedBubbleKey() != null) {
            int[] bubbleBarCoords = mBarView.getLocationOnScreen();
            if (mSelectedBubble instanceof BubbleBarBubble) {
                // TODO (b/269670235): hide the update dot on the view if needed.
            }
            mSystemUiProxy.showBubble(getSelectedBubbleKey(),
                    bubbleBarCoords[0], bubbleBarCoords[1]);
        } else {
            Log.w(TAG, "Trying to show the selected bubble but it's null");
        }
    }

    /** Updates the currently selected bubble for launcher views and tells WMShell to show it. */
    public void showAndSelectBubble(BubbleBarItem b) {
        if (DEBUG) Log.w(TAG, "showingSelectedBubble: " + b.getKey());
        setSelectedBubble(b);
        showSelectedBubble();
    }

    /**
     * Sets the bubble that should be selected. This notifies the views, it does not notify
     * WMShell that the selection has changed, that should go through
     * {@link SystemUiProxy#showBubble}.
     * WMShell that the selection has changed, that should go through either
     * {@link #showSelectedBubble()} or {@link #showAndSelectBubble(BubbleBarItem)}.
     */
    public void setSelectedBubble(BubbleBarItem b) {
    private void setSelectedBubble(BubbleBarItem b) {
        if (!Objects.equals(b, mSelectedBubble)) {
            if (DEBUG) Log.w(TAG, "selectingBubble: " + b.getKey());
            mSelectedBubble = b;
+2 −10
Original line number Diff line number Diff line
@@ -112,9 +112,7 @@ public class BubbleBarViewController {
            setExpanded(false);
            mBubbleStashController.stashBubbleBar();
        } else {
            mBubbleBarController.setSelectedBubble(bubble);
            int[] bubbleBarCoords = mBarView.getLocationOnScreen();
            mSystemUiProxy.showBubble(bubble.getKey(), bubbleBarCoords[0], bubbleBarCoords[1]);
            mBubbleBarController.showAndSelectBubble(bubble);
        }
    }

@@ -291,13 +289,7 @@ public class BubbleBarViewController {
            if (!isExpanded) {
                mSystemUiProxy.collapseBubbles();
            } else {
                final String selectedKey = mBubbleBarController.getSelectedBubbleKey();
                if (selectedKey != null) {
                    int[] bubbleBarCoords = mBarView.getLocationOnScreen();
                    mSystemUiProxy.showBubble(selectedKey, bubbleBarCoords[0], bubbleBarCoords[1]);
                } else {
                    Log.w(TAG, "trying to expand bubbles when there isn't one selected");
                }
                mBubbleBarController.showSelectedBubble();
                mTaskbarStashController.updateAndAnimateTransientTaskbar(true /* stash */,
                        false /* shouldBubblesFollow */);
            }