mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-25 12:27:38 +00:00 
			
		
		
		
	Merge pull request #8972 from Stypox/fix-suggestions-listadapter
Fix various issues in the search suggestions list
This commit is contained in:
		| @@ -340,6 +340,8 @@ public class SearchFragment extends BaseListFragment<SearchInfo, ListExtractor.I | ||||
|         super.initViews(rootView, savedInstanceState); | ||||
|  | ||||
|         searchBinding.suggestionsList.setAdapter(suggestionListAdapter); | ||||
|         // animations are just strange and useless, since the suggestions keep changing too much | ||||
|         searchBinding.suggestionsList.setItemAnimator(null); | ||||
|         new ItemTouchHelper(new ItemTouchHelper.Callback() { | ||||
|             @Override | ||||
|             public int getMovementFlags(@NonNull final RecyclerView recyclerView, | ||||
| @@ -944,8 +946,8 @@ public class SearchFragment extends BaseListFragment<SearchInfo, ListExtractor.I | ||||
|         if (DEBUG) { | ||||
|             Log.d(TAG, "handleSuggestions() called with: suggestions = [" + suggestions + "]"); | ||||
|         } | ||||
|         searchBinding.suggestionsList.smoothScrollToPosition(0); | ||||
|         suggestionListAdapter.submitList(suggestions); | ||||
|         suggestionListAdapter.submitList(suggestions, | ||||
|                 () -> searchBinding.suggestionsList.scrollToPosition(0)); | ||||
|  | ||||
|         if (suggestionsPanelVisible && isErrorPanelVisible()) { | ||||
|             hideLoading(); | ||||
|   | ||||
| @@ -80,13 +80,14 @@ public class SuggestionListAdapter | ||||
|         @Override | ||||
|         public boolean areItemsTheSame(@NonNull final SuggestionItem oldItem, | ||||
|                                        @NonNull final SuggestionItem newItem) { | ||||
|             return oldItem.query.equals(newItem.query); | ||||
|             return oldItem.fromHistory == newItem.fromHistory | ||||
|                     && oldItem.query.equals(newItem.query); | ||||
|         } | ||||
|  | ||||
|         @Override | ||||
|         public boolean areContentsTheSame(@NonNull final SuggestionItem oldItem, | ||||
|                                           @NonNull final SuggestionItem newItem) { | ||||
|             return oldItem.equals(newItem); | ||||
|             return true; // items' contents never change; the list of items themselves does | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Stypox
					Stypox