changed object article to LatLon
This commit is contained in:
parent
7fd6f9d43f
commit
ca4d2d47a3
3 changed files with 14 additions and 21 deletions
|
@ -296,7 +296,7 @@ public class AmenityMenuBuilder extends MenuBuilder {
|
|||
if (text.contains(".wikipedia.org/w")) {
|
||||
if (Version.isPaidVersion(app)) {
|
||||
WikipediaArticleHelper wikipediaArticleHelper = new WikipediaArticleHelper(mapActivity, !light);
|
||||
wikipediaArticleHelper.getWikiArticle(amenity, text);
|
||||
wikipediaArticleHelper.showWikiArticle(amenity.getLocation(), text);
|
||||
} else {
|
||||
WikipediaArticleWikiLinkFragment.showInstance(mapActivity.getSupportFragmentManager(), text);
|
||||
}
|
||||
|
|
|
@ -22,7 +22,6 @@ import net.osmand.plus.download.DownloadResources;
|
|||
import net.osmand.plus.download.IndexItem;
|
||||
import net.osmand.plus.resources.AmenityIndexRepositoryBinary;
|
||||
import net.osmand.plus.wikivoyage.article.WikivoyageArticleWikiLinkFragment;
|
||||
import net.osmand.plus.wikivoyage.data.TravelArticle;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.io.UnsupportedEncodingException;
|
||||
|
@ -58,20 +57,20 @@ public class WikipediaArticleHelper {
|
|||
private CallbackWithObject<String> callback;
|
||||
private WeakReference<MapActivity> weakMapActivity;
|
||||
|
||||
private Object article;
|
||||
private LatLon articleLatLon;
|
||||
private String regionName;
|
||||
private String url;
|
||||
private String lang;
|
||||
private String name;
|
||||
private boolean isNightMode;
|
||||
|
||||
WikiArticleSearchTask(Object article,
|
||||
WikiArticleSearchTask(LatLon articleLatLon,
|
||||
String regionName,
|
||||
MapActivity mapActivity,
|
||||
boolean nightMode,
|
||||
String url,
|
||||
final CallbackWithObject<String> callback) {
|
||||
this.article = article;
|
||||
this.articleLatLon = articleLatLon;
|
||||
this.regionName = regionName;
|
||||
weakMapActivity = new WeakReference<>(mapActivity);
|
||||
this.isNightMode = nightMode;
|
||||
|
@ -97,16 +96,9 @@ public class WikipediaArticleHelper {
|
|||
if (application != null && !isCancelled()) {
|
||||
IndexItem item = null;
|
||||
try {
|
||||
if (article != null) {
|
||||
if (article instanceof TravelArticle) {
|
||||
TravelArticle travelArticle = (TravelArticle) article;
|
||||
item = DownloadResources.findSmallestIndexItemAt(application,
|
||||
new LatLon(travelArticle.getLat(), travelArticle.getLon()), DownloadActivityType.WIKIPEDIA_FILE);
|
||||
} else if (article instanceof Amenity) {
|
||||
Amenity amenityArticle = (Amenity) article;
|
||||
item = DownloadResources.findSmallestIndexItemAt(application,
|
||||
amenityArticle.getLocation(), DownloadActivityType.WIKIPEDIA_FILE);
|
||||
}
|
||||
if (articleLatLon != null) {
|
||||
item = DownloadResources.findSmallestIndexItemAt(application,
|
||||
articleLatLon, DownloadActivityType.WIKIPEDIA_FILE);
|
||||
}
|
||||
} catch (IOException e) {
|
||||
Log.e(TAG, e.getMessage(), e);
|
||||
|
@ -188,11 +180,11 @@ public class WikipediaArticleHelper {
|
|||
return null;
|
||||
}
|
||||
|
||||
public void getWikiArticle(Object article, String url) {
|
||||
if (article == null) {
|
||||
public void showWikiArticle(LatLon articleLatLon, String url) {
|
||||
if (articleLatLon == null) {
|
||||
return;
|
||||
}
|
||||
articleSearchTask = new WikiArticleSearchTask(article, regionName, mapActivity, nightMode, url, new CallbackWithObject<String>() {
|
||||
articleSearchTask = new WikiArticleSearchTask(articleLatLon, regionName, mapActivity, nightMode, url, new CallbackWithObject<String>() {
|
||||
@Override
|
||||
public boolean processResult(String s) {
|
||||
regionName = s;
|
||||
|
|
|
@ -12,6 +12,7 @@ import android.util.Log;
|
|||
import android.webkit.WebView;
|
||||
import android.webkit.WebViewClient;
|
||||
|
||||
import net.osmand.data.LatLon;
|
||||
import net.osmand.data.PointDescription;
|
||||
import net.osmand.plus.GPXUtilities;
|
||||
import net.osmand.plus.OsmandApplication;
|
||||
|
@ -64,8 +65,8 @@ public class WikivoyageWebViewClient extends WebViewClient {
|
|||
public boolean shouldOverrideUrlLoading(WebView view, String url) {
|
||||
boolean isWebPage = url.startsWith(PAGE_PREFIX_HTTP) || url.startsWith(PAGE_PREFIX_HTTPS);
|
||||
if (url.contains(WIKIVOAYAGE_DOMAIN) && isWebPage) {
|
||||
String lang = wikipediaArticleHelper.getLang(url);
|
||||
String articleName = wikipediaArticleHelper.getArticleNameFromUrl(url, lang);
|
||||
String lang = WikipediaArticleHelper.getLang(url);
|
||||
String articleName = WikipediaArticleHelper.getArticleNameFromUrl(url, lang);
|
||||
long articleId = app.getTravelDbHelper().getArticleId(articleName, lang);
|
||||
if (articleId != 0) {
|
||||
WikivoyageArticleDialogFragment.showInstance(app, fragmentManager, articleId, lang);
|
||||
|
@ -74,7 +75,7 @@ public class WikivoyageWebViewClient extends WebViewClient {
|
|||
}
|
||||
return true;
|
||||
} else if (url.contains(WIKI_DOMAIN) && isWebPage) {
|
||||
wikipediaArticleHelper.getWikiArticle(article, url);
|
||||
wikipediaArticleHelper.showWikiArticle(new LatLon(article.getLat(), article.getLon()), url);
|
||||
} else if (isWebPage) {
|
||||
warnAboutExternalLoad(url, context, nightMode);
|
||||
} else if (url.startsWith(PREFIX_GEO)) {
|
||||
|
|
Loading…
Reference in a new issue