Merge pull request #3434 from orionlee/access_feed_from_player_2929
add Open Podcast to player screen
This commit is contained in:
commit
ab7d36f77f
@ -2,6 +2,7 @@ package de.danoeh.antennapod.activity;
|
|||||||
|
|
||||||
import android.annotation.TargetApi;
|
import android.annotation.TargetApi;
|
||||||
import android.app.ProgressDialog;
|
import android.app.ProgressDialog;
|
||||||
|
import android.content.Context;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
@ -10,6 +11,7 @@ import android.database.DataSetObserver;
|
|||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
|
import android.support.annotation.NonNull;
|
||||||
import android.support.annotation.VisibleForTesting;
|
import android.support.annotation.VisibleForTesting;
|
||||||
import android.support.design.widget.Snackbar;
|
import android.support.design.widget.Snackbar;
|
||||||
import android.support.v4.app.Fragment;
|
import android.support.v4.app.Fragment;
|
||||||
@ -32,9 +34,11 @@ import android.widget.Toast;
|
|||||||
|
|
||||||
import com.bumptech.glide.Glide;
|
import com.bumptech.glide.Glide;
|
||||||
|
|
||||||
import de.danoeh.antennapod.preferences.PreferenceUpgrader;
|
|
||||||
import org.apache.commons.lang3.ArrayUtils;
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
import org.apache.commons.lang3.Validate;
|
import org.apache.commons.lang3.Validate;
|
||||||
|
import org.greenrobot.eventbus.EventBus;
|
||||||
|
import org.greenrobot.eventbus.Subscribe;
|
||||||
|
import org.greenrobot.eventbus.ThreadMode;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -67,13 +71,11 @@ import de.danoeh.antennapod.fragment.PlaybackHistoryFragment;
|
|||||||
import de.danoeh.antennapod.fragment.QueueFragment;
|
import de.danoeh.antennapod.fragment.QueueFragment;
|
||||||
import de.danoeh.antennapod.fragment.SubscriptionFragment;
|
import de.danoeh.antennapod.fragment.SubscriptionFragment;
|
||||||
import de.danoeh.antennapod.menuhandler.NavDrawerActivity;
|
import de.danoeh.antennapod.menuhandler.NavDrawerActivity;
|
||||||
|
import de.danoeh.antennapod.preferences.PreferenceUpgrader;
|
||||||
import io.reactivex.Observable;
|
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 org.greenrobot.eventbus.ThreadMode;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The activity that is shown when the user launches the app.
|
* The activity that is shown when the user launches the app.
|
||||||
@ -93,7 +95,7 @@ public class MainActivity extends CastEnabledActivity implements NavDrawerActivi
|
|||||||
public static final String EXTRA_NAV_INDEX = "nav_index";
|
public static final String EXTRA_NAV_INDEX = "nav_index";
|
||||||
public static final String EXTRA_FRAGMENT_TAG = "fragment_tag";
|
public static final String EXTRA_FRAGMENT_TAG = "fragment_tag";
|
||||||
public static final String EXTRA_FRAGMENT_ARGS = "fragment_args";
|
public static final String EXTRA_FRAGMENT_ARGS = "fragment_args";
|
||||||
public static final String EXTRA_FEED_ID = "fragment_feed_id";
|
private static final String EXTRA_FEED_ID = "fragment_feed_id";
|
||||||
|
|
||||||
private static final String SAVE_BACKSTACK_COUNT = "backstackCount";
|
private static final String SAVE_BACKSTACK_COUNT = "backstackCount";
|
||||||
private static final String SAVE_TITLE = "title";
|
private static final String SAVE_TITLE = "title";
|
||||||
@ -127,6 +129,14 @@ public class MainActivity extends CastEnabledActivity implements NavDrawerActivi
|
|||||||
|
|
||||||
private long lastBackButtonPressTime = 0;
|
private long lastBackButtonPressTime = 0;
|
||||||
|
|
||||||
|
@NonNull
|
||||||
|
public static Intent getIntentToOpenFeed(@NonNull Context context, long feedId) {
|
||||||
|
Intent intent = new Intent(context.getApplicationContext(), MainActivity.class);
|
||||||
|
intent.putExtra(MainActivity.EXTRA_FEED_ID, feedId);
|
||||||
|
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
||||||
|
return intent;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreate(Bundle savedInstanceState) {
|
public void onCreate(Bundle savedInstanceState) {
|
||||||
setTheme(UserPreferences.getNoTitleTheme());
|
setTheme(UserPreferences.getNoTitleTheme());
|
||||||
|
@ -322,6 +322,8 @@ public abstract class MediaplayerActivity extends CastEnabledActivity implements
|
|||||||
Playable media = controller.getMedia();
|
Playable media = controller.getMedia();
|
||||||
boolean isFeedMedia = media != null && (media instanceof FeedMedia);
|
boolean isFeedMedia = media != null && (media instanceof FeedMedia);
|
||||||
|
|
||||||
|
menu.findItem(R.id.open_feed_item).setVisible(isFeedMedia); // FeedMedia implies it belongs to a Feed
|
||||||
|
|
||||||
boolean hasWebsiteLink = ( getWebsiteLinkWithFallback(media) != null );
|
boolean hasWebsiteLink = ( getWebsiteLinkWithFallback(media) != null );
|
||||||
menu.findItem(R.id.visit_website_item).setVisible(hasWebsiteLink);
|
menu.findItem(R.id.visit_website_item).setVisible(hasWebsiteLink);
|
||||||
|
|
||||||
@ -389,30 +391,25 @@ public abstract class MediaplayerActivity extends CastEnabledActivity implements
|
|||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
if (media != null) {
|
if (media != null) {
|
||||||
|
final @Nullable FeedItem feedItem = getFeedItem(media); // some options option requires FeedItem
|
||||||
switch (item.getItemId()) {
|
switch (item.getItemId()) {
|
||||||
case R.id.add_to_favorites_item:
|
case R.id.add_to_favorites_item:
|
||||||
if(media instanceof FeedMedia) {
|
if (feedItem != null) {
|
||||||
FeedItem feedItem = ((FeedMedia)media).getItem();
|
|
||||||
if(feedItem != null) {
|
|
||||||
DBWriter.addFavoriteItem(feedItem);
|
DBWriter.addFavoriteItem(feedItem);
|
||||||
isFavorite = true;
|
isFavorite = true;
|
||||||
invalidateOptionsMenu();
|
invalidateOptionsMenu();
|
||||||
Toast.makeText(this, R.string.added_to_favorites, Toast.LENGTH_SHORT)
|
Toast.makeText(this, R.string.added_to_favorites, Toast.LENGTH_SHORT)
|
||||||
.show();
|
.show();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case R.id.remove_from_favorites_item:
|
case R.id.remove_from_favorites_item:
|
||||||
if(media instanceof FeedMedia) {
|
if (feedItem != null) {
|
||||||
FeedItem feedItem = ((FeedMedia)media).getItem();
|
|
||||||
if(feedItem != null) {
|
|
||||||
DBWriter.removeFavoriteItem(feedItem);
|
DBWriter.removeFavoriteItem(feedItem);
|
||||||
isFavorite = false;
|
isFavorite = false;
|
||||||
invalidateOptionsMenu();
|
invalidateOptionsMenu();
|
||||||
Toast.makeText(this, R.string.removed_from_favorites, Toast.LENGTH_SHORT)
|
Toast.makeText(this, R.string.removed_from_favorites, Toast.LENGTH_SHORT)
|
||||||
.show();
|
.show();
|
||||||
}
|
}
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case R.id.disable_sleeptimer_item:
|
case R.id.disable_sleeptimer_item:
|
||||||
if (controller.serviceAvailable()) {
|
if (controller.serviceAvailable()) {
|
||||||
@ -448,28 +445,34 @@ public abstract class MediaplayerActivity extends CastEnabledActivity implements
|
|||||||
PlaybackControlsDialog dialog = PlaybackControlsDialog.newInstance(isPlayingVideo);
|
PlaybackControlsDialog dialog = PlaybackControlsDialog.newInstance(isPlayingVideo);
|
||||||
dialog.show(getSupportFragmentManager(), "playback_controls");
|
dialog.show(getSupportFragmentManager(), "playback_controls");
|
||||||
break;
|
break;
|
||||||
|
case R.id.open_feed_item:
|
||||||
|
if (feedItem != null) {
|
||||||
|
Intent intent = MainActivity.getIntentToOpenFeed(this, feedItem.getFeedId());
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
|
break;
|
||||||
case R.id.visit_website_item:
|
case R.id.visit_website_item:
|
||||||
Uri uri = Uri.parse(getWebsiteLinkWithFallback(media));
|
Uri uri = Uri.parse(getWebsiteLinkWithFallback(media));
|
||||||
startActivity(new Intent(Intent.ACTION_VIEW, uri));
|
startActivity(new Intent(Intent.ACTION_VIEW, uri));
|
||||||
break;
|
break;
|
||||||
case R.id.share_link_item:
|
case R.id.share_link_item:
|
||||||
if (media instanceof FeedMedia) {
|
if (feedItem != null) {
|
||||||
ShareUtils.shareFeedItemLink(this, ((FeedMedia) media).getItem());
|
ShareUtils.shareFeedItemLink(this, feedItem);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case R.id.share_download_url_item:
|
case R.id.share_download_url_item:
|
||||||
if (media instanceof FeedMedia) {
|
if (feedItem != null) {
|
||||||
ShareUtils.shareFeedItemDownloadLink(this, ((FeedMedia) media).getItem());
|
ShareUtils.shareFeedItemDownloadLink(this, feedItem);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case R.id.share_link_with_position_item:
|
case R.id.share_link_with_position_item:
|
||||||
if (media instanceof FeedMedia) {
|
if (feedItem != null) {
|
||||||
ShareUtils.shareFeedItemLink(this, ((FeedMedia) media).getItem(), true);
|
ShareUtils.shareFeedItemLink(this, feedItem, true);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case R.id.share_download_url_with_position_item:
|
case R.id.share_download_url_with_position_item:
|
||||||
if (media instanceof FeedMedia) {
|
if (feedItem != null) {
|
||||||
ShareUtils.shareFeedItemDownloadLink(this, ((FeedMedia) media).getItem(), true);
|
ShareUtils.shareFeedItemDownloadLink(this, feedItem, true);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case R.id.share_file:
|
case R.id.share_file:
|
||||||
@ -813,11 +816,7 @@ public abstract class MediaplayerActivity extends CastEnabledActivity implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void checkFavorite() {
|
private void checkFavorite() {
|
||||||
Playable playable = controller.getMedia();
|
FeedItem feedItem = getFeedItem(controller.getMedia());
|
||||||
if (!(playable instanceof FeedMedia)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
FeedItem feedItem = ((FeedMedia) playable).getItem();
|
|
||||||
if (feedItem == null) {
|
if (feedItem == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -872,4 +871,13 @@ public abstract class MediaplayerActivity extends CastEnabledActivity implements
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
private static FeedItem getFeedItem(@Nullable Playable playable) {
|
||||||
|
if ((playable != null) && (playable instanceof FeedMedia)) {
|
||||||
|
return ((FeedMedia)playable).getItem();
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -32,7 +32,6 @@ import android.widget.TextView;
|
|||||||
import com.bumptech.glide.Glide;
|
import com.bumptech.glide.Glide;
|
||||||
import com.bumptech.glide.request.RequestOptions;
|
import com.bumptech.glide.request.RequestOptions;
|
||||||
|
|
||||||
import de.danoeh.antennapod.core.glide.FastBlurTransformation;
|
|
||||||
import org.apache.commons.lang3.StringUtils;
|
import org.apache.commons.lang3.StringUtils;
|
||||||
import org.greenrobot.eventbus.EventBus;
|
import org.greenrobot.eventbus.EventBus;
|
||||||
import org.greenrobot.eventbus.Subscribe;
|
import org.greenrobot.eventbus.Subscribe;
|
||||||
@ -55,6 +54,7 @@ import de.danoeh.antennapod.core.feed.Feed;
|
|||||||
import de.danoeh.antennapod.core.feed.FeedItem;
|
import de.danoeh.antennapod.core.feed.FeedItem;
|
||||||
import de.danoeh.antennapod.core.feed.FeedPreferences;
|
import de.danoeh.antennapod.core.feed.FeedPreferences;
|
||||||
import de.danoeh.antennapod.core.glide.ApGlideSettings;
|
import de.danoeh.antennapod.core.glide.ApGlideSettings;
|
||||||
|
import de.danoeh.antennapod.core.glide.FastBlurTransformation;
|
||||||
import de.danoeh.antennapod.core.preferences.UserPreferences;
|
import de.danoeh.antennapod.core.preferences.UserPreferences;
|
||||||
import de.danoeh.antennapod.core.service.download.DownloadRequest;
|
import de.danoeh.antennapod.core.service.download.DownloadRequest;
|
||||||
import de.danoeh.antennapod.core.service.download.DownloadStatus;
|
import de.danoeh.antennapod.core.service.download.DownloadStatus;
|
||||||
@ -442,11 +442,9 @@ public class OnlineFeedViewActivity extends AppCompatActivity {
|
|||||||
|
|
||||||
subscribeButton.setOnClickListener(v -> {
|
subscribeButton.setOnClickListener(v -> {
|
||||||
if(feedInFeedlist(feed)) {
|
if(feedInFeedlist(feed)) {
|
||||||
Intent intent = new Intent(OnlineFeedViewActivity.this, MainActivity.class);
|
|
||||||
// feed.getId() is always 0, we have to retrieve the id from the feed list from
|
// feed.getId() is always 0, we have to retrieve the id from the feed list from
|
||||||
// the database
|
// the database
|
||||||
intent.putExtra(MainActivity.EXTRA_FEED_ID, getFeedId(feed));
|
Intent intent = MainActivity.getIntentToOpenFeed(this, getFeedId(feed));
|
||||||
intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
|
|
||||||
startActivity(intent);
|
startActivity(intent);
|
||||||
} else {
|
} else {
|
||||||
Feed f = new Feed(selectedDownloadUrl, null, feed.getTitle());
|
Feed f = new Feed(selectedDownloadUrl, null, feed.getTitle());
|
||||||
|
@ -34,6 +34,14 @@
|
|||||||
custom:showAsAction="always">
|
custom:showAsAction="always">
|
||||||
</item>
|
</item>
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/open_feed_item"
|
||||||
|
android:icon="?attr/feed"
|
||||||
|
custom:showAsAction="collapseActionView"
|
||||||
|
android:title="@string/open_podcast"
|
||||||
|
android:visible="false">
|
||||||
|
</item>
|
||||||
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/visit_website_item"
|
android:id="@+id/visit_website_item"
|
||||||
android:icon="?attr/location_web_site"
|
android:icon="?attr/location_web_site"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user