Added underPageBackgroundColor, isTextInteractionEnabled, isSiteSpecificQuirksModeEnabled, upgradeKnownHostsToHTTPS WebView settings, Updated getMetaThemeColor on iOS 15.0+

This commit is contained in:
Lorenzo Pichilli 2022-04-21 02:14:21 +02:00
parent bca59d3e87
commit 3cd3b30457
21 changed files with 150 additions and 20 deletions

View File

@ -1,7 +1,9 @@
## 6.0.0 ## 6.0.0
- Added `pauseAllMediaPlayback`, `setAllMediaPlaybackSuspended`, `closeAllMediaPresentations`, `requestMediaPlaybackState` WebView controller methods
- Deprecated old classes/properties/methods to make them eventually compatible with other operating systems and WebView engines. - Deprecated old classes/properties/methods to make them eventually compatible with other operating systems and WebView engines.
- Added `pauseAllMediaPlayback`, `setAllMediaPlaybackSuspended`, `closeAllMediaPresentations`, `requestMediaPlaybackState` WebView controller methods
- Added `underPageBackgroundColor`, `isTextInteractionEnabled`, `isSiteSpecificQuirksModeEnabled`, `upgradeKnownHostsToHTTPS` WebView settings
- Updated `getMetaThemeColor` on iOS 15.0+
## 5.4.0+2 ## 5.4.0+2

View File

@ -25,7 +25,7 @@ class _InAppWebViewExampleScreenState extends State<InAppWebViewExampleScreen> {
useShouldOverrideUrlLoading: true, useShouldOverrideUrlLoading: true,
mediaPlaybackRequiresUserGesture: false, mediaPlaybackRequiresUserGesture: false,
useHybridComposition: true, useHybridComposition: true,
allowsInlineMediaPlayback: true, allowsInlineMediaPlayback: true
); );
late PullToRefreshController pullToRefreshController; late PullToRefreshController pullToRefreshController;
@ -118,7 +118,7 @@ class _InAppWebViewExampleScreenState extends State<InAppWebViewExampleScreen> {
key: webViewKey, key: webViewKey,
// contextMenu: contextMenu, // contextMenu: contextMenu,
initialUrlRequest: initialUrlRequest:
URLRequest(url: Uri.parse("https://www.youtube.com/watch?v=7_v6oMtz7tA")), URLRequest(url: Uri.parse("http://github.com/flutter/")),
// initialFile: "assets/index.html", // initialFile: "assets/index.html",
initialUserScripts: UnmodifiableListView<UserScript>([]), initialUserScripts: UnmodifiableListView<UserScript>([]),
initialSettings: settings, initialSettings: settings,
@ -126,11 +126,12 @@ class _InAppWebViewExampleScreenState extends State<InAppWebViewExampleScreen> {
onWebViewCreated: (controller) { onWebViewCreated: (controller) {
webViewController = controller; webViewController = controller;
}, },
onLoadStart: (controller, url) { onLoadStart: (controller, url) async {
setState(() { setState(() {
this.url = url.toString(); this.url = url.toString();
urlController.text = this.url; urlController.text = this.url;
}); });
print((await controller.getSettings())?.upgradeKnownHostsToHTTPS);
}, },
onPermissionRequest: (controller, origin, resources) async { onPermissionRequest: (controller, origin, resources) async {
return PermissionRequestResponse( return PermissionRequestResponse(
@ -167,6 +168,7 @@ class _InAppWebViewExampleScreenState extends State<InAppWebViewExampleScreen> {
this.url = url.toString(); this.url = url.toString();
urlController.text = this.url; urlController.text = this.url;
}); });
print((await controller.getSettings())?.upgradeKnownHostsToHTTPS);
}, },
onLoadError: (controller, url, code, message) { onLoadError: (controller, url, code, message) {
pullToRefreshController.endRefreshing(); pullToRefreshController.endRefreshing();

View File

@ -385,6 +385,12 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
pageZoom = CGFloat(settings.pageZoom) pageZoom = CGFloat(settings.pageZoom)
} }
if #available(iOS 15.0, *) {
if let underPageBackgroundColor = settings.underPageBackgroundColor, !underPageBackgroundColor.isEmpty {
self.underPageBackgroundColor = UIColor(hexString: underPageBackgroundColor)
}
}
// debugging is always enabled for iOS, // debugging is always enabled for iOS,
// there isn't any option to set about it such as on Android. // there isn't any option to set about it such as on Android.
@ -421,6 +427,14 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
if #available(iOS 14.0, *) { if #available(iOS 14.0, *) {
configuration.defaultWebpagePreferences.allowsContentJavaScript = settings.javaScriptEnabled configuration.defaultWebpagePreferences.allowsContentJavaScript = settings.javaScriptEnabled
} }
if #available(iOS 14.5, *) {
configuration.preferences.isTextInteractionEnabled = settings.isTextInteractionEnabled
}
if #available(iOS 15.0, *) {
configuration.preferences.isSiteSpecificQuirksModeEnabled = settings.isSiteSpecificQuirksModeEnabled
}
} }
} }
@ -543,6 +557,10 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
if #available(iOS 14.0, *) { if #available(iOS 14.0, *) {
configuration.limitsNavigationsToAppBoundDomains = settings.limitsNavigationsToAppBoundDomains configuration.limitsNavigationsToAppBoundDomains = settings.limitsNavigationsToAppBoundDomains
} }
if #available(iOS 14.5, *) {
configuration.upgradeKnownHostsToHTTPS = settings.upgradeKnownHostsToHTTPS
}
} }
return configuration return configuration
@ -1098,6 +1116,26 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
} }
} }
if #available(iOS 14.5, *) {
if newSettingsMap["upgradeKnownHostsToHTTPS"] != nil && settings?.upgradeKnownHostsToHTTPS != newSettings.upgradeKnownHostsToHTTPS {
configuration.upgradeKnownHostsToHTTPS = newSettings.upgradeKnownHostsToHTTPS
}
if newSettingsMap["isTextInteractionEnabled"] != nil && settings?.isTextInteractionEnabled != newSettings.isTextInteractionEnabled {
configuration.preferences.isTextInteractionEnabled = newSettings.isTextInteractionEnabled
}
}
if #available(iOS 15.0, *) {
if newSettingsMap["underPageBackgroundColor"] != nil, settings?.underPageBackgroundColor != newSettings.underPageBackgroundColor,
let underPageBackgroundColor = newSettings.underPageBackgroundColor, !underPageBackgroundColor.isEmpty {
self.underPageBackgroundColor = UIColor(hexString: underPageBackgroundColor)
}
if newSettingsMap["isSiteSpecificQuirksModeEnabled"] != nil &&
settings?.isSiteSpecificQuirksModeEnabled != newSettings.isSiteSpecificQuirksModeEnabled {
configuration.preferences.isSiteSpecificQuirksModeEnabled = newSettings.isSiteSpecificQuirksModeEnabled
}
}
scrollView.isScrollEnabled = !(newSettings.disableVerticalScroll && newSettings.disableHorizontalScroll) scrollView.isScrollEnabled = !(newSettings.disableVerticalScroll && newSettings.disableHorizontalScroll)
self.settings = newSettings self.settings = newSettings

View File

@ -70,6 +70,10 @@ public class InAppWebViewSettings: IWebViewSettings<InAppWebView> {
var allowingReadAccessTo: String? = nil var allowingReadAccessTo: String? = nil
var disableLongPressContextMenuOnLinks = false var disableLongPressContextMenuOnLinks = false
var disableInputAccessoryView = false var disableInputAccessoryView = false
var underPageBackgroundColor: String?
var isTextInteractionEnabled = true
var isSiteSpecificQuirksModeEnabled = true
var upgradeKnownHostsToHTTPS = true
override init(){ override init(){
super.init() super.init()
@ -133,6 +137,14 @@ public class InAppWebViewSettings: IWebViewSettings<InAppWebView> {
realSettings["limitsNavigationsToAppBoundDomains"] = configuration.limitsNavigationsToAppBoundDomains realSettings["limitsNavigationsToAppBoundDomains"] = configuration.limitsNavigationsToAppBoundDomains
realSettings["javaScriptEnabled"] = configuration.defaultWebpagePreferences.allowsContentJavaScript realSettings["javaScriptEnabled"] = configuration.defaultWebpagePreferences.allowsContentJavaScript
} }
if #available(iOS 14.5, *) {
realSettings["isTextInteractionEnabled"] = configuration.preferences.isTextInteractionEnabled
realSettings["upgradeKnownHostsToHTTPS"] = configuration.upgradeKnownHostsToHTTPS
}
if #available(iOS 15.0, *) {
realSettings["underPageBackgroundColor"] = webView.underPageBackgroundColor.hexString
realSettings["isSiteSpecificQuirksModeEnabled"] = configuration.preferences.isSiteSpecificQuirksModeEnabled
}
} }
return realSettings return realSettings
} }

View File

@ -585,6 +585,13 @@ public class InAppWebViewMethodHandler: FlutterMethodCallDelegate {
result(nil) result(nil)
} }
break break
case "getMetaThemeColor":
if let webView = webView, #available(iOS 15.0, *) {
result(webView.themeColor?.hexString)
} else {
result(nil)
}
break
default: default:
result(FlutterMethodNotImplemented) result(FlutterMethodNotImplemented)
break break

View File

@ -6,7 +6,7 @@ import '../../types.dart';
import '../chrome_safari_browser_settings.dart'; import '../chrome_safari_browser_settings.dart';
import '../chrome_safari_browser.dart'; import '../chrome_safari_browser.dart';
import '../../in_app_webview/ios/in_app_webview_options.dart'; import '../../in_app_webview/apple/in_app_webview_options.dart';
///This class represents all the iOS-only [ChromeSafariBrowser] options available. ///This class represents all the iOS-only [ChromeSafariBrowser] options available.
///Use [ChromeSafariBrowserSettings] instead. ///Use [ChromeSafariBrowserSettings] instead.

View File

@ -5,7 +5,7 @@ import 'package:flutter/foundation.dart';
import '../util.dart'; import '../util.dart';
import 'android/chrome_custom_tabs_options.dart'; import 'android/chrome_custom_tabs_options.dart';
import 'ios/safari_options.dart'; import 'apple/safari_options.dart';
import '../types.dart'; import '../types.dart';
class ChromeSafariBrowserOptions { class ChromeSafariBrowserOptions {

View File

@ -1,4 +1,4 @@
export 'chrome_safari_browser.dart'; export 'chrome_safari_browser.dart';
export 'chrome_safari_browser_settings.dart'; export 'chrome_safari_browser_settings.dart';
export 'android/main.dart'; export 'android/main.dart';
export 'ios/main.dart'; export 'apple/main.dart';

View File

@ -1,6 +1,6 @@
import 'dart:ui'; import 'dart:ui';
import '../../in_app_webview/ios/in_app_webview_options.dart'; import '../../in_app_webview/apple/in_app_webview_options.dart';
import '../in_app_browser_settings.dart'; import '../in_app_browser_settings.dart';
import '../in_app_browser.dart'; import '../in_app_browser.dart';

View File

@ -11,8 +11,8 @@ import '../in_app_webview/in_app_webview_settings.dart';
import 'android/in_app_browser_options.dart'; import 'android/in_app_browser_options.dart';
import '../in_app_webview/android/in_app_webview_options.dart'; import '../in_app_webview/android/in_app_webview_options.dart';
import 'ios/in_app_browser_options.dart'; import 'apple/in_app_browser_options.dart';
import '../in_app_webview/ios/in_app_webview_options.dart'; import '../in_app_webview/apple/in_app_webview_options.dart';
class BrowserOptions { class BrowserOptions {
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {

View File

@ -1,4 +1,4 @@
export 'in_app_browser.dart'; export 'in_app_browser.dart';
export 'in_app_browser_settings.dart'; export 'in_app_browser_settings.dart';
export 'android/main.dart'; export 'android/main.dart';
export 'ios/main.dart'; export 'apple/main.dart';

View File

@ -10,7 +10,7 @@ import 'package:flutter/services.dart';
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
import 'android/in_app_webview_controller.dart'; import 'android/in_app_webview_controller.dart';
import 'ios/in_app_webview_controller.dart'; import 'apple/in_app_webview_controller.dart';
import '../context_menu.dart'; import '../context_menu.dart';
import '../types.dart'; import '../types.dart';
@ -2295,12 +2295,27 @@ class InAppWebViewController
///Returns an instance of [Color] representing the `content` value of the ///Returns an instance of [Color] representing the `content` value of the
///`<meta name="theme-color" content="">` tag of the current WebView, if available, otherwise `null`. ///`<meta name="theme-color" content="">` tag of the current WebView, if available, otherwise `null`.
/// ///
///**NOTE**: It is implemented using JavaScript. ///**NOTE**: on Android and iOS < 15.0, it is implemented using JavaScript.
/// ///
///**Supported Platforms/Implementations**: ///**Supported Platforms/Implementations**:
///- Android native WebView ///- Android native WebView
///- iOS ///- iOS ([Official API - WKWebView.themeColor](https://developer.apple.com/documentation/webkit/wkwebview/3794258-themecolor))
Future<Color?> getMetaThemeColor() async { Future<Color?> getMetaThemeColor() async {
Color? themeColor;
try {
Map<String, dynamic> args = <String, dynamic>{};
themeColor = UtilColor.fromStringRepresentation(await _channel.invokeMethod('getMetaThemeColor', args));
} catch (e) {
// not implemented
}
if (themeColor != null) {
return themeColor;
}
// try using javascript
var metaTags = await getMetaTags(); var metaTags = await getMetaTags();
MetaTag? metaTagThemeColor; MetaTag? metaTagThemeColor;
@ -2317,9 +2332,11 @@ class InAppWebViewController
var colorValue = metaTagThemeColor.content; var colorValue = metaTagThemeColor.content;
return colorValue != null themeColor = colorValue != null
? UtilColor.fromStringRepresentation(colorValue) ? UtilColor.fromStringRepresentation(colorValue)
: null; : null;
return themeColor;
} }
///Returns the scrolled left position of the current WebView. ///Returns the scrolled left position of the current WebView.

View File

@ -4,7 +4,7 @@ import 'dart:ui';
import 'package:flutter/foundation.dart'; import 'package:flutter/foundation.dart';
import 'android/in_app_webview_options.dart'; import 'android/in_app_webview_options.dart';
import 'ios/in_app_webview_options.dart'; import 'apple/in_app_webview_options.dart';
import '../content_blocker.dart'; import '../content_blocker.dart';
import '../types.dart'; import '../types.dart';
import '../util.dart'; import '../util.dart';
@ -956,6 +956,46 @@ class InAppWebViewSettings
///- iOS ///- iOS
bool disableInputAccessoryView; bool disableInputAccessoryView;
///The color the web view displays behind the active page, visible when the user scrolls beyond the bounds of the page.
///
///The web view derives the default value of this property from the content of the page,
///using the background colors of the `<html>` and `<body>` elements with the background color of the web view.
///To override the default color, set this property to a new color.
///
///**NOTE**: available on iOS 15.0+.
///
///**Supported Platforms/Implementations**:
///- iOS
Color? underPageBackgroundColor;
///A Boolean value indicating whether text interaction is enabled or not.
///The default value is `true`.
///
///**NOTE**: available on iOS 14.5+.
///
///**Supported Platforms/Implementations**:
///- iOS
bool isTextInteractionEnabled;
///A Boolean value indicating whether WebKit will apply built-in workarounds (quirks)
///to improve compatibility with certain known websites. You can disable site-specific quirks
///to help test your website without these workarounds. The default value is `true`.
///
///**NOTE**: available on iOS 15.0+.
///
///**Supported Platforms/Implementations**:
///- iOS
bool isSiteSpecificQuirksModeEnabled;
///A Boolean value indicating whether HTTP requests to servers known to support HTTPS should be automatically upgraded to HTTPS requests.
///The default value is `true`.
///
///**NOTE**: available on iOS 14.5+.
///
///**Supported Platforms/Implementations**:
///- iOS
bool upgradeKnownHostsToHTTPS;
InAppWebViewSettings( InAppWebViewSettings(
{this.useShouldOverrideUrlLoading = false, {this.useShouldOverrideUrlLoading = false,
this.useOnLoadResource = false, this.useOnLoadResource = false,
@ -1071,7 +1111,11 @@ class InAppWebViewSettings
this.applePayAPIEnabled = false, this.applePayAPIEnabled = false,
this.allowingReadAccessTo, this.allowingReadAccessTo,
this.disableLongPressContextMenuOnLinks = false, this.disableLongPressContextMenuOnLinks = false,
this.disableInputAccessoryView = false}) { this.disableInputAccessoryView = false,
this.underPageBackgroundColor,
this.isTextInteractionEnabled = true,
this.isSiteSpecificQuirksModeEnabled = true,
this.upgradeKnownHostsToHTTPS = true}) {
if (this.minimumFontSize == null) if (this.minimumFontSize == null)
this.minimumFontSize = this.minimumFontSize =
defaultTargetPlatform == TargetPlatform.android ? 8 : 0; defaultTargetPlatform == TargetPlatform.android ? 8 : 0;
@ -1210,6 +1254,10 @@ class InAppWebViewSettings
"allowingReadAccessTo": allowingReadAccessTo.toString(), "allowingReadAccessTo": allowingReadAccessTo.toString(),
"disableLongPressContextMenuOnLinks": disableLongPressContextMenuOnLinks, "disableLongPressContextMenuOnLinks": disableLongPressContextMenuOnLinks,
"disableInputAccessoryView": disableInputAccessoryView, "disableInputAccessoryView": disableInputAccessoryView,
"underPageBackgroundColor": underPageBackgroundColor?.toHex(),
"isTextInteractionEnabled": isTextInteractionEnabled,
"isSiteSpecificQuirksModeEnabled": isSiteSpecificQuirksModeEnabled,
"upgradeKnownHostsToHTTPS": upgradeKnownHostsToHTTPS
}; };
} }
@ -1382,6 +1430,10 @@ class InAppWebViewSettings
settings.disableLongPressContextMenuOnLinks = settings.disableLongPressContextMenuOnLinks =
map["disableLongPressContextMenuOnLinks"]; map["disableLongPressContextMenuOnLinks"];
settings.disableInputAccessoryView = map["disableInputAccessoryView"]; settings.disableInputAccessoryView = map["disableInputAccessoryView"];
settings.underPageBackgroundColor = UtilColor.fromHex(map["underPageBackgroundColor"]);
settings.isTextInteractionEnabled = map["isTextInteractionEnabled"];
settings.isSiteSpecificQuirksModeEnabled = map["isSiteSpecificQuirksModeEnabled"];
settings.upgradeKnownHostsToHTTPS = map["upgradeKnownHostsToHTTPS"];
} }
return settings; return settings;
} }

View File

@ -4,4 +4,4 @@ export 'in_app_webview_controller.dart';
export 'in_app_webview_settings.dart'; export 'in_app_webview_settings.dart';
export 'headless_in_app_webview.dart'; export 'headless_in_app_webview.dart';
export 'android/main.dart'; export 'android/main.dart';
export 'ios/main.dart'; export 'apple/main.dart';

View File

@ -2,7 +2,7 @@ export 'in_app_webview/main.dart';
export 'in_app_browser/main.dart'; export 'in_app_browser/main.dart';
export 'chrome_safari_browser/main.dart'; export 'chrome_safari_browser/main.dart';
export 'android/main.dart'; export 'android/main.dart';
export 'ios/main.dart'; export 'apple/main.dart';
export 'x509_certificate/main.dart'; export 'x509_certificate/main.dart';
export 'web_storage/main.dart'; export 'web_storage/main.dart';
export 'types.dart'; export 'types.dart';