Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR adds a simple mechanism for infinite scrolling to the Polls and FIP Tracker pages.
Since all of the conversation data is loaded onto the client, the point of this feature is not to reduce load on the database but purely to make the UI more responsive - if we are trying to display all of the conversations and apply a filter, this can involve having to reflow the layout for hundreds of components, which can take hundreds of milliseconds, leading to noticeable lag. It seems like the problem here really is just reflowing the layout, I had hoped that it was something to do with React memoising props since that would have been fixable by refactoring the components themselves...
Changes:
scrollCursor
which shows the current "cursor"IsVisibleObserver
component which is added to the end of the list of items. When it comes into view, incrementscrollCursor
by some fixed amount (e.g. 10)scrollCursor + pageSize
. SetpageSize
to whatever the number of items to initially show is.Note that this mechanism assumes that the filters can only be set from the top of the page - which is currently how the filter dropdowns work.