Added 'values' property for all the custom Enums, bug fixes
This commit is contained in:
parent
b0c06c6146
commit
64246d84d9
10
CHANGELOG.md
10
CHANGELOG.md
|
@ -3,15 +3,21 @@
|
||||||
- Added `requestFocusNodeHref`, `requestImageRef`, `getMetaTags`, `getMetaThemeColor`, `getScrollX`, `getScrollY`, `getCertificate` webview methods
|
- Added `requestFocusNodeHref`, `requestImageRef`, `getMetaTags`, `getMetaThemeColor`, `getScrollX`, `getScrollY`, `getCertificate` webview methods
|
||||||
- Added `WebStorage`, `LocalStorage` and `SessionStorage` class to manage `window.localStorage` and `window.sessionStorage` JavaScript [Web Storage API](https://developer.mozilla.org/en-US/docs/Web/API/Web_Storage_API)
|
- Added `WebStorage`, `LocalStorage` and `SessionStorage` class to manage `window.localStorage` and `window.sessionStorage` JavaScript [Web Storage API](https://developer.mozilla.org/en-US/docs/Web/API/Web_Storage_API)
|
||||||
- Added `supportZoom` webview option also on iOS
|
- Added `supportZoom` webview option also on iOS
|
||||||
- Added `HttpOnly`, `SameSite` set cookie options
|
- Added `HttpOnly`, `SameSite` cookie options
|
||||||
- Updated `Cookie` class
|
- Updated `Cookie` class
|
||||||
- Added `animated` option to `scrollTo` and `scrollBy` webview methods
|
- Added `animated` option to `scrollTo` and `scrollBy` webview methods
|
||||||
- Added error and message to the `ServerTrustChallenge` class for iOS (class used by the `onReceivedServerTrustAuthRequest` event)
|
- Added error and message to the `ServerTrustChallenge` class for iOS (class used by the `onReceivedServerTrustAuthRequest` event)
|
||||||
- Added `contentInsetAdjustmentBehavior` webview iOS-specific option
|
- Added `contentInsetAdjustmentBehavior` webview iOS-specific option
|
||||||
- Added `copy` and `copyWithValue` methods for webview class options
|
- Added `copy` methods for webview class options
|
||||||
- Added `SslCertificate` class and `X509Certificate` class and parser
|
- Added `SslCertificate` class and `X509Certificate` class and parser
|
||||||
|
- Added `values` property for all the custom Enums
|
||||||
|
- Updated Android workaround to hide the Keyboard when the user click outside on something not focusable such as input or a textarea.
|
||||||
- Fixed `zoomBy`, `setOptions` webview methods on Android
|
- Fixed `zoomBy`, `setOptions` webview methods on Android
|
||||||
- Fixed `databaseEnabled` android webview option default value to `true`
|
- Fixed `databaseEnabled` android webview option default value to `true`
|
||||||
|
- Fixed `verticalScrollBarEnabled` and `horizontalScrollBarEnabled` on Android
|
||||||
|
- Fixed error caused by `pauseTimers` on iOS when the WebView has been disposed
|
||||||
|
- Fixed `ignoresViewportScaleLimits`, `dataDetectorTypes`, `suppressesIncrementalRendering`, `selectionGranularity` iOS-specific option when used in `initialOptions`
|
||||||
|
- Fixed `getFavicons` method
|
||||||
|
|
||||||
### BREAKING CHANGES
|
### BREAKING CHANGES
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
package com.pichillilorenzo.flutter_inappwebview.InAppWebView;
|
package com.pichillilorenzo.flutter_inappwebview.InAppWebView;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.MutableContextWrapper;
|
||||||
import android.hardware.display.DisplayManager;
|
import android.hardware.display.DisplayManager;
|
||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
|
@ -64,6 +65,11 @@ public class FlutterWebView implements PlatformView, MethodCallHandler {
|
||||||
"- See the official wiki here: https://github.com/flutter/flutter/wiki/Upgrading-pre-1.12-Android-projects\n\n\n");
|
"- See the official wiki here: https://github.com/flutter/flutter/wiki/Upgrading-pre-1.12-Android-projects\n\n\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// MutableContextWrapper mMutableContext = new MutableContextWrapper(Shared.activity);
|
||||||
|
// webView = new InAppWebView(mMutableContext, this, id, options, contextMenu, containerView);
|
||||||
|
// displayListenerProxy.onPostWebViewInitialization(displayManager);
|
||||||
|
// mMutableContext.setBaseContext(context);
|
||||||
|
|
||||||
webView = new InAppWebView(Shared.activity, this, id, options, contextMenu, containerView);
|
webView = new InAppWebView(Shared.activity, this, id, options, contextMenu, containerView);
|
||||||
displayListenerProxy.onPostWebViewInitialization(displayManager);
|
displayListenerProxy.onPostWebViewInitialization(displayManager);
|
||||||
|
|
||||||
|
|
|
@ -28,6 +28,9 @@ import android.view.MotionEvent;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.view.ViewTreeObserver;
|
import android.view.ViewTreeObserver;
|
||||||
|
import android.view.inputmethod.EditorInfo;
|
||||||
|
import android.view.inputmethod.InputConnection;
|
||||||
|
import android.view.inputmethod.InputMethodManager;
|
||||||
import android.webkit.CookieManager;
|
import android.webkit.CookieManager;
|
||||||
import android.webkit.DownloadListener;
|
import android.webkit.DownloadListener;
|
||||||
import android.webkit.ValueCallback;
|
import android.webkit.ValueCallback;
|
||||||
|
@ -70,6 +73,7 @@ import java.util.regex.Pattern;
|
||||||
import io.flutter.plugin.common.MethodChannel;
|
import io.flutter.plugin.common.MethodChannel;
|
||||||
import okhttp3.OkHttpClient;
|
import okhttp3.OkHttpClient;
|
||||||
|
|
||||||
|
import static android.content.Context.INPUT_METHOD_SERVICE;
|
||||||
import static com.pichillilorenzo.flutter_inappwebview.InAppWebView.PreferredContentModeOptionType.fromValue;
|
import static com.pichillilorenzo.flutter_inappwebview.InAppWebView.PreferredContentModeOptionType.fromValue;
|
||||||
|
|
||||||
final public class InAppWebView extends InputAwareWebView {
|
final public class InAppWebView extends InputAwareWebView {
|
||||||
|
@ -204,7 +208,7 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
" };" +
|
" };" +
|
||||||
" function handleEvent(e) {" +
|
" function handleEvent(e) {" +
|
||||||
" var self = this;" +
|
" var self = this;" +
|
||||||
" if (window." + variableForShouldInterceptAjaxRequestJS + " == null || window." + variableForShouldInterceptAjaxRequestJS + " == true) {" +
|
" if (" + variableForShouldInterceptAjaxRequestJS + " == null || " + variableForShouldInterceptAjaxRequestJS + " == true) {" +
|
||||||
" var headers = this.getAllResponseHeaders();" +
|
" var headers = this.getAllResponseHeaders();" +
|
||||||
" var responseHeaders = {};" +
|
" var responseHeaders = {};" +
|
||||||
" if (headers != null) {" +
|
" if (headers != null) {" +
|
||||||
|
@ -255,12 +259,12 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
" };" +
|
" };" +
|
||||||
" ajax.prototype.send = function(data) {" +
|
" ajax.prototype.send = function(data) {" +
|
||||||
" var self = this;" +
|
" var self = this;" +
|
||||||
" if (window." + variableForShouldInterceptAjaxRequestJS + " == null || window." + variableForShouldInterceptAjaxRequestJS + " == true) {" +
|
" if (" + variableForShouldInterceptAjaxRequestJS + " == null || " + variableForShouldInterceptAjaxRequestJS + " == true) {" +
|
||||||
" if (!this._flutter_inappwebview_already_onreadystatechange_wrapped) {" +
|
" if (!this._flutter_inappwebview_already_onreadystatechange_wrapped) {" +
|
||||||
" this._flutter_inappwebview_already_onreadystatechange_wrapped = true;" +
|
" this._flutter_inappwebview_already_onreadystatechange_wrapped = true;" +
|
||||||
" var onreadystatechange = this.onreadystatechange;" +
|
" var onreadystatechange = this.onreadystatechange;" +
|
||||||
" this.onreadystatechange = function() {" +
|
" this.onreadystatechange = function() {" +
|
||||||
" if (window." + variableForShouldInterceptAjaxRequestJS + " == null || window." + variableForShouldInterceptAjaxRequestJS + " == true) {" +
|
" if (" + variableForShouldInterceptAjaxRequestJS + " == null || " + variableForShouldInterceptAjaxRequestJS + " == true) {" +
|
||||||
" var headers = this.getAllResponseHeaders();" +
|
" var headers = this.getAllResponseHeaders();" +
|
||||||
" var responseHeaders = {};" +
|
" var responseHeaders = {};" +
|
||||||
" if (headers != null) {" +
|
" if (headers != null) {" +
|
||||||
|
@ -588,26 +592,6 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
" });" +
|
" });" +
|
||||||
"})();";
|
"})();";
|
||||||
|
|
||||||
// android Workaround to hide the Keyboard when the user click outside
|
|
||||||
// on something not focusable such as input or a textarea.
|
|
||||||
static final String androidKeyboardWorkaroundFocusoutEventJS = "(function(){" +
|
|
||||||
" var isFocusin = false;" +
|
|
||||||
" document.addEventListener('focusin', function(e) {" +
|
|
||||||
" var nodeName = e.target.nodeName.toLowerCase();" +
|
|
||||||
" var isInputButton = nodeName === 'input' && e.target.type != null && e.target.type === 'button';" +
|
|
||||||
" isFocusin = (['a', 'area', 'button', 'details', 'iframe', 'select', 'summary'].indexOf(nodeName) >= 0 || isInputButton) ? false : true;" +
|
|
||||||
" });" +
|
|
||||||
" document.addEventListener('focusout', function(e) {" +
|
|
||||||
" isFocusin = false;" +
|
|
||||||
" setTimeout(function() {" +
|
|
||||||
isActiveElementInputEditableJS +
|
|
||||||
" if (!isFocusin && !isActiveElementEditable) {" +
|
|
||||||
" window." + JavaScriptBridgeInterface.name + ".callHandler('androidKeyboardWorkaroundFocusoutEvent');" +
|
|
||||||
" }" +
|
|
||||||
" }, 300);" +
|
|
||||||
" });" +
|
|
||||||
"})();";
|
|
||||||
|
|
||||||
public InAppWebView(Context context) {
|
public InAppWebView(Context context) {
|
||||||
super(context);
|
super(context);
|
||||||
}
|
}
|
||||||
|
@ -705,8 +689,9 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
settings.setUseWideViewPort(options.useWideViewPort);
|
settings.setUseWideViewPort(options.useWideViewPort);
|
||||||
settings.setSupportZoom(options.supportZoom);
|
settings.setSupportZoom(options.supportZoom);
|
||||||
settings.setTextZoom(options.textZoom);
|
settings.setTextZoom(options.textZoom);
|
||||||
setVerticalScrollBarEnabled(options.verticalScrollBarEnabled);
|
|
||||||
setHorizontalScrollBarEnabled(options.horizontalScrollBarEnabled);
|
setVerticalScrollBarEnabled(!options.disableVerticalScroll && options.verticalScrollBarEnabled);
|
||||||
|
setHorizontalScrollBarEnabled(!options.disableHorizontalScroll && options.horizontalScrollBarEnabled);
|
||||||
|
|
||||||
if (options.transparentBackground)
|
if (options.transparentBackground)
|
||||||
setBackgroundColor(Color.TRANSPARENT);
|
setBackgroundColor(Color.TRANSPARENT);
|
||||||
|
@ -780,8 +765,6 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
options.scrollBarFadeDuration = getScrollBarFadeDuration();
|
options.scrollBarFadeDuration = getScrollBarFadeDuration();
|
||||||
}
|
}
|
||||||
setVerticalScrollbarPosition(options.verticalScrollbarPosition);
|
setVerticalScrollbarPosition(options.verticalScrollbarPosition);
|
||||||
setVerticalScrollBarEnabled(!options.disableVerticalScroll);
|
|
||||||
setHorizontalScrollBarEnabled(!options.disableHorizontalScroll);
|
|
||||||
setOverScrollMode(options.overScrollMode);
|
setOverScrollMode(options.overScrollMode);
|
||||||
if (options.networkAvailable != null) {
|
if (options.networkAvailable != null) {
|
||||||
setNetworkAvailable(options.networkAvailable);
|
setNetworkAvailable(options.networkAvailable);
|
||||||
|
@ -1065,9 +1048,10 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
headlessHandler.post(new Runnable() {
|
headlessHandler.post(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
|
try {
|
||||||
int height = (int) (getContentHeight() * scale + 0.5);
|
int height = (int) (getContentHeight() * scale + 0.5);
|
||||||
|
|
||||||
Bitmap b = Bitmap.createBitmap( getWidth(),
|
Bitmap b = Bitmap.createBitmap(getWidth(),
|
||||||
height, Bitmap.Config.ARGB_8888);
|
height, Bitmap.Config.ARGB_8888);
|
||||||
Canvas c = new Canvas(b);
|
Canvas c = new Canvas(b);
|
||||||
|
|
||||||
|
@ -1084,10 +1068,21 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
byteArrayOutputStream.close();
|
byteArrayOutputStream.close();
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
Log.e(LOG_TAG, e.getMessage());
|
String errorMessage = e.getMessage();
|
||||||
|
if (errorMessage != null) {
|
||||||
|
Log.e(LOG_TAG, errorMessage);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
resized.recycle();
|
resized.recycle();
|
||||||
result.success(byteArrayOutputStream.toByteArray());
|
result.success(byteArrayOutputStream.toByteArray());
|
||||||
|
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
String errorMessage = e.getMessage();
|
||||||
|
if (errorMessage != null) {
|
||||||
|
Log.e(LOG_TAG, errorMessage);
|
||||||
|
}
|
||||||
|
result.success(null);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -1367,10 +1362,10 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
setVerticalScrollbarPosition(newOptions.verticalScrollbarPosition);
|
setVerticalScrollbarPosition(newOptions.verticalScrollbarPosition);
|
||||||
|
|
||||||
if (newOptionsMap.get("disableVerticalScroll") != null && options.disableVerticalScroll != newOptions.disableVerticalScroll)
|
if (newOptionsMap.get("disableVerticalScroll") != null && options.disableVerticalScroll != newOptions.disableVerticalScroll)
|
||||||
setVerticalScrollBarEnabled(!newOptions.disableVerticalScroll);
|
setVerticalScrollBarEnabled(!newOptions.disableVerticalScroll && newOptions.verticalScrollBarEnabled);
|
||||||
|
|
||||||
if (newOptionsMap.get("disableHorizontalScroll") != null && options.disableHorizontalScroll != newOptions.disableHorizontalScroll)
|
if (newOptionsMap.get("disableHorizontalScroll") != null && options.disableHorizontalScroll != newOptions.disableHorizontalScroll)
|
||||||
setHorizontalScrollBarEnabled(!newOptions.disableHorizontalScroll);
|
setHorizontalScrollBarEnabled(!newOptions.disableHorizontalScroll && newOptions.horizontalScrollBarEnabled);
|
||||||
|
|
||||||
if (newOptionsMap.get("overScrollMode") != null && !options.overScrollMode.equals(newOptions.overScrollMode))
|
if (newOptionsMap.get("overScrollMode") != null && !options.overScrollMode.equals(newOptions.overScrollMode))
|
||||||
setOverScrollMode(newOptions.overScrollMode);
|
setOverScrollMode(newOptions.overScrollMode);
|
||||||
|
@ -1600,6 +1595,31 @@ final public class InAppWebView extends InputAwareWebView {
|
||||||
return super.dispatchTouchEvent(event);
|
return super.dispatchTouchEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public InputConnection onCreateInputConnection(EditorInfo outAttrs) {
|
||||||
|
InputConnection connection = super.onCreateInputConnection(outAttrs);
|
||||||
|
if (connection == null && containerView != null) {
|
||||||
|
// workaround to hide the Keyboard when the user click outside
|
||||||
|
// on something not focusable such as input or a textarea.
|
||||||
|
containerView
|
||||||
|
.getHandler()
|
||||||
|
.postDelayed(
|
||||||
|
new Runnable() {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
InputMethodManager imm =
|
||||||
|
(InputMethodManager) getContext().getSystemService(INPUT_METHOD_SERVICE);
|
||||||
|
if (imm != null && !imm.isAcceptingText()) {
|
||||||
|
imm.hideSoftInputFromWindow(
|
||||||
|
containerView.getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
128);
|
||||||
|
}
|
||||||
|
return connection;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ActionMode startActionMode(ActionMode.Callback callback) {
|
public ActionMode startActionMode(ActionMode.Callback callback) {
|
||||||
return rebuildActionMode(super.startActionMode(callback), callback);
|
return rebuildActionMode(super.startActionMode(callback), callback);
|
||||||
|
|
|
@ -185,9 +185,6 @@ public class InAppWebViewClient extends WebViewClient {
|
||||||
js += InAppWebView.resourceObserverJS.replaceAll("[\r\n]+", "");
|
js += InAppWebView.resourceObserverJS.replaceAll("[\r\n]+", "");
|
||||||
}
|
}
|
||||||
js += InAppWebView.checkGlobalKeyDownEventToHideContextMenuJS.replaceAll("[\r\n]+", "");
|
js += InAppWebView.checkGlobalKeyDownEventToHideContextMenuJS.replaceAll("[\r\n]+", "");
|
||||||
if (flutterWebView != null) {
|
|
||||||
js += InAppWebView.androidKeyboardWorkaroundFocusoutEventJS.replaceAll("[\r\n]+", "");
|
|
||||||
}
|
|
||||||
js += InAppWebView.printJS.replaceAll("[\r\n]+", "");
|
js += InAppWebView.printJS.replaceAll("[\r\n]+", "");
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
{"info":"This is a generated file; do not edit or check into version control.","plugins":{"ios":[{"name":"e2e","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/e2e-0.2.4+4/","dependencies":[]},{"name":"flutter_downloader","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/flutter_downloader-1.4.4/","dependencies":[]},{"name":"flutter_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","dependencies":[]},{"name":"path_provider","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/path_provider-1.6.9/","dependencies":[]},{"name":"permission_handler","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/permission_handler-5.0.0+hotfix.6/","dependencies":[]}],"android":[{"name":"e2e","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/e2e-0.2.4+4/","dependencies":[]},{"name":"flutter_downloader","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/flutter_downloader-1.4.4/","dependencies":[]},{"name":"flutter_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","dependencies":[]},{"name":"path_provider","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/path_provider-1.6.9/","dependencies":[]},{"name":"permission_handler","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/permission_handler-5.0.0+hotfix.6/","dependencies":[]}],"macos":[{"name":"path_provider_macos","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/path_provider_macos-0.0.4+3/","dependencies":[]}],"linux":[],"windows":[],"web":[]},"dependencyGraph":[{"name":"e2e","dependencies":[]},{"name":"flutter_downloader","dependencies":[]},{"name":"flutter_inappwebview","dependencies":[]},{"name":"path_provider","dependencies":["path_provider_macos"]},{"name":"path_provider_macos","dependencies":[]},{"name":"permission_handler","dependencies":[]}],"date_created":"2020-06-14 18:36:37.641339","version":"1.17.1"}
|
{"info":"This is a generated file; do not edit or check into version control.","plugins":{"ios":[{"name":"e2e","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/e2e-0.2.4+4/","dependencies":[]},{"name":"flutter_downloader","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/flutter_downloader-1.4.4/","dependencies":[]},{"name":"flutter_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","dependencies":[]},{"name":"path_provider","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/path_provider-1.6.10/","dependencies":[]},{"name":"permission_handler","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/permission_handler-5.0.1/","dependencies":[]}],"android":[{"name":"e2e","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/e2e-0.2.4+4/","dependencies":[]},{"name":"flutter_downloader","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/flutter_downloader-1.4.4/","dependencies":[]},{"name":"flutter_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","dependencies":[]},{"name":"path_provider","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/path_provider-1.6.10/","dependencies":[]},{"name":"permission_handler","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/permission_handler-5.0.1/","dependencies":[]}],"macos":[{"name":"path_provider_macos","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/path_provider_macos-0.0.4+3/","dependencies":[]}],"linux":[{"name":"path_provider_linux","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/path_provider_linux-0.0.1+1/","dependencies":[]}],"windows":[],"web":[]},"dependencyGraph":[{"name":"e2e","dependencies":[]},{"name":"flutter_downloader","dependencies":[]},{"name":"flutter_inappwebview","dependencies":[]},{"name":"path_provider","dependencies":["path_provider_macos","path_provider_linux"]},{"name":"path_provider_linux","dependencies":[]},{"name":"path_provider_macos","dependencies":[]},{"name":"permission_handler","dependencies":[]}],"date_created":"2020-06-18 15:48:06.962625","version":"1.17.3"}
|
|
@ -24,7 +24,6 @@
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
<main role="main" class="inner cover">
|
<main role="main" class="inner cover">
|
||||||
<input type="text">
|
|
||||||
<h1 class="cover-heading">Inline WebView</h1>
|
<h1 class="cover-heading">Inline WebView</h1>
|
||||||
<img src="images/flutter-logo.svg" alt="flutter logo">
|
<img src="images/flutter-logo.svg" alt="flutter logo">
|
||||||
<a href="index.html"><img src="images/flutter-logo.svg" alt="flutter logo"></a>
|
<a href="index.html"><img src="images/flutter-logo.svg" alt="flutter logo"></a>
|
||||||
|
|
|
@ -2,11 +2,10 @@
|
||||||
# This is a generated file; do not edit or check into version control.
|
# This is a generated file; do not edit or check into version control.
|
||||||
export "FLUTTER_ROOT=/Users/lorenzopichilli/flutter"
|
export "FLUTTER_ROOT=/Users/lorenzopichilli/flutter"
|
||||||
export "FLUTTER_APPLICATION_PATH=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example"
|
export "FLUTTER_APPLICATION_PATH=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example"
|
||||||
export "FLUTTER_TARGET=/Users/lorenzopichilli/Desktop/flutter_inappwebview/example/lib/main.dart"
|
export "FLUTTER_TARGET=lib/main.dart"
|
||||||
export "FLUTTER_BUILD_DIR=build"
|
export "FLUTTER_BUILD_DIR=build"
|
||||||
export "SYMROOT=${SOURCE_ROOT}/../build/ios"
|
export "SYMROOT=${SOURCE_ROOT}/../build/ios"
|
||||||
export "OTHER_LDFLAGS=$(inherited) -framework Flutter"
|
export "OTHER_LDFLAGS=$(inherited) -framework Flutter"
|
||||||
export "FLUTTER_FRAMEWORK_DIR=/Users/lorenzopichilli/flutter/bin/cache/artifacts/engine/ios"
|
export "FLUTTER_FRAMEWORK_DIR=/Users/lorenzopichilli/flutter/bin/cache/artifacts/engine/ios"
|
||||||
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 "TRACK_WIDGET_CREATION=true"
|
|
||||||
|
|
|
@ -26,25 +26,25 @@ class _InAppWebViewExampleScreenState extends State<InAppWebViewExampleScreen> {
|
||||||
contextMenu = ContextMenu(
|
contextMenu = ContextMenu(
|
||||||
menuItems: [
|
menuItems: [
|
||||||
ContextMenuItem(androidId: 1, iosId: "1", title: "Special", action: () async {
|
ContextMenuItem(androidId: 1, iosId: "1", title: "Special", action: () async {
|
||||||
print("Menu item Special clicked!");
|
//print("Menu item Special clicked!");
|
||||||
print(await webView.getSelectedText());
|
print(await webView.getSelectedText());
|
||||||
await webView.clearFocus();
|
await webView.clearFocus();
|
||||||
})
|
})
|
||||||
],
|
],
|
||||||
options: ContextMenuOptions(
|
options: ContextMenuOptions(
|
||||||
hideDefaultSystemContextMenuItems: true
|
hideDefaultSystemContextMenuItems: false
|
||||||
),
|
),
|
||||||
onCreateContextMenu: (hitTestResult) async {
|
onCreateContextMenu: (hitTestResult) async {
|
||||||
print("onCreateContextMenu");
|
//print("onCreateContextMenu");
|
||||||
print(hitTestResult.extra);
|
print(hitTestResult.extra);
|
||||||
print(await webView.getSelectedText());
|
print(await webView.getSelectedText());
|
||||||
},
|
},
|
||||||
onHideContextMenu: () {
|
onHideContextMenu: () {
|
||||||
print("onHideContextMenu");
|
//print("onHideContextMenu");
|
||||||
},
|
},
|
||||||
onContextMenuActionItemClicked: (contextMenuItemClicked) async {
|
onContextMenuActionItemClicked: (contextMenuItemClicked) async {
|
||||||
var id = (Platform.isAndroid) ? contextMenuItemClicked.androidId : contextMenuItemClicked.iosId;
|
var id = (Platform.isAndroid) ? contextMenuItemClicked.androidId : contextMenuItemClicked.iosId;
|
||||||
print("onContextMenuActionItemClicked: " + id.toString() + " " + contextMenuItemClicked.title);
|
// print("onContextMenuActionItemClicked: " + id.toString() + " " + contextMenuItemClicked.title);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -80,8 +80,8 @@ class _InAppWebViewExampleScreenState extends State<InAppWebViewExampleScreen> {
|
||||||
BoxDecoration(border: Border.all(color: Colors.blueAccent)),
|
BoxDecoration(border: Border.all(color: Colors.blueAccent)),
|
||||||
child: InAppWebView(
|
child: InAppWebView(
|
||||||
contextMenu: contextMenu,
|
contextMenu: contextMenu,
|
||||||
initialUrl: "https://github.com/flutter",
|
// initialUrl: "https://github.com/flutter",
|
||||||
// initialFile: "assets/index.html",
|
initialFile: "assets/index.html",
|
||||||
initialHeaders: {},
|
initialHeaders: {},
|
||||||
initialOptions: InAppWebViewGroupOptions(
|
initialOptions: InAppWebViewGroupOptions(
|
||||||
crossPlatform: InAppWebViewOptions(
|
crossPlatform: InAppWebViewOptions(
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
<excludeFolder url="file://$MODULE_DIR$/example/ios/.symlinks/plugins/flutter_inappwebview/example/.pub" />
|
<excludeFolder url="file://$MODULE_DIR$/example/ios/.symlinks/plugins/flutter_inappwebview/example/.pub" />
|
||||||
<excludeFolder url="file://$MODULE_DIR$/example/ios/.symlinks/plugins/flutter_inappwebview/example/build" />
|
<excludeFolder url="file://$MODULE_DIR$/example/ios/.symlinks/plugins/flutter_inappwebview/example/build" />
|
||||||
<excludeFolder url="file://$MODULE_DIR$/example/ios/.symlinks/plugins/flutter_inappwebview/example/ios/Flutter/App.framework/flutter_assets/packages" />
|
<excludeFolder url="file://$MODULE_DIR$/example/ios/.symlinks/plugins/flutter_inappwebview/example/ios/Flutter/App.framework/flutter_assets/packages" />
|
||||||
|
<excludeFolder url="file://$MODULE_DIR$/example/ios/Flutter/App.framework/flutter_assets/packages" />
|
||||||
<excludeFolder url="file://$MODULE_DIR$/flutter_inappbrowser_tests/.dart_tool" />
|
<excludeFolder url="file://$MODULE_DIR$/flutter_inappbrowser_tests/.dart_tool" />
|
||||||
<excludeFolder url="file://$MODULE_DIR$/flutter_inappbrowser_tests/.pub" />
|
<excludeFolder url="file://$MODULE_DIR$/flutter_inappbrowser_tests/.pub" />
|
||||||
<excludeFolder url="file://$MODULE_DIR$/flutter_inappbrowser_tests/build" />
|
<excludeFolder url="file://$MODULE_DIR$/flutter_inappbrowser_tests/build" />
|
||||||
|
|
|
@ -320,7 +320,7 @@ let interceptAjaxRequestsJS = """
|
||||||
};
|
};
|
||||||
function handleEvent(e) {
|
function handleEvent(e) {
|
||||||
var self = this;
|
var self = this;
|
||||||
if (window.\(variableForShouldInterceptAjaxRequestJS) == null || window.\(variableForShouldInterceptAjaxRequestJS) == true) {
|
if (\(variableForShouldInterceptAjaxRequestJS) == null || \(variableForShouldInterceptAjaxRequestJS) == true) {
|
||||||
var headers = this.getAllResponseHeaders();
|
var headers = this.getAllResponseHeaders();
|
||||||
var responseHeaders = {};
|
var responseHeaders = {};
|
||||||
if (headers != null) {
|
if (headers != null) {
|
||||||
|
@ -371,12 +371,12 @@ let interceptAjaxRequestsJS = """
|
||||||
};
|
};
|
||||||
ajax.prototype.send = function(data) {
|
ajax.prototype.send = function(data) {
|
||||||
var self = this;
|
var self = this;
|
||||||
if (window.\(variableForShouldInterceptAjaxRequestJS) == null || window.\(variableForShouldInterceptAjaxRequestJS) == true) {
|
if (\(variableForShouldInterceptAjaxRequestJS) == null || \(variableForShouldInterceptAjaxRequestJS) == true) {
|
||||||
if (!this._flutter_inappwebview_already_onreadystatechange_wrapped) {
|
if (!this._flutter_inappwebview_already_onreadystatechange_wrapped) {
|
||||||
this._flutter_inappwebview_already_onreadystatechange_wrapped = true;
|
this._flutter_inappwebview_already_onreadystatechange_wrapped = true;
|
||||||
var onreadystatechange = this.onreadystatechange;
|
var onreadystatechange = this.onreadystatechange;
|
||||||
this.onreadystatechange = function() {
|
this.onreadystatechange = function() {
|
||||||
if (window.\(variableForShouldInterceptAjaxRequestJS) == null || window.\(variableForShouldInterceptAjaxRequestJS) == true) {
|
if (\(variableForShouldInterceptAjaxRequestJS) == null || \(variableForShouldInterceptAjaxRequestJS) == true) {
|
||||||
var headers = this.getAllResponseHeaders();
|
var headers = this.getAllResponseHeaders();
|
||||||
var responseHeaders = {};
|
var responseHeaders = {};
|
||||||
if (headers != null) {
|
if (headers != null) {
|
||||||
|
@ -1029,14 +1029,15 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
configuration.userContentController = WKUserContentController()
|
configuration.userContentController = WKUserContentController()
|
||||||
configuration.preferences = WKPreferences()
|
configuration.preferences = WKPreferences()
|
||||||
|
|
||||||
if (options?.transparentBackground)! {
|
if let options = options {
|
||||||
|
if options.transparentBackground {
|
||||||
isOpaque = false
|
isOpaque = false
|
||||||
backgroundColor = UIColor.clear
|
backgroundColor = UIColor.clear
|
||||||
scrollView.backgroundColor = UIColor.clear
|
scrollView.backgroundColor = UIColor.clear
|
||||||
}
|
}
|
||||||
|
|
||||||
// prevent webView from bouncing
|
// prevent webView from bouncing
|
||||||
if (options?.disallowOverScroll)! {
|
if options.disallowOverScroll {
|
||||||
if responds(to: #selector(getter: scrollView)) {
|
if responds(to: #selector(getter: scrollView)) {
|
||||||
scrollView.bounces = false
|
scrollView.bounces = false
|
||||||
}
|
}
|
||||||
|
@ -1052,11 +1053,11 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
let originalViewPortMetaTagContentJSScript = WKUserScript(source: originalViewPortMetaTagContentJS, injectionTime: .atDocumentEnd, forMainFrameOnly: true)
|
let originalViewPortMetaTagContentJSScript = WKUserScript(source: originalViewPortMetaTagContentJS, injectionTime: .atDocumentEnd, forMainFrameOnly: true)
|
||||||
configuration.userContentController.addUserScript(originalViewPortMetaTagContentJSScript)
|
configuration.userContentController.addUserScript(originalViewPortMetaTagContentJSScript)
|
||||||
|
|
||||||
if !(options?.supportZoom)! {
|
if !options.supportZoom {
|
||||||
let jscript = "var meta = document.createElement('meta'); meta.setAttribute('name', 'viewport'); meta.setAttribute('content', 'width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no'); document.getElementsByTagName('head')[0].appendChild(meta);"
|
let jscript = "var meta = document.createElement('meta'); meta.setAttribute('name', 'viewport'); meta.setAttribute('content', 'width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no'); document.getElementsByTagName('head')[0].appendChild(meta);"
|
||||||
let userScript = WKUserScript(source: jscript, injectionTime: .atDocumentEnd, forMainFrameOnly: true)
|
let userScript = WKUserScript(source: jscript, injectionTime: .atDocumentEnd, forMainFrameOnly: true)
|
||||||
configuration.userContentController.addUserScript(userScript)
|
configuration.userContentController.addUserScript(userScript)
|
||||||
} else if (options?.enableViewportScale)! {
|
} else if options.enableViewportScale {
|
||||||
let jscript = "var meta = document.createElement('meta'); meta.setAttribute('name', 'viewport'); meta.setAttribute('content', 'width=device-width'); document.getElementsByTagName('head')[0].appendChild(meta);"
|
let jscript = "var meta = document.createElement('meta'); meta.setAttribute('name', 'viewport'); meta.setAttribute('content', 'width=device-width'); document.getElementsByTagName('head')[0].appendChild(meta);"
|
||||||
let userScript = WKUserScript(source: jscript, injectionTime: .atDocumentEnd, forMainFrameOnly: true)
|
let userScript = WKUserScript(source: jscript, injectionTime: .atDocumentEnd, forMainFrameOnly: true)
|
||||||
configuration.userContentController.addUserScript(userScript)
|
configuration.userContentController.addUserScript(userScript)
|
||||||
|
@ -1086,7 +1087,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
let lastTouchedAnchorOrImageJSScript = WKUserScript(source: lastTouchedAnchorOrImageJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
let lastTouchedAnchorOrImageJSScript = WKUserScript(source: lastTouchedAnchorOrImageJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
||||||
configuration.userContentController.addUserScript(lastTouchedAnchorOrImageJSScript)
|
configuration.userContentController.addUserScript(lastTouchedAnchorOrImageJSScript)
|
||||||
|
|
||||||
if (options?.useOnLoadResource)! {
|
if options.useOnLoadResource {
|
||||||
let resourceObserverJSScript = WKUserScript(source: resourceObserverJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
let resourceObserverJSScript = WKUserScript(source: resourceObserverJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
||||||
configuration.userContentController.addUserScript(resourceObserverJSScript)
|
configuration.userContentController.addUserScript(resourceObserverJSScript)
|
||||||
}
|
}
|
||||||
|
@ -1095,79 +1096,65 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
configuration.userContentController.addUserScript(findTextHighlightJSScript)
|
configuration.userContentController.addUserScript(findTextHighlightJSScript)
|
||||||
configuration.userContentController.add(self, name: "onFindResultReceived")
|
configuration.userContentController.add(self, name: "onFindResultReceived")
|
||||||
|
|
||||||
if (options?.useShouldInterceptAjaxRequest)! {
|
if options.useShouldInterceptAjaxRequest {
|
||||||
let interceptAjaxRequestsJSScript = WKUserScript(source: interceptAjaxRequestsJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
let interceptAjaxRequestsJSScript = WKUserScript(source: interceptAjaxRequestsJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
||||||
configuration.userContentController.addUserScript(interceptAjaxRequestsJSScript)
|
configuration.userContentController.addUserScript(interceptAjaxRequestsJSScript)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (options?.useShouldInterceptFetchRequest)! {
|
if options.useShouldInterceptFetchRequest {
|
||||||
let interceptFetchRequestsJSScript = WKUserScript(source: interceptFetchRequestsJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
let interceptFetchRequestsJSScript = WKUserScript(source: interceptFetchRequestsJS, injectionTime: .atDocumentStart, forMainFrameOnly: false)
|
||||||
configuration.userContentController.addUserScript(interceptFetchRequestsJSScript)
|
configuration.userContentController.addUserScript(interceptFetchRequestsJSScript)
|
||||||
}
|
}
|
||||||
|
|
||||||
if #available(iOS 11.0, *) {
|
if #available(iOS 11.0, *) {
|
||||||
accessibilityIgnoresInvertColors = (options?.accessibilityIgnoresInvertColors)!
|
accessibilityIgnoresInvertColors = options.accessibilityIgnoresInvertColors
|
||||||
scrollView.contentInsetAdjustmentBehavior =
|
scrollView.contentInsetAdjustmentBehavior =
|
||||||
UIScrollView.ContentInsetAdjustmentBehavior.init(rawValue: (options?.contentInsetAdjustmentBehavior)!)!
|
UIScrollView.ContentInsetAdjustmentBehavior.init(rawValue: options.contentInsetAdjustmentBehavior)!
|
||||||
}
|
}
|
||||||
|
|
||||||
configuration.suppressesIncrementalRendering = (options?.suppressesIncrementalRendering)!
|
allowsBackForwardNavigationGestures = options.allowsBackForwardNavigationGestures
|
||||||
allowsBackForwardNavigationGestures = (options?.allowsBackForwardNavigationGestures)!
|
|
||||||
if #available(iOS 9.0, *) {
|
if #available(iOS 9.0, *) {
|
||||||
allowsLinkPreview = (options?.allowsLinkPreview)!
|
allowsLinkPreview = options.allowsLinkPreview
|
||||||
configuration.allowsAirPlayForMediaPlayback = (options?.allowsAirPlayForMediaPlayback)!
|
configuration.allowsAirPlayForMediaPlayback = options.allowsAirPlayForMediaPlayback
|
||||||
configuration.allowsPictureInPictureMediaPlayback = (options?.allowsPictureInPictureMediaPlayback)!
|
configuration.allowsPictureInPictureMediaPlayback = options.allowsPictureInPictureMediaPlayback
|
||||||
if (options?.applicationNameForUserAgent != nil && (options?.applicationNameForUserAgent)! != "") {
|
if !options.applicationNameForUserAgent.isEmpty {
|
||||||
configuration.applicationNameForUserAgent = (options?.applicationNameForUserAgent)!
|
configuration.applicationNameForUserAgent = options.applicationNameForUserAgent
|
||||||
}
|
}
|
||||||
if (options?.userAgent != nil && (options?.userAgent)! != "") {
|
if !options.userAgent.isEmpty {
|
||||||
customUserAgent = (options?.userAgent)!
|
customUserAgent = options.userAgent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
configuration.preferences.javaScriptCanOpenWindowsAutomatically = (options?.javaScriptCanOpenWindowsAutomatically)!
|
configuration.preferences.javaScriptCanOpenWindowsAutomatically = options.javaScriptCanOpenWindowsAutomatically
|
||||||
configuration.preferences.javaScriptEnabled = (options?.javaScriptEnabled)!
|
configuration.preferences.javaScriptEnabled = options.javaScriptEnabled
|
||||||
configuration.preferences.minimumFontSize = CGFloat((options?.minimumFontSize)!)
|
configuration.preferences.minimumFontSize = CGFloat(options.minimumFontSize)
|
||||||
configuration.selectionGranularity = WKSelectionGranularity.init(rawValue: (options?.selectionGranularity)!)!
|
|
||||||
|
|
||||||
if #available(iOS 10.0, *) {
|
|
||||||
configuration.ignoresViewportScaleLimits = (options?.ignoresViewportScaleLimits)!
|
|
||||||
|
|
||||||
var dataDetectorTypes = WKDataDetectorTypes.init(rawValue: 0)
|
|
||||||
for type in options?.dataDetectorTypes ?? [] {
|
|
||||||
let dataDetectorType = InAppWebView.getDataDetectorType(type: type)
|
|
||||||
dataDetectorTypes = WKDataDetectorTypes(rawValue: dataDetectorTypes.rawValue | dataDetectorType.rawValue)
|
|
||||||
}
|
|
||||||
configuration.dataDetectorTypes = dataDetectorTypes
|
|
||||||
}
|
|
||||||
|
|
||||||
if #available(iOS 13.0, *) {
|
if #available(iOS 13.0, *) {
|
||||||
configuration.preferences.isFraudulentWebsiteWarningEnabled = (options?.isFraudulentWebsiteWarningEnabled)!
|
configuration.preferences.isFraudulentWebsiteWarningEnabled = options.isFraudulentWebsiteWarningEnabled
|
||||||
if options?.preferredContentMode != nil {
|
configuration.defaultWebpagePreferences.preferredContentMode = WKWebpagePreferences.ContentMode(rawValue: options.preferredContentMode)!
|
||||||
configuration.defaultWebpagePreferences.preferredContentMode = WKWebpagePreferences.ContentMode(rawValue: (options?.preferredContentMode)!)!
|
scrollView.automaticallyAdjustsScrollIndicatorInsets = options.automaticallyAdjustsScrollIndicatorInsets
|
||||||
}
|
|
||||||
scrollView.automaticallyAdjustsScrollIndicatorInsets = (options?.automaticallyAdjustsScrollIndicatorInsets)!
|
|
||||||
}
|
}
|
||||||
|
|
||||||
scrollView.showsVerticalScrollIndicator = !(options?.disableVerticalScroll)!
|
scrollView.showsVerticalScrollIndicator = !options.disableVerticalScroll
|
||||||
scrollView.showsHorizontalScrollIndicator = !(options?.disableHorizontalScroll)!
|
scrollView.showsHorizontalScrollIndicator = !options.disableHorizontalScroll
|
||||||
scrollView.showsVerticalScrollIndicator = (options?.verticalScrollBarEnabled)!
|
scrollView.showsVerticalScrollIndicator = options.verticalScrollBarEnabled
|
||||||
scrollView.showsHorizontalScrollIndicator = (options?.horizontalScrollBarEnabled)!
|
scrollView.showsHorizontalScrollIndicator = options.horizontalScrollBarEnabled
|
||||||
|
|
||||||
scrollView.decelerationRate = InAppWebView.getDecelerationRate(type: (options?.decelerationRate)!)
|
scrollView.decelerationRate = InAppWebView.getDecelerationRate(type: options.decelerationRate)
|
||||||
scrollView.alwaysBounceVertical = (options?.alwaysBounceVertical)!
|
scrollView.alwaysBounceVertical = options.alwaysBounceVertical
|
||||||
scrollView.alwaysBounceHorizontal = (options?.alwaysBounceHorizontal)!
|
scrollView.alwaysBounceHorizontal = options.alwaysBounceHorizontal
|
||||||
scrollView.scrollsToTop = (options?.scrollsToTop)!
|
scrollView.scrollsToTop = options.scrollsToTop
|
||||||
scrollView.isPagingEnabled = (options?.isPagingEnabled)!
|
scrollView.isPagingEnabled = options.isPagingEnabled
|
||||||
scrollView.maximumZoomScale = CGFloat((options?.maximumZoomScale)!)
|
scrollView.maximumZoomScale = CGFloat(options.maximumZoomScale)
|
||||||
scrollView.minimumZoomScale = CGFloat((options?.minimumZoomScale)!)
|
scrollView.minimumZoomScale = CGFloat(options.minimumZoomScale)
|
||||||
|
|
||||||
// options.debuggingEnabled is always enabled for iOS.
|
// options.debuggingEnabled is always enabled for iOS.
|
||||||
|
|
||||||
if (options?.clearCache)! {
|
if options.clearCache {
|
||||||
clearCache()
|
clearCache()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@available(iOS 10.0, *)
|
@available(iOS 10.0, *)
|
||||||
static public func getDataDetectorType(type: String) -> WKDataDetectorTypes {
|
static public func getDataDetectorType(type: String) -> WKDataDetectorTypes {
|
||||||
|
@ -1261,39 +1248,46 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
|
|
||||||
configuration.processPool = WKProcessPoolManager.sharedProcessPool
|
configuration.processPool = WKProcessPoolManager.sharedProcessPool
|
||||||
|
|
||||||
if #available(iOS 10.0, *) {
|
if let options = options {
|
||||||
configuration.mediaTypesRequiringUserActionForPlayback = ((options?.mediaPlaybackRequiresUserGesture)!) ? .all : []
|
configuration.allowsInlineMediaPlayback = options.allowsInlineMediaPlayback
|
||||||
} else {
|
configuration.suppressesIncrementalRendering = options.suppressesIncrementalRendering
|
||||||
// Fallback on earlier versions
|
configuration.selectionGranularity = WKSelectionGranularity.init(rawValue: options.selectionGranularity)!
|
||||||
configuration.mediaPlaybackRequiresUserAction = (options?.mediaPlaybackRequiresUserGesture)!
|
|
||||||
}
|
|
||||||
|
|
||||||
configuration.allowsInlineMediaPlayback = (options?.allowsInlineMediaPlayback)!
|
|
||||||
|
|
||||||
if #available(iOS 11.0, *) {
|
|
||||||
if let schemes = options?.resourceCustomSchemes {
|
|
||||||
for scheme in schemes {
|
|
||||||
configuration.setURLSchemeHandler(CustomeSchemeHandler(), forURLScheme: scheme)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if #available(iOS 9.0, *) {
|
if #available(iOS 9.0, *) {
|
||||||
if ((options?.incognito)!) {
|
if options.incognito {
|
||||||
configuration.websiteDataStore = WKWebsiteDataStore.nonPersistent()
|
configuration.websiteDataStore = WKWebsiteDataStore.nonPersistent()
|
||||||
} else if ((options?.cacheEnabled)!) {
|
} else if options.cacheEnabled {
|
||||||
configuration.websiteDataStore = WKWebsiteDataStore.default()
|
configuration.websiteDataStore = WKWebsiteDataStore.default()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if #available(iOS 10.0, *) {
|
||||||
|
configuration.ignoresViewportScaleLimits = options.ignoresViewportScaleLimits
|
||||||
|
|
||||||
|
var dataDetectorTypes = WKDataDetectorTypes.init(rawValue: 0)
|
||||||
|
for type in options.dataDetectorTypes {
|
||||||
|
let dataDetectorType = InAppWebView.getDataDetectorType(type: type)
|
||||||
|
dataDetectorTypes = WKDataDetectorTypes(rawValue: dataDetectorTypes.rawValue | dataDetectorType.rawValue)
|
||||||
|
}
|
||||||
|
configuration.dataDetectorTypes = dataDetectorTypes
|
||||||
|
|
||||||
|
configuration.mediaTypesRequiringUserActionForPlayback = options.mediaPlaybackRequiresUserGesture ? .all : []
|
||||||
|
} else {
|
||||||
|
// Fallback on earlier versions
|
||||||
|
configuration.mediaPlaybackRequiresUserAction = options.mediaPlaybackRequiresUserGesture
|
||||||
|
}
|
||||||
|
|
||||||
if #available(iOS 11.0, *) {
|
if #available(iOS 11.0, *) {
|
||||||
if((options?.sharedCookiesEnabled)!) {
|
for scheme in options.resourceCustomSchemes {
|
||||||
|
configuration.setURLSchemeHandler(CustomeSchemeHandler(), forURLScheme: scheme)
|
||||||
|
}
|
||||||
|
if options.sharedCookiesEnabled {
|
||||||
// More info to sending cookies with WKWebView
|
// More info to sending cookies with WKWebView
|
||||||
// https://stackoverflow.com/questions/26573137/can-i-set-the-cookies-to-be-used-by-a-wkwebview/26577303#26577303
|
// https://stackoverflow.com/questions/26573137/can-i-set-the-cookies-to-be-used-by-a-wkwebview/26577303#26577303
|
||||||
// Set Cookies in iOS 11 and above, initialize websiteDataStore before setting cookies
|
// Set Cookies in iOS 11 and above, initialize websiteDataStore before setting cookies
|
||||||
// See also https://forums.developer.apple.com/thread/97194
|
// See also https://forums.developer.apple.com/thread/97194
|
||||||
// check if websiteDataStore has not been initialized before
|
// check if websiteDataStore has not been initialized before
|
||||||
if(!(options?.incognito)! && !(options?.cacheEnabled)!) {
|
if(!options.incognito && options.cacheEnabled) {
|
||||||
configuration.websiteDataStore = WKWebsiteDataStore.nonPersistent()
|
configuration.websiteDataStore = WKWebsiteDataStore.nonPersistent()
|
||||||
}
|
}
|
||||||
for cookie in HTTPCookieStorage.shared.cookies ?? [] {
|
for cookie in HTTPCookieStorage.shared.cookies ?? [] {
|
||||||
|
@ -1301,6 +1295,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return configuration
|
return configuration
|
||||||
}
|
}
|
||||||
|
@ -2804,18 +2799,22 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
|
|
||||||
|
|
||||||
public func pauseTimers() {
|
public func pauseTimers() {
|
||||||
|
if !isPausedTimers {
|
||||||
isPausedTimers = true
|
isPausedTimers = true
|
||||||
let script = "alert();";
|
let script = "alert();";
|
||||||
self.evaluateJavaScript(script, completionHandler: nil)
|
self.evaluateJavaScript(script, completionHandler: nil)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public func resumeTimers() {
|
public func resumeTimers() {
|
||||||
|
if isPausedTimers {
|
||||||
if let completionHandler = isPausedTimersCompletionHandler {
|
if let completionHandler = isPausedTimersCompletionHandler {
|
||||||
|
self.isPausedTimersCompletionHandler = nil
|
||||||
completionHandler()
|
completionHandler()
|
||||||
isPausedTimersCompletionHandler = nil
|
|
||||||
}
|
}
|
||||||
isPausedTimers = false
|
isPausedTimers = false
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public func printCurrentPage(printCompletionHandler: ((_ completed: Bool, _ error: Error?) -> Void)?) {
|
public func printCurrentPage(printCompletionHandler: ((_ completed: Bool, _ error: Error?) -> Void)?) {
|
||||||
let printController = UIPrintInteractionController.shared
|
let printController = UIPrintInteractionController.shared
|
||||||
|
@ -2925,6 +2924,10 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
|
||||||
}
|
}
|
||||||
|
|
||||||
public func dispose() {
|
public func dispose() {
|
||||||
|
if isPausedTimers, let completionHandler = isPausedTimersCompletionHandler {
|
||||||
|
isPausedTimersCompletionHandler = nil
|
||||||
|
completionHandler()
|
||||||
|
}
|
||||||
stopLoading()
|
stopLoading()
|
||||||
configuration.userContentController.removeScriptMessageHandler(forName: "consoleLog")
|
configuration.userContentController.removeScriptMessageHandler(forName: "consoleLog")
|
||||||
configuration.userContentController.removeScriptMessageHandler(forName: "consoleDebug")
|
configuration.userContentController.removeScriptMessageHandler(forName: "consoleDebug")
|
||||||
|
|
|
@ -4,7 +4,7 @@ class ASN1DistinguishedNames {
|
||||||
|
|
||||||
const ASN1DistinguishedNames._internal(this._oid, this._representation);
|
const ASN1DistinguishedNames._internal(this._oid, this._representation);
|
||||||
|
|
||||||
static List<ASN1DistinguishedNames> values = [
|
static final Set<ASN1DistinguishedNames> values = [
|
||||||
ASN1DistinguishedNames.COMMON_NAME,
|
ASN1DistinguishedNames.COMMON_NAME,
|
||||||
ASN1DistinguishedNames.DN_QUALIFIER,
|
ASN1DistinguishedNames.DN_QUALIFIER,
|
||||||
ASN1DistinguishedNames.SERIAL_NUMBER,
|
ASN1DistinguishedNames.SERIAL_NUMBER,
|
||||||
|
@ -17,10 +17,12 @@ class ASN1DistinguishedNames {
|
||||||
ASN1DistinguishedNames.STATE_OR_PROVINCE_NAME,
|
ASN1DistinguishedNames.STATE_OR_PROVINCE_NAME,
|
||||||
ASN1DistinguishedNames.COUNTRY_NAME,
|
ASN1DistinguishedNames.COUNTRY_NAME,
|
||||||
ASN1DistinguishedNames.EMAIL,
|
ASN1DistinguishedNames.EMAIL,
|
||||||
];
|
].toSet();
|
||||||
|
|
||||||
static ASN1DistinguishedNames fromValue(String oid) {
|
static ASN1DistinguishedNames fromValue(String oid) {
|
||||||
|
if (oid != null)
|
||||||
return ASN1DistinguishedNames.values.firstWhere((element) => element.oid() == oid, orElse: () => null);
|
return ASN1DistinguishedNames.values.firstWhere((element) => element.oid() == oid, orElse: () => null);
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String oid() => _oid;
|
String oid() => _oid;
|
||||||
|
|
|
@ -3,12 +3,12 @@ class ASN1IdentifierClass {
|
||||||
|
|
||||||
const ASN1IdentifierClass._internal(this._value);
|
const ASN1IdentifierClass._internal(this._value);
|
||||||
|
|
||||||
static List<ASN1IdentifierClass> values = [
|
static final Set<ASN1IdentifierClass> values = [
|
||||||
ASN1IdentifierClass.UNIVERSAL,
|
ASN1IdentifierClass.UNIVERSAL,
|
||||||
ASN1IdentifierClass.APPLICATION,
|
ASN1IdentifierClass.APPLICATION,
|
||||||
ASN1IdentifierClass.CONTEXT_SPECIFIC,
|
ASN1IdentifierClass.CONTEXT_SPECIFIC,
|
||||||
ASN1IdentifierClass.PRIVATE,
|
ASN1IdentifierClass.PRIVATE,
|
||||||
];
|
].toSet();
|
||||||
|
|
||||||
static ASN1IdentifierClass fromValue(int value) {
|
static ASN1IdentifierClass fromValue(int value) {
|
||||||
if (value != null)
|
if (value != null)
|
||||||
|
@ -47,7 +47,7 @@ class ASN1IdentifierTagNumber {
|
||||||
|
|
||||||
const ASN1IdentifierTagNumber._internal(this._value);
|
const ASN1IdentifierTagNumber._internal(this._value);
|
||||||
|
|
||||||
static List<ASN1IdentifierTagNumber> values = [
|
static final Set<ASN1IdentifierTagNumber> values = [
|
||||||
ASN1IdentifierTagNumber.END_OF_CONTENT,
|
ASN1IdentifierTagNumber.END_OF_CONTENT,
|
||||||
ASN1IdentifierTagNumber.BOOLEAN,
|
ASN1IdentifierTagNumber.BOOLEAN,
|
||||||
ASN1IdentifierTagNumber.INTEGER,
|
ASN1IdentifierTagNumber.INTEGER,
|
||||||
|
@ -77,7 +77,7 @@ class ASN1IdentifierTagNumber {
|
||||||
ASN1IdentifierTagNumber.UNIVERSAL_STRING,
|
ASN1IdentifierTagNumber.UNIVERSAL_STRING,
|
||||||
ASN1IdentifierTagNumber.CHARACTER_STRING,
|
ASN1IdentifierTagNumber.CHARACTER_STRING,
|
||||||
ASN1IdentifierTagNumber.BMP_STRING,
|
ASN1IdentifierTagNumber.BMP_STRING,
|
||||||
];
|
].toSet();
|
||||||
|
|
||||||
static ASN1IdentifierTagNumber fromValue(int value) {
|
static ASN1IdentifierTagNumber fromValue(int value) {
|
||||||
if (value != null)
|
if (value != null)
|
||||||
|
|
|
@ -3,7 +3,7 @@ class KeyUsage {
|
||||||
|
|
||||||
const KeyUsage._internal(this._value);
|
const KeyUsage._internal(this._value);
|
||||||
|
|
||||||
static List<KeyUsage> values = [
|
static final Set<KeyUsage> values = [
|
||||||
KeyUsage.digitalSignature,
|
KeyUsage.digitalSignature,
|
||||||
KeyUsage.nonRepudiation,
|
KeyUsage.nonRepudiation,
|
||||||
KeyUsage.keyEncipherment,
|
KeyUsage.keyEncipherment,
|
||||||
|
@ -13,7 +13,7 @@ class KeyUsage {
|
||||||
KeyUsage.cRLSign,
|
KeyUsage.cRLSign,
|
||||||
KeyUsage.encipherOnly,
|
KeyUsage.encipherOnly,
|
||||||
KeyUsage.decipherOnly,
|
KeyUsage.decipherOnly,
|
||||||
];
|
].toSet();
|
||||||
|
|
||||||
static KeyUsage fromIndex(int value) {
|
static KeyUsage fromIndex(int value) {
|
||||||
return KeyUsage.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
return KeyUsage.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
|
|
|
@ -3,7 +3,7 @@ class OID {
|
||||||
|
|
||||||
const OID._internal(this._value);
|
const OID._internal(this._value);
|
||||||
|
|
||||||
static List<OID> values = [
|
static final Set<OID> values = [
|
||||||
OID.etsiQcsCompliance,
|
OID.etsiQcsCompliance,
|
||||||
OID.etsiQcsRetentionPeriod,
|
OID.etsiQcsRetentionPeriod,
|
||||||
OID.etsiQcsQcSSCD,
|
OID.etsiQcsQcSSCD,
|
||||||
|
@ -100,7 +100,7 @@ class OID {
|
||||||
OID.codeSigning,
|
OID.codeSigning,
|
||||||
OID.emailProtection,
|
OID.emailProtection,
|
||||||
OID.timeStamping,
|
OID.timeStamping,
|
||||||
];
|
].toSet();
|
||||||
|
|
||||||
static OID fromValue(String value) {
|
static OID fromValue(String value) {
|
||||||
return OID.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
return OID.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
|
|
|
@ -287,10 +287,18 @@ class _InAppWebViewState extends State<InAppWebView> {
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
if (defaultTargetPlatform == TargetPlatform.android) {
|
if (defaultTargetPlatform == TargetPlatform.android) {
|
||||||
|
var gestureRecognizers = widget.gestureRecognizers;
|
||||||
|
if (gestureRecognizers == null) {
|
||||||
|
gestureRecognizers = <Factory<OneSequenceGestureRecognizer>>[
|
||||||
|
Factory<OneSequenceGestureRecognizer>(
|
||||||
|
() => EagerGestureRecognizer(),
|
||||||
|
),
|
||||||
|
].toSet();
|
||||||
|
}
|
||||||
return AndroidView(
|
return AndroidView(
|
||||||
viewType: 'com.pichillilorenzo/flutter_inappwebview',
|
viewType: 'com.pichillilorenzo/flutter_inappwebview',
|
||||||
onPlatformViewCreated: _onPlatformViewCreated,
|
onPlatformViewCreated: _onPlatformViewCreated,
|
||||||
gestureRecognizers: widget.gestureRecognizers,
|
gestureRecognizers: gestureRecognizers,
|
||||||
layoutDirection: TextDirection.rtl,
|
layoutDirection: TextDirection.rtl,
|
||||||
creationParams: <String, dynamic>{
|
creationParams: <String, dynamic>{
|
||||||
'initialUrl': '${Uri.parse(widget.initialUrl)}',
|
'initialUrl': '${Uri.parse(widget.initialUrl)}',
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
import 'dart:developer';
|
|
||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
import 'dart:collection';
|
import 'dart:collection';
|
||||||
|
@ -13,8 +12,6 @@ import 'package:flutter/widgets.dart';
|
||||||
import 'X509Certificate/asn1_distinguished_names.dart';
|
import 'X509Certificate/asn1_distinguished_names.dart';
|
||||||
import 'X509Certificate/x509_certificate.dart';
|
import 'X509Certificate/x509_certificate.dart';
|
||||||
|
|
||||||
import 'package:html/parser.dart' show parse;
|
|
||||||
|
|
||||||
import 'context_menu.dart';
|
import 'context_menu.dart';
|
||||||
import 'types.dart';
|
import 'types.dart';
|
||||||
import 'in_app_browser.dart';
|
import 'in_app_browser.dart';
|
||||||
|
@ -586,11 +583,6 @@ class InAppWebViewController {
|
||||||
List<dynamic> args = jsonDecode(call.arguments["args"]);
|
List<dynamic> args = jsonDecode(call.arguments["args"]);
|
||||||
|
|
||||||
switch (handlerName) {
|
switch (handlerName) {
|
||||||
case "androidKeyboardWorkaroundFocusoutEvent":
|
|
||||||
// android Workaround to hide the Keyboard when the user click outside
|
|
||||||
// on something not focusable such as input or a textarea.
|
|
||||||
SystemChannels.textInput.invokeMethod("TextInput.hide");
|
|
||||||
break;
|
|
||||||
case "onLoadResource":
|
case "onLoadResource":
|
||||||
Map<dynamic, dynamic> argMap = args[0];
|
Map<dynamic, dynamic> argMap = args[0];
|
||||||
String initiatorType = argMap["initiatorType"];
|
String initiatorType = argMap["initiatorType"];
|
||||||
|
@ -883,7 +875,6 @@ class InAppWebViewController {
|
||||||
if (html == null || (html != null && html.isEmpty)) {
|
if (html == null || (html != null && html.isEmpty)) {
|
||||||
return favicons;
|
return favicons;
|
||||||
}
|
}
|
||||||
|
|
||||||
var assetPathBase;
|
var assetPathBase;
|
||||||
|
|
||||||
if (webviewUrl.startsWith("file:///")) {
|
if (webviewUrl.startsWith("file:///")) {
|
||||||
|
@ -891,13 +882,39 @@ class InAppWebViewController {
|
||||||
assetPathBase = assetPathSplitted[0] + "/flutter_assets/";
|
assetPathBase = assetPathSplitted[0] + "/flutter_assets/";
|
||||||
}
|
}
|
||||||
|
|
||||||
// get all link html elements
|
InAppWebViewGroupOptions options = await getOptions();
|
||||||
var document = parse(html);
|
if (options != null && options.crossPlatform.javaScriptEnabled == true) {
|
||||||
var links = document.getElementsByTagName('link');
|
List<Map<dynamic, dynamic>> links = (await evaluateJavascript(
|
||||||
|
source: """
|
||||||
|
(function() {
|
||||||
|
var linkNodes = document.head.getElementsByTagName("link");
|
||||||
|
var links = [];
|
||||||
|
for (var i = 0; i < linkNodes.length; i++) {
|
||||||
|
var linkNode = linkNodes[i];
|
||||||
|
if (linkNode.rel === 'manifest') {
|
||||||
|
links.push(
|
||||||
|
{
|
||||||
|
rel: linkNode.rel,
|
||||||
|
href: linkNode.href,
|
||||||
|
sizes: null
|
||||||
|
}
|
||||||
|
);
|
||||||
|
} else if (linkNode.rel != null && linkNode.rel.indexOf('icon') >= 0) {
|
||||||
|
links.push(
|
||||||
|
{
|
||||||
|
rel: linkNode.rel,
|
||||||
|
href: linkNode.href,
|
||||||
|
sizes: linkNode.sizes != null && linkNode.sizes.value != "" ? linkNode.sizes.value : null
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return links;
|
||||||
|
})();
|
||||||
|
"""))?.cast<Map<dynamic, dynamic>>() ?? [];
|
||||||
for (var link in links) {
|
for (var link in links) {
|
||||||
var attributes = link.attributes;
|
if (link["rel"] == "manifest") {
|
||||||
if (attributes["rel"] == "manifest") {
|
manifestUrl = link["href"];
|
||||||
manifestUrl = attributes["href"];
|
|
||||||
if (!_isUrlAbsolute(manifestUrl)) {
|
if (!_isUrlAbsolute(manifestUrl)) {
|
||||||
if (manifestUrl.startsWith("/")) {
|
if (manifestUrl.startsWith("/")) {
|
||||||
manifestUrl = manifestUrl.substring(1);
|
manifestUrl = manifestUrl.substring(1);
|
||||||
|
@ -909,11 +926,9 @@ class InAppWebViewController {
|
||||||
}
|
}
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (!attributes["rel"].contains("icon")) {
|
favicons.addAll(_createFavicons(url, assetPathBase, link["href"],
|
||||||
continue;
|
link["rel"], link["sizes"], false));
|
||||||
}
|
}
|
||||||
favicons.addAll(_createFavicons(url, assetPathBase, attributes["href"],
|
|
||||||
attributes["rel"], attributes["sizes"], false));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// try to get /favicon.ico
|
// try to get /favicon.ico
|
||||||
|
@ -923,7 +938,7 @@ class InAppWebViewController {
|
||||||
favicons.add(Favicon(url: faviconUrl, rel: "shortcut icon"));
|
favicons.add(Favicon(url: faviconUrl, rel: "shortcut icon"));
|
||||||
} catch (e, stacktrace) {
|
} catch (e, stacktrace) {
|
||||||
print("/favicon.ico file not found: " + e.toString());
|
print("/favicon.ico file not found: " + e.toString());
|
||||||
print(stacktrace);
|
// print(stacktrace);
|
||||||
}
|
}
|
||||||
|
|
||||||
// try to get the manifest file
|
// try to get the manifest file
|
||||||
|
@ -940,7 +955,7 @@ class InAppWebViewController {
|
||||||
manifestResponse.headers.contentType?.mimeType == "application/json";
|
manifestResponse.headers.contentType?.mimeType == "application/json";
|
||||||
} catch (e, stacktrace) {
|
} catch (e, stacktrace) {
|
||||||
print("Manifest file not found: " + e.toString());
|
print("Manifest file not found: " + e.toString());
|
||||||
print(stacktrace);
|
// print(stacktrace);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (manifestFound) {
|
if (manifestFound) {
|
||||||
|
@ -1181,6 +1196,11 @@ class InAppWebViewController {
|
||||||
|
|
||||||
///Evaluates JavaScript code into the WebView and returns the result of the evaluation.
|
///Evaluates JavaScript code into the WebView and returns the result of the evaluation.
|
||||||
///
|
///
|
||||||
|
///**NOTE**: This method shouldn't be called in the [WebView.onWebViewCreated] or [WebView.onLoadStart] events,
|
||||||
|
///because, in these events, the [WebView] is not ready to handle it yet.
|
||||||
|
///Instead, you should call this method, for example, inside the [WebView.onLoadStop] event or in any other events
|
||||||
|
///where you know the page is ready "enough".
|
||||||
|
///
|
||||||
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebView#evaluateJavascript(java.lang.String,%20android.webkit.ValueCallback%3Cjava.lang.String%3E)
|
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebView#evaluateJavascript(java.lang.String,%20android.webkit.ValueCallback%3Cjava.lang.String%3E)
|
||||||
///**Official iOS API**: https://developer.apple.com/documentation/webkit/wkwebview/1415017-evaluatejavascript
|
///**Official iOS API**: https://developer.apple.com/documentation/webkit/wkwebview/1415017-evaluatejavascript
|
||||||
Future<dynamic> evaluateJavascript({@required String source}) async {
|
Future<dynamic> evaluateJavascript({@required String source}) async {
|
||||||
|
@ -1192,6 +1212,11 @@ class InAppWebViewController {
|
||||||
}
|
}
|
||||||
|
|
||||||
///Injects an external JavaScript file into the WebView from a defined url.
|
///Injects an external JavaScript file into the WebView from a defined url.
|
||||||
|
///
|
||||||
|
///**NOTE**: This method shouldn't be called in the [WebView.onWebViewCreated] or [WebView.onLoadStart] events,
|
||||||
|
///because, in these events, the [WebView] is not ready to handle it yet.
|
||||||
|
///Instead, you should call this method, for example, inside the [WebView.onLoadStop] event or in any other events
|
||||||
|
///where you know the page is ready "enough".
|
||||||
Future<void> injectJavascriptFileFromUrl({@required String urlFile}) async {
|
Future<void> injectJavascriptFileFromUrl({@required String urlFile}) async {
|
||||||
Map<String, dynamic> args = <String, dynamic>{};
|
Map<String, dynamic> args = <String, dynamic>{};
|
||||||
args.putIfAbsent('urlFile', () => urlFile);
|
args.putIfAbsent('urlFile', () => urlFile);
|
||||||
|
@ -1199,6 +1224,11 @@ class InAppWebViewController {
|
||||||
}
|
}
|
||||||
|
|
||||||
///Injects a JavaScript file into the WebView from the flutter assets directory.
|
///Injects a JavaScript file into the WebView from the flutter assets directory.
|
||||||
|
///
|
||||||
|
///**NOTE**: This method shouldn't be called in the [WebView.onWebViewCreated] or [WebView.onLoadStart] events,
|
||||||
|
///because, in these events, the [WebView] is not ready to handle it yet.
|
||||||
|
///Instead, you should call this method, for example, inside the [WebView.onLoadStop] event or in any other events
|
||||||
|
///where you know the page is ready "enough".
|
||||||
Future<void> injectJavascriptFileFromAsset(
|
Future<void> injectJavascriptFileFromAsset(
|
||||||
{@required String assetFilePath}) async {
|
{@required String assetFilePath}) async {
|
||||||
String source = await rootBundle.loadString(assetFilePath);
|
String source = await rootBundle.loadString(assetFilePath);
|
||||||
|
@ -1206,6 +1236,11 @@ class InAppWebViewController {
|
||||||
}
|
}
|
||||||
|
|
||||||
///Injects CSS into the WebView.
|
///Injects CSS into the WebView.
|
||||||
|
///
|
||||||
|
///**NOTE**: This method shouldn't be called in the [WebView.onWebViewCreated] or [WebView.onLoadStart] events,
|
||||||
|
///because, in these events, the [WebView] is not ready to handle it yet.
|
||||||
|
///Instead, you should call this method, for example, inside the [WebView.onLoadStop] event or in any other events
|
||||||
|
///where you know the page is ready "enough".
|
||||||
Future<void> injectCSSCode({@required String source}) async {
|
Future<void> injectCSSCode({@required String source}) async {
|
||||||
Map<String, dynamic> args = <String, dynamic>{};
|
Map<String, dynamic> args = <String, dynamic>{};
|
||||||
args.putIfAbsent('source', () => source);
|
args.putIfAbsent('source', () => source);
|
||||||
|
@ -1213,6 +1248,11 @@ class InAppWebViewController {
|
||||||
}
|
}
|
||||||
|
|
||||||
///Injects an external CSS file into the WebView from a defined url.
|
///Injects an external CSS file into the WebView from a defined url.
|
||||||
|
///
|
||||||
|
///**NOTE**: This method shouldn't be called in the [WebView.onWebViewCreated] or [WebView.onLoadStart] events,
|
||||||
|
///because, in these events, the [WebView] is not ready to handle it yet.
|
||||||
|
///Instead, you should call this method, for example, inside the [WebView.onLoadStop] event or in any other events
|
||||||
|
///where you know the page is ready "enough".
|
||||||
Future<void> injectCSSFileFromUrl({@required String urlFile}) async {
|
Future<void> injectCSSFileFromUrl({@required String urlFile}) async {
|
||||||
Map<String, dynamic> args = <String, dynamic>{};
|
Map<String, dynamic> args = <String, dynamic>{};
|
||||||
args.putIfAbsent('urlFile', () => urlFile);
|
args.putIfAbsent('urlFile', () => urlFile);
|
||||||
|
@ -1220,6 +1260,11 @@ class InAppWebViewController {
|
||||||
}
|
}
|
||||||
|
|
||||||
///Injects a CSS file into the WebView from the flutter assets directory.
|
///Injects a CSS file into the WebView from the flutter assets directory.
|
||||||
|
///
|
||||||
|
///**NOTE**: This method shouldn't be called in the [WebView.onWebViewCreated] or [WebView.onLoadStart] events,
|
||||||
|
///because, in these events, the [WebView] is not ready to handle it yet.
|
||||||
|
///Instead, you should call this method, for example, inside the [WebView.onLoadStop] event or in any other events
|
||||||
|
///where you know the page is ready "enough".
|
||||||
Future<void> injectCSSFileFromAsset({@required String assetFilePath}) async {
|
Future<void> injectCSSFileFromAsset({@required String assetFilePath}) async {
|
||||||
String source = await rootBundle.loadString(assetFilePath);
|
String source = await rootBundle.loadString(assetFilePath);
|
||||||
await injectCSSCode(source: source);
|
await injectCSSCode(source: source);
|
||||||
|
@ -1271,6 +1316,10 @@ class InAppWebViewController {
|
||||||
///```
|
///```
|
||||||
///
|
///
|
||||||
///Forbidden names for JavaScript handlers are defined in [javaScriptHandlerForbiddenNames].
|
///Forbidden names for JavaScript handlers are defined in [javaScriptHandlerForbiddenNames].
|
||||||
|
///
|
||||||
|
///**NOTE**: This method should be called, for example, in the [WebView.onWebViewCreated] or [WebView.onLoadStart] events or, at least,
|
||||||
|
///before you know that your JavaScript code will call the `window.flutter_inappwebview.callHandler` method,
|
||||||
|
///otherwise you won't be able to intercept the JavaScript message.
|
||||||
void addJavaScriptHandler(
|
void addJavaScriptHandler(
|
||||||
{@required String handlerName,
|
{@required String handlerName,
|
||||||
@required JavaScriptHandlerCallback callback}) {
|
@required JavaScriptHandlerCallback callback}) {
|
||||||
|
|
|
@ -36,9 +36,17 @@ class ConsoleMessageLevel {
|
||||||
|
|
||||||
const ConsoleMessageLevel._internal(this._value);
|
const ConsoleMessageLevel._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<ConsoleMessageLevel> values = [
|
||||||
|
ConsoleMessageLevel.TIP,
|
||||||
|
ConsoleMessageLevel.LOG,
|
||||||
|
ConsoleMessageLevel.WARNING,
|
||||||
|
ConsoleMessageLevel.ERROR,
|
||||||
|
ConsoleMessageLevel.DEBUG,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static ConsoleMessageLevel fromValue(int value) {
|
static ConsoleMessageLevel fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 4)
|
if (value != null)
|
||||||
return ConsoleMessageLevel._internal(value);
|
return ConsoleMessageLevel.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -126,8 +134,7 @@ class InAppWebViewInitialData {
|
||||||
///The URL to use as the history entry. The default value is `about:blank`. If non-null, this must be a valid URL. This parameter is used only on Android.
|
///The URL to use as the history entry. The default value is `about:blank`. If non-null, this must be a valid URL. This parameter is used only on Android.
|
||||||
String historyUrl;
|
String historyUrl;
|
||||||
|
|
||||||
InAppWebViewInitialData(
|
InAppWebViewInitialData({@required this.data,
|
||||||
{@required this.data,
|
|
||||||
this.mimeType = "text/html",
|
this.mimeType = "text/html",
|
||||||
this.encoding = "utf8",
|
this.encoding = "utf8",
|
||||||
this.baseUrl = "about:blank",
|
this.baseUrl = "about:blank",
|
||||||
|
@ -189,8 +196,7 @@ class WebResourceRequest {
|
||||||
///**NOTE**: Available on Android 21+. For Android < 21 it will be always `false`.
|
///**NOTE**: Available on Android 21+. For Android < 21 it will be always `false`.
|
||||||
bool isRedirect;
|
bool isRedirect;
|
||||||
|
|
||||||
WebResourceRequest(
|
WebResourceRequest({@required this.url,
|
||||||
{@required this.url,
|
|
||||||
this.headers,
|
this.headers,
|
||||||
this.method,
|
this.method,
|
||||||
this.hasGesture,
|
this.hasGesture,
|
||||||
|
@ -249,10 +255,9 @@ class WebResourceResponse {
|
||||||
///**NOTE**: Available on Android 21+. For Android < 21 it won't be used.
|
///**NOTE**: Available on Android 21+. For Android < 21 it won't be used.
|
||||||
String reasonPhrase;
|
String reasonPhrase;
|
||||||
|
|
||||||
WebResourceResponse(
|
WebResourceResponse({this.contentType = "",
|
||||||
{this.contentType = "",
|
|
||||||
this.contentEncoding = "utf-8",
|
this.contentEncoding = "utf-8",
|
||||||
this.data = null,
|
this.data,
|
||||||
this.headers,
|
this.headers,
|
||||||
this.statusCode,
|
this.statusCode,
|
||||||
this.reasonPhrase});
|
this.reasonPhrase});
|
||||||
|
@ -289,8 +294,7 @@ class CustomSchemeResponse {
|
||||||
///Content-Enconding of the data, such as `utf-8`.
|
///Content-Enconding of the data, such as `utf-8`.
|
||||||
String contentEnconding;
|
String contentEnconding;
|
||||||
|
|
||||||
CustomSchemeResponse(
|
CustomSchemeResponse({@required this.data,
|
||||||
{@required this.data,
|
|
||||||
@required this.contentType,
|
@required this.contentType,
|
||||||
this.contentEnconding = 'utf-8'});
|
this.contentEnconding = 'utf-8'});
|
||||||
|
|
||||||
|
@ -459,8 +463,7 @@ class JsAlertResponse {
|
||||||
///Action used to confirm that the user hit confirm button.
|
///Action used to confirm that the user hit confirm button.
|
||||||
JsAlertResponseAction action;
|
JsAlertResponseAction action;
|
||||||
|
|
||||||
JsAlertResponse(
|
JsAlertResponse({this.message = "",
|
||||||
{this.message = "",
|
|
||||||
this.handledByClient = false,
|
this.handledByClient = false,
|
||||||
this.confirmButtonTitle = "",
|
this.confirmButtonTitle = "",
|
||||||
this.action = JsAlertResponseAction.CONFIRM});
|
this.action = JsAlertResponseAction.CONFIRM});
|
||||||
|
@ -518,8 +521,7 @@ class JsConfirmResponse {
|
||||||
///Action used to confirm that the user hit confirm or cancel button.
|
///Action used to confirm that the user hit confirm or cancel button.
|
||||||
JsConfirmResponseAction action;
|
JsConfirmResponseAction action;
|
||||||
|
|
||||||
JsConfirmResponse(
|
JsConfirmResponse({this.message = "",
|
||||||
{this.message = "",
|
|
||||||
this.handledByClient = false,
|
this.handledByClient = false,
|
||||||
this.confirmButtonTitle = "",
|
this.confirmButtonTitle = "",
|
||||||
this.cancelButtonTitle = "",
|
this.cancelButtonTitle = "",
|
||||||
|
@ -585,8 +587,7 @@ class JsPromptResponse {
|
||||||
///Action used to confirm that the user hit confirm or cancel button.
|
///Action used to confirm that the user hit confirm or cancel button.
|
||||||
JsPromptResponseAction action;
|
JsPromptResponseAction action;
|
||||||
|
|
||||||
JsPromptResponse(
|
JsPromptResponse({this.message = "",
|
||||||
{this.message = "",
|
|
||||||
this.defaultValue = "",
|
this.defaultValue = "",
|
||||||
this.handledByClient = false,
|
this.handledByClient = false,
|
||||||
this.confirmButtonTitle = "",
|
this.confirmButtonTitle = "",
|
||||||
|
@ -622,9 +623,17 @@ class SafeBrowsingThreat {
|
||||||
|
|
||||||
const SafeBrowsingThreat._internal(this._value);
|
const SafeBrowsingThreat._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<SafeBrowsingThreat> values = [
|
||||||
|
SafeBrowsingThreat.SAFE_BROWSING_THREAT_UNKNOWN,
|
||||||
|
SafeBrowsingThreat.SAFE_BROWSING_THREAT_MALWARE,
|
||||||
|
SafeBrowsingThreat.SAFE_BROWSING_THREAT_PHISHING,
|
||||||
|
SafeBrowsingThreat.SAFE_BROWSING_THREAT_UNWANTED_SOFTWARE,
|
||||||
|
SafeBrowsingThreat.SAFE_BROWSING_THREAT_BILLING,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static SafeBrowsingThreat fromValue(int value) {
|
static SafeBrowsingThreat fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 4)
|
if (value != null)
|
||||||
return SafeBrowsingThreat._internal(value);
|
return SafeBrowsingThreat.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -696,8 +705,7 @@ class SafeBrowsingResponse {
|
||||||
///Indicate the [SafeBrowsingResponseAction] to take when hitting a malicious URL.
|
///Indicate the [SafeBrowsingResponseAction] to take when hitting a malicious URL.
|
||||||
SafeBrowsingResponseAction action;
|
SafeBrowsingResponseAction action;
|
||||||
|
|
||||||
SafeBrowsingResponse(
|
SafeBrowsingResponse({this.report = true,
|
||||||
{this.report = true,
|
|
||||||
this.action = SafeBrowsingResponseAction.SHOW_INTERSTITIAL});
|
this.action = SafeBrowsingResponseAction.SHOW_INTERSTITIAL});
|
||||||
|
|
||||||
Map<String, dynamic> toMap() {
|
Map<String, dynamic> toMap() {
|
||||||
|
@ -752,8 +760,7 @@ class HttpAuthResponse {
|
||||||
///Indicate the [HttpAuthResponseAction] to take in response of the authentication challenge.
|
///Indicate the [HttpAuthResponseAction] to take in response of the authentication challenge.
|
||||||
HttpAuthResponseAction action;
|
HttpAuthResponseAction action;
|
||||||
|
|
||||||
HttpAuthResponse(
|
HttpAuthResponse({this.username = "",
|
||||||
{this.username = "",
|
|
||||||
this.password = "",
|
this.password = "",
|
||||||
this.permanentPersistence = false,
|
this.permanentPersistence = false,
|
||||||
this.action = HttpAuthResponseAction.CANCEL});
|
this.action = HttpAuthResponseAction.CANCEL});
|
||||||
|
@ -928,8 +935,7 @@ class ServerTrustChallenge {
|
||||||
///The SSL certificate used for this challenge.
|
///The SSL certificate used for this challenge.
|
||||||
SslCertificate sslCertificate;
|
SslCertificate sslCertificate;
|
||||||
|
|
||||||
ServerTrustChallenge(
|
ServerTrustChallenge({@required this.protectionSpace,
|
||||||
{@required this.protectionSpace,
|
|
||||||
this.androidError,
|
this.androidError,
|
||||||
this.iosError,
|
this.iosError,
|
||||||
this.message,
|
this.message,
|
||||||
|
@ -993,8 +999,7 @@ class ClientCertResponse {
|
||||||
///Indicate the [ClientCertResponseAction] to take in response of the client certificate challenge.
|
///Indicate the [ClientCertResponseAction] to take in response of the client certificate challenge.
|
||||||
ClientCertResponseAction action;
|
ClientCertResponseAction action;
|
||||||
|
|
||||||
ClientCertResponse(
|
ClientCertResponse({this.certificatePath,
|
||||||
{this.certificatePath,
|
|
||||||
this.certificatePassword = "",
|
this.certificatePassword = "",
|
||||||
this.androidKeyStoreType = "PKCS12",
|
this.androidKeyStoreType = "PKCS12",
|
||||||
this.action = ClientCertResponseAction.CANCEL}) {
|
this.action = ClientCertResponseAction.CANCEL}) {
|
||||||
|
@ -1081,9 +1086,16 @@ class AndroidCacheMode {
|
||||||
|
|
||||||
const AndroidCacheMode._internal(this._value);
|
const AndroidCacheMode._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidCacheMode> values = [
|
||||||
|
AndroidCacheMode.LOAD_DEFAULT,
|
||||||
|
AndroidCacheMode.LOAD_CACHE_ELSE_NETWORK,
|
||||||
|
AndroidCacheMode.LOAD_NO_CACHE,
|
||||||
|
AndroidCacheMode.LOAD_CACHE_ONLY,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidCacheMode fromValue(int value) {
|
static AndroidCacheMode fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 3)
|
if (value != null)
|
||||||
return AndroidCacheMode._internal(value);
|
return AndroidCacheMode.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1131,9 +1143,16 @@ class AndroidActionModeMenuItem {
|
||||||
|
|
||||||
const AndroidActionModeMenuItem._internal(this._value);
|
const AndroidActionModeMenuItem._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidActionModeMenuItem> values = [
|
||||||
|
AndroidActionModeMenuItem.MENU_ITEM_NONE,
|
||||||
|
AndroidActionModeMenuItem.MENU_ITEM_SHARE,
|
||||||
|
AndroidActionModeMenuItem.MENU_ITEM_WEB_SEARCH,
|
||||||
|
AndroidActionModeMenuItem.MENU_ITEM_PROCESS_TEXT,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidActionModeMenuItem fromValue(int value) {
|
static AndroidActionModeMenuItem fromValue(int value) {
|
||||||
if (value != null && value != 3 && value >= 0 && value <= 4)
|
if (value != null)
|
||||||
return AndroidActionModeMenuItem._internal(value);
|
return AndroidActionModeMenuItem.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1182,9 +1201,15 @@ class AndroidForceDark {
|
||||||
|
|
||||||
const AndroidForceDark._internal(this._value);
|
const AndroidForceDark._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidForceDark> values = [
|
||||||
|
AndroidForceDark.FORCE_DARK_OFF,
|
||||||
|
AndroidForceDark.FORCE_DARK_AUTO,
|
||||||
|
AndroidForceDark.FORCE_DARK_ON,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidForceDark fromValue(int value) {
|
static AndroidForceDark fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 2)
|
if (value != null)
|
||||||
return AndroidForceDark._internal(value);
|
return AndroidForceDark.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1225,10 +1250,16 @@ class AndroidLayoutAlgorithm {
|
||||||
|
|
||||||
const AndroidLayoutAlgorithm._internal(this._value);
|
const AndroidLayoutAlgorithm._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidLayoutAlgorithm> values = [
|
||||||
|
AndroidLayoutAlgorithm.NORMAL,
|
||||||
|
AndroidLayoutAlgorithm.TEXT_AUTOSIZING,
|
||||||
|
AndroidLayoutAlgorithm.NARROW_COLUMNS,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidLayoutAlgorithm fromValue(String value) {
|
static AndroidLayoutAlgorithm fromValue(String value) {
|
||||||
return (["NORMAL", "TEXT_AUTOSIZING", "NARROW_COLUMNS"].contains(value))
|
if (value != null)
|
||||||
? AndroidLayoutAlgorithm._internal(value)
|
return AndroidLayoutAlgorithm.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
: null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -1264,9 +1295,15 @@ class AndroidMixedContentMode {
|
||||||
|
|
||||||
const AndroidMixedContentMode._internal(this._value);
|
const AndroidMixedContentMode._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidMixedContentMode> values = [
|
||||||
|
AndroidMixedContentMode.MIXED_CONTENT_ALWAYS_ALLOW,
|
||||||
|
AndroidMixedContentMode.MIXED_CONTENT_NEVER_ALLOW,
|
||||||
|
AndroidMixedContentMode.MIXED_CONTENT_COMPATIBILITY_MODE,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidMixedContentMode fromValue(int value) {
|
static AndroidMixedContentMode fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 2)
|
if (value != null)
|
||||||
return AndroidMixedContentMode._internal(value);
|
return AndroidMixedContentMode.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1315,9 +1352,14 @@ class IOSWKSelectionGranularity {
|
||||||
|
|
||||||
const IOSWKSelectionGranularity._internal(this._value);
|
const IOSWKSelectionGranularity._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSWKSelectionGranularity> values = [
|
||||||
|
IOSWKSelectionGranularity.DYNAMIC,
|
||||||
|
IOSWKSelectionGranularity.CHARACTER,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSWKSelectionGranularity fromValue(int value) {
|
static IOSWKSelectionGranularity fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 1)
|
if (value != null)
|
||||||
return IOSWKSelectionGranularity._internal(value);
|
return IOSWKSelectionGranularity.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1354,22 +1396,23 @@ class IOSWKDataDetectorTypes {
|
||||||
|
|
||||||
const IOSWKDataDetectorTypes._internal(this._value);
|
const IOSWKDataDetectorTypes._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSWKDataDetectorTypes> values = [
|
||||||
|
IOSWKDataDetectorTypes.NONE,
|
||||||
|
IOSWKDataDetectorTypes.PHONE_NUMBER,
|
||||||
|
IOSWKDataDetectorTypes.LINK,
|
||||||
|
IOSWKDataDetectorTypes.ADDRESS,
|
||||||
|
IOSWKDataDetectorTypes.CALENDAR_EVENT,
|
||||||
|
IOSWKDataDetectorTypes.TRACKING_NUMBER,
|
||||||
|
IOSWKDataDetectorTypes.FLIGHT_NUMBER,
|
||||||
|
IOSWKDataDetectorTypes.LOOKUP_SUGGESTION,
|
||||||
|
IOSWKDataDetectorTypes.SPOTLIGHT_SUGGESTION,
|
||||||
|
IOSWKDataDetectorTypes.ALL,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSWKDataDetectorTypes fromValue(String value) {
|
static IOSWKDataDetectorTypes fromValue(String value) {
|
||||||
return ([
|
if (value != null)
|
||||||
"NONE",
|
return IOSWKDataDetectorTypes.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
"PHONE_NUMBER",
|
return null;
|
||||||
"LINK",
|
|
||||||
"ADDRESS",
|
|
||||||
"CALENDAR_EVENT",
|
|
||||||
"TRACKING_NUMBER",
|
|
||||||
"TRACKING_NUMBER",
|
|
||||||
"FLIGHT_NUMBER",
|
|
||||||
"LOOKUP_SUGGESTION",
|
|
||||||
"SPOTLIGHT_SUGGESTION",
|
|
||||||
"ALL"
|
|
||||||
].contains(value))
|
|
||||||
? IOSWKDataDetectorTypes._internal(value)
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -1425,10 +1468,15 @@ class IOSUIScrollViewDecelerationRate {
|
||||||
|
|
||||||
const IOSUIScrollViewDecelerationRate._internal(this._value);
|
const IOSUIScrollViewDecelerationRate._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSUIScrollViewDecelerationRate> values = [
|
||||||
|
IOSUIScrollViewDecelerationRate.NORMAL,
|
||||||
|
IOSUIScrollViewDecelerationRate.FAST,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSUIScrollViewDecelerationRate fromValue(String value) {
|
static IOSUIScrollViewDecelerationRate fromValue(String value) {
|
||||||
return (["NORMAL", "FAST"].contains(value))
|
if (value != null)
|
||||||
? IOSUIScrollViewDecelerationRate._internal(value)
|
return IOSUIScrollViewDecelerationRate.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
: null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -1455,9 +1503,15 @@ class UserPreferredContentMode {
|
||||||
|
|
||||||
const UserPreferredContentMode._internal(this._value);
|
const UserPreferredContentMode._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<UserPreferredContentMode> values = [
|
||||||
|
UserPreferredContentMode.RECOMMENDED,
|
||||||
|
UserPreferredContentMode.MOBILE,
|
||||||
|
UserPreferredContentMode.DESKTOP,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static UserPreferredContentMode fromValue(int value) {
|
static UserPreferredContentMode fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 2)
|
if (value != null)
|
||||||
return UserPreferredContentMode._internal(value);
|
return UserPreferredContentMode.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1497,9 +1551,22 @@ class IOSUIModalPresentationStyle {
|
||||||
|
|
||||||
const IOSUIModalPresentationStyle._internal(this._value);
|
const IOSUIModalPresentationStyle._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSUIModalPresentationStyle> values = [
|
||||||
|
IOSUIModalPresentationStyle.FULL_SCREEN,
|
||||||
|
IOSUIModalPresentationStyle.PAGE_SHEET,
|
||||||
|
IOSUIModalPresentationStyle.FORM_SHEET,
|
||||||
|
IOSUIModalPresentationStyle.CURRENT_CONTEXT,
|
||||||
|
IOSUIModalPresentationStyle.CUSTOM,
|
||||||
|
IOSUIModalPresentationStyle.OVER_FULL_SCREEN,
|
||||||
|
IOSUIModalPresentationStyle.OVER_CURRENT_CONTEXT,
|
||||||
|
IOSUIModalPresentationStyle.POPOVER,
|
||||||
|
IOSUIModalPresentationStyle.NONE,
|
||||||
|
IOSUIModalPresentationStyle.AUTOMATIC,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSUIModalPresentationStyle fromValue(int value) {
|
static IOSUIModalPresentationStyle fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 9)
|
if (value != null)
|
||||||
return IOSUIModalPresentationStyle._internal(value);
|
return IOSUIModalPresentationStyle.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1578,9 +1645,16 @@ class IOSUIModalTransitionStyle {
|
||||||
|
|
||||||
const IOSUIModalTransitionStyle._internal(this._value);
|
const IOSUIModalTransitionStyle._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSUIModalTransitionStyle> values = [
|
||||||
|
IOSUIModalTransitionStyle.COVER_VERTICAL,
|
||||||
|
IOSUIModalTransitionStyle.FLIP_HORIZONTAL,
|
||||||
|
IOSUIModalTransitionStyle.CROSS_DISSOLVE,
|
||||||
|
IOSUIModalTransitionStyle.PARTIAL_CURL,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSUIModalTransitionStyle fromValue(int value) {
|
static IOSUIModalTransitionStyle fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 3)
|
if (value != null)
|
||||||
return IOSUIModalTransitionStyle._internal(value);
|
return IOSUIModalTransitionStyle.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1633,9 +1707,15 @@ class IOSSafariDismissButtonStyle {
|
||||||
|
|
||||||
const IOSSafariDismissButtonStyle._internal(this._value);
|
const IOSSafariDismissButtonStyle._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSSafariDismissButtonStyle> values = [
|
||||||
|
IOSSafariDismissButtonStyle.DONE,
|
||||||
|
IOSSafariDismissButtonStyle.CLOSE,
|
||||||
|
IOSSafariDismissButtonStyle.CANCEL,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSSafariDismissButtonStyle fromValue(int value) {
|
static IOSSafariDismissButtonStyle fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 2)
|
if (value != null)
|
||||||
return IOSSafariDismissButtonStyle._internal(value);
|
return IOSSafariDismissButtonStyle.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1680,7 +1760,13 @@ class InAppWebViewGroupOptions {
|
||||||
///iOS-specific options.
|
///iOS-specific options.
|
||||||
IOSInAppWebViewOptions ios;
|
IOSInAppWebViewOptions ios;
|
||||||
|
|
||||||
InAppWebViewGroupOptions({this.crossPlatform, this.android, this.ios});
|
InAppWebViewGroupOptions({this.crossPlatform,
|
||||||
|
this.android,
|
||||||
|
this.ios}) {
|
||||||
|
this.crossPlatform = this.crossPlatform ?? InAppWebViewOptions();
|
||||||
|
this.android = this.android ?? AndroidInAppWebViewOptions();
|
||||||
|
this.ios = this.ios ?? IOSInAppWebViewOptions();
|
||||||
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toMap() {
|
Map<String, dynamic> toMap() {
|
||||||
Map<String, dynamic> options = {};
|
Map<String, dynamic> options = {};
|
||||||
|
@ -1695,9 +1781,11 @@ class InAppWebViewGroupOptions {
|
||||||
static InAppWebViewGroupOptions fromMap(Map<String, dynamic> options) {
|
static InAppWebViewGroupOptions fromMap(Map<String, dynamic> options) {
|
||||||
InAppWebViewGroupOptions inAppWebViewGroupOptions = InAppWebViewGroupOptions();
|
InAppWebViewGroupOptions inAppWebViewGroupOptions = InAppWebViewGroupOptions();
|
||||||
|
|
||||||
inAppWebViewGroupOptions.crossPlatform = InAppWebViewOptions.fromMap(options);
|
inAppWebViewGroupOptions.crossPlatform =
|
||||||
|
InAppWebViewOptions.fromMap(options);
|
||||||
if (Platform.isAndroid)
|
if (Platform.isAndroid)
|
||||||
inAppWebViewGroupOptions.android = AndroidInAppWebViewOptions.fromMap(options);
|
inAppWebViewGroupOptions.android =
|
||||||
|
AndroidInAppWebViewOptions.fromMap(options);
|
||||||
else if (Platform.isIOS)
|
else if (Platform.isIOS)
|
||||||
inAppWebViewGroupOptions.ios = IOSInAppWebViewOptions.fromMap(options);
|
inAppWebViewGroupOptions.ios = IOSInAppWebViewOptions.fromMap(options);
|
||||||
|
|
||||||
|
@ -1716,12 +1804,6 @@ class InAppWebViewGroupOptions {
|
||||||
InAppWebViewGroupOptions copy() {
|
InAppWebViewGroupOptions copy() {
|
||||||
return InAppWebViewGroupOptions.fromMap(this.toMap());
|
return InAppWebViewGroupOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
InAppWebViewGroupOptions copyWithValue(InAppWebViewGroupOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return InAppWebViewGroupOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///Class that represents the options that can be used for an [InAppBrowser] WebView.
|
///Class that represents the options that can be used for an [InAppBrowser] WebView.
|
||||||
|
@ -1738,11 +1820,16 @@ class InAppBrowserClassOptions {
|
||||||
///WebView options.
|
///WebView options.
|
||||||
InAppWebViewGroupOptions inAppWebViewGroupOptions;
|
InAppWebViewGroupOptions inAppWebViewGroupOptions;
|
||||||
|
|
||||||
InAppBrowserClassOptions(
|
InAppBrowserClassOptions({this.crossPlatform,
|
||||||
{this.crossPlatform,
|
|
||||||
this.android,
|
this.android,
|
||||||
this.ios,
|
this.ios,
|
||||||
this.inAppWebViewGroupOptions});
|
this.inAppWebViewGroupOptions}) {
|
||||||
|
this.crossPlatform = this.crossPlatform ?? InAppBrowserOptions();
|
||||||
|
this.android = this.android ?? AndroidInAppBrowserOptions();
|
||||||
|
this.ios = this.ios ?? IOSInAppBrowserOptions();
|
||||||
|
this.inAppWebViewGroupOptions =
|
||||||
|
this.inAppWebViewGroupOptions ?? InAppWebViewGroupOptions();
|
||||||
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toMap() {
|
Map<String, dynamic> toMap() {
|
||||||
Map<String, dynamic> options = {};
|
Map<String, dynamic> options = {};
|
||||||
|
@ -1795,12 +1882,6 @@ class InAppBrowserClassOptions {
|
||||||
InAppBrowserClassOptions copy() {
|
InAppBrowserClassOptions copy() {
|
||||||
return InAppBrowserClassOptions.fromMap(this.toMap());
|
return InAppBrowserClassOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
InAppBrowserClassOptions copyWithValue(InAppBrowserClassOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return InAppBrowserClassOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///Class that represents the options that can be used for an [ChromeSafariBrowser] window.
|
///Class that represents the options that can be used for an [ChromeSafariBrowser] window.
|
||||||
|
@ -1811,7 +1892,13 @@ class ChromeSafariBrowserClassOptions {
|
||||||
///iOS-specific options.
|
///iOS-specific options.
|
||||||
IOSSafariOptions ios;
|
IOSSafariOptions ios;
|
||||||
|
|
||||||
ChromeSafariBrowserClassOptions({this.android, this.ios});
|
ChromeSafariBrowserClassOptions({
|
||||||
|
this.android,
|
||||||
|
this.ios
|
||||||
|
}) {
|
||||||
|
this.android = this.android ?? AndroidChromeCustomTabsOptions();
|
||||||
|
this.ios = this.ios ?? IOSSafariOptions();
|
||||||
|
}
|
||||||
|
|
||||||
Map<String, dynamic> toMap() {
|
Map<String, dynamic> toMap() {
|
||||||
Map<String, dynamic> options = {};
|
Map<String, dynamic> options = {};
|
||||||
|
@ -1873,11 +1960,20 @@ class AjaxRequestEventType {
|
||||||
|
|
||||||
const AjaxRequestEventType._internal(this._value);
|
const AjaxRequestEventType._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AjaxRequestEventType> values = [
|
||||||
|
AjaxRequestEventType.LOADSTART,
|
||||||
|
AjaxRequestEventType.LOAD,
|
||||||
|
AjaxRequestEventType.LOADEND,
|
||||||
|
AjaxRequestEventType.PROGRESS,
|
||||||
|
AjaxRequestEventType.ERROR,
|
||||||
|
AjaxRequestEventType.ABORT,
|
||||||
|
AjaxRequestEventType.TIMEOUT,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AjaxRequestEventType fromValue(String value) {
|
static AjaxRequestEventType fromValue(String value) {
|
||||||
return (["loadstart", "load", "loadend", "progress", "error", "abort"]
|
if (value != null)
|
||||||
.contains(value))
|
return AjaxRequestEventType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
? AjaxRequestEventType._internal(value)
|
return null;
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -1939,9 +2035,17 @@ class AjaxRequestReadyState {
|
||||||
|
|
||||||
const AjaxRequestReadyState._internal(this._value);
|
const AjaxRequestReadyState._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AjaxRequestReadyState> values = [
|
||||||
|
AjaxRequestReadyState.UNSENT,
|
||||||
|
AjaxRequestReadyState.OPENED,
|
||||||
|
AjaxRequestReadyState.HEADERS_RECEIVED,
|
||||||
|
AjaxRequestReadyState.LOADING,
|
||||||
|
AjaxRequestReadyState.DONE,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AjaxRequestReadyState fromValue(int value) {
|
static AjaxRequestReadyState fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 4)
|
if (value != null)
|
||||||
return AjaxRequestReadyState._internal(value);
|
return AjaxRequestReadyState.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2079,8 +2183,7 @@ class AjaxRequest {
|
||||||
///Indicates the [AjaxRequestAction] that can be used to control the `XMLHttpRequest` request.
|
///Indicates the [AjaxRequestAction] that can be used to control the `XMLHttpRequest` request.
|
||||||
AjaxRequestAction action;
|
AjaxRequestAction action;
|
||||||
|
|
||||||
AjaxRequest(
|
AjaxRequest({this.data,
|
||||||
{this.data,
|
|
||||||
this.method,
|
this.method,
|
||||||
this.url,
|
this.url,
|
||||||
this.isAsync,
|
this.isAsync,
|
||||||
|
@ -2319,8 +2422,7 @@ class FetchRequest {
|
||||||
///Indicates the [FetchRequestAction] that can be used to control the request.
|
///Indicates the [FetchRequestAction] that can be used to control the request.
|
||||||
FetchRequestAction action;
|
FetchRequestAction action;
|
||||||
|
|
||||||
FetchRequest(
|
FetchRequest({this.url,
|
||||||
{this.url,
|
|
||||||
this.method,
|
this.method,
|
||||||
this.headers,
|
this.headers,
|
||||||
this.body,
|
this.body,
|
||||||
|
@ -2393,19 +2495,21 @@ class ContentBlockerTriggerResourceType {
|
||||||
|
|
||||||
const ContentBlockerTriggerResourceType._internal(this._value);
|
const ContentBlockerTriggerResourceType._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<ContentBlockerTriggerResourceType> values = [
|
||||||
|
ContentBlockerTriggerResourceType.DOCUMENT,
|
||||||
|
ContentBlockerTriggerResourceType.IMAGE,
|
||||||
|
ContentBlockerTriggerResourceType.STYLE_SHEET,
|
||||||
|
ContentBlockerTriggerResourceType.SCRIPT,
|
||||||
|
ContentBlockerTriggerResourceType.FONT,
|
||||||
|
ContentBlockerTriggerResourceType.MEDIA,
|
||||||
|
ContentBlockerTriggerResourceType.SVG_DOCUMENT,
|
||||||
|
ContentBlockerTriggerResourceType.RAW,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static ContentBlockerTriggerResourceType fromValue(String value) {
|
static ContentBlockerTriggerResourceType fromValue(String value) {
|
||||||
return ([
|
if (value != null)
|
||||||
"document",
|
return ContentBlockerTriggerResourceType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
"image",
|
return null;
|
||||||
"style-sheet",
|
|
||||||
"script",
|
|
||||||
"font",
|
|
||||||
"media",
|
|
||||||
"svg-document",
|
|
||||||
"raw"
|
|
||||||
].contains(value))
|
|
||||||
? ContentBlockerTriggerResourceType._internal(value)
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -2442,10 +2546,15 @@ class ContentBlockerTriggerLoadType {
|
||||||
|
|
||||||
const ContentBlockerTriggerLoadType._internal(this._value);
|
const ContentBlockerTriggerLoadType._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<ContentBlockerTriggerLoadType> values = [
|
||||||
|
ContentBlockerTriggerLoadType.FIRST_PARTY,
|
||||||
|
ContentBlockerTriggerLoadType.THIRD_PARTY,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static ContentBlockerTriggerLoadType fromValue(String value) {
|
static ContentBlockerTriggerLoadType fromValue(String value) {
|
||||||
return (["first-party", "third-party"].contains(value))
|
if (value != null)
|
||||||
? ContentBlockerTriggerLoadType._internal(value)
|
return ContentBlockerTriggerLoadType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
: null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -2473,10 +2582,16 @@ class ContentBlockerActionType {
|
||||||
|
|
||||||
const ContentBlockerActionType._internal(this._value);
|
const ContentBlockerActionType._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<ContentBlockerActionType> values = [
|
||||||
|
ContentBlockerActionType.BLOCK,
|
||||||
|
ContentBlockerActionType.CSS_DISPLAY_NONE,
|
||||||
|
ContentBlockerActionType.MAKE_HTTPS,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static ContentBlockerActionType fromValue(String value) {
|
static ContentBlockerActionType fromValue(String value) {
|
||||||
return (["block", "css-display-none", "make-https"].contains(value))
|
if (value != null)
|
||||||
? ContentBlockerActionType._internal(value)
|
return ContentBlockerActionType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
: null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -2546,8 +2661,7 @@ class Cookie {
|
||||||
///**NOTE**: on Android it will be always `null`.
|
///**NOTE**: on Android it will be always `null`.
|
||||||
String path;
|
String path;
|
||||||
|
|
||||||
Cookie(
|
Cookie({@required this.name,
|
||||||
{@required this.name,
|
|
||||||
@required this.value,
|
@required this.value,
|
||||||
this.expiresDate,
|
this.expiresDate,
|
||||||
this.isSessionOnly,
|
this.isSessionOnly,
|
||||||
|
@ -2609,8 +2723,7 @@ class PermissionRequestResponse {
|
||||||
///Indicate the [PermissionRequestResponseAction] to take in response of a permission request.
|
///Indicate the [PermissionRequestResponseAction] to take in response of a permission request.
|
||||||
PermissionRequestResponseAction action;
|
PermissionRequestResponseAction action;
|
||||||
|
|
||||||
PermissionRequestResponse(
|
PermissionRequestResponse({this.resources = const [],
|
||||||
{this.resources = const [],
|
|
||||||
this.action = PermissionRequestResponseAction.DENY});
|
this.action = PermissionRequestResponseAction.DENY});
|
||||||
|
|
||||||
Map<String, dynamic> toMap() {
|
Map<String, dynamic> toMap() {
|
||||||
|
@ -2660,14 +2773,23 @@ class IOSWKNavigationType {
|
||||||
|
|
||||||
const IOSWKNavigationType._internal(this._value);
|
const IOSWKNavigationType._internal(this._value);
|
||||||
|
|
||||||
int toValue() => _value;
|
static final Set<IOSWKNavigationType> values = [
|
||||||
|
IOSWKNavigationType.LINK_ACTIVATED,
|
||||||
|
IOSWKNavigationType.FORM_SUBMITTED,
|
||||||
|
IOSWKNavigationType.BACK_FORWARD,
|
||||||
|
IOSWKNavigationType.RELOAD,
|
||||||
|
IOSWKNavigationType.FORM_RESUBMITTED,
|
||||||
|
IOSWKNavigationType.OTHER,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSWKNavigationType fromValue(int value) {
|
static IOSWKNavigationType fromValue(int value) {
|
||||||
if (value != null && ((value >= 0 && value <= 4) || value == -1))
|
if (value != null)
|
||||||
return IOSWKNavigationType._internal(value);
|
return IOSWKNavigationType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int toValue() => _value;
|
||||||
|
|
||||||
///A link with an href attribute was activated by the user.
|
///A link with an href attribute was activated by the user.
|
||||||
static const LINK_ACTIVATED = const IOSWKNavigationType._internal(0);
|
static const LINK_ACTIVATED = const IOSWKNavigationType._internal(0);
|
||||||
|
|
||||||
|
@ -2720,8 +2842,7 @@ class ShouldOverrideUrlLoadingRequest {
|
||||||
///The type of action triggering the navigation. Available only on iOS.
|
///The type of action triggering the navigation. Available only on iOS.
|
||||||
IOSWKNavigationType iosWKNavigationType;
|
IOSWKNavigationType iosWKNavigationType;
|
||||||
|
|
||||||
ShouldOverrideUrlLoadingRequest(
|
ShouldOverrideUrlLoadingRequest({this.url,
|
||||||
{this.url,
|
|
||||||
this.method,
|
this.method,
|
||||||
this.headers,
|
this.headers,
|
||||||
this.isForMainFrame,
|
this.isForMainFrame,
|
||||||
|
@ -2765,8 +2886,7 @@ class OnCreateWindowRequest {
|
||||||
///The type of action triggering the navigation. Available only on iOS.
|
///The type of action triggering the navigation. Available only on iOS.
|
||||||
IOSWKNavigationType iosWKNavigationType;
|
IOSWKNavigationType iosWKNavigationType;
|
||||||
|
|
||||||
OnCreateWindowRequest(
|
OnCreateWindowRequest({this.url,
|
||||||
{this.url,
|
|
||||||
this.androidIsDialog,
|
this.androidIsDialog,
|
||||||
this.androidIsUserGesture,
|
this.androidIsUserGesture,
|
||||||
this.iosWKNavigationType});
|
this.iosWKNavigationType});
|
||||||
|
@ -2826,21 +2946,23 @@ class IOSWKWebsiteDataType {
|
||||||
|
|
||||||
const IOSWKWebsiteDataType._internal(this._value);
|
const IOSWKWebsiteDataType._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSWKWebsiteDataType> values = [
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeFetchCache,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeDiskCache,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeMemoryCache,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeOfflineWebApplicationCache,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeCookies,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeSessionStorage,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeLocalStorage,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeWebSQLDatabases,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeIndexedDBDatabases,
|
||||||
|
IOSWKWebsiteDataType.WKWebsiteDataTypeServiceWorkerRegistrations,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSWKWebsiteDataType fromValue(String value) {
|
static IOSWKWebsiteDataType fromValue(String value) {
|
||||||
return ([
|
if (value != null)
|
||||||
"WKWebsiteDataTypeFetchCache",
|
return IOSWKWebsiteDataType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
"WKWebsiteDataTypeDiskCache",
|
return null;
|
||||||
"WKWebsiteDataTypeMemoryCache",
|
|
||||||
"WKWebsiteDataTypeOfflineWebApplicationCache",
|
|
||||||
"WKWebsiteDataTypeCookies",
|
|
||||||
"WKWebsiteDataTypeSessionStorage",
|
|
||||||
"WKWebsiteDataTypeLocalStorage",
|
|
||||||
"WKWebsiteDataTypeWebSQLDatabases",
|
|
||||||
"WKWebsiteDataTypeIndexedDBDatabases",
|
|
||||||
"WKWebsiteDataTypeServiceWorkerRegistrations"
|
|
||||||
].contains(value))
|
|
||||||
? IOSWKWebsiteDataType._internal(value)
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -2896,6 +3018,7 @@ class IOSWKWebsiteDataType {
|
||||||
"WKWebsiteDataTypeServiceWorkerRegistrations");
|
"WKWebsiteDataTypeServiceWorkerRegistrations");
|
||||||
|
|
||||||
///Returns a set of all available website data types.
|
///Returns a set of all available website data types.
|
||||||
|
// ignore: non_constant_identifier_names
|
||||||
static final Set<IOSWKWebsiteDataType> ALL = [
|
static final Set<IOSWKWebsiteDataType> ALL = [
|
||||||
IOSWKWebsiteDataType.WKWebsiteDataTypeFetchCache,
|
IOSWKWebsiteDataType.WKWebsiteDataTypeFetchCache,
|
||||||
IOSWKWebsiteDataType.WKWebsiteDataTypeDiskCache,
|
IOSWKWebsiteDataType.WKWebsiteDataTypeDiskCache,
|
||||||
|
@ -2952,9 +3075,20 @@ class InAppWebViewHitTestResultType {
|
||||||
|
|
||||||
const InAppWebViewHitTestResultType._internal(this._value);
|
const InAppWebViewHitTestResultType._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<InAppWebViewHitTestResultType> values = [
|
||||||
|
InAppWebViewHitTestResultType.UNKNOWN_TYPE,
|
||||||
|
InAppWebViewHitTestResultType.PHONE_TYPE,
|
||||||
|
InAppWebViewHitTestResultType.GEO_TYPE,
|
||||||
|
InAppWebViewHitTestResultType.EMAIL_TYPE,
|
||||||
|
InAppWebViewHitTestResultType.IMAGE_TYPE,
|
||||||
|
InAppWebViewHitTestResultType.SRC_ANCHOR_TYPE,
|
||||||
|
InAppWebViewHitTestResultType.SRC_IMAGE_ANCHOR_TYPE,
|
||||||
|
InAppWebViewHitTestResultType.EDIT_TEXT_TYPE,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static InAppWebViewHitTestResultType fromValue(int value) {
|
static InAppWebViewHitTestResultType fromValue(int value) {
|
||||||
if (value != null && [0, 2, 3, 4, 5, 7, 8, 9].contains(value))
|
if (value != null)
|
||||||
return InAppWebViewHitTestResultType._internal(value);
|
return InAppWebViewHitTestResultType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3099,9 +3233,15 @@ class RendererPriority {
|
||||||
|
|
||||||
const RendererPriority._internal(this._value);
|
const RendererPriority._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<RendererPriority> values = [
|
||||||
|
RendererPriority.RENDERER_PRIORITY_WAIVED,
|
||||||
|
RendererPriority.RENDERER_PRIORITY_BOUND,
|
||||||
|
RendererPriority.RENDERER_PRIORITY_IMPORTANT,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static RendererPriority fromValue(int value) {
|
static RendererPriority fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 2)
|
if (value != null)
|
||||||
return RendererPriority._internal(value);
|
return RendererPriority.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3150,8 +3290,7 @@ class RendererPriorityPolicy {
|
||||||
///If true, this flag specifies that when this WebView is not visible, it will be treated as if it had requested a priority of [RendererPriority.RENDERER_PRIORITY_WAIVED].
|
///If true, this flag specifies that when this WebView is not visible, it will be treated as if it had requested a priority of [RendererPriority.RENDERER_PRIORITY_WAIVED].
|
||||||
bool waivedWhenNotVisible;
|
bool waivedWhenNotVisible;
|
||||||
|
|
||||||
RendererPriorityPolicy(
|
RendererPriorityPolicy({@required this.rendererRequestedPriority,
|
||||||
{@required this.rendererRequestedPriority,
|
|
||||||
@required this.waivedWhenNotVisible});
|
@required this.waivedWhenNotVisible});
|
||||||
|
|
||||||
Map<String, dynamic> toMap() {
|
Map<String, dynamic> toMap() {
|
||||||
|
@ -3220,9 +3359,15 @@ class AndroidOverScrollMode {
|
||||||
|
|
||||||
const AndroidOverScrollMode._internal(this._value);
|
const AndroidOverScrollMode._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidOverScrollMode> values = [
|
||||||
|
AndroidOverScrollMode.OVER_SCROLL_ALWAYS,
|
||||||
|
AndroidOverScrollMode.OVER_SCROLL_IF_CONTENT_SCROLLS,
|
||||||
|
AndroidOverScrollMode.OVER_SCROLL_NEVER,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidOverScrollMode fromValue(int value) {
|
static AndroidOverScrollMode fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 2)
|
if (value != null)
|
||||||
return AndroidOverScrollMode._internal(value);
|
return AndroidOverScrollMode.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3269,9 +3414,16 @@ class AndroidScrollBarStyle {
|
||||||
|
|
||||||
const AndroidScrollBarStyle._internal(this._value);
|
const AndroidScrollBarStyle._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidScrollBarStyle> values = [
|
||||||
|
AndroidScrollBarStyle.SCROLLBARS_INSIDE_OVERLAY,
|
||||||
|
AndroidScrollBarStyle.SCROLLBARS_INSIDE_INSET,
|
||||||
|
AndroidScrollBarStyle.SCROLLBARS_OUTSIDE_OVERLAY,
|
||||||
|
AndroidScrollBarStyle.SCROLLBARS_OUTSIDE_INSET,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidScrollBarStyle fromValue(int value) {
|
static AndroidScrollBarStyle fromValue(int value) {
|
||||||
if (value != null && [0, 16777216, 33554432, 50331648].contains(value))
|
if (value != null)
|
||||||
return AndroidScrollBarStyle._internal(value);
|
return AndroidScrollBarStyle.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3324,9 +3476,15 @@ class AndroidVerticalScrollbarPosition {
|
||||||
|
|
||||||
const AndroidVerticalScrollbarPosition._internal(this._value);
|
const AndroidVerticalScrollbarPosition._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidVerticalScrollbarPosition> values = [
|
||||||
|
AndroidVerticalScrollbarPosition.SCROLLBAR_POSITION_DEFAULT,
|
||||||
|
AndroidVerticalScrollbarPosition.SCROLLBAR_POSITION_LEFT,
|
||||||
|
AndroidVerticalScrollbarPosition.SCROLLBAR_POSITION_RIGHT,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidVerticalScrollbarPosition fromValue(int value) {
|
static AndroidVerticalScrollbarPosition fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 2)
|
if (value != null)
|
||||||
return AndroidVerticalScrollbarPosition._internal(value);
|
return AndroidVerticalScrollbarPosition.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3505,13 +3663,15 @@ class WebStorageType {
|
||||||
|
|
||||||
const WebStorageType._internal(this._value);
|
const WebStorageType._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<WebStorageType> values = [
|
||||||
|
WebStorageType.LOCAL_STORAGE,
|
||||||
|
WebStorageType.SESSION_STORAGE,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static WebStorageType fromValue(String value) {
|
static WebStorageType fromValue(String value) {
|
||||||
return ([
|
if (value != null)
|
||||||
"localStorage",
|
return WebStorageType.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
"sessionStorage",
|
return null;
|
||||||
].contains(value))
|
|
||||||
? WebStorageType._internal(value)
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -3539,14 +3699,16 @@ class HTTPCookieSameSitePolicy {
|
||||||
|
|
||||||
const HTTPCookieSameSitePolicy._internal(this._value);
|
const HTTPCookieSameSitePolicy._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<HTTPCookieSameSitePolicy> values = [
|
||||||
|
HTTPCookieSameSitePolicy.LAX,
|
||||||
|
HTTPCookieSameSitePolicy.STRICT,
|
||||||
|
HTTPCookieSameSitePolicy.NONE,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static HTTPCookieSameSitePolicy fromValue(String value) {
|
static HTTPCookieSameSitePolicy fromValue(String value) {
|
||||||
return ([
|
if (value != null)
|
||||||
"Lax",
|
return HTTPCookieSameSitePolicy.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
"Strict",
|
return null;
|
||||||
"None",
|
|
||||||
].contains(value))
|
|
||||||
? HTTPCookieSameSitePolicy._internal(value)
|
|
||||||
: null;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
String toValue() => _value;
|
String toValue() => _value;
|
||||||
|
@ -3584,9 +3746,18 @@ class AndroidSslError {
|
||||||
|
|
||||||
const AndroidSslError._internal(this._value);
|
const AndroidSslError._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<AndroidSslError> values = [
|
||||||
|
AndroidSslError.SSL_NOTYETVALID,
|
||||||
|
AndroidSslError.SSL_EXPIRED,
|
||||||
|
AndroidSslError.SSL_IDMISMATCH,
|
||||||
|
AndroidSslError.SSL_UNTRUSTED,
|
||||||
|
AndroidSslError.SSL_DATE_INVALID,
|
||||||
|
AndroidSslError.SSL_INVALID,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static AndroidSslError fromValue(int value) {
|
static AndroidSslError fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 5)
|
if (value != null)
|
||||||
return AndroidSslError._internal(value);
|
return AndroidSslError.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3642,9 +3813,18 @@ class IOSSslError {
|
||||||
|
|
||||||
const IOSSslError._internal(this._value);
|
const IOSSslError._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSSslError> values = [
|
||||||
|
IOSSslError.INVALID,
|
||||||
|
IOSSslError.DENY,
|
||||||
|
IOSSslError.UNSPECIFIED,
|
||||||
|
IOSSslError.RECOVERABLE_TRUST_FAILURE,
|
||||||
|
IOSSslError.FATAL_TRUST_FAILURE,
|
||||||
|
IOSSslError.OTHER_ERROR,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSSslError fromValue(int value) {
|
static IOSSslError fromValue(int value) {
|
||||||
if (value != null && [0, 3, 4, 5, 6, 7].contains(value))
|
if (value != null)
|
||||||
return IOSSslError._internal(value);
|
return IOSSslError.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3701,9 +3881,16 @@ class IOSUIScrollViewContentInsetAdjustmentBehavior {
|
||||||
|
|
||||||
const IOSUIScrollViewContentInsetAdjustmentBehavior._internal(this._value);
|
const IOSUIScrollViewContentInsetAdjustmentBehavior._internal(this._value);
|
||||||
|
|
||||||
|
static final Set<IOSUIScrollViewContentInsetAdjustmentBehavior> values = [
|
||||||
|
IOSUIScrollViewContentInsetAdjustmentBehavior.AUTOMATIC,
|
||||||
|
IOSUIScrollViewContentInsetAdjustmentBehavior.SCROLLABLE_AXES,
|
||||||
|
IOSUIScrollViewContentInsetAdjustmentBehavior.NEVER,
|
||||||
|
IOSUIScrollViewContentInsetAdjustmentBehavior.ALWAYS,
|
||||||
|
].toSet();
|
||||||
|
|
||||||
static IOSUIScrollViewContentInsetAdjustmentBehavior fromValue(int value) {
|
static IOSUIScrollViewContentInsetAdjustmentBehavior fromValue(int value) {
|
||||||
if (value != null && value >= 0 && value <= 3)
|
if (value != null)
|
||||||
return IOSUIScrollViewContentInsetAdjustmentBehavior._internal(value);
|
return IOSUIScrollViewContentInsetAdjustmentBehavior.values.firstWhere((element) => element.toValue() == value, orElse: () => null);
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3725,16 +3912,20 @@ class IOSUIScrollViewContentInsetAdjustmentBehavior {
|
||||||
}
|
}
|
||||||
|
|
||||||
///Automatically adjust the scroll view insets.
|
///Automatically adjust the scroll view insets.
|
||||||
static const AUTOMATIC = const IOSUIScrollViewContentInsetAdjustmentBehavior._internal(0);
|
static const AUTOMATIC = const IOSUIScrollViewContentInsetAdjustmentBehavior
|
||||||
|
._internal(0);
|
||||||
|
|
||||||
///Adjust the insets only in the scrollable directions.
|
///Adjust the insets only in the scrollable directions.
|
||||||
static const SCROLLABLE_AXES = const IOSUIScrollViewContentInsetAdjustmentBehavior._internal(1);
|
static const SCROLLABLE_AXES = const IOSUIScrollViewContentInsetAdjustmentBehavior
|
||||||
|
._internal(1);
|
||||||
|
|
||||||
///Do not adjust the scroll view insets.
|
///Do not adjust the scroll view insets.
|
||||||
static const NEVER = const IOSUIScrollViewContentInsetAdjustmentBehavior._internal(2);
|
static const NEVER = const IOSUIScrollViewContentInsetAdjustmentBehavior
|
||||||
|
._internal(2);
|
||||||
|
|
||||||
///Always include the safe area insets in the content adjustment.
|
///Always include the safe area insets in the content adjustment.
|
||||||
static const ALWAYS = const IOSUIScrollViewContentInsetAdjustmentBehavior._internal(3);
|
static const ALWAYS = const IOSUIScrollViewContentInsetAdjustmentBehavior
|
||||||
|
._internal(3);
|
||||||
|
|
||||||
bool operator ==(value) => value == _value;
|
bool operator ==(value) => value == _value;
|
||||||
|
|
||||||
|
@ -3778,10 +3969,14 @@ class SslCertificate {
|
||||||
}
|
}
|
||||||
|
|
||||||
return map != null ? SslCertificate(
|
return map != null ? SslCertificate(
|
||||||
issuedBy: SslCertificateDName.fromMap(map["issuedBy"]?.cast<String, dynamic>()),
|
issuedBy: SslCertificateDName.fromMap(
|
||||||
issuedTo: SslCertificateDName.fromMap(map["issuedTo"]?.cast<String, dynamic>()),
|
map["issuedBy"]?.cast<String, dynamic>()),
|
||||||
validNotAfterDate: DateTime.fromMillisecondsSinceEpoch(map["validNotAfterDate"]),
|
issuedTo: SslCertificateDName.fromMap(
|
||||||
validNotBeforeDate: DateTime.fromMillisecondsSinceEpoch(map["validNotBeforeDate"]),
|
map["issuedTo"]?.cast<String, dynamic>()),
|
||||||
|
validNotAfterDate: DateTime.fromMillisecondsSinceEpoch(
|
||||||
|
map["validNotAfterDate"]),
|
||||||
|
validNotBeforeDate: DateTime.fromMillisecondsSinceEpoch(
|
||||||
|
map["validNotBeforeDate"]),
|
||||||
x509Certificate: x509Certificate,
|
x509Certificate: x509Certificate,
|
||||||
) : null;
|
) : null;
|
||||||
}
|
}
|
||||||
|
@ -3811,18 +4006,22 @@ class SslCertificateDName {
|
||||||
///Common-name (CN) component of the name
|
///Common-name (CN) component of the name
|
||||||
// ignore: non_constant_identifier_names
|
// ignore: non_constant_identifier_names
|
||||||
String CName;
|
String CName;
|
||||||
|
|
||||||
///Distinguished name (normally includes CN, O, and OU names)
|
///Distinguished name (normally includes CN, O, and OU names)
|
||||||
// ignore: non_constant_identifier_names
|
// ignore: non_constant_identifier_names
|
||||||
String DName;
|
String DName;
|
||||||
|
|
||||||
///Organization (O) component of the name
|
///Organization (O) component of the name
|
||||||
// ignore: non_constant_identifier_names
|
// ignore: non_constant_identifier_names
|
||||||
String OName;
|
String OName;
|
||||||
|
|
||||||
///Organizational Unit (OU) component of the name
|
///Organizational Unit (OU) component of the name
|
||||||
// ignore: non_constant_identifier_names
|
// ignore: non_constant_identifier_names
|
||||||
String UName;
|
String UName;
|
||||||
|
|
||||||
|
SslCertificateDName(
|
||||||
// ignore: non_constant_identifier_names
|
// ignore: non_constant_identifier_names
|
||||||
SslCertificateDName({this.CName = "", this.DName = "", this.OName = "", this.UName = ""});
|
{this.CName = "", this.DName = "", this.OName = "", this.UName = ""});
|
||||||
|
|
||||||
static SslCertificateDName fromMap(Map<String, dynamic> map) {
|
static SslCertificateDName fromMap(Map<String, dynamic> map) {
|
||||||
return map != null ? SslCertificateDName(
|
return map != null ? SslCertificateDName(
|
||||||
|
|
|
@ -301,12 +301,6 @@ class InAppWebViewOptions
|
||||||
InAppWebViewOptions copy() {
|
InAppWebViewOptions copy() {
|
||||||
return InAppWebViewOptions.fromMap(this.toMap());
|
return InAppWebViewOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
InAppWebViewOptions copyWithValue(InAppWebViewOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return InAppWebViewOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///This class represents all the Android-only WebView options available.
|
///This class represents all the Android-only WebView options available.
|
||||||
|
@ -709,12 +703,6 @@ class AndroidInAppWebViewOptions
|
||||||
AndroidInAppWebViewOptions copy() {
|
AndroidInAppWebViewOptions copy() {
|
||||||
return AndroidInAppWebViewOptions.fromMap(this.toMap());
|
return AndroidInAppWebViewOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
AndroidInAppWebViewOptions copyWithValue(AndroidInAppWebViewOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return AndroidInAppWebViewOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///This class represents all the iOS-only WebView options available.
|
///This class represents all the iOS-only WebView options available.
|
||||||
|
@ -783,7 +771,7 @@ class IOSInAppWebViewOptions
|
||||||
///**NOTE**: available on iOS 13.0+.
|
///**NOTE**: available on iOS 13.0+.
|
||||||
bool automaticallyAdjustsScrollIndicatorInsets;
|
bool automaticallyAdjustsScrollIndicatorInsets;
|
||||||
|
|
||||||
///A Boolean value indicating whether the view ignores an accessibility request to invert its colors.
|
///A Boolean value indicating whether the WebView ignores an accessibility request to invert its colors.
|
||||||
///The default value is `false`.
|
///The default value is `false`.
|
||||||
///
|
///
|
||||||
///**NOTE**: available on iOS 11.0+.
|
///**NOTE**: available on iOS 11.0+.
|
||||||
|
@ -949,12 +937,6 @@ class IOSInAppWebViewOptions
|
||||||
IOSInAppWebViewOptions copy() {
|
IOSInAppWebViewOptions copy() {
|
||||||
return IOSInAppWebViewOptions.fromMap(this.toMap());
|
return IOSInAppWebViewOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
IOSInAppWebViewOptions copyWithValue(IOSInAppWebViewOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return IOSInAppWebViewOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///This class represents all the cross-platform [InAppBrowser] options available.
|
///This class represents all the cross-platform [InAppBrowser] options available.
|
||||||
|
@ -1012,12 +994,6 @@ class InAppBrowserOptions
|
||||||
InAppBrowserOptions copy() {
|
InAppBrowserOptions copy() {
|
||||||
return InAppBrowserOptions.fromMap(this.toMap());
|
return InAppBrowserOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
InAppBrowserOptions copyWithValue(InAppBrowserOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return InAppBrowserOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///This class represents all the Android-only [InAppBrowser] options available.
|
///This class represents all the Android-only [InAppBrowser] options available.
|
||||||
|
@ -1073,12 +1049,6 @@ class AndroidInAppBrowserOptions implements BrowserOptions, AndroidOptions {
|
||||||
AndroidInAppBrowserOptions copy() {
|
AndroidInAppBrowserOptions copy() {
|
||||||
return AndroidInAppBrowserOptions.fromMap(this.toMap());
|
return AndroidInAppBrowserOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
AndroidInAppBrowserOptions copyWithValue(AndroidInAppBrowserOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return AndroidInAppBrowserOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///This class represents all the iOS-only [InAppBrowser] options available.
|
///This class represents all the iOS-only [InAppBrowser] options available.
|
||||||
|
@ -1160,12 +1130,6 @@ class IOSInAppBrowserOptions implements BrowserOptions, IosOptions {
|
||||||
IOSInAppBrowserOptions copy() {
|
IOSInAppBrowserOptions copy() {
|
||||||
return IOSInAppBrowserOptions.fromMap(this.toMap());
|
return IOSInAppBrowserOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
IOSInAppBrowserOptions copyWithValue(IOSInAppBrowserOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return IOSInAppBrowserOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///This class represents all the Android-only [ChromeSafariBrowser] options available.
|
///This class represents all the Android-only [ChromeSafariBrowser] options available.
|
||||||
|
@ -1245,12 +1209,6 @@ class AndroidChromeCustomTabsOptions
|
||||||
AndroidChromeCustomTabsOptions copy() {
|
AndroidChromeCustomTabsOptions copy() {
|
||||||
return AndroidChromeCustomTabsOptions.fromMap(this.toMap());
|
return AndroidChromeCustomTabsOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
AndroidChromeCustomTabsOptions copyWithValue(AndroidChromeCustomTabsOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return AndroidChromeCustomTabsOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
///This class represents all the iOS-only [ChromeSafariBrowser] options available.
|
///This class represents all the iOS-only [ChromeSafariBrowser] options available.
|
||||||
|
@ -1333,10 +1291,4 @@ class IOSSafariOptions implements ChromeSafariBrowserOptions, IosOptions {
|
||||||
IOSSafariOptions copy() {
|
IOSSafariOptions copy() {
|
||||||
return IOSSafariOptions.fromMap(this.toMap());
|
return IOSSafariOptions.fromMap(this.toMap());
|
||||||
}
|
}
|
||||||
|
|
||||||
IOSSafariOptions copyWithValue(IOSSafariOptions webViewOptions) {
|
|
||||||
var mergedMap = this.toMap();
|
|
||||||
mergedMap.addAll(webViewOptions.toMap());
|
|
||||||
return IOSSafariOptions.fromMap(mergedMap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,7 +12,6 @@ dependencies:
|
||||||
sdk: flutter
|
sdk: flutter
|
||||||
uuid: ^2.0.0
|
uuid: ^2.0.0
|
||||||
mime: ^0.9.6+2
|
mime: ^0.9.6+2
|
||||||
html: ^0.14.0+3
|
|
||||||
|
|
||||||
# For information on the generic Dart part of this file, see the
|
# For information on the generic Dart part of this file, see the
|
||||||
# following page: https://www.dartlang.org/tools/pub/pubspec
|
# following page: https://www.dartlang.org/tools/pub/pubspec
|
||||||
|
|
Loading…
Reference in New Issue