summaryrefslogtreecommitdiff
path: root/app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java
diff options
context:
space:
mode:
authorByteHamster <ByteHamster@users.noreply.github.com>2023-10-13 17:31:09 +0200
committerGitHub <noreply@github.com>2023-10-13 17:31:09 +0200
commit58484d5790cd8410368f989e1ce3390a666a4346 (patch)
tree9a4ff81c81e6d2626e712da2a111014b8def9320 /app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java
parent2ee2cb67029c27200324884127f556d89e2e9460 (diff)
downloadAntennaPod-58484d5790cd8410368f989e1ce3390a666a4346.zip
Add 'Search online' button if local search has no results (#6681)
Diffstat (limited to 'app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java')
-rw-r--r--app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java19
1 files changed, 19 insertions, 0 deletions
diff --git a/app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java b/app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java
index b85e34e7d..307ef0af1 100644
--- a/app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java
+++ b/app/src/main/java/de/danoeh/antennapod/fragment/SearchFragment.java
@@ -2,6 +2,7 @@ package de.danoeh.antennapod.fragment;
import android.content.Context;
+import android.content.Intent;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
@@ -26,6 +27,7 @@ import com.google.android.material.chip.Chip;
import de.danoeh.antennapod.R;
import de.danoeh.antennapod.activity.MainActivity;
+import de.danoeh.antennapod.activity.OnlineFeedViewActivity;
import de.danoeh.antennapod.adapter.EpisodeItemListAdapter;
import de.danoeh.antennapod.adapter.HorizontalFeedListAdapter;
import de.danoeh.antennapod.core.menuhandler.MenuItemUtils;
@@ -39,6 +41,7 @@ import de.danoeh.antennapod.model.feed.FeedItem;
import de.danoeh.antennapod.core.storage.FeedSearcher;
import de.danoeh.antennapod.core.util.FeedItemUtil;
import de.danoeh.antennapod.menuhandler.FeedItemMenuHandler;
+import de.danoeh.antennapod.net.discovery.CombinedSearcher;
import de.danoeh.antennapod.view.EmptyViewHandler;
import de.danoeh.antennapod.view.EpisodeItemListRecyclerView;
import de.danoeh.antennapod.view.LiftOnScrollListener;
@@ -334,6 +337,7 @@ public class SearchFragment extends Fragment {
if (disposable != null) {
disposable.dispose();
}
+ adapterFeeds.setEndButton(R.string.search_online, this::searchOnline);
chip.setVisibility((getArguments().getLong(ARG_FEED, 0) == 0) ? View.GONE : View.VISIBLE);
disposable = Observable.fromCallable(this::performSearch)
.subscribeOn(Schedulers.io())
@@ -374,4 +378,19 @@ public class SearchFragment extends Fragment {
imm.showSoftInput(view, 0);
}
}
+
+ private void searchOnline() {
+ searchView.clearFocus();
+ InputMethodManager in = (InputMethodManager) getActivity().getSystemService(Context.INPUT_METHOD_SERVICE);
+ in.hideSoftInputFromWindow(searchView.getWindowToken(), 0);
+ String query = searchView.getQuery().toString();
+ if (query.matches("http[s]?://.*")) {
+ Intent intent = new Intent(getActivity(), OnlineFeedViewActivity.class);
+ intent.putExtra(OnlineFeedViewActivity.ARG_FEEDURL, query);
+ startActivity(intent);
+ return;
+ }
+ ((MainActivity) getActivity()).loadChildFragment(
+ OnlineSearchFragment.newInstance(CombinedSearcher.class, query));
+ }
}