mirror of
https://github.com/gsantner/dandelion
synced 2024-11-22 12:22:08 +01:00
Moved WebView in own fragments. There is still a bug, where the webview cannot be returned for some reason.
This commit is contained in:
parent
52d6947d3e
commit
b2337b1955
18 changed files with 764 additions and 530 deletions
|
@ -62,7 +62,7 @@ public class AboutActivity extends AppCompatActivity {
|
||||||
private SectionsPagerAdapter mSectionsPagerAdapter;
|
private SectionsPagerAdapter mSectionsPagerAdapter;
|
||||||
private ViewPager mViewPager;
|
private ViewPager mViewPager;
|
||||||
|
|
||||||
@BindView(R.id.toolbar)
|
@BindView(R.id.main__topbar)
|
||||||
protected Toolbar toolbar;
|
protected Toolbar toolbar;
|
||||||
|
|
||||||
@BindView(R.id.linearlayout)
|
@BindView(R.id.linearlayout)
|
||||||
|
|
|
@ -45,6 +45,8 @@ import android.support.annotation.NonNull;
|
||||||
import android.support.design.widget.AppBarLayout;
|
import android.support.design.widget.AppBarLayout;
|
||||||
import android.support.design.widget.NavigationView;
|
import android.support.design.widget.NavigationView;
|
||||||
import android.support.design.widget.Snackbar;
|
import android.support.design.widget.Snackbar;
|
||||||
|
import android.support.v4.app.Fragment;
|
||||||
|
import android.support.v4.app.FragmentManager;
|
||||||
import android.support.v4.content.LocalBroadcastManager;
|
import android.support.v4.content.LocalBroadcastManager;
|
||||||
import android.support.v4.view.GravityCompat;
|
import android.support.v4.view.GravityCompat;
|
||||||
import android.support.v4.widget.DrawerLayout;
|
import android.support.v4.widget.DrawerLayout;
|
||||||
|
@ -69,7 +71,6 @@ import android.widget.FrameLayout;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.ProgressBar;
|
import android.widget.ProgressBar;
|
||||||
import android.widget.RelativeLayout;
|
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
@ -77,9 +78,11 @@ import com.github.dfa.diaspora_android.App;
|
||||||
import com.github.dfa.diaspora_android.R;
|
import com.github.dfa.diaspora_android.R;
|
||||||
import com.github.dfa.diaspora_android.data.AppSettings;
|
import com.github.dfa.diaspora_android.data.AppSettings;
|
||||||
import com.github.dfa.diaspora_android.data.PodUserProfile;
|
import com.github.dfa.diaspora_android.data.PodUserProfile;
|
||||||
|
import com.github.dfa.diaspora_android.fragment.CustomFragment;
|
||||||
|
import com.github.dfa.diaspora_android.fragment.StreamFragment;
|
||||||
import com.github.dfa.diaspora_android.listener.WebUserProfileChangedListener;
|
import com.github.dfa.diaspora_android.listener.WebUserProfileChangedListener;
|
||||||
import com.github.dfa.diaspora_android.receivers.OpenExternalLinkReceiver;
|
import com.github.dfa.diaspora_android.receiver.OpenExternalLinkReceiver;
|
||||||
import com.github.dfa.diaspora_android.receivers.UpdateTitleReceiver;
|
import com.github.dfa.diaspora_android.receiver.UpdateTitleReceiver;
|
||||||
import com.github.dfa.diaspora_android.ui.BadgeDrawable;
|
import com.github.dfa.diaspora_android.ui.BadgeDrawable;
|
||||||
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;
|
||||||
|
@ -110,9 +113,9 @@ public class MainActivity extends AppCompatActivity
|
||||||
implements NavigationView.OnNavigationItemSelectedListener, WebUserProfileChangedListener {
|
implements NavigationView.OnNavigationItemSelectedListener, WebUserProfileChangedListener {
|
||||||
|
|
||||||
|
|
||||||
private static final int INPUT_FILE_REQUEST_CODE_NEW = 1;
|
public static final int INPUT_FILE_REQUEST_CODE_NEW = 1;
|
||||||
private static final int INPUT_FILE_REQUEST_CODE_OLD = 2;
|
public static final int INPUT_FILE_REQUEST_CODE_OLD = 2;
|
||||||
private static final int REQUEST_CODE_ASK_PERMISSIONS = 123;
|
public static final int REQUEST_CODE_ASK_PERMISSIONS = 123;
|
||||||
public static final int REQUEST_CODE__ACCESS_EXTERNAL_STORAGE = 124;
|
public static final int REQUEST_CODE__ACCESS_EXTERNAL_STORAGE = 124;
|
||||||
|
|
||||||
public static final String ACTION_OPEN_URL = "com.github.dfa.diaspora_android.MainActivity.open_url";
|
public static final String ACTION_OPEN_URL = "com.github.dfa.diaspora_android.MainActivity.open_url";
|
||||||
|
@ -130,42 +133,33 @@ public class MainActivity extends AppCompatActivity
|
||||||
private ValueCallback<Uri> imageUploadFilePathCallbackOld;
|
private ValueCallback<Uri> imageUploadFilePathCallbackOld;
|
||||||
private String mCameraPhotoPath;
|
private String mCameraPhotoPath;
|
||||||
private CustomTabActivityHelper customTabActivityHelper;
|
private CustomTabActivityHelper customTabActivityHelper;
|
||||||
private WebSettings webSettings;
|
|
||||||
private AppSettings appSettings;
|
private AppSettings appSettings;
|
||||||
private DiasporaUrlHelper urls;
|
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 OpenExternalLinkReceiver brOpenExternalLink;
|
private OpenExternalLinkReceiver brOpenExternalLink;
|
||||||
private BroadcastReceiver brSetTitle;
|
private BroadcastReceiver brSetTitle;
|
||||||
private Snackbar snackbarExitApp;
|
private Snackbar snackbarExitApp;
|
||||||
private Snackbar snackbarNoInternet;
|
private Snackbar snackbarNoInternet;
|
||||||
private String textToBeShared = null;
|
|
||||||
|
private FragmentManager fm;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* UI Bindings
|
* UI Bindings
|
||||||
*/
|
*/
|
||||||
@BindView(R.id.content_layout)
|
@BindView(R.id.main__topbar)
|
||||||
RelativeLayout contentLayout;
|
|
||||||
|
|
||||||
@BindView(R.id.progressBar)
|
|
||||||
ProgressBar progressBar;
|
|
||||||
|
|
||||||
@BindView(R.id.toolbar)
|
|
||||||
Toolbar toolbarTop;
|
Toolbar toolbarTop;
|
||||||
|
|
||||||
@BindView(R.id.toolbar2)
|
@BindView(R.id.main__bottombar)
|
||||||
ActionMenuView toolbarBottom;
|
ActionMenuView toolbarBottom;
|
||||||
|
|
||||||
@BindView(R.id.placeholder_webview)
|
@BindView(R.id.fragment_container)
|
||||||
FrameLayout webviewPlaceholder;
|
FrameLayout fragmentContainer;
|
||||||
|
|
||||||
ContextMenuWebView webView;
|
|
||||||
|
|
||||||
@BindView(R.id.main__navigaion_view)
|
@BindView(R.id.main__navigaion_view)
|
||||||
NavigationView navView;
|
NavigationView navView;
|
||||||
|
|
||||||
@BindView(R.id.main__layout)
|
@BindView(R.id.main__navdrawer)
|
||||||
DrawerLayout navDrawer;
|
DrawerLayout navDrawer;
|
||||||
|
|
||||||
|
|
||||||
|
@ -187,6 +181,14 @@ public class MainActivity extends AppCompatActivity
|
||||||
|
|
||||||
// Bind UI
|
// Bind UI
|
||||||
setContentView(R.layout.main__activity);
|
setContentView(R.layout.main__activity);
|
||||||
|
ButterKnife.bind(this);
|
||||||
|
|
||||||
|
fm = getSupportFragmentManager();
|
||||||
|
if(fm.findFragmentByTag(StreamFragment.TAG) == null) {
|
||||||
|
fm.beginTransaction().replace(R.id.fragment_container, new StreamFragment()).commit();
|
||||||
|
} else {
|
||||||
|
fm.beginTransaction().replace(R.id.fragment_container, fm.findFragmentByTag(StreamFragment.TAG)).commit();
|
||||||
|
}
|
||||||
|
|
||||||
if ((app = (App) getApplication()) == null) AppLog.e(this, "App is null!");
|
if ((app = (App) getApplication()) == null) AppLog.e(this, "App is null!");
|
||||||
if ((appSettings = app.getSettings()) == null) AppLog.e(this, "AppSettings is null!");
|
if ((appSettings = app.getSettings()) == null) AppLog.e(this, "AppSettings is null!");
|
||||||
|
@ -199,15 +201,6 @@ public class MainActivity extends AppCompatActivity
|
||||||
|
|
||||||
setupUI(savedInstanceState);
|
setupUI(savedInstanceState);
|
||||||
|
|
||||||
if (appSettings.isProxyEnabled()) {
|
|
||||||
if (!setProxy(appSettings.getProxyHost(), appSettings.getProxyPort())) {
|
|
||||||
AppLog.e(this, "Could not enable Proxy");
|
|
||||||
Toast.makeText(MainActivity.this, R.string.toast_set_proxy_failed, Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
} else if (appSettings.wasProxyEnabled()) {
|
|
||||||
resetProxy();
|
|
||||||
}
|
|
||||||
|
|
||||||
brOpenExternalLink = new OpenExternalLinkReceiver(this);
|
brOpenExternalLink = new OpenExternalLinkReceiver(this);
|
||||||
brSetTitle = new UpdateTitleReceiver(app, urls, new UpdateTitleReceiver.TitleCallback() {
|
brSetTitle = new UpdateTitleReceiver(app, urls, new UpdateTitleReceiver.TitleCallback() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -224,27 +217,7 @@ public class MainActivity extends AppCompatActivity
|
||||||
|
|
||||||
private void setupUI(Bundle savedInstanceState) {
|
private void setupUI(Bundle savedInstanceState) {
|
||||||
AppLog.i(this, "setupUI()");
|
AppLog.i(this, "setupUI()");
|
||||||
ButterKnife.bind(this);
|
|
||||||
if (webviewPlaceholder.getChildCount() != 0) {
|
|
||||||
AppLog.v(this, "remove child views from webViewPlaceholder");
|
|
||||||
webviewPlaceholder.removeAllViews();
|
|
||||||
} else {
|
|
||||||
AppLog.v(this, "webViewPlaceholder had no child views");
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean newWebView = (webView == null);
|
|
||||||
if (newWebView) {
|
|
||||||
AppLog.v(this, "WebView was null. Create new one.");
|
|
||||||
View webviewHolder = getLayoutInflater().inflate(R.layout.ui__webview, this.contentLayout, false);
|
|
||||||
this.webView = (ContextMenuWebView) webviewHolder.findViewById(R.id.webView);
|
|
||||||
((LinearLayout) webView.getParent()).removeView(webView);
|
|
||||||
setupWebView(savedInstanceState);
|
|
||||||
} else {
|
|
||||||
AppLog.v(this, "Reuse old WebView to avoid reloading page");
|
|
||||||
}
|
|
||||||
|
|
||||||
AppLog.v(this, "Add WebView to placeholder");
|
|
||||||
webviewPlaceholder.addView(webView);
|
|
||||||
// Setup toolbar
|
// Setup toolbar
|
||||||
setSupportActionBar(toolbarTop);
|
setSupportActionBar(toolbarTop);
|
||||||
getMenuInflater().inflate(R.menu.main__menu_bottom, toolbarBottom.getMenu());
|
getMenuInflater().inflate(R.menu.main__menu_bottom, toolbarBottom.getMenu());
|
||||||
|
@ -257,7 +230,7 @@ public class MainActivity extends AppCompatActivity
|
||||||
|
|
||||||
//Setup snackbar
|
//Setup snackbar
|
||||||
snackbarExitApp = Snackbar
|
snackbarExitApp = Snackbar
|
||||||
.make(contentLayout, R.string.confirm_exit, Snackbar.LENGTH_LONG)
|
.make(fragmentContainer, R.string.confirm_exit, Snackbar.LENGTH_LONG)
|
||||||
.setAction(android.R.string.yes, new View.OnClickListener() {
|
.setAction(android.R.string.yes, new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
|
@ -265,24 +238,11 @@ public class MainActivity extends AppCompatActivity
|
||||||
moveTaskToBack(true);
|
moveTaskToBack(true);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
snackbarNoInternet = Snackbar.make(contentLayout, R.string.no_internet, Snackbar.LENGTH_LONG);
|
snackbarNoInternet = Snackbar.make(fragmentContainer, R.string.no_internet, Snackbar.LENGTH_LONG);
|
||||||
|
|
||||||
// Load app settings
|
// Load app settings
|
||||||
setupNavigationSlider();
|
setupNavigationSlider();
|
||||||
|
|
||||||
progressBar = (ProgressBar) findViewById(R.id.progressBar);
|
|
||||||
|
|
||||||
String url = urls.getPodUrl();
|
|
||||||
if (newWebView) {
|
|
||||||
if (WebHelper.isOnline(MainActivity.this)) {
|
|
||||||
AppLog.v(this, "setupUI: reload url");
|
|
||||||
webView.loadData("", "text/html", null);
|
|
||||||
webView.loadUrlNew(url);
|
|
||||||
} else {
|
|
||||||
snackbarNoInternet.show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!appSettings.isIntellihideToolbars()) {
|
if (!appSettings.isIntellihideToolbars()) {
|
||||||
AppLog.v(this, "Disable intelligent hiding of toolbars");
|
AppLog.v(this, "Disable intelligent hiding of toolbars");
|
||||||
AppBarLayout.LayoutParams params = (AppBarLayout.LayoutParams) toolbarTop.getLayoutParams();
|
AppBarLayout.LayoutParams params = (AppBarLayout.LayoutParams) toolbarTop.getLayoutParams();
|
||||||
|
@ -293,14 +253,26 @@ public class MainActivity extends AppCompatActivity
|
||||||
handleIntent(getIntent());
|
handleIntent(getIntent());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void openDiasporaUrl(String url) {
|
||||||
|
StreamFragment streamFragment = getStreamFragment();
|
||||||
|
if(!streamFragment.isVisible()) {
|
||||||
|
fm.beginTransaction().replace(R.id.fragment_container, streamFragment, StreamFragment.TAG).commit();
|
||||||
|
streamFragment.onCreateBottomOptionsMenu(toolbarBottom.getMenu(), getMenuInflater());
|
||||||
|
}
|
||||||
|
streamFragment.loadUrl(url);
|
||||||
|
}
|
||||||
|
|
||||||
|
public StreamFragment getStreamFragment() {
|
||||||
|
StreamFragment streamFragment = (StreamFragment) fm.findFragmentByTag(StreamFragment.TAG);
|
||||||
|
if(streamFragment == null) {
|
||||||
|
streamFragment = new StreamFragment();
|
||||||
|
}
|
||||||
|
return streamFragment;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onConfigurationChanged(Configuration newConfig) {
|
public void onConfigurationChanged(Configuration newConfig) {
|
||||||
AppLog.i(this, "onConfigurationChanged()");
|
AppLog.i(this, "onConfigurationChanged()");
|
||||||
if (webView != null) {
|
|
||||||
// Remove the WebView from the old placeholder
|
|
||||||
AppLog.v(this, "removeView from placeholder in order to prevent recreation");
|
|
||||||
webviewPlaceholder.removeView(webView);
|
|
||||||
}
|
|
||||||
|
|
||||||
super.onConfigurationChanged(newConfig);
|
super.onConfigurationChanged(newConfig);
|
||||||
|
|
||||||
|
@ -312,161 +284,6 @@ public class MainActivity extends AppCompatActivity
|
||||||
setupUI(null);
|
setupUI(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setupWebView(Bundle savedInstanceState) {
|
|
||||||
|
|
||||||
webSettings = webView.getSettings();
|
|
||||||
webSettings.setJavaScriptEnabled(true);
|
|
||||||
webSettings.setAllowFileAccess(false);
|
|
||||||
webSettings.setUseWideViewPort(true);
|
|
||||||
webSettings.setLoadWithOverviewMode(true);
|
|
||||||
webSettings.setDomStorageEnabled(true);
|
|
||||||
webSettings.setMinimumFontSize(appSettings.getMinimumFontSize());
|
|
||||||
webSettings.setLoadsImagesAutomatically(appSettings.isLoadImages());
|
|
||||||
webSettings.setAppCacheEnabled(true);
|
|
||||||
|
|
||||||
if (savedInstanceState != null) {
|
|
||||||
AppLog.v(this, "restore WebView state");
|
|
||||||
webView.restoreState(savedInstanceState);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= 21) {
|
|
||||||
WebView.enableSlowWholeDocumentDraw();
|
|
||||||
webSettings.setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.registerForContextMenu(webView);
|
|
||||||
webView.setParentActivity(this);
|
|
||||||
webView.setOverScrollMode(WebView.OVER_SCROLL_ALWAYS);
|
|
||||||
|
|
||||||
// Setup WebView
|
|
||||||
webView.addJavascriptInterface(new JavaScriptInterface(), "AndroidBridge");
|
|
||||||
|
|
||||||
//Set proxy
|
|
||||||
if (appSettings.isProxyEnabled()) {
|
|
||||||
if (!setProxy())
|
|
||||||
Toast.makeText(this, R.string.toast_set_proxy_failed, Toast.LENGTH_LONG).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* WebViewClient
|
|
||||||
*/
|
|
||||||
webViewClient = new CustomWebViewClient(app, webView);
|
|
||||||
webView.setWebViewClient(webViewClient);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* WebChromeClient
|
|
||||||
*/
|
|
||||||
webView.setWebChromeClient(new WebChromeClient() {
|
|
||||||
|
|
||||||
public void onProgressChanged(WebView wv, int progress) {
|
|
||||||
progressBar.setProgress(progress);
|
|
||||||
|
|
||||||
if (progress > 0 && progress <= 60) {
|
|
||||||
WebHelper.getUserProfile(wv);
|
|
||||||
WebHelper.optimizeMobileSiteLayout(wv);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (progress > 60) {
|
|
||||||
WebHelper.optimizeMobileSiteLayout(wv);
|
|
||||||
|
|
||||||
if (textToBeShared != null) {
|
|
||||||
WebHelper.shareTextIntoWebView(wv, textToBeShared);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
progressBar.setVisibility(progress == 100 ? View.GONE : View.VISIBLE);
|
|
||||||
}
|
|
||||||
|
|
||||||
//For Android 4.1/4.2 only. DO NOT REMOVE!
|
|
||||||
@SuppressWarnings("unused")
|
|
||||||
protected void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture) {
|
|
||||||
AppLog.v(this, "openFileChooser(ValCallback<Uri>, String, String");
|
|
||||||
imageUploadFilePathCallbackOld = uploadMsg;
|
|
||||||
Intent intent = new Intent();
|
|
||||||
intent.setType("image/*");
|
|
||||||
intent.setAction(Intent.ACTION_GET_CONTENT);
|
|
||||||
intent.putExtra("return-data", true);
|
|
||||||
intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);
|
|
||||||
AppLog.v(this, "startActivityForResult");
|
|
||||||
startActivityForResult(Intent.createChooser(intent, "Select Picture"), INPUT_FILE_REQUEST_CODE_OLD);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {
|
|
||||||
if (Build.VERSION.SDK_INT >= 23) {
|
|
||||||
int hasWRITE_EXTERNAL_STORAGE = checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE);
|
|
||||||
if (hasWRITE_EXTERNAL_STORAGE != PackageManager.PERMISSION_GRANTED) {
|
|
||||||
if (!shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
|
|
||||||
new AlertDialog.Builder(MainActivity.this)
|
|
||||||
.setMessage(R.string.permissions_image)
|
|
||||||
.setNegativeButton(android.R.string.no, null)
|
|
||||||
.setPositiveButton(android.R.string.yes, new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= 23)
|
|
||||||
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
|
||||||
REQUEST_CODE_ASK_PERMISSIONS);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.show();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
|
||||||
REQUEST_CODE_ASK_PERMISSIONS);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
AppLog.v(MainActivity.this, "onOpenFileChooser");
|
|
||||||
imageUploadFilePathCallbackNew = filePathCallback;
|
|
||||||
|
|
||||||
Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
|
|
||||||
if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
|
|
||||||
// Create the File where the photo should go
|
|
||||||
File photoFile;
|
|
||||||
try {
|
|
||||||
photoFile = Helpers.createImageFile();
|
|
||||||
takePictureIntent.putExtra("PhotoPath", mCameraPhotoPath);
|
|
||||||
} catch (IOException ex) {
|
|
||||||
AppLog.e(this, "ERROR creating temp file: " + ex.toString());
|
|
||||||
// Error occurred while creating the File
|
|
||||||
Snackbar.make(contentLayout, R.string.unable_to_load_image, Snackbar.LENGTH_LONG).show();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Continue only if the File was successfully created
|
|
||||||
if (photoFile != null) {
|
|
||||||
mCameraPhotoPath = "file:" + photoFile.getAbsolutePath();
|
|
||||||
takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT,
|
|
||||||
Uri.fromFile(photoFile));
|
|
||||||
} else {
|
|
||||||
takePictureIntent = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Intent contentSelectionIntent = new Intent(Intent.ACTION_GET_CONTENT);
|
|
||||||
contentSelectionIntent.addCategory(Intent.CATEGORY_OPENABLE);
|
|
||||||
contentSelectionIntent.setType("image/*");
|
|
||||||
|
|
||||||
Intent[] intentArray;
|
|
||||||
if (takePictureIntent != null) {
|
|
||||||
intentArray = new Intent[]{takePictureIntent};
|
|
||||||
} else {
|
|
||||||
intentArray = new Intent[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
Intent chooserIntent = new Intent(Intent.ACTION_CHOOSER);
|
|
||||||
chooserIntent.putExtra(Intent.EXTRA_INTENT, contentSelectionIntent);
|
|
||||||
chooserIntent.putExtra(Intent.EXTRA_TITLE, "Image Chooser");
|
|
||||||
chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, intentArray);
|
|
||||||
|
|
||||||
AppLog.v(this, "startActivityForResult");
|
|
||||||
startActivityForResult(chooserIntent, INPUT_FILE_REQUEST_CODE_NEW);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setupNavigationSlider() {
|
private void setupNavigationSlider() {
|
||||||
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
|
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
|
||||||
this, navDrawer, toolbarTop, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
|
this, navDrawer, toolbarTop, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
|
||||||
|
@ -478,12 +295,13 @@ public class MainActivity extends AppCompatActivity
|
||||||
|
|
||||||
View navHeader = navView.getHeaderView(0);
|
View navHeader = navView.getHeaderView(0);
|
||||||
LinearLayout navheaderProfileSection = ButterKnife.findById(navHeader, R.id.nav_profile_picture);
|
LinearLayout navheaderProfileSection = ButterKnife.findById(navHeader, R.id.nav_profile_picture);
|
||||||
|
//Handle clicks on profile picture
|
||||||
navheaderProfileSection.setOnClickListener(new View.OnClickListener() {
|
navheaderProfileSection.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View view) {
|
public void onClick(View view) {
|
||||||
navDrawer.closeDrawer(GravityCompat.START);
|
navDrawer.closeDrawer(GravityCompat.START);
|
||||||
if (WebHelper.isOnline(MainActivity.this)) {
|
if (WebHelper.isOnline(MainActivity.this)) {
|
||||||
webView.loadUrlNew(urls.getProfileUrl());
|
openDiasporaUrl(urls.getProfileUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
|
@ -530,7 +348,7 @@ public class MainActivity extends AppCompatActivity
|
||||||
navMenu.findItem(R.id.nav_public).setVisible(appSettings.isVisibleInNavPublic_activities());
|
navMenu.findItem(R.id.nav_public).setVisible(appSettings.isVisibleInNavPublic_activities());
|
||||||
}
|
}
|
||||||
|
|
||||||
@OnClick(R.id.toolbar)
|
@OnClick(R.id.main__topbar)
|
||||||
public void onToolBarClicked(View view) {
|
public void onToolBarClicked(View view) {
|
||||||
AppLog.i(this, "onToolBarClicked()");
|
AppLog.i(this, "onToolBarClicked()");
|
||||||
onNavigationItemSelected(navView.getMenu().findItem(R.id.nav_stream));
|
onNavigationItemSelected(navView.getMenu().findItem(R.id.nav_stream));
|
||||||
|
@ -566,11 +384,11 @@ public class MainActivity extends AppCompatActivity
|
||||||
}
|
}
|
||||||
} else if (ACTION_CHANGE_ACCOUNT.equals(action)) {
|
} else if (ACTION_CHANGE_ACCOUNT.equals(action)) {
|
||||||
AppLog.v(this, "Reset pod data and animate to PodSelectionActivity");
|
AppLog.v(this, "Reset pod data and animate to PodSelectionActivity");
|
||||||
app.resetPodData(webView);
|
app.resetPodData(getStreamFragment().getWebView());
|
||||||
Helpers.animateToActivity(MainActivity.this, PodSelectionActivity.class, true);
|
Helpers.animateToActivity(MainActivity.this, PodSelectionActivity.class, true);
|
||||||
} else if (ACTION_CLEAR_CACHE.equals(action)) {
|
} else if (ACTION_CLEAR_CACHE.equals(action)) {
|
||||||
AppLog.v(this, "Clear WebView cache");
|
AppLog.v(this, "Clear WebView cache");
|
||||||
webView.clearCache(true);
|
getStreamFragment().getWebView().clearCache(true);
|
||||||
} else if (ACTION_RELOAD_ACTIVITY.equals(action)) {
|
} else if (ACTION_RELOAD_ACTIVITY.equals(action)) {
|
||||||
AppLog.v(this, "Recreate activity");
|
AppLog.v(this, "Recreate activity");
|
||||||
recreate();
|
recreate();
|
||||||
|
@ -593,9 +411,8 @@ public class MainActivity extends AppCompatActivity
|
||||||
}
|
}
|
||||||
|
|
||||||
if (loadUrl != null) {
|
if (loadUrl != null) {
|
||||||
webView.stopLoading();
|
|
||||||
navDrawer.closeDrawers();
|
navDrawer.closeDrawers();
|
||||||
webView.loadUrlNew(loadUrl);
|
openDiasporaUrl(loadUrl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -672,16 +489,21 @@ public class MainActivity extends AppCompatActivity
|
||||||
protected void onSaveInstanceState(Bundle outState) {
|
protected void onSaveInstanceState(Bundle outState) {
|
||||||
AppLog.v(this, "onSaveInstanceState()");
|
AppLog.v(this, "onSaveInstanceState()");
|
||||||
super.onSaveInstanceState(outState);
|
super.onSaveInstanceState(outState);
|
||||||
AppLog.v(this, "Save WebView state");
|
|
||||||
webView.saveState(outState);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onRestoreInstanceState(@NonNull Bundle savedInstanceState) {
|
protected void onRestoreInstanceState(@NonNull Bundle savedInstanceState) {
|
||||||
AppLog.v(this, "onRestoreInstanceState()");
|
AppLog.v(this, "onRestoreInstanceState()");
|
||||||
super.onRestoreInstanceState(savedInstanceState);
|
super.onRestoreInstanceState(savedInstanceState);
|
||||||
AppLog.v(this, "Restore state of WebView");
|
}
|
||||||
webView.restoreState(savedInstanceState);
|
|
||||||
|
private Fragment getTopFragment() {
|
||||||
|
for(Fragment f : fm.getFragments()) {
|
||||||
|
if(f.isVisible()) {
|
||||||
|
return f;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -691,10 +513,14 @@ public class MainActivity extends AppCompatActivity
|
||||||
navDrawer.closeDrawer(navView);
|
navDrawer.closeDrawer(navView);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
CustomFragment top = (CustomFragment) getTopFragment();
|
||||||
if (webView.canGoBack()) {
|
if(top != null) {
|
||||||
webView.goBack();
|
if(!top.onBackPressed()) {
|
||||||
|
//TODO: Go back in Fragment backstack
|
||||||
return;
|
return;
|
||||||
|
} else {
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!snackbarExitApp.isShown()) {
|
if (!snackbarExitApp.isShown()) {
|
||||||
|
@ -761,7 +587,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.loadUrlNew(urls.getNotificationsUrl());
|
openDiasporaUrl(urls.getNotificationsUrl());
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
|
@ -771,17 +597,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.loadUrlNew(urls.getConversationsUrl());
|
openDiasporaUrl(urls.getConversationsUrl());
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
snackbarNoInternet.show();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.id.action_reload: {
|
|
||||||
if (WebHelper.isOnline(MainActivity.this)) {
|
|
||||||
webView.reload();
|
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
|
@ -795,47 +611,15 @@ public class MainActivity extends AppCompatActivity
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
case R.id.action_toggle_desktop_page: {
|
|
||||||
webView.loadUrlNew(urls.getToggleMobileUrl());
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.id.action_compose: {
|
case R.id.action_compose: {
|
||||||
if (WebHelper.isOnline(MainActivity.this)) {
|
if (WebHelper.isOnline(MainActivity.this)) {
|
||||||
webView.loadUrlNew(urls.getNewPostUrl());
|
openDiasporaUrl(urls.getNewPostUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
case R.id.action_go_to_top: {
|
|
||||||
// Scroll to top (animated)
|
|
||||||
ObjectAnimator anim = ObjectAnimator.ofInt(webView, "scrollY", webView.getScrollY(), 0);
|
|
||||||
anim.setDuration(400);
|
|
||||||
anim.start();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.id.action_share_link: {
|
|
||||||
Intent sharingIntent = new Intent(Intent.ACTION_SEND);
|
|
||||||
sharingIntent.setType("text/plain");
|
|
||||||
sharingIntent.putExtra(Intent.EXTRA_SUBJECT, webView.getTitle());
|
|
||||||
sharingIntent.putExtra(Intent.EXTRA_TEXT, webView.getUrl());
|
|
||||||
startActivity(Intent.createChooser(sharingIntent, getResources().getString(R.string.action_share_dotdotdot)));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.id.action_take_screenshot: {
|
|
||||||
makeScreenshotOfWebView(false);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.id.action_share_screenshot: {
|
|
||||||
makeScreenshotOfWebView(true);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
case R.id.action_search: {
|
case R.id.action_search: {
|
||||||
if (WebHelper.isOnline(MainActivity.this)) {
|
if (WebHelper.isOnline(MainActivity.this)) {
|
||||||
final InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
final InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
||||||
|
@ -847,9 +631,9 @@ public class MainActivity extends AppCompatActivity
|
||||||
public void onClick(DialogInterface dialogInterface, int which) {
|
public void onClick(DialogInterface dialogInterface, int which) {
|
||||||
String query = input.getText().toString().trim().replaceAll((which == DialogInterface.BUTTON_NEGATIVE ? "\\*" : "\\#"), "");
|
String query = input.getText().toString().trim().replaceAll((which == DialogInterface.BUTTON_NEGATIVE ? "\\*" : "\\#"), "");
|
||||||
if (query.equals("")) {
|
if (query.equals("")) {
|
||||||
Snackbar.make(contentLayout, R.string.search_alert_bypeople_validate_needsomedata, Snackbar.LENGTH_LONG).show();
|
Snackbar.make(fragmentContainer, R.string.search_alert_bypeople_validate_needsomedata, Snackbar.LENGTH_LONG).show();
|
||||||
} else {
|
} else {
|
||||||
webView.loadUrl(which == DialogInterface.BUTTON_NEGATIVE ? urls.getSearchPeopleUrl(query) : urls.getSearchTagsUrl(query));
|
openDiasporaUrl(which == DialogInterface.BUTTON_NEGATIVE ? urls.getSearchPeopleUrl(query) : urls.getSearchTagsUrl(query));
|
||||||
}
|
}
|
||||||
getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);
|
getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);
|
||||||
imm.hideSoftInputFromWindow(input.getWindowToken(), 0);
|
imm.hideSoftInputFromWindow(input.getWindowToken(), 0);
|
||||||
|
@ -890,88 +674,6 @@ public class MainActivity extends AppCompatActivity
|
||||||
return super.onOptionsItemSelected(item);
|
return super.onOptionsItemSelected(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("ResultOfMethodCallIgnored")
|
|
||||||
private boolean makeScreenshotOfWebView(boolean hasToShareScreenshot) {
|
|
||||||
AppLog.i(this, "makeScreenshotOfWebView()");
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= 23) {
|
|
||||||
int hasWRITE_EXTERNAL_STORAGE = checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE);
|
|
||||||
if (hasWRITE_EXTERNAL_STORAGE != PackageManager.PERMISSION_GRANTED) {
|
|
||||||
if (!shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
|
|
||||||
new AlertDialog.Builder(MainActivity.this)
|
|
||||||
.setMessage(R.string.permissions_screenshot)
|
|
||||||
.setNegativeButton(android.R.string.no, null)
|
|
||||||
.setPositiveButton(android.R.string.yes, new DialogInterface.OnClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= 23)
|
|
||||||
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
|
||||||
REQUEST_CODE_ASK_PERMISSIONS);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.show();
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
|
||||||
REQUEST_CODE_ASK_PERMISSIONS);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Date dateNow = new Date();
|
|
||||||
DateFormat dateFormat = new SimpleDateFormat("yy_MM_dd--HH_mm_ss", Locale.getDefault());
|
|
||||||
File fileSaveDirectory = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES) + "/Diaspora");
|
|
||||||
|
|
||||||
String fileSaveName = hasToShareScreenshot ? ".DfA_share.jpg" : String.format("DfA_%s.jpg", dateFormat.format(dateNow));
|
|
||||||
if (!fileSaveDirectory.exists()) {
|
|
||||||
if (!fileSaveDirectory.mkdirs()) {
|
|
||||||
AppLog.w(this, "Could not mkdir " + fileSaveDirectory.getAbsolutePath());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!hasToShareScreenshot) {
|
|
||||||
Snackbar.make(contentLayout, getString(R.string.share__toast_screenshot) + " " + fileSaveName, Snackbar.LENGTH_LONG).show();
|
|
||||||
}
|
|
||||||
|
|
||||||
Bitmap bitmap;
|
|
||||||
webView.setDrawingCacheEnabled(true);
|
|
||||||
bitmap = Bitmap.createBitmap(webView.getDrawingCache());
|
|
||||||
webView.setDrawingCacheEnabled(false);
|
|
||||||
|
|
||||||
OutputStream bitmapWriter = null;
|
|
||||||
try {
|
|
||||||
bitmapWriter = new FileOutputStream(new File(fileSaveDirectory, fileSaveName));
|
|
||||||
bitmap.compress(Bitmap.CompressFormat.JPEG, 85, bitmapWriter);
|
|
||||||
bitmapWriter.flush();
|
|
||||||
bitmap.recycle();
|
|
||||||
} catch (Exception e) {
|
|
||||||
return false;
|
|
||||||
} finally {
|
|
||||||
if (bitmapWriter != null) {
|
|
||||||
try {
|
|
||||||
bitmapWriter.close();
|
|
||||||
} catch (IOException _ignSaveored) {/* Nothing */}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Only show share intent when Action Share Screenshot was selected
|
|
||||||
if (hasToShareScreenshot) {
|
|
||||||
Intent sharingIntent = new Intent(Intent.ACTION_SEND);
|
|
||||||
sharingIntent.setType("image/jpeg");
|
|
||||||
sharingIntent.putExtra(Intent.EXTRA_SUBJECT, webView.getTitle());
|
|
||||||
sharingIntent.putExtra(Intent.EXTRA_TEXT, webView.getUrl());
|
|
||||||
Uri bmpUri = Uri.fromFile(new File(fileSaveDirectory, fileSaveName));
|
|
||||||
sharingIntent.putExtra(Intent.EXTRA_STREAM, bmpUri);
|
|
||||||
startActivity(Intent.createChooser(sharingIntent, getString(R.string.action_share_dotdotdot)));
|
|
||||||
} else {
|
|
||||||
// Broadcast that this file is indexable
|
|
||||||
File file = new File(fileSaveDirectory, fileSaveName);
|
|
||||||
Uri uri = Uri.fromFile(file);
|
|
||||||
Intent intent = new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE, uri);
|
|
||||||
sendBroadcast(intent);
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onUserProfileNameChanged(String name) {
|
public void onUserProfileNameChanged(String name) {
|
||||||
AppLog.i(this, "onUserProfileNameChanged()");
|
AppLog.i(this, "onUserProfileNameChanged()");
|
||||||
|
@ -991,7 +693,7 @@ public class MainActivity extends AppCompatActivity
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
AppLog.e(this, e.toString());
|
AppLog.e(this, e.toString());
|
||||||
}
|
}
|
||||||
webView.loadUrlNew(urls.getNewPostUrl());
|
openDiasporaUrl(urls.getNewPostUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void handleSendText(Intent intent) {
|
private void handleSendText(Intent intent) {
|
||||||
|
@ -1001,8 +703,8 @@ public class MainActivity extends AppCompatActivity
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
AppLog.e(this, e.toString());
|
AppLog.e(this, e.toString());
|
||||||
}
|
}
|
||||||
webView.loadUrlNew(urls.getBlankUrl());
|
openDiasporaUrl(urls.getBlankUrl());
|
||||||
webView.loadUrlNew(urls.getNewPostUrl());
|
openDiasporaUrl(urls.getNewPostUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1017,11 +719,12 @@ public class MainActivity extends AppCompatActivity
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
AppLog.e(this, e.toString());
|
AppLog.e(this, e.toString());
|
||||||
}
|
}
|
||||||
webView.loadUrlNew(urls.getBlankUrl()); //TODO: Necessary?
|
openDiasporaUrl(urls.getBlankUrl()); //TODO: Necessary?
|
||||||
webView.loadUrlNew(urls.getNewPostUrl());
|
openDiasporaUrl(urls.getNewPostUrl());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* TODO: MOVE
|
||||||
* Set sharedText variable to escaped and formatted subject + body.
|
* Set sharedText variable to escaped and formatted subject + body.
|
||||||
* If subject is null, only the body will be set. Else the subject will be set as header.
|
* If subject is null, only the body will be set. Else the subject will be set as header.
|
||||||
* Depending on whether the user has the setting isAppendSharedViaApp set, a reference to
|
* Depending on whether the user has the setting isAppendSharedViaApp set, a reference to
|
||||||
|
@ -1041,10 +744,10 @@ public class MainActivity extends AppCompatActivity
|
||||||
if (sharedSubject != null) {
|
if (sharedSubject != null) {
|
||||||
AppLog.v(this, "Append subject to shared text");
|
AppLog.v(this, "Append subject to shared text");
|
||||||
String escapedSubject = WebHelper.escapeHtmlText(WebHelper.replaceUrlWithMarkdown(sharedSubject));
|
String escapedSubject = WebHelper.escapeHtmlText(WebHelper.replaceUrlWithMarkdown(sharedSubject));
|
||||||
textToBeShared = "**" + escapedSubject + "** " + escapedBody;
|
//textToBeShared = "**" + escapedSubject + "** " + escapedBody;
|
||||||
} else {
|
} else {
|
||||||
AppLog.v(this, "Set shared text; Subject: \"" + sharedSubject + "\" Body: \"" + sharedBody + "\"");
|
AppLog.v(this, "Set shared text; Subject: \"" + sharedSubject + "\" Body: \"" + sharedBody + "\"");
|
||||||
textToBeShared = escapedBody;
|
//textToBeShared = escapedBody;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -1079,24 +782,6 @@ public class MainActivity extends AppCompatActivity
|
||||||
invalidateOptionsMenu();
|
invalidateOptionsMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
private class JavaScriptInterface {
|
|
||||||
@JavascriptInterface
|
|
||||||
public void setUserProfile(final String webMessage) throws JSONException {
|
|
||||||
AppLog.spam(this, "JavaScriptInterface.setUserProfile()");
|
|
||||||
if (podUserProfile.isRefreshNeeded()) {
|
|
||||||
AppLog.spam(this, "PodUserProfile needs refresh; Try to parse JSON");
|
|
||||||
podUserProfile.parseJson(webMessage);
|
|
||||||
} else {
|
|
||||||
AppLog.spam(this, "No PodUserProfile refresh needed");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@JavascriptInterface
|
|
||||||
public void contentHasBeenShared() {
|
|
||||||
textToBeShared = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@SuppressWarnings("StatementWithEmptyBody")
|
@SuppressWarnings("StatementWithEmptyBody")
|
||||||
@Override
|
@Override
|
||||||
public boolean onNavigationItemSelected(MenuItem item) {
|
public boolean onNavigationItemSelected(MenuItem item) {
|
||||||
|
@ -1105,7 +790,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.loadUrlNew(urls.getStreamUrl());
|
openDiasporaUrl(urls.getStreamUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
|
@ -1114,16 +799,18 @@ 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.loadUrlNew(urls.getProfileUrl());
|
openDiasporaUrl(urls.getProfileUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
//TODO: Replace with fragment
|
||||||
case R.id.nav_followed_tags: {
|
case R.id.nav_followed_tags: {
|
||||||
if (WebHelper.isOnline(MainActivity.this)) {
|
if (WebHelper.isOnline(MainActivity.this)) {
|
||||||
WebHelper.showFollowedTagsList(webView, app);
|
openDiasporaUrl(urls.getBlankUrl());
|
||||||
|
WebHelper.showFollowedTagsList(getStreamFragment().getWebView(), app);
|
||||||
setTitle(R.string.nav_followed_tags);
|
setTitle(R.string.nav_followed_tags);
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
|
@ -1131,10 +818,11 @@ public class MainActivity extends AppCompatActivity
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
//TODO: Replace with fragment
|
||||||
case R.id.nav_aspects: {
|
case R.id.nav_aspects: {
|
||||||
if (WebHelper.isOnline(MainActivity.this)) {
|
if (WebHelper.isOnline(MainActivity.this)) {
|
||||||
webView.loadUrlNew(DiasporaUrlHelper.URL_BLANK);
|
openDiasporaUrl(DiasporaUrlHelper.URL_BLANK);
|
||||||
WebHelper.showAspectList(webView, app);
|
WebHelper.showAspectList(getStreamFragment().getWebView(), app);
|
||||||
setTitle(R.string.aspects);
|
setTitle(R.string.aspects);
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
|
@ -1144,7 +832,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.loadUrlNew(urls.getActivityUrl());
|
openDiasporaUrl(urls.getActivityUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
|
@ -1153,7 +841,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.loadUrlNew(urls.getLikedPostsUrl());
|
openDiasporaUrl(urls.getLikedPostsUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
|
@ -1162,7 +850,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.loadUrlNew(urls.getCommentedUrl());
|
openDiasporaUrl(urls.getCommentedUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
|
@ -1171,7 +859,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.loadUrlNew(urls.getMentionsUrl());
|
openDiasporaUrl(urls.getMentionsUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
|
@ -1180,7 +868,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.loadUrlNew(urls.getPublicUrl());
|
openDiasporaUrl(urls.getPublicUrl());
|
||||||
} else {
|
} else {
|
||||||
snackbarNoInternet.show();
|
snackbarNoInternet.show();
|
||||||
}
|
}
|
||||||
|
@ -1226,83 +914,4 @@ public class MainActivity extends AppCompatActivity
|
||||||
grantResults);
|
grantResults);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Set proxy according to arguments. host must not be "" or null, port must be positive.
|
|
||||||
* Return true on success and update appSettings' proxy related values.
|
|
||||||
*
|
|
||||||
* @param host proxy host (eg. localhost or 127.0.0.1)
|
|
||||||
* @param port proxy port (eg. 8118)
|
|
||||||
* @return success
|
|
||||||
* @throws IllegalArgumentException if arguments do not fit specifications above
|
|
||||||
*/
|
|
||||||
private boolean setProxy(final String host, final int port) {
|
|
||||||
AppLog.v(this, "setProxy()");
|
|
||||||
if (host != null && !host.equals("") && port >= 0) {
|
|
||||||
AppLog.v(this, "Set proxy to " + host + ":" + port);
|
|
||||||
//Temporary change thread policy
|
|
||||||
AppLog.v(this, "Set temporary ThreadPolicy");
|
|
||||||
StrictMode.ThreadPolicy old = StrictMode.getThreadPolicy();
|
|
||||||
StrictMode.ThreadPolicy tmp = new StrictMode.ThreadPolicy.Builder().permitAll().build();
|
|
||||||
StrictMode.setThreadPolicy(tmp);
|
|
||||||
|
|
||||||
AppLog.v(this, "Apply NetCipher proxy settings");
|
|
||||||
NetCipher.setProxy(host, port); //Proxy for HttpsUrlConnections
|
|
||||||
try {
|
|
||||||
//Proxy for the ui__webview
|
|
||||||
AppLog.v(this, "Apply Webkit proxy settings");
|
|
||||||
WebkitProxy.setProxy(MainActivity.class.getName(), getApplicationContext(), null, host, port);
|
|
||||||
} catch (Exception e) {
|
|
||||||
AppLog.e(this, "Could not apply WebKit proxy settings:\n" + e.toString());
|
|
||||||
}
|
|
||||||
AppLog.v(this, "Save changes in appSettings");
|
|
||||||
appSettings.setProxyEnabled(true);
|
|
||||||
appSettings.setProxyWasEnabled(true);
|
|
||||||
|
|
||||||
AppLog.v(this, "Reset old ThreadPolicy");
|
|
||||||
StrictMode.setThreadPolicy(old);
|
|
||||||
AppLog.v(this, "Success! Reload WebView");
|
|
||||||
webView.reload();
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
AppLog.w(this, "Invalid proxy configuration. Host: " + host + " Port: " + port + "\nRefuse to set proxy");
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean setProxy() {
|
|
||||||
return setProxy(appSettings.getProxyHost(), appSettings.getProxyPort());
|
|
||||||
}
|
|
||||||
|
|
||||||
private void resetProxy() {
|
|
||||||
AppLog.i(this, "resetProxy()");
|
|
||||||
AppLog.v(this, "write changes to appSettings");
|
|
||||||
appSettings.setProxyEnabled(false);
|
|
||||||
appSettings.setProxyWasEnabled(false);
|
|
||||||
|
|
||||||
//Temporary change thread policy
|
|
||||||
AppLog.v(this, "Set temporary ThreadPolicy");
|
|
||||||
StrictMode.ThreadPolicy old = StrictMode.getThreadPolicy();
|
|
||||||
StrictMode.ThreadPolicy tmp = new StrictMode.ThreadPolicy.Builder().permitAll().build();
|
|
||||||
StrictMode.setThreadPolicy(tmp);
|
|
||||||
|
|
||||||
AppLog.v(this, "clear NetCipher proxy");
|
|
||||||
NetCipher.clearProxy();
|
|
||||||
try {
|
|
||||||
AppLog.v(this, "clear WebKit proxy");
|
|
||||||
WebkitProxy.resetProxy(MainActivity.class.getName(), this);
|
|
||||||
} catch (Exception e) {
|
|
||||||
AppLog.e(this, "Could not clear WebKit proxy:\n" + e.toString());
|
|
||||||
}
|
|
||||||
AppLog.v(this, "Reset old ThreadPolicy");
|
|
||||||
StrictMode.setThreadPolicy(old);
|
|
||||||
|
|
||||||
//Restart app
|
|
||||||
AppLog.i(this, "Success! Restart app due to proxy reset");
|
|
||||||
Intent restartActivity = new Intent(this, MainActivity.class);
|
|
||||||
PendingIntent pendingIntent = PendingIntent.getActivity(this, 12374, restartActivity, PendingIntent.FLAG_CANCEL_CURRENT);
|
|
||||||
AlarmManager mgr = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
|
|
||||||
mgr.set(AlarmManager.RTC, System.currentTimeMillis() + 100, pendingIntent);
|
|
||||||
System.exit(0);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,7 +65,7 @@ public class PodSelectionActivity extends AppCompatActivity {
|
||||||
@BindView(R.id.podselection__listpods)
|
@BindView(R.id.podselection__listpods)
|
||||||
ListView listPods;
|
ListView listPods;
|
||||||
|
|
||||||
@BindView(R.id.toolbar)
|
@BindView(R.id.main__topbar)
|
||||||
Toolbar toolbar;
|
Toolbar toolbar;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
package com.github.dfa.diaspora_android.fragment;
|
||||||
|
|
||||||
|
import android.support.v4.app.Fragment;
|
||||||
|
import android.view.Menu;
|
||||||
|
import android.view.MenuInflater;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Customized abstract Fragment class with some useful methods
|
||||||
|
* Created by vanitas on 21.09.16.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public abstract class CustomFragment extends Fragment {
|
||||||
|
/**
|
||||||
|
* Return the tag used to identify the Fragment.
|
||||||
|
* @return tag
|
||||||
|
*/
|
||||||
|
public abstract String getFragmentTag();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add fragment-dependent options to the bottom options toolbar
|
||||||
|
* @param menu bottom menu
|
||||||
|
* @param inflater inflater
|
||||||
|
*/
|
||||||
|
public abstract void onCreateBottomOptionsMenu(Menu menu, MenuInflater inflater);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return true if the fragment reacted to a back button press, false else.
|
||||||
|
* In case the fragment returned false, the parent activity should handle the backPress.
|
||||||
|
* @return did we react to the back press?
|
||||||
|
*/
|
||||||
|
public abstract boolean onBackPressed();
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,141 @@
|
||||||
|
package com.github.dfa.diaspora_android.fragment;
|
||||||
|
|
||||||
|
import android.animation.ObjectAnimator;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.Menu;
|
||||||
|
import android.view.MenuInflater;
|
||||||
|
import android.view.MenuItem;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.ProgressBar;
|
||||||
|
|
||||||
|
import com.github.dfa.diaspora_android.App;
|
||||||
|
import com.github.dfa.diaspora_android.R;
|
||||||
|
import com.github.dfa.diaspora_android.ui.ContextMenuWebView;
|
||||||
|
import com.github.dfa.diaspora_android.util.AppLog;
|
||||||
|
import com.github.dfa.diaspora_android.util.DiasporaUrlHelper;
|
||||||
|
import com.github.dfa.diaspora_android.util.WebHelper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fragment that contains a WebView displaying the stream of the user
|
||||||
|
* Created by vanitas on 21.09.16.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public class StreamFragment extends WebViewFragment {
|
||||||
|
public static final String TAG = "com.github.dfa.diaspora_android.StreamFragment";
|
||||||
|
|
||||||
|
private DiasporaUrlHelper urls;
|
||||||
|
private Bundle webViewState;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
|
||||||
|
return inflater.inflate(R.layout.stream__fragment, container, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onViewCreated(View view, Bundle savedInstanceState) {
|
||||||
|
super.onViewCreated(view, savedInstanceState);
|
||||||
|
this.webView = (ContextMenuWebView) view.findViewById(R.id.webView);
|
||||||
|
this.progressBar = (ProgressBar) view.findViewById(R.id.progressBar);
|
||||||
|
this.appSettings = ((App) getActivity().getApplication()).getSettings();
|
||||||
|
this.urls = new DiasporaUrlHelper(appSettings);
|
||||||
|
|
||||||
|
this.setup(
|
||||||
|
webView,
|
||||||
|
progressBar,
|
||||||
|
appSettings);
|
||||||
|
|
||||||
|
if(webView.getUrl() == null) {
|
||||||
|
loadUrl(urls.getPodUrl());
|
||||||
|
}
|
||||||
|
this.setRetainInstance(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getFragmentTag() {
|
||||||
|
return TAG;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
|
||||||
|
inflater.inflate(R.menu.stream__menu_top, menu);
|
||||||
|
super.onCreateOptionsMenu(menu, inflater);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onCreateBottomOptionsMenu(Menu menu, MenuInflater inflater) {
|
||||||
|
inflater.inflate(R.menu.stream__menu_bottom, menu);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onOptionsItemSelected(MenuItem item) {
|
||||||
|
AppLog.d(this, "StreamFragment.onOptionsItemSelected()");
|
||||||
|
switch (item.getItemId()) {
|
||||||
|
case R.id.action_reload: {
|
||||||
|
if(WebHelper.isOnline(getContext())) {
|
||||||
|
reloadUrl();
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.action_toggle_desktop_page: {
|
||||||
|
loadUrl(urls.getToggleMobileUrl());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.action_go_to_top: {
|
||||||
|
ObjectAnimator anim = ObjectAnimator.ofInt(webView, "scrollY", webView.getScrollY(), 0);
|
||||||
|
anim.setDuration(400);
|
||||||
|
anim.start();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.action_share_link: {
|
||||||
|
Intent sharingIntent = new Intent(Intent.ACTION_SEND);
|
||||||
|
sharingIntent.setType("text/plain");
|
||||||
|
sharingIntent.putExtra(Intent.EXTRA_SUBJECT, webView.getTitle());
|
||||||
|
sharingIntent.putExtra(Intent.EXTRA_TEXT, webView.getUrl());
|
||||||
|
startActivity(Intent.createChooser(sharingIntent, getResources().getString(R.string.action_share_dotdotdot)));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.action_take_screenshot: {
|
||||||
|
makeScreenshotOfWebView(false);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
case R.id.action_share_screenshot: {
|
||||||
|
makeScreenshotOfWebView(true);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return super.onOptionsItemSelected(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPause() {
|
||||||
|
super.onPause();
|
||||||
|
webViewState = new Bundle();
|
||||||
|
webView.saveState(webViewState);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onResume() {
|
||||||
|
super.onResume();
|
||||||
|
if(webViewState != null) {
|
||||||
|
webView.restoreState(webViewState);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onBackPressed() {
|
||||||
|
if(webView.canGoBack()) {
|
||||||
|
webView.goBack();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,430 @@
|
||||||
|
package com.github.dfa.diaspora_android.fragment;
|
||||||
|
|
||||||
|
import android.Manifest;
|
||||||
|
import android.app.AlarmManager;
|
||||||
|
import android.app.PendingIntent;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.content.pm.PackageManager;
|
||||||
|
import android.graphics.Bitmap;
|
||||||
|
import android.net.Uri;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.os.Environment;
|
||||||
|
import android.os.StrictMode;
|
||||||
|
import android.support.design.widget.Snackbar;
|
||||||
|
import android.support.v7.app.AlertDialog;
|
||||||
|
import android.view.View;
|
||||||
|
import android.webkit.JavascriptInterface;
|
||||||
|
import android.webkit.ValueCallback;
|
||||||
|
import android.webkit.WebChromeClient;
|
||||||
|
import android.webkit.WebSettings;
|
||||||
|
import android.webkit.WebView;
|
||||||
|
import android.webkit.WebViewClient;
|
||||||
|
import android.widget.ProgressBar;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import com.github.dfa.diaspora_android.App;
|
||||||
|
import com.github.dfa.diaspora_android.R;
|
||||||
|
import com.github.dfa.diaspora_android.activity.MainActivity;
|
||||||
|
import com.github.dfa.diaspora_android.data.AppSettings;
|
||||||
|
import com.github.dfa.diaspora_android.data.PodUserProfile;
|
||||||
|
import com.github.dfa.diaspora_android.ui.ContextMenuWebView;
|
||||||
|
import com.github.dfa.diaspora_android.ui.CustomWebViewClient;
|
||||||
|
import com.github.dfa.diaspora_android.util.AppLog;
|
||||||
|
import com.github.dfa.diaspora_android.util.WebHelper;
|
||||||
|
|
||||||
|
import org.json.JSONException;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.text.DateFormat;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.Locale;
|
||||||
|
|
||||||
|
import info.guardianproject.netcipher.NetCipher;
|
||||||
|
import info.guardianproject.netcipher.webkit.WebkitProxy;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fragment that contains a WebView with a bunch of functionality
|
||||||
|
* Created by vanitas on 21.09.16.
|
||||||
|
*/
|
||||||
|
|
||||||
|
public abstract class WebViewFragment extends CustomFragment {
|
||||||
|
|
||||||
|
protected WebSettings webSettings;
|
||||||
|
protected WebViewClient webViewClient;
|
||||||
|
protected ContextMenuWebView webView;
|
||||||
|
protected ProgressBar progressBar;
|
||||||
|
protected AppSettings appSettings;
|
||||||
|
|
||||||
|
protected String textToBeShared;
|
||||||
|
|
||||||
|
public void onViewCreated(View view, Bundle savedInstanceState) {
|
||||||
|
super.onViewCreated(view, savedInstanceState);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void setup(ContextMenuWebView webView, final ProgressBar progressBar, AppSettings appSettings) {
|
||||||
|
this.appSettings = appSettings;
|
||||||
|
this.webSettings = webView.getSettings();
|
||||||
|
this.webView = webView;
|
||||||
|
this.progressBar = progressBar;
|
||||||
|
|
||||||
|
if (appSettings.isProxyEnabled()) {
|
||||||
|
if (!setProxy(appSettings.getProxyHost(), appSettings.getProxyPort())) {
|
||||||
|
AppLog.e(this, "Could not enable Proxy");
|
||||||
|
Toast.makeText(getContext(), R.string.toast_set_proxy_failed, Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
} else if (appSettings.wasProxyEnabled()) {
|
||||||
|
resetProxy();
|
||||||
|
}
|
||||||
|
|
||||||
|
webSettings.setJavaScriptEnabled(true);
|
||||||
|
webSettings.setAllowFileAccess(false);
|
||||||
|
webSettings.setUseWideViewPort(true);
|
||||||
|
webSettings.setLoadWithOverviewMode(true);
|
||||||
|
webSettings.setDomStorageEnabled(true);
|
||||||
|
webSettings.setMinimumFontSize(appSettings.getMinimumFontSize());
|
||||||
|
webSettings.setLoadsImagesAutomatically(appSettings.isLoadImages());
|
||||||
|
webSettings.setAppCacheEnabled(true);
|
||||||
|
|
||||||
|
if (android.os.Build.VERSION.SDK_INT >= 21) {
|
||||||
|
WebView.enableSlowWholeDocumentDraw();
|
||||||
|
webSettings.setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.registerForContextMenu(webView);
|
||||||
|
//webView.setParentActivity(this);
|
||||||
|
webView.setOverScrollMode(WebView.OVER_SCROLL_ALWAYS);
|
||||||
|
|
||||||
|
// Setup WebView
|
||||||
|
webView.addJavascriptInterface(new JavaScriptInterface(), "AndroidBridge");
|
||||||
|
|
||||||
|
//Set proxy
|
||||||
|
if (appSettings.isProxyEnabled()) {
|
||||||
|
if (!setProxy(appSettings.getProxyHost(), appSettings.getProxyPort())) {
|
||||||
|
AppLog.d(this, "Could not enable Proxy");
|
||||||
|
Toast.makeText(getContext(), R.string.toast_set_proxy_failed, Toast.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
} else if (appSettings.wasProxyEnabled()) {
|
||||||
|
resetProxy();
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* WebViewClient
|
||||||
|
*/
|
||||||
|
this.webViewClient = new CustomWebViewClient((App) getActivity().getApplication(), webView);
|
||||||
|
webView.setWebViewClient(webViewClient);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* WebChromeClient
|
||||||
|
*/
|
||||||
|
webView.setWebChromeClient(new WebChromeClient() {
|
||||||
|
final ProgressBar pb = progressBar;
|
||||||
|
|
||||||
|
public void onProgressChanged(WebView wv, int progress) {
|
||||||
|
pb.setProgress(progress);
|
||||||
|
|
||||||
|
if (progress > 0 && progress <= 60) {
|
||||||
|
WebHelper.getUserProfile(wv);
|
||||||
|
WebHelper.optimizeMobileSiteLayout(wv);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (progress > 60) {
|
||||||
|
WebHelper.optimizeMobileSiteLayout(wv);
|
||||||
|
|
||||||
|
if (textToBeShared != null) {
|
||||||
|
WebHelper.shareTextIntoWebView(wv, textToBeShared);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
progressBar.setVisibility(progress == 100 ? View.GONE : View.VISIBLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
//For Android 4.1/4.2 only. DO NOT REMOVE!
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
protected void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture)
|
||||||
|
{
|
||||||
|
AppLog.v(this, "openFileChooser(ValCallback<Uri>, String, String");
|
||||||
|
//imageUploadFilePathCallbackOld = uploadMsg;
|
||||||
|
Intent intent = new Intent();
|
||||||
|
intent.setType("image/*");
|
||||||
|
intent.setAction(Intent.ACTION_GET_CONTENT);
|
||||||
|
intent.putExtra("return-data", true);
|
||||||
|
intent.setFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP);
|
||||||
|
AppLog.v(this, "startActivityForResult");
|
||||||
|
startActivityForResult(Intent.createChooser(intent, "Select Picture"), MainActivity.INPUT_FILE_REQUEST_CODE_OLD);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
@Override
|
||||||
|
public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {
|
||||||
|
if(Build.VERSION.SDK_INT >= 23) {
|
||||||
|
int hasWRITE_EXTERNAL_STORAGE = getActivity().checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE);
|
||||||
|
if (hasWRITE_EXTERNAL_STORAGE != PackageManager.PERMISSION_GRANTED) {
|
||||||
|
if (!shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
|
||||||
|
new AlertDialog.Builder(getContext())
|
||||||
|
.setMessage(R.string.permissions_image)
|
||||||
|
.setNegativeButton(android.R.string.no, null)
|
||||||
|
.setPositiveButton(android.R.string.yes, new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
if (android.os.Build.VERSION.SDK_INT >= 23)
|
||||||
|
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
||||||
|
MainActivity.REQUEST_CODE_ASK_PERMISSIONS);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.show();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
||||||
|
MainActivity.REQUEST_CODE_ASK_PERMISSIONS);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
AppLog.d(this, "onOpenFileChooser");
|
||||||
|
if (MainActivity.imageUploadFilePathCallbackNew != null) imageUploadFilePathCallbackNew.onReceiveValue(null);
|
||||||
|
imageUploadFilePathCallbackNew = filePathCallback;
|
||||||
|
Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
|
||||||
|
if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
|
||||||
|
// Create the File where the photo should go
|
||||||
|
File photoFile;
|
||||||
|
try {
|
||||||
|
photoFile = Helpers.createImageFile();
|
||||||
|
takePictureIntent.putExtra("PhotoPath", mCameraPhotoPath);
|
||||||
|
} catch (IOException ex) {
|
||||||
|
AppLog.e(this, "ERROR creating temp file: "+ ex.toString());
|
||||||
|
// Error occurred while creating the File
|
||||||
|
Snackbar.make(contentLayout, R.string.unable_to_load_image, Snackbar.LENGTH_LONG).show();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
// Continue only if the File was successfully created
|
||||||
|
if (photoFile != null) {
|
||||||
|
mCameraPhotoPath = "file:" + photoFile.getAbsolutePath();
|
||||||
|
takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT,
|
||||||
|
Uri.fromFile(photoFile));
|
||||||
|
} else {
|
||||||
|
takePictureIntent = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Intent contentSelectionIntent = new Intent(Intent.ACTION_GET_CONTENT);
|
||||||
|
contentSelectionIntent.addCategory(Intent.CATEGORY_OPENABLE);
|
||||||
|
contentSelectionIntent.setType("image/*");
|
||||||
|
Intent[] intentArray;
|
||||||
|
if (takePictureIntent != null) {
|
||||||
|
intentArray = new Intent[]{takePictureIntent};
|
||||||
|
} else {
|
||||||
|
intentArray = new Intent[0];
|
||||||
|
}
|
||||||
|
Intent chooserIntent = new Intent(Intent.ACTION_CHOOSER);
|
||||||
|
chooserIntent.putExtra(Intent.EXTRA_INTENT, contentSelectionIntent);
|
||||||
|
chooserIntent.putExtra(Intent.EXTRA_TITLE, "Image Chooser");
|
||||||
|
chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, intentArray);
|
||||||
|
Log.d(App.TAG,"startActivityForResult");
|
||||||
|
startActivityForResult(chooserIntent, INPUT_FILE_REQUEST_CODE_NEW);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set proxy according to arguments. host must not be "" or null, port must be positive.
|
||||||
|
* Return true on success and update appSettings' proxy related values.
|
||||||
|
*
|
||||||
|
* @param host proxy host (eg. localhost or 127.0.0.1)
|
||||||
|
* @param port proxy port (eg. 8118)
|
||||||
|
* @return success
|
||||||
|
* @throws IllegalArgumentException if arguments do not fit specifications above
|
||||||
|
*/
|
||||||
|
private boolean setProxy(final String host, final int port) {
|
||||||
|
AppLog.i(this, "StreamFragment.setProxy()");
|
||||||
|
if (host != null && !host.equals("") && port >= 0) {
|
||||||
|
AppLog.i(this, "Set proxy to "+host+":"+port);
|
||||||
|
//Temporary change thread policy
|
||||||
|
AppLog.v(this, "Set temporary ThreadPolicy");
|
||||||
|
StrictMode.ThreadPolicy old = StrictMode.getThreadPolicy();
|
||||||
|
StrictMode.ThreadPolicy tmp = new StrictMode.ThreadPolicy.Builder().permitAll().build();
|
||||||
|
StrictMode.setThreadPolicy(tmp);
|
||||||
|
|
||||||
|
AppLog.v(this, "Apply NetCipher proxy settings");
|
||||||
|
NetCipher.setProxy(host, port); //Proxy for HttpsUrlConnections
|
||||||
|
try {
|
||||||
|
//Proxy for the webview
|
||||||
|
AppLog.v(this, "Apply Webkit proxy settings");
|
||||||
|
WebkitProxy.setProxy(MainActivity.class.getName(), getContext().getApplicationContext(), null, host, port);
|
||||||
|
} catch (Exception e) {
|
||||||
|
AppLog.e(this, "Could not apply WebKit proxy settings:\n"+e.toString());
|
||||||
|
}
|
||||||
|
AppLog.v(this, "Save changes in appSettings");
|
||||||
|
appSettings.setProxyEnabled(true);
|
||||||
|
appSettings.setProxyWasEnabled(true);
|
||||||
|
|
||||||
|
AppLog.v(this, "Reset old ThreadPolicy");
|
||||||
|
StrictMode.setThreadPolicy(old);
|
||||||
|
AppLog.i(this, "Success! Reload WebView");
|
||||||
|
webView.reload();
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
AppLog.e(this, "Invalid proxy configuration. Host: "+host+" Port: "+port+"\nRefuse to set proxy");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean setProxy() {
|
||||||
|
return setProxy(appSettings.getProxyHost(), appSettings.getProxyPort());
|
||||||
|
}
|
||||||
|
|
||||||
|
private void resetProxy() {
|
||||||
|
AppLog.i(this, "StreamFragment.resetProxy()");
|
||||||
|
AppLog.v(this, "write changes to appSettings");
|
||||||
|
appSettings.setProxyEnabled(false);
|
||||||
|
appSettings.setProxyWasEnabled(false);
|
||||||
|
|
||||||
|
//Temporary change thread policy
|
||||||
|
AppLog.v(this, "Set temporary ThreadPolicy");
|
||||||
|
StrictMode.ThreadPolicy old = StrictMode.getThreadPolicy();
|
||||||
|
StrictMode.ThreadPolicy tmp = new StrictMode.ThreadPolicy.Builder().permitAll().build();
|
||||||
|
StrictMode.setThreadPolicy(tmp);
|
||||||
|
|
||||||
|
AppLog.v(this, "clear NetCipher proxy");
|
||||||
|
NetCipher.clearProxy();
|
||||||
|
try {
|
||||||
|
AppLog.v(this, "clear WebKit proxy");
|
||||||
|
WebkitProxy.resetProxy(MainActivity.class.getName(), getContext());
|
||||||
|
} catch (Exception e) {
|
||||||
|
AppLog.e(this, "Could not clear WebKit proxy:\n"+e.toString());
|
||||||
|
}
|
||||||
|
AppLog.v(this, "Reset old ThreadPolicy");
|
||||||
|
StrictMode.setThreadPolicy(old);
|
||||||
|
|
||||||
|
//Restart app
|
||||||
|
AppLog.i(this, "Success! Restart app due to proxy reset");
|
||||||
|
Intent restartActivity = new Intent(getContext(), MainActivity.class);
|
||||||
|
PendingIntent pendingIntent = PendingIntent.getActivity(getContext(), 12374, restartActivity, PendingIntent.FLAG_CANCEL_CURRENT);
|
||||||
|
AlarmManager mgr = (AlarmManager) getActivity().getSystemService(Context.ALARM_SERVICE);
|
||||||
|
mgr.set(AlarmManager.RTC, System.currentTimeMillis() + 100, pendingIntent);
|
||||||
|
System.exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private class JavaScriptInterface {
|
||||||
|
@JavascriptInterface
|
||||||
|
public void setUserProfile(final String webMessage) throws JSONException {
|
||||||
|
PodUserProfile pup = ((App)getActivity().getApplication()).getPodUserProfile();
|
||||||
|
AppLog.i(this, "StreamFragment.JavaScriptInterface.setUserProfile()");
|
||||||
|
if (pup.isRefreshNeeded()) {
|
||||||
|
AppLog.v(this, "PodUserProfile needs refresh; Try to parse JSON");
|
||||||
|
pup.parseJson(webMessage);
|
||||||
|
} else {
|
||||||
|
AppLog.v(this, "No PodUserProfile refresh needed");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@JavascriptInterface
|
||||||
|
public void contentHasBeenShared() {
|
||||||
|
textToBeShared = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("ResultOfMethodCallIgnored")
|
||||||
|
protected boolean makeScreenshotOfWebView(boolean hasToShareScreenshot) {
|
||||||
|
AppLog.i(this, "StreamFragment.makeScreenshotOfWebView()");
|
||||||
|
if (android.os.Build.VERSION.SDK_INT >= 23) {
|
||||||
|
int hasWRITE_EXTERNAL_STORAGE = getActivity().checkSelfPermission(Manifest.permission.WRITE_EXTERNAL_STORAGE);
|
||||||
|
if (hasWRITE_EXTERNAL_STORAGE != PackageManager.PERMISSION_GRANTED) {
|
||||||
|
if (!shouldShowRequestPermissionRationale(Manifest.permission.WRITE_EXTERNAL_STORAGE)) {
|
||||||
|
new AlertDialog.Builder(getContext())
|
||||||
|
.setMessage(R.string.permissions_screenshot)
|
||||||
|
.setNegativeButton(android.R.string.no, null)
|
||||||
|
.setPositiveButton(android.R.string.yes, new DialogInterface.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
|
if (android.os.Build.VERSION.SDK_INT >= 23)
|
||||||
|
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
||||||
|
MainActivity.REQUEST_CODE_ASK_PERMISSIONS);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.show();
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
requestPermissions(new String[]{Manifest.permission.WRITE_EXTERNAL_STORAGE},
|
||||||
|
MainActivity.REQUEST_CODE_ASK_PERMISSIONS);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Date dateNow = new Date();
|
||||||
|
DateFormat dateFormat = new SimpleDateFormat("yy_MM_dd--HH_mm_ss", Locale.getDefault());
|
||||||
|
File fileSaveDirectory = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES) + "/Diaspora");
|
||||||
|
|
||||||
|
String fileSaveName = hasToShareScreenshot ? ".DfA_share.jpg" : String.format("DfA_%s.jpg", dateFormat.format(dateNow));
|
||||||
|
if (!fileSaveDirectory.exists()) {
|
||||||
|
if(!fileSaveDirectory.mkdirs()) {
|
||||||
|
AppLog.w(this, "Could not mkdir "+fileSaveDirectory.getAbsolutePath());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!hasToShareScreenshot) {
|
||||||
|
Snackbar.make(webView, getString(R.string.share__toast_screenshot) + " " + fileSaveName, Snackbar.LENGTH_LONG).show();
|
||||||
|
}
|
||||||
|
|
||||||
|
Bitmap bitmap;
|
||||||
|
webView.setDrawingCacheEnabled(true);
|
||||||
|
bitmap = Bitmap.createBitmap(webView.getDrawingCache());
|
||||||
|
webView.setDrawingCacheEnabled(false);
|
||||||
|
|
||||||
|
OutputStream bitmapWriter = null;
|
||||||
|
try {
|
||||||
|
bitmapWriter = new FileOutputStream(new File(fileSaveDirectory, fileSaveName));
|
||||||
|
bitmap.compress(Bitmap.CompressFormat.JPEG, 85, bitmapWriter);
|
||||||
|
bitmapWriter.flush();
|
||||||
|
bitmap.recycle();
|
||||||
|
} catch (Exception e) {
|
||||||
|
return false;
|
||||||
|
} finally {
|
||||||
|
if (bitmapWriter != null) {
|
||||||
|
try {
|
||||||
|
bitmapWriter.close();
|
||||||
|
} catch (IOException _ignSaveored) {/* Nothing */}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only show share intent when Action Share Screenshot was selected
|
||||||
|
if (hasToShareScreenshot) {
|
||||||
|
Intent sharingIntent = new Intent(Intent.ACTION_SEND);
|
||||||
|
sharingIntent.setType("image/jpeg");
|
||||||
|
sharingIntent.putExtra(Intent.EXTRA_SUBJECT, webView.getTitle());
|
||||||
|
sharingIntent.putExtra(Intent.EXTRA_TEXT, webView.getUrl());
|
||||||
|
Uri bmpUri = Uri.fromFile(new File(fileSaveDirectory, fileSaveName));
|
||||||
|
sharingIntent.putExtra(Intent.EXTRA_STREAM, bmpUri);
|
||||||
|
startActivity(Intent.createChooser(sharingIntent, getString(R.string.action_share_dotdotdot)));
|
||||||
|
} else {
|
||||||
|
// Broadcast that this file is indexable
|
||||||
|
File file = new File(fileSaveDirectory, fileSaveName);
|
||||||
|
Uri uri = Uri.fromFile(file);
|
||||||
|
Intent intent = new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE, uri);
|
||||||
|
getActivity().sendBroadcast(intent);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void loadUrl(String url) {
|
||||||
|
getWebView().loadUrlNew(url);
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getUrl() {
|
||||||
|
return getWebView().getUrl();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void reloadUrl() {
|
||||||
|
getWebView().reload();
|
||||||
|
}
|
||||||
|
|
||||||
|
public ContextMenuWebView getWebView() {
|
||||||
|
return this.webView;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
package com.github.dfa.diaspora_android.receivers;
|
package com.github.dfa.diaspora_android.receiver;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
|
@ -9,7 +9,6 @@ import android.graphics.BitmapFactory;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.support.customtabs.CustomTabsIntent;
|
import android.support.customtabs.CustomTabsIntent;
|
||||||
|
|
||||||
import com.github.dfa.diaspora_android.App;
|
|
||||||
import com.github.dfa.diaspora_android.R;
|
import com.github.dfa.diaspora_android.R;
|
||||||
import com.github.dfa.diaspora_android.activity.MainActivity;
|
import com.github.dfa.diaspora_android.activity.MainActivity;
|
||||||
import com.github.dfa.diaspora_android.data.AppSettings;
|
import com.github.dfa.diaspora_android.data.AppSettings;
|
||||||
|
@ -17,7 +16,6 @@ import com.github.dfa.diaspora_android.util.AppLog;
|
||||||
import com.github.dfa.diaspora_android.util.CustomTabHelpers.BrowserFallback;
|
import com.github.dfa.diaspora_android.util.CustomTabHelpers.BrowserFallback;
|
||||||
import com.github.dfa.diaspora_android.util.CustomTabHelpers.CustomTabActivityHelper;
|
import com.github.dfa.diaspora_android.util.CustomTabHelpers.CustomTabActivityHelper;
|
||||||
import com.github.dfa.diaspora_android.util.Helpers;
|
import com.github.dfa.diaspora_android.util.Helpers;
|
||||||
import com.github.dfa.diaspora_android.util.Log;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* BroadcastReceiver that opens links in a Chrome CustomTab
|
* BroadcastReceiver that opens links in a Chrome CustomTab
|
|
@ -1,4 +1,4 @@
|
||||||
package com.github.dfa.diaspora_android.receivers;
|
package com.github.dfa.diaspora_android.receiver;
|
||||||
|
|
||||||
import android.content.BroadcastReceiver;
|
import android.content.BroadcastReceiver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
|
@ -26,7 +26,7 @@
|
||||||
<android.support.v7.widget.Toolbar
|
<android.support.v7.widget.Toolbar
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:id="@+id/toolbar"/>
|
android:id="@+id/main__topbar"/>
|
||||||
|
|
||||||
<android.support.design.widget.TabLayout
|
<android.support.design.widget.TabLayout
|
||||||
android:id="@+id/tabs"
|
android:id="@+id/tabs"
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:id="@+id/main__layout"
|
android:id="@+id/main__navdrawer"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:fitsSystemWindows="true"
|
android:fitsSystemWindows="true"
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
android:theme="@style/AppTheme.AppBarOverlay">
|
android:theme="@style/AppTheme.AppBarOverlay">
|
||||||
|
|
||||||
<android.support.v7.widget.Toolbar
|
<android.support.v7.widget.Toolbar
|
||||||
android:id="@+id/toolbar"
|
android:id="@+id/main__topbar"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="?attr/actionBarSize"
|
android:layout_height="?attr/actionBarSize"
|
||||||
android:background="?attr/colorPrimary"
|
android:background="?attr/colorPrimary"
|
||||||
|
@ -22,7 +22,10 @@
|
||||||
|
|
||||||
</android.support.design.widget.AppBarLayout>
|
</android.support.design.widget.AppBarLayout>
|
||||||
|
|
||||||
<include layout="@layout/main__content"/>
|
<FrameLayout
|
||||||
|
android:id="@+id/fragment_container"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent" />
|
||||||
|
|
||||||
<android.support.design.widget.AppBarLayout
|
<android.support.design.widget.AppBarLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
|
@ -32,7 +35,7 @@
|
||||||
app:layout_behavior=".ui.BottomBarBehavior">
|
app:layout_behavior=".ui.BottomBarBehavior">
|
||||||
|
|
||||||
<android.support.v7.widget.ActionMenuView
|
<android.support.v7.widget.ActionMenuView
|
||||||
android:id="@+id/toolbar2"
|
android:id="@+id/main__bottombar"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="45dp"
|
android:layout_height="45dp"
|
||||||
android:background="@color/colorPrimary"
|
android:background="@color/colorPrimary"
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
android:theme="@style/AppTheme.AppBarOverlay">
|
android:theme="@style/AppTheme.AppBarOverlay">
|
||||||
|
|
||||||
<android.support.v7.widget.Toolbar
|
<android.support.v7.widget.Toolbar
|
||||||
android:id="@+id/toolbar"
|
android:id="@+id/main__topbar"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="?attr/actionBarSize"
|
android:layout_height="?attr/actionBarSize"
|
||||||
android:background="?attr/colorPrimary"
|
android:background="?attr/colorPrimary"
|
||||||
|
|
|
@ -2,17 +2,16 @@
|
||||||
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:id="@+id/content_layout"
|
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
app:layout_behavior="@string/appbar_scrolling_view_behavior"
|
app:layout_behavior="@string/appbar_scrolling_view_behavior"
|
||||||
tools:context=".activity.MainActivity"
|
tools:context=".activity.MainActivity"
|
||||||
tools:showIn="@layout/main__app_bar">
|
tools:showIn="@layout/main__app_bar">
|
||||||
|
|
||||||
<FrameLayout
|
<com.github.dfa.diaspora_android.ui.ContextMenuWebView
|
||||||
android:id="@+id/placeholder_webview"
|
android:id="@+id/webView"
|
||||||
android:layout_width="fill_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="fill_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_alignParentEnd="true"
|
android:layout_alignParentEnd="true"
|
||||||
android:layout_alignParentStart="true"
|
android:layout_alignParentStart="true"
|
||||||
android:layout_centerVertical="true" />
|
android:layout_centerVertical="true" />
|
|
@ -8,42 +8,31 @@
|
||||||
android:id="@+id/action_search"
|
android:id="@+id/action_search"
|
||||||
android:icon="@drawable/ic_search_white_48px"
|
android:icon="@drawable/ic_search_white_48px"
|
||||||
app:showAsAction="always"
|
app:showAsAction="always"
|
||||||
|
android:orderInCategory="100"
|
||||||
android:title="@string/action_search_by_tags_or_persons" />
|
android:title="@string/action_search_by_tags_or_persons" />
|
||||||
|
|
||||||
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/action_compose"
|
android:id="@+id/action_compose"
|
||||||
android:icon="@drawable/ic_mode_edit_white_48px"
|
android:icon="@drawable/ic_mode_edit_white_48px"
|
||||||
app:showAsAction="always"
|
app:showAsAction="always"
|
||||||
|
android:orderInCategory="200"
|
||||||
android:title="@string/action_compose_new_post" />
|
android:title="@string/action_compose_new_post" />
|
||||||
|
|
||||||
<item
|
|
||||||
android:icon="@drawable/ic_share_white_48px"
|
|
||||||
android:title="@string/action_share_dotdotdot"
|
|
||||||
app:showAsAction="always" >
|
|
||||||
<menu>
|
|
||||||
<item android:id="@+id/action_share_screenshot" android:title="@string/share__share_screenshot"/>
|
|
||||||
<item android:id="@+id/action_take_screenshot" android:title="@string/share__take_screenshot"/>
|
|
||||||
<item android:id="@+id/action_share_link" android:title="@string/share__share_link_as_text"/>
|
|
||||||
</menu>
|
|
||||||
</item>
|
|
||||||
|
|
||||||
<!-- Keep right most -->
|
<!-- Keep right most -->
|
||||||
<item
|
<item
|
||||||
android:id="@+id/action_go_to_top"
|
android:id="@+id/action_go_to_top"
|
||||||
android:icon="@drawable/ic_arrow_upward_white_48px"
|
android:icon="@drawable/ic_arrow_upward_white_48px"
|
||||||
android:title="@string/action_go_to_top"
|
app:showAsAction="always"
|
||||||
app:showAsAction="always"/>
|
android:orderInCategory="400"
|
||||||
|
android:title="@string/action_go_to_top" />
|
||||||
|
|
||||||
<!-- overflow menu -->
|
<!-- overflow menu -->
|
||||||
<item
|
|
||||||
android:id="@+id/action_toggle_desktop_page"
|
|
||||||
android:icon="@drawable/ic_sync_white_48px"
|
|
||||||
android:title="@string/action_toggle_desktop_page" />
|
|
||||||
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/action_exit"
|
android:id="@+id/action_exit"
|
||||||
|
app:showAsAction="never"
|
||||||
|
android:orderInCategory="600"
|
||||||
android:title="@string/action_exit_app"
|
android:title="@string/action_exit_app"
|
||||||
app:showAsAction="never" />
|
/>
|
||||||
|
|
||||||
</menu>
|
</menu>
|
||||||
|
|
|
@ -6,19 +6,16 @@
|
||||||
<item
|
<item
|
||||||
android:id="@+id/action_notifications"
|
android:id="@+id/action_notifications"
|
||||||
android:icon="@drawable/ic_notifications_white_48px__layer"
|
android:icon="@drawable/ic_notifications_white_48px__layer"
|
||||||
|
app:showAsAction="always"
|
||||||
|
android:orderInCategory="100"
|
||||||
android:title="@string/notifications"
|
android:title="@string/notifications"
|
||||||
app:showAsAction="always" />
|
/>
|
||||||
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/action_conversations"
|
android:id="@+id/action_conversations"
|
||||||
android:icon="@drawable/ic_mail_white_48px__layer"
|
android:icon="@drawable/ic_mail_white_48px__layer"
|
||||||
android:title="@string/conversations"
|
app:showAsAction="always"
|
||||||
app:showAsAction="always" />
|
android:orderInCategory="200"
|
||||||
|
android:title="@string/conversations" />
|
||||||
<item
|
|
||||||
android:id="@+id/action_reload"
|
|
||||||
android:icon="@drawable/ic_refresh_white_48px"
|
|
||||||
android:title="@string/reload"
|
|
||||||
app:showAsAction="always"/>
|
|
||||||
|
|
||||||
</menu>
|
</menu>
|
||||||
|
|
23
app/src/main/res/menu/stream__menu_bottom.xml
Normal file
23
app/src/main/res/menu/stream__menu_bottom.xml
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<menu xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto">
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:icon="@drawable/ic_share_white_48px"
|
||||||
|
app:showAsAction="always"
|
||||||
|
android:orderInCategory="300"
|
||||||
|
android:title="@string/action_share_dotdotdot">
|
||||||
|
<menu>
|
||||||
|
<item android:id="@+id/action_share_screenshot" android:title="@string/share__share_screenshot"/>
|
||||||
|
<item android:id="@+id/action_take_screenshot" android:title="@string/share__take_screenshot"/>
|
||||||
|
<item android:id="@+id/action_share_link" android:title="@string/share__share_link_as_text"/>
|
||||||
|
</menu>
|
||||||
|
</item>
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/action_toggle_desktop_page"
|
||||||
|
android:icon="@drawable/ic_sync_white_48px"
|
||||||
|
android:orderInCategory="700"
|
||||||
|
android:title="@string/action_toggle_desktop_page" />
|
||||||
|
|
||||||
|
</menu>
|
12
app/src/main/res/menu/stream__menu_top.xml
Normal file
12
app/src/main/res/menu/stream__menu_top.xml
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<menu xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto">
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/action_reload"
|
||||||
|
android:icon="@drawable/ic_refresh_white_48px"
|
||||||
|
app:showAsAction="always"
|
||||||
|
android:orderInCategory="1000"
|
||||||
|
android:title="@string/reload"/>
|
||||||
|
|
||||||
|
</menu>
|
|
@ -5,7 +5,7 @@ buildscript {
|
||||||
jcenter()
|
jcenter()
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath 'com.android.tools.build:gradle:2.1.3'
|
classpath 'com.android.tools.build:gradle:2.2.0'
|
||||||
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
|
classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
|
||||||
|
|
||||||
// NOTE: Do not place your application dependencies here; they belong
|
// NOTE: Do not place your application dependencies here; they belong
|
||||||
|
|
Loading…
Reference in a new issue