diff --git a/app/src/main/java/eu/faircode/email/ActivityBase.java b/app/src/main/java/eu/faircode/email/ActivityBase.java index fc5d765104..4c793c9ce0 100644 --- a/app/src/main/java/eu/faircode/email/ActivityBase.java +++ b/app/src/main/java/eu/faircode/email/ActivityBase.java @@ -20,12 +20,14 @@ package eu.faircode.email; */ import android.Manifest; +import android.content.ActivityNotFoundException; import android.content.Context; import android.content.Intent; import android.content.SharedPreferences; import android.content.res.Configuration; import android.os.Bundle; import android.os.PowerManager; +import android.widget.Toast; import androidx.annotation.Nullable; import androidx.appcompat.app.AppCompatActivity; @@ -186,16 +188,26 @@ abstract class ActivityBase extends AppCompatActivity implements SharedPreferenc @Override public void startActivity(Intent intent) { - if (Helper.hasAuthentication(this)) - intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); - super.startActivity(intent); + try { + if (Helper.hasAuthentication(this)) + intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); + super.startActivity(intent); + } catch (ActivityNotFoundException ex) { + Log.e(ex); + ToastEx.makeText(this, getString(R.string.title_no_viewer, intent.getAction()), Toast.LENGTH_LONG).show(); + } } @Override public void startActivityForResult(Intent intent, int requestCode) { - if (Helper.hasAuthentication(this)) - intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); - super.startActivityForResult(intent, requestCode); + try { + if (Helper.hasAuthentication(this)) + intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); + super.startActivityForResult(intent, requestCode); + } catch (ActivityNotFoundException ex) { + Log.e(ex); + ToastEx.makeText(this, getString(R.string.title_no_viewer, intent.getAction()), Toast.LENGTH_LONG).show(); + } } @Override diff --git a/app/src/main/java/eu/faircode/email/FragmentBase.java b/app/src/main/java/eu/faircode/email/FragmentBase.java index bcb3e91406..1cc923b703 100644 --- a/app/src/main/java/eu/faircode/email/FragmentBase.java +++ b/app/src/main/java/eu/faircode/email/FragmentBase.java @@ -19,6 +19,7 @@ package eu.faircode.email; Copyright 2018-2019 by Marcel Bokhorst (M66B) */ +import android.content.ActivityNotFoundException; import android.content.Context; import android.content.Intent; import android.content.res.Configuration; @@ -27,6 +28,7 @@ import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.view.inputmethod.InputMethodManager; +import android.widget.Toast; import androidx.annotation.Nullable; import androidx.appcompat.app.ActionBar; @@ -52,16 +54,26 @@ public class FragmentBase extends Fragment { @Override public void startActivity(Intent intent) { - if (Helper.hasAuthentication(getContext())) - intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); - super.startActivity(intent); + try { + if (Helper.hasAuthentication(getContext())) + intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); + super.startActivity(intent); + } catch (ActivityNotFoundException ex) { + Log.e(ex); + ToastEx.makeText(getContext(), getString(R.string.title_no_viewer, intent.getAction()), Toast.LENGTH_LONG).show(); + } } @Override public void startActivityForResult(Intent intent, int requestCode) { - if (Helper.hasAuthentication(getContext())) - intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); - super.startActivityForResult(intent, requestCode); + try { + if (Helper.hasAuthentication(getContext())) + intent.addFlags(Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS); + super.startActivityForResult(intent, requestCode); + } catch (ActivityNotFoundException ex) { + Log.e(ex); + ToastEx.makeText(getContext(), getString(R.string.title_no_viewer, intent.getAction()), Toast.LENGTH_LONG).show(); + } } protected void finish() {