merged fix: try to open with Chrome if default browser app does not support custom tabs
This commit is contained in:
parent
f0d3039533
commit
cad913f279
|
@ -38,6 +38,7 @@
|
||||||
- Fixed iOS 14.0 crash when calling `callAsyncJavaScript` method
|
- Fixed iOS 14.0 crash when calling `callAsyncJavaScript` method
|
||||||
- Merged "Android fix leaking MethodChannel through anonymous class" [#1201](https://github.com/pichillilorenzo/flutter_inappwebview/pull/1201) (thanks to [emakar](https://github.com/emakar))
|
- Merged "Android fix leaking MethodChannel through anonymous class" [#1201](https://github.com/pichillilorenzo/flutter_inappwebview/pull/1201) (thanks to [emakar](https://github.com/emakar))
|
||||||
- Merged "Fix RangeError: Maximum call stack size exceeded" [#1208](https://github.com/pichillilorenzo/flutter_inappwebview/pull/1208) (thanks to [liasica](https://github.com/liasica))
|
- Merged "Fix RangeError: Maximum call stack size exceeded" [#1208](https://github.com/pichillilorenzo/flutter_inappwebview/pull/1208) (thanks to [liasica](https://github.com/liasica))
|
||||||
|
- Merged "fix: try to open with Chrome if default browser app does not support custom tabs" [#1233](https://github.com/pichillilorenzo/flutter_inappwebview/pull/1233) (thanks to [addie9000](https://github.com/addie9000))
|
||||||
|
|
||||||
## 5.4.4+3
|
## 5.4.4+3
|
||||||
|
|
||||||
|
|
|
@ -6,6 +6,7 @@ import android.content.IntentFilter;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
|
import android.os.Build;
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
|
@ -52,6 +53,7 @@ public class CustomTabsHelper {
|
||||||
PackageManager pm = context.getPackageManager();
|
PackageManager pm = context.getPackageManager();
|
||||||
// Get default VIEW intent handler.
|
// Get default VIEW intent handler.
|
||||||
Intent activityIntent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://www.example.com"));
|
Intent activityIntent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://www.example.com"));
|
||||||
|
activityIntent.addCategory(Intent.CATEGORY_BROWSABLE);
|
||||||
ResolveInfo defaultViewHandlerInfo = pm.resolveActivity(activityIntent, 0);
|
ResolveInfo defaultViewHandlerInfo = pm.resolveActivity(activityIntent, 0);
|
||||||
String defaultViewHandlerPackageName = null;
|
String defaultViewHandlerPackageName = null;
|
||||||
if (defaultViewHandlerInfo != null) {
|
if (defaultViewHandlerInfo != null) {
|
||||||
|
@ -59,7 +61,11 @@ public class CustomTabsHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get all apps that can handle VIEW intents.
|
// Get all apps that can handle VIEW intents.
|
||||||
List<ResolveInfo> resolvedActivityList = pm.queryIntentActivities(activityIntent, 0);
|
int flags = 0;
|
||||||
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
|
||||||
|
flags |= PackageManager.MATCH_ALL;
|
||||||
|
}
|
||||||
|
List<ResolveInfo> resolvedActivityList = pm.queryIntentActivities(activityIntent, flags);
|
||||||
List<String> packagesSupportingCustomTabs = new ArrayList<>();
|
List<String> packagesSupportingCustomTabs = new ArrayList<>();
|
||||||
for (ResolveInfo info : resolvedActivityList) {
|
for (ResolveInfo info : resolvedActivityList) {
|
||||||
Intent serviceIntent = new Intent();
|
Intent serviceIntent = new Intent();
|
||||||
|
|
Loading…
Reference in New Issue