mirror of
https://github.com/LawnchairLauncher/lawnchair.git
synced 2026-03-02 17:06:49 +00:00
Refactors Search results into separate RV for Toast.
This will help enable transitions between A-Z apps lists and search results because both can be seen simultaneously and manipulated independently. Some high level items of the refactor: - SearchRecyclerView is added; logic that populated the main (personal) tab with search results was simply redirected to this RV instead. - BaseAllAppsContainerView added isSearching() method. Returns false, and ActivityAllAppsContainerView overrides (as search is handled there). - Renamed BaseRecyclerView to FastScrollRecyclerView to better describe what it does. SearchRecyclerView extends this, but returns false for supportsFastScrolling(). - AlphabeticalAppsList#mAllAppsStore is now optional, so the Search RV doesn't need to store/listen to apps. Note this doesn't affect the predicted app row which is still updated if one of the predicted apps is uninstalled (I tested this). Future work: - Determine why dispatchRestoreInstanceState is not called for BaseAllAppsContainerView. Save is called, e.g. on rotation. Effect of restore not called: rotating while searching goes back to A-Z list. - Keep suggested apps in Header while searching. Currently they are rendered in the SearchRV above search results, as before. - Potentially extract Personal/Work tabs to move independently of header. - AlphabeticalAppsList is a misleading name because it can also contains search results. However, things are pretty intertwined between that and BaseAllAppsAdapter (effectively a circular dependency), so I figured cleaning all that up was out of the immediate scope of this refactor, which is mainly meant to unblock transition work. Bug: 206905515 Test: Manually checked for regressions, ran tests. Change-Id: I4d3757c8a8f9b774956ca6be541dd4fcdad1de13
This commit is contained in:
@@ -80,7 +80,7 @@ public class ActivityAllAppsContainerView<T extends Context & AppLauncher
|
||||
OnClickListener marketSearchClickListener = (v) -> mActivityContext.startActivitySafely(v,
|
||||
marketSearchIntent, null);
|
||||
for (int i = 0; i < mAH.size(); i++) {
|
||||
mAH.get(i).adapter.setLastSearchQuery(query, marketSearchClickListener);
|
||||
mAH.get(i).mAdapter.setLastSearchQuery(query, marketSearchClickListener);
|
||||
}
|
||||
mIsSearching = true;
|
||||
rebindAdapters();
|
||||
@@ -142,7 +142,7 @@ public class ActivityAllAppsContainerView<T extends Context & AppLauncher
|
||||
|
||||
@Override
|
||||
public String getDescription() {
|
||||
if (!mUsingTabs && mIsSearching) {
|
||||
if (!mUsingTabs && isSearching()) {
|
||||
return getContext().getString(R.string.all_apps_search_results);
|
||||
} else {
|
||||
return super.getDescription();
|
||||
@@ -150,8 +150,13 @@ public class ActivityAllAppsContainerView<T extends Context & AppLauncher
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean showTabs() {
|
||||
return super.showTabs() && !mIsSearching;
|
||||
protected boolean shouldShowTabs() {
|
||||
return super.shouldShowTabs() && !isSearching();
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isSearching() {
|
||||
return mIsSearching;
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -173,15 +178,19 @@ public class ActivityAllAppsContainerView<T extends Context & AppLauncher
|
||||
}
|
||||
|
||||
@Override
|
||||
protected View replaceRVContainer(boolean showTabs) {
|
||||
View rvContainer = super.replaceRVContainer(showTabs);
|
||||
protected View replaceAppsRVContainer(boolean showTabs) {
|
||||
View rvContainer = super.replaceAppsRVContainer(showTabs);
|
||||
|
||||
removeCustomRules(rvContainer);
|
||||
removeCustomRules(getSearchRecyclerView());
|
||||
if (FeatureFlags.ENABLE_FLOATING_SEARCH_BAR.get()) {
|
||||
alignParentTop(rvContainer, showTabs);
|
||||
alignParentTop(getSearchRecyclerView(), showTabs);
|
||||
layoutAboveSearchContainer(rvContainer);
|
||||
layoutAboveSearchContainer(getSearchRecyclerView());
|
||||
} else {
|
||||
layoutBelowSearchContainer(rvContainer, showTabs);
|
||||
layoutBelowSearchContainer(getSearchRecyclerView(), showTabs);
|
||||
}
|
||||
|
||||
return rvContainer;
|
||||
@@ -208,7 +217,7 @@ public class ActivityAllAppsContainerView<T extends Context & AppLauncher
|
||||
|
||||
float prog = Utilities.boundToRange((float) scrolledOffset / mHeaderThreshold, 0f, 1f);
|
||||
boolean bgVisible = mSearchUiManager.getBackgroundVisibility();
|
||||
if (scrolledOffset == 0 && !mIsSearching) {
|
||||
if (scrolledOffset == 0 && !isSearching()) {
|
||||
bgVisible = true;
|
||||
} else if (scrolledOffset > mHeaderThreshold) {
|
||||
bgVisible = false;
|
||||
@@ -242,7 +251,7 @@ public class ActivityAllAppsContainerView<T extends Context & AppLauncher
|
||||
int topMargin = getContext().getResources().getDimensionPixelSize(
|
||||
R.dimen.all_apps_header_top_margin);
|
||||
if (includeTabsMargin) {
|
||||
topMargin = topMargin + getContext().getResources().getDimensionPixelSize(
|
||||
topMargin += getContext().getResources().getDimensionPixelSize(
|
||||
R.dimen.all_apps_header_pill_height);
|
||||
}
|
||||
layoutParams.topMargin = topMargin;
|
||||
@@ -283,9 +292,9 @@ public class ActivityAllAppsContainerView<T extends Context & AppLauncher
|
||||
}
|
||||
|
||||
@Override
|
||||
protected BaseAllAppsAdapter getAdapter(AlphabeticalAppsList<T> mAppsList,
|
||||
protected BaseAllAppsAdapter<T> createAdapter(AlphabeticalAppsList<T> appsList,
|
||||
BaseAdapterProvider[] adapterProviders) {
|
||||
return new AllAppsGridAdapter<>(mActivityContext, getLayoutInflater(), mAppsList,
|
||||
return new AllAppsGridAdapter<>(mActivityContext, getLayoutInflater(), appsList,
|
||||
adapterProviders);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user