Simplifying widget search pipeline
Bug: 183607616 Test: Verified on device Change-Id: I3e5dd9e280f375475d1e1cf41dff6e6533175ebf
This commit is contained in:
@@ -16,42 +16,41 @@
|
||||
|
||||
package com.android.launcher3.widget.picker.search;
|
||||
|
||||
import android.os.Handler;
|
||||
import android.util.Log;
|
||||
import static com.android.launcher3.search.StringMatcherUtility.matches;
|
||||
|
||||
import android.os.Handler;
|
||||
|
||||
import com.android.launcher3.model.WidgetItem;
|
||||
import com.android.launcher3.popup.PopupDataProvider;
|
||||
import com.android.launcher3.search.SearchAlgorithm;
|
||||
import com.android.launcher3.search.SearchCallback;
|
||||
import com.android.launcher3.search.StringMatcherUtility.StringMatcher;
|
||||
import com.android.launcher3.widget.model.WidgetsListBaseEntry;
|
||||
import com.android.launcher3.widget.model.WidgetsListContentEntry;
|
||||
import com.android.launcher3.widget.model.WidgetsListHeaderEntry;
|
||||
import com.android.launcher3.widget.model.WidgetsListSearchHeaderEntry;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* Implementation of {@link SearchAlgorithm} that posts a task to query on the main thread.
|
||||
*/
|
||||
public final class SimpleWidgetsSearchAlgorithm implements SearchAlgorithm<WidgetsListBaseEntry> {
|
||||
|
||||
private static final boolean DEBUG = false;
|
||||
private static final String TAG = "SimpleWidgetsSearchAlgo";
|
||||
private static final String DELIM = "\t";
|
||||
|
||||
private final Handler mResultHandler;
|
||||
private final WidgetsPickerSearchPipeline mSearchPipeline;
|
||||
private final PopupDataProvider mDataProvider;
|
||||
|
||||
public SimpleWidgetsSearchAlgorithm(WidgetsPickerSearchPipeline searchPipeline) {
|
||||
public SimpleWidgetsSearchAlgorithm(PopupDataProvider dataProvider) {
|
||||
mResultHandler = new Handler();
|
||||
mSearchPipeline = searchPipeline;
|
||||
mDataProvider = dataProvider;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void doSearch(String query, SearchCallback<WidgetsListBaseEntry> callback) {
|
||||
long startTime = System.currentTimeMillis();
|
||||
String queryToken = query + DELIM + startTime;
|
||||
if (DEBUG) {
|
||||
Log.d(TAG, "doSearch queryToken:" + queryToken);
|
||||
}
|
||||
mSearchPipeline.query(query,
|
||||
results -> mResultHandler.post(
|
||||
() -> callback.onSearchResult(queryToken, new ArrayList(results))));
|
||||
ArrayList<WidgetsListBaseEntry> result = getFilteredWidgets(mDataProvider, query);
|
||||
mResultHandler.post(() -> callback.onSearchResult(query, result));
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -60,4 +59,36 @@ public final class SimpleWidgetsSearchAlgorithm implements SearchAlgorithm<Widge
|
||||
mResultHandler.removeCallbacksAndMessages(/*token= */null);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns entries for all matched widgets
|
||||
*/
|
||||
public static ArrayList<WidgetsListBaseEntry> getFilteredWidgets(
|
||||
PopupDataProvider dataProvider, String input) {
|
||||
ArrayList<WidgetsListBaseEntry> results = new ArrayList<>();
|
||||
dataProvider.getAllWidgets().stream()
|
||||
.filter(entry -> entry instanceof WidgetsListHeaderEntry)
|
||||
.forEach(headerEntry -> {
|
||||
List<WidgetItem> matchedWidgetItems = filterWidgetItems(
|
||||
input, headerEntry.mPkgItem.title.toString(), headerEntry.mWidgets);
|
||||
if (matchedWidgetItems.size() > 0) {
|
||||
results.add(new WidgetsListSearchHeaderEntry(headerEntry.mPkgItem,
|
||||
headerEntry.mTitleSectionName, matchedWidgetItems));
|
||||
results.add(new WidgetsListContentEntry(headerEntry.mPkgItem,
|
||||
headerEntry.mTitleSectionName, matchedWidgetItems));
|
||||
}
|
||||
});
|
||||
return results;
|
||||
}
|
||||
|
||||
private static List<WidgetItem> filterWidgetItems(String query, String packageTitle,
|
||||
List<WidgetItem> items) {
|
||||
StringMatcher matcher = StringMatcher.getInstance();
|
||||
if (matches(query, packageTitle, matcher)) {
|
||||
return items;
|
||||
}
|
||||
return items.stream()
|
||||
.filter(item -> matches(query, item.label, matcher))
|
||||
.collect(Collectors.toList());
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user