Don't restart library subscription

This commit is contained in:
inorichi 2015-10-18 02:33:15 +02:00
parent c6df23b1aa
commit 920a71601b
5 changed files with 19 additions and 26 deletions

View File

@ -1,7 +1,5 @@
package eu.kanade.mangafeed.data.models; package eu.kanade.mangafeed.data.models;
import android.support.annotation.Nullable;
import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteColumn; import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteColumn;
import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteType; import com.pushtorefresh.storio.sqlite.annotations.StorIOSQLiteType;

View File

@ -7,13 +7,12 @@ import javax.inject.Inject;
import eu.kanade.mangafeed.data.helpers.DatabaseHelper; import eu.kanade.mangafeed.data.helpers.DatabaseHelper;
import eu.kanade.mangafeed.data.helpers.PreferencesHelper; import eu.kanade.mangafeed.data.helpers.PreferencesHelper;
import eu.kanade.mangafeed.data.models.Manga; import eu.kanade.mangafeed.ui.adapter.LibraryAdapter;
import eu.kanade.mangafeed.ui.fragment.LibraryFragment; import eu.kanade.mangafeed.ui.fragment.LibraryFragment;
import rx.Observable; import rx.Observable;
import rx.Subscription; import rx.Subscription;
import rx.android.schedulers.AndroidSchedulers; import rx.android.schedulers.AndroidSchedulers;
import rx.schedulers.Schedulers; import rx.schedulers.Schedulers;
import uk.co.ribot.easyadapter.EasyAdapter;
public class LibraryPresenter extends BasePresenter<LibraryFragment> { public class LibraryPresenter extends BasePresenter<LibraryFragment> {
@ -36,31 +35,26 @@ public class LibraryPresenter extends BasePresenter<LibraryFragment> {
public void getFavoriteMangas() { public void getFavoriteMangas() {
if (mFavoriteMangasSubscription != null) if (mFavoriteMangasSubscription != null)
remove(mFavoriteMangasSubscription); return;
mFavoriteMangasSubscription = db.getMangasWithUnread() add(mFavoriteMangasSubscription = db.getMangasWithUnread()
.subscribeOn(Schedulers.io()) .subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread()) .observeOn(AndroidSchedulers.mainThread())
.compose(deliverLatestCache()) .compose(deliverLatestCache())
.subscribe(this.split((view, mangas) -> { .subscribe(this.split(LibraryFragment::onNextMangas)));
view.getAdapter().setNewItems(mangas);
}));
add(mFavoriteMangasSubscription);
} }
public void onDelete(SparseBooleanArray checkedItems, EasyAdapter<Manga> adapter) { public void onDelete(SparseBooleanArray checkedItems, LibraryAdapter adapter) {
remove(mDeleteMangaSubscription); if (mDeleteMangaSubscription != null)
remove(mDeleteMangaSubscription);
mDeleteMangaSubscription = Observable.range(0, checkedItems.size()) add(mDeleteMangaSubscription = Observable.range(0, checkedItems.size())
.observeOn(Schedulers.io()) .observeOn(Schedulers.io())
.map(checkedItems::keyAt) .map(checkedItems::keyAt)
.map(adapter::getItem) .map(adapter::getItem)
.toList() .toList()
.flatMap(db::deleteMangas) .flatMap(db::deleteMangas)
.subscribe(); .subscribe());
add(mDeleteMangaSubscription);
} }
} }

View File

@ -8,7 +8,6 @@ import eu.kanade.mangafeed.ui.fragment.MangaInfoFragment;
import rx.Observable; import rx.Observable;
import rx.Subscription; import rx.Subscription;
import rx.android.schedulers.AndroidSchedulers; import rx.android.schedulers.AndroidSchedulers;
import rx.schedulers.Schedulers;
public class MangaInfoPresenter extends BasePresenter<MangaInfoFragment> { public class MangaInfoPresenter extends BasePresenter<MangaInfoFragment> {

View File

@ -10,7 +10,7 @@ import eu.kanade.mangafeed.data.models.Manga;
import rx.Observable; import rx.Observable;
import uk.co.ribot.easyadapter.EasyAdapter; import uk.co.ribot.easyadapter.EasyAdapter;
public class LibraryAdapter<T> extends EasyAdapter<T> implements Filterable { public class LibraryAdapter extends EasyAdapter<Manga> implements Filterable {
List<Manga> mangas; List<Manga> mangas;
Filter filter; Filter filter;
@ -20,9 +20,9 @@ public class LibraryAdapter<T> extends EasyAdapter<T> implements Filterable {
filter = new LibraryFilter(); filter = new LibraryFilter();
} }
public void setNewItems(List<T> list) { public void setNewItems(List<Manga> list) {
super.setItems(list); super.setItems(list);
mangas = (List<Manga>)list; mangas = list;
} }
@Override @Override
@ -57,7 +57,7 @@ public class LibraryAdapter<T> extends EasyAdapter<T> implements Filterable {
@Override @Override
public void publishResults(CharSequence constraint, FilterResults results) { public void publishResults(CharSequence constraint, FilterResults results) {
setItems((List<T>) results.values); setItems((List<Manga >) results.values);
} }
} }

View File

@ -12,6 +12,8 @@ import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
import android.widget.GridView; import android.widget.GridView;
import java.util.List;
import butterknife.Bind; import butterknife.Bind;
import butterknife.ButterKnife; import butterknife.ButterKnife;
import butterknife.OnItemClick; import butterknife.OnItemClick;
@ -28,7 +30,7 @@ public class LibraryFragment extends BaseFragment<LibraryPresenter> {
@Bind(R.id.gridView) GridView grid; @Bind(R.id.gridView) GridView grid;
private MainActivity activity; private MainActivity activity;
private LibraryAdapter<Manga> adapter; private LibraryAdapter adapter;
public static LibraryFragment newInstance() { public static LibraryFragment newInstance() {
LibraryFragment fragment = new LibraryFragment(); LibraryFragment fragment = new LibraryFragment();
@ -82,12 +84,12 @@ public class LibraryFragment extends BaseFragment<LibraryPresenter> {
} }
private void createAdapter() { private void createAdapter() {
adapter = new LibraryAdapter<>(getActivity()); adapter = new LibraryAdapter(getActivity());
grid.setAdapter(adapter); grid.setAdapter(adapter);
} }
public LibraryAdapter<Manga> getAdapter() { public void onNextMangas(List<Manga> mangas) {
return adapter; adapter.setNewItems(mangas);
} }
@OnItemClick(R.id.gridView) @OnItemClick(R.id.gridView)