подгрузкой. Посмотрел доклад Евгения и Александра, где используется Paginator в интеракторе и PaginationState.
Получается так, что мы подписываемся на изменение данных в БД, при этом после загрузки следующей порции с сервера мы сохраняем данные в БД.
1) Но тогда как происходит ограничение списка, который находится в PaginationState?
2) Или нужно делать к БД запрос вида limit 100 offset X, где X будет изменяться при увеличении списка? Тогда необходимо изменять запрос к БД и переподписываться.
3) Нужно ли в памяти хранить список элементов для того, чтобы при изменении состояния загрузки/ошибок использовать его в PaginationState?
4) Где нибудь можно посмотреть еще про реализации списков с подгрузкой в clean?
@xanderblinov
1) чаще всего его не нужно ограничивать. Если нужно, то после давления элементов вниз, считаем сколько надо выкидывать сверху и меняем глобальный offset 2) такие именно запросы и надо делать. Если мы говорим в парадигме Rx - будет не observable наружу торчать и single 3) да, собственно потому иногда нужно его ограничивать 4) есть много библиотек с умным адаптером. Они обычно имеют под капотом стейт машину. Примерно такую же и нужно сделать в пагинаторе
Обсуждают сегодня