Commit 72f10fd0 authored by Filipe de Lima Brito's avatar Filipe de Lima Brito

Update SidebarMainFragment.java

parent 7aeab1e3
...@@ -40,17 +40,18 @@ import chat.rocket.persistence.realm.repositories.RealmSpotlightRepository; ...@@ -40,17 +40,18 @@ import chat.rocket.persistence.realm.repositories.RealmSpotlightRepository;
import chat.rocket.persistence.realm.repositories.RealmUserRepository; import chat.rocket.persistence.realm.repositories.RealmUserRepository;
import com.jakewharton.rxbinding2.support.v7.widget.RxSearchView; import com.jakewharton.rxbinding2.support.v7.widget.RxSearchView;
import com.jakewharton.rxbinding2.widget.RxCompoundButton; import com.jakewharton.rxbinding2.widget.RxCompoundButton;
import io.reactivex.Observable;
import io.reactivex.android.schedulers.AndroidSchedulers; import io.reactivex.android.schedulers.AndroidSchedulers;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.concurrent.TimeUnit;
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 List<RoomSidebar> roomSidebarList;
private String hostname; private String hostname;
private static final String HOSTNAME = "hostname"; private static final String HOSTNAME = "hostname";
...@@ -137,24 +138,66 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -137,24 +138,66 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
} }
}); });
RecyclerView recyclerView = rootView.findViewById(R.id.room_list_container); 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);
loadMoreResultsText = rootView.findViewById(R.id.text_load_more_results);
RxSearchView.queryTextChanges(searchView) RxSearchView.queryTextChanges(searchView)
.compose(bindToLifecycle()) .observeOn(AndroidSchedulers.mainThread())
.debounce(100, TimeUnit.MILLISECONDS) .subscribe(charSequence -> {
.observeOn(AndroidSchedulers.mainThread()) adapter.setMode(RoomListAdapter.MODE_ROOM);
.switchMap(charSequence -> { if (charSequence.length() == 0) {
if (charSequence.length() == 0) { loadMoreResultsText.setVisibility(View.GONE);
adapter.setMode(RoomListAdapter.MODE_ROOM); presenter.bindView(this);
return Observable.just(Collections.<Spotlight>emptyList()); recyclerView.setVisibility(View.VISIBLE);
} else { } else {
adapter.setMode(RoomListAdapter.MODE_SPOTLIGHT); presenter.disposeSubscriptions();
return presenter.searchSpotlight(charSequence.toString()).toObservable(); filterRoomSidebarList(charSequence);
}
});
loadMoreResultsText.setOnClickListener(view -> loadMoreResults());
}
@Override
public void showRoomSidebarList(@NonNull List<RoomSidebar> roomSidebarList) {
this.roomSidebarList = roomSidebarList;
adapter.setRoomSidebarList(roomSidebarList);
}
@Override
public void filterRoomSidebarList(CharSequence term) {
List<RoomSidebar> filteredRoomSidebarList = new ArrayList<>();
for (RoomSidebar roomSidebar: roomSidebarList) {
if (roomSidebar.getRoomName().contains(term)) {
filteredRoomSidebarList.add(roomSidebar);
} }
}) }
.subscribe(this::showSearchSuggestions, Logger::report);
if (filteredRoomSidebarList.isEmpty()) {
recyclerView.setVisibility(View.GONE);
} else {
recyclerView.setVisibility(View.VISIBLE);
adapter.setRoomSidebarList(filteredRoomSidebarList);
}
loadMoreResultsText.setVisibility(View.VISIBLE);
}
private void loadMoreResults() {
presenter.searchSpotlight(searchView.getQuery().toString())
.toObservable()
.observeOn(AndroidSchedulers.mainThread())
.subscribe(this::showSearchSuggestions);
}
private void showSearchSuggestions(List<Spotlight> spotlightList) {
loadMoreResultsText.setVisibility(View.GONE);
adapter.setMode(RoomListAdapter.MODE_SPOTLIGHT);
adapter.setSpotlightList(spotlightList);
recyclerView.setVisibility(View.VISIBLE);
} }
@SuppressLint("RxLeakedSubscription") @SuppressLint("RxLeakedSubscription")
...@@ -187,15 +230,10 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -187,15 +230,10 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
rootView.setVisibility(View.INVISIBLE); rootView.setVisibility(View.INVISIBLE);
} }
@Override
public void showRoomSidebarList(@NonNull List<RoomSidebar> roomSidebarList) {
adapter.setRoomSidebarList(roomSidebarList);
}
@Override @Override
public void show(User user) { public void show(User user) {
onRenderCurrentUser(user); onRenderCurrentUser(user);
updateRoomListMode(user); updateRoomListMode();
} }
private void setupUserStatusButtons() { private void setupUserStatusButtons() {
...@@ -226,7 +264,7 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -226,7 +264,7 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
} }
} }
private void updateRoomListMode(User user) { private void updateRoomListMode() {
final List<RoomListHeader> roomListHeaders = new ArrayList<>(); final List<RoomListHeader> roomListHeaders = new ArrayList<>();
roomListHeaders.add(new UnreadRoomListHeader( roomListHeaders.add(new UnreadRoomListHeader(
...@@ -274,7 +312,4 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain ...@@ -274,7 +312,4 @@ public class SidebarMainFragment extends AbstractFragment implements SidebarMain
dialog.show(getFragmentManager(), "AbstractAddRoomDialogFragment"); dialog.show(getFragmentManager(), "AbstractAddRoomDialogFragment");
} }
private void showSearchSuggestions(List<Spotlight> spotlightList) {
adapter.setSpotlightList(spotlightList);
}
} }
\ No newline at end of file
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