Fixed listener not re-registering after e.g. a new search is started

This commit is contained in:
litetex 2022-01-16 19:42:30 +01:00
parent ff7cfe4715
commit 85f701b94e

View file

@ -304,28 +304,36 @@ public abstract class BaseListFragment<I, N> extends BaseStateFragment<I>
} }
}); });
infoListAdapter.setOnCommentsSelectedListener(new OnClickGesture<CommentsInfoItem>() { infoListAdapter.setOnCommentsSelectedListener(new OnClickGesture<>() {
@Override @Override
public void selected(final CommentsInfoItem selectedItem) { public void selected(final CommentsInfoItem selectedItem) {
onItemSelected(selectedItem); onItemSelected(selectedItem);
} }
}); });
}
itemsList.clearOnScrollListeners(); /**
* Remove all listeners and add the initial scroll listener to the {@link #itemsList}.
/* * <br/>
* Add initial scroll listener - which tries to load more items when not enough * Which tries to load more items when not enough are in the view (not scrollable)
* are in the view (not scrollable) and more are available. * and more are available.
* * <br/>
* Note: This method only works because "This callback will also be called if visible * Note: This method only works because "This callback will also be called if visible
* item range changes after a layout calculation. In that case, dx and dy will be 0." * item range changes after a layout calculation. In that case, dx and dy will be 0."
* - which might be unexpected because no actual scrolling occurs... * - which might be unexpected because no actual scrolling occurs...
* * <br/>
* This listener will be replaced by DefaultItemListOnScrolledDownListener when * This listener will be replaced by DefaultItemListOnScrolledDownListener when
* * the view was actually scrolled * <ul>
* * the view is scrollable * <li>the view was actually scrolled</li>
* * No more items can be loaded * <li>the view is scrollable</li>
* <li>no more items can be loaded</li>
* </ul>
*/ */
protected void setItemsListInitialScrollListener() {
if (DEBUG) {
Log.d(TAG, "setItemsListInitialScrollListener called");
}
itemsList.clearOnScrollListeners();
itemsList.addOnScrollListener(new DefaultItemListOnScrolledDownListener() { itemsList.addOnScrollListener(new DefaultItemListOnScrolledDownListener() {
@Override @Override
public void onScrolled(final RecyclerView recyclerView, final int dx, final int dy) { public void onScrolled(final RecyclerView recyclerView, final int dx, final int dy) {
@ -360,7 +368,6 @@ public abstract class BaseListFragment<I, N> extends BaseStateFragment<I>
} }
private void useNormalScrollListener() { private void useNormalScrollListener() {
log("Unregistering and using normal listener");
itemsList.removeOnScrollListener(this); itemsList.removeOnScrollListener(this);
itemsList.addOnScrollListener(new DefaultItemListOnScrolledDownListener()); itemsList.addOnScrollListener(new DefaultItemListOnScrolledDownListener());
} }
@ -467,6 +474,12 @@ public abstract class BaseListFragment<I, N> extends BaseStateFragment<I>
// Load and handle // Load and handle
//////////////////////////////////////////////////////////////////////////*/ //////////////////////////////////////////////////////////////////////////*/
@Override
protected void startLoading(final boolean forceLoad) {
setItemsListInitialScrollListener();
super.startLoading(forceLoad);
}
protected abstract void loadMoreItems(); protected abstract void loadMoreItems();
protected abstract boolean hasMoreItems(); protected abstract boolean hasMoreItems();