diff --git a/org.fox.ttrss/src/main/java/org/fox/ttrss/CommonActivity.java b/org.fox.ttrss/src/main/java/org/fox/ttrss/CommonActivity.java index efef731d..76240781 100755 --- a/org.fox.ttrss/src/main/java/org/fox/ttrss/CommonActivity.java +++ b/org.fox.ttrss/src/main/java/org/fox/ttrss/CommonActivity.java @@ -2,8 +2,11 @@ package org.fox.ttrss; import android.annotation.SuppressLint; +import android.app.AlertDialog; +import android.app.Dialog; import android.app.PendingIntent; import android.content.ComponentName; +import android.content.DialogInterface; import android.content.Intent; import android.content.SharedPreferences; import android.database.sqlite.SQLiteDatabase; @@ -20,6 +23,8 @@ import android.support.v7.app.ActionBarActivity; import android.util.Log; import android.util.TypedValue; import android.view.Display; +import android.view.View; +import android.widget.CheckBox; import android.widget.Toast; import org.fox.ttrss.util.DatabaseHelper; @@ -213,10 +218,8 @@ public class CommonActivity extends ActionBarActivity implements SharedPreferenc }); } - // uses chrome custom tabs when available - public void openUri(Uri uri) { + private void openUriWithCustomTab(Uri uri) { if (m_customTabClient != null) { - TypedValue tvBackground = new TypedValue(); getTheme().resolveAttribute(R.attr.colorPrimary, tvBackground, true); @@ -240,6 +243,80 @@ public class CommonActivity extends ActionBarActivity implements SharedPreferenc CustomTabsIntent intent = builder.build(); intent.launchUrl(this, uri); + } + } + + // uses chrome custom tabs when available + public void openUri(final Uri uri) { + boolean enableCustomTabs = m_prefs.getBoolean("enable_custom_tabs", false); + final boolean askEveryTime = m_prefs.getBoolean("custom_tabs_ask_always", false); + + if (enableCustomTabs && m_customTabClient != null) { + + if (askEveryTime) { + + View dialogView = View.inflate(this, R.layout.dialog_open_link_askcb, null); + final CheckBox askEveryTimeCB = (CheckBox) dialogView.findViewById(R.id.open_link_ask_checkbox); + + AlertDialog.Builder builder = new AlertDialog.Builder( + CommonActivity.this) + .setTitle("Open link") + .setView(dialogView) + .setMessage(uri.toString()) + .setPositiveButton("Quick preview", + new Dialog.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + + if (!askEveryTimeCB.isChecked()) { + SharedPreferences.Editor editor = m_prefs.edit(); + editor.putBoolean("custom_tabs_ask_always", false); + editor.apply(); + } + + openUriWithCustomTab(uri); + + } + }) + .setNegativeButton("Open with app", + new Dialog.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + + if (!askEveryTimeCB.isChecked()) { + SharedPreferences.Editor editor = m_prefs.edit(); + editor.putBoolean("custom_tabs_ask_always", false); + editor.putBoolean("enable_custom_tabs", false); + editor.apply(); + } + + Intent intent = new Intent(Intent.ACTION_VIEW, uri); + + startActivity(intent); + + } + }); + /*.setNegativeButton(R.string.cancel, + new Dialog.OnClickListener() { + public void onClick(DialogInterface dialog, + int which) { + + if (!askEveryTimeCB.isChecked()) { + SharedPreferences.Editor editor = m_prefs.edit(); + editor.putBoolean("custom_tabs_ask_always", false); + editor.apply(); + } + + } + });*/ + + AlertDialog dlg = builder.create(); + dlg.show(); + + } else { + openUriWithCustomTab(uri); + } + } else { Intent intent = new Intent(Intent.ACTION_VIEW, uri); diff --git a/org.fox.ttrss/src/main/res/layout/dialog_open_link_askcb.xml b/org.fox.ttrss/src/main/res/layout/dialog_open_link_askcb.xml new file mode 100755 index 00000000..45fd2af5 --- /dev/null +++ b/org.fox.ttrss/src/main/res/layout/dialog_open_link_askcb.xml @@ -0,0 +1,14 @@ + + + + + \ No newline at end of file diff --git a/org.fox.ttrss/src/main/res/xml/preferences.xml b/org.fox.ttrss/src/main/res/xml/preferences.xml index e8fcdcb6..c9ffd79b 100755 --- a/org.fox.ttrss/src/main/res/xml/preferences.xml +++ b/org.fox.ttrss/src/main/res/xml/preferences.xml @@ -156,6 +156,17 @@ android:summary="@string/prefs_enable_fab_long" android:title="@string/prefs_enable_fab" /> + + + +