summaryrefslogtreecommitdiff
path: root/app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java
diff options
context:
space:
mode:
authordaniel oeh <daniel.oeh@gmail.com>2014-10-25 11:20:29 +0200
committerdaniel oeh <daniel.oeh@gmail.com>2014-10-25 11:20:29 +0200
commitdcc7c9d25d5540f0caa6e10b2bb69a249e340455 (patch)
tree87b6f93fdfa40d0e6f771687d1e625fa60b51bb2 /app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java
parent17feaa72adfee3e0ceb66a8fb20a262f702e0cc0 (diff)
downloadAntennaPod-dcc7c9d25d5540f0caa6e10b2bb69a249e340455.zip
Removed use of indeterminate progress bar
No longer supported in version 21 of the support library
Diffstat (limited to 'app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java')
-rw-r--r--app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java26
1 files changed, 15 insertions, 11 deletions
diff --git a/app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java b/app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java
index d126f2980..d423c335a 100644
--- a/app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java
+++ b/app/src/main/java/de/danoeh/antennapod/fragment/NewEpisodesFragment.java
@@ -7,6 +7,7 @@ import android.os.AsyncTask;
import android.os.Bundle;
import android.os.Handler;
import android.support.v4.app.Fragment;
+import android.support.v4.view.MenuItemCompat;
import android.support.v7.app.ActionBarActivity;
import android.support.v7.widget.SearchView;
import android.view.*;
@@ -75,6 +76,8 @@ public class NewEpisodesFragment extends Fragment {
private FeedItemDialog feedItemDialog;
private FeedItemDialog.FeedItemDialogSavedInstance feedItemDialogSavedInstance;
+ private boolean isUpdatingFeeds;
+
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
@@ -136,6 +139,14 @@ public class NewEpisodesFragment extends Fragment {
feedItemDialog = null;
}
+
+ private final MenuItemUtils.UpdateRefreshMenuItemChecker updateRefreshMenuItemChecker = new MenuItemUtils.UpdateRefreshMenuItemChecker() {
+ @Override
+ public boolean isRefreshing() {
+ return DownloadService.isRunning && DownloadRequester.getInstance().isDownloadingFeeds();
+ }
+ };
+
@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
super.onCreateOptionsMenu(menu, inflater);
@@ -158,6 +169,7 @@ public class NewEpisodesFragment extends Fragment {
return false;
}
});
+ isUpdatingFeeds = MenuItemUtils.updateRefreshMenuItem(menu, R.id.refresh_item, updateRefreshMenuItemChecker);
}
}
@@ -252,7 +264,6 @@ public class NewEpisodesFragment extends Fragment {
}
listAdapter.notifyDataSetChanged();
getActivity().supportInvalidateOptionsMenu();
- updateProgressBarVisibility();
updateShowOnlyEpisodesListViewState();
}
@@ -319,21 +330,14 @@ public class NewEpisodesFragment extends Fragment {
};
- private void updateProgressBarVisibility() {
- if (!viewsCreated) {
- return;
- }
- ((ActionBarActivity) getActivity())
- .setSupportProgressBarIndeterminateVisibility(DownloadService.isRunning
- && DownloadRequester.getInstance().isDownloadingFeeds());
- }
-
private EventDistributor.EventListener contentUpdate = new EventDistributor.EventListener() {
@Override
public void update(EventDistributor eventDistributor, Integer arg) {
if ((arg & EVENTS) != 0) {
startItemLoader();
- updateProgressBarVisibility();
+ if (isUpdatingFeeds != updateRefreshMenuItemChecker.isRefreshing()) {
+ getActivity().supportInvalidateOptionsMenu();
+ }
}
}
};