Added 'toString()' method to various classes in order to have a better output instead of simply 'Instance of ...', updated getOptions() method

This commit is contained in:
Lorenzo Pichilli 2020-05-29 19:56:03 +02:00
parent 7d88cd80be
commit ad56ca6621
32 changed files with 1341 additions and 476 deletions

View File

@ -1,5 +1,6 @@
## 3.3.0 ## 3.3.0
- Updated API docs
- Updated Android context menu workaround - Updated Android context menu workaround
- Calling `onCreateContextMenu` event on iOS also when the context menu is disabled in order to have the same effect as Android - Calling `onCreateContextMenu` event on iOS also when the context menu is disabled in order to have the same effect as Android
- Added Android keyboard workaround to hide the keyboard when clicking other HTML elements, losing the focus on the previous input - Added Android keyboard workaround to hide the keyboard when clicking other HTML elements, losing the focus on the previous input
@ -10,11 +11,13 @@
- Added `getCurrentWebViewPackage` static webview method on Android - Added `getCurrentWebViewPackage` static webview method on Android
- Added `onPageCommitVisible` webview event - Added `onPageCommitVisible` webview event
- Added `androidShouldInterceptRequest`, `androidOnRenderProcessUnresponsive`, `androidOnRenderProcessResponsive`, `androidOnRenderProcessGone`, `androidOnFormResubmission`, `androidOnScaleChanged` Android events - Added `androidShouldInterceptRequest`, `androidOnRenderProcessUnresponsive`, `androidOnRenderProcessResponsive`, `androidOnRenderProcessGone`, `androidOnFormResubmission`, `androidOnScaleChanged` Android events
- Added `toString()` method to various classes in order to have a better output instead of simply `Instance of ...`
- Fixed `Print preview is not working? java.lang.IllegalStateException: Can print only from an activity` [#128](https://github.com/pichillilorenzo/flutter_inappwebview/issues/128) - Fixed `Print preview is not working? java.lang.IllegalStateException: Can print only from an activity` [#128](https://github.com/pichillilorenzo/flutter_inappwebview/issues/128)
- Fixed `onJsAlert`, `onJsConfirm`, `onJsPrompt` for `InAppBrowser` on Android - Fixed `onJsAlert`, `onJsConfirm`, `onJsPrompt` for `InAppBrowser` on Android
- Fixed `onActivityResult` for `InAppBrowser` on Android - Fixed `onActivityResult` for `InAppBrowser` on Android
- Fixed `InAppBrowser.openWithSystemBrowser crash on iOS` [#358](https://github.com/pichillilorenzo/flutter_inappwebview/issues/358) - Fixed `InAppBrowser.openWithSystemBrowser crash on iOS` [#358](https://github.com/pichillilorenzo/flutter_inappwebview/issues/358)
- Fixed `Attempt to invoke virtual method 'java.util.Set java.util.HashMap.entrySet()' on a null object reference` [#367](https://github.com/pichillilorenzo/flutter_inappwebview/issues/367) - Fixed `Attempt to invoke virtual method 'java.util.Set java.util.HashMap.entrySet()' on a null object reference` [#367](https://github.com/pichillilorenzo/flutter_inappwebview/issues/367)
- Fixed missing `allowsAirPlayForMediaPlayback` iOS webview options implementation
### BREAKING CHANGES ### BREAKING CHANGES

View File

@ -29,13 +29,13 @@ public class ChromeCustomTabsActivity extends Activity implements MethodChannel.
protected static final String LOG_TAG = "CustomTabsActivity"; protected static final String LOG_TAG = "CustomTabsActivity";
public MethodChannel channel; public MethodChannel channel;
public String uuid; public String uuid;
private CustomTabsIntent.Builder builder; public CustomTabsIntent.Builder builder;
private ChromeCustomTabsOptions options; public ChromeCustomTabsOptions options;
private CustomTabActivityHelper customTabActivityHelper; public CustomTabActivityHelper customTabActivityHelper;
private CustomTabsSession customTabsSession; public CustomTabsSession customTabsSession;
private final int CHROME_CUSTOM_TAB_REQUEST_CODE = 100; protected final int CHROME_CUSTOM_TAB_REQUEST_CODE = 100;
private boolean onChromeSafariBrowserOpened = false; protected boolean onChromeSafariBrowserOpened = false;
private boolean onChromeSafariBrowserCompletedInitialLoad = false; protected boolean onChromeSafariBrowserCompletedInitialLoad = false;
@Override @Override
protected void onCreate(Bundle savedInstanceState) { protected void onCreate(Bundle savedInstanceState) {

View File

@ -1,11 +1,13 @@
package com.pichillilorenzo.flutter_inappwebview.ChromeCustomTabs; package com.pichillilorenzo.flutter_inappwebview.ChromeCustomTabs;
import android.content.Intent;
import com.pichillilorenzo.flutter_inappwebview.Options; import com.pichillilorenzo.flutter_inappwebview.Options;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
public class ChromeCustomTabsOptions implements Options { public class ChromeCustomTabsOptions implements Options<ChromeCustomTabsActivity> {
final static String LOG_TAG = "ChromeCustomTabsOptions"; final static String LOG_TAG = "ChromeCustomTabsOptions";
@ -18,7 +20,7 @@ public class ChromeCustomTabsOptions implements Options {
public Boolean keepAliveEnabled = false; public Boolean keepAliveEnabled = false;
@Override @Override
public ChromeCustomTabsOptions parse(HashMap<String, Object> options) { public ChromeCustomTabsOptions parse(Map<String, Object> options) {
for (Map.Entry<String, Object> pair : options.entrySet()) { for (Map.Entry<String, Object> pair : options.entrySet()) {
String key = pair.getKey(); String key = pair.getKey();
Object value = pair.getValue(); Object value = pair.getValue();
@ -55,8 +57,8 @@ public class ChromeCustomTabsOptions implements Options {
} }
@Override @Override
public HashMap<String, Object> getHashMap() { public Map<String, Object> toMap() {
HashMap<String, Object> options = new HashMap<>(); Map<String, Object> options = new HashMap<>();
options.put("addDefaultShareMenuItem", addDefaultShareMenuItem); options.put("addDefaultShareMenuItem", addDefaultShareMenuItem);
options.put("showTitle", showTitle); options.put("showTitle", showTitle);
options.put("toolbarBackgroundColor", toolbarBackgroundColor); options.put("toolbarBackgroundColor", toolbarBackgroundColor);
@ -66,4 +68,17 @@ public class ChromeCustomTabsOptions implements Options {
options.put("keepAliveEnabled", keepAliveEnabled); options.put("keepAliveEnabled", keepAliveEnabled);
return options; return options;
} }
@Override
public Map<String, Object> getRealOptions(ChromeCustomTabsActivity chromeCustomTabsActivity) {
Map<String, Object> realOptions = toMap();
if (chromeCustomTabsActivity != null) {
Intent intent = chromeCustomTabsActivity.getIntent();
if (intent != null) {
realOptions.put("packageName", intent.getPackage());
realOptions.put("keepAliveEnabled", intent.hasExtra(CustomTabsHelper.EXTRA_CUSTOM_TABS_KEEP_ALIVE));
}
}
return realOptions;
}
} }

View File

@ -18,12 +18,12 @@ import java.util.List;
* Helper class for Custom Tabs. * Helper class for Custom Tabs.
*/ */
public class CustomTabsHelper { public class CustomTabsHelper {
private static final String TAG = "CustomTabsHelper"; protected static final String TAG = "CustomTabsHelper";
static final String STABLE_PACKAGE = "com.android.chrome"; static final String STABLE_PACKAGE = "com.android.chrome";
static final String BETA_PACKAGE = "com.chrome.beta"; static final String BETA_PACKAGE = "com.chrome.beta";
static final String DEV_PACKAGE = "com.chrome.dev"; static final String DEV_PACKAGE = "com.chrome.dev";
static final String LOCAL_PACKAGE = "com.google.android.apps.chrome"; static final String LOCAL_PACKAGE = "com.google.android.apps.chrome";
private static final String EXTRA_CUSTOM_TABS_KEEP_ALIVE = protected static final String EXTRA_CUSTOM_TABS_KEEP_ALIVE =
"android.support.customtabs.extra.KEEP_ALIVE"; "android.support.customtabs.extra.KEEP_ALIVE";
private static String sPackageNameToUse; private static String sPackageNameToUse;

View File

@ -72,14 +72,14 @@ public class ChromeSafariBrowserManager implements MethodChannel.MethodCallHandl
intent = new Intent(activity, ChromeCustomTabsActivity.class); intent = new Intent(activity, ChromeCustomTabsActivity.class);
} }
// check for webview fallback // check for webview fallback
else if (!CustomTabActivityHelper.isAvailable(activity) && !uuidFallback.isEmpty()) { else if (!CustomTabActivityHelper.isAvailable(activity) && uuidFallback != null) {
Log.d(LOG_TAG, "WebView fallback declared."); Log.d(LOG_TAG, "WebView fallback declared.");
// overwrite with extras fallback parameters // overwrite with extras fallback parameters
extras.putString("uuid", uuidFallback); extras.putString("uuid", uuidFallback);
if (optionsFallback != null) if (optionsFallback != null)
extras.putSerializable("options", optionsFallback); extras.putSerializable("options", optionsFallback);
else else
extras.putSerializable("options", (new InAppBrowserOptions()).getHashMap()); extras.putSerializable("options", (Serializable) (new InAppBrowserOptions()).toMap());
intent = new Intent(activity, InAppBrowserActivity.class); intent = new Intent(activity, InAppBrowserActivity.class);
} }

View File

@ -707,12 +707,12 @@ public class InAppBrowserActivity extends AppCompatActivity implements MethodCha
options = newOptions; options = newOptions;
} }
public HashMap<String, Object> getOptions() { public Map<String, Object> getOptions() {
HashMap<String, Object> webViewOptionsMap = webView.getOptions(); Map<String, Object> webViewOptionsMap = webView.getOptions();
if (options == null || webViewOptionsMap == null) if (options == null || webViewOptionsMap == null)
return null; return null;
HashMap<String, Object> optionsMap = options.getHashMap(); Map<String, Object> optionsMap = options.getRealOptions(this);
optionsMap.putAll(webViewOptionsMap); optionsMap.putAll(webViewOptionsMap);
return optionsMap; return optionsMap;
} }

View File

@ -5,7 +5,7 @@ import com.pichillilorenzo.flutter_inappwebview.Options;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
public class InAppBrowserOptions implements Options { public class InAppBrowserOptions implements Options<InAppBrowserActivity> {
public static final String LOG_TAG = "InAppBrowserOptions"; public static final String LOG_TAG = "InAppBrowserOptions";
@ -20,7 +20,7 @@ public class InAppBrowserOptions implements Options {
public Boolean progressBar = true; public Boolean progressBar = true;
@Override @Override
public InAppBrowserOptions parse(HashMap<String, Object> options) { public InAppBrowserOptions parse(Map<String, Object> options) {
for (Map.Entry<String, Object> pair : options.entrySet()) { for (Map.Entry<String, Object> pair : options.entrySet()) {
String key = pair.getKey(); String key = pair.getKey();
Object value = pair.getValue(); Object value = pair.getValue();
@ -60,8 +60,8 @@ public class InAppBrowserOptions implements Options {
} }
@Override @Override
public HashMap<String, Object> getHashMap() { public Map<String, Object> toMap() {
HashMap<String, Object> options = new HashMap<>(); Map<String, Object> options = new HashMap<>();
options.put("hidden", hidden); options.put("hidden", hidden);
options.put("toolbarTop", toolbarTop); options.put("toolbarTop", toolbarTop);
options.put("toolbarTopBackgroundColor", toolbarTopBackgroundColor); options.put("toolbarTopBackgroundColor", toolbarTopBackgroundColor);
@ -72,4 +72,10 @@ public class InAppBrowserOptions implements Options {
options.put("progressBar", progressBar); options.put("progressBar", progressBar);
return options; return options;
} }
@Override
public Map<String, Object> getRealOptions(InAppBrowserActivity inAppBrowserActivity) {
Map<String, Object> realOptions = toMap();
return realOptions;
}
} }

View File

@ -1,7 +1,6 @@
package com.pichillilorenzo.flutter_inappwebview.InAppWebView; package com.pichillilorenzo.flutter_inappwebview.InAppWebView;
import android.content.Context; import android.content.Context;
import android.content.Intent;
import android.graphics.Bitmap; import android.graphics.Bitmap;
import android.graphics.Canvas; import android.graphics.Canvas;
import android.graphics.Color; import android.graphics.Color;
@ -73,6 +72,7 @@ final public class InAppWebView extends InputAwareWebView {
public InAppWebViewClient inAppWebViewClient; public InAppWebViewClient inAppWebViewClient;
public InAppWebViewChromeClient inAppWebViewChromeClient; public InAppWebViewChromeClient inAppWebViewChromeClient;
public InAppWebViewRenderProcessClient inAppWebViewRenderProcessClient; public InAppWebViewRenderProcessClient inAppWebViewRenderProcessClient;
public JavaScriptBridgeInterface javaScriptBridgeInterface;
public InAppWebViewOptions options; public InAppWebViewOptions options;
public boolean isLoading = false; public boolean isLoading = false;
public OkHttpClient httpClient; public OkHttpClient httpClient;
@ -632,7 +632,8 @@ final public class InAppWebView extends InputAwareWebView {
httpClient = new OkHttpClient().newBuilder().build(); httpClient = new OkHttpClient().newBuilder().build();
addJavascriptInterface(new JavaScriptBridgeInterface((isFromInAppBrowserActivity) ? inAppBrowserActivity : flutterWebView), JavaScriptBridgeInterface.name); javaScriptBridgeInterface = new JavaScriptBridgeInterface((isFromInAppBrowserActivity) ? inAppBrowserActivity : flutterWebView);
addJavascriptInterface(javaScriptBridgeInterface, JavaScriptBridgeInterface.name);
inAppWebViewChromeClient = new InAppWebViewChromeClient((isFromInAppBrowserActivity) ? inAppBrowserActivity : flutterWebView); inAppWebViewChromeClient = new InAppWebViewChromeClient((isFromInAppBrowserActivity) ? inAppBrowserActivity : flutterWebView);
setWebChromeClient(inAppWebViewChromeClient); setWebChromeClient(inAppWebViewChromeClient);
@ -1373,8 +1374,8 @@ final public class InAppWebView extends InputAwareWebView {
options = newOptions; options = newOptions;
} }
public HashMap<String, Object> getOptions() { public Map<String, Object> getOptions() {
return (options != null) ? options.getHashMap() : null; return (options != null) ? options.getRealOptions(this) : null;
} }
public void injectDeferredObject(String source, String jsWrapper, final MethodChannel.Result result) { public void injectDeferredObject(String source, String jsWrapper, final MethodChannel.Result result) {

View File

@ -5,18 +5,17 @@ import android.util.Log;
import android.view.View; import android.view.View;
import android.webkit.WebSettings; import android.webkit.WebSettings;
import com.pichillilorenzo.flutter_inappwebview.ChromeCustomTabs.ChromeCustomTabsOptions;
import com.pichillilorenzo.flutter_inappwebview.Options; import com.pichillilorenzo.flutter_inappwebview.Options;
import java.lang.reflect.Field;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import static android.webkit.WebSettings.LayoutAlgorithm.NARROW_COLUMNS;
import static android.webkit.WebSettings.LayoutAlgorithm.NORMAL; import static android.webkit.WebSettings.LayoutAlgorithm.NORMAL;
public class InAppWebViewOptions implements Options { public class InAppWebViewOptions implements Options<InAppWebView> {
public static final String LOG_TAG = "InAppWebViewOptions"; public static final String LOG_TAG = "InAppWebViewOptions";
@ -99,7 +98,7 @@ public class InAppWebViewOptions implements Options {
public Boolean useOnRenderProcessGone = false; public Boolean useOnRenderProcessGone = false;
@Override @Override
public InAppWebViewOptions parse(HashMap<String, Object> options) { public InAppWebViewOptions parse(Map<String, Object> options) {
for (Map.Entry<String, Object> pair : options.entrySet()) { for (Map.Entry<String, Object> pair : options.entrySet()) {
String key = pair.getKey(); String key = pair.getKey();
Object value = pair.getValue(); Object value = pair.getValue();
@ -343,8 +342,8 @@ public class InAppWebViewOptions implements Options {
} }
@Override @Override
public HashMap<String, Object> getHashMap() { public Map<String, Object> toMap() {
HashMap<String, Object> options = new HashMap<>(); Map<String, Object> options = new HashMap<>();
options.put("useShouldOverrideUrlLoading", useShouldOverrideUrlLoading); options.put("useShouldOverrideUrlLoading", useShouldOverrideUrlLoading);
options.put("useOnLoadResource", useOnLoadResource); options.put("useOnLoadResource", useOnLoadResource);
options.put("useOnDownloadStart", useOnDownloadStart); options.put("useOnDownloadStart", useOnDownloadStart);
@ -424,9 +423,83 @@ public class InAppWebViewOptions implements Options {
return options; return options;
} }
@Override
public Map<String, Object> getRealOptions(InAppWebView webView) {
Map<String, Object> realOptions = toMap();
if (webView != null) {
WebSettings settings = webView.getSettings();
realOptions.put("userAgent", settings.getUserAgentString());
realOptions.put("javaScriptEnabled", settings.getJavaScriptEnabled());
realOptions.put("javaScriptCanOpenWindowsAutomatically", settings.getJavaScriptCanOpenWindowsAutomatically());
realOptions.put("mediaPlaybackRequiresUserGesture", settings.getMediaPlaybackRequiresUserGesture());
realOptions.put("minimumFontSize", settings.getMinimumFontSize());
realOptions.put("verticalScrollBarEnabled", webView.isVerticalScrollBarEnabled());
realOptions.put("horizontalScrollBarEnabled", webView.isHorizontalScrollBarEnabled());
realOptions.put("textZoom", settings.getTextZoom());
realOptions.put("builtInZoomControls", settings.getBuiltInZoomControls());
realOptions.put("supportZoom", settings.supportZoom());
realOptions.put("displayZoomControls", settings.getDisplayZoomControls());
realOptions.put("databaseEnabled", settings.getDatabaseEnabled());
realOptions.put("domStorageEnabled", settings.getDomStorageEnabled());
realOptions.put("useWideViewPort", settings.getUseWideViewPort());
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
realOptions.put("safeBrowsingEnabled", settings.getSafeBrowsingEnabled());
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
realOptions.put("mixedContentMode", settings.getMixedContentMode());
}
realOptions.put("allowContentAccess", settings.getAllowContentAccess());
realOptions.put("allowFileAccess", settings.getAllowFileAccess());
realOptions.put("allowFileAccessFromFileURLs", settings.getAllowFileAccessFromFileURLs());
realOptions.put("allowUniversalAccessFromFileURLs", settings.getAllowUniversalAccessFromFileURLs());
realOptions.put("blockNetworkImage", settings.getBlockNetworkImage());
realOptions.put("blockNetworkLoads", settings.getBlockNetworkLoads());
realOptions.put("cacheMode", settings.getCacheMode());
realOptions.put("cursiveFontFamily", settings.getCursiveFontFamily());
realOptions.put("defaultFixedFontSize", settings.getDefaultFixedFontSize());
realOptions.put("defaultFontSize", settings.getDefaultFontSize());
realOptions.put("defaultTextEncodingName", settings.getDefaultTextEncodingName());
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
realOptions.put("disabledActionModeMenuItems", settings.getDisabledActionModeMenuItems());
}
realOptions.put("fantasyFontFamily", settings.getFantasyFontFamily());
realOptions.put("fixedFontFamily", settings.getFixedFontFamily());
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
realOptions.put("forceDark", settings.getForceDark());
}
realOptions.put("layoutAlgorithm", settings.getLayoutAlgorithm().name());
realOptions.put("loadWithOverviewMode", settings.getLoadWithOverviewMode());
realOptions.put("loadsImagesAutomatically", settings.getLoadsImagesAutomatically());
realOptions.put("minimumLogicalFontSize", settings.getMinimumLogicalFontSize());
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
realOptions.put("offscreenPreRaster", settings.getOffscreenPreRaster());
}
realOptions.put("sansSerifFontFamily", settings.getSansSerifFontFamily());
realOptions.put("serifFontFamily", settings.getSerifFontFamily());
realOptions.put("standardFontFamily", settings.getStandardFontFamily());
realOptions.put("saveFormData", settings.getSaveFormData());
realOptions.put("supportMultipleWindows", settings.supportMultipleWindows());
realOptions.put("overScrollMode", webView.getOverScrollMode());
realOptions.put("scrollBarStyle", webView.getScrollBarStyle());
realOptions.put("verticalScrollbarPosition", webView.getVerticalScrollbarPosition());
realOptions.put("scrollBarDefaultDelayBeforeFade", webView.getScrollBarDefaultDelayBeforeFade());
realOptions.put("scrollbarFadingEnabled", webView.isScrollbarFadingEnabled());
realOptions.put("scrollBarFadeDuration", webView.getScrollBarFadeDuration());
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
Map<String, Object> rendererPriorityPolicy = new HashMap<>();
rendererPriorityPolicy.put("rendererRequestedPriority", webView.getRendererRequestedPriority());
rendererPriorityPolicy.put("waivedWhenNotVisible", webView.getRendererPriorityWaivedWhenNotVisible());
realOptions.put("rendererPriorityPolicy", rendererPriorityPolicy);
}
}
return realOptions;
}
private void setLayoutAlgorithm(String value) { private void setLayoutAlgorithm(String value) {
if (value != null) { if (value != null) {
switch (value) { switch (value) {
case "NARROW_COLUMNS":
layoutAlgorithm = NARROW_COLUMNS;
case "NORMAL": case "NORMAL":
layoutAlgorithm = NORMAL; layoutAlgorithm = NORMAL;
case "TEXT_AUTOSIZING": case "TEXT_AUTOSIZING":
@ -451,6 +524,8 @@ public class InAppWebViewOptions implements Options {
} else { } else {
return "NORMAL"; return "NORMAL";
} }
case NARROW_COLUMNS:
return "NARROW_COLUMNS";
} }
} }
return null; return null;

View File

@ -1,9 +1,10 @@
package com.pichillilorenzo.flutter_inappwebview; package com.pichillilorenzo.flutter_inappwebview;
import java.util.HashMap; import java.util.Map;
public interface Options { public interface Options<T> {
static String LOG_TAG = "Options"; static String LOG_TAG = "Options";
public Options parse(HashMap<String, Object> options); public Options parse(Map<String, Object> options);
public HashMap<String, Object> getHashMap(); public Map<String, Object> toMap();
public Map<String, Object> getRealOptions(T webView);
} }

View File

@ -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_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","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_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","dependencies":[]},{"name":"permission_handler","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/permission_handler-5.0.0+hotfix.6/","dependencies":[]}],"macos":[],"linux":[],"windows":[],"web":[]},"dependencyGraph":[{"name":"e2e","dependencies":[]},{"name":"flutter_inappwebview","dependencies":[]},{"name":"permission_handler","dependencies":[]}],"date_created":"2020-05-29 10:25:22.515235","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_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","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_inappwebview","path":"/Users/lorenzopichilli/Desktop/flutter_inappwebview/","dependencies":[]},{"name":"permission_handler","path":"/Users/lorenzopichilli/flutter/.pub-cache/hosted/pub.dartlang.org/permission_handler-5.0.0+hotfix.6/","dependencies":[]}],"macos":[],"linux":[],"windows":[],"web":[]},"dependencyGraph":[{"name":"e2e","dependencies":[]},{"name":"flutter_inappwebview","dependencies":[]},{"name":"permission_handler","dependencies":[]}],"date_created":"2020-05-29 19:53:44.213613","version":"1.17.1"}

View File

@ -4,7 +4,7 @@ import 'package:flutter_inappwebview/flutter_inappwebview.dart';
import 'main.dart'; import 'main.dart';
class MyChromeSafariBrowser extends ChromeSafariBrowser { class MyChromeSafariBrowser extends ChromeSafariBrowser {
MyChromeSafariBrowser(browserFallback) : super(bFallback: browserFallback); MyChromeSafariBrowser({browserFallback}) : super(bFallback: browserFallback);
@override @override
void onOpened() { void onOpened() {
@ -24,23 +24,23 @@ class MyChromeSafariBrowser extends ChromeSafariBrowser {
class ChromeSafariBrowserExampleScreen extends StatefulWidget { class ChromeSafariBrowserExampleScreen extends StatefulWidget {
final ChromeSafariBrowser browser = final ChromeSafariBrowser browser =
new MyChromeSafariBrowser(new InAppBrowser()); MyChromeSafariBrowser(browserFallback: InAppBrowser());
@override @override
_ChromeSafariBrowserExampleScreenState createState() => _ChromeSafariBrowserExampleScreenState createState() =>
new _ChromeSafariBrowserExampleScreenState(); _ChromeSafariBrowserExampleScreenState();
} }
class _ChromeSafariBrowserExampleScreenState class _ChromeSafariBrowserExampleScreenState
extends State<ChromeSafariBrowserExampleScreen> { extends State<ChromeSafariBrowserExampleScreen> {
@override @override
void initState() { void initState() {
widget.browser.addMenuItem(new ChromeSafariBrowserMenuItem(id: 1, label: 'Custom item menu 1', action: (url, title) { widget.browser.addMenuItem(ChromeSafariBrowserMenuItem(id: 1, label: 'Custom item menu 1', action: (url, title) {
print('Custom item menu 1 clicked!'); print('Custom item menu 1 clicked!');
print(url); print(url);
print(title); print(title);
})); }));
widget.browser.addMenuItem(new ChromeSafariBrowserMenuItem(id: 2, label: 'Custom item menu 2', action: (url, title) { widget.browser.addMenuItem(ChromeSafariBrowserMenuItem(id: 2, label: 'Custom item menu 2', action: (url, title) {
print('Custom item menu 2 clicked!'); print('Custom item menu 2 clicked!');
print(url); print(url);
print(title); print(title);

View File

@ -39,10 +39,10 @@ public class ChromeSafariBrowserManager: NSObject, FlutterPlugin {
let url = arguments!["url"] as! String let url = arguments!["url"] as! String
let options = arguments!["options"] as! [String: Any?] let options = arguments!["options"] as! [String: Any?]
let menuItemList = arguments!["menuItemList"] as! [[String: Any]] let menuItemList = arguments!["menuItemList"] as! [[String: Any]]
let uuidFallback: String = arguments!["uuidFallback"] as! String let uuidFallback = arguments!["uuidFallback"] as? String
let headersFallback = arguments!["headersFallback"] as! [String: String] let headersFallback = arguments!["headersFallback"] as? [String: String]
let optionsFallback = arguments!["optionsFallback"] as! [String: Any?] let optionsFallback = arguments!["optionsFallback"] as? [String: Any?]
let contextMenuFallback = arguments!["contextMenuFallback"] as! [String: Any] let contextMenuFallback = arguments!["contextMenuFallback"] as? [String: Any]
open(uuid: uuid, url: url, options: options, menuItemList: menuItemList, uuidFallback: uuidFallback, headersFallback: headersFallback, optionsFallback: optionsFallback, contextMenuFallback: contextMenuFallback, result: result) open(uuid: uuid, url: url, options: options, menuItemList: menuItemList, uuidFallback: uuidFallback, headersFallback: headersFallback, optionsFallback: optionsFallback, contextMenuFallback: contextMenuFallback, result: result)
break break
default: default:
@ -51,7 +51,7 @@ public class ChromeSafariBrowserManager: NSObject, FlutterPlugin {
} }
} }
public func open(uuid: String, url: String, options: [String: Any?], menuItemList: [[String: Any]], uuidFallback: String, headersFallback: [String: String], optionsFallback: [String: Any?], contextMenuFallback: [String: Any], result: @escaping FlutterResult) { public func open(uuid: String, url: String, options: [String: Any?], menuItemList: [[String: Any]], uuidFallback: String?, headersFallback: [String: String]?, optionsFallback: [String: Any?]?, contextMenuFallback: [String: Any]?, result: @escaping FlutterResult) {
let absoluteUrl = URL(string: url)!.absoluteURL let absoluteUrl = URL(string: url)!.absoluteURL
if self.previousStatusBarStyle == -1 { if self.previousStatusBarStyle == -1 {
@ -106,7 +106,7 @@ public class ChromeSafariBrowserManager: NSObject, FlutterPlugin {
return return
} }
SwiftFlutterPlugin.instance!.inAppBrowserManager!.openUrl(uuid: uuidFallback, url: url, options: optionsFallback, headers: headersFallback, contextMenu: contextMenuFallback) SwiftFlutterPlugin.instance!.inAppBrowserManager!.openUrl(uuid: uuidFallback!, url: url, options: optionsFallback ?? [:], headers: headersFallback ?? [:], contextMenu: contextMenuFallback ?? [:])
} }
} }
} }

View File

@ -8,7 +8,7 @@
import Foundation import Foundation
@objcMembers @objcMembers
public class InAppBrowserOptions: Options { public class InAppBrowserOptions: Options<InAppBrowserWebViewController> {
var hidden = false var hidden = false
var toolbarTop = true var toolbarTop = true
@ -29,5 +29,12 @@ public class InAppBrowserOptions: Options {
super.init() super.init()
} }
override func getRealOptions(obj: InAppBrowserWebViewController?) -> [String: Any?] {
var realOptions: [String: Any?] = toMap()
if let inAppBrowserWebViewController = obj {
realOptions["presentationStyle"] = inAppBrowserWebViewController.modalPresentationStyle.rawValue
realOptions["transitionStyle"] = inAppBrowserWebViewController.modalTransitionStyle.rawValue
}
return realOptions
}
} }

View File

@ -688,11 +688,12 @@ public class InAppBrowserWebViewController: UIViewController, FlutterPlugin, UIS
} }
public func getOptions() -> [String: Any?]? { public func getOptions() -> [String: Any?]? {
if (self.browserOptions == nil || self.webView.getOptions() == nil) { let webViewOptionsMap = self.webView.getOptions()
if (self.browserOptions == nil || webViewOptionsMap == nil) {
return nil return nil
} }
var optionsMap = self.browserOptions!.getHashMap() var optionsMap = self.browserOptions!.getRealOptions(obj: self)
optionsMap.merge(self.webView.getOptions()!, uniquingKeysWith: { (current, _) in current }) optionsMap.merge(webViewOptionsMap!, uniquingKeysWith: { (current, _) in current })
return optionsMap return optionsMap
} }

View File

@ -1056,6 +1056,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
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.allowsPictureInPictureMediaPlayback = (options?.allowsPictureInPictureMediaPlayback)! configuration.allowsPictureInPictureMediaPlayback = (options?.allowsPictureInPictureMediaPlayback)!
if (options?.applicationNameForUserAgent != nil && (options?.applicationNameForUserAgent)! != "") { if (options?.applicationNameForUserAgent != nil && (options?.applicationNameForUserAgent)! != "") {
configuration.applicationNameForUserAgent = (options?.applicationNameForUserAgent)! configuration.applicationNameForUserAgent = (options?.applicationNameForUserAgent)!
@ -1075,7 +1076,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
var dataDetectorTypes = WKDataDetectorTypes.init(rawValue: 0) var dataDetectorTypes = WKDataDetectorTypes.init(rawValue: 0)
for type in options?.dataDetectorTypes ?? [] { for type in options?.dataDetectorTypes ?? [] {
let dataDetectorType = getDataDetectorType(type: type) let dataDetectorType = InAppWebView.getDataDetectorType(type: type)
dataDetectorTypes = WKDataDetectorTypes(rawValue: dataDetectorTypes.rawValue | dataDetectorType.rawValue) dataDetectorTypes = WKDataDetectorTypes(rawValue: dataDetectorTypes.rawValue | dataDetectorType.rawValue)
} }
configuration.dataDetectorTypes = dataDetectorTypes configuration.dataDetectorTypes = dataDetectorTypes
@ -1094,7 +1095,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
scrollView.showsVerticalScrollIndicator = (options?.verticalScrollBarEnabled)! scrollView.showsVerticalScrollIndicator = (options?.verticalScrollBarEnabled)!
scrollView.showsHorizontalScrollIndicator = (options?.horizontalScrollBarEnabled)! scrollView.showsHorizontalScrollIndicator = (options?.horizontalScrollBarEnabled)!
scrollView.decelerationRate = 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)!
@ -1110,7 +1111,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
} }
@available(iOS 10.0, *) @available(iOS 10.0, *)
public func getDataDetectorType(type: String) -> WKDataDetectorTypes { static public func getDataDetectorType(type: String) -> WKDataDetectorTypes {
switch type { switch type {
case "NONE": case "NONE":
return WKDataDetectorTypes.init(rawValue: 0) return WKDataDetectorTypes.init(rawValue: 0)
@ -1137,7 +1138,44 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
} }
} }
public func getDecelerationRate(type: String) -> UIScrollView.DecelerationRate { @available(iOS 10.0, *)
static public func getDataDetectorTypeString(type: WKDataDetectorTypes) -> [String] {
var dataDetectorTypeString: [String] = []
if type.contains(.all) {
dataDetectorTypeString.append("ALL")
} else {
if type.contains(.phoneNumber) {
dataDetectorTypeString.append("PHONE_NUMBER")
}
if type.contains(.link) {
dataDetectorTypeString.append("LINK")
}
if type.contains(.address) {
dataDetectorTypeString.append("ADDRESS")
}
if type.contains(.calendarEvent) {
dataDetectorTypeString.append("CALENDAR_EVENT")
}
if type.contains(.trackingNumber) {
dataDetectorTypeString.append("TRACKING_NUMBER")
}
if type.contains(.flightNumber) {
dataDetectorTypeString.append("FLIGHT_NUMBER")
}
if type.contains(.lookupSuggestion) {
dataDetectorTypeString.append("LOOKUP_SUGGESTION")
}
if type.contains(.spotlightSuggestion) {
dataDetectorTypeString.append("SPOTLIGHT_SUGGESTION")
}
}
if dataDetectorTypeString.count == 0 {
dataDetectorTypeString = ["NONE"]
}
return dataDetectorTypeString
}
static public func getDecelerationRate(type: String) -> UIScrollView.DecelerationRate {
switch type { switch type {
case "NORMAL": case "NORMAL":
return .normal return .normal
@ -1148,6 +1186,17 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
} }
} }
static public func getDecelerationRateString(type: UIScrollView.DecelerationRate) -> String {
switch type {
case .normal:
return "NORMAL"
case .fast:
return "FAST"
default:
return "NORMAL"
}
}
public static func preWKWebViewConfiguration(options: InAppWebViewOptions?) -> WKWebViewConfiguration { public static func preWKWebViewConfiguration(options: InAppWebViewOptions?) -> WKWebViewConfiguration {
let configuration = WKWebViewConfiguration() let configuration = WKWebViewConfiguration()
@ -1403,10 +1452,6 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
allowsBackForwardNavigationGestures = newOptions.allowsBackForwardNavigationGestures allowsBackForwardNavigationGestures = newOptions.allowsBackForwardNavigationGestures
} }
if newOptionsMap["allowsInlineMediaPlayback"] != nil && options?.allowsInlineMediaPlayback != newOptions.allowsInlineMediaPlayback {
configuration.allowsInlineMediaPlayback = newOptions.allowsInlineMediaPlayback
}
if newOptionsMap["javaScriptCanOpenWindowsAutomatically"] != nil && options?.javaScriptCanOpenWindowsAutomatically != newOptions.javaScriptCanOpenWindowsAutomatically { if newOptionsMap["javaScriptCanOpenWindowsAutomatically"] != nil && options?.javaScriptCanOpenWindowsAutomatically != newOptions.javaScriptCanOpenWindowsAutomatically {
configuration.preferences.javaScriptCanOpenWindowsAutomatically = newOptions.javaScriptCanOpenWindowsAutomatically configuration.preferences.javaScriptCanOpenWindowsAutomatically = newOptions.javaScriptCanOpenWindowsAutomatically
} }
@ -1431,7 +1476,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
if newOptionsMap["dataDetectorTypes"] != nil && options?.dataDetectorTypes != newOptions.dataDetectorTypes { if newOptionsMap["dataDetectorTypes"] != nil && options?.dataDetectorTypes != newOptions.dataDetectorTypes {
var dataDetectorTypes = WKDataDetectorTypes.init(rawValue: 0) var dataDetectorTypes = WKDataDetectorTypes.init(rawValue: 0)
for type in newOptions.dataDetectorTypes { for type in newOptions.dataDetectorTypes {
let dataDetectorType = getDataDetectorType(type: type) let dataDetectorType = InAppWebView.getDataDetectorType(type: type)
dataDetectorTypes = WKDataDetectorTypes(rawValue: dataDetectorTypes.rawValue | dataDetectorType.rawValue) dataDetectorTypes = WKDataDetectorTypes(rawValue: dataDetectorTypes.rawValue | dataDetectorType.rawValue)
} }
configuration.dataDetectorTypes = dataDetectorTypes configuration.dataDetectorTypes = dataDetectorTypes
@ -1465,7 +1510,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
} }
if newOptionsMap["decelerationRate"] != nil && options?.decelerationRate != newOptions.decelerationRate { if newOptionsMap["decelerationRate"] != nil && options?.decelerationRate != newOptions.decelerationRate {
scrollView.decelerationRate = getDecelerationRate(type: newOptions.decelerationRate) scrollView.decelerationRate = InAppWebView.getDecelerationRate(type: newOptions.decelerationRate)
} }
if newOptionsMap["alwaysBounceVertical"] != nil && options?.alwaysBounceVertical != newOptions.alwaysBounceVertical { if newOptionsMap["alwaysBounceVertical"] != nil && options?.alwaysBounceVertical != newOptions.alwaysBounceVertical {
scrollView.alwaysBounceVertical = newOptions.alwaysBounceVertical scrollView.alwaysBounceVertical = newOptions.alwaysBounceVertical
@ -1490,6 +1535,9 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
if newOptionsMap["allowsLinkPreview"] != nil && options?.allowsLinkPreview != newOptions.allowsLinkPreview { if newOptionsMap["allowsLinkPreview"] != nil && options?.allowsLinkPreview != newOptions.allowsLinkPreview {
allowsLinkPreview = newOptions.allowsLinkPreview allowsLinkPreview = newOptions.allowsLinkPreview
} }
if newOptionsMap["allowsAirPlayForMediaPlayback"] != nil && options?.allowsAirPlayForMediaPlayback != newOptions.allowsAirPlayForMediaPlayback {
configuration.allowsAirPlayForMediaPlayback = newOptions.allowsAirPlayForMediaPlayback
}
if newOptionsMap["allowsPictureInPictureMediaPlayback"] != nil && options?.allowsPictureInPictureMediaPlayback != newOptions.allowsPictureInPictureMediaPlayback { if newOptionsMap["allowsPictureInPictureMediaPlayback"] != nil && options?.allowsPictureInPictureMediaPlayback != newOptions.allowsPictureInPictureMediaPlayback {
configuration.allowsPictureInPictureMediaPlayback = newOptions.allowsPictureInPictureMediaPlayback configuration.allowsPictureInPictureMediaPlayback = newOptions.allowsPictureInPictureMediaPlayback
} }
@ -1534,7 +1582,7 @@ public class InAppWebView: WKWebView, UIScrollViewDelegate, WKUIDelegate, WKNavi
if (self.options == nil) { if (self.options == nil) {
return nil return nil
} }
return self.options!.getHashMap() return self.options!.getRealOptions(obj: self)
} }
public func clearCache() { public func clearCache() {

View File

@ -9,7 +9,7 @@ import Foundation
import WebKit import WebKit
@objcMembers @objcMembers
public class InAppWebViewOptions: Options { public class InAppWebViewOptions: Options<InAppWebView> {
var useShouldOverrideUrlLoading = false var useShouldOverrideUrlLoading = false
var useOnLoadResource = false var useOnLoadResource = false
@ -63,4 +63,47 @@ public class InAppWebViewOptions: Options {
super.init() super.init()
} }
override func getRealOptions(obj: InAppWebView?) -> [String: Any?] {
var realOptions: [String: Any?] = toMap()
if let webView = obj {
let configuration = webView.configuration
if #available(iOS 9.0, *) {
realOptions["userAgent"] = webView.customUserAgent
realOptions["applicationNameForUserAgent"] = configuration.applicationNameForUserAgent
realOptions["allowsAirPlayForMediaPlayback"] = configuration.allowsAirPlayForMediaPlayback
realOptions["allowsLinkPreview"] = webView.allowsLinkPreview
realOptions["allowsPictureInPictureMediaPlayback"] = configuration.allowsPictureInPictureMediaPlayback
}
realOptions["javaScriptEnabled"] = configuration.preferences.javaScriptEnabled
realOptions["javaScriptCanOpenWindowsAutomatically"] = configuration.preferences.javaScriptCanOpenWindowsAutomatically
if #available(iOS 10.0, *) {
realOptions["mediaPlaybackRequiresUserGesture"] = configuration.mediaTypesRequiringUserActionForPlayback == .all
realOptions["ignoresViewportScaleLimits"] = configuration.ignoresViewportScaleLimits
realOptions["dataDetectorTypes"] = InAppWebView.getDataDetectorTypeString(type: configuration.dataDetectorTypes)
} else {
realOptions["mediaPlaybackRequiresUserGesture"] = configuration.mediaPlaybackRequiresUserAction
}
realOptions["minimumFontSize"] = configuration.preferences.minimumFontSize
realOptions["suppressesIncrementalRendering"] = configuration.suppressesIncrementalRendering
realOptions["allowsBackForwardNavigationGestures"] = webView.allowsBackForwardNavigationGestures
realOptions["allowsInlineMediaPlayback"] = configuration.allowsInlineMediaPlayback
if #available(iOS 13.0, *) {
realOptions["isFraudulentWebsiteWarningEnabled"] = configuration.preferences.isFraudulentWebsiteWarningEnabled
realOptions["preferredContentMode"] = configuration.defaultWebpagePreferences.preferredContentMode.rawValue
realOptions["automaticallyAdjustsScrollIndicatorInsets"] = webView.scrollView.automaticallyAdjustsScrollIndicatorInsets
}
realOptions["selectionGranularity"] = configuration.selectionGranularity.rawValue
if #available(iOS 11.0, *) {
realOptions["accessibilityIgnoresInvertColors"] = webView.accessibilityIgnoresInvertColors
}
realOptions["decelerationRate"] = InAppWebView.getDecelerationRateString(type: webView.scrollView.decelerationRate)
realOptions["alwaysBounceVertical"] = webView.scrollView.alwaysBounceVertical
realOptions["alwaysBounceHorizontal"] = webView.scrollView.alwaysBounceHorizontal
realOptions["scrollsToTop"] = webView.scrollView.scrollsToTop
realOptions["isPagingEnabled"] = webView.scrollView.isPagingEnabled
realOptions["maximumZoomScale"] = webView.scrollView.maximumZoomScale
realOptions["minimumZoomScale"] = webView.scrollView.minimumZoomScale
}
return realOptions
}
} }

View File

@ -8,7 +8,7 @@
import Foundation import Foundation
@objcMembers @objcMembers
public class Options: NSObject { public class Options<T>: NSObject {
override init(){ override init(){
super.init() super.init()
@ -23,7 +23,7 @@ public class Options: NSObject {
return self return self
} }
func getHashMap() -> [String: Any?] { func toMap() -> [String: Any?] {
var options: [String: Any?] = [:] var options: [String: Any?] = [:]
var counts = UInt32(); var counts = UInt32();
let properties = class_copyPropertyList(object_getClass(self), &counts); let properties = class_copyPropertyList(object_getClass(self), &counts);
@ -38,4 +38,9 @@ public class Options: NSObject {
free(properties) free(properties)
return options return options
} }
func getRealOptions(obj: T?) -> [String: Any?] {
let realOptions: [String: Any?] = toMap()
return realOptions
}
} }

View File

@ -7,8 +7,9 @@
import Foundation import Foundation
@available(iOS 9.0, *)
@objcMembers @objcMembers
public class SafariBrowserOptions: Options { public class SafariBrowserOptions: Options<SafariViewController> {
var entersReaderIfAvailable = false var entersReaderIfAvailable = false
var barCollapsingEnabled = false var barCollapsingEnabled = false
@ -22,4 +23,17 @@ public class SafariBrowserOptions: Options {
super.init() super.init()
} }
override func getRealOptions(obj: SafariViewController?) -> [String: Any?] {
var realOptions: [String: Any?] = toMap()
if let safariViewController = obj {
if #available(iOS 11.0, *) {
realOptions["entersReaderIfAvailable"] = safariViewController.configuration.entersReaderIfAvailable
realOptions["barCollapsingEnabled"] = safariViewController.configuration.barCollapsingEnabled
realOptions["dismissButtonStyle"] = safariViewController.dismissButtonStyle.rawValue
}
realOptions["presentationStyle"] = safariViewController.modalPresentationStyle.rawValue
realOptions["transitionStyle"] = safariViewController.modalTransitionStyle.rawValue
}
return realOptions
}
} }

View File

@ -17,7 +17,8 @@ class ChromeSafariBrowser {
Map<int, ChromeSafariBrowserMenuItem> _menuItems = new HashMap(); Map<int, ChromeSafariBrowserMenuItem> _menuItems = new HashMap();
bool _isOpened = false; bool _isOpened = false;
MethodChannel _channel; MethodChannel _channel;
static const MethodChannel _sharedChannel = const MethodChannel('com.pichillilorenzo/flutter_chromesafaribrowser'); static const MethodChannel _sharedChannel =
const MethodChannel('com.pichillilorenzo/flutter_chromesafaribrowser');
///Initialize the [ChromeSafariBrowser] instance with an [InAppBrowser] fallback instance or `null`. ///Initialize the [ChromeSafariBrowser] instance with an [InAppBrowser] fallback instance or `null`.
ChromeSafariBrowser({bFallback}) { ChromeSafariBrowser({bFallback}) {
@ -73,10 +74,7 @@ class ChromeSafariBrowser {
List<Map<String, dynamic>> menuItemList = new List(); List<Map<String, dynamic>> menuItemList = new List();
_menuItems.forEach((key, value) { _menuItems.forEach((key, value) {
menuItemList.add({ menuItemList.add({"id": value.id, "label": value.label});
"id": value.id,
"label": value.label
});
}); });
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
@ -84,11 +82,11 @@ class ChromeSafariBrowser {
args.putIfAbsent('url', () => url); args.putIfAbsent('url', () => url);
args.putIfAbsent('options', () => options?.toMap() ?? {}); args.putIfAbsent('options', () => options?.toMap() ?? {});
args.putIfAbsent('menuItemList', () => menuItemList); args.putIfAbsent('menuItemList', () => menuItemList);
args.putIfAbsent('uuidFallback', args.putIfAbsent('uuidFallback', () => browserFallback?.uuid);
() => (browserFallback != null) ? browserFallback.uuid : ''); args.putIfAbsent('headersFallback', () => headersFallback ?? {});
args.putIfAbsent('headersFallback', () => headersFallback);
args.putIfAbsent('optionsFallback', () => optionsFallback?.toMap() ?? {}); args.putIfAbsent('optionsFallback', () => optionsFallback?.toMap() ?? {});
args.putIfAbsent('contextMenuFallback', () => browserFallback?.contextMenu?.toMap() ?? {}); args.putIfAbsent('contextMenuFallback',
() => browserFallback?.contextMenu?.toMap() ?? {});
await _sharedChannel.invokeMethod('open', args); await _sharedChannel.invokeMethod('open', args);
this._isOpened = true; this._isOpened = true;
} }
@ -142,10 +140,30 @@ class ChromeSafariBrowser {
} }
} }
///Class that represents a custom menu item for a [ChromeSafariBrowser] instance.
class ChromeSafariBrowserMenuItem { class ChromeSafariBrowserMenuItem {
///The menu item id
int id; int id;
///The label of the menu item
String label; String label;
///Callback function to be invoked when the menu item is clicked
final void Function(String url, String title) action; final void Function(String url, String title) action;
ChromeSafariBrowserMenuItem({@required this.id, @required this.label, @required this.action}); ChromeSafariBrowserMenuItem(
{@required this.id, @required this.label, @required this.action});
Map<String, dynamic> toMap() {
return {"id": id, "label": label};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }

View File

@ -7,11 +7,11 @@ import 'types.dart';
/// ///
///**NOTE**: To make it work properly on Android, JavaScript should be enabled! ///**NOTE**: To make it work properly on Android, JavaScript should be enabled!
class ContextMenu { class ContextMenu {
///Event fired when the context menu for this WebView is being built. ///Event fired when the context menu for this WebView is being built.
/// ///
///[hitTestResult] represents the hit result for hitting an HTML elements. ///[hitTestResult] represents the hit result for hitting an HTML elements.
final void Function(InAppWebViewHitTestResult hitTestResult) onCreateContextMenu; final void Function(InAppWebViewHitTestResult hitTestResult)
onCreateContextMenu;
///Event fired when the context menu for this WebView is being hidden. ///Event fired when the context menu for this WebView is being hidden.
final void Function() onHideContextMenu; final void Function() onHideContextMenu;
@ -19,17 +19,17 @@ class ContextMenu {
///Event fired when a context menu item has been clicked. ///Event fired when a context menu item has been clicked.
/// ///
///[contextMenuItemClicked] represents the [ContextMenuItem] clicked. ///[contextMenuItemClicked] represents the [ContextMenuItem] clicked.
final void Function(ContextMenuItem contextMenuItemClicked) onContextMenuActionItemClicked; final void Function(ContextMenuItem contextMenuItemClicked)
onContextMenuActionItemClicked;
///List of the custom [ContextMenuItem]. ///List of the custom [ContextMenuItem].
List<ContextMenuItem> menuItems = List(); List<ContextMenuItem> menuItems = List();
ContextMenu({ ContextMenu(
this.menuItems, {this.menuItems,
this.onCreateContextMenu, this.onCreateContextMenu,
this.onHideContextMenu, this.onHideContextMenu,
this.onContextMenuActionItemClicked this.onContextMenuActionItemClicked});
});
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return { return {
@ -46,21 +46,24 @@ class ContextMenu {
class ContextMenuItem { class ContextMenuItem {
///Android menu item ID. ///Android menu item ID.
int androidId; int androidId;
///iOS menu item ID. ///iOS menu item ID.
String iosId; String iosId;
///Menu item title. ///Menu item title.
String title; String title;
///Menu item action that will be called when an user clicks on it. ///Menu item action that will be called when an user clicks on it.
Function() action; Function() action;
ContextMenuItem({@required this.androidId, @required this.iosId, @required this.title, this.action}); ContextMenuItem(
{@required this.androidId,
@required this.iosId,
@required this.title,
this.action});
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return { return {"androidId": androidId, "iosId": iosId, "title": title};
"androidId": androidId,
"iosId": iosId,
"title": title
};
} }
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {

View File

@ -22,7 +22,7 @@ class CookieManager {
static CookieManager _init() { static CookieManager _init() {
_channel.setMethodCallHandler(_handleMethod); _channel.setMethodCallHandler(_handleMethod);
_instance = new CookieManager(); _instance = CookieManager();
return _instance; return _instance;
} }

View File

@ -12,13 +12,14 @@ import 'in_app_webview_controller.dart';
class HeadlessInAppWebView implements WebView { class HeadlessInAppWebView implements WebView {
String uuid; String uuid;
bool _isDisposed = true; bool _isDisposed = true;
static const MethodChannel _sharedChannel = const MethodChannel('com.pichillilorenzo/flutter_headless_inappwebview'); static const MethodChannel _sharedChannel =
const MethodChannel('com.pichillilorenzo/flutter_headless_inappwebview');
///WebView Controller that can be used to access the [InAppWebViewController] API. ///WebView Controller that can be used to access the [InAppWebViewController] API.
InAppWebViewController webViewController; InAppWebViewController webViewController;
HeadlessInAppWebView({ HeadlessInAppWebView(
this.onWebViewCreated, {this.onWebViewCreated,
this.onLoadStart, this.onLoadStart,
this.onLoadStop, this.onLoadStop,
this.onLoadError, this.onLoadError,
@ -65,8 +66,7 @@ class HeadlessInAppWebView implements WebView {
this.initialData, this.initialData,
this.initialHeaders, this.initialHeaders,
this.initialOptions, this.initialOptions,
this.contextMenu this.contextMenu}) {
}) {
uuid = uuidGenerator.v4(); uuid = uuidGenerator.v4();
webViewController = new InAppWebViewController(uuid, this); webViewController = new InAppWebViewController(uuid, this);
} }
@ -89,7 +89,9 @@ class HeadlessInAppWebView implements WebView {
_isDisposed = false; _isDisposed = false;
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
args.putIfAbsent('uuid', () => uuid); args.putIfAbsent('uuid', () => uuid);
args.putIfAbsent('params', () => <String, dynamic>{ args.putIfAbsent(
'params',
() => <String, dynamic>{
'initialUrl': '${Uri.parse(this.initialUrl)}', 'initialUrl': '${Uri.parse(this.initialUrl)}',
'initialFile': this.initialFile, 'initialFile': this.initialFile,
'initialData': this.initialData?.toMap(), 'initialData': this.initialData?.toMap(),
@ -149,7 +151,8 @@ class HeadlessInAppWebView implements WebView {
final String initialUrl; final String initialUrl;
@override @override
final Future<void> Function(InAppWebViewController controller, String url) onPageCommitVisible; final Future<void> Function(InAppWebViewController controller, String url)
onPageCommitVisible;
@override @override
final Future<void> Function(InAppWebViewController controller) final Future<void> Function(InAppWebViewController controller)
@ -284,26 +287,31 @@ class HeadlessInAppWebView implements WebView {
final void Function(InAppWebViewController controller) onExitFullscreen; final void Function(InAppWebViewController controller) onExitFullscreen;
@override @override
final Future<WebResourceResponse> Function(InAppWebViewController controller, WebResourceRequest request) final Future<WebResourceResponse> Function(
InAppWebViewController controller, WebResourceRequest request)
androidShouldInterceptRequest; androidShouldInterceptRequest;
@override @override
final Future<WebViewRenderProcessAction> Function(InAppWebViewController controller, String url) final Future<WebViewRenderProcessAction> Function(
InAppWebViewController controller, String url)
androidOnRenderProcessUnresponsive; androidOnRenderProcessUnresponsive;
@override @override
final Future<WebViewRenderProcessAction> Function(InAppWebViewController controller, String url) final Future<WebViewRenderProcessAction> Function(
InAppWebViewController controller, String url)
androidOnRenderProcessResponsive; androidOnRenderProcessResponsive;
@override @override
final Future<void> Function(InAppWebViewController controller, RenderProcessGoneDetail detail) final Future<void> Function(
InAppWebViewController controller, RenderProcessGoneDetail detail)
androidOnRenderProcessGone; androidOnRenderProcessGone;
@override @override
final Future<FormResubmissionAction> Function(InAppWebViewController controller, String url) final Future<FormResubmissionAction> Function(
androidOnFormResubmission; InAppWebViewController controller, String url) androidOnFormResubmission;
@override @override
final Future<void> Function(InAppWebViewController controller, double oldScale, double newScale) final Future<void> Function(
InAppWebViewController controller, double oldScale, double newScale)
androidOnScaleChanged; androidOnScaleChanged;
} }

View File

@ -22,7 +22,7 @@ class HttpAuthCredentialDatabase {
static HttpAuthCredentialDatabase _init() { static HttpAuthCredentialDatabase _init() {
_channel.setMethodCallHandler(_handleMethod); _channel.setMethodCallHandler(_handleMethod);
_instance = new HttpAuthCredentialDatabase(); _instance = HttpAuthCredentialDatabase();
return _instance; return _instance;
} }

View File

@ -23,7 +23,8 @@ class InAppBrowser {
HashMap<String, JavaScriptHandlerCallback>(); HashMap<String, JavaScriptHandlerCallback>();
bool _isOpened = false; bool _isOpened = false;
MethodChannel _channel; MethodChannel _channel;
static const MethodChannel _sharedChannel = const MethodChannel('com.pichillilorenzo/flutter_inappbrowser'); static const MethodChannel _sharedChannel =
const MethodChannel('com.pichillilorenzo/flutter_inappbrowser');
/// WebView Controller that can be used to access the [InAppWebViewController] API. /// WebView Controller that can be used to access the [InAppWebViewController] API.
InAppWebViewController webViewController; InAppWebViewController webViewController;
@ -35,8 +36,8 @@ class InAppBrowser {
MethodChannel('com.pichillilorenzo/flutter_inappbrowser_$uuid'); MethodChannel('com.pichillilorenzo/flutter_inappbrowser_$uuid');
this._channel.setMethodCallHandler(handleMethod); this._channel.setMethodCallHandler(handleMethod);
_isOpened = false; _isOpened = false;
webViewController = new InAppWebViewController.fromInAppBrowser( webViewController =
uuid, this._channel, this); new InAppWebViewController.fromInAppBrowser(uuid, this._channel, this);
} }
Future<dynamic> handleMethod(MethodCall call) async { Future<dynamic> handleMethod(MethodCall call) async {
@ -117,8 +118,6 @@ class InAppBrowser {
assert(assetFilePath != null && assetFilePath.isNotEmpty); assert(assetFilePath != null && assetFilePath.isNotEmpty);
this.throwIsAlreadyOpened(message: 'Cannot open $assetFilePath!'); this.throwIsAlreadyOpened(message: 'Cannot open $assetFilePath!');
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
args.putIfAbsent('uuid', () => uuid); args.putIfAbsent('uuid', () => uuid);
args.putIfAbsent('url', () => assetFilePath); args.putIfAbsent('url', () => assetFilePath);
@ -217,20 +216,19 @@ class InAppBrowser {
options = options.cast<String, dynamic>(); options = options.cast<String, dynamic>();
inAppBrowserClassOptions.crossPlatform = inAppBrowserClassOptions.crossPlatform =
InAppBrowserOptions.fromMap(options); InAppBrowserOptions.fromMap(options);
inAppBrowserClassOptions.inAppWebViewGroupOptions = InAppWebViewGroupOptions(); inAppBrowserClassOptions.inAppWebViewGroupOptions =
InAppWebViewGroupOptions();
inAppBrowserClassOptions.inAppWebViewGroupOptions.crossPlatform = inAppBrowserClassOptions.inAppWebViewGroupOptions.crossPlatform =
InAppWebViewOptions.fromMap(options); InAppWebViewOptions.fromMap(options);
if (Platform.isAndroid) { if (Platform.isAndroid) {
inAppBrowserClassOptions.android = inAppBrowserClassOptions.android =
AndroidInAppBrowserOptions.fromMap(options); AndroidInAppBrowserOptions.fromMap(options);
inAppBrowserClassOptions inAppBrowserClassOptions.inAppWebViewGroupOptions.android =
.inAppWebViewGroupOptions.android =
AndroidInAppWebViewOptions.fromMap(options); AndroidInAppWebViewOptions.fromMap(options);
} else if (Platform.isIOS) { } else if (Platform.isIOS) {
inAppBrowserClassOptions.ios = inAppBrowserClassOptions.ios = IOSInAppBrowserOptions.fromMap(options);
IOSInAppBrowserOptions.fromMap(options); inAppBrowserClassOptions.inAppWebViewGroupOptions.ios =
inAppBrowserClassOptions.inAppWebViewGroupOptions IOSInAppWebViewOptions.fromMap(options);
.ios = IOSInAppWebViewOptions.fromMap(options);
} }
} }
@ -305,7 +303,8 @@ class InAppBrowser {
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#shouldOverrideUrlLoading(android.webkit.WebView,%20java.lang.String) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#shouldOverrideUrlLoading(android.webkit.WebView,%20java.lang.String)
///**Official iOS API**: https://developer.apple.com/documentation/webkit/wknavigationdelegate/1455641-webview ///**Official iOS API**: https://developer.apple.com/documentation/webkit/wknavigationdelegate/1455641-webview
// ignore: missing_return // ignore: missing_return
Future<ShouldOverrideUrlLoadingAction> shouldOverrideUrlLoading(ShouldOverrideUrlLoadingRequest shouldOverrideUrlLoadingRequest) {} Future<ShouldOverrideUrlLoadingAction> shouldOverrideUrlLoading(
ShouldOverrideUrlLoadingRequest shouldOverrideUrlLoadingRequest) {}
///Event fired when the [InAppBrowser] webview loads a resource. ///Event fired when the [InAppBrowser] webview loads a resource.
/// ///

View File

@ -29,7 +29,7 @@ class InAppLocalhostServer {
throw Exception('Server already started on http://localhost:$_port'); throw Exception('Server already started on http://localhost:$_port');
} }
var completer = new Completer(); var completer = Completer();
runZoned(() { runZoned(() {
HttpServer.bind('127.0.0.1', _port).then((server) { HttpServer.bind('127.0.0.1', _port).then((server) {
@ -62,7 +62,7 @@ class InAppLocalhostServer {
} }
request.response.headers.contentType = request.response.headers.contentType =
new ContentType(contentType[0], contentType[1], charset: 'utf-8'); ContentType(contentType[0], contentType[1], charset: 'utf-8');
request.response.add(body); request.response.add(body);
request.response.close(); request.response.close();
}); });

View File

@ -116,7 +116,8 @@ class InAppWebView extends StatefulWidget implements WebView {
final ContextMenu contextMenu; final ContextMenu contextMenu;
@override @override
final Future<void> Function(InAppWebViewController controller, String url) onPageCommitVisible; final Future<void> Function(InAppWebViewController controller, String url)
onPageCommitVisible;
@override @override
final Future<void> Function(InAppWebViewController controller) final Future<void> Function(InAppWebViewController controller)
@ -251,27 +252,32 @@ class InAppWebView extends StatefulWidget implements WebView {
final void Function(InAppWebViewController controller) onExitFullscreen; final void Function(InAppWebViewController controller) onExitFullscreen;
@override @override
final Future<WebResourceResponse> Function(InAppWebViewController controller, WebResourceRequest request) final Future<WebResourceResponse> Function(
InAppWebViewController controller, WebResourceRequest request)
androidShouldInterceptRequest; androidShouldInterceptRequest;
@override @override
final Future<WebViewRenderProcessAction> Function(InAppWebViewController controller, String url) final Future<WebViewRenderProcessAction> Function(
InAppWebViewController controller, String url)
androidOnRenderProcessUnresponsive; androidOnRenderProcessUnresponsive;
@override @override
final Future<WebViewRenderProcessAction> Function(InAppWebViewController controller, String url) final Future<WebViewRenderProcessAction> Function(
InAppWebViewController controller, String url)
androidOnRenderProcessResponsive; androidOnRenderProcessResponsive;
@override @override
final Future<void> Function(InAppWebViewController controller, RenderProcessGoneDetail detail) final Future<void> Function(
InAppWebViewController controller, RenderProcessGoneDetail detail)
androidOnRenderProcessGone; androidOnRenderProcessGone;
@override @override
final Future<FormResubmissionAction> Function(InAppWebViewController controller, String url) final Future<FormResubmissionAction> Function(
androidOnFormResubmission; InAppWebViewController controller, String url) androidOnFormResubmission;
@override @override
final Future<void> Function(InAppWebViewController controller, double oldScale, double newScale) final Future<void> Function(
InAppWebViewController controller, double oldScale, double newScale)
androidOnScaleChanged; androidOnScaleChanged;
} }

View File

@ -1590,7 +1590,8 @@ class AndroidInAppWebViewController {
///If `true`, [basename] is assumed to be a directory in which a filename will be chosen according to the URL of the current page. ///If `true`, [basename] is assumed to be a directory in which a filename will be chosen according to the URL of the current page.
/// ///
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebView#saveWebArchive(java.lang.String,%20boolean,%20android.webkit.ValueCallback%3Cjava.lang.String%3E) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebView#saveWebArchive(java.lang.String,%20boolean,%20android.webkit.ValueCallback%3Cjava.lang.String%3E)
Future<String> saveWebArchive({@required String basename, @required bool autoname}) async { Future<String> saveWebArchive(
{@required String basename, @required bool autoname}) async {
assert(basename != null && autoname != null); assert(basename != null && autoname != null);
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
args.putIfAbsent("basename", () => basename); args.putIfAbsent("basename", () => basename);
@ -1681,7 +1682,10 @@ class AndroidInAppWebViewController {
///**Official Android API**: https://developer.android.com/reference/androidx/webkit/WebViewCompat#getCurrentWebViewPackage(android.content.Context) ///**Official Android API**: https://developer.android.com/reference/androidx/webkit/WebViewCompat#getCurrentWebViewPackage(android.content.Context)
static Future<AndroidWebViewPackageInfo> getCurrentWebViewPackage() async { static Future<AndroidWebViewPackageInfo> getCurrentWebViewPackage() async {
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
Map<String, dynamic> packageInfo = (await InAppWebViewController._staticChannel.invokeMethod('getCurrentWebViewPackage', args))?.cast<String, dynamic>(); Map<String, dynamic> packageInfo = (await InAppWebViewController
._staticChannel
.invokeMethod('getCurrentWebViewPackage', args))
?.cast<String, dynamic>();
return AndroidWebViewPackageInfo.fromMap(packageInfo); return AndroidWebViewPackageInfo.fromMap(packageInfo);
} }
} }

View File

@ -87,6 +87,24 @@ class LoadedResource {
double duration; double duration;
LoadedResource({this.initiatorType, this.url, this.startTime, this.duration}); LoadedResource({this.initiatorType, this.url, this.startTime, this.duration});
Map<String, dynamic> toMap() {
return {
"initiatorType": initiatorType,
"url": url,
"startTime": startTime,
"duration": duration
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Initial [data] as a content for an [WebView] instance, using [baseUrl] as the base URL for it. ///Initial [data] as a content for an [WebView] instance, using [baseUrl] as the base URL for it.
@ -122,6 +140,15 @@ class InAppWebViewInitialData {
"historyUrl": historyUrl "historyUrl": historyUrl
}; };
} }
Map<String, String> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class representing a resource request of the WebView used by the event [WebView.androidShouldInterceptRequest]. ///Class representing a resource request of the WebView used by the event [WebView.androidShouldInterceptRequest].
@ -131,14 +158,17 @@ class InAppWebViewInitialData {
class WebResourceRequest { class WebResourceRequest {
///The URL for which the resource request was made. ///The URL for which the resource request was made.
String url; String url;
///The headers associated with the request. ///The headers associated with the request.
/// ///
///**NOTE**: Available on Android 21+. For Android < 21 it will be always `null`. ///**NOTE**: Available on Android 21+. For Android < 21 it will be always `null`.
Map<String, String> headers; Map<String, String> headers;
///The method associated with the request, for example `GET`. ///The method associated with the request, for example `GET`.
/// ///
///**NOTE**: Available on Android 21+. For Android < 21 it will be always "GET". ///**NOTE**: Available on Android 21+. For Android < 21 it will be always "GET".
String method; String method;
///Gets whether a gesture (such as a click) was associated with the request. ///Gets whether a gesture (such as a click) was associated with the request.
///For security reasons in certain situations this method may return `false` even though ///For security reasons in certain situations this method may return `false` even though
///the sequence of events which caused the request to be created was initiated by a user ///the sequence of events which caused the request to be created was initiated by a user
@ -146,23 +176,44 @@ 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 hasGesture; bool hasGesture;
///Whether the request was made in order to fetch the main frame's document. ///Whether the request was made in order to fetch the main frame's document.
/// ///
///**NOTE**: Available on Android 21+. For Android < 21 it will be always `true`. ///**NOTE**: Available on Android 21+. For Android < 21 it will be always `true`.
bool isForMainFrame; bool isForMainFrame;
///Whether the request was a result of a server-side redirect. ///Whether the request was a result of a server-side redirect.
/// ///
///**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,
this.isForMainFrame, this.isForMainFrame,
this.isRedirect this.isRedirect});
});
Map<String, dynamic> toMap() {
return {
"url": url,
"headers": headers,
"method": method,
"hasGesture": hasGesture,
"isForMainFrame": isForMainFrame,
"isRedirect": isRedirect
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class representing a resource response of the WebView used by the event [WebView.androidShouldInterceptRequest]. ///Class representing a resource response of the WebView used by the event [WebView.androidShouldInterceptRequest].
@ -172,33 +223,37 @@ class WebResourceRequest {
class WebResourceResponse { class WebResourceResponse {
///The resource response's MIME type, for example `text/html`. ///The resource response's MIME type, for example `text/html`.
String contentType; String contentType;
///The resource response's encoding. The default value is `utf-8`. ///The resource response's encoding. The default value is `utf-8`.
String contentEncoding; String contentEncoding;
///The data provided by the resource response. ///The data provided by the resource response.
Uint8List data; Uint8List data;
///The headers for the resource response. If [headers] isn't `null`, then you need to set also [statusCode] and [reasonPhrase]. ///The headers for the resource response. If [headers] isn't `null`, then you need to set also [statusCode] and [reasonPhrase].
/// ///
///**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.
Map<String, String> headers; Map<String, String> headers;
///The status code needs to be in the ranges [100, 299], [400, 599]. Causing a redirect by specifying a 3xx code is not supported. ///The status code needs to be in the ranges [100, 299], [400, 599]. Causing a redirect by specifying a 3xx code is not supported.
///If statusCode is set, then you need to set also [headers] and [reasonPhrase]. This value cannot be `null`. ///If statusCode is set, then you need to set also [headers] and [reasonPhrase]. This value cannot be `null`.
/// ///
///**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.
int statusCode; int statusCode;
///The phrase describing the status code, for example `"OK"`. Must be non-empty. ///The phrase describing the status code, for example `"OK"`. Must be non-empty.
///If reasonPhrase is set, then you need to set also [headers] and [reasonPhrase]. This value cannot be `null`. ///If reasonPhrase is set, then you need to set also [headers] and [reasonPhrase]. This value cannot be `null`.
/// ///
///**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 = null,
this.headers, this.headers,
this.statusCode, this.statusCode,
this.reasonPhrase this.reasonPhrase});
});
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return { return {
@ -209,6 +264,15 @@ class WebResourceResponse {
"reasonPhrase": reasonPhrase "reasonPhrase": reasonPhrase
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class representing the response returned by the [WebView.onLoadResourceCustomScheme] event. ///Class representing the response returned by the [WebView.onLoadResourceCustomScheme] event.
@ -228,13 +292,22 @@ class CustomSchemeResponse {
@required this.contentType, @required this.contentType,
this.contentEnconding = 'utf-8'}); this.contentEnconding = 'utf-8'});
Map<String, dynamic> toJson() { Map<String, dynamic> toMap() {
return { return {
'content-type': contentType, 'content-type': contentType,
'content-encoding': contentEnconding, 'content-encoding': contentEnconding,
'data': data 'data': data
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class representing a JavaScript console message from WebCore. ///Class representing a JavaScript console message from WebCore.
@ -247,6 +320,19 @@ class ConsoleMessage {
ConsoleMessage( ConsoleMessage(
{this.message = "", this.messageLevel = ConsoleMessageLevel.LOG}); {this.message = "", this.messageLevel = ConsoleMessageLevel.LOG});
Map<String, dynamic> toMap() {
return {"message": message, "messageLevel": messageLevel?.toValue()};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class contains a snapshot of the current back/forward list for a [WebView]. ///This class contains a snapshot of the current back/forward list for a [WebView].
@ -258,6 +344,19 @@ class WebHistory {
int currentIndex; int currentIndex;
WebHistory({this.list, this.currentIndex}); WebHistory({this.list, this.currentIndex});
Map<String, dynamic> toMap() {
return {"list": list, "currentIndex": currentIndex};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///A convenience class for accessing fields in an entry in the back/forward list of a WebView. Each [WebHistoryItem] is a snapshot of the requested history item. ///A convenience class for accessing fields in an entry in the back/forward list of a WebView. Each [WebHistoryItem] is a snapshot of the requested history item.
@ -279,6 +378,25 @@ class WebHistoryItem {
WebHistoryItem( WebHistoryItem(
{this.originalUrl, this.title, this.url, this.index, this.offset}); {this.originalUrl, this.title, this.url, this.index, this.offset});
Map<String, dynamic> toMap() {
return {
"originalUrl": originalUrl,
"title": title,
"url": url,
"index": index,
"offset": offset
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by the host application to set the Geolocation permission state for an origin during the [WebView.androidOnGeolocationPermissionsShowPrompt] event. ///Class used by the host application to set the Geolocation permission state for an origin during the [WebView.androidOnGeolocationPermissionsShowPrompt] event.
@ -298,6 +416,15 @@ class GeolocationPermissionShowPromptResponse {
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return {"origin": origin, "allow": allow, "retain": retain}; return {"origin": origin, "allow": allow, "retain": retain};
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [JsAlertResponse] class. ///Class used by [JsAlertResponse] class.
@ -344,6 +471,15 @@ class JsAlertResponse {
"action": action?.toValue() "action": action?.toValue()
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [JsConfirmResponse] class. ///Class used by [JsConfirmResponse] class.
@ -396,6 +532,15 @@ class JsConfirmResponse {
"action": action?.toValue() "action": action?.toValue()
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [JsPromptResponse] class. ///Class used by [JsPromptResponse] class.
@ -458,6 +603,15 @@ class JsPromptResponse {
"action": action?.toValue() "action": action?.toValue()
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the reason the resource was caught by Safe Browsing. ///Class that represents the reason the resource was caught by Safe Browsing.
@ -547,6 +701,15 @@ class SafeBrowsingResponse {
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return {"report": report, "action": action?.toValue()}; return {"report": report, "action": action?.toValue()};
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [HttpAuthResponse] class. ///Class used by [HttpAuthResponse] class.
@ -601,6 +764,15 @@ class HttpAuthResponse {
"action": action?.toValue() "action": action?.toValue()
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the challenge of the [WebView.onReceivedHttpAuthRequest] event. ///Class that represents the challenge of the [WebView.onReceivedHttpAuthRequest] event.
@ -615,6 +787,22 @@ class HttpAuthChallenge {
HttpAuthChallenge( HttpAuthChallenge(
{@required this.previousFailureCount, @required this.protectionSpace}) {@required this.previousFailureCount, @required this.protectionSpace})
: assert(previousFailureCount != null && protectionSpace != null); : assert(previousFailureCount != null && protectionSpace != null);
Map<String, dynamic> toMap() {
return {
"previousFailureCount": previousFailureCount,
"protectionSpace": protectionSpace?.toMap()
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents a protection space requiring authentication. ///Class that represents a protection space requiring authentication.
@ -636,6 +824,19 @@ class ProtectionSpace {
ProtectionSpace( ProtectionSpace(
{@required this.host, @required this.protocol, this.realm, this.port}) {@required this.host, @required this.protocol, this.realm, this.port})
: assert(host != null && protocol != null); : assert(host != null && protocol != null);
Map<String, dynamic> toMap() {
return {"host": host, "protocol": protocol, "realm": realm, "port": port};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the credentials of an http authentication. ///Class that represents the credentials of an http authentication.
@ -649,6 +850,19 @@ class HttpAuthCredential {
HttpAuthCredential({@required this.username, @required this.password}) HttpAuthCredential({@required this.username, @required this.password})
: assert(username != null && password != null); : assert(username != null && password != null);
Map<String, dynamic> toMap() {
return {"username": username, "password": password};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [ServerTrustAuthResponse] class. ///Class used by [ServerTrustAuthResponse] class.
@ -681,6 +895,15 @@ class ServerTrustAuthResponse {
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return {"action": action?.toValue()}; return {"action": action?.toValue()};
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the challenge of the [WebView.onReceivedServerTrustAuthRequest] event. ///Class that represents the challenge of the [WebView.onReceivedServerTrustAuthRequest] event.
@ -708,6 +931,24 @@ class ServerTrustChallenge {
this.message, this.message,
this.serverCertificate}) this.serverCertificate})
: assert(protectionSpace != null && error != null); : assert(protectionSpace != null && error != null);
Map<String, dynamic> toMap() {
return {
"protectionSpace": protectionSpace?.toMap(),
"error": error,
"message": message,
"serverCertificate": serverCertificate
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [ClientCertResponse] class. ///Class used by [ClientCertResponse] class.
@ -764,6 +1005,15 @@ class ClientCertResponse {
"action": action?.toValue() "action": action?.toValue()
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the challenge of the [WebView.onReceivedClientCertRequest] event. ///Class that represents the challenge of the [WebView.onReceivedClientCertRequest] event.
@ -774,6 +1024,19 @@ class ClientCertChallenge {
ClientCertChallenge({@required this.protectionSpace}) ClientCertChallenge({@required this.protectionSpace})
: assert(protectionSpace != null); : assert(protectionSpace != null);
Map<String, dynamic> toMap() {
return {"protectionSpace": protectionSpace?.toMap()};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents a favicon of a website. It is used by [InAppWebViewController.getFavicons] method. ///Class that represents a favicon of a website. It is used by [InAppWebViewController.getFavicons] method.
@ -793,8 +1056,17 @@ class Favicon {
Favicon({@required this.url, this.rel, this.width, this.height}) Favicon({@required this.url, this.rel, this.width, this.height})
: assert(url != null); : assert(url != null);
Map<String, dynamic> toMap() {
return {"url": url, "rel": rel, "width": width, "height": height};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() { String toString() {
return "url: $url, rel: $rel, width: $width, height: $height"; return toMap().toString();
} }
} }
@ -949,7 +1221,7 @@ class AndroidLayoutAlgorithm {
const AndroidLayoutAlgorithm._internal(this._value); const AndroidLayoutAlgorithm._internal(this._value);
static AndroidLayoutAlgorithm fromValue(String value) { static AndroidLayoutAlgorithm fromValue(String value) {
return (["NORMAL", "TEXT_AUTOSIZING"].contains(value)) return (["NORMAL", "TEXT_AUTOSIZING", "NARROW_COLUMNS"].contains(value))
? AndroidLayoutAlgorithm._internal(value) ? AndroidLayoutAlgorithm._internal(value)
: null; : null;
} }
@ -969,6 +1241,10 @@ class AndroidLayoutAlgorithm {
static const TEXT_AUTOSIZING = static const TEXT_AUTOSIZING =
const AndroidLayoutAlgorithm._internal("TEXT_AUTOSIZING"); const AndroidLayoutAlgorithm._internal("TEXT_AUTOSIZING");
///NARROW_COLUMNS makes all columns no wider than the screen if possible. Only use this for API levels prior to `Build.VERSION_CODES.KITKAT`.
static const NARROW_COLUMNS =
const AndroidLayoutAlgorithm._internal("NARROW_COLUMNS");
bool operator ==(value) => value == _value; bool operator ==(value) => value == _value;
@override @override
@ -1414,6 +1690,11 @@ class InAppWebViewGroupOptions {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
return this.toMap(); return this.toMap();
} }
@override
String toString() {
return toMap().toString();
}
} }
///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.
@ -1455,6 +1736,11 @@ class InAppBrowserClassOptions {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
return this.toMap(); return this.toMap();
} }
@override
String toString() {
return toMap().toString();
}
} }
///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.
@ -1479,6 +1765,11 @@ class ChromeSafariBrowserClassOptions {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
return this.toMap(); return this.toMap();
} }
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [AjaxRequest] class. ///Class used by [AjaxRequest] class.
@ -1509,6 +1800,11 @@ class AjaxRequestAction {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
return this.toMap(); return this.toMap();
} }
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [AjaxRequestEvent] class. ///Class used by [AjaxRequestEvent] class.
@ -1770,6 +2066,11 @@ class AjaxRequest {
Map<String, dynamic> toJson() { Map<String, dynamic> toJson() {
return this.toMap(); return this.toMap();
} }
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [FetchRequest] class. ///Class used by [FetchRequest] class.
@ -1802,6 +2103,15 @@ class FetchRequestCredential {
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return {"type": type}; return {"type": type};
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the default credentials used by an [FetchRequest]. ///Class that represents the default credentials used by an [FetchRequest].
@ -1817,6 +2127,15 @@ class FetchRequestCredentialDefault extends FetchRequestCredential {
"value": value, "value": value,
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents a [FederatedCredential](https://developer.mozilla.org/en-US/docs/Web/API/FederatedCredential) type of credentials. ///Class that represents a [FederatedCredential](https://developer.mozilla.org/en-US/docs/Web/API/FederatedCredential) type of credentials.
@ -1850,6 +2169,15 @@ class FetchRequestFederatedCredential extends FetchRequestCredential {
"iconURL": iconURL "iconURL": iconURL
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents a [PasswordCredential](https://developer.mozilla.org/en-US/docs/Web/API/PasswordCredential) type of credentials. ///Class that represents a [PasswordCredential](https://developer.mozilla.org/en-US/docs/Web/API/PasswordCredential) type of credentials.
@ -1879,6 +2207,15 @@ class FetchRequestPasswordCredential extends FetchRequestCredential {
"iconURL": iconURL "iconURL": iconURL
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents a HTTP request created with JavaScript using the [Fetch API](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch). ///Class that represents a HTTP request created with JavaScript using the [Fetch API](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch).
@ -1959,6 +2296,11 @@ class FetchRequest {
return this.toMap(); return this.toMap();
} }
@override
String toString() {
return toMap().toString();
}
static FetchRequestCredential createFetchRequestCredentialFromMap( static FetchRequestCredential createFetchRequestCredentialFromMap(
credentialsMap) { credentialsMap) {
if (credentialsMap != null) { if (credentialsMap != null) {
@ -2111,6 +2453,19 @@ class Cookie {
dynamic value; dynamic value;
Cookie({@required this.name, @required this.value}); Cookie({@required this.name, @required this.value});
Map<String, dynamic> toMap() {
return {"name": name, "value": value};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [PermissionRequestResponse] class. ///Class used by [PermissionRequestResponse] class.
@ -2148,6 +2503,15 @@ class PermissionRequestResponse {
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return {"resources": resources, "action": action?.toValue()}; return {"resources": resources, "action": action?.toValue()};
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that is used by [WebView.shouldOverrideUrlLoading] event. ///Class that is used by [WebView.shouldOverrideUrlLoading] event.
@ -2251,6 +2615,27 @@ class ShouldOverrideUrlLoadingRequest {
this.androidHasGesture, this.androidHasGesture,
this.androidIsRedirect, this.androidIsRedirect,
this.iosWKNavigationType}); this.iosWKNavigationType});
Map<String, dynamic> toMap() {
return {
"url": url,
"headers": headers,
"method": method,
"isForMainFrame": isForMainFrame,
"androidHasGesture": androidHasGesture,
"androidIsRedirect": androidIsRedirect,
"iosWKNavigationType": iosWKNavigationType?.toValue()
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the navigation request used by the [WebView.onCreateWindow] event. ///Class that represents the navigation request used by the [WebView.onCreateWindow] event.
@ -2272,6 +2657,24 @@ class OnCreateWindowRequest {
this.androidIsDialog, this.androidIsDialog,
this.androidIsUserGesture, this.androidIsUserGesture,
this.iosWKNavigationType}); this.iosWKNavigationType});
Map<String, dynamic> toMap() {
return {
"url": url,
"androidIsDialog": androidIsDialog,
"androidIsUserGesture": androidIsUserGesture,
"iosWKNavigationType": iosWKNavigationType?.toValue()
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that encapsulates information about the amount of storage currently used by an origin for the JavaScript storage APIs. ///Class that encapsulates information about the amount of storage currently used by an origin for the JavaScript storage APIs.
@ -2292,6 +2695,11 @@ class AndroidWebStorageOrigin {
return {"origin": origin, "quota": quota, "usage": usage}; return {"origin": origin, "quota": quota, "usage": usage};
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() { String toString() {
return toMap().toString(); return toMap().toString();
} }
@ -2415,6 +2823,11 @@ class IOSWKWebsiteDataRecord {
return {"displayName": displayName, "dataTypes": dataTypesString}; return {"displayName": displayName, "dataTypes": dataTypesString};
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() { String toString() {
return toMap().toString(); return toMap().toString();
} }
@ -2499,6 +2912,19 @@ class InAppWebViewHitTestResult {
String extra; String extra;
InAppWebViewHitTestResult({this.type, this.extra}); InAppWebViewHitTestResult({this.type, this.extra});
Map<String, dynamic> toMap() {
return {"type": type?.toValue(), "extra": extra};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class that represents the action to take used by the [WebView.androidOnRenderProcessUnresponsive] and [WebView.androidOnRenderProcessResponsive] event ///Class that represents the action to take used by the [WebView.androidOnRenderProcessUnresponsive] and [WebView.androidOnRenderProcessResponsive] event
@ -2519,9 +2945,7 @@ class WebViewRenderProcessAction {
int get hashCode => _value.hashCode; int get hashCode => _value.hashCode;
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return { return {"action": _value};
"action": _value
};
} }
} }
@ -2532,11 +2956,28 @@ class RenderProcessGoneDetail {
/// ///
///If the render process was killed, this is most likely caused by the system being low on memory. ///If the render process was killed, this is most likely caused by the system being low on memory.
bool didCrash; bool didCrash;
/// Returns the renderer priority that was set at the time that the renderer exited. This may be greater than the priority that /// Returns the renderer priority that was set at the time that the renderer exited. This may be greater than the priority that
/// any individual [WebView] requested using []. /// any individual [WebView] requested using [].
RendererPriority rendererPriorityAtExit; RendererPriority rendererPriorityAtExit;
RenderProcessGoneDetail({this.didCrash, this.rendererPriorityAtExit}); RenderProcessGoneDetail({this.didCrash, this.rendererPriorityAtExit});
Map<String, dynamic> toMap() {
return {
"didCrash": didCrash,
"rendererPriorityAtExit": rendererPriorityAtExit?.toValue()
};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///Class used by [RendererPriorityPolicy] class. ///Class used by [RendererPriorityPolicy] class.
@ -2574,7 +3015,8 @@ class RendererPriority {
static const RENDERER_PRIORITY_BOUND = const RendererPriority._internal(1); static const RENDERER_PRIORITY_BOUND = const RendererPriority._internal(1);
///The renderer associated with this WebView is bound with Android `Context#BIND_IMPORTANT`. ///The renderer associated with this WebView is bound with Android `Context#BIND_IMPORTANT`.
static const RENDERER_PRIORITY_IMPORTANT = const RendererPriority._internal(2); static const RENDERER_PRIORITY_IMPORTANT =
const RendererPriority._internal(2);
bool operator ==(value) => value == _value; bool operator ==(value) => value == _value;
@ -2591,10 +3033,13 @@ class RendererPriority {
class RendererPriorityPolicy { class RendererPriorityPolicy {
///The minimum priority at which this WebView desires the renderer process to be bound. ///The minimum priority at which this WebView desires the renderer process to be bound.
RendererPriority rendererRequestedPriority; RendererPriority rendererRequestedPriority;
///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({@required this.rendererRequestedPriority, @required this.waivedWhenNotVisible}); RendererPriorityPolicy(
{@required this.rendererRequestedPriority,
@required this.waivedWhenNotVisible});
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return { return {
@ -2603,11 +3048,22 @@ class RendererPriorityPolicy {
}; };
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
static RendererPriorityPolicy fromMap(Map<String, dynamic> map) { static RendererPriorityPolicy fromMap(Map<String, dynamic> map) {
return map != null ? RendererPriorityPolicy( return map != null
rendererRequestedPriority: RendererPriority.fromValue(map["rendererRequestedPriority"]), ? RendererPriorityPolicy(
waivedWhenNotVisible: map["waivedWhenNotVisible"] rendererRequestedPriority:
) : RendererPriorityPolicy(); RendererPriority.fromValue(map["rendererRequestedPriority"]),
waivedWhenNotVisible: map["waivedWhenNotVisible"])
: RendererPriorityPolicy();
} }
} }
@ -2631,9 +3087,16 @@ class FormResubmissionAction {
int get hashCode => _value.hashCode; int get hashCode => _value.hashCode;
Map<String, dynamic> toMap() { Map<String, dynamic> toMap() {
return { return {"action": _value};
"action": _value }
};
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
} }
} }
@ -2666,16 +3129,14 @@ class AndroidOverScrollMode {
} }
///Always allow a user to over-scroll this view, provided it is a view that can scroll. ///Always allow a user to over-scroll this view, provided it is a view that can scroll.
static const OVER_SCROLL_ALWAYS = static const OVER_SCROLL_ALWAYS = const AndroidOverScrollMode._internal(0);
const AndroidOverScrollMode._internal(0);
///Allow a user to over-scroll this view only if the content is large enough to meaningfully scroll, provided it is a view that can scroll. ///Allow a user to over-scroll this view only if the content is large enough to meaningfully scroll, provided it is a view that can scroll.
static const OVER_SCROLL_IF_CONTENT_SCROLLS = static const OVER_SCROLL_IF_CONTENT_SCROLLS =
const AndroidOverScrollMode._internal(1); const AndroidOverScrollMode._internal(1);
///Never allow a user to over-scroll this view. ///Never allow a user to over-scroll this view.
static const OVER_SCROLL_NEVER = static const OVER_SCROLL_NEVER = const AndroidOverScrollMode._internal(2);
const AndroidOverScrollMode._internal(2);
bool operator ==(value) => value == _value; bool operator ==(value) => value == _value;
@ -2793,15 +3254,29 @@ class AndroidVerticalScrollbarPosition {
class AndroidWebViewPackageInfo { class AndroidWebViewPackageInfo {
///The version name of this WebView package. ///The version name of this WebView package.
String versionName; String versionName;
///The name of this WebView package. ///The name of this WebView package.
String packageName; String packageName;
AndroidWebViewPackageInfo({this.versionName, this.packageName}); AndroidWebViewPackageInfo({this.versionName, this.packageName});
static AndroidWebViewPackageInfo fromMap(Map<String, dynamic> map) { static AndroidWebViewPackageInfo fromMap(Map<String, dynamic> map) {
return map != null ? AndroidWebViewPackageInfo( return map != null
versionName: map["versionName"], ? AndroidWebViewPackageInfo(
packageName: map["packageName"] versionName: map["versionName"], packageName: map["packageName"])
) : AndroidWebViewPackageInfo(); : AndroidWebViewPackageInfo();
}
Map<String, dynamic> toMap() {
return {"versionName": versionName, "packageName": packageName};
}
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
} }
} }

View File

@ -40,10 +40,15 @@ class AndroidWebStorageManager {
List<AndroidWebStorageOrigin> originsList = []; List<AndroidWebStorageOrigin> originsList = [];
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
List<Map<dynamic, dynamic>> origins = (await WebStorageManager._channel.invokeMethod('getOrigins', args)).cast<Map<dynamic, dynamic>>(); List<Map<dynamic, dynamic>> origins =
(await WebStorageManager._channel.invokeMethod('getOrigins', args))
.cast<Map<dynamic, dynamic>>();
for(var origin in origins) { for (var origin in origins) {
originsList.add(AndroidWebStorageOrigin(origin: origin["origin"], quota: origin["quota"], usage: origin["usage"])); originsList.add(AndroidWebStorageOrigin(
origin: origin["origin"],
quota: origin["quota"],
usage: origin["usage"]));
} }
return originsList; return originsList;
@ -72,7 +77,8 @@ class AndroidWebStorageManager {
assert(origin != null); assert(origin != null);
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
args.putIfAbsent("origin", () => origin); args.putIfAbsent("origin", () => origin);
return await WebStorageManager._channel.invokeMethod('getQuotaForOrigin', args); return await WebStorageManager._channel
.invokeMethod('getQuotaForOrigin', args);
} }
///Gets the amount of storage currently being used by both the Application Cache and Web SQL Database APIs by the given [origin]. ///Gets the amount of storage currently being used by both the Application Cache and Web SQL Database APIs by the given [origin].
@ -81,7 +87,8 @@ class AndroidWebStorageManager {
assert(origin != null); assert(origin != null);
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
args.putIfAbsent("origin", () => origin); args.putIfAbsent("origin", () => origin);
return await WebStorageManager._channel.invokeMethod('getUsageForOrigin', args); return await WebStorageManager._channel
.invokeMethod('getUsageForOrigin', args);
} }
} }
@ -93,7 +100,8 @@ class IOSWebStorageManager {
///Fetches data records containing the given website data types. ///Fetches data records containing the given website data types.
/// ///
///[dataTypes] represents the website data types to fetch records for. ///[dataTypes] represents the website data types to fetch records for.
Future<List<IOSWKWebsiteDataRecord>> fetchDataRecords({@required Set<IOSWKWebsiteDataType> dataTypes}) async { Future<List<IOSWKWebsiteDataRecord>> fetchDataRecords(
{@required Set<IOSWKWebsiteDataType> dataTypes}) async {
assert(dataTypes != null); assert(dataTypes != null);
List<IOSWKWebsiteDataRecord> recordList = []; List<IOSWKWebsiteDataRecord> recordList = [];
List<String> dataTypesList = []; List<String> dataTypesList = [];
@ -102,14 +110,17 @@ class IOSWebStorageManager {
} }
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
args.putIfAbsent("dataTypes", () => dataTypesList); args.putIfAbsent("dataTypes", () => dataTypesList);
List<Map<dynamic, dynamic>> records = (await WebStorageManager._channel.invokeMethod('fetchDataRecords', args)).cast<Map<dynamic, dynamic>>(); List<Map<dynamic, dynamic>> records = (await WebStorageManager._channel
for(var record in records) { .invokeMethod('fetchDataRecords', args))
.cast<Map<dynamic, dynamic>>();
for (var record in records) {
List<String> dataTypesString = record["dataTypes"].cast<String>(); List<String> dataTypesString = record["dataTypes"].cast<String>();
Set<IOSWKWebsiteDataType> dataTypes = Set(); Set<IOSWKWebsiteDataType> dataTypes = Set();
for(var dataType in dataTypesString) { for (var dataType in dataTypesString) {
dataTypes.add(IOSWKWebsiteDataType.fromValue(dataType)); dataTypes.add(IOSWKWebsiteDataType.fromValue(dataType));
} }
recordList.add(IOSWKWebsiteDataRecord(displayName: record["displayName"], dataTypes: dataTypes)); recordList.add(IOSWKWebsiteDataRecord(
displayName: record["displayName"], dataTypes: dataTypes));
} }
return recordList; return recordList;
} }
@ -119,7 +130,9 @@ class IOSWebStorageManager {
///[dataTypes] represents the website data types that should be removed. ///[dataTypes] represents the website data types that should be removed.
/// ///
///[dataRecords] represents the website data records to delete website data for. ///[dataRecords] represents the website data records to delete website data for.
Future<void> removeDataFor({@required Set<IOSWKWebsiteDataType> dataTypes, @required List<IOSWKWebsiteDataRecord> dataRecords}) async { Future<void> removeDataFor(
{@required Set<IOSWKWebsiteDataType> dataTypes,
@required List<IOSWKWebsiteDataRecord> dataRecords}) async {
assert(dataTypes != null && dataRecords != null); assert(dataTypes != null && dataRecords != null);
List<String> dataTypesList = []; List<String> dataTypesList = [];
@ -143,7 +156,9 @@ class IOSWebStorageManager {
///[dataTypes] represents the website data types that should be removed. ///[dataTypes] represents the website data types that should be removed.
/// ///
///[date] represents a date. All website data modified after this date will be removed. ///[date] represents a date. All website data modified after this date will be removed.
Future<void> removeDataModifiedSince({@required Set<IOSWKWebsiteDataType> dataTypes, @required DateTime date}) async { Future<void> removeDataModifiedSince(
{@required Set<IOSWKWebsiteDataType> dataTypes,
@required DateTime date}) async {
assert(dataTypes != null && date != null); assert(dataTypes != null && date != null);
List<String> dataTypesList = []; List<String> dataTypesList = [];
@ -156,6 +171,7 @@ class IOSWebStorageManager {
Map<String, dynamic> args = <String, dynamic>{}; Map<String, dynamic> args = <String, dynamic>{};
args.putIfAbsent("dataTypes", () => dataTypesList); args.putIfAbsent("dataTypes", () => dataTypesList);
args.putIfAbsent("timestamp", () => timestamp); args.putIfAbsent("timestamp", () => timestamp);
await WebStorageManager._channel.invokeMethod('removeDataModifiedSince', args); await WebStorageManager._channel
.invokeMethod('removeDataModifiedSince', args);
} }
} }

View File

@ -316,7 +316,8 @@ abstract class WebView {
/// ///
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onPageCommitVisible(android.webkit.WebView,%20java.lang.String) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onPageCommitVisible(android.webkit.WebView,%20java.lang.String)
///**Official iOS API**: https://developer.apple.com/documentation/webkit/wknavigationdelegate/1455635-webview ///**Official iOS API**: https://developer.apple.com/documentation/webkit/wknavigationdelegate/1455635-webview
final Future<void> Function(InAppWebViewController controller, String url) onPageCommitVisible; final Future<void> Function(InAppWebViewController controller, String url)
onPageCommitVisible;
///Event fired when the webview notifies that a loading URL has been flagged by Safe Browsing. ///Event fired when the webview notifies that a loading URL has been flagged by Safe Browsing.
///The default behavior is to show an interstitial to the user, with the reporting checkbox visible. ///The default behavior is to show an interstitial to the user, with the reporting checkbox visible.
@ -384,7 +385,8 @@ abstract class WebView {
///**Official Android API**: ///**Official Android API**:
///- https://developer.android.com/reference/android/webkit/WebViewClient#shouldInterceptRequest(android.webkit.WebView,%20android.webkit.WebResourceRequest) ///- https://developer.android.com/reference/android/webkit/WebViewClient#shouldInterceptRequest(android.webkit.WebView,%20android.webkit.WebResourceRequest)
///- https://developer.android.com/reference/android/webkit/WebViewClient#shouldInterceptRequest(android.webkit.WebView,%20java.lang.String) ///- https://developer.android.com/reference/android/webkit/WebViewClient#shouldInterceptRequest(android.webkit.WebView,%20java.lang.String)
final Future<WebResourceResponse> Function(InAppWebViewController controller, WebResourceRequest request) final Future<WebResourceResponse> Function(
InAppWebViewController controller, WebResourceRequest request)
androidShouldInterceptRequest; androidShouldInterceptRequest;
///Event called when the renderer currently associated with the WebView becomes unresponsive as a result of a long running blocking task such as the execution of JavaScript. ///Event called when the renderer currently associated with the WebView becomes unresponsive as a result of a long running blocking task such as the execution of JavaScript.
@ -405,7 +407,8 @@ abstract class WebView {
///**NOTE**: available only on Android 29+. ///**NOTE**: available only on Android 29+.
/// ///
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewRenderProcessClient#onRenderProcessUnresponsive(android.webkit.WebView,%20android.webkit.WebViewRenderProcess) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewRenderProcessClient#onRenderProcessUnresponsive(android.webkit.WebView,%20android.webkit.WebViewRenderProcess)
final Future<WebViewRenderProcessAction> Function(InAppWebViewController controller, String url) final Future<WebViewRenderProcessAction> Function(
InAppWebViewController controller, String url)
androidOnRenderProcessUnresponsive; androidOnRenderProcessUnresponsive;
///Event called once when an unresponsive renderer currently associated with the WebView becomes responsive. ///Event called once when an unresponsive renderer currently associated with the WebView becomes responsive.
@ -419,7 +422,8 @@ abstract class WebView {
///**NOTE**: available only on Android 29+. ///**NOTE**: available only on Android 29+.
/// ///
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewRenderProcessClient#onRenderProcessResponsive(android.webkit.WebView,%20android.webkit.WebViewRenderProcess) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewRenderProcessClient#onRenderProcessResponsive(android.webkit.WebView,%20android.webkit.WebViewRenderProcess)
final Future<WebViewRenderProcessAction> Function(InAppWebViewController controller, String url) final Future<WebViewRenderProcessAction> Function(
InAppWebViewController controller, String url)
androidOnRenderProcessResponsive; androidOnRenderProcessResponsive;
///Event fired when the given WebView's render process has exited. ///Event fired when the given WebView's render process has exited.
@ -431,7 +435,8 @@ abstract class WebView {
///**NOTE**: available only on Android 26+. ///**NOTE**: available only on Android 26+.
/// ///
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onRenderProcessGone(android.webkit.WebView,%20android.webkit.RenderProcessGoneDetail) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onRenderProcessGone(android.webkit.WebView,%20android.webkit.RenderProcessGoneDetail)
final Future<void> Function(InAppWebViewController controller, RenderProcessGoneDetail detail) final Future<void> Function(
InAppWebViewController controller, RenderProcessGoneDetail detail)
androidOnRenderProcessGone; androidOnRenderProcessGone;
///As the host application if the browser should resend data as the requested page was a result of a POST. The default is to not resend the data. ///As the host application if the browser should resend data as the requested page was a result of a POST. The default is to not resend the data.
@ -439,8 +444,8 @@ abstract class WebView {
///**NOTE**: available only on Android. ///**NOTE**: available only on Android.
/// ///
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onFormResubmission(android.webkit.WebView,%20android.os.Message,%20android.os.Message) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onFormResubmission(android.webkit.WebView,%20android.os.Message,%20android.os.Message)
final Future<FormResubmissionAction> Function(InAppWebViewController controller, String url) final Future<FormResubmissionAction> Function(
androidOnFormResubmission; InAppWebViewController controller, String url) androidOnFormResubmission;
///Event fired when the scale applied to the WebView has changed. ///Event fired when the scale applied to the WebView has changed.
/// ///
@ -451,7 +456,8 @@ abstract class WebView {
///**NOTE**: available only on Android. ///**NOTE**: available only on Android.
/// ///
///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onScaleChanged(android.webkit.WebView,%20float,%20float) ///**Official Android API**: https://developer.android.com/reference/android/webkit/WebViewClient#onScaleChanged(android.webkit.WebView,%20float,%20float)
final Future<void> Function(InAppWebViewController controller, double oldScale, double newScale) final Future<void> Function(
InAppWebViewController controller, double oldScale, double newScale)
androidOnScaleChanged; androidOnScaleChanged;
///Invoked when the web view's web content process is terminated. ///Invoked when the web view's web content process is terminated.
@ -488,8 +494,8 @@ abstract class WebView {
///Context menu which contains custom menu items to be shown when [ContextMenu] is presented. ///Context menu which contains custom menu items to be shown when [ContextMenu] is presented.
final ContextMenu contextMenu; final ContextMenu contextMenu;
WebView({ WebView(
this.onWebViewCreated, {this.onWebViewCreated,
this.onLoadStart, this.onLoadStart,
this.onLoadStop, this.onLoadStop,
this.onLoadError, this.onLoadError,
@ -536,6 +542,5 @@ abstract class WebView {
this.initialData, this.initialData,
this.initialHeaders, this.initialHeaders,
this.initialOptions, this.initialOptions,
this.contextMenu this.contextMenu});
});
} }

View File

@ -16,6 +16,15 @@ class WebViewOptions {
static WebViewOptions fromMap(Map<String, dynamic> map) { static WebViewOptions fromMap(Map<String, dynamic> map) {
return null; return null;
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
class BrowserOptions { class BrowserOptions {
@ -26,6 +35,15 @@ class BrowserOptions {
static BrowserOptions fromMap(Map<String, dynamic> map) { static BrowserOptions fromMap(Map<String, dynamic> map) {
return null; return null;
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
class ChromeSafariBrowserOptions { class ChromeSafariBrowserOptions {
@ -36,6 +54,15 @@ class ChromeSafariBrowserOptions {
static ChromeSafariBrowserOptions fromMap(Map<String, dynamic> map) { static ChromeSafariBrowserOptions fromMap(Map<String, dynamic> map) {
return null; return null;
} }
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the cross-platform WebView options available. ///This class represents all the cross-platform WebView options available.
@ -148,8 +175,7 @@ class InAppWebViewOptions
this.horizontalScrollBarEnabled = true, this.horizontalScrollBarEnabled = true,
this.resourceCustomSchemes = const [], this.resourceCustomSchemes = const [],
this.contentBlockers = const [], this.contentBlockers = const [],
this.preferredContentMode = this.preferredContentMode = UserPreferredContentMode.RECOMMENDED,
UserPreferredContentMode.RECOMMENDED,
this.useShouldInterceptAjaxRequest = false, this.useShouldInterceptAjaxRequest = false,
this.useShouldInterceptFetchRequest = false, this.useShouldInterceptFetchRequest = false,
this.incognito = false, this.incognito = false,
@ -229,8 +255,7 @@ class InAppWebViewOptions
List<String>.from(map["resourceCustomSchemes"] ?? []); List<String>.from(map["resourceCustomSchemes"] ?? []);
options.contentBlockers = contentBlockers; options.contentBlockers = contentBlockers;
options.preferredContentMode = options.preferredContentMode =
UserPreferredContentMode.fromValue( UserPreferredContentMode.fromValue(map["preferredContentMode"]);
map["preferredContentMode"]);
options.useShouldInterceptAjaxRequest = options.useShouldInterceptAjaxRequest =
map["useShouldInterceptAjaxRequest"]; map["useShouldInterceptAjaxRequest"];
options.useShouldInterceptFetchRequest = options.useShouldInterceptFetchRequest =
@ -243,6 +268,16 @@ class InAppWebViewOptions
options.disableContextMenu = map["disableContextMenu"]; options.disableContextMenu = map["disableContextMenu"];
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the Android-only WebView options available. ///This class represents all the Android-only WebView options available.
@ -503,7 +538,8 @@ class AndroidInAppWebViewOptions
this.overScrollMode = AndroidOverScrollMode.OVER_SCROLL_IF_CONTENT_SCROLLS, this.overScrollMode = AndroidOverScrollMode.OVER_SCROLL_IF_CONTENT_SCROLLS,
this.networkAvailable, this.networkAvailable,
this.scrollBarStyle = AndroidScrollBarStyle.SCROLLBARS_INSIDE_OVERLAY, this.scrollBarStyle = AndroidScrollBarStyle.SCROLLBARS_INSIDE_OVERLAY,
this.verticalScrollbarPosition = AndroidVerticalScrollbarPosition.SCROLLBAR_POSITION_DEFAULT, this.verticalScrollbarPosition =
AndroidVerticalScrollbarPosition.SCROLLBAR_POSITION_DEFAULT,
this.scrollBarDefaultDelayBeforeFade, this.scrollBarDefaultDelayBeforeFade,
this.scrollbarFadingEnabled = true, this.scrollbarFadingEnabled = true,
this.scrollBarFadeDuration, this.scrollBarFadeDuration,
@ -589,19 +625,16 @@ class AndroidInAppWebViewOptions
options.appCachePath = map["appCachePath"]; options.appCachePath = map["appCachePath"];
options.blockNetworkImage = map["blockNetworkImage"]; options.blockNetworkImage = map["blockNetworkImage"];
options.blockNetworkLoads = map["blockNetworkLoads"]; options.blockNetworkLoads = map["blockNetworkLoads"];
options.cacheMode = options.cacheMode = AndroidCacheMode.fromValue(map["cacheMode"]);
AndroidCacheMode.fromValue(map["cacheMode"]);
options.cursiveFontFamily = map["cursiveFontFamily"]; options.cursiveFontFamily = map["cursiveFontFamily"];
options.defaultFixedFontSize = map["defaultFixedFontSize"]; options.defaultFixedFontSize = map["defaultFixedFontSize"];
options.defaultFontSize = map["defaultFontSize"]; options.defaultFontSize = map["defaultFontSize"];
options.defaultTextEncodingName = map["defaultTextEncodingName"]; options.defaultTextEncodingName = map["defaultTextEncodingName"];
options.disabledActionModeMenuItems = options.disabledActionModeMenuItems =
AndroidActionModeMenuItem.fromValue( AndroidActionModeMenuItem.fromValue(map["disabledActionModeMenuItems"]);
map["disabledActionModeMenuItems"]);
options.fantasyFontFamily = map["fantasyFontFamily"]; options.fantasyFontFamily = map["fantasyFontFamily"];
options.fixedFontFamily = map["fixedFontFamily"]; options.fixedFontFamily = map["fixedFontFamily"];
options.forceDark = options.forceDark = AndroidForceDark.fromValue(map["forceDark"]);
AndroidForceDark.fromValue(map["forceDark"]);
options.geolocationEnabled = map["geolocationEnabled"]; options.geolocationEnabled = map["geolocationEnabled"];
options.layoutAlgorithm = options.layoutAlgorithm =
AndroidLayoutAlgorithm.fromValue(map["layoutAlgorithm"]); AndroidLayoutAlgorithm.fromValue(map["layoutAlgorithm"]);
@ -618,19 +651,36 @@ class AndroidInAppWebViewOptions
options.thirdPartyCookiesEnabled = map["thirdPartyCookiesEnabled"]; options.thirdPartyCookiesEnabled = map["thirdPartyCookiesEnabled"];
options.hardwareAcceleration = map["hardwareAcceleration"]; options.hardwareAcceleration = map["hardwareAcceleration"];
options.supportMultipleWindows = map["supportMultipleWindows"]; options.supportMultipleWindows = map["supportMultipleWindows"];
options.regexToCancelSubFramesLoading = map["regexToCancelSubFramesLoading"]; options.regexToCancelSubFramesLoading =
map["regexToCancelSubFramesLoading"];
options.useShouldInterceptRequest = map["useShouldInterceptRequest"]; options.useShouldInterceptRequest = map["useShouldInterceptRequest"];
options.useOnRenderProcessGone = map["useOnRenderProcessGone"]; options.useOnRenderProcessGone = map["useOnRenderProcessGone"];
options.overScrollMode = AndroidOverScrollMode.fromValue(map["overScrollMode"]); options.overScrollMode =
AndroidOverScrollMode.fromValue(map["overScrollMode"]);
options.networkAvailable = map["networkAvailable"]; options.networkAvailable = map["networkAvailable"];
options.scrollBarStyle = AndroidScrollBarStyle.fromValue(map["scrollBarStyle"]); options.scrollBarStyle =
options.verticalScrollbarPosition = AndroidVerticalScrollbarPosition.fromValue(map["verticalScrollbarPosition"]); AndroidScrollBarStyle.fromValue(map["scrollBarStyle"]);
options.scrollBarDefaultDelayBeforeFade = map["scrollBarDefaultDelayBeforeFade"]; options.verticalScrollbarPosition =
AndroidVerticalScrollbarPosition.fromValue(
map["verticalScrollbarPosition"]);
options.scrollBarDefaultDelayBeforeFade =
map["scrollBarDefaultDelayBeforeFade"];
options.scrollbarFadingEnabled = map["scrollbarFadingEnabled"]; options.scrollbarFadingEnabled = map["scrollbarFadingEnabled"];
options.scrollBarFadeDuration = map["scrollBarFadeDuration"]; options.scrollBarFadeDuration = map["scrollBarFadeDuration"];
options.rendererPriorityPolicy = RendererPriorityPolicy.fromMap(map["rendererPriorityPolicy"]?.cast<String, dynamic>()); options.rendererPriorityPolicy = RendererPriorityPolicy.fromMap(
map["rendererPriorityPolicy"]?.cast<String, dynamic>());
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the iOS-only WebView options available. ///This class represents all the iOS-only WebView options available.
@ -786,7 +836,8 @@ class IOSInAppWebViewOptions
"selectionGranularity": selectionGranularity.toValue(), "selectionGranularity": selectionGranularity.toValue(),
"dataDetectorTypes": dataDetectorTypesList, "dataDetectorTypes": dataDetectorTypesList,
"sharedCookiesEnabled": sharedCookiesEnabled, "sharedCookiesEnabled": sharedCookiesEnabled,
"automaticallyAdjustsScrollIndicatorInsets": automaticallyAdjustsScrollIndicatorInsets, "automaticallyAdjustsScrollIndicatorInsets":
automaticallyAdjustsScrollIndicatorInsets,
"accessibilityIgnoresInvertColors": accessibilityIgnoresInvertColors, "accessibilityIgnoresInvertColors": accessibilityIgnoresInvertColors,
"decelerationRate": decelerationRate.toValue(), "decelerationRate": decelerationRate.toValue(),
"alwaysBounceVertical": alwaysBounceVertical, "alwaysBounceVertical": alwaysBounceVertical,
@ -803,8 +854,7 @@ class IOSInAppWebViewOptions
List<String> dataDetectorTypesList = List<String> dataDetectorTypesList =
List<String>.from(map["dataDetectorTypes"] ?? []); List<String>.from(map["dataDetectorTypes"] ?? []);
dataDetectorTypesList.forEach((dataDetectorType) { dataDetectorTypesList.forEach((dataDetectorType) {
dataDetectorTypes dataDetectorTypes.add(IOSWKDataDetectorTypes.fromValue(dataDetectorType));
.add(IOSWKDataDetectorTypes.fromValue(dataDetectorType));
}); });
IOSInAppWebViewOptions options = IOSInAppWebViewOptions(); IOSInAppWebViewOptions options = IOSInAppWebViewOptions();
@ -824,13 +874,15 @@ class IOSInAppWebViewOptions
options.isFraudulentWebsiteWarningEnabled = options.isFraudulentWebsiteWarningEnabled =
map["isFraudulentWebsiteWarningEnabled"]; map["isFraudulentWebsiteWarningEnabled"];
options.selectionGranularity = options.selectionGranularity =
IOSWKSelectionGranularity.fromValue( IOSWKSelectionGranularity.fromValue(map["selectionGranularity"]);
map["selectionGranularity"]);
options.dataDetectorTypes = dataDetectorTypes; options.dataDetectorTypes = dataDetectorTypes;
options.sharedCookiesEnabled = map["sharedCookiesEnabled"]; options.sharedCookiesEnabled = map["sharedCookiesEnabled"];
options.automaticallyAdjustsScrollIndicatorInsets = map["automaticallyAdjustsScrollIndicatorInsets"]; options.automaticallyAdjustsScrollIndicatorInsets =
options.accessibilityIgnoresInvertColors = map["accessibilityIgnoresInvertColors"]; map["automaticallyAdjustsScrollIndicatorInsets"];
options.decelerationRate = IOSUIScrollViewDecelerationRate.fromValue(map["decelerationRate"]); options.accessibilityIgnoresInvertColors =
map["accessibilityIgnoresInvertColors"];
options.decelerationRate =
IOSUIScrollViewDecelerationRate.fromValue(map["decelerationRate"]);
options.alwaysBounceVertical = map["alwaysBounceVertical"]; options.alwaysBounceVertical = map["alwaysBounceVertical"];
options.alwaysBounceHorizontal = map["alwaysBounceHorizontal"]; options.alwaysBounceHorizontal = map["alwaysBounceHorizontal"];
options.scrollsToTop = map["scrollsToTop"]; options.scrollsToTop = map["scrollsToTop"];
@ -839,6 +891,16 @@ class IOSInAppWebViewOptions
options.minimumZoomScale = map["minimumZoomScale"]; options.minimumZoomScale = map["minimumZoomScale"];
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the cross-platform [InAppBrowser] options available. ///This class represents all the cross-platform [InAppBrowser] options available.
@ -881,6 +943,16 @@ class InAppBrowserOptions
options.hideUrlBar = map["hideUrlBar"]; options.hideUrlBar = map["hideUrlBar"];
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the Android-only [InAppBrowser] options available. ///This class represents all the Android-only [InAppBrowser] options available.
@ -921,6 +993,16 @@ class AndroidInAppBrowserOptions implements BrowserOptions, AndroidOptions {
options.progressBar = map["progressBar"]; options.progressBar = map["progressBar"];
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the iOS-only [InAppBrowser] options available. ///This class represents all the iOS-only [InAppBrowser] options available.
@ -987,6 +1069,16 @@ class IOSInAppBrowserOptions implements BrowserOptions, IosOptions {
options.spinner = map["spinner"]; options.spinner = map["spinner"];
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the Android-only [ChromeSafariBrowser] options available. ///This class represents all the Android-only [ChromeSafariBrowser] options available.
@ -1051,6 +1143,16 @@ class AndroidChromeCustomTabsOptions
options.keepAliveEnabled = map["keepAliveEnabled"]; options.keepAliveEnabled = map["keepAliveEnabled"];
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }
///This class represents all the iOS-only [ChromeSafariBrowser] options available. ///This class represents all the iOS-only [ChromeSafariBrowser] options available.
@ -1118,4 +1220,14 @@ class IOSSafariOptions implements ChromeSafariBrowserOptions, IosOptions {
IOSUIModalTransitionStyle.fromValue(map["transitionStyle"]); IOSUIModalTransitionStyle.fromValue(map["transitionStyle"]);
return options; return options;
} }
@override
Map<String, dynamic> toJson() {
return this.toMap();
}
@override
String toString() {
return toMap().toString();
}
} }