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

Commit 92b4a480 authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Automerger Merge Worker
Browse files

Merge "Fix the duplicate components in edit shortcut menu list." into rvc-dev...

Merge "Fix the duplicate components in edit shortcut menu list." into rvc-dev am: 22a0b13e am: 084b7b3a

Change-Id: I25c2b76c101ff9135bd076b123a15c4317d10be7
parents ff21a9d2 084b7b3a
Loading
Loading
Loading
Loading
+30 −2
Original line number Diff line number Diff line
@@ -169,13 +169,41 @@ public class AccessibilityButtonChooserActivity extends Activity {
    private static List<AccessibilityButtonTarget> getInstalledServiceTargets(
            @NonNull Context context) {
        final List<AccessibilityButtonTarget> targets = new ArrayList<>();
        targets.addAll(getAccessibilityServiceTargets(context));
        targets.addAll(getAccessibilityActivityTargets(context));
        targets.addAll(getAccessibilityFilteredTargets(context));
        targets.addAll(getWhiteListingServiceTargets(context));

        return targets;
    }

    private static List<AccessibilityButtonTarget> getAccessibilityFilteredTargets(
            @NonNull Context context) {
        final List<AccessibilityButtonTarget> serviceTargets =
                getAccessibilityServiceTargets(context);
        final List<AccessibilityButtonTarget> activityTargets =
                getAccessibilityActivityTargets(context);

        for (AccessibilityButtonTarget activityTarget : activityTargets) {
            serviceTargets.removeIf(serviceTarget -> {
                final ComponentName serviceComponentName =
                        ComponentName.unflattenFromString(serviceTarget.getId());
                final ComponentName activityComponentName =
                        ComponentName.unflattenFromString(activityTarget.getId());
                final boolean isSamePackageName = activityComponentName.getPackageName().equals(
                        serviceComponentName.getPackageName());
                final boolean isSameLabel = activityTarget.getLabel().equals(
                        serviceTarget.getLabel());

                return isSamePackageName && isSameLabel;
            });
        }

        final List<AccessibilityButtonTarget> targets = new ArrayList<>();
        targets.addAll(serviceTargets);
        targets.addAll(activityTargets);

        return targets;
    }

    private static List<AccessibilityButtonTarget> getAccessibilityServiceTargets(
            @NonNull Context context) {
        final AccessibilityManager ams = context.getSystemService(AccessibilityManager.class);