Я хочу отфильтровать список на основе RealmRecyclerViewAdapter
и получить детальную анимацию (notifyItemRange*()
).
Моя логика фильтрации:
override fun observeCampaigns(nameQuery: String): Flowable<RealmResults<CampaignRealm>> =
Realm.getDefaultInstance().use { realm ->
realm.where<CampaignRealm>()
.contains(CampaignRealmFields.NAME, nameQuery, Case.INSENSITIVE)
.findAllAsync()
.asFlowable()
.filter { it.isLoaded }
}
Проблема заключается в том, что внутри адаптерасостояние changeSet всегда НАЧАЛЬНОЕ, я предполагаю, потому что я создаю новый объект RealmResults каждый раз, когда я меняю запрос.
private OrderedRealmCollectionChangeListener createListener() {
return new OrderedRealmCollectionChangeListener() {
@Override
public void onChange(Object collection, OrderedCollectionChangeSet changeSet) {
if (changeSet.getState() == OrderedCollectionChangeSet.State.INITIAL) {
// IT ALWAYS HITS THIS
notifyDataSetChanged();
return;
}
// For deletions, the adapter has to be notified in reverse order.
OrderedCollectionChangeSet.Range[] deletions = changeSet.getDeletionRanges();
for (int i = deletions.length - 1; i >= 0; i--) {
OrderedCollectionChangeSet.Range range = deletions[i];
notifyItemRangeRemoved(range.startIndex, range.length);
}
OrderedCollectionChangeSet.Range[] insertions = changeSet.getInsertionRanges();
for (OrderedCollectionChangeSet.Range range : insertions) {
notifyItemRangeInserted(range.startIndex, range.length);
}
if (!updateOnModification) {
return;
}
OrderedCollectionChangeSet.Range[] modifications = changeSet.getChangeRanges();
for (OrderedCollectionChangeSet.Range range : modifications) {
notifyItemRangeChanged(range.startIndex, range.length);
}
}
};
}
Я нигде не мог найти решение.Я не могу быть первым человеком, у которого есть простой случай использования как это ... правильно ?!(Я схожу с ума здесь ?)
Идеи?