Remove the index of the homepage category tiles
Do not index the tiles of homepage category since we would like to index their target activity for search. Fixes: 151418948 Test: visual Change-Id: I693534de006b4dbcaf192858e6f7d031bad78fef
This commit is contained in:
@@ -61,12 +61,14 @@ import android.util.Log;
|
||||
import androidx.annotation.Nullable;
|
||||
import androidx.slice.SliceViewManager;
|
||||
|
||||
import com.android.internal.annotations.VisibleForTesting;
|
||||
import com.android.settings.R;
|
||||
import com.android.settings.SettingsActivity;
|
||||
import com.android.settings.dashboard.DashboardFeatureProvider;
|
||||
import com.android.settings.overlay.FeatureFactory;
|
||||
import com.android.settings.slices.SettingsSliceProvider;
|
||||
import com.android.settingslib.drawer.ActivityTile;
|
||||
import com.android.settingslib.drawer.CategoryKey;
|
||||
import com.android.settingslib.drawer.DashboardCategory;
|
||||
import com.android.settingslib.drawer.Tile;
|
||||
import com.android.settingslib.search.Indexable;
|
||||
@@ -379,9 +381,7 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
||||
final String currentPackageName = context.getPackageName();
|
||||
for (DashboardCategory category : dashboardFeatureProvider.getAllCategories()) {
|
||||
for (Tile tile : category.getTiles()) {
|
||||
if (currentPackageName.equals(tile.getPackageName())
|
||||
&& tile instanceof ActivityTile) {
|
||||
// Skip Settings injected items because they should be indexed in the sub-pages.
|
||||
if (!isEligibleForIndexing(currentPackageName, tile)) {
|
||||
continue;
|
||||
}
|
||||
final SearchIndexableRaw raw = new SearchIndexableRaw(context);
|
||||
@@ -402,6 +402,20 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
||||
return rawList;
|
||||
}
|
||||
|
||||
@VisibleForTesting
|
||||
boolean isEligibleForIndexing(String packageName, Tile tile) {
|
||||
if (TextUtils.equals(packageName, tile.getPackageName())
|
||||
&& tile instanceof ActivityTile) {
|
||||
// Skip Settings injected items because they should be indexed in the sub-pages.
|
||||
return false;
|
||||
}
|
||||
if (TextUtils.equals(tile.getCategory(), CategoryKey.CATEGORY_HOMEPAGE)) {
|
||||
// Skip homepage injected items since we would like to index their target activity.
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
private static Object[] createIndexableRawColumnObjects(SearchIndexableRaw raw) {
|
||||
final Object[] ref = new Object[INDEXABLES_RAW_COLUMNS.length];
|
||||
ref[COLUMN_INDEX_RAW_TITLE] = raw.title;
|
||||
|
Reference in New Issue
Block a user