summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authortom79 <tschneider.ac@gmail.com>2020-04-11 14:43:33 +0200
committertom79 <tschneider.ac@gmail.com>2020-04-11 14:43:33 +0200
commit62fd00c871020c5983dc02c4c1b26505f97630f3 (patch)
treefd2e2f6a17f6214d7a8da7620b0c010f27f801ec
parent4284bccab9bb84269452e16fe67976b4f9942446 (diff)
Fix crash when playing youtube videos
-rw-r--r--app/build.gradle1
-rw-r--r--app/src/main/assets/changelogs/359.txt5
-rw-r--r--app/src/main/java/app/fedilab/android/drawers/StatusListAdapter.java12
-rw-r--r--app/src/main/java/app/fedilab/android/helper/Helper.java8
-rw-r--r--app/src/main/java/app/fedilab/android/webview/MastalabWebChromeClient.java5
-rw-r--r--app/src/main/res/layout/fragment_settings_reveal.xml13
-rw-r--r--app/src/main/res/values/strings.xml1
-rw-r--r--build.gradle2
8 files changed, 39 insertions, 8 deletions
diff --git a/app/build.gradle b/app/build.gradle
index 9b1476805..80069389a 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -47,6 +47,7 @@ android {
packagingOptions {
exclude 'META-INF/proguard/androidx-annotations.pro'
}
+ viewBinding.enabled = true
}
allprojects {
repositories {
diff --git a/app/src/main/assets/changelogs/359.txt b/app/src/main/assets/changelogs/359.txt
new file mode 100644
index 000000000..b237b22a1
--- /dev/null
+++ b/app/src/main/assets/changelogs/359.txt
@@ -0,0 +1,5 @@
+Changed:
+
+
+Fixed:
+- Crash when Youtube videos in timelines \ No newline at end of file
diff --git a/app/src/main/java/app/fedilab/android/drawers/StatusListAdapter.java b/app/src/main/java/app/fedilab/android/drawers/StatusListAdapter.java
index 761778fd3..a31920fa0 100644
--- a/app/src/main/java/app/fedilab/android/drawers/StatusListAdapter.java
+++ b/app/src/main/java/app/fedilab/android/drawers/StatusListAdapter.java
@@ -2141,7 +2141,11 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
if (status.getReblog() == null) {
if (status.getWebviewURL() != null) {
String url = status.getWebviewURL().replaceAll("&amp;", "&");
- holder.status_cardview_webview.loadUrl(url);
+ try {
+ holder.status_cardview_webview.loadUrl(url);
+ }catch (Exception e){
+ e.printStackTrace();
+ }
holder.status_cardview_webview.setVisibility(View.VISIBLE);
holder.status_cardview_video.setVisibility(View.VISIBLE);
holder.webview_preview.setVisibility(View.GONE);
@@ -2153,7 +2157,11 @@ public class StatusListAdapter extends RecyclerView.Adapter implements OnPostAct
} else {
if (status.getReblog().getWebviewURL() != null) {
String url = status.getReblog().getWebviewURL().replaceAll("&amp;", "&");
- holder.status_cardview_webview.loadUrl(url);
+ try {
+ holder.status_cardview_webview.loadUrl(url);
+ }catch (Exception e){
+ e.printStackTrace();
+ }
holder.status_cardview_webview.setVisibility(View.VISIBLE);
holder.status_cardview_video.setVisibility(View.VISIBLE);
holder.webview_preview.setVisibility(View.GONE);
diff --git a/app/src/main/java/app/fedilab/android/helper/Helper.java b/app/src/main/java/app/fedilab/android/helper/Helper.java
index f21d7b05e..ee5e6fb8a 100644
--- a/app/src/main/java/app/fedilab/android/helper/Helper.java
+++ b/app/src/main/java/app/fedilab/android/helper/Helper.java
@@ -79,6 +79,7 @@ import android.view.WindowManager;
import android.webkit.CookieManager;
import android.webkit.MimeTypeMap;
import android.webkit.URLUtil;
+import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Button;
@@ -2222,7 +2223,12 @@ public class Helper {
webView.getSettings().setAppCacheEnabled(true);
webView.getSettings().setDatabaseEnabled(true);
webView.getSettings().setCacheMode(WebSettings.LOAD_DEFAULT);
-
+ webView.setWebChromeClient(new WebChromeClient() {
+ @Override
+ public Bitmap getDefaultVideoPoster() {
+ return Bitmap.createBitmap(50, 50, Bitmap.Config.ARGB_8888);
+ }
+ });
boolean proxyEnabled = sharedpreferences.getBoolean(Helper.SET_PROXY_ENABLED, false);
if (proxyEnabled) {
String host = sharedpreferences.getString(Helper.SET_PROXY_HOST, "127.0.0.1");
diff --git a/app/src/main/java/app/fedilab/android/webview/MastalabWebChromeClient.java b/app/src/main/java/app/fedilab/android/webview/MastalabWebChromeClient.java
index 925b16c59..b66395c35 100644
--- a/app/src/main/java/app/fedilab/android/webview/MastalabWebChromeClient.java
+++ b/app/src/main/java/app/fedilab/android/webview/MastalabWebChromeClient.java
@@ -77,6 +77,11 @@ public class MastalabWebChromeClient extends WebChromeClient implements MediaPla
}
@Override
+ public Bitmap getDefaultVideoPoster() {
+ return Bitmap.createBitmap(50, 50, Bitmap.Config.ARGB_8888);
+ }
+
+ @Override
public void onReceivedIcon(WebView view, Bitmap icon) {
super.onReceivedIcon(view, icon);
LayoutInflater mInflater = LayoutInflater.from(activity);
diff --git a/app/src/main/res/layout/fragment_settings_reveal.xml b/app/src/main/res/layout/fragment_settings_reveal.xml
index c4aaa8a71..e3be902d4 100644
--- a/app/src/main/res/layout/fragment_settings_reveal.xml
+++ b/app/src/main/res/layout/fragment_settings_reveal.xml
@@ -1843,7 +1843,9 @@
android:id="@+id/translation_key"
android:layout_width="match_parent"
android:layout_height="wrap_content"
- android:hint="@string/your_api_key" />
+ android:hint="@string/your_api_key"
+ android:inputType="text"
+ android:importantForAutofill="no" />
</LinearLayout>
<LinearLayout
@@ -2363,7 +2365,9 @@
android:id="@+id/custom_sharing_url"
android:layout_width="match_parent"
android:layout_height="wrap_content"
- android:hint="@string/settings_custom_sharing_url" />
+ android:hint="@string/settings_custom_sharing_url"
+ android:inputType="textUri"
+ android:importantForAutofill="no" />
<!-- ADD TAGS -->
<LinearLayout
@@ -2500,7 +2504,8 @@
android:layout_height="wrap_content"
android:ellipsize="end"
android:hint="@string/set_invidious_host"
- android:inputType="textWebEditText" />
+ android:inputType="textWebEditText"
+ android:importantForAutofill="no" />
<LinearLayout
android:layout_width="match_parent"
@@ -2675,7 +2680,7 @@
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
- android:text="@string/set_enable_crash_report_indication"
+ android:text="@string/set_custom_tabs_indication"
android:textColor="@color/mastodonC2"
android:textSize="12sp" />
</LinearLayout>
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index 28ee0ba50..000a0b10e 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -1226,4 +1226,5 @@
<string name="action_announcements">Announcements</string>
<string name="no_announcements">No announcements!</string>
<string name="add_reaction">Add a reaction</string>
+ <string name="set_custom_tabs_indication">Use your favourite browser inside the app. Uncheck this feature to open links externally.</string>
</resources> \ No newline at end of file
diff --git a/build.gradle b/build.gradle
index 2d1d9aae1..db1fb473c 100644
--- a/build.gradle
+++ b/build.gradle
@@ -6,7 +6,7 @@ buildscript {
google()
}
dependencies {
- classpath 'com.android.tools.build:gradle:3.6.1'
+ classpath 'com.android.tools.build:gradle:3.6.2'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files