Commit 4fb39f89 authored by Lucio Maciel's avatar Lucio Maciel Committed by GitHub

Merge pull request #449 from filipedelimabrito/local-spotlight

[FIX] Spotlight results
parents 5487017d a4c17bd3
...@@ -43,16 +43,18 @@ import com.jakewharton.rxbinding2.support.v7.widget.RxSearchView; ...@@ -43,16 +43,18 @@ import com.jakewharton.rxbinding2.support.v7.widget.RxSearchView;
import com.jakewharton.rxbinding2.widget.RxCompoundButton; import com.jakewharton.rxbinding2.widget.RxCompoundButton;
import io.reactivex.android.schedulers.AndroidSchedulers; import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.Disposable;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
public class SidebarMainFragment extends AbstractFragment implements SidebarMainContract.View { public class SidebarMainFragment extends AbstractFragment implements SidebarMainContract.View {
private SidebarMainContract.Presenter presenter; private SidebarMainContract.Presenter presenter;
private RoomListAdapter adapter; private RoomListAdapter adapter;
private RecyclerView recyclerView;
private SearchView searchView; private SearchView searchView;
private TextView loadMoreResultsText; private TextView loadMoreResultsText;
private List<RoomSidebar> roomSidebarList; private List<RoomSidebar> roomSidebarList;
private Disposable spotlightDisposable;
private String hostname; private String hostname;
private static final String HOSTNAME = "hostname"; private static final String HOSTNAME = "hostname";
...@@ -139,7 +141,7 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -139,7 +141,7 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
} }
}); });
recyclerView = rootView.findViewById(R.id.room_list_container); RecyclerView recyclerView = rootView.findViewById(R.id.room_list_container);
recyclerView.setLayoutManager(new LinearLayoutManager(getContext(), LinearLayoutManager.VERTICAL, false)); recyclerView.setLayoutManager(new LinearLayoutManager(getContext(), LinearLayoutManager.VERTICAL, false));
recyclerView.setAdapter(adapter); recyclerView.setAdapter(adapter);
...@@ -148,13 +150,15 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -148,13 +150,15 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
RxSearchView.queryTextChanges(searchView) RxSearchView.queryTextChanges(searchView)
.observeOn(AndroidSchedulers.mainThread()) .observeOn(AndroidSchedulers.mainThread())
.subscribe(charSequence -> { .subscribe(charSequence -> {
adapter.setMode(RoomListAdapter.MODE_ROOM); if (spotlightDisposable != null && !spotlightDisposable.isDisposed()) {
spotlightDisposable.dispose();
}
presenter.disposeSubscriptions();
if (charSequence.length() == 0) { if (charSequence.length() == 0) {
loadMoreResultsText.setVisibility(View.GONE); loadMoreResultsText.setVisibility(View.GONE);
adapter.setMode(RoomListAdapter.MODE_ROOM);
presenter.bindView(this); presenter.bindView(this);
recyclerView.setVisibility(View.VISIBLE);
} else { } else {
presenter.disposeSubscriptions();
filterRoomSidebarList(charSequence); filterRoomSidebarList(charSequence);
} }
}); });
...@@ -179,16 +183,16 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -179,16 +183,16 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
} }
if (filteredRoomSidebarList.isEmpty()) { if (filteredRoomSidebarList.isEmpty()) {
recyclerView.setVisibility(View.GONE); loadMoreResults();
} else { } else {
recyclerView.setVisibility(View.VISIBLE); loadMoreResultsText.setVisibility(View.VISIBLE);
adapter.setMode(RoomListAdapter.MODE_ROOM);
adapter.setRoomSidebarList(filteredRoomSidebarList); adapter.setRoomSidebarList(filteredRoomSidebarList);
} }
loadMoreResultsText.setVisibility(View.VISIBLE);
} }
private void loadMoreResults() { private void loadMoreResults() {
presenter.searchSpotlight(searchView.getQuery().toString()) spotlightDisposable = presenter.searchSpotlight(searchView.getQuery().toString())
.toObservable() .toObservable()
.observeOn(AndroidSchedulers.mainThread()) .observeOn(AndroidSchedulers.mainThread())
.subscribe(this::showSearchSuggestions); .subscribe(this::showSearchSuggestions);
...@@ -198,7 +202,6 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -198,7 +202,6 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
loadMoreResultsText.setVisibility(View.GONE); loadMoreResultsText.setVisibility(View.GONE);
adapter.setMode(RoomListAdapter.MODE_SPOTLIGHT); adapter.setMode(RoomListAdapter.MODE_SPOTLIGHT);
adapter.setSpotlightList(spotlightList); adapter.setSpotlightList(spotlightList);
recyclerView.setVisibility(View.VISIBLE);
} }
@SuppressLint("RxLeakedSubscription") @SuppressLint("RxLeakedSubscription")
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment