подгружается в бесконечную ленту страница за страницей.
Обычно данные сначала появляются из бд, отображаются во вью. В какой-то момент прилетают новые и нужно найти разницу между теми данными, что уже во вью и теми, что пришли из репозитория, затем уведомить адаптер, что именно поменялось (notifyItemChanged/inserted).
Стоит ли хранить 2 списка данных - в презентере и в адаптере? Как иначе презентер сможет найти diff? Не думаю, что этим должна заниматься view - это же уже логика отображения...
Да, хороший вопрос, на самом деле. В истории со списком я хранил и в адаптере и в презентере. Но это было скорее обусловлено тем, что пользователь мог выйти с экрана, а получать новые сообщения должен был. Поэтому я весь скоуп оставлял в живых. И когда появлялась вьюшка, то выдавал ей актуальный список. Дифф то никакой не нужно искать. Вы же все проводите через презентер, и там всегда самая актуальная информация. А потом уже презентер выдает команды вьюшке, в том числе и отдает новые сообщения. А вьюшка их уже в адаптер и список. Хотя можно адаптер и в презентер хранить. Но тогда получается, что мы скрытно управляем вьюшкой еще и через адаптер. Из-за этого очень легко можно запутаться. Ну и Single Responsobility как бы страдает
Обсуждают сегодня