1
0
Fork 0
mirror of https://github.com/gsantner/dandelion synced 2024-11-24 21:32:07 +01:00

Capsulated diaspora urls into util.DiasporaUrlHelper

This commit is contained in:
vanitasvitae 2016-08-10 17:14:05 +02:00
parent 237a2f21e4
commit 4cb91d430a
2 changed files with 136 additions and 52 deletions

View file

@ -67,7 +67,6 @@ import android.webkit.ValueCallback;
import android.webkit.WebChromeClient; import android.webkit.WebChromeClient;
import android.webkit.WebSettings; import android.webkit.WebSettings;
import android.webkit.WebView; import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.EditText; import android.widget.EditText;
import android.widget.ImageView; import android.widget.ImageView;
import android.widget.LinearLayout; import android.widget.LinearLayout;
@ -83,6 +82,7 @@ import com.github.dfa.diaspora_android.data.PodUserProfile;
import com.github.dfa.diaspora_android.listener.WebUserProfileChangedListener; import com.github.dfa.diaspora_android.listener.WebUserProfileChangedListener;
import com.github.dfa.diaspora_android.ui.ContextMenuWebView; import com.github.dfa.diaspora_android.ui.ContextMenuWebView;
import com.github.dfa.diaspora_android.ui.CustomWebViewClient; import com.github.dfa.diaspora_android.ui.CustomWebViewClient;
import com.github.dfa.diaspora_android.util.DiasporaUrlHelper;
import com.github.dfa.diaspora_android.util.Helpers; import com.github.dfa.diaspora_android.util.Helpers;
import com.github.dfa.diaspora_android.util.WebHelper; import com.github.dfa.diaspora_android.util.WebHelper;
@ -125,6 +125,7 @@ public class MainActivity extends AppCompatActivity
private String mCameraPhotoPath; private String mCameraPhotoPath;
private WebSettings webSettings; private WebSettings webSettings;
private AppSettings appSettings; private AppSettings appSettings;
private DiasporaUrlHelper urls;
private PodUserProfile podUserProfile; private PodUserProfile podUserProfile;
private final Handler uiHandler = new Handler(); private final Handler uiHandler = new Handler();
private CustomWebViewClient webViewClient; private CustomWebViewClient webViewClient;
@ -183,6 +184,7 @@ public class MainActivity extends AppCompatActivity
podUserProfile = app.getPodUserProfile(); podUserProfile = app.getPodUserProfile();
podUserProfile.setCallbackHandler(uiHandler); podUserProfile.setCallbackHandler(uiHandler);
podUserProfile.setListener(this); podUserProfile.setListener(this);
urls = new DiasporaUrlHelper(appSettings);
if (appSettings.isProxyEnabled()) { if (appSettings.isProxyEnabled()) {
if (!setProxy(appSettings.getProxyHost(), appSettings.getProxyPort())) { if (!setProxy(appSettings.getProxyHost(), appSettings.getProxyPort())) {
@ -220,7 +222,7 @@ public class MainActivity extends AppCompatActivity
@Override @Override
public void onClick(View view) { public void onClick(View view) {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/notifications"); webView.loadUrl(urls.getNotificationsUrl());
} else { } else {
Snackbar.make(contentLayout, R.string.no_internet, Snackbar.LENGTH_LONG).show(); Snackbar.make(contentLayout, R.string.no_internet, Snackbar.LENGTH_LONG).show();
} }
@ -234,7 +236,7 @@ public class MainActivity extends AppCompatActivity
progressBar = (ProgressBar) findViewById(R.id.progressBar); progressBar = (ProgressBar) findViewById(R.id.progressBar);
podDomain = appSettings.getPodDomain(); podDomain = appSettings.getPodDomain();
String url = "https://" + podDomain; String url = urls.getPodUrl();
if (savedInstanceState == null) { if (savedInstanceState == null) {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadData("", "text/html", null); webView.loadData("", "text/html", null);
@ -508,7 +510,6 @@ public class MainActivity extends AppCompatActivity
@Override @Override
protected void onResume() { protected void onResume() {
super.onResume(); super.onResume();
//registerReceiver(brLoadUrl, new IntentFilter(URL_MESSAGE));
LocalBroadcastManager.getInstance(this).registerReceiver(brSetTitle, new IntentFilter(ACTION_UPDATE_TITLE_FROM_URL)); LocalBroadcastManager.getInstance(this).registerReceiver(brSetTitle, new IntentFilter(ACTION_UPDATE_TITLE_FROM_URL));
} }
@ -529,42 +530,33 @@ public class MainActivity extends AppCompatActivity
} }
} }
private final BroadcastReceiver brLoadUrl = new BroadcastReceiver() {
@Override
public void onReceive(Context context, Intent intent) {
String url = intent.getStringExtra("url");
webView.loadUrl(url);
}
};
private final BroadcastReceiver brSetTitle = new BroadcastReceiver() { private final BroadcastReceiver brSetTitle = new BroadcastReceiver() {
@Override @Override
public void onReceive(Context context, Intent intent) { public void onReceive(Context context, Intent intent) {
String url = intent.getStringExtra(EXTRA_URL); String url = intent.getStringExtra(EXTRA_URL);
if (url != null && url.startsWith("https://" + podDomain)) { if (url != null && url.startsWith(urls.getPodUrl())) {
String subUrl = url.substring(("https://" + podDomain).length()); String subUrl = url.substring((urls.getPodUrl()).length());
if (subUrl.startsWith("/stream")) { if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_STREAM)) {
setTitle(R.string.nav_stream); setTitle(R.string.nav_stream);
} else if (subUrl.startsWith("/posts/")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_POSTS)) {
setTitle(R.string.diaspora); //TODO: Extract posts title somehow? setTitle(R.string.diaspora); //TODO: Extract posts title somehow?
} else if (subUrl.startsWith("/notifications")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_NOTIFICATIONS)) {
setTitle(R.string.notifications); setTitle(R.string.notifications);
} else if (subUrl.startsWith("/conversations")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_CONVERSATIONS)) {
setTitle(R.string.conversations); setTitle(R.string.conversations);
} else if (subUrl.startsWith("/status_messages/new")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_NEW_POST)) {
setTitle(R.string.new_post); setTitle(R.string.new_post);
} else if (subUrl.startsWith("/people/" + appSettings.getProfileId())) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_PEOPLE + appSettings.getProfileId())) {
setTitle(R.string.nav_profile); setTitle(R.string.nav_profile);
} else if (subUrl.startsWith("/activity")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_ACTIVITY)) {
setTitle(R.string.nav_activities); setTitle(R.string.nav_activities);
} else if (subUrl.startsWith("/liked")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_LIKED)) {
setTitle(R.string.nav_liked); setTitle(R.string.nav_liked);
} else if (subUrl.startsWith("/commented")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_COMMENTED)) {
setTitle(R.string.nav_commented); setTitle(R.string.nav_commented);
} else if (subUrl.startsWith("/mentions")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_MENTIONS)) {
setTitle(R.string.nav_mentions); setTitle(R.string.nav_mentions);
} else if (subUrl.startsWith("/public")) { } else if (subUrl.startsWith(DiasporaUrlHelper.SUBURL_PUBLIC)) {
setTitle(R.string.public_); setTitle(R.string.public_);
} }
} }
@ -573,7 +565,6 @@ public class MainActivity extends AppCompatActivity
@Override @Override
protected void onPause() { protected void onPause() {
//unregisterReceiver(brLoadUrl);
LocalBroadcastManager.getInstance(this).unregisterReceiver(brSetTitle); LocalBroadcastManager.getInstance(this).unregisterReceiver(brSetTitle);
super.onPause(); super.onPause();
} }
@ -609,7 +600,7 @@ public class MainActivity extends AppCompatActivity
switch (item.getItemId()) { switch (item.getItemId()) {
case R.id.action_notifications: { case R.id.action_notifications: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/notifications"); webView.loadUrl(urls.getNotificationsUrl());
return true; return true;
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
@ -619,7 +610,7 @@ public class MainActivity extends AppCompatActivity
case R.id.action_conversations: { case R.id.action_conversations: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/conversations"); webView.loadUrl(urls.getConversationsUrl());
return true; return true;
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
@ -644,13 +635,13 @@ public class MainActivity extends AppCompatActivity
} }
case R.id.action_toggle_desktop_page: { case R.id.action_toggle_desktop_page: {
webView.loadUrl("https://" + podDomain + "/mobile/toggle"); webView.loadUrl(urls.getToggleMobileUrl());
return true; return true;
} }
case R.id.action_compose: { case R.id.action_compose: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/status_messages/new"); webView.loadUrl(urls.getNewPostUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -670,7 +661,7 @@ public class MainActivity extends AppCompatActivity
sharingIntent.setType("text/plain"); sharingIntent.setType("text/plain");
sharingIntent.putExtra(Intent.EXTRA_SUBJECT, webView.getTitle()); sharingIntent.putExtra(Intent.EXTRA_SUBJECT, webView.getTitle());
sharingIntent.putExtra(Intent.EXTRA_TEXT, webView.getUrl()); sharingIntent.putExtra(Intent.EXTRA_TEXT, webView.getUrl());
startActivity(Intent.createChooser(sharingIntent, "Share using")); startActivity(Intent.createChooser(sharingIntent, getResources().getString(R.string.action_share_dotdotdot)));
return true; return true;
} }
@ -707,9 +698,9 @@ public class MainActivity extends AppCompatActivity
Snackbar.make(contentLayout, R.string.search_alert_bypeople_validate_needsomedata, Snackbar.LENGTH_LONG).show(); Snackbar.make(contentLayout, R.string.search_alert_bypeople_validate_needsomedata, Snackbar.LENGTH_LONG).show();
} else { // User have added a search tag } else { // User have added a search tag
if (wasClickedOnSearchForPeople) { if (wasClickedOnSearchForPeople) {
webView.loadUrl("https://" + podDomain + "/people.mobile?q=" + cleanTag); webView.loadUrl(urls.getSearchPeopleUrl(cleanTag));
} else { } else {
webView.loadUrl("https://" + podDomain + "/tags/" + cleanTag); webView.loadUrl(urls.getSearchTagsUrl(cleanTag));
} }
} }
@ -855,8 +846,8 @@ public class MainActivity extends AppCompatActivity
} }
webView.stopLoading(); webView.stopLoading();
webView.loadUrl("about:blank"); webView.loadUrl(urls.getBlankUrl());
webView.loadUrl("https://"+podDomain+"/status_messages/new"); webView.loadUrl(urls.getNewPostUrl());
} }
/** /**
@ -864,7 +855,7 @@ public class MainActivity extends AppCompatActivity
* @param intent * @param intent
*/ */
void handleSendSubject(Intent intent) { void handleSendSubject(Intent intent) {
webView.loadUrl("https://"+podDomain+"/status_messages/new"); webView.loadUrl(urls.getNewPostUrl());
String content = WebHelper.replaceUrlWithMarkdown(intent.getStringExtra(Intent.EXTRA_TEXT)); String content = WebHelper.replaceUrlWithMarkdown(intent.getStringExtra(Intent.EXTRA_TEXT));
String subject = WebHelper.replaceUrlWithMarkdown(intent.getStringExtra(Intent.EXTRA_SUBJECT)); String subject = WebHelper.replaceUrlWithMarkdown(intent.getStringExtra(Intent.EXTRA_SUBJECT));
@ -878,8 +869,8 @@ public class MainActivity extends AppCompatActivity
textToBeShared = "**" + sharedSubject + "** " + sharedContent; textToBeShared = "**" + sharedSubject + "** " + sharedContent;
webView.stopLoading(); webView.stopLoading();
webView.loadUrl("about:blank"); webView.loadUrl(urls.getBlankUrl());
webView.loadUrl("https://"+podDomain+"/status_messages/new"); webView.loadUrl(urls.getNewPostUrl());
} }
//TODO: Implement? //TODO: Implement?
@ -898,7 +889,7 @@ public class MainActivity extends AppCompatActivity
invalidateOptionsMenu(); invalidateOptionsMenu();
if (notificationCount > 0 && !snackbarNewNotification.isShown() if (notificationCount > 0 && !snackbarNewNotification.isShown()
&& !webView.getUrl().equals("https://" + podDomain + "/notifications")) { && !webView.getUrl().equals(urls.getNotificationsUrl())) {
snackbarNewNotification.show(); snackbarNewNotification.show();
} }
} }
@ -910,7 +901,7 @@ public class MainActivity extends AppCompatActivity
invalidateOptionsMenu(); invalidateOptionsMenu();
if (unreadMessageCount > 0 && !snackbarNewNotification.isShown() if (unreadMessageCount > 0 && !snackbarNewNotification.isShown()
&& !webView.getUrl().equals("https://" + podDomain + "/notifications")) { && !webView.getUrl().equals(urls.getNotificationsUrl())) {
snackbarNewNotification.show(); snackbarNewNotification.show();
} }
} }
@ -941,7 +932,7 @@ public class MainActivity extends AppCompatActivity
switch (item.getItemId()) { switch (item.getItemId()) {
case R.id.nav_stream: { case R.id.nav_stream: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/stream"); webView.loadUrl(urls.getStreamUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -950,7 +941,7 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_profile: { case R.id.nav_profile: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/people/" + appSettings.getProfileId()); webView.loadUrl(urls.getProfileUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -959,7 +950,6 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_followed_tags: { case R.id.nav_followed_tags: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
// webView.loadUrl("https://" + podDomain + "/followed_tags");
WebHelper.showFollowedTagsList(webView, app); WebHelper.showFollowedTagsList(webView, app);
setTitle(R.string.nav_followed_tags); setTitle(R.string.nav_followed_tags);
} else { } else {
@ -970,7 +960,6 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_aspects: { case R.id.nav_aspects: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
// webView.loadUrl("https://" + podDomain + "/aspects");
WebHelper.showAspectList(webView, app); WebHelper.showAspectList(webView, app);
setTitle(R.string.aspects); setTitle(R.string.aspects);
} else { } else {
@ -981,7 +970,7 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_activities: { case R.id.nav_activities: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/activity"); webView.loadUrl(urls.getActivityUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -990,7 +979,7 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_liked: { case R.id.nav_liked: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/liked"); webView.loadUrl(urls.getLikedPostsUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -999,7 +988,7 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_commented: { case R.id.nav_commented: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/commented"); webView.loadUrl(urls.getCommentedUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -1008,7 +997,7 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_mentions: { case R.id.nav_mentions: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/mentions"); webView.loadUrl(urls.getMentionsUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -1017,7 +1006,7 @@ public class MainActivity extends AppCompatActivity
case R.id.nav_public: { case R.id.nav_public: {
if (WebHelper.isOnline(MainActivity.this)) { if (WebHelper.isOnline(MainActivity.this)) {
webView.loadUrl("https://" + podDomain + "/public"); webView.loadUrl(urls.getPublicUrl());
} else { } else {
snackbarNoInternet.show(); snackbarNoInternet.show();
} }
@ -1116,12 +1105,10 @@ public class MainActivity extends AppCompatActivity
} }
private boolean setProxy() { private boolean setProxy() {
Log.d(App.TAG, "Enable Proxy");
return setProxy(appSettings.getProxyHost(), appSettings.getProxyPort()); return setProxy(appSettings.getProxyHost(), appSettings.getProxyPort());
} }
private void resetProxy() { private void resetProxy() {
Log.d(App.TAG, "Reset Proxy");
appSettings.setProxyEnabled(false); appSettings.setProxyEnabled(false);
appSettings.setProxyWasEnabled(false); appSettings.setProxyWasEnabled(false);

View file

@ -0,0 +1,97 @@
package com.github.dfa.diaspora_android.util;
import com.github.dfa.diaspora_android.data.AppSettings;
/**
* Created by vanitas on 10.08.16.
*/
public class DiasporaUrlHelper {
private AppSettings settings;
public static final String HTTPS = "https://";
public static final String SUBURL_NOTIFICATIONS = "/notifications";
public static final String SUBURL_POSTS = "/posts/";
public static final String SUBURL_STREAM = "/stream";
public static final String SUBURL_CONVERSATIONS = "/conversations";
public static final String SUBURL_NEW_POST = "/status_messages/new";
public static final String SUBURL_PEOPLE = "/people/";
public static final String SUBURL_ACTIVITY = "/activity";
public static final String SUBURL_LIKED = "/liked";
public static final String SUBURL_COMMENTED = "/commented";
public static final String SUBURL_MENTIONS = "/mentions";
public static final String SUBURL_PUBLIC = "/public";
public static final String SUBURL_TOGGLE_MOBILE = "/mobile/toggle";
public static final String SUBURL_SEARCH_TAGS = "/tags/";
public static final String SUBURL_SEARCH_PEOPLE = "/people.mobile?q=";
public static final String SUBURL_FOLOWED_TAGS = "/followed_tags";
public static final String SUBURL_ASPECTS = "/aspects";
public static final String URL_BLANK = "about:blank";
public DiasporaUrlHelper(AppSettings settings) {
this.settings = settings;
}
public String getPodUrl() {
return HTTPS+settings.getPodDomain();
}
public String getStreamUrl() {
return getPodUrl()+SUBURL_STREAM;
}
public String getNotificationsUrl() {
return getPodUrl()+SUBURL_NOTIFICATIONS;
}
public String getPostsUrl() {
return getPodUrl()+SUBURL_POSTS;
}
public String getConversationsUrl() {
return getPodUrl()+SUBURL_CONVERSATIONS;
}
public String getNewPostUrl() {
return getPodUrl()+SUBURL_NEW_POST;
}
public String getProfileUrl() {
return getPodUrl()+SUBURL_PEOPLE+settings.getProfileId();
}
public String getActivityUrl() {
return getPodUrl()+SUBURL_ACTIVITY;
}
public String getLikedPostsUrl() {
return getPodUrl()+SUBURL_LIKED;
}
public String getCommentedUrl() {
return getPodUrl()+SUBURL_COMMENTED;
}
public String getMentionsUrl() {
return getPodUrl()+SUBURL_MENTIONS;
}
public String getPublicUrl() {
return getPodUrl()+SUBURL_PUBLIC;
}
public String getToggleMobileUrl() {
return getPodUrl()+SUBURL_TOGGLE_MOBILE;
}
public String getSearchTagsUrl(String query) {
return getPodUrl()+SUBURL_SEARCH_TAGS+query;
}
public String getSearchPeopleUrl(String query) {
return getPodUrl()+SUBURL_SEARCH_PEOPLE+query;
}
public String getBlankUrl() {
return URL_BLANK;
}
}