This commit is contained in:
Lorenzo Pichilli 2022-12-06 02:26:29 +01:00
parent 459875ff2e
commit 0f1c7e3029
5 changed files with 41 additions and 10 deletions

View File

@ -1,3 +1,7 @@
## 6.0.0-beta.21
- Fixed "Android plugin version 6 - UserScripts not executing on new tabs." [#1455](https://github.com/pichillilorenzo/flutter_inappwebview/issues/1455)
## 6.0.0-beta.20 ## 6.0.0-beta.20
- Using Android `WebViewClientCompat` for Chromium-based WebView if the WebView package major version is >= 73 (https://bugs.chromium.org/p/chromium/issues/detail?id=925887) - Using Android `WebViewClientCompat` for Chromium-based WebView if the WebView package major version is >= 73 (https://bugs.chromium.org/p/chromium/issues/detail?id=925887)

View File

@ -1,5 +1,6 @@
package com.pichillilorenzo.flutter_inappwebview.webview.in_app_webview; package com.pichillilorenzo.flutter_inappwebview.webview.in_app_webview;
import android.annotation.SuppressLint;
import android.content.Context; import android.content.Context;
import android.hardware.display.DisplayManager; import android.hardware.display.DisplayManager;
import android.os.Build; import android.os.Build;
@ -88,7 +89,12 @@ public class FlutterWebView implements PlatformWebView {
return pullToRefreshLayout != null ? pullToRefreshLayout : webView; return pullToRefreshLayout != null ? pullToRefreshLayout : webView;
} }
@SuppressLint("RestrictedApi")
public void makeInitialLoad(HashMap<String, Object> params) { public void makeInitialLoad(HashMap<String, Object> params) {
if (webView == null) {
return;
}
Integer windowId = (Integer) params.get("windowId"); Integer windowId = (Integer) params.get("windowId");
Map<String, Object> initialUrlRequest = (Map<String, Object>) params.get("initialUrlRequest"); Map<String, Object> initialUrlRequest = (Map<String, Object>) params.get("initialUrlRequest");
final String initialFile = (String) params.get("initialFile"); final String initialFile = (String) params.get("initialFile");
@ -99,6 +105,23 @@ public class FlutterWebView implements PlatformWebView {
if (resultMsg != null) { if (resultMsg != null) {
((WebView.WebViewTransport) resultMsg.obj).setWebView(webView); ((WebView.WebViewTransport) resultMsg.obj).setWebView(webView);
resultMsg.sendToTarget(); resultMsg.sendToTarget();
if (WebViewFeature.isFeatureSupported(WebViewFeature.DOCUMENT_START_SCRIPT)) {
// for some reason, if a WebView is created using a window id,
// the initial plugin and user scripts injected
// with WebViewCompat.addDocumentStartJavaScript will not be added!
// https://github.com/pichillilorenzo/flutter_inappwebview/issues/1455
//
// Also, calling the prepareAndAddUserScripts method right after won't work,
// so use the View.post method here.
webView.post(new Runnable() {
@Override
public void run() {
if (webView != null) {
webView.prepareAndAddUserScripts();
}
}
});
}
} }
} else { } else {
if (initialFile != null) { if (initialFile != null) {

View File

@ -61,7 +61,6 @@ import androidx.webkit.WebViewCompat;
import androidx.webkit.WebViewFeature; import androidx.webkit.WebViewFeature;
import com.pichillilorenzo.flutter_inappwebview.InAppWebViewFlutterPlugin; import com.pichillilorenzo.flutter_inappwebview.InAppWebViewFlutterPlugin;
import com.pichillilorenzo.flutter_inappwebview.InAppWebViewStatic;
import com.pichillilorenzo.flutter_inappwebview.R; import com.pichillilorenzo.flutter_inappwebview.R;
import com.pichillilorenzo.flutter_inappwebview.Util; import com.pichillilorenzo.flutter_inappwebview.Util;
import com.pichillilorenzo.flutter_inappwebview.content_blocker.ContentBlocker; import com.pichillilorenzo.flutter_inappwebview.content_blocker.ContentBlocker;
@ -166,7 +165,7 @@ final public class InAppWebView extends InputAwareWebView implements InAppWebVie
public Map<String, WebMessageChannel> webMessageChannels = new HashMap<>(); public Map<String, WebMessageChannel> webMessageChannels = new HashMap<>();
public List<WebMessageListener> webMessageListeners = new ArrayList<>(); public List<WebMessageListener> webMessageListeners = new ArrayList<>();
private List<UserScript> initialUserOnlyScript = new ArrayList<>(); private List<UserScript> initialUserOnlyScripts = new ArrayList<>();
@Nullable @Nullable
public FindInteractionController findInteractionController; public FindInteractionController findInteractionController;
@ -198,7 +197,7 @@ final public class InAppWebView extends InputAwareWebView implements InAppWebVie
this.windowId = windowId; this.windowId = windowId;
this.customSettings = customSettings; this.customSettings = customSettings;
this.contextMenu = contextMenu; this.contextMenu = contextMenu;
this.initialUserOnlyScript = userScripts; this.initialUserOnlyScripts = userScripts;
if (plugin != null && plugin.activity != null) { if (plugin != null && plugin.activity != null) {
plugin.activity.registerForContextMenu(this); plugin.activity.registerForContextMenu(this);
} }
@ -260,7 +259,13 @@ final public class InAppWebView extends InputAwareWebView implements InAppWebVie
WebViewCompat.setWebViewRenderProcessClient(this, inAppWebViewRenderProcessClient); WebViewCompat.setWebViewRenderProcessClient(this, inAppWebViewRenderProcessClient);
} }
if (windowId == null || !WebViewFeature.isFeatureSupported(WebViewFeature.DOCUMENT_START_SCRIPT)) {
// for some reason, if a WebView is created using a window id,
// the initial plugin and user scripts injected
// with WebViewCompat.addDocumentStartJavaScript will not be added!
// https://github.com/pichillilorenzo/flutter_inappwebview/issues/1455
prepareAndAddUserScripts(); prepareAndAddUserScripts();
}
if (customSettings.useOnDownloadStart) if (customSettings.useOnDownloadStart)
setDownloadListener(new DownloadStartListener()); setDownloadListener(new DownloadStartListener());
@ -552,7 +557,7 @@ final public class InAppWebView extends InputAwareWebView implements InAppWebVie
}); });
} }
private void prepareAndAddUserScripts() { public void prepareAndAddUserScripts() {
userContentController.addPluginScript(PromisePolyfillJS.PROMISE_POLYFILL_JS_PLUGIN_SCRIPT); userContentController.addPluginScript(PromisePolyfillJS.PROMISE_POLYFILL_JS_PLUGIN_SCRIPT);
userContentController.addPluginScript(JavaScriptBridgeJS.JAVASCRIPT_BRIDGE_JS_PLUGIN_SCRIPT); userContentController.addPluginScript(JavaScriptBridgeJS.JAVASCRIPT_BRIDGE_JS_PLUGIN_SCRIPT);
userContentController.addPluginScript(ConsoleLogJS.CONSOLE_LOG_JS_PLUGIN_SCRIPT); userContentController.addPluginScript(ConsoleLogJS.CONSOLE_LOG_JS_PLUGIN_SCRIPT);
@ -571,7 +576,7 @@ final public class InAppWebView extends InputAwareWebView implements InAppWebVie
if (!customSettings.useHybridComposition) { if (!customSettings.useHybridComposition) {
userContentController.addPluginScript(PluginScriptsUtil.CHECK_GLOBAL_KEY_DOWN_EVENT_TO_HIDE_CONTEXT_MENU_JS_PLUGIN_SCRIPT); userContentController.addPluginScript(PluginScriptsUtil.CHECK_GLOBAL_KEY_DOWN_EVENT_TO_HIDE_CONTEXT_MENU_JS_PLUGIN_SCRIPT);
} }
this.userContentController.addUserOnlyScripts(this.initialUserOnlyScript); this.userContentController.addUserOnlyScripts(this.initialUserOnlyScripts);
} }
public void setIncognito(boolean enabled) { public void setIncognito(boolean enabled) {

View File

@ -3,12 +3,11 @@
export "FLUTTER_ROOT=/Users/lorenzopichilli/fvm/versions/3.3.6" export "FLUTTER_ROOT=/Users/lorenzopichilli/fvm/versions/3.3.6"
export "FLUTTER_APPLICATION_PATH=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example" export "FLUTTER_APPLICATION_PATH=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example"
export "COCOAPODS_PARALLEL_CODE_SIGN=true" export "COCOAPODS_PARALLEL_CODE_SIGN=true"
export "FLUTTER_TARGET=integration_test/webview_flutter_test.dart" export "FLUTTER_TARGET=lib/main.dart"
export "FLUTTER_BUILD_DIR=build" export "FLUTTER_BUILD_DIR=build"
export "FLUTTER_BUILD_NAME=1.0.0" export "FLUTTER_BUILD_NAME=1.0.0"
export "FLUTTER_BUILD_NUMBER=1" export "FLUTTER_BUILD_NUMBER=1"
export "DART_DEFINES=RkxVVFRFUl9XRUJfQVVUT19ERVRFQ1Q9dHJ1ZQ=="
export "DART_OBFUSCATION=false" export "DART_OBFUSCATION=false"
export "TRACK_WIDGET_CREATION=true" export "TRACK_WIDGET_CREATION=true"
export "TREE_SHAKE_ICONS=false" export "TREE_SHAKE_ICONS=false"
export "PACKAGE_CONFIG=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example/.dart_tool/package_config.json" export "PACKAGE_CONFIG=.dart_tool/package_config.json"

View File

@ -1,6 +1,6 @@
name: flutter_inappwebview name: flutter_inappwebview
description: A Flutter plugin that allows you to add an inline webview, to use an headless webview, and to open an in-app browser window. description: A Flutter plugin that allows you to add an inline webview, to use an headless webview, and to open an in-app browser window.
version: 6.0.0-beta.20 version: 6.0.0-beta.21
homepage: https://inappwebview.dev/ homepage: https://inappwebview.dev/
repository: https://github.com/pichillilorenzo/flutter_inappwebview repository: https://github.com/pichillilorenzo/flutter_inappwebview
issue_tracker: https://github.com/pichillilorenzo/flutter_inappwebview/issues issue_tracker: https://github.com/pichillilorenzo/flutter_inappwebview/issues