]> gitweb.stoutner.com Git - PrivacyBrowserAndroid.git/commitdiff
Add support for `tel:` links. https://redmine.stoutner.com/issues/226
authorSoren Stoutner <soren@stoutner.com>
Mon, 20 Nov 2017 22:17:45 +0000 (15:17 -0700)
committerSoren Stoutner <soren@stoutner.com>
Mon, 20 Nov 2017 22:17:45 +0000 (15:17 -0700)
app/build.gradle
app/src/main/assets/de/about_changelog_dark.html
app/src/main/assets/de/about_changelog_light.html
app/src/main/assets/en/about_changelog_dark.html
app/src/main/assets/en/about_changelog_light.html
app/src/main/assets/es/about_changelog_dark.html
app/src/main/assets/es/about_changelog_light.html
app/src/main/assets/it/about_changelog_dark.html
app/src/main/assets/it/about_changelog_light.html
app/src/main/java/com/stoutner/privacybrowser/activities/MainWebViewActivity.java
build.gradle

index 50c0c2cfe8af776c532d7eadf2ad51ff18f7cc1d..ad44a2b8d2672cf27ccf005dbc7693b009218540 100644 (file)
@@ -67,7 +67,7 @@ dependencies {
     implementation fileTree(include: ['*.jar'], dir: 'libs')
     implementation 'com.android.support:design:26.1.0'
     // Only compile `com.google.firebase:firebase-ads:9.8.0` for the free flavor.
-    freeImplementation 'com.google.firebase:firebase-ads:11.4.2'
+    freeImplementation 'com.google.firebase:firebase-ads:11.6.0'
 }
 
 // Google's documentation says the following line is required for `firebase-ads` but things work correctly without it.  I have no interest in applying the Google Mobile Services plugin in the standard flavor if I don't have to.
index 67926e547788fcb6f10bfed766c09e9c32b59009..3c19e767ff8365d469725578dbbfb8a663f78a90 100644 (file)
@@ -30,7 +30,7 @@
 
     <body>
         <h3>2.7.1 (version code 28)</h3>
-        <p>9. November 2017 - minimum API 19, target API 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9. November 2017</a> - minimum API 19, target API 26</p>
         <ul>
             <li>Fix a crash when <a href="https://redmine.stoutner.com/issues/225">editing a bookmark</a> in the new bookmarks drawer.</li>
         </ul>
index ca438446268abbd7107def1ef16925c963ab006b..4b474a380a2bdbcb0867299c0bccb176449fee21 100644 (file)
@@ -30,7 +30,7 @@
 
     <body>
         <h3>2.7.1 (version code 28)</h3>
-        <p>9. November 2017 - minimum API 19, target API 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9. November 2017</a> - minimum API 19, target API 26</p>
         <ul>
             <li>Fix a crash when <a href="https://redmine.stoutner.com/issues/225">editing a bookmark</a> in the new bookmarks drawer.</li>
         </ul>
index f994a3bd9e6e19204a862d596f5c1ad44c153b24..c7078a1607cbdc37c75d2ca76ea67faf795b58fb 100644 (file)
@@ -25,7 +25,7 @@
 
     <body>
         <h3>2.7.1 (version code 28)</h3>
-        <p>9 November 2017 - minimum API 19, target API 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9 November 2017</a> - minimum API 19, target API 26</p>
         <ul>
             <li>Fix a crash when <a href="https://redmine.stoutner.com/issues/225">editing a bookmark</a> in the new bookmarks drawer.</li>
         </ul>
index 6877439b425ac3dbe6b75a10f217fc68f23466bb..ac7c1f515057ccd914eb506c4ceaecd95d74e850 100644 (file)
@@ -25,7 +25,7 @@
 
     <body>
         <h3>2.7.1 (version code 28)</h3>
-        <p>9 November 2017 - minimum API 19, target API 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9 November 2017</a> - minimum API 19, target API 26</p>
         <ul>
             <li>Fix a crash when <a href="https://redmine.stoutner.com/issues/225">editing a bookmark</a> in the new bookmarks drawer.</li>
         </ul>
index 6c7e8df4860c95a4df19571de02f4bceb4ea4405..c5fd9de14906517bd629a9ee8dda423efbeebed7 100644 (file)
@@ -27,7 +27,7 @@
 
     <body>
         <h3>2.7.1 (código de versión 28)</h3>
-        <p>9 de noviembre de 2017 - API mínimo 19, API dirigido 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9 de noviembre de 2017</a> - API mínimo 19, API dirigido 26</p>
         <ul>
             <li>Corrregir un fallo al <a href="https://redmine.stoutner.com/issues/225">editar un favorito</a> en el nuevo cajón de favoritos.</li>
         </ul>
index 5abd0a8359149f99cf04c411ec21c49e5ff1873e..254d64f01ec767fe64d7562a725c4125c157c188 100644 (file)
@@ -27,7 +27,7 @@
 
     <body>
         <h3>2.7.1 (código de versión 28)</h3>
-        <p>9 de noviembre de 2017 - API mínimo 19, API dirigido 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9 de noviembre de 2017</a> - API mínimo 19, API dirigido 26</p>
         <ul>
             <li>Corrregir un fallo al <a href="https://redmine.stoutner.com/issues/225">editar un favorito</a> en el nuevo cajón de favoritos.</li>
         </ul>
index c9e592ae876cef17f1d3b0d1f398577bc3133cdb..b55c002e7e5aac90ab94b9435c2f2576b4b9c902 100644 (file)
@@ -27,7 +27,7 @@
 
     <body>
         <h3>2.7.1 (versione codice 28)</h3>
-        <p>9 Novembre 2017 - minima API 19, target API 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9 Novembre 2017</a> - minima API 19, target API 26</p>
         <ul>
             <li>Eliminato un crash che si verificava nel caso di <a href="https://redmine.stoutner.com/issues/225">editing dei segnalibri</a> dal nuovo cassetto dei segnalibri.</li>
         </ul>
index bbae4cd92cc94b7290a2e4a7c35728ed848ad3b8..ee963d500b48bab099506be7117a8247e6598963 100644 (file)
@@ -27,7 +27,7 @@
 
     <body>
         <h3>2.7.1 (versione codice 28)</h3>
-        <p>9 Novembre 2017 - minima API 19, target API 26</p>
+        <p><a href="https://git.stoutner.com/?p=PrivacyBrowser.git;a=commitdiff;h=24f2d6529540bc8ea47f45bc07dd058f402a9140">9 Novembre 2017</a> - minima API 19, target API 26</p>
         <ul>
             <li>Eliminato un crash che si verificava nel caso di <a href="https://redmine.stoutner.com/issues/225">editing dei segnalibri</a> dal nuovo cassetto dei segnalibri.</li>
         </ul>
index c6f04a0fab47119a7ca812ea8b6af1c2a257e63c..29332ebc599c6511fce76c686fd8c1c9af9c599a 100644 (file)
@@ -812,8 +812,8 @@ public class MainWebViewActivity extends AppCompatActivity implements CreateBook
             @SuppressWarnings("deprecation")
             @Override
             public boolean shouldOverrideUrlLoading(WebView view, String url) {
-                if (url.startsWith("mailto:")) {  // Load the URL in an external email program because it begins with `mailto:`.
-                    // We use `ACTION_SENDTO` instead of `ACTION_SEND` so that only email programs are launched.
+                if (url.startsWith("mailto:")) {  // Load the email address in an external email program.
+                    // Use `ACTION_SENDTO` instead of `ACTION_SEND` so that only email programs are launched.
                     Intent emailIntent = new Intent(Intent.ACTION_SENDTO);
 
                     // Parse the url and set it as the data for the `Intent`.
@@ -825,6 +825,21 @@ public class MainWebViewActivity extends AppCompatActivity implements CreateBook
                     // Make it so.
                     startActivity(emailIntent);
 
+                    // Returning `true` indicates the application is handling the URL.
+                    return true;
+                } else if (url.startsWith("tel:")) {  // Load the phone number in the dialer.
+                    // `ACTION_DIAL` open the dialer and loads the phone number, but waits for the user to place the call.
+                    Intent dialIntent = new Intent(Intent.ACTION_DIAL);
+
+                    // Add the phone number to the intent.
+                    dialIntent.setData(Uri.parse(url));
+
+                    // `FLAG_ACTIVITY_NEW_TASK` opens the dialer in a new task instead as part of Privacy Browser.
+                    dialIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
+
+                    // Make it so.
+                    startActivity(dialIntent);
+
                     // Returning `true` indicates the application is handling the URL.
                     return true;
                 } else {  // Load the URL in Privacy Browser.
index 5aa4870fbea023cc47691dcbab4c3e2f0a969ef4..f903bec373bd78a382dbc52f75bf6e3330ea2baa 100644 (file)
@@ -1,11 +1,34 @@
+/*
+ * Copyright © 2016-2017 Soren Stoutner <soren@stoutner.com>.
+ *
+ * This file is part of Privacy Browser <https://www.stoutner.com/privacy-browser>.
+ *
+ * Privacy Browser is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Privacy Browser is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with Privacy Browser.  If not, see <http://www.gnu.org/licenses/>.
+ */
+
 // Top-level build file where you can add configuration options common to all sub-projects/modules.
 
 buildscript {
     repositories {
         jcenter()
+        maven {
+            url 'https://maven.google.com/'
+            name 'Google'
+        }
     }
     dependencies {
-        classpath 'com.android.tools.build:gradle:3.0.0'
+        classpath 'com.android.tools.build:gradle:3.0.1'
 
         // NOTE: Do not place your application dependencies here; they belong
         // in the individual module build.gradle files
@@ -15,6 +38,9 @@ buildscript {
 allprojects {
     repositories {
         jcenter()
-        google()
+        maven {
+            url 'https://maven.google.com/'
+            name 'Google'
+        }
     }
 }