Display recents when search fragment open.
Bug: 27391895 Test: make RunSettingsRoboTests Change-Id: I62cfa35af96babf85a795910aa76dc774e2b80f2
This commit is contained in:
@@ -25,7 +25,7 @@ public class SavedQueryViewHolder extends SearchViewHolder {
|
||||
|
||||
public SavedQueryViewHolder(View view) {
|
||||
super(view);
|
||||
titleView = (TextView) view.findViewById(android.R.id.title);
|
||||
titleView = view.findViewById(android.R.id.title);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@@ -45,9 +45,8 @@ import com.android.settings.overlay.FeatureFactory;
|
||||
import java.util.List;
|
||||
import java.util.concurrent.atomic.AtomicInteger;
|
||||
|
||||
public class SearchFragment extends InstrumentedFragment implements
|
||||
SearchView.OnQueryTextListener, LoaderManager.LoaderCallbacks<List<? extends SearchResult>>
|
||||
{
|
||||
public class SearchFragment extends InstrumentedFragment implements SearchView.OnQueryTextListener,
|
||||
LoaderManager.LoaderCallbacks<List<? extends SearchResult>> {
|
||||
private static final String TAG = "SearchFragment";
|
||||
|
||||
@VisibleForTesting
|
||||
@@ -66,7 +65,7 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
private static final int NUM_QUERY_LOADERS = 2;
|
||||
|
||||
@VisibleForTesting(otherwise = VisibleForTesting.PRIVATE)
|
||||
AtomicInteger mUnfinishedLoadersCount = new AtomicInteger(NUM_QUERY_LOADERS);;
|
||||
AtomicInteger mUnfinishedLoadersCount = new AtomicInteger(NUM_QUERY_LOADERS);
|
||||
|
||||
// Logging
|
||||
@VisibleForTesting(otherwise = VisibleForTesting.PRIVATE)
|
||||
@@ -82,7 +81,7 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
private int mResultClickCount;
|
||||
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||
|
||||
@VisibleForTesting (otherwise = VisibleForTesting.PRIVATE)
|
||||
@VisibleForTesting(otherwise = VisibleForTesting.PRIVATE)
|
||||
SearchFeatureProvider mSearchFeatureProvider;
|
||||
|
||||
private SearchResultsAdapter mSearchAdapter;
|
||||
@@ -93,8 +92,7 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
private LinearLayout mNoResultsView;
|
||||
|
||||
@VisibleForTesting
|
||||
final RecyclerView.OnScrollListener mScrollListener =
|
||||
new RecyclerView.OnScrollListener() {
|
||||
final RecyclerView.OnScrollListener mScrollListener = new RecyclerView.OnScrollListener() {
|
||||
@Override
|
||||
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
|
||||
if (dy != 0) {
|
||||
@@ -120,7 +118,7 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
super.onCreate(savedInstanceState);
|
||||
setHasOptionsMenu(true);
|
||||
mSearchAdapter = new SearchResultsAdapter(this);
|
||||
|
||||
|
||||
mSearchFeatureProvider.initFeedbackButton();
|
||||
|
||||
final LoaderManager loaderManager = getLoaderManager();
|
||||
@@ -155,12 +153,12 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
public View onCreateView(LayoutInflater inflater, ViewGroup container,
|
||||
Bundle savedInstanceState) {
|
||||
final View view = inflater.inflate(R.layout.search_panel_2, container, false);
|
||||
mResultsRecyclerView = (RecyclerView) view.findViewById(R.id.list_results);
|
||||
mResultsRecyclerView = view.findViewById(R.id.list_results);
|
||||
mResultsRecyclerView.setAdapter(mSearchAdapter);
|
||||
mResultsRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity()));
|
||||
mResultsRecyclerView.addOnScrollListener(mScrollListener);
|
||||
|
||||
mNoResultsView = (LinearLayout) view.findViewById(R.id.no_results_layout);
|
||||
mNoResultsView = view.findViewById(R.id.no_results_layout);
|
||||
return view;
|
||||
}
|
||||
|
||||
@@ -245,16 +243,20 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
@Override
|
||||
public void onLoadFinished(Loader<List<? extends SearchResult>> loader,
|
||||
List<? extends SearchResult> data) {
|
||||
mSearchAdapter.addResultsToMap(data, loader.getClass().getName());
|
||||
|
||||
if (mUnfinishedLoadersCount.decrementAndGet() == 0) {
|
||||
final int resultCount = mSearchAdapter.mergeResults();
|
||||
mSearchFeatureProvider.showFeedbackButton(this, getView());
|
||||
|
||||
if (resultCount == 0) {
|
||||
mNoResultsView.setVisibility(View.VISIBLE);
|
||||
}
|
||||
final int resultCount;
|
||||
switch (loader.getId()) {
|
||||
case LOADER_ID_RECENTS:
|
||||
resultCount = mSearchAdapter.displaySavedQuery(data);
|
||||
break;
|
||||
default:
|
||||
mSearchAdapter.addSearchResults(data, loader.getClass().getName());
|
||||
if (mUnfinishedLoadersCount.decrementAndGet() != 0) {
|
||||
return;
|
||||
}
|
||||
resultCount = mSearchAdapter.displaySearchResults();
|
||||
}
|
||||
mNoResultsView.setVisibility(resultCount == 0 ? View.VISIBLE : View.GONE);
|
||||
mSearchFeatureProvider.showFeedbackButton(this, getView());
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -267,6 +269,8 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
|
||||
public void onSavedQueryClicked(CharSequence query) {
|
||||
final String queryString = query.toString();
|
||||
mMetricsFeatureProvider.action(getContext(),
|
||||
MetricsProto.MetricsEvent.ACTION_CLICK_SETTINGS_SEARCH_SAVED_QUERY);
|
||||
mSearchView.setQuery(queryString, false /* submit */);
|
||||
onQueryTextChange(queryString);
|
||||
}
|
||||
@@ -286,7 +290,7 @@ public class SearchFragment extends InstrumentedFragment implements
|
||||
return mSearchAdapter.getSearchResults();
|
||||
}
|
||||
|
||||
@VisibleForTesting (otherwise = VisibleForTesting.PRIVATE)
|
||||
@VisibleForTesting(otherwise = VisibleForTesting.PRIVATE)
|
||||
SearchView makeSearchView(ActionBar actionBar, String query) {
|
||||
final SearchView searchView = new SearchView(actionBar.getThemedContext());
|
||||
searchView.setIconifiedByDefault(false);
|
||||
|
@@ -19,7 +19,7 @@ package com.android.settings.search2;
|
||||
import android.content.Context;
|
||||
import android.support.annotation.MainThread;
|
||||
import android.support.annotation.VisibleForTesting;
|
||||
import android.support.v7.widget.RecyclerView.Adapter;
|
||||
import android.support.v7.widget.RecyclerView;
|
||||
import android.util.ArrayMap;
|
||||
import android.view.LayoutInflater;
|
||||
import android.view.View;
|
||||
@@ -32,10 +32,10 @@ import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.android.settings.search2.SearchResult.TOP_RANK;
|
||||
import static com.android.settings.search2.SearchResult.BOTTOM_RANK;
|
||||
import static com.android.settings.search2.SearchResult.TOP_RANK;
|
||||
|
||||
public class SearchResultsAdapter extends Adapter<SearchViewHolder> {
|
||||
public class SearchResultsAdapter extends RecyclerView.Adapter<SearchViewHolder> {
|
||||
|
||||
private final List<SearchResult> mSearchResults;
|
||||
private final SearchFragment mFragment;
|
||||
@@ -91,16 +91,28 @@ public class SearchResultsAdapter extends Adapter<SearchViewHolder> {
|
||||
|
||||
/**
|
||||
* Store the results from each of the loaders to be merged when all loaders are finished.
|
||||
* @param freshResults are the results from the loader.
|
||||
*
|
||||
* @param results the results from the loader.
|
||||
* @param loaderClassName class name of the loader.
|
||||
*/
|
||||
@MainThread
|
||||
public void addResultsToMap(List<? extends SearchResult> freshResults,
|
||||
String loaderClassName) {
|
||||
if (freshResults == null) {
|
||||
public void addSearchResults(List<? extends SearchResult> results, String loaderClassName) {
|
||||
if (results == null) {
|
||||
return;
|
||||
}
|
||||
mResultsMap.put(loaderClassName, freshResults);
|
||||
mResultsMap.put(loaderClassName, results);
|
||||
}
|
||||
|
||||
/**
|
||||
* Displays recent searched queries.
|
||||
*
|
||||
* @return The number of saved queries to display
|
||||
*/
|
||||
public int displaySavedQuery(List<? extends SearchResult> data) {
|
||||
clearResults();
|
||||
mSearchResults.addAll(data);
|
||||
notifyDataSetChanged();
|
||||
return mSearchResults.size();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -109,7 +121,7 @@ public class SearchResultsAdapter extends Adapter<SearchViewHolder> {
|
||||
*
|
||||
* @return Number of matched results
|
||||
*/
|
||||
public int mergeResults() {
|
||||
public int displaySearchResults() {
|
||||
final List<? extends SearchResult> databaseResults = mResultsMap
|
||||
.get(DatabaseResultLoader.class.getName());
|
||||
final List<? extends SearchResult> installedAppResults = mResultsMap
|
||||
@@ -129,7 +141,7 @@ public class SearchResultsAdapter extends Adapter<SearchViewHolder> {
|
||||
while ((appIndex < appSize) && (installedAppResults.get(appIndex).rank == rank)) {
|
||||
results.add(installedAppResults.get(appIndex++));
|
||||
}
|
||||
rank ++;
|
||||
rank++;
|
||||
}
|
||||
|
||||
while (dbIndex < dbSize) {
|
||||
|
Reference in New Issue
Block a user