Merge pull request #3551 from ByteHamster/eventdistributor

Migrated some events from EventDistributor to EventBus
This commit is contained in:
H. Lehmann 2019-10-24 22:28:33 +02:00 committed by GitHub
commit 437f3f29c0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 80 additions and 39 deletions

View File

@ -16,6 +16,7 @@ import java.util.List;
import de.danoeh.antennapod.R; import de.danoeh.antennapod.R;
import de.danoeh.antennapod.activity.MainActivity; import de.danoeh.antennapod.activity.MainActivity;
import de.danoeh.antennapod.adapter.DownloadedEpisodesListAdapter; import de.danoeh.antennapod.adapter.DownloadedEpisodesListAdapter;
import de.danoeh.antennapod.core.event.DownloadLogEvent;
import de.danoeh.antennapod.core.feed.EventDistributor; import de.danoeh.antennapod.core.feed.EventDistributor;
import de.danoeh.antennapod.core.feed.FeedItem; import de.danoeh.antennapod.core.feed.FeedItem;
import de.danoeh.antennapod.core.storage.DBReader; import de.danoeh.antennapod.core.storage.DBReader;
@ -27,6 +28,8 @@ import io.reactivex.Observable;
import io.reactivex.android.schedulers.AndroidSchedulers; import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.Disposable; import io.reactivex.disposables.Disposable;
import io.reactivex.schedulers.Schedulers; import io.reactivex.schedulers.Schedulers;
import org.greenrobot.eventbus.EventBus;
import org.greenrobot.eventbus.Subscribe;
import static de.danoeh.antennapod.dialog.EpisodesApplyActionFragment.ACTION_ADD_TO_QUEUE; import static de.danoeh.antennapod.dialog.EpisodesApplyActionFragment.ACTION_ADD_TO_QUEUE;
import static de.danoeh.antennapod.dialog.EpisodesApplyActionFragment.ACTION_DELETE; import static de.danoeh.antennapod.dialog.EpisodesApplyActionFragment.ACTION_DELETE;
@ -38,10 +41,6 @@ public class CompletedDownloadsFragment extends ListFragment {
private static final String TAG = CompletedDownloadsFragment.class.getSimpleName(); private static final String TAG = CompletedDownloadsFragment.class.getSimpleName();
private static final int EVENTS = EventDistributor.DOWNLOAD_HANDLED |
EventDistributor.DOWNLOADLOG_UPDATE |
EventDistributor.UNREAD_ITEMS_UPDATE;
private List<FeedItem> items = new ArrayList<>(); private List<FeedItem> items = new ArrayList<>();
private DownloadedEpisodesListAdapter listAdapter; private DownloadedEpisodesListAdapter listAdapter;
private Disposable disposable; private Disposable disposable;
@ -56,6 +55,13 @@ public class CompletedDownloadsFragment extends ListFragment {
listAdapter = new DownloadedEpisodesListAdapter(getActivity(), itemAccess); listAdapter = new DownloadedEpisodesListAdapter(getActivity(), itemAccess);
setListAdapter(listAdapter); setListAdapter(listAdapter);
setListShown(false); setListShown(false);
EventBus.getDefault().register(this);
}
@Override
public void onDestroyView() {
EventBus.getDefault().unregister(this);
super.onDestroyView();
} }
@Override @Override
@ -138,12 +144,17 @@ public class CompletedDownloadsFragment extends ListFragment {
private final EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() { private final EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() {
@Override @Override
public void update(EventDistributor eventDistributor, Integer arg) { public void update(EventDistributor eventDistributor, Integer arg) {
if ((arg & EVENTS) != 0) { if ((arg & EventDistributor.UNREAD_ITEMS_UPDATE) != 0) {
loadItems(); loadItems();
} }
} }
}; };
@Subscribe
public void onDownloadLogChanged(DownloadLogEvent event) {
loadItems();
}
private void loadItems() { private void loadItems() {
if (disposable != null) { if (disposable != null) {
disposable.dispose(); disposable.dispose();

View File

@ -19,6 +19,7 @@ import java.util.List;
import de.danoeh.antennapod.R; import de.danoeh.antennapod.R;
import de.danoeh.antennapod.adapter.DownloadLogAdapter; import de.danoeh.antennapod.adapter.DownloadLogAdapter;
import de.danoeh.antennapod.core.event.DownloadLogEvent;
import de.danoeh.antennapod.core.feed.EventDistributor; import de.danoeh.antennapod.core.feed.EventDistributor;
import de.danoeh.antennapod.core.feed.Feed; import de.danoeh.antennapod.core.feed.Feed;
import de.danoeh.antennapod.core.feed.FeedMedia; import de.danoeh.antennapod.core.feed.FeedMedia;
@ -30,6 +31,8 @@ import io.reactivex.Observable;
import io.reactivex.android.schedulers.AndroidSchedulers; import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.disposables.Disposable; import io.reactivex.disposables.Disposable;
import io.reactivex.schedulers.Schedulers; import io.reactivex.schedulers.Schedulers;
import org.greenrobot.eventbus.EventBus;
import org.greenrobot.eventbus.Subscribe;
/** /**
* Shows the download log * Shows the download log
@ -45,14 +48,12 @@ public class DownloadLogFragment extends ListFragment {
@Override @Override
public void onStart() { public void onStart() {
super.onStart(); super.onStart();
EventDistributor.getInstance().register(contentUpdate);
loadItems(); loadItems();
} }
@Override @Override
public void onStop() { public void onStop() {
super.onStop(); super.onStop();
EventDistributor.getInstance().unregister(contentUpdate);
if (disposable != null) { if (disposable != null) {
disposable.dispose(); disposable.dispose();
} }
@ -77,6 +78,13 @@ public class DownloadLogFragment extends ListFragment {
adapter = new DownloadLogAdapter(getActivity(), itemAccess); adapter = new DownloadLogAdapter(getActivity(), itemAccess);
setListAdapter(adapter); setListAdapter(adapter);
EventBus.getDefault().register(this);
}
@Override
public void onDestroyView() {
EventBus.getDefault().unregister(this);
super.onDestroyView();
} }
private void onFragmentLoaded() { private void onFragmentLoaded() {
@ -133,15 +141,10 @@ public class DownloadLogFragment extends ListFragment {
} }
}; };
private final EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() { @Subscribe
public void onDownloadLogChanged(DownloadLogEvent event) {
@Override
public void update(EventDistributor eventDistributor, Integer arg) {
if ((arg & EventDistributor.DOWNLOADLOG_UPDATE) != 0) {
loadItems(); loadItems();
} }
}
};
@Override @Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {

View File

@ -12,6 +12,7 @@ import android.view.MenuItem;
import android.view.View; import android.view.View;
import android.widget.ListView; import android.widget.ListView;
import de.danoeh.antennapod.core.event.PlaybackHistoryEvent;
import org.greenrobot.eventbus.EventBus; import org.greenrobot.eventbus.EventBus;
import org.greenrobot.eventbus.Subscribe; import org.greenrobot.eventbus.Subscribe;
import org.greenrobot.eventbus.ThreadMode; import org.greenrobot.eventbus.ThreadMode;
@ -42,8 +43,7 @@ public class PlaybackHistoryFragment extends ListFragment {
public static final String TAG = "PlaybackHistoryFragment"; public static final String TAG = "PlaybackHistoryFragment";
private static final int EVENTS = EventDistributor.PLAYBACK_HISTORY_UPDATE | private static final int EVENTS = EventDistributor.PLAYER_STATUS_UPDATE;
EventDistributor.PLAYER_STATUS_UPDATE;
private List<FeedItem> playbackHistory; private List<FeedItem> playbackHistory;
private FeedItemlistAdapter adapter; private FeedItemlistAdapter adapter;
@ -166,6 +166,12 @@ public class PlaybackHistoryFragment extends ListFragment {
} }
} }
@Subscribe(threadMode = ThreadMode.MAIN)
public void onHistoryUpdated(PlaybackHistoryEvent event) {
loadItems();
getActivity().supportInvalidateOptionsMenu();
}
private final EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() { private final EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() {
@Override @Override

View File

@ -76,9 +76,8 @@ public class QueueFragment extends Fragment {
public static final String TAG = "QueueFragment"; public static final String TAG = "QueueFragment";
private static final int EVENTS = EventDistributor.DOWNLOAD_HANDLED | private static final int EVENTS = EventDistributor.UNREAD_ITEMS_UPDATE // sent when playback position is reset
EventDistributor.UNREAD_ITEMS_UPDATE | // sent when playback position is reset | EventDistributor.PLAYER_STATUS_UPDATE;
EventDistributor.PLAYER_STATUS_UPDATE;
private TextView infoBar; private TextView infoBar;
private RecyclerView recyclerView; private RecyclerView recyclerView;

View File

@ -148,8 +148,7 @@ public class SearchFragment extends ListFragment {
private final EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() { private final EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() {
@Override @Override
public void update(EventDistributor eventDistributor, Integer arg) { public void update(EventDistributor eventDistributor, Integer arg) {
if ((arg & (EventDistributor.UNREAD_ITEMS_UPDATE if ((arg & EventDistributor.UNREAD_ITEMS_UPDATE) != 0) {
| EventDistributor.DOWNLOAD_HANDLED)) != 0) {
search(); search();
} }
} }

View File

@ -0,0 +1,16 @@
package de.danoeh.antennapod.core.event;
public class DownloadLogEvent {
private DownloadLogEvent() {
}
public static DownloadLogEvent listUpdated() {
return new DownloadLogEvent();
}
@Override
public String toString() {
return "DownloadLogEvent";
}
}

View File

@ -0,0 +1,16 @@
package de.danoeh.antennapod.core.event;
public class PlaybackHistoryEvent {
private PlaybackHistoryEvent() {
}
public static PlaybackHistoryEvent listUpdated() {
return new PlaybackHistoryEvent();
}
@Override
public String toString() {
return "PlaybackHistoryEvent";
}
}

View File

@ -22,9 +22,6 @@ public class EventDistributor extends Observable {
public static final int FEED_LIST_UPDATE = 1; public static final int FEED_LIST_UPDATE = 1;
public static final int UNREAD_ITEMS_UPDATE = 2; public static final int UNREAD_ITEMS_UPDATE = 2;
public static final int DOWNLOADLOG_UPDATE = 8;
public static final int PLAYBACK_HISTORY_UPDATE = 16;
public static final int DOWNLOAD_HANDLED = 64;
public static final int PLAYER_STATUS_UPDATE = 128; public static final int PLAYER_STATUS_UPDATE = 128;
private final Handler handler; private final Handler handler;
@ -86,14 +83,6 @@ public class EventDistributor extends Observable {
addEvent(FEED_LIST_UPDATE); addEvent(FEED_LIST_UPDATE);
} }
public void sendPlaybackHistoryUpdateBroadcast() {
addEvent(PLAYBACK_HISTORY_UPDATE);
}
public void sendDownloadLogUpdateBroadcast() {
addEvent(DOWNLOADLOG_UPDATE);
}
public void sendPlayerStatusUpdateBroadcast() { addEvent(PLAYER_STATUS_UPDATE); } public void sendPlayerStatusUpdateBroadcast() { addEvent(PLAYER_STATUS_UPDATE); }
public abstract static class EventListener implements Observer { public abstract static class EventListener implements Observer {

View File

@ -6,6 +6,8 @@ import android.util.Log;
import androidx.annotation.NonNull; import androidx.annotation.NonNull;
import de.danoeh.antennapod.core.event.DownloadLogEvent;
import de.danoeh.antennapod.core.event.PlaybackHistoryEvent;
import org.greenrobot.eventbus.EventBus; import org.greenrobot.eventbus.EventBus;
import java.io.File; import java.io.File;
@ -176,7 +178,7 @@ public class DBWriter {
// we assume we also removed download log entries for the feed or its media files. // we assume we also removed download log entries for the feed or its media files.
// especially important if download or refresh failed, as the user should not be able // especially important if download or refresh failed, as the user should not be able
// to retry these // to retry these
EventDistributor.getInstance().sendDownloadLogUpdateBroadcast(); EventBus.getDefault().post(DownloadLogEvent.listUpdated());
BackupManager backupManager = new BackupManager(context); BackupManager backupManager = new BackupManager(context);
backupManager.dataChanged(); backupManager.dataChanged();
@ -193,7 +195,7 @@ public class DBWriter {
adapter.open(); adapter.open();
adapter.clearPlaybackHistory(); adapter.clearPlaybackHistory();
adapter.close(); adapter.close();
EventDistributor.getInstance().sendPlaybackHistoryUpdateBroadcast(); EventBus.getDefault().post(PlaybackHistoryEvent.listUpdated());
}); });
} }
@ -206,7 +208,7 @@ public class DBWriter {
adapter.open(); adapter.open();
adapter.clearDownloadLog(); adapter.clearDownloadLog();
adapter.close(); adapter.close();
EventDistributor.getInstance().sendDownloadLogUpdateBroadcast(); EventBus.getDefault().post(DownloadLogEvent.listUpdated());
}); });
} }
@ -227,7 +229,7 @@ public class DBWriter {
adapter.open(); adapter.open();
adapter.setFeedMediaPlaybackCompletionDate(media); adapter.setFeedMediaPlaybackCompletionDate(media);
adapter.close(); adapter.close();
EventDistributor.getInstance().sendPlaybackHistoryUpdateBroadcast(); EventBus.getDefault().post(PlaybackHistoryEvent.listUpdated());
}); });
} }
@ -243,7 +245,7 @@ public class DBWriter {
adapter.open(); adapter.open();
adapter.setDownloadStatus(status); adapter.setDownloadStatus(status);
adapter.close(); adapter.close();
EventDistributor.getInstance().sendDownloadLogUpdateBroadcast(); EventBus.getDefault().post(DownloadLogEvent.listUpdated());
}); });
} }