mirror of
https://github.com/LawnchairLauncher/lawnchair.git
synced 2026-03-03 01:16:49 +00:00
Fix bug with Taskbar not differentiating between user profiles
This patch fixes a bug where Taskbar would not differentiate between user profiles when selecting an app to launch from Overview. The bug occurred because findLastActiveTaskAndRunCallback(), which checks for already-running tasks when launching an app from the Taskbar, only checks for a ComponentName match and not a userId match. Fixed by making the findLastActiveTaskAndRunCallback() also check for a userId match. Fixes: 270456926 Test: Manual Change-Id: I43ff06083a5dce775fdbd0b0ed951beaae34c0ab
This commit is contained in:
@@ -29,7 +29,6 @@ import android.app.ActivityManager;
|
||||
import android.app.ActivityOptions;
|
||||
import android.app.ActivityThread;
|
||||
import android.app.PendingIntent;
|
||||
import android.content.ComponentName;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.content.pm.PackageManager;
|
||||
@@ -58,6 +57,7 @@ import com.android.launcher3.statehandlers.DepthController;
|
||||
import com.android.launcher3.statemanager.StateManager;
|
||||
import com.android.launcher3.testing.TestLogging;
|
||||
import com.android.launcher3.testing.shared.TestProtocol;
|
||||
import com.android.launcher3.util.ComponentKey;
|
||||
import com.android.launcher3.util.SplitConfigurationOptions;
|
||||
import com.android.launcher3.util.SplitConfigurationOptions.StagePosition;
|
||||
import com.android.quickstep.RecentsModel;
|
||||
@@ -162,7 +162,7 @@ public class SplitSelectStateController {
|
||||
* Used in various task-switching or splitscreen operations when we need to check if there is a
|
||||
* currently running Task of a certain type and use the most recent one.
|
||||
*/
|
||||
public void findLastActiveTaskAndRunCallback(ComponentName componentName,
|
||||
public void findLastActiveTaskAndRunCallback(ComponentKey componentKey,
|
||||
Consumer<Task> callback) {
|
||||
mRecentTasksModel.getTasks(taskGroups -> {
|
||||
Task lastActiveTask = null;
|
||||
@@ -170,12 +170,12 @@ public class SplitSelectStateController {
|
||||
for (int i = taskGroups.size() - 1; i >= 0; i--) {
|
||||
GroupTask groupTask = taskGroups.get(i);
|
||||
Task task1 = groupTask.task1;
|
||||
if (isInstanceOfComponent(task1, componentName)) {
|
||||
if (isInstanceOfComponent(task1, componentKey)) {
|
||||
lastActiveTask = task1;
|
||||
break;
|
||||
}
|
||||
Task task2 = groupTask.task2;
|
||||
if (isInstanceOfComponent(task2, componentName)) {
|
||||
if (isInstanceOfComponent(task2, componentKey)) {
|
||||
lastActiveTask = task2;
|
||||
break;
|
||||
}
|
||||
@@ -189,13 +189,14 @@ public class SplitSelectStateController {
|
||||
* Checks if a given Task is the most recently-active Task of type componentName. Used for
|
||||
* selecting already-running Tasks for splitscreen.
|
||||
*/
|
||||
public boolean isInstanceOfComponent(@Nullable Task task, ComponentName componentName) {
|
||||
public boolean isInstanceOfComponent(@Nullable Task task, ComponentKey componentKey) {
|
||||
// Exclude the task that is already staged
|
||||
if (task == null || task.key.id == mInitialTaskId) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return task.key.baseIntent.getComponent().equals(componentName);
|
||||
return task.key.baseIntent.getComponent().equals(componentKey.componentName)
|
||||
&& task.key.userId == componentKey.user.getIdentifier();
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user